/* ============ Tokens — professional monochrome (warm paper + ink, single slate accent) ============ */
:root {
  --ink:        #1A1A18;
  --ink-hover:  #2E4257;
  --accent:     #2E4257;
  --accent-soft:#EEF1F4;
  --navy:       #2E4257;
  --navy-700:   #233340;
  --gold:       #2E4257;
  --gold-soft:  #ECEFF2;

  --bg:         #F6F5F2;
  --surface:    #FFFFFF;
  --surface-2:  #F0EEE9;
  --panel:      #FBFAF7;

  --fg:         #3D3A34;
  --fg-strong:  #1A1A18;
  --muted:      #756F65;
  --border:     #E7E3DB;
  --border-strong:#CFCABE;
  --ring:       #2E4257;

  --high-fg:#8E2C2C; --high-bg:#F7ECEA; --high-bd:#E6D0CC;
  --med-fg:#7A5E2E;  --med-bg:#F4EEE1;  --med-bd:#E3D5BA;
  --low-fg:#3C6149;  --low-bg:#EBF1EC;  --low-bd:#CFE0D5;
  --info-fg:#2E4257; --info-bg:#EEF1F4; --info-bd:#D6DDE3;

  --shadow-sm: 0 1px 1px rgba(26,26,24,.03);
  --shadow:    0 1px 2px rgba(26,26,24,.04), 0 2px 8px rgba(26,26,24,.045);
  --shadow-lg: 0 10px 34px rgba(26,26,24,.09);

  --serif: "Newsreader", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --maxw: 78rem;
  --radius: 12px;
  --radius-sm: 8px;
  --transition: 200ms cubic-bezier(.2,.7,.3,1);
}
:root[data-theme="dark"] {
  --ink:#ECEAE3; --ink-hover:#B4C6D5;
  --accent:#9DB2C4; --accent-soft:#243140;
  --navy:#9DB2C4; --navy-700:#B4C6D5; --gold:#9DB2C4; --gold-soft:#1E2530;
  --bg:#121211; --surface:#1A1A18; --surface-2:#232220; --panel:#171715;
  --fg:#D7D3CB; --fg-strong:#F4F2EC; --muted:#969089; --border:#2C2B27; --border-strong:#403E39; --ring:#9DB2C4;
  --high-fg:#E0908B; --high-bg:#2A1816; --high-bd:#523029;
  --med-fg:#D6B679;  --med-bg:#262014;  --med-bd:#4C4024;
  --low-fg:#88B79B;  --low-bg:#15231A;  --low-bd:#2E4A39;
  --info-fg:#A9C0D2; --info-bg:#161E26;  --info-bd:#2C3E4C;
  --shadow-sm:0 1px 1px rgba(0,0,0,.4); --shadow:0 1px 2px rgba(0,0,0,.5),0 2px 10px rgba(0,0,0,.45); --shadow-lg:0 16px 44px rgba(0,0,0,.55);
}

* ,*::before,*::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body { margin:0; font-family:var(--sans); font-size:16px; line-height:1.6; color:var(--fg); background:var(--bg); -webkit-font-smoothing:antialiased; }
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto;} *{animation-duration:.001ms!important;transition-duration:.001ms!important;} }

h1,h2,h3,h4 { font-family:var(--serif); color:var(--fg-strong); font-weight:600; line-height:1.18; margin:0; }
p { margin:0 0 .9rem; }
a { color:var(--navy); text-underline-offset:3px; }
::selection { background:var(--gold-soft); }
:focus-visible { outline:3px solid var(--ring); outline-offset:2px; border-radius:6px; }

.wrap { max-width:var(--maxw); margin:0 auto; padding:0 1.25rem; }
.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;}
.skip-link{position:absolute;left:.6rem;top:-3rem;z-index:200;background:var(--navy);color:#fff;padding:.55rem .9rem;border-radius:8px;font-weight:600;transition:top var(--transition);}
.skip-link:focus{top:.6rem;color:#fff;}

/* ============ Header + mega-menu ============ */
header.site{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--surface) 88%,transparent);backdrop-filter:saturate(1.2) blur(10px);border-bottom:1px solid var(--border);}
.nav{display:flex;align-items:center;gap:.5rem;min-height:64px;}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:inherit;margin-right:auto;}
.brand .logo{width:38px;height:38px;border-radius:9px;background:var(--ink);color:#fff;display:grid;place-items:center;flex:none;}
:root[data-theme="dark"] .brand .logo{background:var(--navy);color:#0A1120;}
.brand .wm{font-family:var(--serif);font-weight:600;font-size:1.32rem;letter-spacing:.01em;color:var(--fg-strong);line-height:1;}
.brand .wm .dot{color:var(--gold);}
.brand .tag{font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.nav .navlink{display:none;font-size:.9rem;font-weight:500;color:var(--muted);text-decoration:none;padding:.5rem .55rem;border-radius:8px;}
.nav .navlink:hover{color:var(--fg-strong);}
.demo-pill{display:none;align-items:center;gap:.35rem;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--gold);background:var(--gold-soft);border:1px solid color-mix(in srgb,var(--gold) 30%,transparent);padding:.3rem .55rem;border-radius:999px;}
.icon-btn{width:42px;height:42px;flex:none;display:grid;place-items:center;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--fg);cursor:pointer;transition:background var(--transition),border-color var(--transition);}
.icon-btn:hover{background:var(--surface-2);border-color:var(--border-strong);}
@media(min-width:880px){ .nav .navlink{display:inline-block;} .demo-pill{display:inline-flex;} }

.menuwrap{position:relative;}
.topics-btn{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--sans);font-size:.9rem;font-weight:600;color:var(--fg-strong);background:var(--surface);border:1px solid var(--border-strong);border-radius:10px;min-height:42px;padding:0 .8rem;cursor:pointer;}
.topics-btn:hover{background:var(--surface-2);}
.topics-btn svg{transition:transform var(--transition);}
.topics-btn[aria-expanded="true"] svg{transform:rotate(180deg);}
.megamenu{position:fixed;top:70px;left:50%;transform:translateX(-50%);z-index:60;width:min(58rem,94vw);background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);padding:1.3rem 1.4rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem 1.6rem;}
.megamenu[hidden]{display:none;}
@media(max-width:820px){ .megamenu{grid-template-columns:1fr 1fr;width:min(94vw,34rem);max-height:74vh;overflow:auto;} }
@media(max-width:520px){ .megamenu{grid-template-columns:1fr;} }
.mm-group h4{font-family:var(--sans);font-size:.68rem;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);margin:0 0 .45rem;}
.mm-list{list-style:none;margin:0;padding:0;}
.mm-link{display:flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--fg-strong);font-size:.92rem;font-weight:600;padding:.34rem 0;}
.mm-link:hover{color:var(--navy);}
.mm-soon{display:flex;align-items:center;gap:.45rem;color:var(--muted);font-size:.92rem;font-weight:500;padding:.34rem 0;}
.soon-tag{font-family:var(--sans);font-size:.58rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:5px;padding:.1rem .32rem;}

/* ============ Persistent disclaimer bar ============ */
.disclaimer-bar{background:var(--info-bg);border-bottom:1px solid var(--info-bd);color:var(--info-fg);font-size:.82rem;}
.disclaimer-bar .wrap{display:flex;align-items:flex-start;gap:.5rem;padding-top:.55rem;padding-bottom:.55rem;}
.disclaimer-bar svg{flex:none;margin-top:.12rem;}
.disclaimer-bar strong{color:var(--info-fg);font-weight:700;}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:46px;padding:.6rem 1.2rem;font-family:var(--sans);font-size:.97rem;font-weight:600;border-radius:10px;border:1px solid transparent;cursor:pointer;text-decoration:none;transition:background var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition);}
.btn:active{transform:translateY(1px);}
.btn svg{flex:none;}
.btn-primary{background:var(--ink);color:var(--surface);box-shadow:none;}
.btn-primary:hover{background:var(--ink-hover);color:var(--surface);}
.btn-outline{background:var(--surface);color:var(--fg-strong);border-color:var(--border-strong);}
.btn-outline:hover{background:var(--surface-2);}
.btn-ghost{background:transparent;color:var(--muted);}
.btn-ghost:hover{color:var(--fg-strong);}
.btn-sm{min-height:38px;padding:.4rem .8rem;font-size:.88rem;}

/* ============ Hero (homepage) ============ */
.hero{padding:4rem 0 1.4rem;position:relative;overflow:hidden;}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--panel),transparent 42%);pointer-events:none;}
.hero .inner{position:relative;max-width:48rem;}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);margin-bottom:1rem;}
.eyebrow .rule{width:26px;height:1.5px;background:var(--gold);}
.hero h1{font-size:clamp(2.2rem,5.4vw,3.5rem);font-weight:500;letter-spacing:-.018em;margin-bottom:1.1rem;}
.hero h1 em{font-style:italic;font-weight:500;color:var(--navy);}
.hero .sub{font-size:1.16rem;color:var(--fg);max-width:42rem;}
.hero .cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem;}
.by{margin-top:1.5rem;font-size:.9rem;color:var(--muted);display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;max-width:42rem;}
.by .av{width:26px;height:26px;border-radius:50%;background:var(--gold-soft);color:var(--gold);display:grid;place-items:center;font-weight:700;font-size:.72rem;font-family:var(--sans);border:1px solid color-mix(in srgb,var(--gold) 30%,transparent);}

/* ============ Topics directory (homepage) ============ */
.topics{padding:1rem 0 2.5rem;}
.grouphead{display:flex;align-items:center;gap:.9rem;margin:2.2rem 0 1rem;}
.grouphead h2{font-size:1.25rem;white-space:nowrap;}
.grouphead .rule{flex:1;height:1px;background:var(--border);}
.topic-grid{display:grid;grid-template-columns:1fr;gap:.8rem;}
@media(min-width:640px){ .topic-grid{grid-template-columns:repeat(2,1fr);} }
@media(min-width:1000px){ .topic-grid{grid-template-columns:repeat(3,1fr);} }
.tcard{display:flex;flex-direction:column;gap:.45rem;text-decoration:none;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.05rem;color:var(--fg);box-shadow:var(--shadow-sm);transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);}
a.tcard:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow);}
.tcard.soon{opacity:.9;}
.tcard .ic{width:34px;height:34px;border-radius:8px;background:var(--info-bg);color:var(--navy);display:grid;place-items:center;}
.tcard .nm{font-weight:700;color:var(--fg-strong);font-size:1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;}
.tcard .bl{font-size:.88rem;color:var(--muted);line-height:1.5;margin:0;}
.tcard .go{margin-top:auto;padding-top:.3rem;font-size:.8rem;font-weight:700;color:var(--navy);display:inline-flex;align-items:center;gap:.3rem;}

/* ============ Value props (reused as cards) ============ */
.about{padding:2.4rem 0;border-top:1px solid var(--border);margin-top:1rem;}
.about h2{font-size:1.7rem;margin-bottom:.4rem;}
.about .lead{color:var(--muted);max-width:46rem;margin-bottom:1.5rem;}
.skills{display:grid;grid-template-columns:1fr;gap:.9rem;}
@media(min-width:680px){ .skills{grid-template-columns:repeat(2,1fr);} }
@media(min-width:980px){ .skills{grid-template-columns:repeat(3,1fr);} }
.skill{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem;box-shadow:var(--shadow-sm);}
.skill .si{width:38px;height:38px;border-radius:9px;background:var(--info-bg);color:var(--navy);display:grid;place-items:center;margin-bottom:.7rem;}
.skill h3{font-family:var(--sans);font-size:1rem;font-weight:700;color:var(--fg-strong);margin-bottom:.3rem;}
.skill p{font-size:.9rem;color:var(--muted);margin:0;}

/* ============ Topic page ============ */
.crumbs{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted);padding:1.1rem 0 0;flex-wrap:wrap;}
.crumbs a{color:var(--muted);text-decoration:none;font-weight:600;}
.crumbs a:hover{color:var(--fg-strong);}
.crumbs svg{opacity:.5;}
.thead{padding:.8rem 0 1.2rem;max-width:48rem;}
.thead h1{font-size:clamp(2rem,4.6vw,2.9rem);font-weight:500;letter-spacing:-.015em;margin:.4rem 0 .8rem;}
.thead .sub{font-size:1.12rem;color:var(--fg);}
.tsec{padding:1.8rem 0;border-top:1px solid var(--border);}
.tsec > h2{font-size:1.5rem;margin-bottom:.35rem;display:flex;align-items:center;gap:.6rem;}
.tsec > h2 svg{flex:none;color:var(--navy);}
.tsec .lead{color:var(--muted);max-width:48rem;margin-bottom:1.1rem;}
.prose{max-width:48rem;}
.prose p{color:var(--fg);}
.prose strong{color:var(--fg-strong);}
.bigcheck{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr;gap:.6rem;}
@media(min-width:760px){ .bigcheck{grid-template-columns:repeat(2,1fr);} }
.bigcheck li{display:flex;gap:.6rem;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.75rem .9rem;font-size:.95rem;box-shadow:var(--shadow-sm);}
.bigcheck li svg{flex:none;margin-top:.15rem;color:var(--navy);}
.bigcheck li b{color:var(--fg-strong);}
.doccards{display:grid;grid-template-columns:1fr;gap:.8rem;}
@media(min-width:760px){ .doccards{grid-template-columns:repeat(3,1fr);} }
.doccard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow-sm);}
.doccard .ic{width:32px;height:32px;border-radius:8px;background:var(--info-bg);color:var(--navy);display:grid;place-items:center;margin-bottom:.5rem;}
.doccard h3{font-family:var(--sans);font-size:.98rem;font-weight:700;color:var(--fg-strong);margin-bottom:.2rem;}
.doccard p{font-size:.86rem;color:var(--muted);margin:0;}
.redflag{background:var(--high-bg);border:1px solid var(--high-bd);border-radius:var(--radius);padding:1.3rem 1.4rem;}
.redflag h2{color:var(--high-fg);font-size:1.35rem;margin-bottom:.4rem;}
.redflag p{color:var(--fg);max-width:48rem;}
.svc{display:grid;grid-template-columns:1fr;gap:.6rem;margin-top:1rem;}
@media(min-width:680px){ .svc{grid-template-columns:repeat(2,1fr);} }
.svc a{display:flex;flex-direction:column;gap:.15rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.75rem .9rem;text-decoration:none;color:var(--fg);}
.svc a:hover{border-color:var(--border-strong);}
.svc .sn{font-weight:700;color:var(--fg-strong);font-size:.92rem;}
.svc .sd{font-size:.82rem;color:var(--muted);}

/* ============ Tool (review + analyse) ============ */
.tool{padding:.6rem 0 1rem;}
.tablist{display:inline-flex;gap:.25rem;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:.3rem;margin-bottom:1.3rem;}
.tab{appearance:none;border:0;background:transparent;font-family:var(--sans);font-size:.94rem;font-weight:600;color:var(--muted);padding:.55rem .95rem;border-radius:9px;cursor:pointer;display:inline-flex;align-items:center;gap:.45rem;transition:background var(--transition),color var(--transition);}
.tab[aria-selected="true"]{background:var(--surface);color:var(--fg-strong);box-shadow:var(--shadow-sm);}
.tab svg{flex:none;}
.tabpanel{display:none;}
.tabpanel.active{display:block;animation:fade .25s ease;}
@keyframes fade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}

.picker{display:grid;grid-template-columns:1fr;gap:.7rem;margin-bottom:1.3rem;}
@media(min-width:720px){ .picker{grid-template-columns:repeat(3,1fr);} }
.doc-card{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.05rem;cursor:pointer;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);color:var(--fg);font-family:var(--sans);}
.doc-card:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow);}
.doc-card[aria-pressed="true"]{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);}
.doc-card .k{display:flex;align-items:center;gap:.55rem;margin-bottom:.5rem;}
.doc-card .k .ic{width:34px;height:34px;border-radius:8px;background:var(--info-bg);color:var(--navy);display:grid;place-items:center;flex:none;}
.doc-card .nm{font-weight:700;color:var(--fg-strong);font-size:1rem;}
.doc-card .ty{font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;}
.doc-card .ds{font-size:.88rem;color:var(--muted);line-height:1.5;}

.summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.3rem;margin-bottom:1.2rem;box-shadow:var(--shadow-sm);}
.summary h2{font-size:1.18rem;margin-bottom:.2rem;}
.summary .read{color:var(--fg);font-size:.98rem;margin:.5rem 0 .9rem;}
.riskbar{display:flex;flex-wrap:wrap;gap:.5rem;}
.rchip{display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;font-weight:600;padding:.35rem .7rem;border-radius:999px;border:1px solid;}
.rchip .n{font-weight:700;}
.rc-high{color:var(--high-fg);background:var(--high-bg);border-color:var(--high-bd);}
.rc-med{color:var(--med-fg);background:var(--med-bg);border-color:var(--med-bd);}
.rc-low{color:var(--low-fg);background:var(--low-bg);border-color:var(--low-bd);}

.panes{display:grid;grid-template-columns:1fr;gap:1.2rem;}
@media(min-width:980px){ .panes{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);align-items:start;} }
.doc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.doc .doc-head{padding:.85rem 1.1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.6rem;background:var(--panel);}
.doc .doc-head .t{font-family:var(--serif);font-weight:600;font-size:1.05rem;color:var(--fg-strong);}
.doc .doc-head .meta{margin-left:auto;font-size:.76rem;color:var(--muted);}
.doc .scroll{max-height:none;}
@media(min-width:980px){ .doc .scroll{max-height:30rem;overflow-y:auto;} }
.clause{display:block;width:100%;text-align:left;background:transparent;border:0;border-bottom:1px solid var(--border);padding:1rem 1.1rem;cursor:pointer;font-family:var(--serif);color:var(--fg);transition:background var(--transition);position:relative;}
.clause:last-child{border-bottom:0;}
.clause:hover{background:var(--surface-2);}
.clause[aria-current="true"]{background:color-mix(in srgb,var(--accent) 12%,transparent);}
.clause[aria-current="true"]::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);}
.clause .ch{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.3rem;}
.clause .num{font-family:var(--sans);font-size:.78rem;font-weight:700;color:var(--navy);flex:none;}
.clause .hd{font-family:var(--sans);font-weight:700;font-size:.95rem;color:var(--fg-strong);}
.clause .badge{margin-left:auto;}
.clause .body{font-size:.96rem;line-height:1.6;color:var(--fg);}
.clause .tap{font-family:var(--sans);font-size:.76rem;color:var(--navy);font-weight:600;margin-top:.45rem;display:inline-flex;align-items:center;gap:.3rem;}

.badge{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.02em;padding:.22rem .5rem;border-radius:6px;border:1px solid;white-space:nowrap;text-transform:uppercase;}
.b-high{color:var(--high-fg);background:var(--high-bg);border-color:var(--high-bd);}
.b-med{color:var(--med-fg);background:var(--med-bg);border-color:var(--med-bd);}
.b-low{color:var(--low-fg);background:var(--low-bg);border-color:var(--low-bd);}
.dotbadge{width:7px;height:7px;border-radius:50%;}

.review{position:relative;}
@media(min-width:980px){ .review{position:sticky;top:84px;} }
.review .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;}
.review .rhead{padding:1.1rem 1.2rem;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--panel),var(--surface));}
.review .rkicker{font-family:var(--sans);font-size:.74rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--navy);margin-bottom:.4rem;display:flex;align-items:center;gap:.5rem;}
.review h3{font-size:1.32rem;margin-bottom:.5rem;}
.review .favours{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--sans);font-size:.82rem;font-weight:600;color:var(--fg);background:var(--surface-2);border:1px solid var(--border);padding:.3rem .6rem;border-radius:999px;}
.review .rbody{padding:1.1rem 1.2rem;}
.review .rbody h4{font-family:var(--sans);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:1.2rem 0 .5rem;display:flex;align-items:center;gap:.45rem;}
.review .rbody h4:first-child{margin-top:0;}
.review .rbody p{font-size:.97rem;}
.review .note{background:var(--info-bg);border:1px solid var(--info-bd);border-left:3px solid var(--navy);border-radius:8px;padding:.7rem .85rem;font-size:.92rem;color:var(--fg);}
.checklist{list-style:none;margin:0;padding:0;}
.checklist li{display:flex;gap:.6rem;align-items:flex-start;font-size:.94rem;padding:.32rem 0;}
.checklist li svg{flex:none;margin-top:.2rem;color:var(--navy);}
.neg{list-style:none;margin:0;padding:0;}
.neg li{display:flex;gap:.6rem;align-items:flex-start;font-size:.94rem;padding:.32rem 0;}
.neg li svg{flex:none;margin-top:.15rem;color:var(--gold);}
.review .empty{padding:2.4rem 1.4rem;text-align:center;color:var(--muted);}
.review .empty svg{color:var(--border-strong);margin-bottom:.6rem;}

.analyzer{display:grid;grid-template-columns:1fr;gap:1.2rem;}
@media(min-width:980px){ .analyzer{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;} }
.analyzer .inp{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow-sm);}
.analyzer label{display:block;font-weight:600;color:var(--fg-strong);margin-bottom:.5rem;font-size:.95rem;}
textarea{width:100%;min-height:170px;resize:vertical;font-family:var(--serif);font-size:1rem;line-height:1.6;color:var(--fg);background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:.8rem .9rem;}
textarea:focus{outline:3px solid var(--ring);outline-offset:1px;}
.examples{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.8rem;}
.ex{font-family:var(--sans);font-size:.82rem;font-weight:600;color:var(--navy);background:var(--info-bg);border:1px solid var(--info-bd);border-radius:999px;padding:.35rem .7rem;cursor:pointer;}
.ex:hover{background:var(--surface-2);}
.analyzer .out .card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;}
.matchrow{display:flex;align-items:center;gap:.6rem;padding:.5rem .7rem;border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;background:var(--panel);}
.matchrow .mn{font-weight:700;color:var(--fg-strong);font-size:.92rem;}
.matchrow .conf{margin-left:auto;font-family:var(--sans);font-size:.76rem;font-weight:700;color:var(--navy);}
.meter{height:5px;border-radius:3px;background:var(--surface-2);overflow:hidden;flex:none;width:70px;}
.meter i{display:block;height:100%;background:var(--navy);}
.disclaimer-inline{font-size:.82rem;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:.6rem .8rem;margin-top:1rem;display:flex;gap:.5rem;align-items:flex-start;}
.disclaimer-inline svg{flex:none;margin-top:.1rem;color:var(--muted);}

/* ============ Worked examples ============ */
.exlist{display:grid;grid-template-columns:1fr;gap:.9rem;max-width:50rem;}
.excard{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);padding:1.1rem 1.2rem;box-shadow:var(--shadow-sm);}
.excard .ext{font-family:var(--sans);font-weight:700;color:var(--fg-strong);font-size:1.02rem;margin-bottom:.45rem;}
.excard .exs{color:var(--fg);font-size:.95rem;line-height:1.6;margin:0 0 .8rem;}
.excard .exl{background:var(--info-bg);border:1px solid var(--info-bd);border-radius:8px;padding:.7rem .85rem;font-size:.9rem;color:var(--fg);line-height:1.55;}
.excard .exl b{color:var(--fg-strong);}

/* ============ Interactive self-check ============ */
.selfcheck{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.sc-list{padding:.4rem;}
.sc-item{display:flex;gap:.75rem;align-items:flex-start;width:100%;text-align:left;background:transparent;border:0;padding:.75rem .85rem;border-radius:10px;cursor:pointer;font-family:var(--sans);color:var(--fg);transition:background var(--transition);}
.sc-item:hover{background:var(--surface-2);}
.sc-box{width:22px;height:22px;flex:none;border:2px solid var(--border-strong);border-radius:6px;display:grid;place-items:center;margin-top:.05rem;color:transparent;transition:background var(--transition),border-color var(--transition);}
.sc-item[aria-checked="true"] .sc-box{background:var(--accent);border-color:var(--accent);color:#fff;}
:root[data-theme="dark"] .sc-item[aria-checked="true"] .sc-box{color:#0A1120;}
.sc-q{font-size:.96rem;color:var(--fg-strong);line-height:1.5;}
.sc-readout{border-top:1px solid var(--border);background:var(--panel);padding:1.1rem 1.2rem;}
.sc-readout .sc-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;}
.sc-readout .sc-head .t{font-family:var(--sans);font-weight:700;color:var(--fg-strong);}
.sc-readout .sc-head .c{font-family:var(--sans);font-size:.85rem;font-weight:700;color:var(--muted);}
.sc-meter{height:8px;border-radius:5px;background:var(--surface-2);overflow:hidden;margin:.55rem 0 .9rem;}
.sc-meter i{display:block;height:100%;width:0;background:var(--accent);transition:width var(--transition);}
.sc-gaps{list-style:none;margin:0;padding:0;}
.sc-gaps li{display:flex;gap:.6rem;align-items:flex-start;font-size:.92rem;padding:.4rem 0;color:var(--fg);border-top:1px solid var(--border);}
.sc-gaps li:first-child{border-top:0;}
.sc-gaps li svg{flex:none;margin-top:.12rem;color:var(--med-fg);}
.sc-gaps li b{color:var(--fg-strong);}
.sc-done{display:flex;gap:.55rem;align-items:center;color:var(--low-fg);font-weight:600;font-size:.95rem;}

/* ============ Templates & examples ============ */
.tpl{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);margin-bottom:.7rem;overflow:hidden;}
.tpl summary{list-style:none;cursor:pointer;padding:1rem 1.1rem;display:flex;align-items:center;gap:.75rem;}
.tpl summary::-webkit-details-marker{display:none;}
.tpl summary .ti{width:34px;height:34px;border-radius:8px;background:var(--info-bg);color:var(--navy);display:grid;place-items:center;flex:none;}
.tpl summary .tx{display:flex;flex-direction:column;gap:.1rem;}
.tpl summary .tt{font-family:var(--sans);font-weight:700;color:var(--fg-strong);font-size:1rem;}
.tpl summary .td{font-size:.84rem;color:var(--muted);}
.tpl summary .chev{margin-left:auto;color:var(--muted);transition:transform var(--transition);flex:none;}
.tpl[open] summary .chev{transform:rotate(90deg);}
.tpl .tbody{padding:0 1.1rem 1.1rem;}
.tpl .parts{list-style:none;margin:0 0 .9rem;padding:0;border-top:1px solid var(--border);}
.tpl .parts li{padding:.65rem 0;border-bottom:1px solid var(--border);}
.tpl .parts li:last-child{border-bottom:0;}
.tpl .parts .ph{font-family:var(--sans);font-weight:700;color:var(--fg-strong);font-size:.92rem;}
.tpl .parts .pn{font-size:.86rem;color:var(--muted);margin-top:.1rem;}
.tpl .copy{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--sans);font-size:.82rem;font-weight:600;color:var(--navy);background:var(--info-bg);border:1px solid var(--info-bd);border-radius:8px;padding:.5rem .8rem;cursor:pointer;}
.tpl .copy:hover{background:var(--surface-2);}
.tpl-note{font-size:.82rem;color:var(--muted);margin-top:.8rem;display:flex;gap:.5rem;align-items:flex-start;}
.tpl-note svg{flex:none;margin-top:.1rem;}

/* ============ Interactive tools: calculator & wizard ============ */
.calc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.2rem 1.3rem;}
.calc .field{max-width:22rem;margin-bottom:1.1rem;}
.calc label{display:block;font-weight:600;color:var(--fg-strong);margin-bottom:.35rem;font-size:.9rem;}
.calc input[type="date"]{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--fg);background:var(--panel);border:1px solid var(--border);border-radius:9px;padding:.6rem .7rem;min-height:44px;}
.calc input[type="date"]:focus{outline:3px solid var(--ring);outline-offset:1px;}
.calc-out{display:grid;gap:.7rem;}
.calc-row{display:flex;align-items:flex-start;gap:1rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--panel);}
.calc-row .cd{flex:none;text-align:center;min-width:92px;}
.calc-row .cd .date{font-family:var(--sans);font-weight:700;color:var(--accent);font-size:.92rem;line-height:1.3;}
.calc-row .cd .sub{font-size:.72rem;color:var(--muted);margin-top:.15rem;}
.calc-row .ci .l{font-weight:700;color:var(--fg-strong);font-size:.94rem;}
.calc-row .ci .n{font-size:.86rem;color:var(--muted);margin-top:.18rem;line-height:1.5;}

.wiz{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;}
.wiz-list{padding:.35rem .45rem;}
.wiz-row{display:flex;align-items:center;gap:.9rem;padding:.7rem .8rem;border-radius:10px;}
.wiz-row + .wiz-row{border-top:1px solid var(--border);}
.wiz-row .wq{flex:1;font-size:.95rem;color:var(--fg-strong);line-height:1.45;}
.wiz-seg{display:inline-flex;border:1px solid var(--border-strong);border-radius:9px;overflow:hidden;flex:none;}
.wiz-seg button{appearance:none;border:0;background:var(--surface);color:var(--muted);font-family:var(--sans);font-weight:600;font-size:.84rem;padding:.45rem .85rem;cursor:pointer;min-height:40px;transition:background var(--transition),color var(--transition);}
.wiz-seg button + button{border-left:1px solid var(--border-strong);}
.wiz-seg button[aria-pressed="true"]{background:var(--accent);color:#fff;}
:root[data-theme="dark"] .wiz-seg button[aria-pressed="true"]{color:#0A1120;}
.wiz-readout{border-top:1px solid var(--border);background:var(--panel);padding:1.1rem 1.2rem;}
.wiz-lean{font-family:var(--serif);font-size:1.3rem;color:var(--fg-strong);margin-bottom:.4rem;}
.wiz-bar{display:flex;height:10px;border-radius:6px;overflow:hidden;background:var(--surface-2);}
.wiz-bar .emp{background:var(--accent);}
.wiz-bar .con{background:var(--med-fg);}
.wiz-leg{display:flex;justify-content:space-between;font-size:.78rem;color:var(--muted);margin-top:.35rem;}
.gapcheck{list-style:none;margin:0;padding:0;}
.gapcheck li{display:flex;gap:.6rem;align-items:flex-start;font-size:.94rem;padding:.34rem 0;}
.gapcheck li svg{flex:none;margin-top:.12rem;color:var(--med-fg);}
.gapcheck li b{color:var(--fg-strong);}
.choose-ranks{display:grid;gap:.5rem;margin-top:.4rem;}
.crk{display:flex;align-items:center;gap:.8rem;}
.crk .crl{flex:none;width:8.5rem;font-size:.86rem;font-weight:600;color:var(--fg-strong);}
.crk .crbar{flex:1;height:8px;border-radius:5px;background:var(--surface-2);overflow:hidden;}
.crk .crbar i{display:block;height:100%;background:var(--accent);transition:width var(--transition);}
.connect .cdisc{font-size:.86rem;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:.7rem .85rem;margin:.2rem 0 0;}
.connect .cdisc strong{color:var(--fg-strong);}

/* ============ Connect with a lawyer (paid, coming soon) ============ */
.connect{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;position:relative;}
.connect::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);}
.connect .ch{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;padding:1.3rem 1.5rem .2rem;}
.connect .ch h2{font-size:1.5rem;}
.soon-pill{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--sans);font-size:.66rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 32%,transparent);padding:.28rem .55rem;border-radius:999px;}
.connect .cbody{padding:.4rem 1.5rem 1.5rem;}
.connect .lead2{color:var(--fg);max-width:50rem;}
.connect form{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-top:1.1rem;}
@media(max-width:640px){ .connect form{grid-template-columns:1fr;} }
.connect .full{grid-column:1 / -1;}
.connect label{display:block;font-size:.85rem;font-weight:600;color:var(--fg-strong);margin-bottom:.3rem;}
.connect input,.connect select,.connect textarea{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--fg);background:var(--panel);border:1px solid var(--border);border-radius:9px;padding:.6rem .7rem;min-height:44px;}
.connect textarea{min-height:92px;resize:vertical;line-height:1.55;}
.connect input:focus,.connect select:focus,.connect textarea:focus{outline:3px solid var(--ring);outline-offset:1px;}
.connect input[aria-invalid="true"],.connect textarea[aria-invalid="true"]{border-color:var(--high-fg);}
.connect .crow{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap;margin-top:.3rem;}
.connect .cnote{font-size:.8rem;color:var(--muted);}
.connect .cdone{padding:.6rem 0 1rem;}
.connect .cdone .ic{width:46px;height:46px;border-radius:50%;background:var(--low-bg);color:var(--low-fg);display:grid;place-items:center;margin-bottom:.7rem;border:1px solid var(--low-bd);}
.connect .cdone h3{font-size:1.3rem;margin-bottom:.3rem;}
.connect .cdone p{color:var(--fg);max-width:44rem;}

/* ============ Footer ============ */
footer.site{border-top:1px solid var(--border);background:var(--surface);}
footer.site .wrap{padding:1.6rem 1.25rem 2.2rem;}
footer.site .fbrand{font-family:var(--serif);font-weight:600;font-size:1.1rem;color:var(--fg-strong);}
footer.site .fbrand .dot{color:var(--gold);}
footer.site p{font-size:.84rem;color:var(--muted);margin:.6rem 0 0;max-width:54rem;}

/* ============ Glossary ============ */
.glossary{padding:1.2rem 0 2.5rem;}
.gsearch{position:relative;max-width:28rem;margin:1.1rem 0 1.5rem;}
.gsearch input{width:100%;font-family:var(--sans);font-size:1rem;color:var(--fg);background:var(--surface);border:1px solid var(--border-strong);border-radius:10px;padding:.7rem .9rem .7rem 2.5rem;min-height:46px;}
.gsearch input:focus{outline:3px solid var(--ring);outline-offset:1px;}
.gsearch svg{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--muted);}
.glist{display:grid;grid-template-columns:1fr;gap:.7rem;margin:0;}
@media(min-width:760px){ .glist{grid-template-columns:1fr 1fr;} }
.gitem{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;box-shadow:var(--shadow-sm);}
.gitem dt{font-family:var(--sans);font-weight:700;color:var(--fg-strong);font-size:1rem;margin-bottom:.2rem;}
.gitem dd{margin:0;font-size:.9rem;color:var(--muted);line-height:1.55;}
.gempty{color:var(--muted);padding:1rem 0;}

/* ============ Print ============ */
@media print {
  header.site, .menuwrap, .icon-btn, .demo-pill, .navlink, .crumbs, .connect, .skip-link, .printbtn, .helpbar { display:none !important; }
  body{ background:#fff; padding:0; }
  .tsec, .doccard, .bigcheck li, .calc, .wiz, .selfcheck, details.tpl { break-inside:avoid; }
  a{ color:#000; text-decoration:none; }
  .wrap{ max-width:none; }
}

/* ============ Page feedback ============ */
.fb{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.1rem;margin:1.4rem 0 .4rem;box-shadow:var(--shadow-sm);}
.fb .fb-q{font-family:var(--sans);font-weight:600;color:var(--fg-strong);font-size:.95rem;}
.fb .fb-done{font-size:.9rem;color:var(--low-fg);font-weight:600;}
@media print{ .fb{display:none;} }

/* ============ Sophistication layer ============ */
#cl-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:120;transition:width .1s linear;}
@media print{ #cl-progress{display:none;} }

/* Topic layout with sticky table of contents (wide screens) */
.topic-layout{display:block;}
.toc{display:none;}
@media(min-width:1240px){
  .topic-layout{display:grid;grid-template-columns:minmax(0,1fr) 14rem;gap:2.8rem;align-items:start;}
  .toc{display:block;position:sticky;top:112px;font-family:var(--sans);padding-top:2.2rem;}
}
.toc .toc-t{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem;}
.toc ol{list-style:none;margin:0;padding:0;border-left:1px solid var(--border);}
.toc a{display:block;font-size:.84rem;font-weight:500;color:var(--muted);text-decoration:none;padding:.34rem 0 .34rem .85rem;margin-left:-1px;border-left:2px solid transparent;line-height:1.4;transition:color var(--transition),border-color var(--transition);}
.toc a:hover{color:var(--fg-strong);}
.toc a.active{color:var(--accent);border-left-color:var(--accent);font-weight:600;}
@media print{ .toc{display:none;} }

/* Topic hero meta chips */
.tmeta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;}
.tmeta .stat{font-size:.82rem;}

/* Prev / next topic navigation */
.pn{display:grid;grid-template-columns:1fr;gap:.8rem;padding:1.8rem 0 .6rem;border-top:1px solid var(--border);margin-top:1.4rem;}
@media(min-width:640px){ .pn{grid-template-columns:1fr 1fr;} }
.pn a{display:flex;flex-direction:column;gap:.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.1rem;text-decoration:none;box-shadow:var(--shadow-sm);transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);}
.pn a:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:var(--shadow);}
.pn .dir{font-family:var(--sans);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:.35rem;}
.pn .nm{font-family:var(--serif);font-size:1.12rem;font-weight:600;color:var(--fg-strong);}
.pn .next{text-align:right;}
.pn .next .dir{justify-content:flex-end;}
@media print{ .pn{display:none;} }

/* ============ Polish: reveal-on-scroll, footer nav ============ */
@media (prefers-reduced-motion: no-preference) {
  .reveal{ opacity:0; transform:translateY(14px); transition:opacity .55s ease, transform .55s cubic-bezier(.2,.7,.3,1); }
  .reveal.in{ opacity:1; transform:none; }
}
.fnav{ display:flex; flex-wrap:wrap; gap:1.3rem; padding-bottom:1.1rem; margin-bottom:1.1rem; border-bottom:1px solid var(--border); }
.fnav a{ font-family:var(--sans); font-size:.9rem; font-weight:600; color:var(--muted); text-decoration:none; }
.fnav a:hover{ color:var(--fg-strong); }
@media print { .fnav, .gsearch { display:none !important; } }
