/*
Theme Name: B I Spatial
Theme URI: https://www.bispatial.com/
Author: B I Spatial
Author URI: https://www.bispatial.com/
Description: Custom classic theme for B I Spatial. A light survey-paper design with a traced drive-time isochrone hero plus products, capabilities, approach, and contact sections. The home page renders directly via front-page.php, with no page builder required.
Version: 1.0.35
Requires at least: 6.0
Tested up to: 6.9
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: bispatial
*/

/* ===== Self-hosted fonts (Space Grotesk + IBM Plex, SIL OFL; see /fonts) ===== */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/space-grotesk-400.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/space-grotesk-500.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/space-grotesk-600.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/space-grotesk-700.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/ibm-plex-sans-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/ibm-plex-sans-500.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Sans';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/ibm-plex-sans-600.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/ibm-plex-mono-400.woff2') format('woff2')}
@font-face{font-family:'IBM Plex Mono';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/ibm-plex-mono-500.woff2') format('woff2')}


/* ----------  LIGHT TOKENS (swap --accent to match the logo)  ---------- */
  :root{
    --bg:#F5F4F0;          /* warm-neutral paper */
    --surface:#FFFFFF;     /* cards / elevated */
    --surface-2:#FBFAF6;   /* subtle alternate */
    --line:rgba(0,0,0,.09);
    --line-strong:rgba(0,0,0,.16);

    --text:#16191F;        /* ink headings */
    --body:#434A55;        /* body copy */
    --muted:#767E8A;       /* muted labels */
    --faint:#A2A8B0;       /* faint */

    --accent:#06823F;        /* logo green (nudged a touch deeper for legible text on light) */
    --accent-bright:#0A9C4D;
    --accent-deep:#05632F;
    --accent-glow:rgba(6,130,63,.13);

    --signal-warm:#F29D20;   /* logo orange = density */
    --signal-hot:#DC4128;    /* logo red = peak density */

    --display:'Space Grotesk',system-ui,sans-serif;
    --body-face:'IBM Plex Sans',system-ui,sans-serif;
    --mono:'IBM Plex Mono',ui-monospace,monospace;

    --maxw:1180px;
    --pad:clamp(20px,5vw,40px);
    --sec:clamp(72px,11vw,140px);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;scroll-padding-top:92px;-webkit-text-size-adjust:100%}
  body{
    background:var(--bg);color:var(--body);font-family:var(--body-face);
    font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;display:flex;flex-direction:column;min-height:100vh;
  }
  body::before{ /* faint paper graticule */
    content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
    background-image:
      linear-gradient(rgba(0,0,0,.045) 1px,transparent 1px),
      linear-gradient(90deg,rgba(0,0,0,.045) 1px,transparent 1px);
    background-size:64px 64px;
    -webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 0%,transparent 75%);
            mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 0%,transparent 75%);
    opacity:.7;
  }
  a{color:inherit;text-decoration:none}
  img,svg{display:block}
  ::selection{background:var(--accent);color:#fff}
  :focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

  .wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);position:relative;z-index:1}

  .eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
    color:var(--accent);display:inline-flex;align-items:center;gap:10px}
  .eyebrow::before{content:"+";color:var(--accent);font-weight:500;opacity:.8}

  /* ----------  NAV  ---------- */
  header.nav{position:sticky;top:0;z-index:50;background:rgba(245,244,240,.82);
    -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:80px;gap:20px}
  .brand{display:flex;align-items:center}
  .brand img{height:56px;width:auto;display:block}      /* your real logo */
  .navlinks{display:flex;align-items:center;gap:34px}
  .navlinks a{font-family:var(--mono);font-size:13px;letter-spacing:.04em;color:var(--muted);transition:color .2s}
  .navlinks a:hover{color:var(--text)}
  .navlinks a.btn-solid,.navlinks a.btn-solid:hover{color:#fff}   /* match the hero button: bright white text */
  .btn{font-family:var(--mono);font-size:13px;letter-spacing:.04em;padding:10px 18px;border-radius:2px;
    transition:.2s;display:inline-flex;align-items:center;gap:8px;cursor:pointer}
  .btn-solid{background:var(--accent);color:#fff;font-weight:500;border:1px solid var(--accent)}
  .btn-solid:hover{background:var(--accent-bright);border-color:var(--accent-bright);transform:translateY(-1px)}
  .btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line-strong)}
  .btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

  /* ----------  HERO  ---------- */
  .hero{position:relative;padding-top:clamp(56px,9vw,104px);padding-bottom:var(--sec)}
  .hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,64px);align-items:center}
  .hero h1{font-family:var(--display);font-weight:500;color:var(--text);
    font-size:clamp(38px,6vw,68px);line-height:1.02;letter-spacing:-.02em;margin:22px 0 0}
  .hero h1 .em{color:var(--accent);font-style:normal}
  .hero p.lead{margin-top:26px;max-width:36ch;font-size:clamp(16px,1.5vw,18px);color:var(--body)}
  .hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
  .hero-cta .btn{padding:13px 24px;font-size:14px}

  .trust{margin-top:clamp(40px,6vw,64px);border-top:1px solid var(--line);padding-top:22px;
    display:flex;flex-wrap:wrap;gap:14px 32px}
  .trust span{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--muted);
    display:inline-flex;align-items:center;gap:9px}
  .trust span::before{content:"";width:5px;height:5px;background:var(--accent);border-radius:50%;flex:none}

  /* hero coordinate field */
  .field{position:relative;width:100%;aspect-ratio:1/1;max-width:520px;margin-inline:auto}
  .field svg{width:100%;height:100%;overflow:visible}
  .grat{stroke:var(--line);stroke-width:1}
  .cross{stroke:var(--line-strong);stroke-width:1}
  .pt-faint{fill:#C2C6CC}
  .pt{fill:var(--signal-warm)}                  /* density points = orange */
  .pt-glow{fill:var(--signal-warm);opacity:.18}
  .pt-hot{fill:var(--signal-hot)}               /* peak hotspot = red */
  .pt-hot-glow{fill:var(--signal-hot);opacity:.16}
  .ring{fill:none;stroke:var(--signal-hot);stroke-width:1}    /* concentric ping at HQ (decorative, not a drive time) */
  .iso-line{fill:none;stroke:var(--accent);stroke-width:1}    /* the 12-min drive-time isochrone = green */
  .iso-fill{fill:var(--accent);opacity:.05}
  .link{stroke:var(--accent);stroke-width:1;opacity:.25}     /* roads = green */
  .lbl{font-family:var(--mono);font-size:11px;fill:var(--muted);letter-spacing:.06em}
  .lbl-a{fill:var(--accent)}                     /* HQ label = green */
  .compass{stroke:var(--muted);stroke-width:1;fill:none}

  .reveal-pt{opacity:0;animation:popIn .6s ease forwards}
  @keyframes popIn{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
  .pulse{transform-origin:center;animation:pulse 4.5s ease-in-out infinite}
  @keyframes pulse{0%,100%{opacity:.5;transform:scale(.92)}50%{opacity:.14;transform:scale(1.08)}}

  /* ----------  SECTIONS  ---------- */
  section{position:relative;padding-block:var(--sec)}
  section + section{padding-top:0}
  .sec-head{max-width:62ch;margin-bottom:clamp(36px,5vw,56px)}
  .sec-head h2{font-family:var(--display);font-weight:500;color:var(--text);
    font-size:clamp(28px,4vw,44px);line-height:1.06;letter-spacing:-.015em;margin:16px 0 0}
  .sec-head p{margin-top:16px;font-size:clamp(15px,1.4vw,17px);color:var(--body);max-width:48ch}

  /* products */
  .cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
    border:1px solid var(--line);border-radius:3px;overflow:hidden}
  .card{background:var(--surface);padding:clamp(24px,2.4vw,34px);min-height:208px;min-width:0;
    display:flex;flex-direction:column;transition:background .25s}
  .card:hover{background:var(--surface-2)}
  .card .tag{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--faint);
    display:flex;align-items:center;justify-content:space-between}
  .card .tag .plus{color:var(--accent);opacity:.8}
  .card h3{font-family:var(--display);font-weight:500;color:var(--text);font-size:20px;
    line-height:1.15;margin:22px 0 0;letter-spacing:-.01em;overflow-wrap:break-word}
  .card h3 sup{font-size:.5em;color:var(--accent);top:-.9em;font-weight:500}
  .card p{margin-top:12px;font-size:14.5px;color:var(--muted);flex:1}
  .card.invite{background:var(--surface-2);justify-content:space-between}
  .card.invite:hover{background:#F2EFE7}
  .card.invite a{margin-top:18px;font-family:var(--mono);font-size:13px;color:var(--accent);
    display:inline-flex;align-items:center;gap:8px}
  .card.invite a .arr{transition:transform .2s}
  .card.invite a:hover .arr{transform:translateX(4px)}

  /* capabilities */
  .pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);
    border:1px solid var(--line);border-radius:3px;overflow:hidden}
  .pillar{background:var(--surface);padding:clamp(26px,2.6vw,40px)}
  .pillar .pnum{font-family:var(--mono);font-size:12px;letter-spacing:.1em;color:var(--accent)}
  .pillar h3{font-family:var(--display);font-weight:500;color:var(--text);font-size:23px;
    margin:14px 0 4px;letter-spacing:-.01em}
  .pillar .blurb{font-size:14.5px;color:var(--muted);margin-bottom:22px}
  .pillar ul{list-style:none}
  .pillar li{font-size:15px;color:var(--body);padding:11px 0;border-top:1px solid var(--line);
    display:flex;align-items:center;gap:12px}
  .pillar li::before{content:"";width:6px;height:6px;flex:none;border:1px solid var(--accent);transform:rotate(45deg)}

  /* approach */
  .values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,3vw,48px)}
  .value{border-top:2px solid var(--accent);padding-top:22px}
  .value h4{font-family:var(--display);font-weight:500;color:var(--text);font-size:19px;
    letter-spacing:-.01em;margin-bottom:10px}
  .value p{font-size:14.5px;color:var(--muted)}

  /* cta */
  .cta-band{position:relative;border:1px solid var(--line-strong);border-radius:4px;
    background:linear-gradient(135deg,#FFFFFF 0%,#FBFAF6 100%);
    padding:clamp(40px,6vw,80px);overflow:hidden;box-shadow:0 1px 0 rgba(0,0,0,.02)}
  .cta-band::after{content:"";position:absolute;right:-120px;bottom:-160px;width:420px;height:420px;
    border-radius:50%;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 62%);pointer-events:none}
  .cta-band h2{font-family:var(--display);font-weight:500;color:var(--text);position:relative;
    font-size:clamp(28px,4.4vw,48px);line-height:1.04;letter-spacing:-.02em;max-width:18ch}
  .cta-band p{position:relative;margin-top:18px;font-size:clamp(15px,1.5vw,18px);color:var(--body);max-width:44ch}
  .cta-actions{position:relative;display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
  .cta-actions .btn{padding:14px 26px;font-size:14px}

  /* footer */
  footer{border-top:1px solid var(--line);padding-block:clamp(40px,5vw,64px);background:var(--surface-2)}
  .foot-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:32px}
  .foot-brand img{height:52px;width:auto;display:block}
  .foot-brand p{margin-top:14px;font-size:14px;color:var(--muted);max-width:30ch}
  .foot-cols{display:flex;gap:clamp(40px,6vw,80px);flex-wrap:wrap}
  .foot-col h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--faint);
    text-transform:uppercase;margin-bottom:14px}
  .foot-col a,.foot-col span{display:block;font-size:14.5px;color:var(--body);padding:5px 0;transition:color .2s}
  .foot-col a:hover{color:var(--accent)}
  .foot-bottom{margin-top:clamp(36px,5vw,56px);padding-top:22px;border-top:1px solid var(--line);
    display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
    font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--faint)}

  /* responsive */
  @media(max-width:920px){
    .hero-grid{grid-template-columns:1fr}
    .field{order:-1;max-width:380px}
    .cards{grid-template-columns:repeat(2,1fr)}
  }
  @media(max-width:760px){
    .navlinks{gap:14px}
    .navlinks a:not(.btn){display:none}
    .pillars{grid-template-columns:1fr}
    .pillar-wide ul{columns:1}
    .values{grid-template-columns:1fr;gap:0}
    .value{border-top:1px solid var(--line);padding:24px 0}
    .value:first-child{border-top:2px solid var(--accent)}
  }
  @media(max-width:520px){.brand img{height:46px}
    .cards{grid-template-columns:1fr}
    .trust{gap:12px 0;flex-direction:column}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
    .reveal-pt{opacity:1}
  }

/* ============ WordPress theme additions ============ */
main{flex:1 0 auto}
body.admin-bar header.nav{top:32px}
@media screen and (max-width:782px){body.admin-bar header.nav{top:46px}}

/* content pages (page.php / index.php) */
.doc{max-width:760px}
.doc .entry-title{font-family:var(--display);font-weight:500;color:var(--text);font-size:clamp(30px,5vw,46px);line-height:1.06;letter-spacing:-.02em;margin-bottom:28px}
.doc .entry-title--list{font-size:clamp(22px,3vw,30px);margin:0 0 10px}
.doc .entry-title--list a{color:var(--text)}
.doc .entry-title--list a:hover{color:var(--accent)}
.doc .entry + .entry{margin-top:56px;padding-top:56px;border-top:1px solid var(--line)}
.doc .entry-content{color:var(--body);font-size:17px;line-height:1.7}
.doc .entry-content > * + *{margin-top:18px}
.doc .entry-content h2{font-family:var(--display);font-weight:500;color:var(--text);font-size:27px;letter-spacing:-.01em;margin-top:44px}
.doc .entry-content h3{font-family:var(--display);font-weight:500;color:var(--text);font-size:21px;margin-top:36px}
.doc .entry-content h4{font-family:var(--display);font-weight:500;color:var(--text);font-size:18px;margin-top:28px}
.doc .entry-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.doc .entry-content a:hover{color:var(--accent-deep)}
.doc .entry-content ul,.doc .entry-content ol{padding-left:22px}
.doc .entry-content li{margin-bottom:8px}
.doc .entry-content blockquote{border-left:2px solid var(--accent);padding-left:18px;color:var(--muted);font-style:italic}
.doc .entry-content img{max-width:100%;height:auto;border-radius:3px}
.doc .entry-content code{font-family:var(--mono);font-size:.9em;background:#ECECE6;padding:2px 6px;border-radius:3px}
.doc .entry-content hr{border:0;border-top:1px solid var(--line);margin:32px 0}
.doc .posts-nav{margin-top:48px;padding-top:22px;border-top:1px solid var(--line);display:flex;gap:16px;justify-content:space-between;font-family:var(--mono);font-size:13px;letter-spacing:.04em}
.doc .posts-nav a{color:var(--accent)}

/* ===== B I Spatial: responsive header ladder (v1.0.2) ===== */
/* Desktop default (tune the two heights below to taste) */
.nav-inner{height:160px}
.brand img{height:140px}
html{scroll-padding-top:172px}
.navlinks .btn{white-space:nowrap}   /* never let "Get in touch" wrap */

@media(max-width:1100px){            /* laptop */
  .nav-inner{height:118px}
  .brand img{height:92px}
  html{scroll-padding-top:130px}
}
@media(max-width:920px){             /* tablet */
  .nav-inner{height:100px}
  .brand img{height:76px}
  html{scroll-padding-top:112px}
}
@media(max-width:760px){             /* narrow tablet: links collapse to logo + button */
  .nav-inner{height:86px}
  .brand img{height:60px}
  html{scroll-padding-top:98px}
  .navlinks a.btn-solid{padding:11px 20px;font-size:14px}
}
@media(max-width:520px){             /* phone */
  .nav-inner{height:70px}
  .brand img{height:52px}
  html{scroll-padding-top:78px}
  .navlinks{gap:10px}
  .navlinks a.btn-solid{padding:8px 12px;font-size:12px}
  .a11y-trigger{width:34px;height:34px}
  .a11y-trigger svg{width:18px;height:18px}
}

/* ===== B I Spatial: tighter hero on phones ===== */
@media(max-width:520px){
  .field{max-width:220px}        /* shrink the map so the full headline shows */
  .hero{padding-top:20px}        /* less space between the header and the map */
  .hero-grid{gap:16px}           /* less space between the map and the text below */
  .hero h1{font-size:28px;line-height:1.05}   /* smaller headline so it fits without scrolling */
}

/* ===== B I Spatial: hero product-intro placeholder ===== */
.hero-intro{align-self:center;border:1px solid var(--line);border-radius:6px;background:var(--surface);padding:clamp(26px,2.6vw,38px)}
.hero-intro .intro-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.hero-intro .intro-title{font-family:var(--display);font-weight:500;font-size:clamp(24px,2.4vw,32px);line-height:1.08;letter-spacing:-.01em;margin:10px 0 0;color:var(--text)}
.hero-intro .intro-title sup{font-size:.52em;vertical-align:super;letter-spacing:0}
.hero-intro .intro-logo{margin:22px 0}
.hero-intro .intro-logo img{display:block;width:100%;height:auto}
.hero-intro .intro-tagline{font-weight:700;color:#000;font-size:15px;line-height:1.4;margin:12px 0 0}
.hero-intro .intro-stats ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.hero-intro .intro-stats li{position:relative;padding-left:18px;font-size:14.5px;line-height:1.4;color:var(--body)}
.hero-intro .intro-stats li::before{content:"";position:absolute;left:0;top:7px;width:6px;height:6px;border:1px solid var(--accent);transform:rotate(45deg)}

/* ===== B I Spatial: full-width capabilities pillar ===== */
.pillar.pillar-wide{grid-column:1 / -1}
.pillar-wide ul{columns:2;column-gap:clamp(24px,4vw,56px)}
.pillar-wide li{break-inside:avoid}

/* ===== B I Spatial: standalone section card ===== */
.solo-card{background:var(--surface);border:1px solid var(--line);border-radius:3px;padding:clamp(26px,2.6vw,40px)}
.solo-card h3{font-family:var(--display);font-weight:500;color:var(--text);font-size:23px;letter-spacing:-.01em;line-height:1.25;margin:0 0 14px}
.solo-card p{margin:0;font-size:15.5px;line-height:1.6;color:var(--body);max-width:80ch}

/* ===== B I Spatial: pull-quote section ===== */
.quote-section{border-block:1px solid var(--line);padding-block:clamp(56px,8vw,100px)}
.quote-section + section{padding-top:var(--sec)}
.pull-quote{max-width:74ch;margin:0 auto;text-align:center}
.pull-quote::before{content:"“";display:block;font-family:var(--display);font-weight:700;font-size:64px;line-height:.7;color:var(--accent);margin-bottom:6px}
.pull-quote blockquote{margin:0;font-family:var(--display);font-weight:500;font-size:clamp(24px,3.2vw,38px);line-height:1.25;letter-spacing:-.015em;color:var(--text)}
.pull-quote figcaption{margin-top:24px;font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ===== B I Spatial: vision accessibility ===== */
.a11y-trigger{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--line);border-radius:50%;background:transparent;cursor:pointer;color:var(--muted);flex:none;padding:0}
.a11y-trigger:hover,.a11y-trigger:focus-visible{color:var(--accent);border-color:var(--accent)}
.a11y-trigger svg{width:20px;height:20px}
.foot-col .a11y-link{display:block;font-size:14.5px;color:var(--body);padding:5px 0;background:none;border:0;cursor:pointer;text-align:left;font-family:inherit}
.foot-col .a11y-link:hover{color:var(--accent)}

.a11y{position:fixed;inset:0;z-index:2000;display:flex;align-items:flex-end;justify-content:flex-end;padding:18px;background:rgba(22,25,31,.3)}
.a11y[hidden]{display:none}
.a11y-panel{background:#fff;color:#16191F;border:1px solid rgba(0,0,0,.16);border-radius:12px;box-shadow:0 20px 54px rgba(0,0,0,.24);width:min(360px,100%);max-height:calc(100vh - 36px);overflow:auto;padding:20px}
.a11y-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.a11y-head h2{font-family:var(--display);font-size:18px;font-weight:600;margin:0;color:#16191F}
.a11y-close{background:none;border:0;font-size:26px;line-height:1;cursor:pointer;color:#434A55;padding:0 4px}
.a11y-intro{font-size:13px;line-height:1.45;color:#434A55;margin:0 0 14px}
.a11y-opt{display:flex;align-items:center;gap:12px;padding:11px 12px;border:1px solid rgba(0,0,0,.1);border-radius:9px;margin-bottom:8px;cursor:pointer;font-size:15px;color:#16191F}
.a11y-opt:hover{background:#F5F4F0}
.a11y-opt input{width:18px;height:18px;accent-color:#06823F;flex:none;cursor:pointer}
.a11y-reset{margin-top:6px;width:100%;padding:11px;border:1px solid rgba(0,0,0,.18);border-radius:9px;background:#F5F4F0;font-family:var(--mono);font-size:13px;letter-spacing:.04em;cursor:pointer;color:#16191F}
.a11y-reset:hover{background:#ECECE6}

html.a11y-contrast{--bg:#FFFFFF;--surface:#FFFFFF;--surface-2:#F1F1ED;--text:#000000;--body:#171C24;--muted:#2B313A;--faint:#3B414A;--line:rgba(0,0,0,.42);--line-strong:rgba(0,0,0,.6);--accent:#055C2C}
html.a11y-contrast body{background:#fff}
html.a11y-contrast a:not(.btn){text-decoration:underline;text-underline-offset:2px}
html.a11y-cb{--accent:#0B5FBF}
html.a11y-cb a:not(.btn){text-decoration:underline;text-underline-offset:2px}
html.a11y-underline a:not(.btn){text-decoration:underline;text-underline-offset:2px}
html.a11y-large header.nav,html.a11y-large main,html.a11y-large footer{zoom:1.12}

/* ===== B I Spatial: color-blind logo swap + radio group + narrow-phone nav ===== */
.logo-prot,.logo-deut{display:none !important}
html.a11y-prot .logo-default{display:none !important}
html.a11y-prot .logo-prot{display:block !important}
html.a11y-deut .logo-default{display:none !important}
html.a11y-deut .logo-deut{display:block !important}
.a11y-group{border:0;margin:0 0 8px;padding:0;min-inline-size:0}
.a11y-group legend{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#434A55;padding:0;margin:6px 0 8px}
.a11y-radio{margin-bottom:6px}
@media(max-width:400px){
  .brand img{height:44px}
  .a11y-trigger{width:32px;height:32px}
  .navlinks a.btn-solid{padding:7px 10px;font-size:11.5px}
}

/* ===== B I Spatial: quote carousel ===== */
.quote-carousel{position:relative}
.quote-carousel .pull-quote{display:none}
.quote-carousel.is-ready .pull-quote.is-active{display:block}
.quote-carousel:not(.is-ready) .pull-quote:first-child{display:block}
@media(prefers-reduced-motion:no-preference){
  .quote-carousel.is-ready .pull-quote.is-active{animation:quoteFade .5s ease}
}
@keyframes quoteFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.quote-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:30px}
.quote-nav[hidden]{display:none}
.quote-arrow{appearance:none;-webkit-appearance:none;border:1px solid var(--line-strong);background:var(--surface);color:var(--body);width:36px;height:36px;border-radius:50%;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s}
.quote-arrow:hover{border-color:var(--accent);color:var(--accent)}
.quote-arrow:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.quote-dots{display:flex;gap:9px}
.quote-dot{appearance:none;-webkit-appearance:none;border:0;padding:0;width:8px;height:8px;border-radius:50%;background:var(--line-strong);cursor:pointer;transition:background .15s,transform .15s}
.quote-dot:hover{background:var(--muted)}
.quote-dot[aria-current="true"]{background:var(--accent);transform:scale(1.25)}
.quote-dot:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.quote-play svg{width:13px;height:13px;fill:currentColor;display:block}
.quote-play .i-play{display:none}
.quote-play[data-state="paused"] .i-pause{display:none}
.quote-play[data-state="paused"] .i-play{display:block}
