/* ——— Terminal Étudiant · shared stylesheet ——— */
:root, [data-theme="dark"]{
  --bg:#0A0A0A;
  --bg-1:#101010;
  --bg-2:#161616;
  --bg-3:#1C1C1C;
  --border:#1F1F1F;
  --border-2:#2A2A2A;
  --text:#E5E5E5;
  --text-2:#9CA3AF;
  --text-3:#6B7280;
  --text-4:#4B5563;
  --accent:#00FF85;
  --accent-dim:rgba(0,255,133,.12);
  --accent-line:rgba(0,255,133,.35);
  --warn:#FBBF24;
  --danger:#EF4444;
  --dot:rgba(255,255,255,.05);
}
[data-theme="light"]{
  --bg:#FAFAF7;
  --bg-1:#F4F4EF;
  --bg-2:#EEEEE8;
  --bg-3:#E5E5DD;
  --border:#E5E5DD;
  --border-2:#D4D4CB;
  --text:#0A0A0A;
  --text-2:#525252;
  --text-3:#737373;
  --text-4:#A3A3A3;
  --accent:#00A352;
  --accent-dim:rgba(0,163,82,.10);
  --accent-line:rgba(0,163,82,.45);
  --warn:#B45309;
  --danger:#DC2626;
  --dot:rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}}

body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:"Inter",ui-sans-serif,system-ui,sans-serif;
  font-size:14px;line-height:1.55;
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;
  background-image:radial-gradient(var(--dot) 1px, transparent 1px);
  background-size:24px 24px;
}

@media(hover:hover) and (pointer:fine){
  body{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><line x1='12' y1='2' x2='12' y2='22' stroke='%2300FF85' stroke-width='1'/><line x1='2' y1='12' x2='22' y2='12' stroke='%2300FF85' stroke-width='1'/><circle cx='12' cy='12' r='2' fill='none' stroke='%2300FF85' stroke-width='1'/></svg>") 12 12, crosshair;}
  a,button,summary,[role="button"]{cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><line x1='12' y1='2' x2='12' y2='22' stroke='%2300FF85' stroke-width='1.5'/><line x1='2' y1='12' x2='22' y2='12' stroke='%2300FF85' stroke-width='1.5'/><circle cx='12' cy='12' r='3' fill='%2300FF85'/></svg>") 12 12, pointer;}
}

::selection{background:var(--accent-dim);color:var(--text)}
a{color:inherit}
a:focus-visible,button:focus-visible,details>summary:focus-visible{outline:1px solid var(--accent);outline-offset:2px}

.mono{font-family:"JetBrains Mono",ui-monospace,monospace}
.tab{font-family:"JetBrains Mono",monospace;font-variant-numeric:tabular-nums}
.up{text-transform:uppercase;letter-spacing:.08em}
.muted{color:var(--text-2)}
.dim{color:var(--text-3)}
.acc{color:var(--accent)}

.skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:var(--bg);padding:8px 12px;z-index:100;font-family:"JetBrains Mono",monospace;font-size:12px}
.skip:focus{left:8px;top:8px}

/* Status bar */
.statusbar{
  position:sticky;top:0;z-index:60;
  background:var(--bg);border-bottom:1px solid var(--border);
  font-family:"JetBrains Mono",monospace;font-size:11px;
  height:30px;display:flex;align-items:center;
  padding:0 16px;gap:18px;color:var(--text-3);overflow:hidden;
}
.statusbar .sep{width:1px;height:14px;background:var(--border-2)}
.statusbar .led{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);margin-right:6px;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.statusbar a{color:var(--text-2);text-decoration:none}
.statusbar a:hover{color:var(--accent)}
.statusbar__live{color:var(--accent)}
.statusbar__time{margin-left:auto;color:var(--text-3)}
@media(max-width:760px){.statusbar .hide-sm{display:none}}

/* Nav */
.nav{
  position:sticky;top:30px;z-index:55;
  background:rgba(10,10,10,.85);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
  height:56px;display:flex;align-items:center;
}
[data-theme="light"] .nav{background:rgba(250,250,247,.85)}
.nav__inner{max-width:1440px;width:100%;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;font-family:"JetBrains Mono",monospace;font-weight:600;font-size:13px;letter-spacing:.02em;color:var(--text)}
.brand__glyph{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--accent);color:var(--accent);font-size:13px;font-weight:700}
.brand__name strong{color:var(--text)}
.brand__name span{color:var(--text-3)}
.nav__links{display:flex;gap:6px;margin-left:auto;align-items:center;font-family:"JetBrains Mono",monospace;font-size:12px}
.nav__links a{padding:6px 10px;color:var(--text-2);text-decoration:none;border:1px solid transparent;letter-spacing:.04em}
.nav__links a:hover{color:var(--text);background:var(--bg-1)}
.nav__links a[aria-current="page"]{color:var(--accent);border-color:var(--border-2);background:var(--bg-1)}
.nav__cta{background:var(--accent);color:#000!important;font-weight:600;padding:8px 14px;border:1px solid var(--accent)!important}
.nav__cta:hover{background:transparent;color:var(--accent)!important}
.theme-toggle{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border-2);background:var(--bg-1);color:var(--text-2);font-family:"JetBrains Mono",monospace;font-size:13px;cursor:pointer}
.theme-toggle:hover{color:var(--accent);border-color:var(--accent-line)}
/* Hamburger button */
.nav__hamburger{
  display:none;width:30px;height:30px;
  border:1px solid var(--border-2);background:var(--bg-1);color:var(--text-2);
  font-family:"JetBrains Mono",monospace;font-size:15px;
  align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;
  transition:color .15s,border-color .15s;padding:0;
}
.nav__hamburger:hover{color:var(--accent);border-color:var(--accent-line)}

@media(max-width:860px){
  .nav__hamburger{display:inline-flex;margin-left:auto}
  /* Force masquage de tout le menu (CTA inclus) — visible uniquement dans le dropdown hamburger */
  .nav__links{
    display:none;
    position:fixed;top:86px;left:0;right:0;
    background:var(--bg);border-bottom:1px solid var(--border);
    flex-direction:column;padding:8px;gap:0;
    z-index:54;max-height:calc(100vh - 86px);overflow-y:auto;margin-left:0;
  }
  [data-theme="light"] .nav__links{background:var(--bg)}
  .nav__links.is-open{display:flex}
  .nav__links a{
    display:flex;width:100%;padding:12px 16px;
    border:0;border-bottom:1px solid var(--border);background:var(--bg-1);
  }
  .nav__links a:last-child{border-bottom:0}
  .nav__links .theme-toggle{
    display:inline-flex;width:100%;height:44px;border:0;
    border-bottom:1px solid var(--border);background:var(--bg-1);
    border-radius:0;justify-content:center;
  }
  .nav__links .nav__cta{
    margin-top:4px;
    border:1px solid var(--accent)!important;border-bottom:1px solid var(--accent)!important;
  }
}

.wrap{max-width:1440px;margin:0 auto;padding:0 24px}

/* Crumb */
.crumb{padding:20px 0 10px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);letter-spacing:.04em}
.crumb a{text-decoration:none;color:var(--text-3)}
.crumb a:hover{color:var(--accent)}
.crumb .slash{margin:0 8px;color:var(--text-4)}
.crumb .now{color:var(--text-2)}

/* Hero */
.hero{padding:32px 0 24px;position:relative;border-bottom:1px solid var(--border)}
.hero__meta{display:flex;gap:16px;align-items:center;flex-wrap:wrap;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);margin-bottom:24px;letter-spacing:.04em}
.hero__meta .tag{padding:3px 8px;border:1px solid var(--border-2);background:var(--bg-1);color:var(--text-2)}
.hero__meta .tag.acc{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}
.hero h1{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:clamp(32px,5.4vw,68px);line-height:1.04;letter-spacing:-.025em;margin:0 0 18px;max-width:22ch}
.hero h1 .acc{color:var(--accent)}
.hero__lede{font-size:clamp(15px,1.4vw,18px);line-height:1.6;max-width:64ch;color:var(--text-2);margin:0 0 28px}
.hero__lede strong{color:var(--text);font-weight:500}
.hero__lede .acc{color:var(--accent)}

/* KPI strip */
.kpi{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);background:var(--bg-1)}
.kpi__cell{padding:18px 20px;border-right:1px solid var(--border)}
.kpi__cell:last-child{border-right:0}
.kpi__label{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-3)}
.kpi__value{font-family:"JetBrains Mono",monospace;font-size:28px;font-weight:600;margin-top:6px;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.kpi__delta{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--accent);margin-top:4px}
.kpi__delta.warn{color:var(--warn)}
@media(max-width:860px){.kpi{grid-template-columns:repeat(2,1fr)}.kpi__cell:nth-child(2){border-right:0}.kpi__cell:nth-child(-n+2){border-bottom:1px solid var(--border)}}

/* Section heads */
.section{padding:64px 0 0;position:relative}
.section__head{display:flex;align-items:baseline;gap:14px;margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.section__id{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase}
.section__title{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:clamp(22px,2.6vw,32px);line-height:1.1;letter-spacing:-.015em;margin:0;flex:1}
.section__title .acc{color:var(--accent)}
.section__hint{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);letter-spacing:.04em}

/* TOC list */
.toc{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--border)}
@media(max-width:780px){.toc{grid-template-columns:1fr}}
.toc__item{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:14px 18px;text-decoration:none;color:var(--text);border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-1);transition:background .15s;font-family:"JetBrains Mono",monospace;font-size:13px}
.toc__item:nth-child(2n){border-right:0}
.toc__item:hover{background:var(--bg-2);color:var(--accent)}
.toc__item .id{color:var(--text-3);font-size:11px}
.toc__item .name strong{color:var(--text);font-weight:500}
.toc__item:hover .name strong{color:var(--accent)}
.toc__item .sub{color:var(--text-3);font-weight:400;font-size:11px;display:block;margin-top:2px}
.toc__badge{font-size:10px;padding:3px 8px;border:1px solid var(--border-2);background:var(--bg);color:var(--text-2);letter-spacing:.06em}
.toc__badge.gold{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}
.toc__badge.warn{color:var(--warn);border-color:rgba(251,191,36,.35)}

/* Tableau */
.tbl-wrap{border:1px solid var(--border);background:var(--bg-1);overflow:hidden}
.tbl-head{display:flex;align-items:center;gap:14px;padding:10px 16px;background:var(--bg-2);border-bottom:1px solid var(--border);font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);letter-spacing:.08em}
.tbl-head .dot{width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 6px var(--accent)}
.tbl-head .ctrls{margin-left:auto;display:flex;gap:6px}
.tbl-head .ctrls span{width:10px;height:10px;border:1px solid var(--border-2);border-radius:50%}
.tbl-scroll{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;min-width:980px;font-family:"JetBrains Mono",monospace;font-size:12px;font-variant-numeric:tabular-nums}
.tbl thead th{position:sticky;top:86px;background:var(--bg-1);text-align:left;padding:12px 14px;font-weight:500;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);border-bottom:1px solid var(--border);white-space:nowrap}
.tbl tbody td{padding:14px;border-bottom:1px solid var(--border);vertical-align:middle}
.tbl tbody tr{transition:background .12s}
.tbl tbody tr:hover{background:var(--bg-2)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl .idx{color:var(--text-3);width:32px}
.tbl .name{font-weight:500;color:var(--text);min-width:170px}
.tbl .name small{display:block;color:var(--text-3);font-size:10px;font-weight:400;margin-top:2px;letter-spacing:.04em}
.tbl .score{font-weight:600;font-size:14px;color:var(--accent)}
.tbl .score.mid{color:var(--text)}
.tbl .score.low{color:var(--warn)}
.tbl .bar{display:inline-block;width:60px;height:4px;background:var(--bg-3);border:1px solid var(--border);margin-left:8px;vertical-align:middle;position:relative;overflow:hidden}
.tbl .bar i{position:absolute;left:0;top:0;bottom:0;background:var(--accent);display:block}
.tbl .yes{color:var(--accent);font-weight:600}
.tbl .no{color:var(--text-4)}
.tbl .price{font-weight:600;color:var(--text);white-space:nowrap}
.tbl .price small{color:var(--text-3);font-weight:400;font-size:10px}
.tbl__note{padding:10px 16px;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);background:var(--bg-2);border-top:1px solid var(--border);letter-spacing:.04em}

/* Chips */
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.chip{font-family:"JetBrains Mono",monospace;font-size:11px;padding:5px 10px;border:1px solid var(--border-2);background:var(--bg-1);color:var(--text-2);cursor:pointer;letter-spacing:.04em}
.chip:hover{color:var(--text);border-color:var(--text-3)}
.chip.active{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}

/* Fiche / residence card */
.fiche{margin-top:28px;border:1px solid var(--border);background:var(--bg-1);position:relative}
.fiche__header{display:flex;align-items:center;gap:14px;padding:12px 18px;background:var(--bg-2);border-bottom:1px solid var(--border);font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);letter-spacing:.04em;flex-wrap:wrap}
.fiche__header .id{color:var(--accent);font-weight:600}
.fiche__header .badges{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}
.badge{font-family:"JetBrains Mono",monospace;font-size:10px;padding:3px 7px;border:1px solid var(--accent-line);color:var(--accent);background:var(--accent-dim);letter-spacing:.08em}
.badge.warn{color:var(--warn);border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.badge.neutral{color:var(--text-2);border-color:var(--border-2);background:var(--bg-1)}

.fiche__body{display:grid;grid-template-columns:1fr 1.1fr;gap:0}
@media(max-width:980px){.fiche__body{grid-template-columns:1fr}}
.fiche__media{padding:18px;border-right:1px solid var(--border);position:relative}
@media(max-width:980px){.fiche__media{border-right:0;border-bottom:1px solid var(--border)}}
.photo{position:relative;aspect-ratio:5/3;width:100%;border:1px solid var(--border);background:var(--bg-2);background-image:linear-gradient(135deg, transparent 49.5%, var(--border) 49.5% 50.5%, transparent 50.5%),linear-gradient(45deg, transparent 49.5%, var(--border) 49.5% 50.5%, transparent 50.5%);display:flex;align-items:center;justify-content:center;font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase}
.photo--filled{
  background-size:cover;background-position:center;
  background-image:none;
  color:transparent;
}
.photo--filled::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,.55) 100%);
  pointer-events:none;
}
.photo--filled .marks span{color:var(--accent);text-shadow:0 0 4px rgba(0,0,0,.6)}
.photo--filled .photo__cap{
  position:absolute;left:10px;bottom:8px;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;
  color:#fff;text-transform:uppercase;z-index:2;
}
.photo .marks{position:absolute;inset:0;pointer-events:none}
.photo .marks span{position:absolute;font-family:"JetBrains Mono",monospace;font-size:9px;color:var(--accent);letter-spacing:.1em}
.photo .marks .tl{left:8px;top:8px}
.photo .marks .tr{right:8px;top:8px}
.photo .marks .bl{left:8px;bottom:8px}
.photo .marks .br{right:8px;bottom:8px}

.meta-grid{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border);font-family:"JetBrains Mono",monospace;font-size:11px}
.meta-grid > div{padding:8px 12px;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.meta-grid > div:nth-child(2n){border-right:0}
.meta-grid > div:nth-last-child(-n+2){border-bottom:0}
.meta-grid .k{color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-size:9px;margin-bottom:2px}
.meta-grid .v{color:var(--text);font-weight:500}

.fiche__main{padding:24px}
.fiche__name{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:clamp(22px,3vw,34px);line-height:1.05;letter-spacing:-.015em;margin:4px 0 4px}
.fiche__addr{display:flex;align-items:center;gap:8px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);margin-bottom:14px;letter-spacing:.04em;flex-wrap:wrap}
.fiche__addr .pin{color:var(--accent)}

.score-block{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:center;padding:18px;border:1px solid var(--border);background:var(--bg-2);margin-bottom:18px}
.score-num{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:56px;line-height:1;color:var(--accent);letter-spacing:-.04em;font-variant-numeric:tabular-nums}
.score-num .of{font-size:18px;color:var(--text-3);font-weight:400;margin-left:2px}
.subscore{display:grid;grid-template-columns:1fr;gap:8px;font-family:"JetBrains Mono",monospace;font-size:11px}
.subscore .row{display:grid;grid-template-columns:90px 1fr 36px;gap:10px;align-items:center}
.subscore .lbl{color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-size:10px}
.subscore .track{height:4px;background:var(--bg-3);border:1px solid var(--border);position:relative}
.subscore .track i{position:absolute;left:0;top:0;bottom:0;background:var(--accent);display:block}
.subscore .val{color:var(--text);text-align:right;font-weight:500}

.fiche__desc{font-family:"Inter",sans-serif;font-size:14.5px;line-height:1.65;color:var(--text-2);margin:0 0 18px}
.fiche__desc strong{color:var(--text);font-weight:500}
.fiche__desc .acc{color:var(--accent)}

.pf{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:4px 0 18px}
@media(max-width:680px){.pf{grid-template-columns:1fr}}
.pf__col h4{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 8px;color:var(--text-3);display:flex;align-items:center;gap:8px}
.pf__col h4::before{content:">";color:var(--accent)}
.pf__col ul{list-style:none;padding:0;margin:0;font-size:13px;line-height:1.55;color:var(--text-2);font-family:"JetBrains Mono",monospace}
.pf__col li{padding:3px 0 3px 18px;position:relative}
.pf__col.plus li::before{content:"+";position:absolute;left:0;color:var(--accent);font-weight:700}
.pf__col.moins li::before{content:"-";position:absolute;left:0;color:var(--warn);font-weight:700}

.terminal-quote{margin:18px 0;padding:14px 16px;background:var(--bg-2);border-left:2px solid var(--accent);font-family:"JetBrains Mono",monospace;font-size:13px;line-height:1.6;color:var(--text);position:relative}
.terminal-quote::before{content:"$ lea.note --terrain";display:block;font-size:10px;color:var(--text-3);margin-bottom:8px;letter-spacing:.04em}
.terminal-quote::after{content:"_";display:inline-block;color:var(--accent);margin-left:2px;animation:blink 1s steps(2) infinite}
@keyframes blink{50%{opacity:0}}

.price-row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;padding:14px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin:18px 0;font-family:"JetBrains Mono",monospace}
.price-row .from{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.12em}
.price-row .val{font-size:32px;font-weight:600;color:var(--text);letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.price-row .val .cur{color:var(--accent)}
.price-row .unit{font-size:11px;color:var(--text-3);letter-spacing:.04em}

.tags{display:flex;gap:6px;flex-wrap:wrap;margin:0 0 18px}
.tag{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.08em;padding:4px 8px;border:1px solid var(--border-2);background:var(--bg);color:var(--text-2)}
.tag.on{color:var(--accent);border-color:var(--accent-line);background:var(--accent-dim)}

.btn{display:inline-flex;align-items:center;gap:10px;background:transparent;color:var(--text);text-decoration:none;padding:10px 16px;border:1px solid var(--border-2);font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;transition:all .15s;font-weight:500}
.btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}
.btn--primary{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}
.btn--primary:hover{background:transparent;color:var(--accent)}
.btn .arr{font-family:"JetBrains Mono",monospace;transition:transform .15s}
.btn:hover .arr{transform:translateX(3px)}

.spark{display:inline-block;vertical-align:middle;width:80px;height:20px}
.spark path{fill:none;stroke:var(--accent);stroke-width:1.2}
.spark .area{fill:var(--accent-dim);stroke:none}

/* Tips */
.tips{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border);background:var(--bg-1)}
@media(max-width:780px){.tips{grid-template-columns:1fr}}
.tip{padding:24px;border-right:1px solid var(--border)}
.tip:last-child{border-right:0}
@media(max-width:780px){.tip{border-right:0;border-bottom:1px solid var(--border)}.tip:last-child{border-bottom:0}}
.tip__id{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--accent);letter-spacing:.12em;margin-bottom:14px}
.tip h3{font-family:"JetBrains Mono",monospace;font-size:18px;font-weight:600;line-height:1.2;margin:0 0 10px;letter-spacing:-.01em}
.tip p{margin:0;font-size:13px;line-height:1.6;color:var(--text-2)}
.tip p strong{color:var(--text)}

/* FAQ */
.faq{margin:0;border:1px solid var(--border);background:var(--bg-1)}
.faq details{border-bottom:1px solid var(--border)}
.faq details:last-child{border-bottom:0}
.faq summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;padding:16px 20px;font-family:"JetBrains Mono",monospace;font-size:14px;font-weight:500;line-height:1.4;transition:background .12s}
.faq summary:hover{background:var(--bg-2)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q-id{font-size:10px;color:var(--text-3);letter-spacing:.1em;font-weight:400}
.faq summary .q-text{color:var(--text)}
.faq summary .q-plus{font-family:"JetBrains Mono",monospace;font-size:18px;line-height:1;color:var(--accent);transition:transform .25s ease;width:18px;text-align:center}
.faq details[open] summary{background:var(--bg-2)}
.faq details[open] summary .q-plus{transform:rotate(45deg)}
.faq .a{padding:0 20px 20px 56px;color:var(--text-2);font-size:13.5px;line-height:1.65;max-width:78ch}
.faq .a strong{color:var(--text)}
.faq .a p{margin:0 0 10px}
.faq .a p:last-child{margin-bottom:0}
@media(max-width:680px){.faq summary{font-size:13px;padding:14px 16px}.faq .a{padding-left:16px}}

/* Final CTA */
.final{margin-top:64px;border:1px solid var(--border);background:var(--bg-1);padding:48px;position:relative;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--accent-dim) 1px, transparent 1px);background-size:100% 32px;opacity:.5;pointer-events:none}
.final__id{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--accent);letter-spacing:.12em;margin-bottom:14px;position:relative}
.final h2{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:clamp(28px,3.6vw,42px);line-height:1.05;letter-spacing:-.02em;margin:0 0 14px;max-width:22ch;position:relative}
.final p{max-width:62ch;font-size:15px;color:var(--text-2);line-height:1.6;position:relative;margin:0 0 24px}
.final__btns{display:flex;gap:12px;flex-wrap:wrap;position:relative}
@media(max-width:680px){.final{padding:28px 20px}}

.author{display:flex;gap:14px;align-items:center;margin-top:24px;padding:16px;border:1px solid var(--border);background:var(--bg);position:relative;font-family:"JetBrains Mono",monospace;font-size:12px}
.author .av{width:44px;height:44px;border:1px solid var(--accent-line);background:var(--accent-dim);display:inline-flex;align-items:center;justify-content:center;color:var(--accent);font-weight:600;font-size:14px;flex-shrink:0}
.author .who{line-height:1.5;color:var(--text-2)}
.author .who b{display:block;color:var(--text);font-weight:600;font-size:13px;margin-bottom:2px}

/* Longform */
.longform{margin-top:40px;display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:48px}
@media(max-width:980px){.longform{grid-template-columns:1fr}}
.longform h2{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:clamp(20px,2.2vw,26px);line-height:1.2;letter-spacing:-.01em;margin:36px 0 10px}
.longform h2:first-of-type{margin-top:0}
.longform h3{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:16px;line-height:1.2;margin:24px 0 8px;color:var(--text)}
.longform p{font-size:14.5px;line-height:1.7;margin:0 0 12px;max-width:64ch;color:var(--text-2)}
.longform p strong{color:var(--text);font-weight:500}
.longform p .acc{color:var(--accent)}
.longform ul{font-size:14.5px;line-height:1.7;color:var(--text-2);padding-left:22px;margin:0 0 14px;max-width:64ch}
.longform ul li{margin-bottom:4px}
.longform .pull{font-family:"JetBrains Mono",monospace;font-size:18px;line-height:1.35;padding:14px 18px;border:1px solid var(--border);background:var(--bg-1);border-left:2px solid var(--accent);margin:20px 0;color:var(--text)}

.aside-card{padding:16px;border:1px solid var(--border);background:var(--bg-1);margin-bottom:14px;font-family:"JetBrains Mono",monospace;font-size:12px}
.aside-card .k{color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;font-size:10px;margin-bottom:8px}
.aside-card .v{color:var(--text);line-height:1.55}
.aside-card .v.acc{color:var(--accent);font-size:18px;font-weight:600}

/* Footer */
footer.foot{margin-top:80px;border-top:1px solid var(--border);padding:40px 0 28px;background:var(--bg-1)}
.foot__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
@media(max-width:780px){.foot__grid{grid-template-columns:1fr 1fr}}
.foot h4{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 12px;color:var(--text-3)}
.foot ul{list-style:none;padding:0;margin:0;font-family:"JetBrains Mono",monospace;font-size:12px;line-height:2}
.foot a{color:var(--text-2);text-decoration:none}
.foot a:hover{color:var(--accent)}
.foot .colophon{margin-top:32px;padding-top:16px;border-top:1px solid var(--border);font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;letter-spacing:.04em}

/* Progress */
#progress{position:fixed;left:0;top:0;height:2px;background:var(--accent);width:0;z-index:70;transition:width .1s linear;box-shadow:0 0 8px var(--accent)}

@keyframes coord-blink{0%,100%{opacity:1}50%{opacity:.5}}
.live{color:var(--accent);animation:coord-blink 2s ease-in-out infinite}

/* Home-specific */
.home-feat{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:0}
@media(max-width:980px){.home-feat{grid-template-columns:1fr}}
.home-feat.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:680px){.home-feat.grid-2{grid-template-columns:1fr}}
.feat-card{border:1px solid var(--border);background:var(--bg-1);padding:0;display:flex;flex-direction:column;text-decoration:none;color:var(--text);transition:border-color .15s,transform .15s}
.feat-card:hover{border-color:var(--accent-line);transform:translateY(-2px)}
.feat-card__hdr{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-2);border-bottom:1px solid var(--border);font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);letter-spacing:.06em}
.feat-card__hdr .id{color:var(--accent);font-weight:600}
.feat-card__hdr .rank{margin-left:auto;color:var(--text-2)}
.feat-card .photo{aspect-ratio:4/3;border:0;border-bottom:1px solid var(--border)}
.feat-card__body{padding:16px;flex:1;display:flex;flex-direction:column}
.feat-card h3{font-family:"JetBrains Mono",monospace;font-weight:600;font-size:18px;margin:0 0 4px;letter-spacing:-.01em}
.feat-card .meta{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--text-3);letter-spacing:.06em;margin-bottom:10px}
.feat-card .desc{font-size:13px;color:var(--text-2);line-height:1.55;margin:0 0 14px;flex:1}
.feat-card__foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:12px;font-family:"JetBrains Mono",monospace;font-size:12px}
.feat-card__foot .price{font-weight:600;color:var(--text)}
.feat-card__foot .price .cur{color:var(--accent)}
.feat-card__foot .score{color:var(--accent);font-weight:600}

.benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);background:var(--bg-1)}
@media(max-width:980px){.benefits{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.benefits{grid-template-columns:1fr}}
.benefits > div{padding:20px;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
@media(min-width:981px){.benefits > div:nth-child(4n){border-right:0}.benefits > div:nth-last-child(-n+4){border-bottom:0}}
@media(max-width:980px) and (min-width:561px){.benefits > div:nth-child(2n){border-right:0}.benefits > div:nth-last-child(-n+2){border-bottom:0}}
@media(max-width:560px){.benefits > div{border-right:0}.benefits > div:last-child{border-bottom:0}}
.benefits .glyph{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border:1px solid var(--accent-line);color:var(--accent);font-family:"JetBrains Mono",monospace;font-weight:600;margin-bottom:10px}
.benefits h3{font-family:"JetBrains Mono",monospace;font-size:14px;font-weight:600;margin:0 0 6px}
.benefits p{margin:0;font-size:12.5px;color:var(--text-2);line-height:1.55}

/* Gallery (fiche detail) */
.gallery{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:480px}
@media(max-width:780px){.gallery{grid-template-columns:1fr 1fr;height:360px}}
.gallery .photo{height:100%;aspect-ratio:auto}
.gallery > :nth-child(1){grid-row:span 2}
@media(max-width:780px){.gallery > :nth-child(1){grid-row:span 1;grid-column:span 2}}

/* Quartiers grid */
.q-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media(max-width:780px){.q-grid{grid-template-columns:1fr}}
.q-card{border:1px solid var(--border);background:var(--bg-1);padding:20px}
.q-card__hdr{display:flex;align-items:baseline;gap:10px;margin-bottom:10px;font-family:"JetBrains Mono",monospace}
.q-card__hdr .id{color:var(--accent);font-size:11px;letter-spacing:.08em}
.q-card h3{font-family:"JetBrains Mono",monospace;font-size:22px;font-weight:600;margin:0;letter-spacing:-.01em}
.q-card .vibe{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--text-3);margin:0 0 12px;letter-spacing:.06em}
.q-card p{font-size:13.5px;color:var(--text-2);line-height:1.6;margin:0 0 12px}
.q-card .qmeta{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-family:"JetBrains Mono",monospace;font-size:11px;margin:10px 0 12px}
.q-card .qmeta > div{padding:6px 8px;border:1px solid var(--border);background:var(--bg-2)}
.q-card .qmeta .k{color:var(--text-3);text-transform:uppercase;font-size:9px;letter-spacing:.08em;margin-bottom:2px}
.q-card .qmeta .v{color:var(--text);font-weight:500}
.q-card .links{display:flex;gap:6px;flex-wrap:wrap;font-family:"JetBrains Mono",monospace;font-size:11px}
.q-card .links a{padding:3px 8px;border:1px solid var(--border-2);background:var(--bg);color:var(--text-2);text-decoration:none}
.q-card .links a:hover{color:var(--accent);border-color:var(--accent-line)}

/* APL calc visual */
.calc{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border);background:var(--bg-1);font-family:"JetBrains Mono",monospace}
@media(max-width:780px){.calc{grid-template-columns:1fr}}
.calc__col{padding:20px;border-right:1px solid var(--border)}
.calc__col:last-child{border-right:0;background:var(--accent-dim)}
@media(max-width:780px){.calc__col{border-right:0;border-bottom:1px solid var(--border)}}
.calc .k{font-size:10px;color:var(--text-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.calc .v{font-size:32px;font-weight:600;letter-spacing:-.02em;color:var(--text);font-variant-numeric:tabular-nums}
.calc__col:last-child .v{color:var(--accent)}
.calc .sub{font-size:11px;color:var(--text-3);margin-top:4px}
.calc .op{font-size:32px;color:var(--text-3);margin-right:8px;font-weight:300}

/* APL table simple */
.simple-tbl{width:100%;border-collapse:collapse;font-family:"JetBrains Mono",monospace;font-size:12px;border:1px solid var(--border);background:var(--bg-1)}
.simple-tbl th{text-align:left;padding:10px 14px;background:var(--bg-2);border-bottom:1px solid var(--border);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-weight:500}
.simple-tbl td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text-2)}
.simple-tbl tr:last-child td{border-bottom:0}
.simple-tbl td:first-child{color:var(--text);font-weight:500}
.simple-tbl tr:hover td{background:var(--bg-2)}

/* Simple-tbl scroll on mobile */
.simple-tbl-wrap{overflow-x:auto}

/* ——— Responsive globals ——— */
@media(max-width:680px){
  .section{padding:40px 0 0}
  .wrap{padding:0 16px}
  .hero{padding:24px 0 18px}
  .final{padding:28px 20px}
  .section__head{flex-wrap:wrap;gap:8px}
  .section__hint{width:100%;font-size:10px}
  .fiche__header{font-size:10px;gap:8px;padding:10px 14px}
  .fiche__main{padding:16px}
  .score-num{font-size:44px}
  .score-block{grid-template-columns:auto 1fr;gap:12px;padding:14px}
  .meta-grid{font-size:10px}
}
@media(max-width:480px){
  .foot__grid{grid-template-columns:1fr}
  .foot .colophon{flex-direction:column;gap:4px}
  .kpi{grid-template-columns:repeat(2,1fr)}
  .kpi__cell:nth-child(2){border-right:0}
  .kpi__cell:nth-child(-n+2){border-bottom:1px solid var(--border)}
  .kpi__value{font-size:22px}
  .hero h1{font-size:28px}
  .price-row .val{font-size:26px}
  .toc{grid-template-columns:1fr}
  .toc__item{border-right:0}
  .tips{grid-template-columns:1fr}
  .tip{border-right:0;border-bottom:1px solid var(--border)}
  .tip:last-child{border-bottom:0}
  .pf{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;height:auto}
  .gallery > :nth-child(1){grid-row:span 1;grid-column:span 1}
  .gallery .photo{height:220px}
  .feat-card .photo{aspect-ratio:3/2}
}
