/* ============================================================================
   AID — "Giving out"
   Apple.com-inspired design system.
   This file is loaded LAST in layouts/main.blade.php, so it overrides the
   legacy Bootstrap/owl theme across every page without touching markup logic.
   ========================================================================== */

:root {
    --aid-blue:        #0071e3;
    --aid-blue-hover:  #0077ed;
    --aid-blue-press:  #006edb;
    --aid-ink:         #1d1d1f;   /* Apple near-black text */
    --aid-ink-soft:    #6e6e73;   /* Apple secondary grey  */
    --aid-line:        #d2d2d7;   /* hairline borders      */
    --aid-bg:          #ffffff;
    --aid-bg-alt:      #f5f5f7;   /* Apple section grey    */
    --aid-bg-dark:     #000000;
    --aid-radius:      18px;
    --aid-radius-lg:   28px;
    --aid-nav-h:       48px;
    --aid-ease:        cubic-bezier(0.28, 0.11, 0.32, 1);
    --aid-font: "SF Pro Display", "SF Pro Text", -apple-system,
                BlinkMacSystemFont, "Helvetica Neue", "DM Sans",
                Helvetica, Arial, sans-serif;
}

/* ----------------------------------------------------------------- Reset -- */
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }

body {
    font-family: var(--aid-font) !important;
    color: var(--aid-ink) !important;
    background: var(--aid-bg) !important;
    letter-spacing: -0.01em;
    line-height: 1.47;
    font-size: 17px;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--aid-font) !important;
    color: var(--aid-ink) !important;
    font-weight: 600 !important;
    letter-spacing: -0.02em !important;
    line-height: 1.07 !important;
}

a { color: var(--aid-blue); transition: color .25s var(--aid-ease), opacity .25s var(--aid-ease); }
a:hover { color: var(--aid-blue-hover); text-decoration: none; }

p { color: var(--aid-ink-soft); }

img { max-width: 100%; }

::selection { background: rgba(0,113,227,0.18); }

/* ---------------------------------------------------- Apple pill buttons -- */
.primary-btn,
.primary-btn2,
.btn,
.genric-btn,
button[type="submit"],
input[type="submit"] {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--aid-font) !important;
    font-size: 17px !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    letter-spacing: -0.01em !important;
    padding: 12px 24px !important;
    border-radius: 980px !important;   /* Apple pill */
    border: none !important;
    background: var(--aid-blue) !important;
    color: #fff !important;
    cursor: pointer;
    text-transform: none !important;
    transition: background .25s var(--aid-ease), transform .25s var(--aid-ease), opacity .25s var(--aid-ease) !important;
    box-shadow: none !important;
    min-width: auto !important;
}
.primary-btn:hover,
.primary-btn2:hover,
.btn:hover,
.genric-btn:hover,
button[type="submit"]:hover,
input[type="submit"]:hover {
    background: var(--aid-blue-hover) !important;
    color: #fff !important;
    transform: none;
}
.primary-btn:active { background: var(--aid-blue-press) !important; }

/* Secondary "Learn more" — Apple text link with chevron, not a filled btn */
.primary-btn2 {
    background: transparent !important;
    color: var(--aid-blue) !important;
    padding: 0 !important;
    border-radius: 0 !important;
    font-size: 17px !important;
}
.primary-btn2::after { content: "›"; font-size: 19px; line-height: 1; transform: translateY(-1px); }
.primary-btn2:hover { color: var(--aid-blue-hover) !important; text-decoration: underline !important; }
.primary-btn2:hover::after { text-decoration: none; }

/* Outline variant on dark imagery */
.primary-btn-log {
    background: rgba(255,255,255,0.12) !important;
    -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,0.35) !important;
}
.primary-btn-log:hover { background: rgba(255,255,255,0.22) !important; }

/* ============================================================ NAVBAR ===== */
.default-header,
header.default-header {
    position: sticky; top: 0; z-index: 9000;
    background: rgba(255,255,255,0.72) !important;
    -webkit-backdrop-filter: saturate(180%) blur(20px);
    backdrop-filter: saturate(180%) blur(20px);
    border-bottom: 1px solid rgba(0,0,0,0.08);
}
.default-header .navbar { padding: 0 !important; min-height: var(--aid-nav-h); }
.default-header .container { max-width: 1024px; }

.navbar-brand img { width: auto !important; max-height: 26px; filter: none; }

.navbar-nav { align-items: center; gap: 4px; }
@media (min-width: 992px) {
    .default-header .navbar-collapse { display: flex !important; flex-basis: auto; }
    .navbar-nav { flex-direction: row !important; }
}
.navbar-nav > li > a,
.navbar-nav li a {
    font-size: 12px !important;
    font-weight: 400 !important;
    color: var(--aid-ink) !important;
    letter-spacing: -0.01em;
    padding: 0 11px !important;
    line-height: var(--aid-nav-h);
    opacity: .88;
    transition: opacity .2s var(--aid-ease);
}
.navbar-nav li a:hover { opacity: 1; color: var(--aid-ink) !important; }

.navbar-light .navbar-toggler { border: none; color: var(--aid-ink); }
.navbar-toggler .fa-bars { color: var(--aid-ink); }

/* avatar dropdown */
.dropdown-menu {
    border: none !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 30px rgba(0,0,0,0.12) !important;
    padding: 8px !important;
    background: rgba(255,255,255,0.92) !important;
    -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);
}
.dropdown-item { border-radius: 8px !important; font-size: 14px; color: var(--aid-ink) !important; padding: 8px 12px !important; }
.dropdown-item:hover { background: var(--aid-bg-alt) !important; }

/* ============================================ HERO / BANNER (Apple style) = */
.home-banner-area {
    min-height: 92vh;
    display: flex; align-items: center;
    background-position: center !important;
    background-size: cover !important;
    text-align: center;
    color: #fff;
}
.home-banner-area .overlay-bg,
.home-banner-area .overlay {
    background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.42) 100%) !important;
}
.home-banner-area .fullscreen { min-height: 92vh; align-items: center; }
.home-banner-area .banner-content {
    margin: 0 auto !important;
    max-width: 820px;
    flex: 0 0 100% !important; max-width: 100% !important;
}
.home-banner-area h1 {
    color: #fff !important;
    font-size: clamp(40px, 7vw, 80px) !important;
    font-weight: 600 !important;
    margin-bottom: 14px;
    text-shadow: 0 1px 30px rgba(0,0,0,0.25);
}
.home-banner-area h4 {
    color: rgba(255,255,255,0.92) !important;
    font-size: clamp(19px, 2.4vw, 27px) !important;
    font-weight: 400 !important;
    letter-spacing: -0.01em !important;
    line-height: 1.4 !important;
    max-width: 680px; margin: 0 auto 32px;
}

/* ===================================================== SECTION RHYTHM ==== */
section { padding: 96px 0; }
.section-gap, .section-gap-top { padding-top: 96px !important; padding-bottom: 96px !important; }
.lite_bg, .about_area.lite_bg { background: var(--aid-bg-alt) !important; }
.container { max-width: 1024px; }

.section-title { text-align: center; margin-bottom: 56px; }
.section-title span { color: var(--aid-blue) !important; font-size: 19px; font-weight: 500; letter-spacing: -0.01em; }
.section-title h2,
h2 {
    font-size: clamp(32px, 4.5vw, 48px) !important;
    font-weight: 600 !important;
}
.section-title h2 span { color: var(--aid-ink) !important; font-size: inherit; }

/* ABOUT block */
.about_details h2 { margin-bottom: 20px; }
.about_details p { font-size: 19px; line-height: 1.55; color: var(--aid-ink-soft) !important; }
.video-play-button span { border-left-color: #fff !important; }

/* ==================================================== FEATURE CARDS ====== */
.features-area .feature_inner { gap: 0; }
.feature-item {
    background: var(--aid-bg-alt);
    border-radius: var(--aid-radius-lg);
    padding: 44px 34px;
    text-align: center;
    height: 100%;
    transition: transform .4s var(--aid-ease), box-shadow .4s var(--aid-ease);
    border: none;
}
.feature-item:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(0,0,0,0.08); }
.feature-item i {
    font-size: 34px; color: var(--aid-blue);
    width: 76px; height: 76px; line-height: 76px;
    background: #fff; border-radius: 50%;
    display: inline-block; margin-bottom: 22px;
    box-shadow: 0 6px 18px rgba(0,113,227,0.12);
}
.feature-item h4 { font-size: 23px; margin-bottom: 12px; }
.feature-item p { font-size: 15px; line-height: 1.5; margin-bottom: 18px; }
.col-lg-4.col-md-6 { margin-bottom: 24px; }

/* ============================================== CAUSE / PRODUCT CARDS ==== */
.single-popular-cause,
.card.single-popular-cause {
    border: none !important;
    border-radius: var(--aid-radius-lg) !important;
    overflow: hidden;
    background: var(--aid-bg-alt) !important;
    box-shadow: none !important;
    transition: transform .4s var(--aid-ease), box-shadow .4s var(--aid-ease);
    height: 100%;
}
.single-popular-cause:hover { transform: translateY(-6px); box-shadow: 0 22px 50px rgba(0,0,0,0.10); }
.single-popular-cause .card-body { padding: 0 !important; }
.single-popular-cause figure { margin: 0; overflow: hidden; }
.single-popular-cause figure img {
    width: 100%; aspect-ratio: 16/10; object-fit: cover;
    transition: transform .6s var(--aid-ease);
}
.single-popular-cause:hover figure img { transform: scale(1.04); }
.single-popular-cause .card_inner_body { padding: 26px 28px 30px; }
.single-popular-cause .tag {
    display: inline-block; font-size: 12px; font-weight: 500;
    color: var(--aid-blue); background: rgba(0,113,227,0.10);
    padding: 5px 12px; border-radius: 980px; margin-bottom: 14px;
}
.single-popular-cause .card-title { font-size: 21px; line-height: 1.2; margin-bottom: 20px; }
.single-popular-cause .chart {
    position: relative; width: 100%; height: 6px;
    background: var(--aid-line); border-radius: 980px; overflow: hidden;
}
.single-popular-cause .chart .bar {
    position: absolute; inset: 0; width: 60%;
    background: var(--aid-blue); border-radius: 980px;
}
.single-popular-cause .chart span {
    position: absolute; right: 0; top: -26px;
    font-size: 13px; font-weight: 600; color: var(--aid-ink);
}
.single-popular-cause .raised_goal { margin-bottom: 22px; padding-top: 8px; }
.single-popular-cause .donation .primary-btn { width: 100%; }

/* ===================================================== CALL-TO BANNER ==== */
.callto-area {
    background-position: center !important; background-size: cover !important;
    text-align: center; color: #fff;
}
.callto-area .overlay-bg { background: linear-gradient(180deg, rgba(0,0,0,0.30), rgba(0,0,0,0.55)) !important; }
.callto-area .top_text { color: var(--aid-blue) !important; font-size: 19px; font-weight: 500; }
.callto-area h1 { color: #fff !important; font-size: clamp(34px,5vw,56px) !important; margin: 8px 0 18px; }
.callto-area p { color: rgba(255,255,255,0.9) !important; font-size: 19px; }

/* ===================================================== EVENTS =========== */
.single_upcoming_event {
    background: var(--aid-bg-alt);
    border-radius: var(--aid-radius-lg);
    padding: 18px; margin-bottom: 28px;
    transition: transform .4s var(--aid-ease), box-shadow .4s var(--aid-ease);
}
.single_upcoming_event:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(0,0,0,0.08); }
.single_upcoming_event figure { position: relative; margin: 0; border-radius: var(--aid-radius); overflow: hidden; }
.single_upcoming_event figure img { aspect-ratio: 1/1; object-fit: cover; }
.single_upcoming_event .date {
    position: absolute; top: 12px; left: 12px;
    background: rgba(255,255,255,0.92); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
    color: var(--aid-ink); font-size: 13px; font-weight: 600;
    padding: 6px 12px; border-radius: 980px;
}
.single_upcoming_event .title { font-size: 19px; line-height: 1.25; margin: 4px 0 10px; }
.single_upcoming_event .title a { color: var(--aid-ink); }
.single_upcoming_event .content_wrapper p { font-size: 14px; }

/* ===================================================== GALLERY =========== */
.single-instagram { border-radius: var(--aid-radius); overflow: hidden; margin: 8px; display: block; }
.single-instagram .instagram-img img { aspect-ratio: 1/1; object-fit: cover; transition: transform .6s var(--aid-ease); }
.single-instagram:hover .instagram-img img { transform: scale(1.06); }
.instagram-text { background: rgba(0,0,0,0.35) !important; }

/* ===================================================== FOOTER ============ */
.footer, .footer-area {
    background: var(--aid-bg-alt) !important;
    color: var(--aid-ink-soft) !important;
    padding-top: 56px;
}
.footer .container { max-width: 1024px; }
.footer-area { border-top: 1px solid var(--aid-line); }
.footer .footer_title { font-size: 13px !important; font-weight: 600; color: var(--aid-ink) !important; margin-bottom: 16px; text-transform: none; }
.footer p, .footer a { font-size: 13px; color: var(--aid-ink-soft) !important; }
.footer a:hover { color: var(--aid-blue) !important; }
.footer .navbar-brand img { max-height: 30px; width: auto !important; }
.section_gap { padding: 16px 0 48px; }

/* ===================================================== FORMS ============= */
input:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
textarea, select, .single-input, .form-control {
    border: 1px solid var(--aid-line) !important;
    border-radius: 12px !important;
    padding: 13px 16px !important;
    font-family: var(--aid-font) !important;
    font-size: 16px !important;
    color: var(--aid-ink) !important;
    background: #fff !important;
    box-shadow: none !important;
    transition: border-color .2s var(--aid-ease), box-shadow .2s var(--aid-ease);
}
input:focus, textarea:focus, select:focus, .form-control:focus {
    border-color: var(--aid-blue) !important;
    box-shadow: 0 0 0 4px rgba(0,113,227,0.15) !important;
    outline: none !important;
}

/* ===================================================== ALERTS =========== */
.alert {
    border: none !important; border-radius: 14px !important;
    font-size: 15px; padding: 14px 18px !important;
}
.alert-success { background: rgba(52,199,89,0.12) !important; color: #248a3d !important; }

/* ===================================================== UTIL / MOTION ==== */
.scroll-reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s var(--aid-ease), transform .8s var(--aid-ease); }
.scroll-reveal.is-visible { opacity: 1; transform: none; }

/* Generic legacy overrides so nothing reverts to old theme colours */
.bg-primary, .btn-primary { background: var(--aid-blue) !important; border-color: var(--aid-blue) !important; }
.text-primary { color: var(--aid-blue) !important; }

/* Responsive */
@media (max-width: 991px) {
    section { padding: 64px 0; }
    .default-header .navbar { padding: 8px 0 !important; }
    .navbar-nav { gap: 0; align-items: flex-start; padding: 10px 0; }
    .navbar-nav li a { line-height: 2.4; font-size: 15px !important; }
    .home-banner-area { min-height: 80vh; }
}
@media (max-width: 575px) {
    body { font-size: 16px; }
    section { padding: 52px 0; }
    .feature-item, .single-popular-cause .card_inner_body { padding: 30px 22px; }
}
