/* =============================================================
   DESIGN TOKENS
============================================================= */
:root {
  --pri:      #0054ad;
  --pri-d:    #003f88;
  --pri-lo:   rgba(0,84,173,.10);
  --pri-lo2:  rgba(0,84,173,.16);
  --pri-glo:  rgba(0,84,173,.30);
  --pri-bdr:  rgba(0,84,173,.28);
  --pri-bdr2: rgba(0,84,173,.50);

  --gold:     #c8a96e;
  --green:    #22c55e;
  --amber:    #f59e0b;
  --red:      #ef4444;
  --violet:   #7c3aed;

  --ease:    cubic-bezier(.16,1,.3,1);
  --spring:  cubic-bezier(.34,1.56,.64,1);
  --r:       12px;
  --r-lg:    20px;
  --r-xl:    28px;
  --nav-h:   64px;
}

:root,
html[data-theme="dark"],
html[data-theme="system"].os-dark {
  --bg:       #01091d;
  --bg2:      #031426;
  --bg3:      #061c34;
  --surf:     rgba(255,255,255,.048);
  --surf2:    rgba(255,255,255,.088);
  --bdr:      rgba(255,255,255,.075);
  --bdr-hi:   var(--pri-bdr);
  --text:     #eceff8;
  --muted:    #8492a6;
  --dim:      #32405a;
  --head:     #f2ece4;
  --nav-bg:   rgba(1,9,29,.90);
  --drw-bg:   #020e22;
  --card-bg:  #031426;
  --code-bg:  #010610;
  --sh:       0 2px 4px rgba(0,0,0,.40),0 8px 36px rgba(0,0,0,.30);
  --sh-pri:   0 8px 44px rgba(0,84,173,.45);
  --sm1: rgba(0,84,173,.12);
  --sm2: rgba(200,169,110,.07);
  --sm3: rgba(80,40,200,.06);
  --grad: linear-gradient(135deg,var(--head) 0%,var(--pri) 55%,var(--gold) 100%);
  --hero-orb1: rgba(0,84,173,.18);
  --hero-orb2: rgba(0,84,173,.10);
  --hero-orb3: rgba(200,169,110,.08);
}

html[data-theme="light"],
html[data-theme="system"].os-light {
  --bg:       #edf3fc;
  --bg2:      #F9FAFB;
  --bg3:      #e2ecf8;
  --surf:     rgba(0,0,0,.038);
  --surf2:    rgba(0,0,0,.072);
  --bdr:      rgba(0,0,0,.082);
  --bdr-hi:   var(--pri-bdr);
  --text:     #121212;
  --muted:    #556070;
  --dim:      #94a3b8;
  --head:     #121212;
  --nav-bg:   rgba(237,243,252,.92);
  --drw-bg:   #F9FAFB;
  --card-bg:  #F9FAFB;
  --code-bg:  #121212;
  --sh:       0 1px 3px rgba(0,0,0,.06),0 8px 32px rgba(0,0,0,.08);
  --sh-pri:   0 8px 44px rgba(0,84,173,.32);
  --sm1: rgba(0,84,173,.07);
  --sm2: rgba(180,140,60,.05);
  --sm3: rgba(80,40,200,.04);
  --grad: linear-gradient(135deg,#0d1629 0%,var(--pri) 55%,var(--gold) 100%);
  --hero-orb1: rgba(0,84,173,.14);
  --hero-orb2: rgba(0,84,173,.08);
  --hero-orb3: rgba(0,84,173,.05);
}

/* =============================================================
   RESET + BASE
============================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);color:var(--text);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
  padding-top:var(--nav-h);line-height:1.6;
}
@media(max-width:768px){:root{--nav-h:58px}}
h1,h2,h3,h4,h5,h6{font-family:'Poppins',sans-serif;line-height:1.1}
a{text-decoration:none;color:inherit}
button{font-family:'Inter',sans-serif;cursor:pointer;border:none;background:none}
ul{list-style:none}
:focus-visible{outline:2px solid var(--pri);outline-offset:2px;border-radius:4px}

html.t-anim *,html.t-anim *::before,html.t-anim *::after{
  transition:background-color .3s ease,border-color .3s ease,
    color .3s ease,box-shadow .3s ease !important;
}

body::after{
  content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;
  opacity:.018;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* =============================================================
   CURSOR
============================================================= */
@media(pointer:fine){
  .cur-dot,.cur-ring{
    position:fixed;pointer-events:none;z-index:10000;border-radius:50%;
    transform:translate(-50%,-50%);will-change:left,top;
  }
  .cur-dot{width:7px;height:7px;background:var(--pri);mix-blend-mode:screen}
  .cur-ring{
    width:28px;height:28px;
    border:1px solid rgba(0,84,173,.45);
    transition:width .28s var(--ease),height .28s var(--ease);
  }
  body:has(a:hover) .cur-ring,
  body:has(button:hover) .cur-ring{width:44px;height:44px;border-color:rgba(0,84,173,.75)}
}

/* =============================================================
   AMBIENT GLOWS
============================================================= */
.amb{position:fixed;pointer-events:none;z-index:0;border-radius:50%;filter:blur(110px)}
.amb1{width:700px;height:700px;top:-200px;right:-180px;
  background:radial-gradient(circle,rgba(0,84,173,.07) 0%,transparent 70%)}
.amb2{width:500px;height:500px;bottom:-100px;left:-150px;
  background:radial-gradient(circle,rgba(200,169,110,.045) 0%,transparent 70%)}

/* =============================================================
   LAYOUT
============================================================= */
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
@media(max-width:1024px){.wrap{padding:0 28px}}
@media(max-width:768px){.wrap{padding:0 20px}}

/* =============================================================
   ATOMS
============================================================= */
.pill{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'DM Mono',monospace;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--pri);background:var(--pri-lo);
  border:1px solid var(--pri-bdr);
  padding:5px 13px;border-radius:999px;
}
.pill .dot{width:5px;height:5px;border-radius:50%;background:var(--pri);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}

.gt{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 24px;border-radius:999px;
  font-size:13.5px;font-weight:600;letter-spacing:-.01em;white-space:nowrap;
  position:relative;overflow:hidden;
  transition:transform .22s var(--ease),box-shadow .22s ease,background .2s,border-color .2s;
}
.btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.13) 0%,transparent 55%);pointer-events:none}
.btn i{font-size:17px;line-height:1}
.btn-p{background:var(--pri);color:#F9FAFB}
.btn-p:hover{transform:translateY(-2px);box-shadow:var(--sh-pri)}
.btn-p:active{transform:translateY(0)}
.btn-o{background:transparent;color:var(--muted);border:1px solid var(--bdr)}
.btn-o:hover{background:var(--surf2);color:var(--text);border-color:var(--bdr-hi);transform:translateY(-2px)}
.btn-sm{padding:7px 16px;font-size:12px}
.btn-sm i{font-size:14px}

.lbl{
  font-family:'DM Mono',monospace;font-size:9px;
  text-transform:uppercase;letter-spacing:.14em;color:var(--dim);
  margin-bottom:10px;display:flex;align-items:center;gap:6px;
}
.lbl::before{content:'';width:10px;height:1px;background:linear-gradient(90deg,var(--pri),transparent);display:inline-block;}

.gt-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:600;color:var(--pri);
  transition:gap .2s var(--ease),opacity .2s;
}
.gt-link:hover{gap:10px;opacity:.8}
.gt-link i{font-size:13px}

/* Scroll reveal */
.rv{opacity:0;transform:translateY(20px);transition:opacity .68s var(--ease),transform .68s var(--ease)}
.rv.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}
.d4{transition-delay:.32s}.d5{transition-delay:.40s}

/* smoke / icon overlay */
.smoke{position:relative;overflow:hidden}
.smoke::before{
  content:'';position:absolute;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 8%  25%,var(--sm1) 0%,transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 80%,var(--sm2) 0%,transparent 55%),
    radial-gradient(ellipse 50% 60% at 50%  0%, var(--sm3) 0%,transparent 50%);
  opacity:.7;transition:opacity .4s;
}
.smoke:hover::before{opacity:1}
.io{
  position:absolute;right:-14px;bottom:-14px;
  font-size:96px;line-height:1;
  color:var(--pri);opacity:.04;pointer-events:none;z-index:0;
  transition:opacity .4s,transform .45s var(--ease);
}
.smoke:hover .io{opacity:.08;transform:scale(1.06) rotate(-4deg)}
.z{position:relative;z-index:1}

/* =============================================================
   NAVBAR
============================================================= */
nav#mainNav{
  position:fixed;inset:0 0 auto;z-index:900;
  height:var(--nav-h);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:0 40px;
  background:var(--nav-bg);
  backdrop-filter:blur(24px) saturate(1.6);
  -webkit-backdrop-filter:blur(24px) saturate(1.6);
  border-bottom:1px solid var(--bdr);
  transition:background .3s,border-color .3s;
}
@supports(padding-left:env(safe-area-inset-left)){
  nav#mainNav{
    padding-left:max(40px,calc(env(safe-area-inset-left)+20px));
    padding-right:max(40px,calc(env(safe-area-inset-right)+20px));
  }
}
@media(max-width:1024px){nav#mainNav{padding:0 24px}}
@media(max-width:768px){nav#mainNav{padding:0 16px}}

.nav-logo{
  display:flex;align-items:center;gap:9px;flex-shrink:0;
  font-family:'Poppins',sans-serif;font-size:18px;font-weight:700;
  letter-spacing:-.03em;color:var(--text);
}
.nav-wordmark{font-family:'Poppins',sans-serif;font-size:17px;font-weight:700;letter-spacing:-.03em;color:var(--text)}

.nav-links{
  display:flex;align-items:center;gap:2px;
  position:absolute;left:50%;transform:translateX(-50%);
}
.nav-links a{
  font-size:13.5px;font-weight:500;color:var(--muted);
  padding:7px 14px;border-radius:8px;
  transition:color .15s,background .15s;
}
.nav-links a:hover{color:var(--text);background:var(--surf)}
@media(max-width:1024px){.nav-links{display:none}}

.nav-r{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Help badge */
.nav-help{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:500;color:var(--muted);
  padding:6px 13px;border-radius:999px;
  background:var(--surf);border:1px solid var(--bdr);
  transition:background .2s,color .2s,border-color .2s;
}
.nav-help:hover{background:var(--surf2);color:var(--text);border-color:var(--bdr-hi)}
.nav-help i{font-size:15px}
@media(max-width:768px){.nav-help{display:none}}

/* Hamburger */
.ham{
  width:38px;height:38px;border-radius:11px;
  background:var(--surf);border:1px solid var(--bdr);
  display:none;flex-direction:column;
  align-items:center;justify-content:center;gap:6px;
  transition:background .2s,border-color .2s,box-shadow .2s;
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
  box-shadow:0 1px 3px rgba(0,0,0,.12);
}
.ham:hover{background:var(--surf2);border-color:var(--bdr-hi);box-shadow:0 2px 8px rgba(0,84,173,.18)}
.ham span{
  display:block;height:1.5px;border-radius:2px;background:var(--text);
  transition:width .36s var(--ease),transform .36s var(--ease);
}
.ham span:nth-child(1){width:20px}
.ham span:nth-child(2){width:13px}
.ham.open span:nth-child(1){width:18px;transform:translateY(4.25px) rotate(45deg)}
.ham.open span:nth-child(2){width:18px;transform:translateY(-4.25px) rotate(-45deg)}
@media(max-width:1024px){.ham{display:flex}}

/* =============================================================
   DRAWER
============================================================= */
.drw-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  opacity:0;pointer-events:none;transition:opacity .38s ease;
}
.drw-overlay.open{opacity:1;pointer-events:auto}

.drw{
  position:fixed;top:0;right:0;bottom:0;z-index:1001;
  width:320px;max-width:90vw;
  background:var(--drw-bg);border-left:1px solid var(--bdr);
  display:flex;flex-direction:column;
  transform:translateX(110%);transition:transform .44s var(--ease);overflow:hidden;
}
.drw.open{transform:translateX(0)}
.drw::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:2px;z-index:3;
  background:linear-gradient(180deg,transparent 0%,var(--pri) 35%,var(--gold) 70%,transparent 100%);opacity:.7;
}
.drw-amb{
  position:absolute;bottom:-80px;right:-80px;width:260px;height:260px;border-radius:50%;
  background:radial-gradient(circle,var(--pri-lo) 0%,transparent 70%);
  pointer-events:none;z-index:0;
}
.drw-header{
  height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;
  padding:0 22px;position:relative;z-index:2;flex-shrink:0;
  border-bottom:1px solid var(--bdr);background:var(--nav-bg);
  backdrop-filter:blur(24px) saturate(1.6);-webkit-backdrop-filter:blur(24px) saturate(1.6);
}
.drw-close{
  width:34px;height:34px;border-radius:10px;background:var(--surf);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:17px;
  transition:background .2s,color .2s,border-color .2s;touch-action:manipulation;
  box-shadow:0 1px 3px rgba(0,0,0,.1);
}
.drw-close:hover{background:rgba(239,68,68,.12);color:var(--red);border-color:rgba(239,68,68,.3)}
.drw-body{flex:1;overflow-y:auto;position:relative;z-index:1;padding:20px 0 8px;-webkit-overflow-scrolling:touch}
.drw-body::-webkit-scrollbar{width:2px}
.drw-body::-webkit-scrollbar-thumb{background:var(--bdr);border-radius:2px}
.drw-nav{padding:0 16px;display:flex;flex-direction:column;gap:2px}
.drw-nav a{
  display:flex;align-items:center;gap:14px;padding:13px 14px;border-radius:11px;
  font-size:14.5px;font-weight:500;color:var(--muted);
  transition:background .15s,color .15s;-webkit-tap-highlight-color:transparent;position:relative;
}
.drw-nav a i.ni{font-size:19px;color:var(--dim);transition:color .15s;flex-shrink:0}
.drw-nav a .nb{
  margin-left:auto;font-size:9px;font-family:'DM Mono',monospace;font-weight:700;
  letter-spacing:.06em;background:var(--pri-lo);color:var(--pri);
  border:1px solid var(--pri-bdr);padding:2px 7px;border-radius:999px;
}
.drw-nav a:hover{background:var(--surf2);color:var(--text)}
.drw-nav a:hover i.ni{color:var(--pri)}
.drw-line{height:1px;background:var(--bdr);margin:16px 28px}
.drw-foot{padding:20px 28px 24px;border-top:1px solid var(--bdr);position:relative;z-index:2;flex-shrink:0}
.drw-socials{display:flex;gap:7px;margin-bottom:16px}
.drw-theme-toggle{
  width:100%;display:flex;align-items:center;justify-content:center;gap:8px;
  margin-bottom:16px;padding:10px 12px;border-radius:10px;border:1px solid var(--bdr);
  background:var(--surf);color:var(--text);font:600 12px/1.3 'Inter',sans-serif;
}
.drw-theme-toggle:hover{border-color:var(--pri-bdr);background:var(--pri-lo);color:var(--pri)}
.dsoc{
  width:34px;height:34px;border-radius:9px;background:var(--surf);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:16px;
  transition:background .2s,color .2s,border-color .2s;
}
.dsoc:hover{background:var(--pri-lo);color:var(--pri);border-color:var(--pri-bdr)}
.drw-cta{
  display:flex;align-items:center;justify-content:center;gap:9px;
  width:100%;padding:14px 24px;border-radius:11px;
  background:var(--pri);color:#F9FAFB;font-size:14.5px;font-weight:700;letter-spacing:-.01em;
  transition:box-shadow .22s,transform .22s var(--ease);
  touch-action:manipulation;position:relative;overflow:hidden;
}
.drw-cta::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.14) 0%,transparent 60%);pointer-events:none}
.drw-cta i{font-size:18px}
.drw-cta:hover{box-shadow:var(--sh-pri);transform:translateY(-1px)}

/* =============================================================
   START PAGE HERO
============================================================= */
.start-hero{
  position:relative;
  padding:88px 0 80px;
  border-top:1px solid var(--pri-bdr);
  border-bottom:1px solid var(--pri-bdr);
  overflow:hidden;
  background:linear-gradient(160deg,
    color-mix(in srgb,var(--card-bg) 88%,var(--pri) 12%),
    color-mix(in srgb,var(--card-bg) 92%,transparent)
  );
}
/* Floating orbs */
.orb{
  position:absolute;border-radius:50%;pointer-events:none;
  background:var(--hero-orb1);
}
.orb1{width:340px;height:340px;top:-80px;left:-60px;background:var(--hero-orb2);filter:blur(2px)}
.orb2{width:200px;height:200px;top:40px;right:60px;background:var(--hero-orb1);filter:blur(1px)}
.orb3{width:100px;height:100px;top:180px;right:200px;background:var(--hero-orb2)}
.orb4{width:50px;height:50px;top:80px;right:340px;background:#1a1a1a}
.orb5{width:120px;height:120px;bottom:20px;left:120px;background:var(--hero-orb3);filter:blur(1px)}
.orb6{width:280px;height:280px;bottom:-60px;right:-40px;background:var(--hero-orb2);filter:blur(2px)}

html[data-theme="light"] .orb4,
html[data-theme="system"].os-light .orb4{background:#0d1629}

/* Grid pattern */
.start-hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,var(--bdr) 1px,transparent 1px);
  background-size:32px 32px;
  opacity:.5;
  -webkit-mask-image:radial-gradient(ellipse 75% 70% at 50% 45%,black 20%,transparent 80%);
  mask-image:radial-gradient(ellipse 75% 70% at 50% 45%,black 20%,transparent 80%);
}

.start-hero-inner{
  position:relative;z-index:2;
  max-width:640px;margin:0 auto;
  text-align:center;padding:0 40px;
}
@media(max-width:768px){.start-hero-inner{padding:0 20px}}

.start-hero h1{
  font-size:clamp(38px,5.8vw,72px);font-weight:900;letter-spacing:-.038em;
  color:var(--head);line-height:1.04;margin-top:20px;
}
.start-hero-sub{
  font-size:16px;color:var(--muted);line-height:1.78;max-width:460px;
  margin:20px auto 0;
}
.start-hero-cta{
  margin-top:36px;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
}
/* Feature badges strip */
.feat-strip{
  margin-top:40px;display:flex;align-items:center;justify-content:center;
  gap:6px;flex-wrap:wrap;
}
.feat-badge{
  display:inline-flex;align-items:center;gap:6px;
  width:fit-content;max-width:100%;
  font-size:11.5px;font-weight:500;color:var(--muted);
  background:var(--surf);border:1px solid var(--bdr);
  padding:5px 12px;border-radius:999px;
  text-transform:none;
}
.feat-badge i{font-size:13px;color:var(--pri)}

/* =============================================================
   BENTO GRID
============================================================= */
.bento{
  margin-top:clamp(20px,3vw,34px);
  padding:64px 0;
}
.bento-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:14px;
}
.bento-swiper{display:none}
@media(max-width:1060px){
  .bento-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .bento-grid{display:none}
  .bento-swiper{display:block}
}

/* Dedicated mobile bento swiper */
.bento-swiper{
  position:relative;
  margin-top:2px;
}
.bento-swiper-track{
  display:flex;
  gap:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  -ms-overflow-style:none;
  padding:2px 2px 8px;
}
.bento-swiper-track::-webkit-scrollbar{display:none}
.bento-slide{
  min-width:100%;
  scroll-snap-align:center;
  min-height:100%;
  background:var(--card-bg);
  border:1px solid var(--bdr);
  border-radius:var(--r-lg);
  padding:24px 20px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.bento-slide-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.bento-pill{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'DM Mono',monospace;font-size:9.5px;
  text-transform:none;letter-spacing:.08em;
  color:var(--muted);padding:5px 10px;
  border-radius:999px;border:1px solid var(--bdr);
  background:var(--surf);
}
.bento-pill i{font-size:12px;color:var(--pri)}
.bento-slide-ico{
  width:34px;height:34px;border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--pri);background:var(--pri-lo);border:1px solid var(--pri-bdr);
}
.bento-slide-ico.amber{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.25);color:var(--amber)}
.bento-slide-ico.green{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.25);color:var(--green)}
.bento-slide-ico.gold{background:rgba(200,169,110,.1);border-color:rgba(200,169,110,.25);color:var(--gold)}
.bento-slide h2{
  font-family:'Poppins',sans-serif;
  font-size:19px;font-weight:700;letter-spacing:-.02em;
  color:var(--head);line-height:1.2;
}
.bento-slide p{
  font-size:13.5px;color:var(--muted);line-height:1.72;
}
.bento-slide .btn,
.bento-slide .gt-link{margin-top:auto}
.bento-mini-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
}
.bento-mini-stats span{
  border:1px solid var(--bdr);background:var(--surf);
  border-radius:10px;padding:10px 11px;
  font-size:11px;color:var(--muted);line-height:1.35;
}
.bento-mini-stats strong{
  display:block;font-family:'Poppins',sans-serif;
  font-size:17px;color:var(--head);letter-spacing:-.03em;
}
.bento-links{display:flex;flex-direction:column;gap:8px}
.bento-swiper-nav{
  margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.swiper-next-preview{
  margin-top:10px;font-size:12px;color:var(--muted);
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;
}
.bento-nav-btn{
  width:40px;height:40px;flex-shrink:0;border-radius:999px;
  border:1px solid var(--bdr);background:var(--card-bg);color:var(--head);
  display:inline-flex;align-items:center;justify-content:center;
  transition:transform .22s var(--ease),border-color .22s var(--ease),box-shadow .22s var(--ease);
}
.bento-nav-btn:active{transform:scale(.96)}
.bento-nav-btn:hover{border-color:var(--bdr-hi);box-shadow:var(--sh)}
.bento-swiper-pagination{
  display:flex;align-items:center;justify-content:center;gap:7px;flex:1;
}
.bento-dot{
  width:8px;height:8px;border-radius:999px;
  background:var(--bdr-hi);border:none;padding:0;cursor:pointer;
  transition:width .22s var(--ease),background .22s var(--ease),opacity .22s var(--ease);
  opacity:.72;
}
.bento-dot.active{
  width:24px;background:var(--pri);opacity:1;
}

/* Base card */
.bc{
  background:var(--card-bg);
  border:1px solid var(--bdr);
  border-radius:var(--r-lg);
  padding:30px;
  position:relative;
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:border-color .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease);
}
.bc:hover{
  border-color:var(--bdr-hi);
  transform:translateY(-2px);
  box-shadow:var(--sh);
}
.bc:hover .io{opacity:.08;transform:scale(1.05) rotate(-3deg)}

/* span modifiers */
.bc-span2{grid-column:span 2}
@media(max-width:680px){.bc-span2{grid-column:span 1}}
.bc-span3{grid-column:span 3}
@media(max-width:1060px){.bc-span3{grid-column:span 2}}
@media(max-width:680px){.bc-span3{grid-column:span 1}}

/* Card header area */
.bc-lbl{
  font-family:'DM Mono',monospace;font-size:9px;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--dim);margin-bottom:10px;
  display:flex;align-items:center;gap:6px;position:relative;z-index:1;
}
.bc-lbl::before{content:'';width:10px;height:1px;background:linear-gradient(90deg,var(--pri),transparent);display:inline-block;flex-shrink:0}
.bc-ico{
  width:40px;height:40px;border-radius:10px;
  background:var(--pri-lo);border:1px solid var(--pri-bdr);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;color:var(--pri);margin-bottom:18px;
  flex-shrink:0;position:relative;z-index:1;
}
.bc-ico.amber{background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.25);color:var(--amber)}
.bc-ico.green{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.25);color:var(--green)}
.bc-ico.gold{background:rgba(200,169,110,.1);border-color:rgba(200,169,110,.25);color:var(--gold)}
.bc-h{
  font-family:'Poppins',sans-serif;font-size:17px;font-weight:700;
  color:var(--head);letter-spacing:-.018em;margin-bottom:8px;
  position:relative;z-index:1;line-height:1.2;
}
.bc-d{
  font-size:13px;color:var(--muted);line-height:1.72;
  position:relative;z-index:1;flex:1;
}

/* Status dot */
.sdot{
  width:7px;height:7px;border-radius:50%;
  display:inline-block;flex-shrink:0;
}
.sdot.g{background:var(--green);box-shadow:0 0 6px var(--green)}
.sdot.b{background:var(--pri);box-shadow:0 0 6px var(--pri)}
.sdot.a{background:var(--amber);box-shadow:0 0 6px var(--amber)}

/* =============================================================
   CARD 1 — Platform Access
============================================================= */
.bc-access .access-cta{
  margin-top:24px;position:relative;z-index:1;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}

/* =============================================================
   CARD 2 — Contact / We're Fast
============================================================= */
.bc-contact .contact-rows{
  margin-top:20px;position:relative;z-index:1;
  display:flex;flex-direction:column;gap:10px;
}
.contact-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 14px;border-radius:11px;
  background:var(--surf);border:1px solid var(--bdr);
  transition:border-color .2s;
}
.contact-row:hover{border-color:var(--bdr-hi)}
.contact-row-l{display:flex;align-items:center;gap:10px}
.contact-row-ico{
  width:30px;height:30px;border-radius:8px;
  background:var(--pri-lo);border:1px solid var(--pri-bdr);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;color:var(--pri);flex-shrink:0;
}
.contact-row-t{font-size:12.5px;font-weight:600;color:var(--text);font-family:'Poppins',sans-serif}
.contact-row-d{font-size:11.5px;color:var(--muted)}
.contact-cta-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 13px;border-radius:999px;
  font-size:11.5px;font-weight:600;
  background:var(--pri);color:#F9FAFB;
  transition:box-shadow .2s,transform .2s var(--ease);
  flex-shrink:0;position:relative;overflow:hidden;
}
.contact-cta-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 55%);pointer-events:none}
.contact-cta-btn:hover{box-shadow:var(--sh-pri);transform:translateY(-1px)}

/* =============================================================
   CARD 3 — Partners / The Frontier
============================================================= */
.bc-frontier .frontier-stats{
  display:flex;gap:18px;margin-top:22px;position:relative;z-index:1;
}
.frontier-stat{
  flex:1;padding:14px;border-radius:11px;
  background:var(--surf);border:1px solid var(--bdr);text-align:center;
  transition:border-color .2s;
}
.frontier-stat:hover{border-color:var(--bdr-hi)}
.fs-n{
  font-family:'Poppins',sans-serif;font-size:26px;font-weight:800;
  letter-spacing:-.04em;color:var(--head);line-height:1;
}
.fs-u{font-size:13px;font-weight:600;color:var(--pri);margin-left:2px}
.fs-l{font-size:11px;color:var(--muted);margin-top:4px}
.apply-link{
  margin-top:20px;position:relative;z-index:1;
}

/* =============================================================
   CARD 4 — Investor Relations
============================================================= */
.bc-investor .inv-metrics{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  margin-top:20px;position:relative;z-index:1;
}
.inv-m{
  padding:14px;border-radius:11px;
  background:var(--surf);border:1px solid var(--bdr);
  transition:border-color .2s;
}
.inv-m:hover{border-color:var(--bdr-hi)}
.inv-m-v{
  font-family:'Poppins',sans-serif;font-size:24px;font-weight:800;
  letter-spacing:-.04em;color:var(--head);line-height:1;
}
.inv-m-l{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.4}

/* =============================================================
   CARD 5 — Careers / Clear Ownership
============================================================= */
.bc-careers .job-list{
  margin-top:20px;position:relative;z-index:1;
  display:flex;flex-direction:column;gap:8px;
}
.job-row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:11px 13px;border-radius:10px;
  background:var(--surf);border:1px solid var(--bdr);
  transition:border-color .2s;
}
.job-row:hover{border-color:var(--bdr-hi)}
.job-t{font-family:'Poppins',sans-serif;font-size:12.5px;font-weight:600;color:var(--text)}
.job-d{font-size:11.5px;color:var(--muted);margin-top:1px}
.job-badge{
  font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.06em;
  background:var(--surf2);color:var(--muted);border:1px solid var(--bdr);
  width:fit-content;max-width:100%;
  padding:3px 8px;border-radius:999px;white-space:nowrap;flex-shrink:0;
  text-transform:none;
}
.view-link{
  display:inline-flex;align-items:center;gap:5px;
  font-size:11.5px;font-weight:600;color:var(--pri);
  padding:5px 11px;border-radius:999px;
  background:var(--pri-lo);border:1px solid var(--pri-bdr);
  transition:background .2s,box-shadow .2s;
  flex-shrink:0;
}
.view-link:hover{background:var(--pri-lo2);box-shadow:0 4px 14px var(--pri-glo)}

/* =============================================================
   CARD 6 — Energy Engine + GitHub (stacked)
============================================================= */
.bc-stack{
  display:flex;flex-direction:column;gap:14px;
}
.bc-stack .bc{
  flex:1;margin:0;
}

/* Mini linked card */
.mini-linked{
  display:flex;align-items:center;gap:12px;
  padding:14px 16px;border-radius:11px;
  background:var(--surf);border:1px solid var(--bdr);
  transition:border-color .2s,background .2s;
  position:relative;z-index:1;
  margin-top:16px;
}
.mini-linked:hover{border-color:var(--bdr-hi);background:var(--surf2)}
.mini-linked-ico{
  width:32px;height:32px;border-radius:9px;
  background:var(--pri-lo);border:1px solid var(--pri-bdr);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--pri);flex-shrink:0;
}
.mini-linked-t{font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;color:var(--text)}
.mini-linked-d{font-size:11.5px;color:var(--muted);margin-top:1px}
.mini-linked-arr{margin-left:auto;color:var(--pri);font-size:14px;flex-shrink:0}

/* =============================================================
   NEWSLETTER + BRAND ROW
============================================================= */
.nb-row{
  padding:0 0 64px;
  display:grid;grid-template-columns:1fr 1fr;gap:14px;
}
@media(max-width:860px){.nb-row{grid-template-columns:1fr}}

.nb-card{
  background:var(--card-bg);border:1px solid var(--bdr);border-radius:var(--r-lg);
  padding:32px 30px;position:relative;overflow:hidden;
  transition:border-color .25s;
}
.nb-card:hover{border-color:var(--bdr-hi)}
.nb-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'DM Mono',monospace;font-size:9px;
  text-transform:uppercase;letter-spacing:.13em;
  padding:4px 10px;border-radius:999px;
  margin-bottom:16px;
}
.nb-tag.nl{background:var(--pri-lo);color:var(--pri);border:1px solid var(--pri-bdr)}
.nb-tag.pub{background:rgba(34,197,94,.1);color:var(--green);border:1px solid rgba(34,197,94,.22)}
.nb-tag i{font-size:11px}
.nb-h{
  font-family:'Poppins',sans-serif;font-size:19px;font-weight:700;
  color:var(--head);letter-spacing:-.02em;margin-bottom:8px;
}
.nb-d{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:20px}

/* Content chips */
.content-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}
.cc2{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11.5px;font-weight:500;padding:4px 10px;border-radius:999px;
  background:var(--surf);border:1px solid var(--bdr);color:var(--muted);
}
.cc2 i{font-size:12px;color:var(--pri)}

/* LinkedIn chip */
.li-chip{
  display:inline-flex;align-items:center;gap:7px;
  font-size:12px;color:var(--muted);margin-bottom:16px;
}
.li-chip i{font-size:16px;color:#0077b5}

/* Newsletter inline pill input */
.nl-group{
  display:flex;align-items:stretch;
  background:var(--bg2);border:1px solid var(--bdr);
  border-radius:999px;overflow:hidden;
  transition:border-color .2s,box-shadow .2s;
  max-width:360px;
}
.nl-group:focus-within{border-color:var(--bdr-hi);box-shadow:0 0 0 3px var(--pri-lo)}
.nl-group input{
  flex:1;min-width:0;padding:10px 16px;
  font-size:13px;color:var(--text);font-family:'Inter',sans-serif;
  background:transparent;border:none;outline:none;
}
.nl-group input::placeholder{color:var(--dim)}
.nl-group button{
  flex-shrink:0;display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;background:var(--pri);color:#F9FAFB;
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:600;
  border:none;cursor:pointer;white-space:nowrap;
  border-radius:0 999px 999px 0;
  transition:background .2s;position:relative;overflow:hidden;
}
.nl-group button::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 55%);pointer-events:none}
.nl-group button:hover{background:var(--pri-d)}

/* Brand assets grid */
.brand-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
  margin-bottom:20px;
}
@media(max-width:520px){.brand-grid{grid-template-columns:repeat(2,1fr)}}
.brand-asset{
  display:flex;flex-direction:column;align-items:center;gap:7px;
  padding:14px 10px;border-radius:11px;
  background:var(--surf);border:1px solid var(--bdr);
  text-align:center;cursor:pointer;
  transition:border-color .2s,background .2s;
}
.brand-asset:hover{border-color:var(--bdr-hi);background:var(--surf2)}
.brand-asset i{font-size:22px;color:var(--pri)}
.brand-asset-t{font-family:'Poppins',sans-serif;font-size:12px;font-weight:600;color:var(--text)}
.brand-asset-d{font-size:10.5px;color:var(--muted)}

/* =============================================================
   GOVERNANCE CTA SECTION
============================================================= */
.gov-cta{padding:0 0 80px}
.gov-cta-inner{
  border:1px solid var(--bdr);border-radius:var(--r-xl);
  background:var(--bg2);
  overflow:hidden;position:relative;
}
.gov-cta-inner::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--pri-glo),rgba(200,169,110,.3),transparent);
}

.gov-cta-grid{
  display:grid;grid-template-columns:5fr 4fr;
  align-items:stretch;
}
@media(max-width:900px){.gov-cta-grid{grid-template-columns:1fr}}

.gov-cta-l{
  padding:56px 52px;
  position:relative;overflow:hidden;
  border-right:1px solid var(--bdr);
}
@media(max-width:900px){.gov-cta-l{border-right:none;border-bottom:1px solid var(--bdr);padding:40px 32px}}
@media(max-width:480px){.gov-cta-l{padding:32px 24px}}

.gov-cta-l::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at -10% 50%,var(--pri-glo) 0%,transparent 65%);
  opacity:.45;
}

/* Big heading with inline accent */
.gov-cta-h{
  font-family:'Poppins',sans-serif;
  font-size:clamp(26px,3.2vw,40px);
  font-weight:900;letter-spacing:-.036em;
  color:var(--head);line-height:1.08;
  margin-bottom:14px;
  position:relative;z-index:1;
}
.gov-cta-h em{font-style:normal;color:var(--pri)}

.gov-cta-d{
  font-size:14px;color:var(--muted);line-height:1.78;
  max-width:400px;margin-bottom:30px;
  position:relative;z-index:1;
}
.gov-cta-btns{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  position:relative;z-index:1;
}

.gov-cta-r{
  padding:40px 36px;
  display:flex;flex-direction:column;justify-content:center;gap:14px;
}
@media(max-width:900px){.gov-cta-r{padding:32px}}

.gov-feat{
  display:flex;align-items:flex-start;gap:14px;
  padding:16px;border-radius:var(--r);
  background:var(--surf);border:1px solid var(--bdr);
  transition:border-color .25s,transform .25s var(--ease);
}
.gov-feat:hover{border-color:var(--bdr-hi);transform:translateX(4px)}
.gov-feat-ico{
  width:34px;height:34px;border-radius:9px;
  background:var(--pri-lo);border:1px solid var(--pri-bdr);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;color:var(--pri);flex-shrink:0;
}
.gov-feat-t{font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;color:var(--text);margin-bottom:3px}
.gov-feat-d{font-size:12px;color:var(--muted);line-height:1.55}

/* =============================================================
   FOOTER
============================================================= */
footer{background:var(--bg2);border-top:1px solid var(--bdr)}
footer::before{
  content:'';display:block;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--pri-glo) 30%,rgba(200,169,110,.35) 68%,transparent 100%);
}
.ft-main{
  padding:56px 0 0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
}
@media(max-width:900px){.ft-main{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.ft-main{grid-template-columns:1fr;padding:36px 0 0}}

.ft-col-h{
  display:flex;align-items:center;gap:7px;
  font-family:'DM Mono',monospace;font-size:9px;
  text-transform:uppercase;letter-spacing:.15em;color:var(--dim);margin-bottom:20px;
}
.ft-col-h::before{
  content:'';width:12px;height:1px;
  background:linear-gradient(90deg,var(--pri),transparent);display:inline-block;flex-shrink:0;
}
.ft-links{display:flex;flex-direction:column;gap:12px}
.ft-links a{
  display:flex;align-items:center;gap:6px;
  font-size:13.5px;color:var(--muted);transition:color .15s;
}
.ft-links a i{font-size:12px;opacity:0;color:var(--pri);transition:opacity .15s}
.ft-links a:hover{color:var(--text)}
.ft-links a:hover i{opacity:1}

.ft-nl-bare{
  padding:28px 0;border-top:1px solid var(--bdr);margin-top:40px;
  display:flex;justify-content:center;
}
@media(max-width:640px){.ft-nl-bare{justify-content:stretch}}
.ft-nl-bare .nl-group{max-width:420px;width:100%}

.ft-btm{
  padding:18px 0;border-top:1px solid var(--bdr);margin-top:40px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
@media(max-width:900px){.ft-btm{flex-direction:column;align-items:flex-start;gap:14px}}
.ft-copy{font-size:12px;color:var(--dim)}
.ft-socs{display:flex;gap:7px}
.fsoc{
  width:32px;height:32px;border-radius:8px;
  background:var(--surf);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:15px;
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.fsoc:hover{background:var(--pri-lo);color:var(--pri);border-color:var(--pri-bdr);transform:translateY(-2px)}
.ft-legal{display:flex;gap:18px;flex-wrap:wrap}
.ft-legal a{font-size:12px;color:var(--dim);transition:color .15s}
.ft-legal a:hover{color:var(--muted)}

/* Theme switcher */
.theme-sw{position:relative;display:inline-flex}
.tsw-btn{
  display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:9px;
  background:var(--surf);border:1px solid var(--bdr);
  font-size:12.5px;font-weight:500;color:var(--muted);
  transition:background .2s,border-color .2s,color .2s;cursor:pointer;
}
.tsw-btn:hover{background:var(--surf2);border-color:var(--bdr-hi);color:var(--text)}
.tsw-btn i{font-size:16px}
.tsw-btn .caret{font-size:12px;margin-left:2px;transition:transform .25s var(--ease)}
.theme-sw.open .tsw-btn .caret{transform:rotate(180deg)}
.tsw-panel{
  position:absolute;bottom:calc(100% + 8px);left:0;min-width:160px;
  background:var(--drw-bg);border:1px solid var(--bdr);border-radius:12px;
  padding:6px;
  box-shadow:0 -8px 32px rgba(0,0,0,.28),0 2px 8px rgba(0,0,0,.15);
  opacity:0;pointer-events:none;transform:translateY(8px);
  transition:opacity .22s var(--ease),transform .22s var(--ease);z-index:200;
}
.theme-sw.open .tsw-panel{opacity:1;pointer-events:auto;transform:translateY(0)}
.tsw-opt{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;
  font-size:13px;font-weight:500;color:var(--muted);cursor:pointer;transition:background .15s,color .15s;
}
.tsw-opt:hover{background:var(--surf2);color:var(--text)}
.tsw-opt.active{background:var(--pri-lo);color:var(--pri)}
.tsw-opt.active i{color:var(--pri)}
.tsw-opt i{font-size:16px;color:var(--dim);transition:color .15s;flex-shrink:0;width:18px;text-align:center}

/* Status chip */
.ft-status-chip{
  display:inline-flex;align-items:center;gap:7px;
  font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);white-space:nowrap;
}
.ndot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 7px var(--green);animation:blink 2s infinite}

/* Footer badges */
.ft-badges{
  display:flex;align-items:stretch;gap:16px;
  padding:20px 40px;border-top:1px solid var(--bdr);flex-wrap:wrap;
}
@media(max-width:768px){.ft-badges{padding:20px}}

.ftb-compatible{
  display:inline-flex;align-items:stretch;
  border:1px solid var(--bdr);border-radius:12px;padding:0;
  overflow:hidden;background:var(--surf);
  transition:border-color .22s,background .22s;
}
.ftb-compatible:hover{border-color:var(--pri-bdr);background:var(--pri-lo)}
.ftb-compatible-inner{display:flex;align-items:center;gap:12px;padding:12px 20px 12px 16px;width:100%}
.ftb-brand{font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;color:var(--head);letter-spacing:-.02em;line-height:1}
.ftb-mark{font-family:'DM Mono',monospace;font-size:9.5px;letter-spacing:.06em;color:var(--pri);text-transform:uppercase}

.ftb-eem{
  display:inline-flex;align-items:center;justify-content:center;
  aspect-ratio:1;background:#121212;border-radius:14px;
  border:1px solid rgba(255,255,255,.10);overflow:hidden;
  transition:transform .22s var(--ease),box-shadow .22s;flex-shrink:0;min-width:64px;
}
.ftb-eem:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.4)}
.ftb-eem img{width:40px;height:40px;object-fit:contain;display:block}

.ft-notice{
  background:var(--bg3);border-top:1px solid var(--bdr);
  padding:13px 40px;text-align:justify;font-size:11px;color:var(--dim);line-height:1.7;
}
@media(max-width:768px){.ft-notice{padding:13px 20px}}
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .ft-notice{padding-bottom:max(13px,calc(env(safe-area-inset-bottom)+9px))}
}

/* =============================================================
   ACCESSIBILITY
============================================================= */
.skip-link{
  position:fixed;top:-100%;left:50%;transform:translateX(-50%);
  z-index:99999;padding:12px 28px;border-radius:0 0 12px 12px;
  background:var(--pri);color:#F9FAFB;
  font-family:'Poppins',sans-serif;font-size:14px;font-weight:700;
  text-decoration:none;white-space:nowrap;transition:top .18s ease;outline:none;
  box-shadow:0 4px 20px rgba(0,84,173,.5);
}
.skip-link:focus{top:0}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
:focus-visible{outline:2px solid var(--pri);outline-offset:3px;border-radius:4px}
.btn:focus-visible,.fsoc:focus-visible,.dsoc:focus-visible,.drw-cta:focus-visible,.tsw-btn:focus-visible{
  outline:2px solid var(--pri);outline-offset:3px;box-shadow:0 0 0 5px var(--pri-lo);
}
.ham:focus-visible{outline:2px solid var(--pri);outline-offset:3px}
.drw-nav a:focus-visible{outline:2px solid var(--pri);outline-offset:0;background:var(--surf2)}
body:not(.using-mouse) :focus{outline:2px solid var(--pri);outline-offset:3px}
body.using-mouse :focus:not(:focus-visible){outline:none}
#a11y-announce{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
  .rv{opacity:1 !important;transform:none !important}
  .rv.in{opacity:1;transform:none}
  .cur-dot,.cur-ring{display:none !important}
  .amb{display:none !important}
}

@media(prefers-contrast:more){
  :root,html[data-theme="dark"],html[data-theme="system"].os-dark{
    --bdr:rgba(255,255,255,.22);--bdr-hi:rgba(0,84,173,.7);--muted:#b0bdd4;--dim:#6b7a96;
  }
  html[data-theme="light"],html[data-theme="system"].os-light{
    --bdr:rgba(0,0,0,.22);--bdr-hi:rgba(0,84,173,.7);--muted:#3a4560;--dim:#6b7a96;
  }
}

@media(max-width:768px){
  .btn{min-height:46px}
  .ham,.tsw-btn{min-height:44px}
  .drw-nav a{min-height:48px}
}
