/* ===== Astral360 — site styles ===== */
:root{
  --ink:#231f20;
  --orange:#ed6719;
  --orange-d:#c9530f;
  --surface:#faf9f7;
  --surface2:#f7f6f4;
  --tint:#fcf0e7;
  --tint-bd:#f6dcc8;
  --border:#e7e4e0;
  --hair:#eceae6;
  --muted:#6b6764;
  --muted2:#8a857f;
  --muted3:#a8a39d;
  --text2:#55514d;
  --max:1200px;
}
*{box-sizing:border-box;}
html,body{margin:0;}
body{
  font-family:'IBM Plex Sans',system-ui,sans-serif;
  color:var(--ink);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
a{text-decoration:none;color:inherit;}
::selection{background:#fcd9c2;}
img{max-width:100%;display:block;}
h1,h2,h3{margin:0;}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px;}
.mono{font-family:'IBM Plex Mono',monospace;}

/* brand logo */
.brand{display:inline-flex;align-items:center;flex:none;}
.brand img{display:block;width:auto;height:26px;}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 24px;border-radius:6px;font-size:15px;font-weight:600;
  border:1px solid transparent;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,color .15s;}
.btn-sm{padding:9px 16px;font-size:14px;}
.btn-primary{background:var(--orange);color:#fff;}
.btn-primary:hover{background:var(--orange-d);}
.btn-secondary{background:#fff;color:var(--ink);border-color:#d6d2cc;}
.btn-secondary:hover{border-color:var(--ink);}
.btn-onorange{background:#fff;color:var(--orange-d);font-weight:700;}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7);}
.btn-ghost:hover{background:rgba(255,255,255,.12);}

/* tag / eyebrow */
.eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--orange);}
.pill{display:inline-flex;align-items:center;gap:8px;font-family:'IBM Plex Mono',monospace;font-size:12px;
  letter-spacing:.04em;color:var(--orange-d);background:var(--tint);border:1px solid var(--tint-bd);padding:6px 12px;border-radius:999px;}
.pill .dot{width:6px;height:6px;border-radius:999px;background:var(--orange);}
.tagcat{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.04em;color:var(--orange-d);}

/* link arrow */
.link{color:var(--orange);font-weight:600;font-size:14px;}
.link:hover{color:var(--orange-d);}

/* ===== header ===== */
.site-header{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.88);
  backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--hair);}
.nav{height:66px;display:flex;align-items:center;gap:28px;}
.nav .brand img{height:26px;}
.nav-links{display:flex;align-items:center;gap:26px;margin-left:14px;}
.nav-links a{color:var(--text2);font-size:14px;font-weight:500;}
.nav-links a:hover{color:var(--ink);}
.nav-links a.active{color:var(--orange);font-weight:600;}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:18px;}
.lang{display:flex;align-items:center;font-family:'IBM Plex Mono',monospace;font-size:12px;
  border:1px solid #e0ddd8;border-radius:6px;overflow:hidden;}
.lang button{border:none;cursor:pointer;padding:6px 10px;font-family:inherit;font-size:12px;background:#fff;color:var(--muted2);}
.lang button.on{background:var(--ink);color:#fff;}
.nav-toggle{display:none;margin-left:auto;background:none;border:1px solid #e0ddd8;border-radius:6px;
  width:40px;height:38px;align-items:center;justify-content:center;cursor:pointer;}
.mobile-menu{display:none;border-top:1px solid var(--hair);padding:14px 28px 22px;flex-direction:column;gap:4px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{color:var(--ink);font-size:16px;font-weight:500;padding:10px 0;border-bottom:1px solid #f1efeb;}
.mobile-menu .mrow{display:flex;align-items:center;gap:16px;margin-top:14px;}

/* language switch as links (real navigation instead of JS) */
.lang a.langbtn{display:inline-block;padding:6px 10px;font-family:'IBM Plex Mono',monospace;
  font-size:12px;background:#fff;color:var(--muted2);text-decoration:none;}
.lang a.langbtn:hover{color:var(--ink);}
.lang a.langbtn.on{background:var(--ink);color:#fff;}
.mobile-menu a.langbtn{border-bottom:none;}

/* ===== sections ===== */
.section{border-bottom:1px solid var(--hair);}
.section.tint{background:var(--surface);}
.section .wrap{padding:84px 28px;}
.shead{margin-bottom:44px;}
.shead h2{font-size:clamp(26px,3vw,36px);line-height:1.1;letter-spacing:-0.02em;font-weight:600;margin-bottom:16px;}
.shead p{font-size:16px;line-height:1.6;color:var(--text2);text-wrap:pretty;margin:0;max-width:720px;}
.shead .eyebrow{display:block;margin-bottom:14px;}

/* hero */
.hero .wrap{padding:0 28px;}
.hero-grid{display:flex;flex-wrap:wrap;align-items:center;gap:48px;padding:72px 0 80px;}
.hero-copy{flex:1 1 380px;min-width:300px;}
.hero-copy h1{font-size:clamp(34px,4.4vw,54px);line-height:1.04;letter-spacing:-0.025em;font-weight:600;margin:22px 0;text-wrap:balance;}
.hero-copy p{font-size:clamp(16px,1.4vw,18px);line-height:1.62;color:var(--text2);margin:0 0 32px;max-width:540px;text-wrap:pretty;}
.hero-visual{flex:1 1 420px;min-width:300px;}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;}
.trust{display:flex;align-items:center;gap:8px;margin-top:22px;font-size:13px;color:var(--muted2);}
.trust svg{flex:none;}

/* browser visual */
.browser{position:relative;border:1px solid #e3e0db;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 1px 0 #f0eee9;}
.browser-bar{display:flex;align-items:center;gap:14px;padding:12px 16px;border-bottom:1px solid var(--hair);background:var(--surface);}
.dots{display:flex;gap:7px;}
.dots span{width:11px;height:11px;border-radius:999px;background:#e0ddd8;}
.addr{flex:1;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--hair);border-radius:6px;
  padding:6px 12px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted2);}
.browser-body{position:relative;height:300px;display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(135deg,#f7f6f4,#f7f6f4 11px,#f2f0ec 11px,#f2f0ec 22px);}
.ph-label{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted3);background:#fff;
  border:1px dashed #d8d4ce;border-radius:8px;padding:10px 16px;}
.metric{position:absolute;right:20px;bottom:20px;background:var(--ink);border-radius:10px;padding:14px 16px;min-width:170px;}
.metric .top{display:flex;align-items:center;gap:7px;margin-bottom:8px;}
.metric .top span.led{width:7px;height:7px;border-radius:999px;background:#3ddc84;}
.metric .top span.lbl{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.06em;color:#9fe9bd;}
.metric .big{font-size:30px;font-weight:700;color:#fff;letter-spacing:-0.02em;line-height:1;}
.metric .unit{font-family:'IBM Plex Mono',monospace;font-size:11px;color:#b8b2ac;margin-top:6px;}

/* product cards */
.cards3{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:20px;}
.pcard{border:1px solid var(--border);border-radius:12px;padding:28px;background:#fff;transition:border-color .15s;}
.pcard:hover{border-color:var(--orange);}
.pcard .ic{width:42px;height:42px;border-radius:9px;background:var(--tint);display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.pcard .tagcat{display:block;margin-bottom:10px;}
.pcard h3{font-size:18px;font-weight:600;margin-bottom:10px;letter-spacing:-0.01em;}
.pcard p{font-size:14px;line-height:1.62;color:var(--muted);margin:0 0 20px;text-wrap:pretty;}

/* why grid */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px 40px;}
.why-grid svg{margin-bottom:16px;}
.why-grid h3{font-size:16px;font-weight:600;margin-bottom:8px;}
.why-grid p{font-size:14px;line-height:1.6;color:var(--muted);margin:0;text-wrap:pretty;}

/* stats */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;}
.stat{border:1px solid var(--border);border-radius:12px;padding:30px;}
.stat .num{font-size:clamp(34px,4vw,46px);font-weight:700;letter-spacing:-0.03em;line-height:1;}
.stat .num.o{color:var(--orange);}
.stat .cap{font-size:14px;color:var(--muted);margin-top:10px;}
.stats-foot{display:flex;flex-wrap:wrap;align-items:center;gap:16px;justify-content:space-between;
  margin-top:28px;padding-top:24px;border-top:1px solid var(--hair);}
.stats-foot p{font-size:14px;line-height:1.55;color:var(--muted2);margin:0;max-width:620px;text-wrap:pretty;}

/* cta band */
.cta-band{background:var(--orange);}
.cta-band .wrap{padding:72px 28px;text-align:center;}
.cta-band h2{font-size:clamp(28px,3.4vw,42px);line-height:1.08;letter-spacing:-0.02em;font-weight:700;color:#fff;margin-bottom:16px;text-wrap:balance;}
.cta-band p{font-size:17px;line-height:1.6;color:#fff;opacity:.92;margin:0 auto 30px;max-width:600px;text-wrap:pretty;}
.cta-band .btn-row{justify-content:center;}

/* footer */
.site-footer{background:#fff;}
.site-footer .wrap{padding:60px 28px 0;}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:40px;}
.foot-brand .brand{margin-bottom:12px;}
.foot-brand .brand img{height:24px;}
.foot-brand p{font-size:13px;line-height:1.6;color:var(--muted2);margin:0;max-width:230px;}
.foot-col h4{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted3);margin-bottom:16px;font-weight:500;}
.foot-col .links{display:flex;flex-direction:column;gap:11px;}
.foot-col .links a{font-size:14px;color:var(--text2);}
.foot-col .links a:hover{color:var(--ink);}
.foot-bottom{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;
  margin-top:54px;padding:24px 0;border-top:1px solid var(--hair);}
.foot-bottom .cr{font-size:13px;color:var(--muted3);}

/* ===== product page extras ===== */
.ps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;}
.ps-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:30px;}
.ps-card.after{border-color:var(--tint-bd);}
.ps-card p{font-size:16px;line-height:1.62;color:var(--text2);margin:0;text-wrap:pretty;}
.ps-pill{display:inline-flex;align-items:center;gap:8px;font-family:'IBM Plex Mono',monospace;font-size:11px;
  letter-spacing:.06em;color:var(--muted2);background:#f4f2ee;border:1px solid var(--border);padding:5px 11px;border-radius:999px;margin-bottom:18px;}
.ps-card.after .ps-pill{color:var(--orange-d);background:var(--tint);border-color:var(--tint-bd);}
.flow{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:20px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted3);}
.flow span.node{padding:5px 9px;border:1px solid var(--border);border-radius:5px;}
.ps-card.after .flow{color:var(--orange-d);}
.ps-card.after .flow span.node{border-color:var(--tint-bd);}
.ps-card.after .flow span.node.hi{background:var(--tint);}

.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px 36px;}
.feat svg{margin-bottom:14px;}
.feat h3{font-size:16px;font-weight:600;margin-bottom:7px;}
.feat p{font-size:14px;line-height:1.58;color:var(--muted);margin:0;text-wrap:pretty;}

.how-box{background:#fff;border:1px solid var(--border);border-radius:14px;padding:36px 30px;}
.how-row{display:flex;flex-wrap:wrap;align-items:stretch;gap:14px;}
.how-step{flex:1 1 150px;min-width:140px;border:1px solid var(--border);border-radius:10px;padding:18px;}
.how-step.warm{border-color:var(--tint-bd);background:#fff7f1;}
.how-step .n{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted3);margin-bottom:8px;}
.how-step.warm .n{color:#e0a274;}
.how-step .t{font-weight:600;font-size:15px;margin-bottom:4px;}
.how-step.warm .t{color:var(--orange-d);}
.how-step .d{font-size:13px;color:var(--muted2);line-height:1.5;}
.how-step.warm .d{color:#a8784f;}
.how-arrow{display:flex;align-items:center;color:#cfc9c3;}
.how-result{flex:2 1 280px;min-width:240px;display:flex;flex-direction:column;gap:12px;}
.res{border:1px solid var(--border);border-radius:10px;padding:16px 18px;}
.res.hit{border-color:#d7eedd;background:#f3fbf6;}
.res .rtop{display:flex;align-items:center;gap:8px;}
.res .rtop .led{width:8px;height:8px;border-radius:999px;background:#a8a39d;}
.res.hit .rtop .led{background:#1f9d57;}
.res .rtop .lbl{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted2);font-weight:500;}
.res.hit .rtop .lbl{color:#1f9d57;}
.res .rd{font-size:14px;color:var(--muted);margin-top:6px;}
.res.hit .rd{color:#3a6b4e;}

.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;}
.price-card{border:1px solid var(--border);border-radius:12px;padding:30px;}
.price-card .ptag{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;color:var(--muted2);}
.price-card.primary .ptag{color:var(--orange);}
.price-card .pnum{font-size:30px;font-weight:700;letter-spacing:-0.02em;margin-bottom:6px;}
.price-card .pnum .per{font-size:15px;font-weight:500;color:var(--muted2);}
.price-card p{font-size:14px;line-height:1.6;color:var(--muted);margin:0 0 20px;}

.faq{border-top:1px solid var(--hair);}
.faq-item{border-bottom:1px solid var(--hair);}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;background:none;border:none;
  cursor:pointer;padding:22px 0;text-align:left;font-family:inherit;}
.faq-q .qt{font-size:16px;font-weight:600;color:var(--ink);}
.faq-q .sign{font-family:'IBM Plex Mono',monospace;font-size:20px;color:var(--orange);flex:none;}
.faq-a{font-size:15px;line-height:1.65;color:var(--text2);margin:0;padding:0 0 24px;max-width:680px;text-wrap:pretty;display:none;}
.faq-item.open .faq-a{display:block;}

/* product hero same as editorial */
.prod-hero .hero-grid{padding:64px 0 72px;}
.prod-hero h1{font-size:clamp(34px,4.4vw,52px);}

/* ===== responsive ===== */
@media (max-width:980px){
  .foot-grid{grid-template-columns:1fr 1fr 1fr;}
  .foot-brand{grid-column:1 / -1;}
}
@media (max-width:880px){
  .nav-links,.nav-right{display:none;}
  .nav-toggle{display:flex;}
  .section .wrap{padding:64px 28px;}
  .hero-grid{padding:56px 0 64px;}
}
@media (max-width:560px){
  .wrap{padding:0 20px;}
  .section .wrap{padding:52px 20px;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}

/* ===== toolbox extensions ===== */
.tb-intro{max-width:680px;}
.ext-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;}
.ext{border:1px solid var(--border);border-radius:12px;padding:22px 24px;background:#fff;}
.ext .etop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px;}
.ext h3{font-size:16px;font-weight:600;letter-spacing:-0.01em;}
.ext p{font-size:14px;line-height:1.55;color:var(--muted);margin:0;}
.ext .price{font-family:'IBM Plex Mono',monospace;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap;flex:none;}
.ext .price.free{color:#1f7a4d;background:#eaf7ef;border:1px solid #cfe9d8;}
.ext .price.paid{color:var(--orange-d);background:var(--tint);border:1px solid var(--tint-bd);}
.ext-note{font-size:14px;line-height:1.55;color:var(--muted2);margin-top:24px;max-width:680px;}
a.ext{text-decoration:none;color:inherit;display:block;transition:border-color .15s ease, box-shadow .15s ease, transform .15s ease;}
a.ext:hover{border-color:var(--orange);box-shadow:0 8px 24px rgba(35,31,32,.07);transform:translateY(-2px);}
.ext-link{display:inline-block;margin-top:14px;color:var(--orange);font-weight:600;font-size:14px;}
.pricetag{display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:12.5px;font-weight:600;padding:5px 12px;border-radius:999px;white-space:nowrap;}
.pricetag.free{color:#1f7a4d;background:#eaf7ef;border:1px solid #cfe9d8;}
.pricetag.paid{color:var(--orange-d);background:var(--tint);border:1px solid var(--tint-bd);}

/* ===== about: people + stack ===== */
.people-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;}
.person{border:1px solid var(--border);border-radius:12px;padding:28px;background:#fff;}
.person .ptop{display:flex;align-items:center;gap:14px;margin-bottom:14px;}
.avatar{width:52px;height:52px;border-radius:50%;background:var(--tint);border:1px solid var(--tint-bd);color:var(--orange-d);display:flex;align-items:center;justify-content:center;font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:17px;flex:none;}
.person h3{font-size:17px;font-weight:600;}
.person .role{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.04em;color:var(--orange-d);margin-top:3px;}
.person p{font-size:14px;line-height:1.6;color:var(--muted);margin:0;}
.stack-label{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted3);margin:0 0 10px;}
.stack{display:flex;flex-wrap:wrap;gap:10px;}
.stack .chip{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--text2);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 13px;}

/* ===== install command + hero screenshot ===== */
.install-label{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.04em;color:var(--muted2);margin:0 0 10px;}
.cmd{display:flex;align-items:center;gap:12px;background:var(--ink);border-radius:10px;padding:13px 16px;overflow-x:auto;}
.cmd code{font-family:'IBM Plex Mono',monospace;font-size:13px;color:#fff;white-space:nowrap;}
.cmd .copy{flex:none;margin-left:auto;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);background:#fff;border:none;border-radius:6px;padding:7px 14px;cursor:pointer;}
.cmd .copy:hover{background:#f0eee9;}
.install-note{font-size:14px;line-height:1.55;color:var(--muted);margin:12px 0 0;}
.browser-body.shot{height:auto;min-height:0;display:block;background:#fff;padding:0;}
.browser-body.shot img{width:100%;display:block;}

/* ===== comparison table ===== */
.cmp-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:12px;}
.cmp{width:100%;border-collapse:collapse;font-size:14px;min-width:680px;}
.cmp th,.cmp td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--hair);vertical-align:top;}
.cmp thead th{font-weight:600;color:var(--ink);background:var(--surface);white-space:nowrap;}
.cmp tbody th{font-weight:500;color:var(--text2);white-space:nowrap;}
.cmp td{color:var(--muted);}
.cmp .me{background:var(--tint);}
.cmp td.me{color:var(--ink);}
.cmp thead th.me{color:var(--orange-d);}
.cmp tr:last-child th,.cmp tr:last-child td{border-bottom:none;}

/* ===== contact form ===== */
.cform .field{margin-bottom:18px;}
.cform label{display:block;font-size:14px;font-weight:500;color:var(--ink);margin-bottom:6px;}
.cform input,.cform textarea{width:100%;font-family:inherit;font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--border);border-radius:8px;padding:11px 14px;}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--tint);}
.cform textarea{resize:vertical;min-height:140px;}
.banner{border-radius:10px;padding:14px 18px;font-size:15px;line-height:1.5;margin-bottom:24px;}
.banner.ok{background:#f3fbf6;border:1px solid #cfe9d8;color:#1f7a4d;}
.banner.err{background:#fcecec;border:1px solid #f3c9c9;color:#a32d2d;}

/* ===== legal pages ===== */
.legal h2{font-size:18px;font-weight:600;color:var(--ink);margin:28px 0 8px;}
.legal h2:first-child{margin-top:0;}
.legal p{font-size:15px;line-height:1.7;color:var(--text2);margin:0;}

/* ===== docs sub-pages: rows, figures, lists, code ===== */
.docrow{display:flex;flex-wrap:wrap;gap:36px;align-items:center;}
.docrow.rev{flex-direction:row-reverse;}
.docrow .txt{flex:1 1 320px;min-width:280px;}
.docrow .txt h2{font-size:clamp(22px,2.4vw,28px);line-height:1.15;letter-spacing:-0.02em;font-weight:600;margin-bottom:12px;}
.docrow .txt > p{font-size:15px;line-height:1.62;color:var(--text2);margin:0;text-wrap:pretty;}
.docrow .fig{flex:1 1 380px;min-width:280px;margin:0;}
.figure{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface);}
.figure img{width:100%;display:block;}
.figure figcaption{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--muted2);padding:9px 14px;border-top:1px solid var(--hair);}
.blist{margin:16px 0 0;padding:0;list-style:none;}
.blist li{position:relative;padding-left:22px;font-size:14px;line-height:1.55;color:var(--text2);margin-bottom:9px;}
.blist li::before{content:"";position:absolute;left:2px;top:8px;width:7px;height:7px;border-radius:50%;background:var(--orange);}
.codeblock{background:var(--ink);border-radius:10px;padding:16px 18px;overflow-x:auto;margin-top:16px;}
.codeblock code{display:block;font-family:'IBM Plex Mono',monospace;font-size:13px;line-height:1.9;color:#fff;white-space:pre;}
.codeblock .cmt{color:#b8b2ac;}

/* ===== nav dropdown ===== */
.nav-item{position:relative;display:flex;align-items:center;}
.nav-item .caret{display:inline-block;margin-left:5px;font-size:9px;vertical-align:2px;color:var(--muted3);}
.drop{position:absolute;top:100%;left:0;margin-top:8px;min-width:250px;background:#fff;border:1px solid var(--border);
  border-radius:10px;padding:8px;box-shadow:0 8px 28px rgba(35,31,32,.10);opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity .14s,transform .14s,visibility .14s;z-index:60;}
.nav-item:hover .drop,.nav-item:focus-within .drop{opacity:1;visibility:visible;transform:translateY(0);}
.drop a{display:block;padding:8px 10px;border-radius:6px;font-size:14px;color:var(--text2);white-space:nowrap;}
.drop a:hover{background:var(--surface);color:var(--ink);}
.drop a.lead{font-weight:500;color:var(--ink);}
.drop .sub{margin:2px 0;}
.drop .sub a{padding-left:24px;font-size:13.5px;}
.drop .sep{height:1px;background:var(--hair);margin:8px 4px;}

/* footer nested products + mobile sub-menu */
.foot-col .links .lead{font-weight:500;color:var(--ink);}
.foot-col .links .sub{display:flex;flex-direction:column;gap:10px;margin:8px 0 4px;padding-left:12px;border-left:1px solid var(--hair);}
.foot-col .links .sub a{font-size:13px;}
.mobile-menu .grp{font-weight:600;}
.mobile-menu .sub{display:flex;flex-direction:column;}
.mobile-menu .sub a{padding-left:18px;font-size:15px;color:var(--text2);}
