/* ==========================================================================
   RANSOMWARE IDENTIFIER — PWN-ALL Design System
   Imported from the "PWN-ALL Design System" Claude Design project.
   IBM Plex Sans/Mono · steel-50 canvas · emerald accent · clear threat
   semantics. Light theme, restrained shadows, hairline borders. No neon.
   ========================================================================== */
/* Self-hosted IBM Plex (SIL OFL). No external calls. */
@font-face { font-family:'IBM Plex Sans'; font-style:normal; font-weight:400; font-display:swap; src:url('fonts/ibm-plex-sans-400.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Sans'; font-style:normal; font-weight:500; font-display:swap; src:url('fonts/ibm-plex-sans-500.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Sans'; font-style:normal; font-weight:600; font-display:swap; src:url('fonts/ibm-plex-sans-600.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Sans'; font-style:normal; font-weight:700; font-display:swap; src:url('fonts/ibm-plex-sans-700.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Mono'; font-style:normal; font-weight:400; font-display:swap; src:url('fonts/ibm-plex-mono-400.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Mono'; font-style:normal; font-weight:500; font-display:swap; src:url('fonts/ibm-plex-mono-500.woff2') format('woff2'); }
@font-face { font-family:'IBM Plex Mono'; font-style:normal; font-weight:600; font-display:swap; src:url('fonts/ibm-plex-mono-600.woff2') format('woff2'); }

:root {
  /* brand green */
  --green-50:#e6faf2; --green-100:#c4f3df; --green-200:#8fe8c2; --green-300:#4fd9a1;
  --green-400:#16c585; --green-500:#00a878; --green-600:#008f66; --green-700:#007152; --green-bright:#00e599;
  /* ink */
  --ink-950:#060a12; --ink-900:#0b1220; --ink-800:#121b2d; --ink-700:#1c283e;
  /* slate */
  --slate-600:#3a4a63; --slate-500:#566480; --slate-400:#7d8aa3; --slate-300:#aab6c9;
  --slate-200:#d4dce8; --slate-150:#e2e8f1; --slate-100:#eef2f8; --slate-50:#f6f8fc; --white:#ffffff;
  /* blue */
  --blue-50:#e9f1ff; --blue-100:#cfe0ff; --blue-400:#4d8bff; --blue-500:#2f6bff; --blue-600:#1f52d6;
  /* red */
  --red-50:#fdecec; --red-100:#fbd5d6; --red-400:#f0595e; --red-500:#e02a31; --red-600:#bd1c22;
  /* amber */
  --amber-50:#fef4e4; --amber-100:#fde4bd; --amber-400:#f4a72b; --amber-500:#db8a04; --amber-600:#a96a02;

  /* semantic */
  --surface-page:var(--slate-50); --surface-card:var(--white); --surface-sunken:var(--slate-100);
  --surface-inverse:var(--ink-900); --surface-code:var(--ink-900);
  --text-strong:var(--ink-900); --text-body:var(--slate-600); --text-muted:var(--slate-500);
  --text-faint:var(--slate-400); --text-inverse:var(--white); --text-link:var(--blue-600);
  --border-subtle:var(--slate-150); --border-default:var(--slate-200); --border-strong:var(--slate-300); --border-focus:var(--blue-500);
  --accent:var(--green-500); --accent-hover:var(--green-600); --accent-soft:var(--green-50); --accent-soft-border:var(--green-200); --accent-text:var(--green-700);
  --danger:var(--red-500); --danger-hover:var(--red-600); --danger-soft:var(--red-50); --danger-border:var(--red-100); --danger-text:var(--red-600);
  --warning:var(--amber-500); --warning-soft:var(--amber-50); --warning-border:var(--amber-100); --warning-text:var(--amber-600);
  --info:var(--blue-500); --info-soft:var(--blue-50); --info-border:var(--blue-100); --info-text:var(--blue-600);
  --safe:var(--green-500); --safe-soft:var(--green-50); --safe-border:var(--green-200); --safe-text:var(--green-700);

  /* type */
  --font-sans:'IBM Plex Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,'SF Mono',SFMono-Regular,Menlo,Consolas,monospace;
  --text-xs:12px; --text-sm:14px; --text-base:16px; --text-md:18px; --text-lg:20px; --text-xl:25px;
  --text-2xl:31px; --text-3xl:39px; --text-4xl:49px; --text-5xl:61px;
  --tracking-tight:-0.02em; --tracking-snug:-0.01em; --tracking-caps:0.08em;

  /* spacing */
  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:20px; --space-6:24px;
  --space-8:32px; --space-10:40px; --space-12:48px; --space-16:64px; --space-20:80px; --space-24:96px;
  --container-md:820px; --container-lg:1080px; --container-xl:1280px; --gutter:24px;

  /* effects */
  --radius-xs:4px; --radius-sm:6px; --radius-md:10px; --radius-lg:14px; --radius-xl:20px; --radius-pill:999px;
  --shadow-xs:0 1px 2px rgba(11,18,32,.06);
  --shadow-sm:0 1px 3px rgba(11,18,32,.08),0 1px 2px rgba(11,18,32,.04);
  --shadow-md:0 4px 12px rgba(11,18,32,.08),0 2px 4px rgba(11,18,32,.04);
  --shadow-lg:0 12px 28px rgba(11,18,32,.10),0 4px 8px rgba(11,18,32,.05);
  --shadow-xl:0 24px 56px rgba(11,18,32,.14),0 8px 16px rgba(11,18,32,.06);
  --focus-ring:0 0 0 3px rgba(47,107,255,.30);
  --focus-ring-accent:0 0 0 3px rgba(0,168,120,.28);
  --ease-out:cubic-bezier(.16,1,.3,1); --ease-standard:cubic-bezier(.2,0,0,1);
  --control-radius:var(--radius-sm); --control-height:44px;
  --input-bg:var(--white);
}

*,*::before,*::after { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body { margin:0; font:400 var(--text-base)/1.5 var(--font-sans); color:var(--text-body); background:var(--surface-page); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
h1,h2,h3,h4 { margin:0; color:var(--text-strong); letter-spacing:var(--tracking-tight); text-wrap:balance; }
p { margin:0; text-wrap:pretty; }
a { color:var(--text-link); text-decoration:none; transition:color .12s var(--ease-standard); }
a:hover { text-decoration:underline; }
:focus-visible { outline:none; box-shadow:var(--focus-ring); border-radius:var(--radius-xs); }
::selection { background:var(--green-100); color:var(--ink-900); }
.ico { display:inline-block; vertical-align:middle; flex:none; }
.mono { font-family:var(--font-mono); }

/* ---- layout ---- */
.container { width:100%; max-width:var(--container-lg); margin-inline:auto; padding-inline:var(--gutter); }
.container-xl { max-width:var(--container-xl); }
.container-md { max-width:var(--container-md); }
.section { padding-block:var(--space-20); }
.section-sm { padding-block:var(--space-16); }
.center { text-align:center; max-width:62ch; margin-inline:auto; }
.eyebrow { font:600 var(--text-xs)/1 var(--font-sans); letter-spacing:var(--tracking-caps); text-transform:uppercase; color:var(--accent-text); }
.h2 { font:600 var(--text-3xl)/1.25 var(--font-sans); letter-spacing:var(--tracking-tight); }
.h3 { font:600 var(--text-2xl)/1.25 var(--font-sans); letter-spacing:var(--tracking-tight); }
.display { font:700 var(--text-5xl)/1.1 var(--font-sans); letter-spacing:var(--tracking-tight); color:var(--text-strong); }
.lede { font:400 var(--text-md)/1.65 var(--font-sans); color:var(--text-body); }
.on-dark { color:var(--white); }
.on-dark.lede,.lede.on-dark { color:var(--slate-300); }

/* ---- header ---- */
.hdr { position:sticky; top:0; z-index:30; background:rgba(246,248,252,.82); backdrop-filter:blur(10px); border-bottom:1px solid var(--border-subtle); }
.hdr-in { display:flex; align-items:center; gap:var(--space-8); height:68px; }
.brand { display:inline-flex; align-items:center; gap:10px; color:var(--text-strong); }
.brand:hover { text-decoration:none; }
.brand img { height:34px; width:34px; display:block; }
.brand-name { font:700 var(--text-md)/1 var(--font-sans); letter-spacing:var(--tracking-tight); }
.hdr-cta { display:flex; gap:var(--space-3); margin-left:auto; }
.hdr-burger { display:none; width:42px; height:38px; flex-direction:column; align-items:center; justify-content:center; gap:5px; border:1px solid var(--border-default); border-radius:var(--radius-sm); background:var(--surface-card); cursor:pointer; }
.hdr-burger:hover { border-color:var(--accent); }
.hdr-burger span { width:18px; height:2px; border-radius:2px; background:var(--text-strong); transition:transform .22s var(--ease-out), opacity .16s var(--ease-out); }
.hdr.nav-open .hdr-burger span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hdr.nav-open .hdr-burger span:nth-child(2) { opacity:0; }
.hdr.nav-open .hdr-burger span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }
.hdr-mobile { display:none; }

/* ---- buttons ---- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; height:var(--control-height); padding:0 var(--space-5); border-radius:var(--control-radius); border:1px solid transparent; font:600 var(--text-sm)/1 var(--font-sans); cursor:pointer; transition:background .15s var(--ease-standard),border-color .15s,color .15s,box-shadow .15s; white-space:nowrap; }
.btn:hover { text-decoration:none; }
.btn-sm { height:36px; padding:0 var(--space-4); }
.btn-lg { height:52px; padding:0 var(--space-6); font-size:var(--text-base); }
.btn-full { width:100%; }
.btn-primary { background:var(--accent); color:var(--white); }
.btn-primary:hover { background:var(--accent-hover); color:var(--white); }
.btn-secondary { background:var(--surface-card); color:var(--text-strong); border-color:var(--border-default); box-shadow:var(--shadow-xs); }
.btn-secondary:hover { border-color:var(--border-strong); color:var(--text-strong); }
.btn-ghost { background:transparent; color:var(--text-body); }
.btn-ghost:hover { background:var(--surface-sunken); color:var(--text-strong); }
.btn[disabled] { opacity:.5; cursor:not-allowed; }

/* ---- cards ---- */
.card { background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); padding:var(--space-6); }
.card-lg { padding:var(--space-8); }
.card.elev-lg { box-shadow:var(--shadow-lg); }
.card.elev-md { box-shadow:var(--shadow-md); }
.card.elev-none { box-shadow:none; }
.card.accent-danger { border-top:3px solid var(--danger); }
.card.accent-accent { border-top:3px solid var(--accent); }

/* ---- badges / tags / pills / chips ---- */
.badge { display:inline-flex; align-items:center; gap:7px; font:600 var(--text-xs)/1 var(--font-sans); padding:6px 11px; border-radius:var(--radius-pill); border:1px solid transparent; }
.badge .dot { width:6px; height:6px; border-radius:50%; background:currentColor; }
.badge-safe { background:var(--safe-soft); color:var(--safe-text); border-color:var(--safe-border); }
.badge-warning { background:var(--warning-soft); color:var(--warning-text); border-color:var(--warning-border); }
.badge-danger { background:var(--danger-soft); color:var(--danger-text); border-color:var(--danger-border); }

.tag { display:inline-flex; align-items:center; font:500 var(--text-xs)/1 var(--font-sans); padding:5px 10px; border-radius:var(--radius-sm); background:var(--surface-sunken); color:var(--text-body); border:1px solid var(--border-subtle); }
.tag-code { font-family:var(--font-mono); background:var(--ink-900); color:var(--green-bright); border-color:var(--ink-700); }

.chip { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:var(--radius-sm); background:var(--accent-soft); color:var(--accent-text); flex:none; }
.chip-lg { width:38px; height:38px; }
.chip-danger { background:var(--danger-soft); color:var(--danger-text); }
.chip-warning { background:var(--warning-soft); color:var(--warning-text); }
.chip-info { background:var(--info-soft); color:var(--info-text); }
.chip-dark { background:rgba(0,229,153,.12); color:var(--green-bright); }

/* ---- alert ---- */
.alert { display:flex; gap:var(--space-3); padding:var(--space-4); border-radius:var(--radius-md); border:1px solid; }
.alert .ico { margin-top:1px; }
.alert strong { display:block; color:var(--text-strong); font-weight:600; font-size:var(--text-sm); }
.alert p { font-size:var(--text-sm); margin-top:3px; }
.alert-safe { background:var(--safe-soft); border-color:var(--safe-border); color:var(--safe-text); }
.alert-warning { background:var(--warning-soft); border-color:var(--warning-border); color:var(--warning-text); }
.alert-safe p,.alert-warning p { color:var(--text-body); }

/* ---- hero ---- */
.hero { background:linear-gradient(180deg,var(--white) 0%,var(--surface-page) 100%); border-bottom:1px solid var(--border-subtle); }
.hero-in { display:grid; grid-template-columns:1fr 1.05fr; gap:var(--space-16); align-items:start; padding-block:var(--space-20); }
.hero h1 { margin-top:var(--space-5); }
.hero .lede { margin-top:var(--space-5); max-width:46ch; }
.trust { list-style:none; padding:0; margin:var(--space-8) 0 0; display:flex; flex-direction:column; gap:var(--space-3); }
.trust li { display:flex; align-items:center; gap:var(--space-3); color:var(--text-body); }

/* ---- form ---- */
.identify { display:flex; flex-direction:column; gap:var(--space-5); }
.field-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); }
.field { display:flex; flex-direction:column; gap:7px; }
.field-label { font:500 var(--text-sm)/1.25 var(--font-sans); color:var(--text-strong); }
.field-hint { font:400 var(--text-xs)/1.4 var(--font-sans); color:var(--text-muted); }
.input { width:100%; height:var(--control-height); padding:0 var(--space-4); background:var(--input-bg); border:1px solid var(--border-default); border-radius:var(--control-radius); color:var(--text-strong); font:400 var(--text-base)/1.5 var(--font-sans); transition:border-color .15s,box-shadow .15s; }
.input.mono { font-family:var(--font-mono); font-size:var(--text-sm); }
textarea.input { height:auto; padding:var(--space-3) var(--space-4); resize:vertical; min-height:120px; line-height:1.6; }
.input::placeholder { color:var(--text-faint); }
.input:focus { outline:none; border-color:var(--border-focus); box-shadow:var(--focus-ring); }

.filedrop { display:flex; align-items:center; gap:var(--space-3); padding:var(--space-4); border:1.5px dashed var(--border-default); border-radius:var(--radius-md); cursor:pointer; transition:border-color .15s,background .15s; }
.filedrop:hover,.filedrop.over { border-color:var(--accent); background:var(--accent-soft); }
.filedrop strong { display:block; color:var(--text-strong); font-size:var(--text-sm); font-weight:600; }
.filedrop p { font-size:var(--text-xs); color:var(--text-muted); margin-top:2px; }

/* ---- results ---- */
.results { padding-block:0; }
.results:empty { display:none; }
.results-in { padding-block:var(--space-12); display:flex; flex-direction:column; gap:var(--space-5); }
.res-head { display:flex; justify-content:space-between; align-items:flex-start; gap:var(--space-6); flex-wrap:wrap; }
.res-title { display:flex; align-items:center; gap:var(--space-3); margin-top:8px; }
.res-title h2 { font:600 var(--text-3xl)/1.25 var(--font-sans); }
.res-tags { display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }
.divider { border:none; border-top:1px solid var(--border-subtle); margin:var(--space-6) 0; }
.res-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-8); }
.res-grid h3 { font:600 var(--text-xl)/1.25 var(--font-sans); margin-bottom:var(--space-4); }
.res-grid h3.mt { margin-top:var(--space-6); }

.conf { display:flex; flex-direction:column; gap:6px; min-width:190px; }
.conf-row { display:flex; justify-content:space-between; font:400 var(--text-xs)/1.4 var(--font-sans); color:var(--text-muted); }
.conf-row b { font-family:var(--font-mono); color:var(--text-strong); font-weight:600; }
.conf-bar { height:8px; border-radius:var(--radius-pill); background:var(--surface-sunken); overflow:hidden; }
.conf-fill { height:100%; border-radius:var(--radius-pill); transition:width .6s var(--ease-out); }

.outlook { display:flex; gap:var(--space-3); align-items:flex-start; }
.outlook p { font-size:var(--text-sm); color:var(--text-body); margin-top:6px; }
.outlook-tool { font-size:var(--text-xs); color:var(--text-muted); margin-top:4px; }

.indicators { display:flex; flex-direction:column; gap:var(--space-2); }
.indicator { display:flex; align-items:center; gap:var(--space-3); }
.indicator .k { font-size:var(--text-sm); color:var(--text-body); flex:none; width:120px; }

.actor { background:var(--surface-sunken); border:1px solid var(--border-subtle); border-radius:var(--radius-md); padding:var(--space-4); box-shadow:none; }
.actor-top { display:flex; align-items:center; gap:var(--space-3); margin-bottom:var(--space-3); }
.actor-top .name { font:600 var(--text-lg)/1.25 var(--font-sans); color:var(--text-strong); }
.actor dl { margin:0; display:grid; grid-template-columns:auto 1fr; gap:8px 14px; font-size:var(--text-sm); }
.actor dt { color:var(--text-muted); }
.actor dd { margin:0; color:var(--text-body); }
.actor .sanction { margin-top:var(--space-3); display:flex; gap:8px; align-items:flex-start; font-size:var(--text-xs); color:var(--danger-text); }
.actor .channels { display:flex; flex-wrap:wrap; gap:6px; margin-top:var(--space-3); }
.res-actions { display:flex; gap:var(--space-3); flex-wrap:wrap; align-items:center; }

.match-2 { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4); }
.match-mini { background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-md); padding:var(--space-4); box-shadow:var(--shadow-xs); }
.match-mini .top { display:flex; justify-content:space-between; align-items:center; gap:10px; }
.match-mini .nm { font:600 var(--text-md)/1.25 var(--font-sans); color:var(--text-strong); }
.match-mini .sc { font-family:var(--font-mono); font-size:var(--text-xs); color:var(--text-muted); }
.iocs { background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-lg); padding:var(--space-6); box-shadow:var(--shadow-sm); display:grid; gap:var(--space-3); }
.iocs h3 { font:600 var(--text-md)/1.25 var(--font-sans); }
.ioc-group .k { font-size:var(--text-xs); font-weight:600; color:var(--text-muted); margin-bottom:6px; }
.ioc-list { display:flex; flex-wrap:wrap; gap:6px; }
.ioc { font-family:var(--font-mono); font-size:var(--text-xs); background:var(--surface-sunken); border:1px solid var(--border-subtle); border-radius:var(--radius-sm); padding:4px 9px; word-break:break-all; color:var(--text-body); }
.empty { text-align:center; color:var(--text-body); background:var(--surface-card); border:1px dashed var(--border-default); border-radius:var(--radius-lg); padding:var(--space-12) var(--space-6); }
.empty strong { color:var(--text-strong); }

/* ---- playbook tabs ---- */
.playbook { padding:0; overflow:hidden; }
.tabs { display:flex; gap:var(--space-2); padding:0 var(--space-6); border-bottom:1px solid var(--border-subtle); }
.tab { background:none; border:none; cursor:pointer; padding:var(--space-4) var(--space-2); margin-bottom:-1px; font:600 var(--text-sm)/1 var(--font-sans); color:var(--text-muted); border-bottom:2px solid transparent; display:inline-flex; align-items:center; gap:7px; }
.tab:hover { color:var(--text-strong); }
.tab.is-active { color:var(--text-strong); border-bottom-color:var(--accent); }
.tab-count { font:500 var(--text-xs)/1 var(--font-mono); color:var(--text-faint); background:var(--surface-sunken); border-radius:var(--radius-pill); padding:2px 7px; }
.tab.is-active .tab-count { color:var(--accent-text); background:var(--accent-soft); }
.play-list { list-style:none; margin:0; padding:var(--space-6); display:flex; flex-direction:column; gap:var(--space-3); }
.play-list[hidden] { display:none; }
.play-list li { display:flex; gap:var(--space-3); align-items:flex-start; }
.play-list .mk { display:inline-flex; width:26px; height:26px; border-radius:var(--radius-sm); align-items:center; justify-content:center; flex:none; margin-top:1px; }
.play-list[data-panel="do"] .mk { background:var(--safe-soft); color:var(--safe-text); }
.play-list[data-panel="dont"] .mk { background:var(--danger-soft); color:var(--danger-text); }
.play-list[data-panel="preserve"] .mk { background:var(--info-soft); color:var(--info-text); }
.play-list li span:last-child { color:var(--text-body); }

/* ---- IR dark band ---- */
.ir { background:var(--ink-900); color:var(--white); }
.ir .container { padding-block:var(--space-20); }
.ir-head { display:flex; justify-content:space-between; align-items:flex-end; gap:var(--space-8); flex-wrap:wrap; margin-bottom:var(--space-10); }
.ir-head > div { max-width:56ch; }
.ir-head h2 { color:var(--white); margin:var(--space-4) 0 var(--space-3); }
.phase-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-4); }
.phase { background:var(--ink-800); border:1px solid var(--ink-700); border-radius:var(--radius-lg); padding:var(--space-5); }
.phase-top { display:flex; align-items:center; gap:var(--space-3); margin-bottom:var(--space-3); }
.phase-num { font:500 var(--text-xs)/1 var(--font-mono); color:var(--slate-400); }
.phase-title { font:600 var(--text-lg)/1.25 var(--font-sans); color:var(--white); margin-bottom:4px; }
.phase p { font-size:var(--text-sm); color:var(--slate-400); }

/* ---- how it works compare ---- */
.compare { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-5); margin-top:var(--space-10); }
.compare .card header { display:flex; align-items:center; gap:var(--space-3); margin-bottom:var(--space-4); }
.compare .compare-title { font:600 var(--text-lg)/1.25 var(--font-sans); color:var(--text-strong); }
.compare ul { margin:0; padding-left:18px; color:var(--text-body); display:flex; flex-direction:column; gap:8px; }
.compare-bad { border-color:var(--danger-border); }

/* ---- faq accordion ---- */
.faq { display:flex; flex-direction:column; gap:var(--space-3); margin-top:var(--space-6); }
.faq details { background:var(--surface-card); border:1px solid var(--border-subtle); border-radius:var(--radius-md); padding:0 var(--space-5); }
.faq summary { display:flex; justify-content:space-between; align-items:center; gap:12px; cursor:pointer; list-style:none; padding:var(--space-4) 0; font:600 var(--text-base)/1.4 var(--font-sans); color:var(--text-strong); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary .ico { color:var(--text-muted); transition:transform .2s var(--ease-standard); }
.faq details[open] summary .ico { transform:rotate(180deg); }
.faq details > p { margin:0 0 var(--space-4); color:var(--text-body); font-size:var(--text-sm); }
.faq + .alert { margin-top:var(--space-6); }

/* ---- footer ---- */
.ftr { background:var(--ink-950); color:var(--slate-300); padding-block:var(--space-16); }
.ftr-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:var(--space-8); }
.ftr-brand { display:inline-flex; align-items:center; gap:10px; color:var(--white); font:700 var(--text-lg)/1 var(--font-sans); letter-spacing:var(--tracking-tight); }
.ftr-brand img { height:40px; width:40px; }
.ftr-grid > div > p { font-size:var(--text-sm); color:var(--slate-400); margin-top:var(--space-4); max-width:34ch; }
.ftr-col h4 { font:600 var(--text-xs)/1 var(--font-sans); letter-spacing:var(--tracking-caps); text-transform:uppercase; color:var(--slate-400); margin-bottom:var(--space-4); }
.ftr-col ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:var(--space-2); }
.ftr-col a { font-size:var(--text-sm); color:var(--slate-300); }
.ftr-col a:hover { color:var(--white); }
.ftr-bottom { border-top:1px solid var(--ink-700); margin-top:var(--space-12); padding-top:var(--space-6); display:flex; justify-content:space-between; gap:var(--space-4); flex-wrap:wrap; font-size:var(--text-xs); color:var(--slate-500); }
.ftr-bottom .mono { color:var(--slate-400); }

/* ---- responsive ---- */
@media (max-width:960px) {
  .hero-in { grid-template-columns:1fr; gap:var(--space-10); }
  .res-grid,.compare,.match-2 { grid-template-columns:1fr; }
  .phase-grid { grid-template-columns:1fr 1fr; }
  .ftr-grid { grid-template-columns:repeat(auto-fit, minmax(150px, 1fr)); gap:var(--space-6) var(--space-8); }
  .hdr-in { gap:var(--space-3); }
  .hdr-cta { display:none; }
  .hdr-burger { display:inline-flex; }
  .lang-switch { margin-left:auto; }
  .hdr-mobile { display:flex; flex-direction:column; gap:var(--space-3); position:absolute; left:0; right:0; top:100%; padding:var(--space-4) var(--gutter) var(--space-5); background:var(--surface-card); border-bottom:1px solid var(--border-subtle); box-shadow:var(--shadow-lg); opacity:0; visibility:hidden; transform:translateY(-12px); transition:opacity .24s var(--ease-out), transform .24s var(--ease-out), visibility .24s; }
  .hdr.nav-open .hdr-mobile { opacity:1; visibility:visible; transform:translateY(0); }
}
@media (max-width:640px) {
  :root { --text-5xl:43px; --text-4xl:37px; --text-3xl:30px; }
  .field-grid { grid-template-columns:1fr; }
  .phase-grid { grid-template-columns:1fr; }
  .ir-head,.ftr-bottom { flex-direction:column; align-items:flex-start; }
}

/* ---- language switcher (header, right side) ---- */
.lang-switch { position:relative; }
.lang-switch > summary { list-style:none; cursor:pointer; display:inline-flex; align-items:center; gap:6px; height:36px; padding:0 12px; border:1px solid var(--border-default); border-radius:var(--radius-pill); background:var(--surface-card); color:var(--text-strong); font:600 13px/1 var(--font-sans); transition:border-color .15s,color .15s; }
.lang-switch > summary::-webkit-details-marker { display:none; }
.lang-switch > summary::marker { content:""; }
.lang-switch > summary:hover { border-color:var(--accent); color:var(--accent); }
.lang-switch > summary svg { width:16px; height:16px; flex:none; }
.lang-cur { letter-spacing:.02em; }
.lang-menu { position:absolute; right:0; top:calc(100% + 8px); z-index:80; display:grid; gap:2px; max-height:min(70vh,460px); overflow:auto; min-width:210px; padding:8px; border:1px solid var(--border-default); border-radius:var(--radius-md); background:var(--surface-card); box-shadow:var(--shadow-lg); }
[dir="rtl"] .lang-menu { right:auto; left:0; }
.lang-menu a { padding:8px 11px; border-radius:8px; color:var(--text-body); font-size:13.5px; line-height:1.3; white-space:nowrap; text-decoration:none; }
.lang-menu a:hover { background:var(--surface-sunken); color:var(--accent); }
.lang-menu a[aria-current] { background:var(--accent-soft); color:var(--accent-text); font-weight:700; }

/* ---- auto dark theme (kept last so overrides win the cascade) ---- */
@media (prefers-color-scheme: dark) {
  :root {
    --surface-page:#070d18; --surface-card:#121b2d; --surface-sunken:#0b1322; --surface-inverse:#f6f8fc;
    --text-strong:#f4f7fb; --text-body:#c0cadb; --text-muted:#93a0b8; --text-faint:#6f7c95; --text-link:#7aa6ff;
    --border-subtle:#222c40; --border-default:#2b3650; --border-strong:#3b4865;
    --accent:#00b483; --accent-hover:#16c585; --accent-soft:#10271f; --accent-soft-border:#1f4a39; --accent-text:#4fd9a1;
    --danger:#f0595e; --danger-hover:#e02a31; --danger-soft:#2a1417; --danger-border:#4a2026; --danger-text:#f4787c;
    --warning:#f4a72b; --warning-soft:#2a2113; --warning-border:#4a3a1d; --warning-text:#f4b14e;
    --info:#4d8bff; --info-soft:#11203a; --info-border:#1d3a66; --info-text:#7aa6ff;
    --safe:#16c585; --safe-soft:#10271f; --safe-border:#1f4a39; --safe-text:#4fd9a1;
    --input-bg:#0b1322;
    --shadow-xs:0 1px 2px rgba(0,0,0,.4);
    --shadow-sm:0 1px 3px rgba(0,0,0,.45),0 1px 2px rgba(0,0,0,.3);
    --shadow-md:0 4px 12px rgba(0,0,0,.5),0 2px 4px rgba(0,0,0,.3);
    --shadow-lg:0 12px 28px rgba(0,0,0,.55),0 4px 8px rgba(0,0,0,.35);
    --shadow-xl:0 24px 56px rgba(0,0,0,.6),0 8px 16px rgba(0,0,0,.4);
  }
  .hdr { background:color-mix(in srgb, var(--surface-page) 82%, transparent); }
  .hero { background:var(--surface-page); }
}
