/* ==========================================================================
   Răzvan Detailing — Coming Soon. Self-contained, buildless.
   Black/gold brand · Fraunces (display) + Inter (body).
   ========================================================================== */

@font-face { font-family:"Inter"; font-style:normal; font-weight:100 900; font-display:swap;
  src:url("/assets/fonts/inter-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:"Inter"; font-style:normal; font-weight:100 900; font-display:swap;
  src:url("/assets/fonts/inter-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:"Fraunces"; font-style:normal; font-weight:100 900; font-display:swap;
  src:url("/assets/fonts/fraunces-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:"Fraunces"; font-style:normal; font-weight:100 900; font-display:swap;
  src:url("/assets/fonts/fraunces-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF; }
@font-face { font-family:"Inter Fallback"; src:local("Arial"); size-adjust:107%; ascent-override:90.5%; descent-override:22.6%; line-gap-override:0%; }
@font-face { font-family:"Fraunces Fallback"; src:local("Georgia"); size-adjust:102%; ascent-override:92%; descent-override:23%; line-gap-override:0%; }

:root {
  --black:#030304; --graphite:#141417; --card:#1a1a1e; --card-2:#212126;
  --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.16);
  --gold:#d4a64a; --gold-2:#b8893a; --gold-text:#f3d88f; --gold-soft:rgba(212,166,74,.14); --gold-line:rgba(212,166,74,.34);
  --ink:#f5f5f6; --muted:rgba(255,255,255,.70); --muted-2:rgba(255,255,255,.52);
  --green:#25d366; --waze:#33ccff;
  --font:"Inter","Inter Fallback",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  --display:"Fraunces","Fraunces Fallback",Georgia,"Times New Roman",serif;
  /* radius scale — everything rounded, consistently */
  --r-sm:12px; --r:16px; --r-lg:22px; --r-xl:28px; --r-pill:999px;
  /* spacing scale */
  --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:24px; --sp-6:32px; --sp-7:48px;
  --gap:16px;
  --section-pad:clamp(40px,5vw,62px);
  --nav-h:64px;
  --gutter:clamp(24px,6vw,56px); --maxw:1240px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

* { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body {
  margin:0; background:var(--black); color:var(--ink);
  font-family:var(--font); font-size:17px; line-height:1.55; letter-spacing:-.005em;
  text-rendering:optimizeLegibility; -webkit-font-smoothing:antialiased; overflow-x:hidden; overflow-wrap:break-word;
}
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto;} *{animation-duration:.001ms!important;transition-duration:.001ms!important;} }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
h1,h2,h3,h4,p { margin:0; }
h1,h2,h3 { text-wrap:balance; }
p { text-wrap:pretty; }
:focus-visible { outline:2px solid var(--gold); outline-offset:3px; border-radius:6px; }

.wrap { max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.skip { position:fixed; left:14px; top:-60px; z-index:1000; background:var(--gold); color:var(--black); padding:10px 16px; border-radius:var(--r-sm); font-weight:800; transition:top .2s; }
.skip:focus { top:14px; }

/* ---- nav ---- */
.nav-shell { position:fixed; inset:0 0 auto; z-index:70; height:var(--nav-h);
  background:rgba(3,3,4,.72); border-bottom:1px solid var(--line);
  backdrop-filter:saturate(180%) blur(20px); -webkit-backdrop-filter:saturate(180%) blur(20px); }
.nav { height:var(--nav-h); display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand-logo { height:42px; width:auto; }
.nav-actions { display:flex; align-items:center; gap:12px; }
.lang { display:inline-flex; gap:2px; padding:3px; background:rgba(255,255,255,.06); border-radius:var(--r-pill); }
.lang-btn { min-width:36px; min-height:30px; padding:4px 10px; border:0; background:transparent; color:var(--muted-2);
  font:inherit; font-size:12px; font-weight:800; border-radius:var(--r-pill); cursor:pointer; transition:background .2s,color .2s; }
.lang-btn.active { background:#fff; color:var(--black); }

/* ---- buttons ---- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; min-height:46px; padding:12px 22px;
  border-radius:var(--r-pill); font-weight:800; font-size:15px; letter-spacing:-.01em; cursor:pointer;
  border:1px solid transparent; transition:transform .15s var(--ease), background .2s, border-color .2s, color .2s; white-space:nowrap; }
.btn svg { width:18px; height:18px; fill:currentColor; flex:none; }
.btn:hover { transform:translateY(-1px); }
.btn.gold { background:var(--gold); color:#1a1407; border-color:var(--gold); box-shadow:0 10px 34px rgba(212,166,74,.26); }
.btn.gold:hover { background:var(--gold-2); border-color:var(--gold-2); }
.btn.ghost { background:rgba(255,255,255,.04); color:var(--ink); border-color:var(--line-2); }
.btn.ghost:hover { background:rgba(255,255,255,.09); }
.btn.wa { background:var(--green); color:#04210f; border-color:var(--green); box-shadow:0 10px 30px rgba(37,211,102,.24); }
.btn.wa:hover { background:#1fbf57; border-color:#1fbf57; color:#04210f; }
.btn.wide { width:100%; }
.nav-cta { min-height:40px; padding:8px 16px; font-size:13px; }

/* ---- floating dock (desktop) ---- */
.dock { position:fixed; right:16px; top:50%; transform:translateY(-50%); z-index:65; display:flex; flex-direction:column; gap:10px; }
.dock-btn { display:grid; place-items:center; width:46px; height:46px; border-radius:var(--r-pill);
  background:rgba(20,20,22,.82); border:1px solid var(--line-2); color:var(--ink);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); transition:background .2s,color .2s,transform .15s,border-color .2s; }
.dock-btn svg { width:20px; height:20px; fill:currentColor; }
.dock-btn:hover { transform:scale(1.07); border-color:var(--gold-line); color:var(--gold); }
.dock-btn.dock-wa { background:rgba(37,211,102,.16); border-color:rgba(37,211,102,.4); color:#5ef0a0; }
.dock-btn.dock-wa { color:#5ef0a0; }
.dock-btn.dock-wa:hover { background:var(--green); color:#04210f; border-color:var(--green); }
.dock-btn.dock-ig { color:#e8769b; }
.dock-btn.dock-ig:hover { background:linear-gradient(45deg,#f09433,#dc2743 55%,#bc1888); color:#fff; border-color:transparent; }
.dock-btn.dock-fb { color:#5b9bff; }
.dock-btn.dock-fb:hover { background:#1877F2; color:#fff; border-color:#1877F2; }
.dock-btn.dock-tt:hover { background:#000; color:#25f4ee; border-color:#25f4ee; }

/* ---- hero ---- */
.hero { position:relative; min-height:92svh; display:flex; align-items:center; isolation:isolate; overflow:hidden;
  padding:calc(var(--nav-h) + 78px) 0 56px; background:#000; }
.hero-picture { position:absolute; inset:0; z-index:-2; }
.hero-img { width:100%; height:100%; object-fit:cover; object-position:center 46%; filter:saturate(1.04) contrast(1.06); }
.hero::after { content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.22) 36%,rgba(0,0,0,.86) 100%); }
.hero-copy { text-align:center; position:relative; }
.hero-copy::before { content:""; position:absolute; inset:-8% -10% -6%; z-index:-1; pointer-events:none;
  background:radial-gradient(120% 92% at 50% 50%, rgba(0,0,0,.58), rgba(0,0,0,0) 70%); }
.hero-brand { font-size:clamp(24px,4.6vw,52px); line-height:1.0; font-weight:900; letter-spacing:.06em; text-transform:uppercase;
  color:var(--gold); text-shadow:0 18px 70px rgba(0,0,0,.6); margin-bottom:10px; }
.hero-kicker { font-size:clamp(13px,1.5vw,16px); font-weight:750; color:var(--ink); text-shadow:0 2px 16px rgba(0,0,0,.7); margin-bottom:26px; }
.display { font-family:var(--display); font-weight:600; font-size:clamp(34px,7vw,72px); line-height:1.02; letter-spacing:-.02em;
  max-width:15ch; margin:0 auto; text-shadow:0 20px 70px rgba(0,0,0,.66); }
.hero-sub { max-width:56ch; margin:20px auto 0; color:rgba(255,255,255,.82); font-size:clamp(15px,1.7vw,18px); text-shadow:0 2px 14px rgba(0,0,0,.6); }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:28px; }
.proof { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:22px; }
.pill { display:inline-flex; align-items:center; gap:8px; min-height:34px; padding:7px 14px; border-radius:var(--r-pill);
  background:rgba(255,255,255,.06); border:1px solid var(--line); color:rgba(255,255,255,.82); font-size:13px; font-weight:700; }
.pill::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--gold); }

/* ---- reviews trust strip ---- */
.reviews { padding-block:clamp(18px,3vw,30px) 0; }
.reviews + .section { padding-top:clamp(34px,5vw,58px); } /* tighten the gap below the strip */
.soon + .services { padding-top:clamp(28px,4vw,44px); } /* even the gap below the cards */
.reviews-card { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:14px 26px;
  background:linear-gradient(180deg,var(--card),var(--graphite)); border:1px solid var(--line-2); border-radius:var(--r-xl);
  padding:var(--sp-5) clamp(20px,4vw,38px); text-align:center; }
.stars { display:inline-flex; gap:3px; color:var(--gold); font-size:22px; line-height:1; letter-spacing:2px; }
.reviews-score { display:flex; align-items:center; gap:10px; }
.reviews-score b { font-family:var(--display); font-size:32px; font-weight:600; line-height:1; }
.reviews-score span { color:var(--muted); font-size:14px; font-weight:600; }
.reviews-score .stars { font-size:30px; letter-spacing:2px; } /* match the score, not the small label */
.reviews-text { color:var(--muted); font-size:15px; max-width:34ch; }

/* ---- sections ---- */
.section { padding-block:var(--section-pad); } /* block-only so .wrap's padding-inline (gutter) is kept */
.head { max-width:760px; margin-bottom:clamp(26px,4vw,44px); }
.head.center { margin-inline:auto; text-align:center; }
.eyebrow { display:inline-flex; align-items:center; gap:10px; color:var(--gold); font-size:12px; font-weight:800;
  letter-spacing:.16em; text-transform:uppercase; margin-bottom:16px; }
.eyebrow::before { content:""; width:22px; height:2px; background:var(--gold); border-radius:2px; }
.head.center .eyebrow::before { display:none; }
.headline { font-family:var(--display); font-weight:600; font-size:clamp(28px,4.6vw,50px); line-height:1.05; letter-spacing:-.02em; }
.lead { margin-top:18px; color:var(--muted); font-size:clamp(15px,1.7vw,18px); max-width:60ch; }
.head.center .lead { margin-inline:auto; }

/* ---- what's coming cards ---- */
.grid-3 { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:var(--gap); }
.card { padding:var(--sp-6) var(--sp-5); border-radius:var(--r-lg); background:var(--card); border:1px solid var(--line);
  transition:transform .2s var(--ease), border-color .2s, background .2s; }
.card:hover { transform:translateY(-4px); border-color:var(--gold-line); background:var(--card-2); }
.card h3 { font-size:21px; font-weight:800; margin:0 0 8px; letter-spacing:-.01em; }
.card p { color:var(--muted); font-size:15px; }

/* ---- gallery CAROUSEL ---- */
.carousel { position:relative; }
.carousel-viewport { overflow:hidden; border-radius:var(--r-lg); }
.carousel-track { display:flex; gap:var(--gap); transition:transform .45s var(--ease); touch-action:pan-y; cursor:grab; }
.carousel-track:active { cursor:grabbing; }
.carousel-slide img { pointer-events:none; }
/* service cards (Ce facem carousel) — image with caption overlay */
.svc-card { position:relative; display:block; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line-2); aspect-ratio:3/4; background:var(--card); }
.svc-card picture { position:absolute; inset:0; }
.svc-card img { width:100%; height:100%; object-fit:cover; }
.svc-card::after { content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.42) 46%,rgba(0,0,0,0) 78%); }
.svc-body { position:absolute; left:0; right:0; bottom:0; z-index:1; padding:22px; }
.svc-body h3 { font-size:20px; font-weight:800; letter-spacing:-.01em; }
.svc-body p { color:rgba(255,255,255,.88); font-size:14px; margin-top:6px; }
.carousel-slide { flex:0 0 calc((100% - 2*var(--gap)) / 3); }
.carousel-slide figure { margin:0; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); aspect-ratio:4/3; background:var(--card); }
.carousel-slide picture { display:block; width:100%; height:100%; }
.carousel-slide img { width:100%; height:100%; object-fit:cover; }
.carousel-controls { display:flex; align-items:center; justify-content:center; gap:18px; margin-top:22px; }
.carousel-arrow { display:grid; place-items:center; width:46px; height:46px; border-radius:var(--r-pill);
  background:var(--card); border:1px solid var(--line-2); color:var(--ink); cursor:pointer; transition:background .2s,border-color .2s,transform .15s; }
.carousel-arrow svg { width:20px; height:20px; fill:currentColor; }
.carousel-arrow:hover { border-color:var(--gold-line); color:var(--gold); }
.carousel-arrow:active { transform:scale(.94); }
.carousel-dots { display:flex; gap:9px; }
.carousel-dots button { width:9px; height:9px; padding:0; border:0; border-radius:50%; background:var(--line-2); cursor:pointer; transition:background .2s,width .2s; }
.carousel-dots button[aria-current="true"] { background:var(--gold); width:24px; border-radius:var(--r-pill); }
.carousel-toggle .i-play { display:none; }
.carousel-toggle[aria-pressed="true"] .i-pause { display:none; }
.carousel-toggle[aria-pressed="true"] .i-play { display:block; }

/* ---- FAQ ---- */
.faq-list { max-width:820px; }
.faq-list details { border:1px solid var(--line); border-radius:var(--r); background:var(--card); margin-bottom:12px; overflow:hidden; }
.faq-list summary { cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:var(--sp-4) var(--sp-5); font-size:clamp(16px,2vw,18px); font-weight:700; color:var(--ink); }
.faq-list summary::-webkit-details-marker { display:none; }
.faq-list summary::after { content:"+"; color:var(--gold); font-weight:400; font-size:26px; line-height:1; flex:none; }
.faq-list details[open] summary::after { content:"–"; }
.faq-list p { color:var(--muted); padding:0 var(--sp-5) var(--sp-5); max-width:70ch; font-size:16px; }

/* ---- SOCIAL (brand-coloured tiles) ---- */
.social-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:var(--gap); }
.social-tile { display:flex; flex-direction:column; gap:10px; min-height:158px; justify-content:space-between; padding:22px;
  border-radius:var(--r-lg); border:1px solid var(--line-2); background:var(--card); position:relative; overflow:hidden;
  transition:transform .2s var(--ease), border-color .2s; }
.st-icon { width:30px; height:30px; fill:#fff; position:relative; z-index:1; filter:drop-shadow(0 1px 2px rgba(0,0,0,.5)); }
.st-text { display:flex; flex-direction:column; gap:4px; position:relative; z-index:1; }
.social-tile::before { content:""; position:absolute; inset:0; opacity:.92; z-index:0; }
.social-tile.ig::before { background:linear-gradient(135deg,#405de6,#833ab4 32%,#c13584 58%,#e1306c 78%,#fd1d1d); }
.social-tile.tk::before { background:linear-gradient(135deg,#25F4EE 0%,#0a2b2c 52%,#FE2C55 100%); }
.social-tile.fb::before { background:linear-gradient(135deg,#1d3a6e,#1877F2); }
.social-tile.th::before { background:linear-gradient(135deg,#43434c,#121214); }
.social-tile::after { content:""; position:absolute; left:0; right:0; bottom:0; height:74%; background:linear-gradient(0deg,rgba(0,0,0,.74) 0%,rgba(0,0,0,.45) 30%,transparent 72%); z-index:0; }
.social-tile > * { position:relative; z-index:1; }
.social-tile:hover { transform:translateY(-4px); border-color:var(--gold-line); }
.st-name { font-size:19px; font-weight:800; letter-spacing:-.01em; }
.st-sub { color:rgba(255,255,255,.93); font-size:13.5px; }
.review-cta { margin-top:26px; display:flex; flex-direction:column; align-items:center; gap:14px; text-align:center; }
.review-cta p { color:var(--muted); font-weight:600; }

/* ---- contact (rounded split card) ---- */
.contact-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:0; align-items:stretch;
  border:1px solid var(--line-2); border-radius:var(--r-xl); overflow:hidden; background:var(--graphite);
  padding-inline:0; width:min(var(--maxw), calc(100% - 2*var(--gutter))); } /* inset the card itself (gutter is outer, not inner) */
.contact-media { min-height:520px; }
.contact-media picture, .contact-media img { width:100%; height:100%; }
.contact-media img { object-fit:cover; }
.contact-card { padding:clamp(30px,4.5vw,60px); display:flex; flex-direction:column; }
.contact-card .headline { margin-top:6px; }
.contact-list { margin:26px 0; display:flex; flex-direction:column; gap:0; }
.contact-list > div { padding:var(--sp-4) 0; border-top:1px solid var(--line); }
.contact-list dt { color:var(--muted-2); font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; margin-bottom:5px; }
.contact-list dd { margin:0; font-size:18px; font-weight:600; }
.contact-list a:hover { color:var(--gold); }
.dir-btns { display:flex; flex-wrap:wrap; gap:10px; margin:4px 0 22px; }
.dir-btns .btn { flex:1 1 0; min-width:150px; }
.btn.maps { background:rgba(66,133,244,.12); border-color:rgba(66,133,244,.42); color:#a9c7fb; }
.btn.maps:hover { background:#1967d2; color:#fff; border-color:#1967d2; }
.btn.waze { background:rgba(51,204,255,.12); border-color:rgba(51,204,255,.4); color:#9fe6ff; }
.btn.waze:hover { background:var(--waze); color:#042430; border-color:var(--waze); }

/* ---- footer ---- */
.footer { border-top:1px solid var(--line); background:#040405; }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px; padding-top:64px; padding-bottom:48px; }
.footer-brand .brand-logo { height:54px; margin-bottom:18px; }
.tagline { color:var(--gold); font-weight:800; letter-spacing:.04em; text-transform:uppercase; font-size:13px; margin-bottom:14px; }
.footer-desc { color:var(--muted); font-size:15px; max-width:42ch; margin-bottom:20px; }
.footer-social { display:flex; flex-wrap:wrap; gap:18px; }
.footer-social a { color:var(--muted); font-size:14px; font-weight:600; }
.footer-social a:hover { color:var(--gold); }
.footer-col { display:flex; flex-direction:column; gap:12px; }
.footer-col h3 { color:var(--ink); font-size:13px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; margin-bottom:4px; }
.footer-col a, .footer-col span { color:var(--muted); font-size:15px; }
.footer-col a:hover { color:var(--gold); }
.footer-bottom { display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; padding-top:24px; padding-bottom:36px;
  border-top:1px solid var(--line); color:var(--muted-2); font-size:13px; }
/* ANPC / EU consumer-protection compliance badges */
.footer-legal { display:flex; flex-wrap:wrap; gap:12px; padding:22px 0; border-top:1px solid var(--line); }
.legal-banner { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:var(--r);
  background:#f3f6fa; color:#13427a; border:1px solid rgba(0,0,0,.08); transition:transform .15s var(--ease), box-shadow .2s; }
.legal-banner:hover { transform:translateY(-1px); box-shadow:0 8px 22px rgba(0,0,0,.28); }
.legal-banner:focus-visible { outline:2px solid var(--gold); outline-offset:3px; }
.lb-icon { width:26px; height:26px; fill:#13427a; flex:none; }
.lb-text { display:flex; flex-direction:column; line-height:1.2; }
.lb-text strong { font-size:12px; font-weight:800; letter-spacing:.02em; }
.lb-text span { font-size:11px; color:#3d5a7d; }

/* ---- mobile sticky CTA bar (phones only) ---- */
.mobilebar { display:none; }
.mobilebar a, .mobilebar button { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
  flex:1; min-height:54px; border-radius:var(--r); font:inherit; font-size:11px; font-weight:800; color:var(--ink);
  background:rgba(255,255,255,.06); border:1px solid var(--line-2);
  -webkit-appearance:none; appearance:none; cursor:pointer; text-align:center; }
.mobilebar a svg, .mobilebar button svg { width:20px; height:20px; fill:currentColor; }
.mobilebar .mb-contact { background:var(--gold); color:#1a1407; border-color:var(--gold); }
.mobilebar .mb-dir { background:rgba(66,133,244,.16); border-color:rgba(66,133,244,.42); color:#a9c7fb; }

/* placeholder links stay visible but inert until URL is filled in js/app.js (RD_LINKS) */
[data-placeholder] { cursor:default; }

/* directions chooser (Maps / Waze) */
.dir-backdrop { position:fixed; inset:0; z-index:74; background:rgba(0,0,0,.55); backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px); }
.dir-sheet { position:fixed; left:12px; right:12px; bottom:calc(82px + env(safe-area-inset-bottom)); z-index:76;
  display:flex; flex-direction:column; gap:10px; padding:16px; border-radius:var(--r-lg);
  background:var(--graphite); border:1px solid var(--line-2); box-shadow:0 -14px 44px rgba(0,0,0,.55); }
.dir-sheet .btn { width:100%; }
.dir-sheet-title { color:var(--muted); font-size:13px; font-weight:700; text-align:center; }
.dir-backdrop[hidden], .dir-sheet[hidden] { display:none; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
/* desktop/tablet: balance the reviews strip across the full card (no dead gutter) */
@media (min-width:641px) {
  .reviews-card { justify-content:space-between; flex-wrap:nowrap; text-align:left; gap:clamp(20px,3vw,40px); }
  .reviews-score { flex:none; }
  .reviews-text { flex:1; max-width:48ch; text-align:left; }
}
/* desktop: two-column FAQ so the accordion uses the full width (kills empty right) */
@media (min-width:901px) {
  .faq { display:grid; grid-template-columns:minmax(280px,360px) 1fr; gap:clamp(32px,5vw,72px); align-items:start; }
  .faq .head { max-width:none; margin-bottom:0; position:sticky; top:88px; }
  .faq-list { max-width:none; }
}
@media (max-width:900px) {
  .contact-grid { grid-template-columns:1fr; }
  .contact-media { min-height:300px; order:2; }
  .contact-card { order:1; }
  .grid-3, .social-grid { grid-template-columns:1fr 1fr; }
  .carousel-slide { flex:0 0 calc((100% - var(--gap)) / 2); }
  .footer-top { grid-template-columns:1fr 1fr; }
  .footer-brand { grid-column:1 / -1; }
}
@media (max-width:640px) {
  body { padding-bottom:calc(88px + env(safe-area-inset-bottom)); } /* clear the mobile bar + breathing room */
  .dock { display:none; }
  .nav-cta { display:none; } /* WhatsApp lives in the bottom bar on phones */
  .brand-logo { height:36px; }
  .hero { min-height:auto; padding:calc(var(--nav-h) + 66px) 0 46px; }
  .grid-3, .social-grid { grid-template-columns:1fr; }
  .carousel-slide { flex:0 0 86%; }
  .social { padding-bottom:clamp(28px,5vw,40px); }  /* trim the dead band before contact */
  .contact { padding-top:clamp(28px,5vw,40px); }
  .hero-actions { width:100%; }
  .hero-actions .btn { flex:1; }
  .reviews-card { flex-direction:column; gap:10px; }
  .dir-btns .btn { flex:1 1 0; min-width:0; } /* Maps + Waze share one row */
  .contact-card .btn.wa.wide { display:none; } /* redundant with the sticky WhatsApp bar on phones */
  .footer-top { grid-template-columns:1fr; }
  /* sticky bottom CTA bar */
  .mobilebar { display:flex; gap:8px; position:fixed; left:0; right:0; bottom:0; z-index:75;
    padding:8px max(10px,env(safe-area-inset-left)) calc(8px + env(safe-area-inset-bottom));
    background:rgba(3,3,4,.94); border-top:1px solid var(--line-2);
    backdrop-filter:saturate(180%) blur(16px); -webkit-backdrop-filter:saturate(180%) blur(16px); }
}
@media (pointer:coarse) {
  .btn, .lang-btn, .dock-btn, .carousel-arrow { min-height:44px; }
  .carousel-dots { gap:12px; }
  .carousel-dots button { position:relative; }
  .carousel-dots button::after { content:""; position:absolute; inset:-17px -7px; } /* 44px hit area, 9px painted dot */
}
