/*
Theme Name: Fade District
Theme URI: https://fadedistrict.nl
Description: Kadence child theme for Fade District. Built by Flashcloud.
Author: Flashcloud
Template: kadence
Version: 1.0.0
*/

/* ============================================================
   1. FONTS (self-hosted variable woff2, latin subset)
   Drop the woff2 files into ./fonts/ at scaffold time.
   ============================================================ */
@font-face{font-family:"Space Grotesk";src:url("fonts/display-var.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url("fonts/body-var.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}

/* ============================================================
   2. TOKENS
   Five config colors (#1C1917/#D4A24E/#F4F0E9/#2A2622/#5F574D)
   plus derived shades via color-mix. Replace any derived value
   with a hand-picked hex when the brand kit has one.
   ============================================================ */
:root{
  --fa-primary:#1C1917;                                        /* primary section ground + heading ink */
  --fa-primary-900:color-mix(in srgb,#1C1917,#000 38%);        /* deepest ground (footer, hero base) */
  --fa-primary-700:color-mix(in srgb,#1C1917,#fff 12%);        /* mid shade */
  --fa-accent:#D4A24E;                                          /* ACTION: buttons, links, focus */
  --fa-accent-600:color-mix(in srgb,#D4A24E,#000 18%);          /* button hover */
  --fa-accent-300:color-mix(in srgb,#D4A24E,#fff 42%);          /* link on dark */
  --fa-accent-2:color-mix(in srgb,#D4A24E,#1C1917 40%);     /* second accent; replace if the brand has one */
  --fa-bg:#F4F0E9;                                                  /* page ground (painted on BODY only) */
  --fa-bg-2:color-mix(in srgb,#F4F0E9,#fff 45%);                    /* lighter alt section ground */
  --fa-ink:#2A2622;                                               /* body text on page ground */
  --fa-text-muted:#5F574D;                                       /* secondary text */
  --fa-text-ondark:color-mix(in srgb,#fff,#1C1917 8%);
  --fa-text-ondark-muted:color-mix(in srgb,#fff,#1C1917 32%);
  --fa-line:color-mix(in srgb,#5F574D,#F4F0E9 65%);               /* hairline / card border */
  --fa-line-dark:rgba(255,255,255,.16);
  --fa-card:#fff;                                                  /* card ground; flip for dark-register builds */
  --fa-font-display:"Space Grotesk",Georgia,serif;
  --fa-font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --fa-r-sm:8px;--fa-r-md:14px;--fa-r-lg:18px;--fa-r-pill:999px;
  --fa-shadow-card:0 14px 38px -18px rgba(0,0,0,.24);
  --fa-shadow-soft:0 6px 20px -10px rgba(0,0,0,.18);
  --fa-container:1180px;
}

/* ============================================================
   3. FRAME KILLERS (Kadence light-theme defaults, edge-to-edge)
   Page bg on BODY only. Never .site-container: it cascades
   into dark footer rows.
   ============================================================ */
body{background:var(--fa-bg);color:var(--fa-ink);font-family:var(--fa-font-body);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}
.site-container,.content-container,.content-area,.site-main,.entry-content,
.content-bg,body.content-style-unboxed .site{background:transparent}  /* .site: Kadence paints var(--global-palette9) on unboxed pages */
.single-page .entry-content,.page .entry-content{margin-top:0!important}
.content-area{margin:0!important}
.page .entry-hero,.entry-hero.page-hero-section{display:none!important}
.page .entry-content>*{margin-top:0;margin-bottom:0}
.wp-site-blocks>main{flex:0 0 auto!important}
.entry-content .wp-block-group,.single-page .entry-content{max-width:none}

/* ============================================================
   4. TYPOGRAPHY + PRIMITIVES
   ============================================================ */
h1,h2,h3,h4{font-family:var(--fa-font-display);font-weight:600;line-height:1.14;letter-spacing:-.01em;color:var(--fa-primary)}
a{color:var(--fa-accent)}
.fa-wrap{max-width:var(--fa-container);margin:0 auto;padding:0 40px}
.fa-section{padding:84px 0}
.fa-center{text-align:center}
.fa-eyebrow{font-family:var(--fa-font-body);font-size:12.5px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--fa-accent-2);margin:0 0 14px}
.fa-eyebrow.on-dark{color:var(--fa-accent-300)}
.fa-lede{font-size:1.22rem;line-height:1.62;color:var(--fa-text-muted);max-width:62ch}
.fa-secthead{max-width:680px;margin:0 auto 42px}
.fa-secthead h2{font-size:clamp(1.9rem,3vw,2.6rem);margin:0 0 12px}
.fa-secthead .fa-lede{margin-left:auto;margin-right:auto}

/* buttons: accent is the action colour */
.fa-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fa-font-body);font-weight:600;font-size:1rem;padding:.9rem 1.65rem;border-radius:var(--fa-r-md);text-decoration:none;border:1.5px solid transparent;transition:background .2s,color .2s,border-color .2s;cursor:pointer;line-height:1}
.fa-btn-primary{background:var(--fa-accent);color:#fff}
.fa-btn-primary:hover{background:var(--fa-accent-600);color:#fff}
.fa-btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.46)}
.fa-btn-ghost:hover{background:rgba(255,255,255,.12);color:#fff}
.fa-btn-ghost.on-light{color:var(--fa-primary);border-color:var(--fa-primary)}
.fa-btn-ghost.on-light:hover{background:var(--fa-primary);color:#fff}
/* cta_band sits on the accent gradient, so its primary action inverts to
   white for contrast (renderer emits -btn-gold there) */
.fa-btn-gold{background:#fff;color:var(--fa-primary)}
.fa-btn-gold:hover{background:var(--fa-primary-900);color:#fff}

/* ============================================================
   5. HERO (Home)
   ============================================================ */
.fa-hero{position:relative;min-height:660px;display:flex;align-items:center;background:var(--fa-primary-900);
  width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.fa-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.34}
.fa-hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(120deg,color-mix(in srgb,var(--fa-primary-900),transparent 6%) 0%,color-mix(in srgb,var(--fa-primary),transparent 22%) 46%,color-mix(in srgb,var(--fa-primary),transparent 58%) 100%)}
.fa-hero-inner{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:120px 0 96px}
.fa-hero-h{font-size:clamp(2.6rem,5vw,3.9rem);color:#fff;max-width:16ch;margin:18px 0 0;line-height:1.04}
.fa-hero-h .acc{color:var(--fa-accent-300)}
.fa-hero-lede{color:var(--fa-text-ondark);font-size:clamp(1.08rem,1.4vw,1.22rem);line-height:1.6;max-width:48ch;margin:22px 0 0}
.fa-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}
.fa-hero-fig{position:relative;aspect-ratio:4/3;border-radius:var(--fa-r-lg);overflow:hidden;box-shadow:0 30px 70px -24px rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.14)}
.fa-hero-fig img{width:100%;height:100%;object-fit:cover}

/* ============================================================
   6. PAGE HERO (interior pages, compact)
   ============================================================ */
.fa-pagehero{position:relative;overflow:hidden;background:var(--fa-primary);color:var(--fa-text-ondark);
  padding:118px 0 66px;text-align:center;
  width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.fa-pagehero::before{content:"";position:absolute;inset:0;background:var(--fa-pagehero-bg) center/cover;opacity:.16}
.fa-pagehero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,color-mix(in srgb,var(--fa-primary),transparent 45%),color-mix(in srgb,var(--fa-primary-900),transparent 15%))}
.fa-pagehero .fa-wrap{position:relative;z-index:2}
.fa-pagehero h1{font-size:clamp(2.2rem,4vw,3.2rem);color:#fff;margin:0 0 14px}
.fa-pagehero .fa-lede{margin:0 auto;color:var(--fa-text-ondark-muted)}
.fa-pagehero .fa-eyebrow{color:var(--fa-accent-300)}

/* ============================================================
   7. PROMISE BAND (stats / markers)
   ============================================================ */
.fa-promise{background:var(--fa-bg);width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);border-bottom:1px solid var(--fa-line)}
.fa-promise>.fa-wrap{max-width:var(--fa-container);margin:0 auto;padding:54px 40px}
.fa-promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.fa-pcard{background:var(--fa-card);border:1px solid var(--fa-line);border-radius:var(--fa-r-md);padding:30px 28px;box-shadow:var(--fa-shadow-soft)}
.fa-pcard-ic{width:48px;height:48px;border-radius:12px;background:color-mix(in srgb,var(--fa-accent),#fff 88%);color:var(--fa-accent);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.fa-pcard-ic svg{width:24px;height:24px}
.fa-pcard h3{font-size:1.3rem;color:var(--fa-primary);margin:0 0 8px}
.fa-pcard p{font-size:.98rem;color:var(--fa-text-muted);line-height:1.55;margin:0}

/* ============================================================
   8. FULL-BLEED SECTION GROUNDS
   100vw escape: width:100vw + margin-left:calc(50% - 50vw).
   ============================================================ */
.fa-bg2{background:var(--fa-bg-2);width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.fa-bg2>.fa-wrap{max-width:var(--fa-container);margin:0 auto;padding:0 40px}
.fa-dark{background:var(--fa-primary);color:var(--fa-text-ondark);width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.fa-dark>.fa-wrap{max-width:var(--fa-container);margin:0 auto;padding:0 40px}
.fa-dark h2,.fa-dark h3,.fa-dark h4{color:#fff}
.fa-dark p{color:var(--fa-text-ondark-muted)}

/* ============================================================
   9. CARD GRID (services / faculties / offerings)
   ============================================================ */
.fa-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.fa-card{background:var(--fa-card);border:1px solid var(--fa-line);border-radius:var(--fa-r-md);overflow:hidden;box-shadow:var(--fa-shadow-card);display:flex;flex-direction:column;text-decoration:none;transition:transform .2s,box-shadow .2s}
a.fa-card:hover{transform:translateY(-3px);box-shadow:0 22px 48px -20px rgba(0,0,0,.32)}
.fa-card-ph{aspect-ratio:16/9;position:relative;overflow:hidden;background:var(--fa-primary-700)}
.fa-card-ph img{width:100%;height:100%;object-fit:cover}
.fa-card-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.fa-card h3{font-size:1.18rem;color:var(--fa-primary);line-height:1.2;margin:0 0 8px}
.fa-card p{font-size:.95rem;color:var(--fa-text-muted);line-height:1.55;margin:0 0 16px}
.fa-card-go{margin-top:auto;font-weight:600;color:var(--fa-accent);font-size:.94rem}
/* cards that are NOT links (no detail page yet) lose the hover cursor */
span.fa-card{cursor:default}

/* ============================================================
   10. SPLIT PROSE (image + text) and long-form prose
   ============================================================ */
.fa-split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.fa-split.img-right .fa-split-fig{order:2}
.fa-split-text h2{font-size:clamp(1.7rem,2.6vw,2.4rem);margin:12px 0 16px}
.fa-split-text p{font-size:1.08rem;line-height:1.65;margin:0 0 16px}
.fa-split-text .fa-btn{margin-top:10px}
.fa-split-fig{aspect-ratio:4/3;border-radius:var(--fa-r-lg);overflow:hidden;box-shadow:var(--fa-shadow-card)}
.fa-split-fig img{width:100%;height:100%;object-fit:cover}
.fa-dark .fa-split-text p{color:var(--fa-text-ondark-muted)}
.fa-dark .fa-split-text p strong{color:#fff}

/* prose-only (legal / about long copy): single readable column */
.fa-prose{max-width:760px;margin:0 auto}
.fa-prose h2{font-size:clamp(1.5rem,2.3vw,1.95rem);margin:30px 0 14px}
.fa-prose h3{font-size:1.25rem;margin:24px 0 10px}
.fa-prose p{font-size:1.06rem;line-height:1.7;color:var(--fa-ink);margin:0 0 16px}
.fa-prose ul{margin:0 0 16px 1.2rem;line-height:1.7}
.fa-prose li{margin-bottom:8px}
.fa-prose a{color:var(--fa-accent);text-decoration:underline}
.fa-prose strong{color:var(--fa-primary)}

/* ============================================================
   11. FEATURE / PEOPLE CARDS (about, leadership, testimonials)
   ============================================================ */
.fa-features{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;max-width:840px;margin:0 auto}
.fa-features.is-single{grid-template-columns:1fr;max-width:680px}
.fa-feature{background:var(--fa-card);border:1px solid var(--fa-line);border-radius:var(--fa-r-md);padding:28px;box-shadow:var(--fa-shadow-soft)}
.fa-feature.has-photo{display:flex;gap:24px;align-items:center;padding:24px}
.fa-feature-ph{flex:none;width:128px;height:128px;border-radius:14px;overflow:hidden;background:var(--fa-primary-700)}
.fa-feature-ph img{width:100%;height:100%;object-fit:cover;object-position:top center}
.fa-feature .role{font-size:.78rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fa-accent-2)}
.fa-feature h3{font-size:1.3rem;color:var(--fa-primary);margin:8px 0 6px}
.fa-feature p{font-size:.97rem;color:var(--fa-text-muted);line-height:1.6;margin:0}
@media(max-width:560px){.fa-feature.has-photo{flex-direction:column;text-align:center}.fa-feature-ph{width:110px;height:110px}}

/* ============================================================
   12. CONTACT BLOCK
   ============================================================ */
.fa-contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:start}
.fa-contact-stack h2{font-size:1.9rem;margin:12px 0 24px}
.fa-contact-row{display:flex;gap:16px;align-items:flex-start;margin-bottom:22px}
.fa-contact-ic{width:46px;height:46px;flex:none;border-radius:12px;background:color-mix(in srgb,var(--fa-accent),#fff 88%);display:flex;align-items:center;justify-content:center}
.fa-contact-ic svg{width:22px;height:22px;color:var(--fa-accent)}
.fa-contact-row b{font-family:var(--fa-font-display);font-size:1.05rem;color:var(--fa-primary);display:block;margin-bottom:2px}
.fa-contact-row span,.fa-contact-row a{color:var(--fa-text-muted);font-size:1rem;text-decoration:none}
.fa-contact-row a:hover{color:var(--fa-accent)}
.fa-wa{display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#0b3d23;font-weight:700;padding:.85rem 1.5rem;border-radius:var(--fa-r-md);text-decoration:none;margin-top:6px}
.fa-wa:hover{background:#1ebe5a;color:#0b3d23}
.fa-wa svg{width:22px;height:22px;fill:#0b3d23}
.fa-links{margin-top:26px;border-top:1px solid var(--fa-line);padding-top:22px;display:flex;flex-direction:column;gap:12px}
.fa-links a{display:inline-flex;align-items:center;gap:8px;color:var(--fa-accent);font-weight:600;text-decoration:none}
.fa-links a:hover{color:var(--fa-accent-600)}
.fa-form-card{background:var(--fa-card);border:1px solid var(--fa-line);border-radius:var(--fa-r-lg);box-shadow:var(--fa-shadow-card);padding:34px}
.fa-form-card h3{font-size:1.5rem;margin:0 0 6px}
.fa-form-sub{color:var(--fa-text-muted);font-size:.97rem;margin:0 0 22px}
/* WPForms branded */
.fa-form-card .wpforms-field-label{font-family:var(--fa-font-body);font-weight:600;font-size:.9rem;color:var(--fa-ink)}
.fa-form-card .wpforms-field input[type=text],
.fa-form-card .wpforms-field input[type=email],
.fa-form-card .wpforms-field textarea,
.fa-form-card .wpforms-field select{border:1.5px solid var(--fa-line)!important;border-radius:10px!important;background:color-mix(in srgb,var(--fa-card),var(--fa-bg) 25%)!important;color:var(--fa-ink)!important;font-family:var(--fa-font-body)!important;padding:.8rem 1rem!important}
.fa-form-card .wpforms-field input:focus,
.fa-form-card .wpforms-field textarea:focus,
.fa-form-card .wpforms-field select:focus{border-color:var(--fa-accent)!important;outline:none!important;box-shadow:0 0 0 3px color-mix(in srgb,var(--fa-accent),transparent 84%)!important}
.fa-form-card .wpforms-submit{background:var(--fa-accent)!important;color:#fff!important;border:none!important;font-family:var(--fa-font-body)!important;font-weight:700!important;font-size:1.02rem!important;padding:.85rem 2rem!important;border-radius:var(--fa-r-md)!important;cursor:pointer;transition:background .2s}
.fa-form-card .wpforms-submit:hover{background:var(--fa-accent-600)!important;color:#fff!important}
.fa-form-card .wpforms-required-label{color:#A22916}

/* ============================================================
   13. PREFOOTER / CTA BAND (accent, the action band)
   ============================================================ */
.fa-cta{background:linear-gradient(120deg,var(--fa-accent),var(--fa-accent-600));text-align:center;padding:80px 0;
  width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.fa-cta .fa-wrap{max-width:760px;margin:0 auto;padding:0 40px}
.fa-cta h2{font-size:clamp(1.9rem,2.8vw,2.6rem);color:#fff;margin:0 0 14px}
.fa-cta .fa-lede{margin:0 auto 28px;color:color-mix(in srgb,#fff,var(--fa-accent) 12%)}
.fa-cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   14. RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .fa-hero-inner{grid-template-columns:1fr;gap:36px;padding:110px 0 72px}
  .fa-hero-fig{max-width:560px}
  .fa-cards{grid-template-columns:repeat(2,1fr)}
  .fa-promise-grid{grid-template-columns:repeat(3,1fr);gap:18px}
}
@media(max-width:782px){
  .fa-section{padding:58px 0}
  .fa-wrap,.fa-bg2>.fa-wrap,.fa-dark>.fa-wrap,.fa-cta .fa-wrap,.fa-promise>.fa-wrap{padding-left:22px;padding-right:22px}
  .fa-hero{min-height:0}
  .fa-hero-inner{padding-top:104px;padding-bottom:60px}
  .fa-hero-h{font-size:clamp(2.1rem,8vw,2.7rem)}
  .fa-cards{grid-template-columns:1fr}
  .fa-promise-grid{grid-template-columns:1fr;gap:16px}
  .fa-split{grid-template-columns:1fr;gap:28px}
  .fa-split.img-right .fa-split-fig{order:0}
  .fa-features{grid-template-columns:1fr}
  .fa-contact-grid{grid-template-columns:1fr;gap:32px}
  .fa-pagehero{padding:94px 0 50px}
  .fa-form-card{padding:24px}
}
