/*
Theme Name: City of Glory (CGICC / CCICG)
Theme URI: https://cgicc.org
Author: CGICC
Author URI: https://cgicc.org
Description: Bilingual (English/French) theme for City of Glory International Christian Community (CGICC) / Communauté Chrétienne Internationale Cité de la Gloire. Mobile-first, accessible, modern-browser compatible. Includes a built-in EN/FR language toggle (no plugin required) and a Daily Meditation custom post type for daily audio meditations with downloadable reflection guides. Palette and logo derived from the City of Glory brand.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cgicc
Tags: nonprofit, religion, bilingual, custom-logo, custom-menu, translation-ready, responsive
*/

/* ============================================================
   The design system below powers the live site. Reference-only
   helpers from the static mockup (spec bar, page dividers) are
   omitted; everything here maps to a real template part.
   ============================================================ */


  /* ============ DESIGN TOKENS ============ */
  :root{
    /* Color — derived from the City of Glory / Cité de la Gloire logo */
    --blue:#1C49B8;        /* Royal blue (dove) — structural primary */
    --blue-700:#143A92;    /* hover / dark */
    --blue-100:#E7EDFB;    /* tint surface */
    --gold:#EB9C19;        /* Marigold amber (disc) — signature accent */
    --gold-200:#F6C658;    /* light amber */
    --red:#CC3A22;         /* Vermilion (roof & cross) — faith accent, used sparingly */
    --red-700:#A52C18;
    --ivory:#FCF7EE;       /* warm cream field */
    --charcoal:#1E1B16;    /* warm near-black (silhouettes) */
    --muted:#6A6357;       /* secondary text */
    --line:#ECE2CF;        /* warm hairline on cream */
    --white:#FFFFFF;
    --success:#2E7D5B;
    --error:#B23A48;
    --gray-100:#F4F0E8; --gray-300:#DBD5C7; --gray-500:#8A8578;

    /* Type scale */
    --display:'Playfair Display',Georgia,serif;
    --body:'Inter',system-ui,sans-serif;
    --h1:clamp(2.4rem,5vw,3.5rem);
    --h2:clamp(1.9rem,3.5vw,2.6rem);
    --h3:1.5rem; --h4:1.2rem;
    --base:1.0625rem; --small:0.9rem; --caption:0.78rem;

    /* Spacing (8px grid) */
    --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:48px; --s6:64px; --s7:96px;

    /* Radius + elevation */
    --r-sm:6px; --r-md:12px; --r-lg:20px; --r-pill:999px;
    --e1:0 1px 2px rgba(28,73,184,.06),0 1px 3px rgba(28,73,184,.08);
    --e2:0 4px 14px rgba(28,73,184,.10);
    --e3:0 14px 40px rgba(28,73,184,.16);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--body);color:var(--charcoal);background:var(--ivory);line-height:1.6;font-size:var(--base);-webkit-font-smoothing:antialiased}
  h1,h2,h3,h4{font-family:var(--display);color:var(--blue);line-height:1.15;font-weight:600}
  h1{font-size:var(--h1)} h2{font-size:var(--h2)} h3{font-size:var(--h3)} h4{font-size:var(--h4)}
  p{max-width:62ch}
  a{color:var(--blue);text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:1200px;margin:0 auto;padding:0 var(--s3)}
  .eyebrow{font-family:var(--body);font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:var(--caption);color:var(--gold)}
  :focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:4px}
  .skip{position:absolute;left:-999px;top:0;background:var(--blue);color:#fff;padding:10px 16px;z-index:200}
  .skip:focus{left:8px;top:8px}

  /* Language visibility */
  [data-lang]{display:none}
  html[data-active="en"] [data-lang="en"]{display:revert}
  html[data-active="fr"] [data-lang="fr"]{display:revert}
  /* inline spans keep flow */
  span[data-lang]{display:none}
  html[data-active="en"] span[data-lang="en"],
  html[data-active="fr"] span[data-lang="fr"]{display:inline}

  /* ============ SPEC CHROME (the gray reference bar — not part of the site) ============ */
  .spec-bar{background:var(--blue-700);color:#fff;font-size:var(--small)}
  .spec-bar .wrap{display:flex;flex-wrap:wrap;gap:var(--s2);align-items:center;justify-content:space-between;padding-top:10px;padding-bottom:10px}
  .spec-bar strong{font-weight:700}
  .spec-bar nav a{color:#cdd9ee;margin-left:var(--s2);font-size:var(--small)}
  .spec-bar nav a:hover{color:#fff}
  .spec-section-label{background:var(--gray-100);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .spec-section-label .wrap{padding:var(--s3) var(--s3);display:flex;align-items:baseline;gap:var(--s2)}
  .spec-section-label .num{font-family:var(--display);color:var(--gold);font-size:1.4rem}
  .spec-section-label h2{font-size:1.5rem}
  .spec-section-label p{color:var(--muted);font-size:var(--small);margin-left:auto;max-width:46ch;text-align:right}

  /* ============ NAV COMPONENT ============ */
  /* WP: becomes header.php — nav items from a WP menu; toggle = Polylang/WPML switcher */
  .nav{position:sticky;top:0;z-index:100;background:rgba(250,247,240,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
  .nav .wrap{display:flex;align-items:center;gap:var(--s3);padding-top:14px;padding-bottom:14px}
  .brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;color:var(--blue);font-size:1.15rem;line-height:1.1}
  .brand .mark{width:40px;height:40px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--gold-200),var(--gold) 60%,var(--blue) 61%);box-shadow:var(--e1);flex:none}
  .brand .logo{width:50px;height:50px;border-radius:50%;object-fit:cover;background:var(--white);box-shadow:var(--e1);border:1px solid var(--line);flex:none}
  .foot-logo{width:64px;height:64px;border-radius:50%;object-fit:cover;background:var(--white);margin-bottom:var(--s2)}
  .brand small{display:block;font-family:var(--body);font-weight:500;font-size:.7rem;letter-spacing:.05em;color:var(--muted)}
  .nav menu{list-style:none;display:flex;gap:var(--s3);margin-left:auto;align-items:center}
  .nav menu a{font-size:.95rem;font-weight:500;color:var(--charcoal);padding:6px 0;position:relative}
  .nav menu a:hover{color:var(--blue)}
  .nav menu a:hover::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--gold)}
  .lang-toggle{display:inline-flex;border:1px solid var(--blue);border-radius:var(--r-pill);overflow:hidden;font-size:.8rem;font-weight:600}
  .lang-toggle button{border:0;background:transparent;color:var(--blue);padding:6px 12px;cursor:pointer;font-family:var(--body);font-weight:600}
  .lang-toggle button[aria-pressed="true"]{background:var(--blue);color:#fff}
  .btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--body);font-weight:600;border-radius:var(--r-pill);padding:11px 22px;cursor:pointer;border:1.5px solid transparent;font-size:.95rem;transition:transform .15s,box-shadow .15s,background .15s}
  .btn:hover{transform:translateY(-1px)}
  .btn-primary{background:var(--gold);color:var(--blue-700);box-shadow:var(--e1)}
  .btn-primary:hover{background:var(--gold-200);box-shadow:var(--e2)}
  .btn-secondary{background:var(--blue);color:#fff}
  .btn-secondary:hover{background:var(--blue-700)}
  .btn-ghost{background:transparent;color:var(--blue);border-color:var(--blue)}
  .btn-ghost:hover{background:var(--blue-100)}
  .hamburger{display:none;background:none;border:0;cursor:pointer;font-size:1.5rem;color:var(--blue);margin-left:auto}

  /* ============ HERO ============ */
  .hero{position:relative;overflow:hidden;padding:var(--s7) 0 var(--s6)}
  .hero::before{content:"";position:absolute;top:-120px;right:-80px;width:520px;height:520px;border-radius:50%;
    background:radial-gradient(circle,rgba(235,156,25,.22),rgba(235,156,25,0) 70%);pointer-events:none}
  .hero .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:var(--s5);align-items:center}
  .hero h1{margin:var(--s2) 0}
  .hero h1 .accent{color:var(--gold)}
  .hero p.lede{font-size:1.15rem;color:var(--muted);margin-bottom:var(--s4)}
  .hero-actions{display:flex;gap:var(--s2);flex-wrap:wrap}
  .hero-visual{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--e3);aspect-ratio:4/5;
    background:linear-gradient(160deg,var(--blue) 0%,var(--blue-700) 100%)}
  .hero-visual .glass{position:absolute;inset:0;background:
     conic-gradient(from 200deg at 70% 20%, rgba(235,156,25,.35), rgba(232,238,247,.12), rgba(235,156,25,.25), rgba(232,238,247,.10), rgba(235,156,25,.35));
     mix-blend-mode:screen;opacity:.7}
  .hero-visual .cap{position:absolute;left:var(--s3);bottom:var(--s3);color:#fff;font-family:var(--display);font-size:1.3rem;text-shadow:0 2px 10px rgba(0,0,0,.4)}

  /* ============ PILLARS ============ */
  .pillars{padding:var(--s6) 0}
  .pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3);margin-top:var(--s4)}
  .pillar{background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s4);box-shadow:var(--e1)}
  .pillar .ico{width:46px;height:46px;border-radius:12px;background:var(--blue-100);display:grid;place-items:center;color:var(--blue);font-size:1.4rem;margin-bottom:var(--s2)}
  .pillar h3{font-size:1.25rem;margin-bottom:6px}
  .pillar p{font-size:var(--small);color:var(--muted)}

  /* ============ TODAY MEDITATION CARD ============ */
  /* WP: pulls latest "Meditation" custom post type entry */
  .today{padding:var(--s6) 0}
  .today-card{background:linear-gradient(160deg,var(--blue),var(--blue-700));color:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--e3);position:relative}
  .today-card::after{content:"";position:absolute;top:-60px;left:-40px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(235,156,25,.30),transparent 70%)}
  .today-grid{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:var(--s5);padding:var(--s5)}
  .today .eyebrow{color:var(--gold-200)}
  .today h2{color:#fff;margin:var(--s1) 0}
  .today .date{font-size:var(--small);color:#cdd9ee;margin-bottom:var(--s3)}
  .today .scripture{font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--gold-200);margin-bottom:var(--s3);border-left:3px solid var(--red);padding-left:var(--s2)}
  .player{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:var(--r-md);padding:var(--s3)}
  .player .row{display:flex;align-items:center;gap:var(--s2)}
  .play-btn{width:54px;height:54px;border-radius:50%;border:0;background:var(--gold);color:var(--blue-700);font-size:1.3rem;cursor:pointer;display:grid;place-items:center;flex:none;box-shadow:var(--e2)}
  .play-btn:hover{background:var(--gold-200)}
  .track{flex:1}
  .track .bar{height:6px;border-radius:var(--r-pill);background:rgba(255,255,255,.22);overflow:hidden}
  .track .bar i{display:block;height:100%;width:34%;background:var(--gold);border-radius:var(--r-pill)}
  .track .time{display:flex;justify-content:space-between;font-size:var(--caption);color:#cdd9ee;margin-top:6px}
  .today-actions{display:flex;flex-direction:column;gap:var(--s2);margin-top:var(--s3)}
  .listen-row{display:flex;gap:var(--s2);margin-top:var(--s2)}
  .chip{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;padding:8px 14px;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.3);color:#fff}
  .chip:hover{background:rgba(255,255,255,.12)}

  /* ============ ARCHIVE GRID + FILTERS ============ */
  .archive{padding:var(--s6) 0}
  .filters{display:flex;flex-wrap:wrap;gap:var(--s2);align-items:center;margin:var(--s3) 0 var(--s4)}
  .filters label{font-size:var(--small);color:var(--muted);font-weight:600}
  .filters select{font-family:var(--body);font-size:var(--small);padding:9px 14px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--white);color:var(--charcoal)}
  .arch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3)}
  .med-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s3);box-shadow:var(--e1);display:flex;flex-direction:column;gap:10px;transition:transform .15s,box-shadow .15s}
  .med-card:hover{transform:translateY(-3px);box-shadow:var(--e2)}
  .med-card .meta{display:flex;justify-content:space-between;align-items:center;font-size:var(--caption);color:var(--muted)}
  .tag{font-size:.68rem;font-weight:700;letter-spacing:.05em;padding:3px 8px;border-radius:var(--r-pill);background:var(--blue-100);color:var(--blue)}
  .tag.fr{background:#F3E9C9;color:#7a5e00}
  .med-card h4{font-size:1.05rem;color:var(--blue)}
  .med-card .card-actions{display:flex;gap:10px;margin-top:auto;padding-top:var(--s1)}
  .mini-play{width:38px;height:38px;border-radius:50%;border:0;background:var(--blue);color:#fff;cursor:pointer;display:grid;place-items:center;flex:none}
  .mini-play:hover{background:var(--blue-700)}
  .dl-link{font-size:var(--small);font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:6px;align-self:center}
  .dl-link:hover{color:var(--gold)}

  /* ============ FOOTER ============ */
  /* WP: footer.php — menus + social links from theme options */
  footer.site{background:var(--blue-700);color:#cdd9ee;margin-top:var(--s7);padding:var(--s6) 0 var(--s4)}
  footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:var(--s4)}
  footer.site h4{color:#fff;font-family:var(--body);font-size:.95rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--s2)}
  footer.site a{color:#cdd9ee;display:block;font-size:var(--small);padding:4px 0}
  footer.site a:hover{color:var(--gold-200)}
  footer.site .tag-line{font-family:var(--display);color:#fff;font-size:1.15rem;max-width:30ch;margin-bottom:var(--s2)}
  .news{display:flex;gap:8px;margin-top:var(--s2)}
  .news input{flex:1;border:0;border-radius:var(--r-pill);padding:11px 16px;font-family:var(--body);font-size:var(--small)}
  .social{display:flex;gap:10px;margin-top:var(--s3)}
  .social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.10);display:grid;place-items:center;padding:0}
  .social a:hover{background:var(--gold);color:var(--blue-700)}
  .social svg{width:18px;height:18px;fill:currentColor;color:#fff}
  .social a:hover svg{color:var(--blue-700)}
  .legal{border-top:1px solid rgba(255,255,255,.14);margin-top:var(--s5);padding-top:var(--s3);display:flex;flex-wrap:wrap;gap:var(--s2);justify-content:space-between;font-size:var(--caption);color:#9fb0cc}

  /* ============ DESIGN-SYSTEM SHOWCASE ============ */
  .ds{padding:var(--s5) 0}
  .swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--s2)}
  .sw{border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;background:#fff;box-shadow:var(--e1)}
  .sw .chip-c{height:74px}
  .sw .info{padding:10px 12px;font-size:var(--caption)}
  .sw .info b{display:block;font-size:var(--small);color:var(--charcoal)}
  .sw .info code{color:var(--muted)}
  .pairs{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--s2);margin-top:var(--s3)}
  .pair{border-radius:var(--r-md);padding:var(--s3);font-weight:600}
  .type-row{border-bottom:1px solid var(--line);padding:var(--s2) 0;display:flex;align-items:baseline;gap:var(--s3)}
  .type-row .lbl{font-size:var(--caption);color:var(--muted);width:120px;flex:none}
  .tokens{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--s2);margin-top:var(--s3)}
  .token{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s2);font-size:var(--caption);color:var(--muted)}
  .token .box{height:40px;background:var(--blue-100);border-radius:var(--r-sm);margin-bottom:8px}
  .comp-block{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s4);margin-top:var(--s3);box-shadow:var(--e1)}
  .note{font-size:var(--small);color:var(--muted);background:var(--blue-100);border-left:3px solid var(--blue);padding:10px 14px;border-radius:0 var(--r-sm) var(--r-sm) 0;margin-top:var(--s2)}
  .row-demo{display:flex;flex-wrap:wrap;gap:var(--s2);align-items:center;margin-bottom:var(--s2)}
  .field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--s2);max-width:340px}
  .field label{font-size:var(--small);font-weight:600;color:var(--charcoal)}
  .field input,.field textarea{font-family:var(--body);border:1px solid var(--gray-300);border-radius:var(--r-sm);padding:11px 14px;font-size:var(--small)}
  .breadcrumb{font-size:var(--small);color:var(--muted)}
  .breadcrumb a{color:var(--blue)}

  /* ============ FRENCH HERO NOTE BLOCK ============ */
  .frnote{background:#F3E9C9;border:1px dashed var(--gold);border-radius:var(--r-md);padding:var(--s3);margin-top:var(--s3);font-size:var(--small);color:#6b5400}

  /* ============ PAGE-DIVIDER BANDS (reference doc only) + INTERIOR PAGES ============ */
  .page-divider{background:var(--blue)}
  .page-divider .wrap{display:flex;align-items:baseline;gap:var(--s2);padding:var(--s3) var(--s3)}
  .page-divider .pg{font-family:var(--display);font-size:1.4rem;color:var(--gold-200)}
  .page-divider h2{color:#fff;font-size:1.25rem}
  .page-divider .url{margin-left:auto;font-size:var(--caption);color:#9fb0cc;font-family:var(--body)}

  .page-hero{padding:var(--s6) 0 var(--s4);position:relative;overflow:hidden}
  .page-hero::before{content:"";position:absolute;top:-100px;right:-60px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(235,156,25,.16),transparent 70%);pointer-events:none}
  .page-hero .wrap{position:relative}
  .page-hero h1{margin:var(--s2) 0;max-width:20ch}
  .page-hero p.lede{font-size:1.1rem;color:var(--muted);max-width:60ch}

  .section{padding:var(--s5) 0}
  .section.tint{background:var(--blue-100)}
  .split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5);align-items:start}
  .stack-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s4);box-shadow:var(--e1)}
  .stack-card ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:var(--s2)}
  .stack-card li{font-size:var(--small);padding-left:24px;position:relative;color:var(--muted)}
  .stack-card li::before{content:"✦";position:absolute;left:0;color:var(--gold)}

  .freq{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:var(--r-pill);background:var(--gold-200);color:#6b5400;margin-left:8px;vertical-align:middle}

  .embed{aspect-ratio:16/9;border-radius:var(--r-md);background:linear-gradient(135deg,var(--blue),var(--blue-700));display:grid;place-items:center;color:#fff;box-shadow:var(--e2);position:relative;overflow:hidden}
  .embed .glass{position:absolute;inset:0;background:conic-gradient(from 200deg at 70% 20%,rgba(235,156,25,.30),rgba(232,238,247,.10),rgba(235,156,25,.22));mix-blend-mode:screen;opacity:.6}
  .embed .play-ph{position:relative;width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--blue);display:grid;place-items:center;font-size:1.5rem}
  .embed small{position:absolute;bottom:12px;left:16px;color:#cdd9ee;font-size:var(--caption)}

  .tier{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s4);box-shadow:var(--e1);display:flex;flex-direction:column;gap:10px}
  .tier.featured{border:2px solid var(--gold);box-shadow:var(--e2);position:relative}
  .tier.featured::before{content:"✝";position:absolute;top:-14px;left:var(--s4);width:28px;height:28px;background:var(--red);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:.85rem}
  .tier h3{font-size:1.2rem}
  .tier ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:var(--small);color:var(--muted)}
  .tier li::before{content:"✓ ";color:var(--success);font-weight:700}

  .amounts{display:flex;flex-wrap:wrap;gap:10px;margin:var(--s2) 0}
  .amounts button{font-family:var(--body);font-weight:700;font-size:1.05rem;border:1.5px solid var(--blue);background:#fff;color:var(--blue);border-radius:var(--r-md);padding:14px 22px;cursor:pointer}
  .amounts button.sel,.amounts button:hover{background:var(--blue);color:#fff}
  .seg{display:inline-flex;border:1px solid var(--blue);border-radius:var(--r-pill);overflow:hidden;font-size:.85rem;font-weight:600;margin-bottom:var(--s2)}
  .seg button{border:0;background:transparent;color:var(--blue);padding:9px 18px;cursor:pointer;font-family:var(--body);font-weight:600}
  .seg button.on{background:var(--blue);color:#fff}

  .person{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
  .person:last-child{border-bottom:0}
  .person .av{width:44px;height:44px;border-radius:50%;background:var(--blue-100);color:var(--blue);display:grid;place-items:center;font-family:var(--display);font-weight:700;flex:none}
  .person .role{font-size:var(--caption);color:var(--muted)}
  .person b{font-size:var(--small)}

  .map-ph{aspect-ratio:16/7;border-radius:var(--r-md);position:relative;box-shadow:var(--e2);
    background:radial-gradient(circle at 28% 42%,rgba(235,156,25,.45),transparent 6%),
      radial-gradient(circle at 60% 56%,rgba(235,156,25,.45),transparent 6%),
      radial-gradient(circle at 80% 34%,rgba(235,156,25,.45),transparent 6%),
      linear-gradient(160deg,var(--blue),var(--blue-700))}
  .info-line{display:flex;gap:10px;align-items:flex-start;font-size:var(--small);color:var(--muted);padding:8px 0}
  .info-line .ico{color:var(--gold);font-size:1.1rem;flex:none}

  /* ============ RESPONSIVE ============ */
  @media(max-width:900px){
    .hero .wrap,.today-grid,.pillars-grid,.arch-grid,footer.site .cols,.split{grid-template-columns:1fr}
    .pillars-grid{gap:var(--s3)} .arch-grid{grid-template-columns:1fr 1fr}
    .nav menu{display:none} .hamburger{display:block}
    .spec-section-label p{display:none}
  }
  @media(max-width:560px){
    .arch-grid{grid-template-columns:1fr}
    .hero{padding:var(--s5) 0}
    footer.site .cols{gap:var(--s3)}
  }
  @media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}

/* ============ MOBILE MENU OPEN STATE (theme-only) ============ */
@media(max-width:900px){
  .nav .wrap{flex-wrap:wrap}
  .nav.menu-open menu{
    display:flex;flex-direction:column;gap:0;width:100%;order:5;
    margin:var(--s2) 0 0;border-top:1px solid var(--line)
  }
  .nav.menu-open menu li{width:100%}
  .nav.menu-open menu a{display:block;padding:14px 4px;border-bottom:1px solid var(--line);font-size:1.05rem}
  .nav.menu-open menu a:hover::after{display:none}
  .cgicc-give{margin-left:auto}
}
/* Ensure the bundled logo never overflows its round frame. */
.brand .logo,.foot-logo{display:block}
.nav menu{ flex-wrap:nowrap; }
.nav menu a{ white-space:nowrap; }
.cgicc-give{ white-space:nowrap; }
.lang-toggle{ flex:none; }
.lang-toggle button{ min-width:42px; text-align:center; white-space:nowrap; }