/* SeatFR — Swiss / seat-map "blueprint" design system. Distinct from all others. */
:root{
  --bg:#ffffff; --bg-2:#f4f6f9; --surface:#ffffff; --ink:#13161d; --ink-2:#454d5c; --muted:#7b8494;
  --blue:#2456e6; --blue-d:#1740bd; --blue-wash:#eaf0fe; --line:#e4e7ee; --line-2:#d2d7e2;
  --ok:#1f9d57; --warn:#d98a16; --vip:#7c3aed;
  --sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'Space Mono','SFMono-Regular',Menlo,monospace;
  --wrap:1180px; --radius:6px;
  --sh-1:0 1px 0 var(--line),0 1px 3px rgba(19,22,29,.04);
  --sh-2:0 10px 30px -16px rgba(19,22,29,.22);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:88px}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--sans);font-weight:800;line-height:1.12;letter-spacing:-.02em;color:var(--ink)}
a{color:var(--blue-d);text-decoration:none}a:hover{color:var(--blue)}
.prose a{text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:.07em}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 28px}
.skip{position:absolute;left:-999px}.skip:focus{left:8px;top:8px;background:var(--blue);color:#fff;padding:8px 14px;z-index:50;border-radius:6px}
.ic{width:1.05em;height:1.05em;vertical-align:-.16em;flex:none}
.mono{font-family:var(--mono)}
::selection{background:var(--blue-wash)}

/* ── Header: two rows (id row + full-width mono nav band) ── */
.site-header{position:sticky;top:0;z-index:30;background:var(--surface)}
.site-header__top{border-bottom:1px solid var(--line-2)}
.site-header__topin{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:13px 28px}
.brand{display:inline-flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}
.brand__mark{display:grid;place-items:center;width:32px;height:32px;border-radius:6px;background:var(--blue);color:#fff}
.brand__mark .ic{width:18px;height:18px}
.brand__name{font-weight:800;font-size:22px;letter-spacing:-.03em}
.site-header__util{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.site-header__util .ic{color:var(--blue);width:15px;height:15px}
.site-header__navband{border-bottom:2px solid var(--ink);background:var(--bg-2)}
.mainnav{display:flex;gap:0;align-items:stretch}
.mainnav__link{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;color:var(--ink-2);padding:12px 20px;border-right:1px solid var(--line-2)}
.mainnav__link:first-child{border-left:1px solid var(--line-2)}
.mainnav__idx{font-size:10px;color:var(--muted)}
.mainnav__link:hover{color:var(--blue-d);background:var(--surface)}
.mainnav__link:hover .mainnav__idx{color:var(--blue)}
.mainnav__link.is-active{color:#fff;background:var(--blue)}.mainnav__link.is-active .mainnav__idx{color:#bcd0ff}
.navtoggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}.navtoggle span{width:24px;height:2px;background:var(--ink)}
.mobilenav{display:none;flex-direction:column;padding:6px 28px 16px;border-bottom:2px solid var(--ink);background:var(--bg-2)}
.mobilenav a{display:flex;align-items:center;gap:10px;padding:13px 4px;border-bottom:1px solid var(--line-2);text-decoration:none;color:var(--ink);font-family:var(--mono);font-size:13px;text-transform:uppercase}
.mobilenav a:last-child{border-bottom:0}.mobilenav .mainnav__idx{font-size:11px}
.site-header.is-open .mobilenav{display:flex}

/* ── Breadcrumb (lives inside the FICHE panel) ── */
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:7px;margin:0;padding:0;font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.crumbs li::after{content:"/";margin-left:7px;color:var(--line-2)}.crumbs li:last-child::after{content:""}
.crumbs a{color:var(--ink-2);text-decoration:none}.crumbs a:hover{color:var(--blue)}.crumbs [aria-current]{color:var(--blue-d)}

/* ── Page: datasheet, FICHE panel on LEFT ── */
.page{padding:40px 0 70px}
.page__grid{display:grid;grid-template-columns:272px minmax(0,1fr);gap:48px;align-items:start}
.page__body{min-width:0;max-width:760px}

/* FICHE technical panel (sticky left) */
.fiche{position:sticky;top:24px}
.fiche__card{border:2px solid var(--ink);border-radius:var(--radius);background:var(--surface);box-shadow:var(--sh-2)}
.fiche__tag{font-family:var(--mono);font-size:11px;letter-spacing:.28em;font-weight:700;color:#fff;background:var(--ink);margin:0;padding:9px 16px}
.fiche__rows{margin:0;border-bottom:1px solid var(--line-2)}
.fiche__row{display:flex;justify-content:space-between;gap:12px;padding:9px 16px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11.5px}
.fiche__row:last-child{border-bottom:0}
.fiche__row dt{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin:0}
.fiche__row dd{margin:0;color:var(--ink);font-weight:700;text-align:right;word-break:break-word}
.fiche__crumbs{padding:11px 16px;border-bottom:1px solid var(--line-2)}
.fiche__legend{padding:13px 16px;border-bottom:1px solid var(--line-2)}
.fiche__legend-lbl,.fiche__toc-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 10px}
.fiche__legend ul{list-style:none;margin:0;padding:0;display:grid;gap:7px}
.fiche__legend li{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink-2)}
.fiche__sw{width:12px;height:12px;border-radius:3px;flex:none;border:1px solid rgba(0,0,0,.12)}
.fiche__sw--fosse{background:var(--blue)}.fiche__sw--grad{background:var(--blue-wash);border-color:var(--blue)}.fiche__sw--vip{background:var(--vip)}
.fiche__toc{padding:13px 16px}
.fiche__toc a{display:flex;gap:9px;align-items:baseline;font-size:13px;color:var(--ink-2);text-decoration:none;line-height:1.35;padding:5px 0;border-bottom:1px dashed var(--line)}
.fiche__toc a:last-child{border-bottom:0}
.fiche__toc a:hover{color:var(--blue-d)}
.fiche__toc-n{font-family:var(--mono);font-size:10.5px;color:var(--muted);flex:none}
.fiche__toc a:hover .fiche__toc-n{color:var(--blue)}
.page__head{margin-bottom:30px;padding-bottom:22px;border-bottom:2px solid var(--ink)}
.page__head h1{font-size:clamp(30px,4.2vw,46px);margin:0 0 16px;letter-spacing:-.03em}
.page__intro{font-size:19px;color:var(--ink-2);line-height:1.55}.page__intro p{margin:.4em 0}
.page__meta{margin:16px 0 0;font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.block{margin:34px 0}
.block h2{font-size:clamp(22px,2.8vw,30px);margin:0 0 14px;display:flex;align-items:baseline;gap:12px}
.block h2::before{content:"§";font-family:var(--mono);font-size:.6em;color:var(--blue);font-weight:400}
.block h3{font-size:19px;margin:0 0 10px}
.prose p{margin:0 0 16px;color:var(--ink-2)}.prose strong{color:var(--ink)}
.prose ul,.prose ol{padding-left:22px}.prose li{margin:7px 0;color:var(--ink-2)}
.rich-list{padding-left:0;list-style:none;display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.rich-list li{position:relative;padding:12px 14px 12px 40px;background:var(--surface);color:var(--ink-2)}
.rich-list li::before{content:"";position:absolute;left:14px;top:15px;width:12px;height:12px;border:2px solid var(--blue);border-radius:3px;background:var(--blue-wash)}

/* ── Verdict (rare) ── */
.verdict{display:flex;gap:22px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);padding:24px;margin:30px 0}
.verdict__score{flex:none;width:104px;height:104px;border-radius:8px;display:grid;place-items:center;text-align:center;background:conic-gradient(var(--blue) var(--p),var(--line) 0);position:relative}
.verdict__score::after{content:"";position:absolute;inset:9px;border-radius:5px;background:var(--surface)}
.verdict__score-num{position:relative;z-index:1;font-weight:800;font-size:36px;color:var(--blue-d)}
.verdict__score-max{position:relative;z-index:1;display:block;font-family:var(--mono);font-size:10px;text-transform:uppercase;color:var(--muted)}
.verdict__label{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--blue-d)}
.verdict__body p{margin:0 0 12px;color:var(--ink-2)}
.stars{display:inline-flex;gap:1px}.star{width:16px;height:16px;color:var(--line-2)}.star.on,.star.half{color:var(--blue)}.star .ic{width:16px;height:16px}

/* ── Pros/cons ── */
.proscons{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.proscons__col{border:1px solid var(--line-2);border-radius:var(--radius);padding:20px;background:var(--surface)}
.proscons__col--pro{border-top:3px solid var(--ok)}.proscons__col--con{border-top:3px solid var(--warn)}
.proscons__col h3{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;margin:0 0 12px}
.proscons__col--pro h3{color:var(--ok)}.proscons__col--con h3{color:var(--warn)}
.proscons__col ul{margin:0;padding-left:18px}.proscons__col li{margin:8px 0;color:var(--ink-2);font-size:15.5px}

/* ── Table (Swiss) ── */
.table-wrap{overflow-x:auto;border:1px solid var(--line-2);border-radius:var(--radius)}
.cmp{width:100%;border-collapse:collapse;font-size:15px;background:var(--surface)}
.cmp th,.cmp td{padding:12px 15px;text-align:left;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.cmp th:last-child,.cmp td:last-child{border-right:0}
.cmp thead th{background:var(--ink);color:#fff;font-family:var(--mono);font-size:11.5px;letter-spacing:.03em;text-transform:uppercase;font-weight:400}
.cmp .cmp__rowhead{font-weight:700;color:var(--ink);background:var(--bg-2)}
.cmp .hl{background:var(--blue-wash)}
.cmp td{color:var(--ink-2)}
.table-note{font-family:var(--mono);font-size:12px;color:var(--muted);margin:9px 2px 0}

/* ── Bars ── */
.bars{display:flex;flex-direction:column;gap:12px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius);padding:22px}
.bar{display:grid;grid-template-columns:170px 1fr 48px;align-items:center;gap:13px}
.bar__label{font-size:14px;color:var(--ink-2)}
.bar__track{height:8px;background:var(--bg-2);border-radius:2px;overflow:hidden;border:1px solid var(--line)}
.bar__fill{height:100%;background:var(--blue)}
.bar__val{font-family:var(--mono);font-size:12px;color:var(--blue-d);text-align:right}

/* ── Sheet: bordered datasheet rows (hubs + home cols) ── */
.block__sub{color:var(--ink-2);margin:-8px 0 18px}
.sheet{border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.sheet__row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px;padding:16px 18px;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);position:relative;transition:background .14s}
.sheet__row:last-child{border-bottom:0}
a.sheet__row:hover{background:var(--blue-wash)}
a.sheet__row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue);transform:scaleY(0);transform-origin:top;transition:transform .14s}
a.sheet__row:hover::before{transform:scaleY(1)}
.sheet__idx{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--muted);align-self:start;padding-top:2px}
a.sheet__row:hover .sheet__idx{color:var(--blue-d)}
.sheet__main{min-width:0;display:flex;flex-direction:column;gap:4px}
.sheet__title{font-weight:800;font-size:17px;line-height:1.2;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.sheet__badge{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--blue-d);background:var(--blue-wash);border:1px solid var(--line-2);padding:2px 7px;border-radius:4px;font-weight:400}
.sheet__rating{display:inline-flex;align-items:center;gap:6px;font-size:13px}
.sheet__meta{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.02em}
.sheet__text{font-size:14.5px;color:var(--ink-2)}
.sheet__more{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;color:var(--blue-d);display:inline-flex;align-items:center;gap:7px;white-space:nowrap;align-self:start;padding-top:3px}
.sheet__more .ic{transition:transform .2s}a.sheet__row:hover .sheet__more .ic{transform:translateX(3px)}

/* ── Callout ── */
.callout{border:1px solid var(--line-2);background:var(--surface);border-radius:var(--radius);padding:18px 20px;margin:26px 0;border-left:4px solid var(--blue)}
.callout--tip{border-left-color:var(--ok);background:#f1faf4}
.callout--warn{border-left-color:var(--warn);background:#fdf6ea}
.callout--info{border-left-color:var(--blue);background:var(--blue-wash)}
.callout h3{display:flex;align-items:center;gap:9px;font-size:16px;margin:0 0 8px;font-weight:800}
.callout h3 .ic{color:var(--blue)}.callout--tip h3 .ic{color:var(--ok)}.callout--warn h3 .ic{color:var(--warn)}
.callout p{margin:0 0 8px;color:var(--ink-2)}.callout p:last-child{margin:0}

/* ── CTA ── */
.ctablock{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;background:var(--ink);color:#eef1f6;border-radius:var(--radius);padding:28px 32px;margin:36px 0;position:relative;overflow:hidden}
.ctablock::after{content:"";position:absolute;right:0;top:0;bottom:0;width:240px;background-image:radial-gradient(var(--blue) 1.4px,transparent 1.6px);background-size:18px 18px;opacity:.25}
.ctablock h3{color:#fff;margin:0 0 6px;font-size:24px}
.ctablock .prose p{margin:0;color:#b7bfce}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;text-decoration:none;padding:13px 24px;border-radius:6px;cursor:pointer;border:2px solid transparent;white-space:nowrap;transition:transform .12s,background .15s}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--blue);color:#fff}.btn--primary:hover{background:var(--blue-d);color:#fff}
.ctablock .btn--primary{background:#fff;color:var(--blue-d)}.ctablock .btn--primary:hover{background:var(--blue-wash)}
.btn--lg{padding:15px 28px;font-size:16px}
.btn--ghost{background:transparent;border-color:var(--line-2);color:var(--ink)}.btn--ghost:hover{border-color:var(--blue);color:var(--blue-d)}

/* ── Steps ── */
.steps{list-style:none;margin:0;padding:0}
.step{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--line)}.step:last-child{border-bottom:0}
.step__n{flex:none;width:38px;height:38px;border-radius:6px;background:var(--blue-wash);color:var(--blue-d);display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:17px}
.step h4{margin:5px 0 4px;font-size:17px}.step p{margin:0;color:var(--ink-2);font-size:15.5px}

/* ── FAQ: square / technical accordion ── */
.faq__list{border:1px solid var(--ink);border-radius:var(--radius);overflow:hidden}
.faq__item{border-bottom:1px solid var(--line-2);background:var(--surface)}
.faq__item:last-child{border-bottom:0}
.faq__item[open]{background:var(--bg-2)}
.faq__item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:15px 18px;font-weight:800;font-size:16.5px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::before{content:"Q";font-family:var(--mono);font-size:12px;font-weight:700;color:var(--blue-d);background:var(--blue-wash);border:1px solid var(--line-2);width:24px;height:24px;display:inline-grid;place-items:center;border-radius:4px;flex:none;margin-right:4px}
.faq__item summary .ic{flex:none;color:var(--blue);transition:transform .2s;margin-left:auto}.faq__item[open] summary .ic{transform:rotate(90deg)}
.faq__item .prose{padding:0 18px 18px 50px;color:var(--ink-2)}

/* ── Related ── */
.related__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.related__item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:var(--surface);border:1px solid var(--line-2);border-radius:var(--radius);text-decoration:none;color:var(--ink);font-size:15px}
.related__item:hover{border-color:var(--blue);color:var(--blue-d)}.related__item .ic{color:var(--blue)}

/* ── Home: split hero (text left / blueprint panel right) ── */
.hero{border-bottom:2px solid var(--ink);background:var(--bg-2);
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:32px 32px}
.hero__inner{max-width:var(--wrap);margin:0 auto;padding:56px 28px;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:48px;align-items:center}
.hero__text{min-width:0}
.hero__kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--blue-d);background:var(--surface);border:1px solid var(--line-2);padding:7px 14px;border-radius:5px;margin:0 0 22px}
.hero h1{font-size:clamp(34px,4.6vw,58px);margin:0 0 18px;letter-spacing:-.035em;max-width:15ch}
.hero h1 em{font-style:normal;color:var(--blue)}
.hero__lead{font-size:19px;color:var(--ink-2);max-width:52ch;margin:0 0 26px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero__trust{display:flex;flex-wrap:wrap;gap:10px}
.hero__stat{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line-2);border-radius:5px;padding:8px 15px;font-size:13px;color:var(--ink-2)}
.hero__stat b{font-weight:800;font-size:18px;color:var(--blue-d)}.hero__stat .ic{color:var(--blue);width:18px;height:18px}
/* blueprint panel */
.hero__panel{margin:0;min-width:0;border:2px solid var(--ink);border-radius:var(--radius);background:var(--surface);box-shadow:var(--sh-2);overflow:hidden}
.hero__panel-head{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:#fff;background:var(--ink);padding:9px 16px}
.hero__panel-ref{color:#9fb4ff;letter-spacing:.1em}
.seatmap{display:block;width:100%;height:auto;background:var(--bg-2);
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:30px 30px}
.sm-frame{fill:none;stroke:var(--line-2)}
.sm-grid{stroke:var(--line);stroke-width:1}
.sm-stage{fill:var(--ink)}
.sm-stagetxt{fill:#fff;font-family:var(--mono);font-size:11px;letter-spacing:.22em}
.sm-axis{fill:var(--muted);font-family:var(--mono);font-size:9px}
.sm-seat{stroke:rgba(0,0,0,.08);stroke-width:.5}
.sm-seat--fosse{fill:var(--blue)}
.sm-seat--grad{fill:var(--blue-wash);stroke:var(--blue);stroke-width:1}
.sm-seat--vip{fill:var(--vip)}
.hero__panel-key{list-style:none;display:flex;flex-wrap:wrap;gap:16px;margin:0;padding:12px 16px;border-top:1px solid var(--line-2);font-family:var(--mono);font-size:11px;text-transform:uppercase;color:var(--ink-2)}
.hero__panel-key li{display:flex;align-items:center;gap:7px}
.hero__sw{width:11px;height:11px;border-radius:3px;flex:none;border:1px solid rgba(0,0,0,.12)}
.hero__sw--fosse{background:var(--blue)}.hero__sw--grad{background:var(--blue-wash);border-color:var(--blue)}.hero__sw--vip{background:var(--vip)}

/* ── Home: rooms index (real table) ── */
.home-index{padding:50px 0;border-bottom:1px solid var(--line)}
.home-index__head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:10px}
.home-index__head h2{font-size:clamp(26px,3.4vw,36px);margin:0;letter-spacing:-.03em}
.home-index__head a{font-family:var(--mono);font-size:12px;text-transform:uppercase;white-space:nowrap}
.home-index__sub{color:var(--ink-2);margin:0 0 20px;max-width:70ch}
.roomindex th a,.roomindex td a{color:var(--ink);text-decoration:none}
.roomindex .cmp__rowhead a{font-weight:700;color:var(--blue-d)}
.roomindex tbody tr:hover{background:var(--blue-wash)}
.roomindex tbody tr:hover .cmp__rowhead{background:var(--blue-wash)}
.roomindex__go{text-align:center;width:48px}
.roomindex__go a{display:inline-flex;color:var(--blue);padding:2px}
.roomindex__go .ic{transition:transform .2s}.roomindex tbody tr:hover .roomindex__go .ic{transform:translateX(3px)}

/* ── Home: two-column sheets ── */
.home-cols{padding:50px 0}
.home-cols__grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.home-card__h{font-size:clamp(22px,2.8vw,28px);margin:0 0 16px;letter-spacing:-.02em}
.home-card__all{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;text-transform:uppercase;margin-top:16px}
.home .ctablock{max-width:var(--wrap);margin-inline:auto}

/* ── Footer: technical mono grid ── */
.site-footer{background:var(--ink);color:#aab3c2;margin-top:36px;padding:0;border-top:2px solid var(--blue)}
.site-footer>.container{padding-top:0;padding-bottom:0}
.site-footer__id{display:flex;align-items:flex-start;gap:24px;flex-wrap:wrap;padding:38px 0 24px;border-bottom:1px solid rgba(255,255,255,.12)}
.site-footer__id .brand,.site-footer__id .brand__name{color:#fff}.site-footer__id .brand__mark{background:#fff;color:var(--blue-d)}
.site-footer__about{font-size:13.5px;color:#8b95a6;margin:0;max-width:52ch;line-height:1.6;flex:1;min-width:240px}
.site-footer__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid rgba(255,255,255,.12)}
.site-footer__col{padding:26px 28px;border-right:1px solid rgba(255,255,255,.12)}
.site-footer__col:first-child{padding-left:0}
.site-footer__col:last-child{border-right:0}
.site-footer__col h4{display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;margin:0 0 14px}
.site-footer__colmark{color:var(--blue);font-weight:700}
.site-footer__col ul{list-style:none;margin:0;padding:0}.site-footer__col li{margin:8px 0}
.site-footer__col a{color:#aab3c2;text-decoration:none;font-size:14px}.site-footer__col a:hover{color:#fff}
.site-footer__bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding:18px 0 30px}
.site-footer__disc{display:flex;gap:10px;font-size:12px;color:#7c8696;max-width:70ch;margin:0;line-height:1.6}
.site-footer__disclbl{font-family:var(--mono);font-weight:700;color:var(--warn);flex:none;letter-spacing:.08em}
.site-footer__copy{font-family:var(--mono);font-size:11.5px;color:#7c8696;margin:0;white-space:nowrap}

/* ── CWV ── */
.site-footer{content-visibility:auto;contain-intrinsic-size:0 440px}
.block.related,.block.faq{content-visibility:auto;contain-intrinsic-size:0 360px}

/* ── Responsive ── */
@media(max-width:980px){
  .hero__inner{grid-template-columns:1fr;gap:34px;padding:44px 28px}
  .hero h1{max-width:18ch}.hero__lead{max-width:60ch}
  .hero__panel{max-width:460px}
  .home-cols__grid{grid-template-columns:1fr;gap:28px}
}
@media(max-width:900px){
  /* FICHE panel stacks ABOVE content (single column; panel is first grid child) */
  .page__grid{grid-template-columns:1fr;gap:26px}
  .fiche{position:static;top:auto}
  .fiche__card{max-width:520px}
  /* collapse nav band to burger */
  .mainnav{display:none}.navtoggle{display:flex}
  .site-header__navband{display:none}
}
@media(max-width:680px){
  .proscons{grid-template-columns:1fr}
  .verdict{flex-direction:column}.bar{grid-template-columns:110px 1fr 44px}.ctablock{flex-direction:column;align-items:flex-start}
  .home-index__head{flex-direction:column;align-items:flex-start;gap:6px}
  /* footer stacks: kill column rules, stack rows */
  .site-footer__grid{grid-template-columns:1fr}
  .site-footer__col{padding:18px 0;border-right:0;border-bottom:1px solid rgba(255,255,255,.12)}
  .site-footer__col:last-child{border-bottom:0}
  .site-footer__bottom{flex-direction:column;gap:12px}
  /* sheet rows: drop the "more" affordance onto its own line */
  .sheet__row{grid-template-columns:auto minmax(0,1fr);gap:12px 14px}
  .sheet__more{grid-column:1 / -1;padding-top:0}
}
@media(max-width:500px){
  body{font-size:16px}
  .container{padding:0 18px}
  .seatmap{background-size:24px 24px}
}

/* ===== Interactions : hovers + transitions (couche additionnelle commune) ===== */
a, .btn, button, summary,
[class*="card"], [class*="tile"], [class*="panel"], [class*="story"], [class*="sheet"], [class*="row"], [class*="tab"],
.ic, .navtoggle span {
  transition: color .18s ease, background-color .18s ease, border-color .18s ease,
              box-shadow .22s ease, transform .2s ease, opacity .18s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
a[class*="card"]:hover, a[class*="tile"]:hover, a[class*="story"]:hover,
a[class*="sheet"]:hover, a[class*="panel"]:hover { transform: translateY(-3px); }
:focus-visible { outline: 2px solid currentColor; outline-offset: 3px; }
@media (prefers-reduced-motion: reduce) { * { transition: none !important; } }
