:root{
  --bg:oklch(0.148 0.018 258);--s1:oklch(0.192 0.018 258);--s2:oklch(0.225 0.018 258);
  --line:oklch(0.285 0.022 258);--line2:oklch(0.34 0.022 258);
  --ink:oklch(0.935 0.008 258);--muted:oklch(0.68 0.012 258);--faint:oklch(0.48 0.010 258);
  --c1:oklch(0.73 0.17 240);--c2:oklch(0.74 0.16 175);--c3:oklch(0.78 0.16 82);
  --c4:oklch(0.73 0.17 305);--c5:oklch(0.74 0.17 38);--c6:oklch(0.72 0.08 90);
  --lvE:oklch(0.75 0.19 150);--lvM:oklch(0.77 0.17 78);--lvH:oklch(0.70 0.19 25);
  --ok:oklch(0.75 0.18 150);--warn:oklch(0.77 0.17 70);--err:oklch(0.70 0.19 25);
  --info:oklch(0.73 0.17 240);
  --sans:'IBM Plex Sans','Helvetica Neue',Helvetica,sans-serif;
  --mono:'IBM Plex Mono',monospace;
  /* Alias compat pour inline styles et script.js */
  --border:var(--line);--text:var(--ink);--accent:var(--c1);--accent2:var(--ok);
  --accent3:var(--warn);--accent4:var(--err);--accent5:var(--c4);
  --bg2:var(--s1);--bg3:var(--s2);--card:var(--s1);--r:10px;
  --smooth:all .2s ease;
}
*{box-sizing:border-box;margin:0;padding:0;scrollbar-width:thin;scrollbar-color:var(--line) var(--bg)}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--line2)}
::selection{background:color-mix(in oklab,var(--c5) 30%,transparent);color:var(--ink)}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.72;min-height:100vh}

/* ── Nav ─────────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--line);height:56px}
.nav-inner{max-width:1060px;margin:0 auto;display:flex;align-items:center;height:100%;padding:0 40px;gap:0}
.nav-logo{font:700 16px/1 var(--sans);letter-spacing:-.01em;color:var(--ink);margin-right:40px;white-space:nowrap;text-decoration:none;transition:color .15s}
.nav-logo:hover{color:var(--muted)}
a.nav-btn{text-decoration:none}
.nav-links{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;flex:1}
.nav-links::-webkit-scrollbar{display:none}
.nav-btn{
  position:relative;background:none;border:none;
  color:var(--muted);font-family:var(--sans);font-size:13px;font-weight:500;
  padding:18px 14px 16px;cursor:pointer;white-space:nowrap;transition:color .15s;
}
.nav-btn::after{
  content:'';position:absolute;bottom:0;left:14px;right:14px;height:2px;
  background:var(--chap,var(--line2));border-radius:2px 2px 0 0;
  transform:scaleX(0);transform-origin:left;transition:transform .2s;
}
.nav-btn:hover{color:var(--ink)}
.nav-btn:hover::after,.nav-btn.active::after{transform:scaleX(1)}
.nav-btn.active{color:var(--ink)}
.nav-links a.nav-btn:nth-child(1),.nav-links button.nav-btn:nth-child(1){--chap:var(--c1)}
.nav-links a.nav-btn:nth-child(2),.nav-links button.nav-btn:nth-child(2){--chap:var(--c2)}
.nav-links a.nav-btn:nth-child(3),.nav-links button.nav-btn:nth-child(3){--chap:var(--c3)}
.nav-links a.nav-btn:nth-child(4),.nav-links button.nav-btn:nth-child(4){--chap:var(--c4)}
.nav-links a.nav-btn:nth-child(5),.nav-links button.nav-btn:nth-child(5){--chap:var(--c5)}
.nav-links a.nav-btn:nth-child(6),.nav-links button.nav-btn:nth-child(6){--chap:var(--c6)}

/* ── Layout ───────────────────────────────────────── */
.page{display:none;padding-top:56px;min-height:100vh;animation:fadein .25s ease}
.page.active{display:block}
@keyframes fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.container{max-width:900px;margin:0 auto;padding:52px 48px 80px}

/* ── Hero / Home ──────────────────────────────────── */
.hero{padding:64px 0 8px}
.hero-tags{display:none}
.tag,.tag-blue,.tag-green,.tag-yellow,.tag-purple{display:none}
.hero-kick{font:600 11.5px var(--mono);letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.hero-title{font:700 52px/1.05 var(--sans);letter-spacing:-.025em;color:var(--ink);text-shadow:none}
.hero-title span{background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--ink);background-clip:unset;color:var(--ink);font-style:normal}
.hero-title br{display:none}
.hero-sub{margin-top:20px;font-size:17px;color:var(--muted);max-width:60ch;line-height:1.65;margin-bottom:0}

/* ── Home grid ────────────────────────────────────── */
.home-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  margin:44px 0 0;background:var(--line);border:1px solid var(--line);
  border-radius:12px;overflow:hidden;
}
.home-card{
  background:var(--bg);padding:24px 26px 26px;
  position:relative;text-decoration:none;color:inherit;display:block;
  transition:background .15s;transform:none!important;box-shadow:none!important;
}
.home-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--chap,var(--line));transition:none;opacity:1;height:2px!important;
}
.home-card:hover{background:var(--s1);border-color:transparent}
.home-card.c1{--chap:var(--c1)}.home-card.c2{--chap:var(--c2)}
.home-card.c3{--chap:var(--c3)}.home-card.c4{--chap:var(--c4)}
.home-card.c5{--chap:var(--c5)}.home-card.c6{--chap:var(--c6)}
.home-card-num{font:700 28px/1 var(--mono);color:var(--chap,var(--faint));opacity:.35;margin-bottom:16px;background:none;-webkit-text-fill-color:unset}
.home-card h3{font:600 16px/1.3 var(--sans);color:var(--ink);margin-bottom:8px}
.home-card p{font-size:13.5px;color:var(--muted);line-height:1.55;margin:0}

/* ── Course group ─────────────────────────────────── */
.course-group{background:none;border:none;border-radius:0;padding:0;margin-top:0}
.course-group-header{display:none}
.course-group .home-grid{margin-top:0}
.course-group-soon{
  margin-top:32px;padding:20px 24px;
  background:var(--s1);border:1px dashed var(--line);border-radius:10px;opacity:.55;
}
.course-group-soon .course-group-header{
  display:flex;align-items:center;gap:12px;margin:0;
}
.course-group-icon{font-size:1.4rem;flex-shrink:0}
.course-group-title{font:600 16px var(--sans);color:var(--ink);margin:0}
.course-group-title::after{display:none}
.course-group-desc{font-size:14px;color:var(--muted);margin:2px 0 0;line-height:1.5}

/* ── Section headers ──────────────────────────────── */
.section-header{margin-bottom:48px;padding-bottom:0;border-bottom:none;position:static}
.section-header::after{display:none}
.section-num{
  display:inline-block;
  font:600 11.5px var(--mono);letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);margin-bottom:12px;
  background:none;-webkit-background-clip:unset;-webkit-text-fill-color:unset;font-style:normal;
}
.section-title{font:700 38px/1.12 var(--sans);letter-spacing:-.022em;color:var(--ink)}
.section-title em{
  color:var(--ink);font-style:normal;
  background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--ink);background-clip:unset;
}
.section-intro{margin-top:14px;font-size:16.5px;color:var(--muted);max-width:60ch;line-height:1.65}

/* ── Typography ───────────────────────────────────── */
h2{
  font:600 22px/1.2 var(--sans);letter-spacing:-.015em;
  color:var(--ink);margin:44px 0 8px;
  display:flex;align-items:center;gap:12px;
}
h2::after{display:none}
h3{font:600 17px/1.3 var(--sans);letter-spacing:-.01em;color:var(--ink);margin:28px 0 8px}
h4{font:600 11px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:24px 0 10px}
p{margin-bottom:1rem;color:var(--muted);line-height:1.72}
ul,ol{padding-left:1.4rem;margin-bottom:1rem;color:var(--muted)}
li{line-height:1.72;margin-bottom:.1rem}
strong{color:var(--ink);font-weight:600}
abbr{text-decoration:underline dotted var(--line2);cursor:help;color:inherit}
code{font:400 13.5px/1 var(--mono);color:var(--ink);background:var(--s2);border:1px solid var(--line2);padding:1px 6px;border-radius:5px}
kbd{font:500 12.5px var(--mono);border:1px solid var(--line2);border-radius:5px;padding:1px 7px;color:var(--ink);background:var(--s2)}
pre{
  background:color-mix(in oklab,var(--bg) 70%,#000);
  border:1px solid var(--line);border-radius:10px;
  padding:18px 20px;font:400 13.5px/1.9 var(--mono);
  overflow-x:auto;color:var(--ink);margin:.9rem 0;box-shadow:none;
}
pre:hover{border-color:var(--line2);box-shadow:none}

/* ── Level blocks ─────────────────────────────────── */
.sblock{margin:44px 0;padding-left:20px;border-left:2px solid var(--line2);border-radius:0}
.sblock>h2{margin-top:0}
.sblock.dif-easy{border-left-color:var(--lvE)}
.sblock.dif-medium{border-left-color:var(--lvM)}
.sblock.dif-hard{border-left-color:var(--lvH)}
.sblock>h2::before{
  font:600 10px var(--mono);letter-spacing:.18em;text-transform:uppercase;
  border-radius:99px;padding:3px 9px;flex-shrink:0;border:1px solid;background:none;
  margin-right:0;
}
.sblock.dif-easy>h2::before{content:'Débutant';color:var(--lvE);border-color:color-mix(in oklab,var(--lvE) 40%,transparent)}
.sblock.dif-medium>h2::before{content:'Intermédiaire';color:var(--lvM);border-color:color-mix(in oklab,var(--lvM) 40%,transparent)}
.sblock.dif-hard>h2::before{content:'Avancé';color:var(--lvH);border-color:color-mix(in oklab,var(--lvH) 40%,transparent)}

/* ── Callouts ─────────────────────────────────────── */
.callout{
  display:flex;gap:14px;align-items:flex-start;
  background:var(--s1);border:1px solid var(--line);
  border-radius:10px;padding:16px 20px;
  margin:28px 0;font-size:15px;color:var(--muted);
  transition:none;box-shadow:none;
}
.callout:hover{transform:none}
.callout.info,.callout.ok,.callout.warn,.callout.danger{border-left-width:1px;box-shadow:none}
.callout-icon{
  flex:0 0 auto;width:20px;height:20px;border-radius:5px;
  display:flex;align-items:center;justify-content:center;margin-top:2px;
  font:700 11px var(--mono);color:var(--bg);flex-shrink:0;
}
.callout.info .callout-icon{background:var(--info)}
.callout.ok .callout-icon{background:var(--ok)}
.callout.warn .callout-icon{background:var(--warn)}
.callout.danger .callout-icon{background:var(--err)}
.callout code{background:var(--s2);color:var(--ink)}

/* ── Tables ───────────────────────────────────────── */
.tw{margin:20px 0 8px;border:1px solid var(--line);border-radius:10px;overflow:hidden;-webkit-overflow-scrolling:touch;box-shadow:none}
table{width:100%;border-collapse:collapse;font-size:14.5px}
th{background:var(--s1);font:600 10.5px var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);text-align:left;padding:11px 16px;border-bottom:1px solid var(--line)}
td{padding:12px 16px;border-bottom:1px solid var(--line);color:var(--muted);vertical-align:top;line-height:1.55}
tr:last-child td{border-bottom:0}
td:first-child{color:var(--ink);font-weight:500}
tr:nth-child(even) td{background:none}
tr:hover td{background:color-mix(in oklab,var(--s1) 60%,transparent)!important;transition:background .15s}
td code{font:400 13px var(--mono);color:var(--c5);background:none;border:none;padding:0}

/* ── Device grid ──────────────────────────────────── */
.device-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:2px;margin:20px 0;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.device-card{background:var(--bg);padding:20px 22px;transition:background .15s;border-radius:0;border:none;backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:none}
.device-card:hover{background:var(--s1);transform:none;box-shadow:none;border-color:transparent}
.device-card-top{display:flex;align-items:flex-start;gap:16px;margin-bottom:12px}
.device-svg-wrap{width:56px;height:56px;flex-shrink:0;background:var(--s1);border-radius:8px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);transition:border-color .15s}
.device-card:hover .device-svg-wrap{border-color:var(--line2);box-shadow:none}
.device-info h3{margin:0 0 6px;font-size:15px;font-weight:600;color:var(--ink)}
.badges{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.badge{font:600 11px var(--mono);padding:2px 8px;border-radius:99px;letter-spacing:.04em}
.bl{background:color-mix(in oklab,var(--c1) 15%,transparent);color:var(--c1);border:1px solid color-mix(in oklab,var(--c1) 35%,transparent)}
.bobs{background:color-mix(in oklab,var(--err) 15%,transparent);color:var(--err);border:1px solid color-mix(in oklab,var(--err) 35%,transparent)}
.bcur{background:color-mix(in oklab,var(--ok) 15%,transparent);color:var(--ok);border:1px solid color-mix(in oklab,var(--ok) 35%,transparent)}
.bwarn{background:color-mix(in oklab,var(--warn) 15%,transparent);color:var(--warn);border:1px solid color-mix(in oklab,var(--warn) 35%,transparent)}
.device-card ul{font-size:13.5px;color:var(--muted);margin:0;padding-left:1.2rem}
.device-card li{margin-bottom:3px}

/* ── Steps ────────────────────────────────────────── */
.steps{counter-reset:step-counter;display:flex;flex-direction:column;gap:10px;margin:.9rem 0}
.step{display:flex;gap:14px;align-items:flex-start}
.step::before{
  counter-increment:step-counter;
  content:counter(step-counter);
  flex:0 0 auto;
  width:26px;height:26px;border-radius:7px;
  background:var(--s1);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font:600 12px var(--mono);color:var(--c5);
  margin-top:2px;box-shadow:none;
}
.step p{margin:0;font-size:15.5px;line-height:1.72;color:var(--muted)}

/* ── Calculator ───────────────────────────────────── */
.calc-wrap{background:var(--s1);border:1px solid var(--line);border-radius:10px;padding:24px;margin:.9rem 0}
.calc-row{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}
.calc-wrap input{flex:1;min-width:180px;background:var(--s2);border:1px solid var(--line);border-radius:7px;color:var(--ink);font-family:var(--mono);font-size:14px;padding:8px 14px;outline:none;transition:border-color .15s}
.calc-wrap input:focus,.lex-search:focus{border-color:var(--c5);box-shadow:none}
.calc-btn{background:var(--c5);border:none;color:var(--bg);font-family:var(--sans);font-size:14px;font-weight:600;padding:8px 18px;border-radius:7px;cursor:pointer;transition:opacity .15s;box-shadow:none}
.calc-btn:hover{opacity:.85;transform:none;box-shadow:none}
.calc-results{display:grid;grid-template-columns:repeat(auto-fit,minmax(145px,1fr));gap:8px}
.cr{background:var(--s2);border:1px solid var(--line);border-radius:7px;padding:10px 14px;transition:border-color .15s}
.cr:hover{border-color:var(--line2);box-shadow:none}
.cr-l{font:600 10px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:4px}
.cr-v{font:500 14px var(--mono);color:var(--ink);word-break:break-all}
.cr-v.g{color:var(--ok)}.cr-v.y{color:var(--warn)}

/* ── DNS chain ────────────────────────────────────── */
.dns-chain{display:flex;align-items:center;gap:2px;flex-wrap:wrap;margin:1rem 0}
.dns-box{background:var(--s1);border:1px solid var(--line);border-radius:7px;padding:6px 12px;font-size:13px;color:var(--muted);text-align:center;transition:all .4s ease;white-space:nowrap}
.dns-box.lit{border-color:var(--ok);background:color-mix(in oklab,var(--ok) 12%,transparent);color:var(--ok);transform:scale(1.03);box-shadow:none}
.dns-box.dns-err{border-color:var(--err);background:color-mix(in oklab,var(--err) 10%,transparent);color:var(--err);font-size:.72rem;box-shadow:none}
.dns-details{display:flex;gap:1.2rem;margin:.5rem 0 0;font-size:.75rem;color:var(--muted);font-family:var(--mono)}
.dns-arrow{color:var(--faint);padding:0 4px;font-size:13px}

/* ── Arch blocks ──────────────────────────────────── */
.arch-block{background:var(--s1);border:1px solid var(--line);border-radius:10px;padding:20px;margin:.9rem 0}
.arch-row{display:flex;align-items:center;gap:8px;margin:4px 0;flex-wrap:wrap}
.arch-node{padding:5px 14px;border-radius:99px;font-size:13px;font-weight:500;white-space:nowrap;border:1px solid var(--line);background:var(--s2);color:var(--ink)}
.arch-line{flex:1;min-width:16px;border-top:1px dashed var(--line2);position:relative}
.arch-lbl{position:absolute;top:-16px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--faint);white-space:nowrap;background:var(--s1);padding:0 4px}
.arch-desc{font-size:13px;color:var(--muted);margin:2px 0 2px 1rem;font-style:italic}

/* ── Lexique ──────────────────────────────────────── */
.lex-search{width:100%;background:var(--s1);border:1px solid var(--line);border-radius:7px;color:var(--ink);font-family:var(--sans);font-size:15px;padding:10px 16px;outline:none;transition:border-color .15s;margin-bottom:12px}
.lex-entries{display:flex;flex-direction:column;gap:0;background:var(--s1);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.lex-entry{background:none;border:none;border-radius:0;border-bottom:1px solid var(--line);overflow:hidden}
.lex-entry:last-child{border-bottom:none}
.lex-entry.hidden{display:none}
.lex-term{padding:12px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:14.5px;transition:background .15s;gap:8px}
.lex-term:hover{background:var(--s2)}
.lex-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.lex-def{padding:0 16px;max-height:0;overflow:hidden;transition:all .3s;font-size:14px;color:var(--muted);line-height:1.7}
.lex-def.open{padding:.15rem 16px .85rem;max-height:500px}
.lex-arrow{color:var(--faint);transition:transform .3s;font-size:12px;flex-shrink:0}
.lex-entry.open .lex-arrow{transform:rotate(180deg)}
.lex-cat{font:600 11px var(--mono);padding:2px 8px;border-radius:99px;min-width:72px;text-align:center;display:inline-block;letter-spacing:.04em}
.lc-hw{background:color-mix(in oklab,var(--ok) 15%,transparent);color:var(--ok);border:1px solid color-mix(in oklab,var(--ok) 30%,transparent)}
.lc-ip{background:color-mix(in oklab,var(--warn) 15%,transparent);color:var(--warn);border:1px solid color-mix(in oklab,var(--warn) 30%,transparent)}
.lc-proto{background:color-mix(in oklab,var(--c4) 15%,transparent);color:var(--c4);border:1px solid color-mix(in oklab,var(--c4) 30%,transparent)}

/* ── Cisco tabs ───────────────────────────────────── */
.cisco-tabs{display:flex;gap:4px;margin:24px 0 16px;border-bottom:1px solid var(--line)}
.cisco-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--sans);font-size:14px;font-weight:500;padding:10px 16px 12px;cursor:pointer;transition:color .15s;margin-bottom:-1px;text-decoration:none;white-space:nowrap}
.cisco-tab:hover{color:var(--ink)}
.cisco-tab.active{color:var(--c5);border-bottom-color:var(--c5)}
.cisco-tab.active::after{display:none}
.cisco-section{display:none}
.cisco-section.active{display:block}

/* ── Corrections ──────────────────────────────────── */
.corr-unlock-btn{display:block;margin:1rem 0 0;padding:10px 18px;background:var(--s1);border:1px solid var(--line);border-radius:7px;color:var(--muted);font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.corr-unlock-btn:hover{border-color:var(--line2);color:var(--ink);background:var(--s2)}
.corr-divider{height:1px;background:var(--line);margin:20px 0}
.corr-title{color:var(--ok);font-size:14px;margin-bottom:10px}
.corr-modal{position:fixed;inset:0;z-index:999;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}
.corr-modal-box{background:var(--s1);border:1px solid var(--line);border-radius:12px;padding:28px;max-width:360px;width:90%}
.corr-modal-box h3{margin-bottom:8px;font-size:16px;color:var(--ink)}
.corr-modal-box p{font-size:13px;color:var(--muted);margin-bottom:12px}
.corr-modal-input{width:100%;padding:10px 14px;background:var(--s2);border:1px solid var(--line);border-radius:7px;color:var(--ink);font-family:var(--mono);font-size:14px;outline:none;transition:border-color .15s}
.corr-modal-input:focus{border-color:var(--c5);box-shadow:none}
.corr-modal-error{color:var(--err);font-size:12px;margin-top:6px}
.corr-modal-btns{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}
.corr-modal-cancel,.corr-modal-ok{padding:8px 16px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:var(--sans)}
.corr-modal-cancel{background:var(--s2);color:var(--muted)}
.corr-modal-cancel:hover{color:var(--ink)}
.corr-modal-ok{background:var(--c5);color:var(--bg)}
.corr-modal-ok:hover{opacity:.85}

/* ── Cmd block ────────────────────────────────────── */
.cmd-block{border:1px solid var(--line);border-radius:10px;margin:.7rem 0;overflow:hidden;box-shadow:none}
.cmd-header{padding:9px 16px;background:var(--s1);border-bottom:1px solid var(--line);font:500 12px var(--mono);color:var(--faint);display:flex;justify-content:space-between;align-items:center}
.cmd-header span{color:var(--warn);font-family:var(--mono);font-size:12px;text-transform:none;letter-spacing:0}
.cmd-body{padding:18px 20px;background:color-mix(in oklab,var(--bg) 70%,#000);font:400 13.5px/1.9 var(--mono);color:var(--ink);white-space:pre;overflow-x:auto}
.cmd-c{color:var(--faint);font-style:italic}.cmd-p{color:var(--ok)}.cmd-k{color:var(--c1)}.cmd-v{color:var(--err)}.cmd-ok{color:var(--ok)}

/* ── Band viz ─────────────────────────────────────── */
.band-viz{display:flex;flex-direction:column;gap:6px;margin:1rem 0}
.band-row{display:flex;align-items:center;gap:10px}
.band-label{width:70px;font-size:12px;color:var(--muted);text-align:right;flex-shrink:0}
.band-bar{height:24px;border-radius:5px;display:flex;align-items:center;padding:0 12px;font:600 12px var(--sans);overflow:hidden}

/* ── Exercise cards ───────────────────────────────── */
.ex-card{background:var(--s1);border:1px solid var(--line);border-radius:10px;padding:20px 24px;margin:12px 0;transition:border-color .15s}
.ex-card:hover{border-color:var(--line2)}
.ex-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.ex-num{width:32px;height:32px;border-radius:7px;background:var(--c5);color:var(--bg);font:600 14px var(--mono);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:none}
.ex-card h3{margin:0;font-size:15px;color:var(--ink);font-weight:600}
.diff{font:600 10px var(--mono);padding:2px 8px;border-radius:99px;margin-left:8px;letter-spacing:.06em}
.de{background:color-mix(in oklab,var(--lvE) 15%,transparent);color:var(--lvE);border:1px solid color-mix(in oklab,var(--lvE) 35%,transparent)}
.dm{background:color-mix(in oklab,var(--lvM) 15%,transparent);color:var(--lvM);border:1px solid color-mix(in oklab,var(--lvM) 35%,transparent)}
.dh{background:color-mix(in oklab,var(--lvH) 15%,transparent);color:var(--lvH);border:1px solid color-mix(in oklab,var(--lvH) 35%,transparent)}

/* ── Corr items & Accordion ───────────────────────── */
.corr-item{background:var(--s1);border:1px solid var(--line);border-radius:10px;margin:6px 0;overflow:hidden;transition:border-color .15s}
.corr-item:hover,.corr-item.open{border-color:var(--line2)}
.corr-q{padding:12px 16px;cursor:pointer;font-size:14px;font-weight:600;display:flex;justify-content:space-between;align-items:center;color:var(--ink)}
.corr-q:hover{background:var(--s2)}
.corr-a{padding:0 16px;max-height:0;overflow:hidden;transition:all .3s;font-size:14px;color:var(--muted);line-height:1.7}
.corr-a.open{padding:.15rem 16px .8rem;max-height:5000px}
.corr-arrow{color:var(--faint);transition:transform .3s;font-size:12px}
.corr-item.open .corr-arrow{transform:rotate(180deg)}
.accordion{background:var(--s1);border:1px solid var(--line);border-radius:10px;margin:6px 0;overflow:hidden;transition:border-color .15s}
.accordion:hover,.accordion.open{border-color:var(--line2)}
.accordion-head{padding:12px 16px;cursor:pointer;font-size:14px;font-weight:600;display:flex;justify-content:space-between;align-items:center;color:var(--ink);transition:background .15s}
.accordion-head:hover{background:var(--s2)}
.accordion-body{padding:0 16px;max-height:0;overflow:hidden;transition:all .3s;font-size:14px;color:var(--muted);line-height:1.7}
.accordion.open .accordion-body{padding:.15rem 16px .85rem;max-height:2000px}
.accordion-arrow{color:var(--faint);transition:transform .3s;font-size:12px;flex-shrink:0}
.accordion.open .accordion-arrow{transform:rotate(180deg)}

/* ── Gate grid ────────────────────────────────────── */
.gate-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin:.8rem 0}
.gate-card{background:var(--s1);border:1px solid var(--line);border-radius:10px;padding:16px;transition:border-color .15s}
.gate-card:hover{border-color:var(--line2)}
.gate-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.gate-icon{width:80px;height:50px;flex-shrink:0}
.gate-name{font-weight:600;font-size:15px;color:var(--ink)}
.gate-desc{font-size:13px;color:var(--muted);margin-top:2px}
.gate-card table{margin-top:8px}
.gate-card th,.gate-card td{padding:4px 10px;font-size:12px;text-align:center}
.gate-card td:first-child{font-weight:400;color:var(--muted)}

/* ── Ex group / inputs ────────────────────────────── */
.ex-group{margin:24px 0}
.ex-group h4{margin-bottom:12px}
.ex-row{display:flex;align-items:center;gap:12px;margin:6px 0;flex-wrap:wrap}
.ex-prompt{font-family:var(--mono);font-size:14px;color:var(--ink);min-width:180px}
.ex-input{background:var(--s2);border:1px solid var(--line);border-radius:7px;color:var(--ink);font-family:var(--mono);font-size:14px;padding:6px 12px;outline:none;transition:border-color .15s;width:130px}
.ex-input:focus{border-color:var(--c5)}
.ex-input.correct{border-color:var(--lvE)}
.ex-input.wrong{border-color:var(--lvH)}
.ex-feedback{font-size:16px;width:24px;text-align:center;flex-shrink:0;opacity:0;transition:opacity .3s}
.ex-feedback.visible{opacity:1}
.ex-feedback.ok{color:var(--ok)}.ex-feedback.ko{color:var(--err)}
.ex-check-btn{background:var(--c5);border:none;color:var(--bg);font-family:var(--sans);font-size:13px;font-weight:600;padding:8px 18px;border-radius:7px;cursor:pointer;transition:opacity .15s;margin-top:12px;box-shadow:none}
.ex-check-btn:hover{opacity:.85;transform:none;box-shadow:none}
.ex-score{margin-top:12px;padding:10px 16px;background:color-mix(in oklab,var(--ok) 10%,transparent);border:1px solid color-mix(in oklab,var(--ok) 30%,transparent);border-radius:7px;font-size:14px;color:var(--ok);display:none}

/* ── Topo / net schemas ───────────────────────────── */
.net-schema{overflow-x:auto;margin:16px 0;border-radius:10px;border:1px solid var(--line);background:var(--s1);padding:16px}
.topo-diagram{background:var(--s1);border:1px solid var(--line);border-radius:10px;padding:16px;margin:12px 0;overflow-x:auto}
.topo-diagram h4{margin:0 0 12px}

/* ── Config cards ─────────────────────────────────── */
.config-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:12px 0}
.config-card{background:var(--s1);border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:border-color .15s}
.config-card:hover{border-color:var(--line2)}
.config-card-head{padding:8px 12px;font:600 13px var(--mono);color:var(--ink);background:var(--s2);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.config-icon{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.config-icon.config-pc{background:color-mix(in oklab,var(--faint) 40%,transparent);border:1.5px solid var(--faint)}
.config-icon.config-router{background:color-mix(in oklab,var(--c1) 20%,transparent);border:1.5px solid var(--c1);border-radius:50%}
.config-icon.config-switch{background:color-mix(in oklab,var(--ok) 15%,transparent);border:1.5px solid var(--ok);width:16px;height:10px}
.config-icon.config-server{background:color-mix(in oklab,var(--c4) 15%,transparent);border:1.5px solid var(--c4)}
.config-card-body{padding:8px 12px}
.config-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:12.5px;gap:8px}
.config-row+.config-row{border-top:1px solid var(--line)}
.config-key{color:var(--muted);font-size:12px;font-weight:500;white-space:nowrap}
.config-val{font:400 12px var(--mono);color:var(--c5);text-align:right}
.config-iface{font:400 11px var(--mono);color:var(--warn);text-transform:uppercase;letter-spacing:.04em;padding:5px 0 2px;margin-top:4px;border-top:1px dashed var(--line)}
.config-iface:first-child{border-top:none;margin-top:0}

/* ── Page nav ─────────────────────────────────────── */
.page-nav{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:52px 0 56px;padding-top:0;border-top:none}
.page-nav-btn{background:var(--s1);border:1px solid var(--line);border-radius:10px;padding:16px 20px;text-decoration:none;color:inherit;transition:border-color .15s;display:flex;flex-direction:column;max-width:100%;transform:none!important;box-shadow:none!important}
.page-nav-btn:hover{border-color:var(--line2)}
.page-nav-btn.prev{align-items:flex-start}
.page-nav-btn.next{align-items:flex-end}
.page-nav-arrow{display:none}
.page-nav-dir{display:block;font:500 11.5px var(--mono);color:var(--faint);margin-bottom:5px;text-transform:none;letter-spacing:0}
.page-nav-title{display:block;font:600 15px var(--sans);color:var(--ink);margin-top:0}

/* ── Responsive ───────────────────────────────────── */
@media(max-width:768px){
  .nav-inner{padding:0 20px}
  .nav-links{-webkit-mask-image:linear-gradient(to right,transparent 0,#000 8px,#000 calc(100% - 16px),transparent 100%);mask-image:linear-gradient(to right,transparent 0,#000 8px,#000 calc(100% - 16px),transparent 100%)}
  .nav-btn{font-size:12px;padding:18px 10px 16px}
  .home-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  body{font-size:15px;line-height:1.65}
  nav{height:52px}
  .nav-inner{padding:0 16px}
  .nav-logo{font-size:14px;margin-right:16px}
  .nav-links{-webkit-mask-image:linear-gradient(to right,transparent 0,#000 12px,#000 calc(100% - 20px),transparent 100%);mask-image:linear-gradient(to right,transparent 0,#000 12px,#000 calc(100% - 20px),transparent 100%);scroll-snap-type:x mandatory}
  .nav-btn{font-size:11px;padding:18px 8px 16px;scroll-snap-align:start;flex-shrink:0}
  .page{padding-top:52px}
  .container{padding:32px 20px 60px}
  .hero{padding:40px 0 8px}
  .hero-title{font-size:36px}
  .hero-sub{font-size:15px}
  .home-grid{grid-template-columns:1fr}
  .section-title{font-size:28px}
  h2{font-size:18px;margin:32px 0 6px}
  h3{font-size:15px;margin:20px 0 6px}
  .device-grid{grid-template-columns:1fr;gap:0;background:none;border:1px solid var(--line);border-radius:12px}
  .device-card{border-bottom:1px solid var(--line);border-radius:0}
  .device-card:last-child{border-bottom:none}
  .config-cards{grid-template-columns:1fr}
  .gate-grid{grid-template-columns:1fr}
  .accordion-head,.corr-q,.lex-term{padding:10px 14px}
  .accordion.open .accordion-body,.corr-a.open,.lex-def.open{padding:.1rem 14px .7rem}
  .ex-row{gap:8px}
  .ex-prompt{min-width:140px;font-size:13px}
  .ex-input{width:100%;min-width:0}
  .dns-chain{flex-direction:column;align-items:stretch;gap:6px}
  .dns-arrow{transform:rotate(90deg);text-align:center;padding:0}
  .dns-box{width:100%}
  .calc-results{grid-template-columns:repeat(2,1fr)}
  .calc-row{flex-direction:column}
  .calc-wrap input{min-width:0;width:100%}
  .cisco-tabs{overflow-x:auto;scrollbar-width:none;-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 16px),transparent 100%);mask-image:linear-gradient(to right,#000 calc(100% - 16px),transparent 100%)}
  .cisco-tabs::-webkit-scrollbar{display:none}
  .cisco-tab{font-size:13px;padding:8px 12px 10px;white-space:nowrap}
  .band-row{gap:6px}
  .band-label{width:55px;font-size:11px}
  .page-nav{grid-template-columns:1fr}
  .cmd-body{white-space:pre-wrap;word-break:break-all;padding:14px 16px;font-size:12px}
  pre{font-size:12px;padding:14px 16px;white-space:pre-wrap;word-break:break-all}
  code{font-size:12px;word-break:break-all}
  td,th{padding:8px 12px;font-size:13px}
  th{font-size:11px}
  .sblock{padding-left:14px}
  .step::before{width:22px;height:22px;font-size:11px}
  .step p{font-size:14px}
  .topo-diagram,.net-schema{padding:12px}
  svg{min-width:0!important;width:100%!important;height:auto}
}
@media(max-width:480px){
  .hero-title{font-size:30px}
  .home-card{padding:18px 20px 20px}
  .home-card h3{font-size:15px}
  .section-title{font-size:24px}
}
