/* ============================================================
   OFK MOTO · design system
   Charte : encre + bleu électrique OFK. Display Oswald / body Inter.
   ============================================================ */

/* ---------- tokens ---------- */
:root{
  --ink:#0b0e13;
  --ink-2:#10151d;
  --steel:#161c26;
  --steel-2:#1c2431;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --paper:#f5f7fb;
  --paper-2:#eef1f7;
  --card:#ffffff;

  --blue:#2b7fff;
  --blue-2:#4f97ff;
  --blue-deep:#1657d0;
  --blue-ink:#0a2a63;
  --glow:rgba(43,127,255,.30);

  --amber:#ffb020;

  --tx:#0d1220;          /* texte sur clair */
  --tx-soft:#4a5566;
  --tx-mut:#8b95a5;
  --tx-inv:#eef2f8;      /* texte sur sombre */
  --tx-inv-soft:#a7b1c2;

  --ok:#1fb46b;

  --r:14px;
  --r-lg:22px;
  --r-sm:9px;
  --shadow:0 8px 24px -14px rgba(9,14,25,.22);
  --shadow-hi:0 20px 44px -24px rgba(9,14,25,.40);
  --ring:0 0 0 3px var(--glow);

  --display:"Oswald",system-ui,sans-serif;
  --body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:"Space Grotesk",ui-monospace,SFMono-Regular,Menlo,monospace;

  --wrap:1200px;
  --pad:clamp(18px,5vw,40px);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--tx);
  background:var(--paper);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:6px}
::selection{background:var(--blue);color:#fff}
.skip{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip:focus{position:fixed;left:10px;top:10px;width:auto;height:auto;clip:auto;margin:0;z-index:200;background:var(--blue);color:#fff;padding:12px 18px;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:0 0 8px 0}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.02;margin:0;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,7vw,5.2rem);font-weight:700;text-transform:uppercase;letter-spacing:-.015em}
h2{font-size:clamp(2rem,4.4vw,3.4rem);text-transform:uppercase}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
p{margin:0 0 1em}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--tx-soft);line-height:1.65}

.kicker{
  font-family:var(--display);font-weight:600;text-transform:uppercase;
  letter-spacing:.24em;font-size:.78rem;color:var(--blue);
  display:inline-flex;align-items:center;gap:.6em;
}
.kicker::before{content:"";width:26px;height:2px;background:var(--blue);display:inline-block}
.kicker.center::after{content:"";width:26px;height:2px;background:var(--blue);display:inline-block}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* ---------- layout ---------- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,120px)}
.section.tight{padding-block:clamp(48px,6vw,80px)}
.dark{background:var(--ink);color:var(--tx-inv)}
.dark h1,.dark h2,.dark h3{color:#fff}
.dark .lead{color:var(--tx-inv-soft)}
.center{text-align:center}
.sec-head{max-width:720px;margin-bottom:clamp(34px,4vw,54px)}
.sec-head.center{margin-inline:auto}
.sec-head h2{margin:.35em 0 .3em}
.grid{display:grid;gap:clamp(16px,2vw,26px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* ---------- buttons ---------- */
.btn{
  --bg:var(--blue);--fg:#fff;
  display:inline-flex;align-items:center;gap:.55em;justify-content:center;
  font-family:var(--display);font-weight:600;text-transform:uppercase;
  letter-spacing:.05em;font-size:.98rem;
  padding:.86em 1.5em;border-radius:var(--r-sm);border:0;cursor:pointer;
  background:var(--bg);color:var(--fg);line-height:1;
  transition:transform .12s ease,box-shadow .2s ease,background .2s ease;
  box-shadow:0 10px 26px -12px var(--glow);
}
@media (hover:hover){.btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px -12px var(--glow)}}
.btn:active{transform:scale(.97)}
.btn svg{width:1.05em;height:1.05em}
.btn.ghost{background:transparent;color:var(--tx);box-shadow:inset 0 0 0 1.5px rgba(13,18,32,.18)}
.dark .btn.ghost{color:#fff;box-shadow:inset 0 0 0 1.5px var(--line-2)}
.btn.ghost:hover{box-shadow:inset 0 0 0 1.5px var(--blue);color:var(--blue)}
.dark .btn.ghost:hover{color:#fff;box-shadow:inset 0 0 0 1.5px var(--blue)}
.btn.lg{padding:1.02em 1.8em;font-size:1.05rem}
.btn.blk{--bg:var(--ink)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}

.link-arrow{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--blue);display:inline-flex;align-items:center;gap:.5em;font-size:.92rem}
.link-arrow svg{width:1.1em;transition:transform .2s}
@media (hover:hover){.link-arrow:hover svg{transform:translateX(4px)}}

/* ---------- chips / stars ---------- */
.chip{display:inline-flex;align-items:center;gap:.5em;padding:.42em .82em;border-radius:100px;font-size:.82rem;font-weight:600;background:rgba(43,127,255,.1);color:var(--blue-deep)}
.dark .chip{background:rgba(43,127,255,.16);color:var(--blue-2)}
.chip.amber{background:rgba(255,176,32,.18);color:#835908}
.dark .chip.amber{color:var(--amber)}
.chip .dot{width:7px;height:7px;border-radius:50%;background:currentColor}

.stars{display:inline-flex;gap:2px;color:var(--amber)}
.stars svg{width:1.05em;height:1.05em;fill:currentColor}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(11,14,19,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  transition:background .3s ease;
}
.nav .wrap{display:flex;align-items:center;gap:22px;height:74px}
.brand{display:flex;align-items:center;gap:11px;margin-right:auto}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.04em;
  font-size:.92rem;color:var(--tx-inv-soft);padding:.5em .8em;border-radius:8px;transition:color .2s,background .2s;
}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,.06)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-tel{font-family:var(--display);font-weight:600;color:#fff;display:inline-flex;align-items:center;gap:.5em;font-size:.98rem;letter-spacing:.02em}
.nav-tel svg{width:1.05em;color:var(--blue-2)}
.burger{display:none;background:transparent;border:0;color:#fff;cursor:pointer;padding:10px}
.burger svg{width:26px;height:26px}

/* ---------- logo lockup ---------- */
.logo{display:inline-flex;align-items:center;gap:9px;line-height:1}
.logo .mark{
  font-family:var(--display);font-weight:700;font-size:1.55rem;letter-spacing:-.02em;
  color:#fff;position:relative;padding-right:2px;
}
.logo .mark b{color:var(--blue-2);font-weight:700}
.logo .txt{display:flex;flex-direction:column;gap:1px}
.logo .txt .t1{font-family:var(--display);font-weight:600;font-size:.72rem;letter-spacing:.42em;color:#fff;text-transform:uppercase;line-height:1}
.logo .txt .t2{font-size:.53rem;letter-spacing:.18em;color:var(--tx-inv-soft);text-transform:uppercase;line-height:1}
.logo.ink .mark{color:var(--ink)}
.logo.ink .txt .t1{color:var(--ink)}
.logo.ink .txt .t2{color:var(--tx-mut)}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--ink);color:var(--tx-inv);overflow:hidden;isolation:isolate}
.hero::before{ /* glow bleu diffus, pas un fond dégradé plat */
  content:"";position:absolute;inset:-20% -10% auto auto;width:60vw;height:60vw;z-index:-1;
  background:radial-gradient(closest-side,var(--glow),transparent 70%);opacity:.7;
}
.hero::after{ /* liseré vitesse diagonal, discret */
  content:"";position:absolute;right:-6%;bottom:-30%;width:52%;height:170%;z-index:-1;
  background:linear-gradient(180deg,transparent,rgba(43,127,255,.06));
  transform:skewX(-11deg);border-left:2px solid rgba(43,127,255,.18);
}
.hero .wrap{position:relative;padding-block:clamp(56px,9vw,110px)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center}
.hero h1{margin:.28em 0 .4em}
.hero h1 .bl{color:var(--blue-2)}
.hero-trust{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:26px}
.rating-badge{display:flex;align-items:center;gap:12px;background:var(--steel);border:1px solid var(--line);padding:12px 16px;border-radius:var(--r)}
.rating-badge .big{font-family:var(--display);font-weight:700;font-size:1.9rem;color:#fff;line-height:1}
.rating-badge .sub{font-size:.8rem;color:var(--tx-inv-soft)}
.rating-badge .sub b{color:#fff;font-weight:600}

.hero-media{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;background:
  linear-gradient(160deg,var(--steel-2),var(--ink) 70%);
  border:1px solid var(--line);box-shadow:var(--shadow-hi);display:grid;place-items:center}
.hero-media .ph{color:var(--tx-inv-soft);text-align:center;padding:24px;font-size:.86rem}
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.hero-media .tag{position:absolute;left:14px;bottom:14px;z-index:2}

/* ---------- stat band ---------- */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-block:1px solid var(--line)}
.statband .s{background:var(--ink);padding:26px 20px;text-align:center}
.statband .n{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.7rem);color:#fff;line-height:1}
.statband .n b{color:var(--blue-2)}
.statband .l{font-size:.82rem;color:var(--tx-inv-soft);margin-top:6px}

/* ---------- cards ---------- */
.card{background:var(--card);border:1px solid rgba(13,18,32,.09);border-radius:var(--r);padding:26px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
@media (hover:hover){.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hi)}}
.dark .card{background:var(--steel);border-color:var(--line);color:var(--tx-inv)}
/* 2 services phares en sombre pour casser la grille de 6 cartes identiques */
.card.svc.hi{background:var(--ink);color:var(--tx-inv);border-color:var(--line)}
.card.svc.hi .ic{background:rgba(43,127,255,.2);color:var(--blue-2)}
.card.svc.hi h3{color:#fff}
.card.svc.hi p{color:var(--tx-inv-soft)}
.card.svc.hi .num{color:rgba(255,255,255,.14)}

.svc{position:relative;overflow:hidden}
.svc .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:rgba(43,127,255,.12);color:var(--blue-deep);margin-bottom:16px}
.dark .svc .ic{background:rgba(43,127,255,.16);color:var(--blue-2)}
.svc .ic svg{width:26px;height:26px}
.svc h3{margin-bottom:.4em}
.svc p{color:var(--tx-soft);margin:0;font-size:.98rem}
.dark .svc p{color:var(--tx-inv-soft)}
.svc .num{position:absolute;top:16px;right:20px;font-family:var(--display);font-weight:700;font-size:1rem;color:rgba(13,18,32,.12)}
.dark .svc .num{color:rgba(255,255,255,.12)}

/* moto occasion card */
.moto{background:var(--card);border:1px solid rgba(13,18,32,.09);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
@media (hover:hover){.moto:hover{transform:translateY(-4px);box-shadow:var(--shadow-hi)}
.moto:hover .pic img{transform:scale(1.05)}}
.moto .pic{aspect-ratio:4/5;background:linear-gradient(160deg,var(--steel-2),var(--ink));position:relative;display:grid;place-items:center;color:var(--tx-inv-soft);overflow:hidden}
.moto .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.moto .badge{position:absolute;z-index:2;top:12px;left:12px;background:var(--ink);color:#fff;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;padding:.4em .7em;border-radius:6px}
.moto .badge.sold{background:var(--amber);color:var(--ink)}
.moto .body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.moto .body h3{font-size:1.22rem}
.moto .yearline{font-size:.85rem;color:var(--tx-soft);font-family:var(--mono)}
.moto .specs{display:flex;gap:14px;flex-wrap:wrap;margin-top:2px}
.moto .specs span{font-size:.82rem;color:var(--tx-soft);display:inline-flex;align-items:center;gap:.4em}
.moto .specs svg{width:1em;color:var(--blue)}
.moto .mfoot{margin-top:auto;padding-top:12px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid rgba(13,18,32,.08)}
.moto .price{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--ink)}

/* review card */
.review{background:var(--card);border:1px solid rgba(13,18,32,.08);border-radius:var(--r);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}
.dark .review{background:var(--steel);border-color:var(--line)}
.review .g{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--tx-mut)}
.review .g svg{width:16px}
.review p{margin:0;color:var(--tx-soft);font-size:.98rem}
.dark .review p{color:var(--tx-inv-soft)}
.review .who{display:flex;align-items:center;gap:11px;margin-top:2px}
.review .av{width:38px;height:38px;border-radius:50%;background:var(--blue);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600}
.review .who b{display:block;font-size:.92rem;font-weight:600;color:var(--tx);line-height:1.3}
.dark .review .who b{color:#fff}
.review .who span{font-size:.78rem;color:var(--tx-mut)}

/* process steps */
.steps{counter-reset:st;display:grid;gap:18px}
.step{display:flex;gap:18px;align-items:flex-start}
.step .n{counter-increment:st;flex:none;width:44px;height:44px;border-radius:12px;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.15rem}
.step .n::before{content:counter(st,decimal-leading-zero)}
.dark .step .n{background:var(--blue)}
.step h3{font-size:1.15rem;margin-bottom:.25em}
.step p{color:var(--tx-soft);margin:0;font-size:.96rem}
.dark .step p{color:var(--tx-inv-soft)}

/* CTA band */
.cta{background:var(--blue);color:#fff;border-radius:var(--r-lg);padding:clamp(30px,5vw,58px);position:relative;overflow:hidden;isolation:isolate}
.cta::after{content:"";position:absolute;right:-8%;top:-40%;width:44%;height:180%;background:rgba(255,255,255,.08);transform:skewX(-12deg);z-index:-1}
.cta h2{color:#fff}
.cta .lead{color:rgba(255,255,255,.9)}
.cta .btn{--bg:#fff;--fg:var(--blue-deep)}
.cta .btn.ghost{color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.6)}
.cta .btn.ghost:hover{box-shadow:inset 0 0 0 1.5px #fff;color:#fff}

/* ---------- footer ---------- */
.foot{background:var(--ink);color:var(--tx-inv-soft);padding-block:clamp(46px,6vw,72px) 30px}
.foot a:hover{color:#fff}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px;padding-bottom:34px;border-bottom:1px solid var(--line)}
.foot h4{font-family:var(--display);text-transform:uppercase;letter-spacing:.1em;font-size:.86rem;color:#fff;margin-bottom:16px}
.foot ul{list-style:none;margin:0;padding:0;display:grid;gap:9px;font-size:.92rem}
.foot .desc{font-size:.92rem;max-width:34ch;margin-top:14px}
.foot-bot{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:22px;font-size:.82rem;color:var(--tx-mut)}
.foot-bot .marsai{color:var(--tx-inv-soft)}
.foot-bot .marsai b{color:var(--blue-2)}

/* ---------- reveal (motion sobre, gaté .js pour rester visible sans JS) ---------- */
.js .reveal{opacity:0;transform:translateY(12px);transition:opacity .45s ease,transform .45s cubic-bezier(.2,.7,.2,1)}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-media{aspect-ratio:1/1;order:-1}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .statband{grid-template-columns:repeat(2,1fr)}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .nav-links{display:none}
  .nav-tel span{display:none}
  .nav-cta .btn{display:none}
  .burger{display:inline-flex}
  .g-2,.g-3{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .seg-chip{min-height:44px}
}

/* ---------- catalogue toolbar + estimateur ---------- */
.toolbar{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:space-between;margin-bottom:26px}
.seg-chips{display:flex;gap:8px;flex-wrap:wrap}
.seg-chip{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.03em;font-size:.82rem;padding:.5em .95em;min-height:40px;display:inline-flex;align-items:center;border-radius:100px;border:1.5px solid rgba(13,18,32,.14);background:#fff;color:var(--tx-soft);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease,transform .1s ease}
@media (hover:hover){.seg-chip:hover{border-color:var(--blue);color:var(--blue)}}
.seg-chip:active{transform:scale(.96)}
.seg-chip.on{background:var(--ink);border-color:var(--ink);color:#fff}
.selects{display:flex;gap:10px;flex-wrap:wrap}
.selects select{font-family:var(--body);font-size:.9rem;color:var(--tx);background:#fff;border:1.5px solid rgba(13,18,32,.14);border-radius:9px;padding:.6em 2.2em .6em .9em;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b95a5' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .8em center}
.selects select:focus{outline:none;border-color:var(--blue)}
.cat-count{font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--tx-soft);font-size:.86rem}

.estimateur{background:var(--ink);color:var(--tx-inv);border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;box-shadow:var(--shadow-hi)}
.estimateur .side{padding:clamp(28px,4vw,44px);display:flex;flex-direction:column;justify-content:center}
.estimateur .side.blue{background:linear-gradient(150deg,#173a8c,#0b0e13);position:relative;isolation:isolate}
.estimateur .side.blue::after{content:"";position:absolute;right:-10%;top:-30%;width:50%;height:160%;background:rgba(43,127,255,.14);transform:skewX(-12deg);z-index:-1}
.est-form{display:grid;gap:14px}
.est-form label{font-size:.82rem;color:var(--tx-inv-soft);font-weight:500;display:block;margin-bottom:5px}
.est-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.est-form select,.est-form input{width:100%;background:var(--steel);border:1px solid var(--line-2);color:#fff;border-radius:10px;padding:.72em .9em;font-family:inherit;font-size:.95rem;outline:none}
.est-form select:focus,.est-form input:focus{border-color:var(--blue)}
.est-form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a7b1c2' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9em center}
.est-out{margin-top:18px;background:var(--steel);border:1px solid rgba(43,127,255,.3);border-radius:14px;padding:20px;opacity:0;transform:translateY(8px);transition:opacity .35s ease,transform .35s cubic-bezier(.2,.7,.2,1)}
.est-out.show{opacity:1;transform:none}
.est-recall{display:grid;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line-2)}
.est-recall .rr{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.est-recall input{width:100%;background:var(--steel-2);border:1px solid var(--line-2);color:#fff;border-radius:10px;padding:.7em .9em;font-family:inherit;font-size:.95rem;outline:none}
.est-recall input:focus{border-color:var(--blue)}
.est-recall .done{color:#5fd39b;font-size:.92rem;font-weight:500}
@media (prefers-reduced-motion:reduce){.est-out{transition:none}}
.est-range{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,3.5vw,2.5rem);color:#fff;line-height:1.05}
.est-range span{color:var(--blue-2);font-weight:500;font-size:.6em}
.est-sub{font-size:.9rem;color:var(--tx-inv-soft);margin:.6em 0 .3em}
.est-note{font-size:.8rem;color:var(--tx-mut);margin:0 0 12px}
@media(max-width:820px){.estimateur{grid-template-columns:1fr}.estimateur .side.blue{order:-1}}

/* ---------- map ---------- */
.map-wrap{border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(13,18,32,.1);box-shadow:var(--shadow);aspect-ratio:16/9;background:var(--steel-2)}
.map-wrap iframe{width:100%;height:100%;border:0;display:block}

/* ---------- form contact ---------- */
.cform{display:grid;gap:14px}
.cform .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform label{font-size:.82rem;color:var(--tx-soft);font-weight:500;display:block;margin-bottom:5px}
.cform input,.cform textarea,.cform select{width:100%;background:#fff;border:1.5px solid rgba(13,18,32,.14);border-radius:10px;padding:.75em .95em;font-family:inherit;font-size:.95rem;color:var(--tx);outline:none}
.cform input:focus,.cform textarea:focus,.cform select:focus{border-color:var(--blue)}
.cform textarea{resize:vertical;min-height:110px}
.cform .ok{background:rgba(31,180,107,.12);color:#0f7a45;border:1px solid rgba(31,180,107,.3);border-radius:10px;padding:14px 16px;font-size:.92rem;font-weight:500}
@media(max-width:620px){.cform .row{grid-template-columns:1fr}}

/* ---------- info tiles ---------- */
.info-tile{display:flex;gap:14px;align-items:flex-start;background:var(--card);border:1px solid rgba(13,18,32,.08);border-radius:var(--r);padding:20px;box-shadow:var(--shadow)}
.info-tile .ic{flex:none;width:44px;height:44px;border-radius:11px;background:rgba(43,127,255,.12);color:var(--blue-deep);display:grid;place-items:center}
.info-tile .ic svg{width:22px;height:22px}
.info-tile b{display:block;font-size:1rem;margin-bottom:2px}
.info-tile span{color:var(--tx-soft);font-size:.92rem}

/* ---------- big rating ---------- */
.bigrate{display:flex;align-items:center;gap:28px;flex-wrap:wrap;background:var(--steel);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,4vw,40px)}
.bigrate .score{font-family:var(--display);font-weight:700;font-size:clamp(3.4rem,8vw,5.6rem);color:#fff;line-height:1}
.bigrate .meta .stars{font-size:1.5rem;margin-bottom:6px}
.bigrate .meta div{color:var(--tx-inv-soft)}
.bigrate .gsrc{margin-left:auto;text-align:right;color:var(--tx-inv-soft);font-size:.86rem}

/* ---------- reels / video strip ---------- */
.reels{display:flex;gap:16px;overflow-x:auto;padding:4px 0 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.reels::-webkit-scrollbar{height:8px}
.reels::-webkit-scrollbar-track{background:transparent}
.reels::-webkit-scrollbar-thumb{background:rgba(13,18,32,.18);border-radius:8px}
.dark .reels::-webkit-scrollbar-thumb{background:var(--line-2)}
.reel{flex:none;width:clamp(214px,25vw,286px);aspect-ratio:9/16;border-radius:18px;overflow:hidden;position:relative;background:var(--steel);border:1px solid rgba(13,18,32,.1);scroll-snap-align:start;box-shadow:var(--shadow-hi)}
.dark .reel{border-color:var(--line)}
.reel video{width:100%;height:100%;object-fit:cover;display:block}
.reel .ov{position:absolute;inset:auto 0 0 0;padding:14px 16px;background:linear-gradient(transparent,rgba(6,9,14,.72));display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--display);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.86rem}
.reel .ov svg{width:16px;height:16px;color:var(--blue-2);flex:none}
.reel .live{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:5px;background:rgba(6,9,14,.6);backdrop-filter:blur(4px);color:#fff;font-size:.7rem;font-weight:600;padding:.3em .6em;border-radius:100px}
.reel .live i{width:6px;height:6px;border-radius:50%;background:#ff3b5c}
@media (prefers-reduced-motion:no-preference){.reel .live i{animation:ofkPulse 2s ease-in-out infinite}}
@keyframes ofkPulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ---------- mobile menu ---------- */
.mobile-menu{position:fixed;inset:0;z-index:80;background:rgba(11,14,19,.97);backdrop-filter:blur(8px);display:none;flex-direction:column;padding:22px var(--pad)}
.mobile-menu.open{display:flex}
.mobile-menu .top{display:flex;align-items:center;height:52px}
.mobile-menu .top .x{margin:-8px -8px -8px auto;padding:8px;background:transparent;border:0;color:#fff;cursor:pointer}
.mobile-menu .top .x svg{width:28px;height:28px}
.mobile-menu nav{display:flex;flex-direction:column;gap:4px;margin-top:20px}
.mobile-menu nav a{font-family:var(--display);text-transform:uppercase;font-size:1.5rem;color:#fff;padding:.5em 0;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:24px}
