/* ===========================================================
   LOS SANTOS — Luxury Car Customs  ·  v2 stylesheet
   Dark-cinematic · depth + grain · bento · EN/AR + RTL
   Ref: DESIGN-GUIDELINES.md (+ v2 addendum)
   =========================================================== */

/* ---------- Tokens ---------- */
:root{
  --ink:#1c1b20;
  --ink-deep:#131217;
  --ink-deeper:#0d0c10;
  --surface:#232228;
  --surface-2:#2b2a31;
  --hairline:rgba(255,255,255,.08);
  --hairline-2:rgba(255,255,255,.14);
  --white:#ffffff;
  --silver:#dddddd;
  --graphite:#8a8a8e;
  --graphite-line:#5c5c5e;
  --purple:#8b28e3;
  --purple-bright:#a558f0;
  --purple-glow:rgba(139,40,227,.30);
  --chrome:linear-gradient(176deg,#fff 0%,#ececed 30%,#a6a7ad 50%,#f6f6f8 66%,#c4c5cb 100%);

  --maxw:1280px;
  --pad:clamp(20px,5vw,72px);
  --r-xl:22px;--r-lg:18px;--r-md:13px;--r-sm:9px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --t:.55s var(--ease);

  --font:"Montserrat",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-ar:"IBM Plex Sans Arabic","Montserrat",sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
html,body{max-width:100%;overflow-x:hidden}
body{
  font-family:var(--font);background:var(--ink);color:var(--silver);
  line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;position:relative;
}
[lang="ar"],[dir="rtl"]{font-family:var(--font-ar)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--purple-bright);outline-offset:3px;border-radius:5px}
::selection{background:var(--purple);color:#fff}

/* ---------- Film grain (premium cinematic) ---------- */
.grain{position:fixed;inset:0;z-index:90;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(72px,9vw,150px);position:relative}
[data-screen-label="Warranty"],.quote{contain:paint}
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--silver);
  display:inline-flex;align-items:center;gap:12px;margin-bottom:22px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--purple);box-shadow:0 0 8px var(--purple-glow)}
[dir="rtl"] .eyebrow{letter-spacing:0}
h1,h2,h3,h4{color:var(--white);font-weight:700;line-height:1.05;letter-spacing:-.02em;text-wrap:balance}
[dir="rtl"] h1,[dir="rtl"] h2,[dir="rtl"] h3,[dir="rtl"] h4{letter-spacing:0;line-height:1.25}
.h-display{font-size:clamp(2.9rem,7.4vw,6.4rem);font-weight:800;letter-spacing:-.035em;line-height:.98}
[dir="rtl"] .h-display{letter-spacing:0;line-height:1.12}
.h2{font-size:clamp(2.1rem,4.4vw,3.4rem);font-weight:800;letter-spacing:-.025em}
.lead{font-size:clamp(1.05rem,1.5vw,1.26rem);color:var(--silver);max-width:58ch;text-wrap:pretty}
.muted{color:var(--graphite)}
.section-head{max-width:64ch;margin-bottom:clamp(40px,5vw,68px)}
.ghost-num{font-size:clamp(5rem,14vw,11rem);font-weight:800;line-height:.8;letter-spacing:-.04em;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.07);user-select:none;pointer-events:none}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:0 28px;
  border-radius:100px;font-weight:600;font-size:15px;letter-spacing:.01em;white-space:nowrap;
  transition:transform .25s var(--ease),box-shadow .35s var(--ease),background .3s,border-color .3s,color .3s}
.btn svg{width:18px;height:18px;flex:none}
.btn-primary{background:var(--white);color:#16151a;box-shadow:0 1px 0 rgba(255,255,255,.4) inset}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 38px -12px var(--purple-glow),0 0 0 1px rgba(165,88,240,.55)}
.btn-ghost{border:1px solid var(--hairline-2);color:var(--white);background:rgba(255,255,255,.02)}
.btn-ghost:hover{border-color:var(--purple-bright);transform:translateY(-2px);box-shadow:0 0 30px -8px var(--purple-glow)}
.btn-sm{min-height:46px;padding:0 20px;font-size:14px}
.btn-block{width:100%}

/* ---------- Header ---------- */
.header{position:fixed;inset-block-start:0;inset-inline:0;z-index:60;
  transition:background .4s var(--ease),border-color .4s,backdrop-filter .4s;border-bottom:1px solid transparent}
.header.scrolled{background:rgba(13,12,16,.72);backdrop-filter:blur(18px) saturate(1.3);border-bottom-color:var(--hairline)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;height:80px;min-width:0}
.brand{display:flex;align-items:center;gap:13px;flex:none;min-width:0;direction:ltr}
.brand img{height:44px;width:auto;max-width:160px;filter:drop-shadow(0 2px 12px rgba(0,0,0,.55))}
.brand .desc{font-size:9.5px;letter-spacing:.32em;text-transform:uppercase;color:var(--graphite);font-weight:600;
  border-inline-start:1px solid var(--hairline);padding-inline-start:13px;white-space:nowrap}
[dir="rtl"] .brand .desc{letter-spacing:.05em}
.nav{display:flex;align-items:center;gap:32px;flex:none}
.nav a{font-size:14px;font-weight:500;color:var(--silver);position:relative;transition:color .25s}
.nav a::after{content:"";position:absolute;inset-inline-start:0;bottom:-6px;width:0;height:1.5px;
  background:var(--purple-bright);transition:width .3s var(--ease);box-shadow:0 0 8px var(--purple-glow)}
.nav a:hover{color:#fff}.nav a:hover::after{width:100%}
.header-cta{display:flex;align-items:center;gap:12px;flex:none}

/* language toggle */
.lang{display:inline-flex;align-items:center;border:1px solid var(--hairline-2);border-radius:100px;overflow:hidden;height:38px}
.lang button{padding:0 13px;height:100%;font-size:12.5px;font-weight:600;letter-spacing:.05em;color:var(--graphite);transition:.25s}
.lang button.on{background:rgba(255,255,255,.92);color:#16151a}
.lang button:not(.on):hover{color:#fff}
.lang .sep{width:1px;height:16px;background:var(--hairline-2)}

.burger{display:none;width:46px;height:46px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{width:22px;height:1.6px;background:var(--white);transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{position:fixed;inset-block-start:80px;inset-inline:0;z-index:55;background:rgba(13,12,16,.98);
  backdrop-filter:blur(22px);border-bottom:1px solid var(--hairline);transform:translateY(-12px);opacity:0;
  pointer-events:none;transition:.35s var(--ease);padding:14px var(--pad) 28px}
.mobile-menu.open{transform:none;opacity:1;pointer-events:auto}
.mobile-menu a.m-link{display:flex;align-items:center;justify-content:space-between;padding:16px 2px;font-size:18px;
  font-weight:500;color:var(--silver);border-bottom:1px solid var(--hairline)}
.mobile-menu a.m-link::after{content:"→";color:var(--graphite);font-size:15px}
[dir="rtl"] .mobile-menu a.m-link::after{content:"←"}
.mobile-cta{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;margin-top:22px;min-height:54px;
  border-radius:100px;background:var(--white);color:#16151a !important;font-weight:700;font-size:15.5px;
  box-shadow:0 0 0 1px rgba(165,88,240,.45),0 14px 30px -12px var(--purple-glow)}
.mobile-cta svg{width:19px;height:19px;color:#16151a}
.m-lang{display:flex;gap:10px;margin-top:18px}
.m-lang button{flex:1;height:46px;border:1px solid var(--hairline-2);border-radius:100px;font-weight:600;font-size:14px;color:var(--graphite)}
.m-lang button.on{background:rgba(255,255,255,.92);color:#16151a;border-color:transparent}

/* ---------- Glow ---------- */
.glow{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0;opacity:.6;background:var(--purple-glow)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--ink-deep);isolation:isolate}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden;background:
  radial-gradient(80% 62% at 76% 18%,rgba(139,40,227,.22),transparent 56%),
  radial-gradient(70% 48% at 18% 72%,rgba(255,255,255,.09),transparent 62%),
  linear-gradient(145deg,#08080b 0%,#17161b 38%,#25242a 50%,#111015 72%,#07070a 100%)}
.hero-media::before{content:"";position:absolute;inset:-30%;opacity:.72;mix-blend-mode:screen;
  background:
    linear-gradient(112deg,transparent 0 36%,rgba(255,255,255,.18) 42%,rgba(165,88,240,.16) 46%,transparent 54%),
    repeating-linear-gradient(112deg,transparent 0 54px,rgba(255,255,255,.055) 55px,transparent 59px);
  transform:translate3d(-12%,0,0) rotate(-2deg);animation:heroSweep 14s var(--ease) infinite alternate}
.hero-media::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(13,12,16,.58) 0%,rgba(13,12,16,.22) 34%,rgba(13,12,16,.76) 74%,var(--ink) 100%),
  linear-gradient(90deg,rgba(13,12,16,.92) 0%,rgba(13,12,16,.38) 42%,rgba(13,12,16,.78) 100%),
  radial-gradient(120% 86% at 78% 8%,rgba(139,40,227,.22),transparent 58%)}
@keyframes heroSweep{to{transform:translate3d(10%,2%,0) rotate(-2deg)}}
.hero-side{position:absolute;z-index:2;inset-inline-start:calc(var(--pad) - 6px);inset-block-end:230px;
  writing-mode:vertical-rl;transform:rotate(180deg);font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--graphite);font-weight:600;display:flex;align-items:center;gap:14px}
.hero-side::after{content:"";width:1px;height:54px;background:linear-gradient(var(--graphite-line),transparent)}
[dir="rtl"] .hero-side{display:none}
.hero-inner{position:relative;z-index:3;width:100%;padding-block-end:clamp(40px,7vh,78px);padding-block-start:120px}
.hero h1{margin:18px 0 0;max-width:17ch}
.hero .chrome-text{background:var(--chrome);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{margin:24px 0 0;max-width:48ch}
.hero-pills{display:flex;flex-wrap:wrap;gap:9px;margin:20px 0 32px;max-width:720px}
.hero-pills span{display:inline-flex;align-items:center;min-height:34px;padding:0 13px;border:1px solid var(--hairline);
  border-radius:100px;background:rgba(255,255,255,.035);color:var(--silver);font-size:12.5px;font-weight:700;letter-spacing:.03em}
[dir="rtl"] .hero-pills span{letter-spacing:0}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-meta{display:flex;flex-wrap:wrap;gap:14px 40px;margin-top:46px;padding-top:28px;border-top:1px solid var(--hairline)}
.hero-meta .item{display:flex;flex-direction:column;gap:3px}
.hero-meta .k{font-size:clamp(1.5rem,2.3vw,2.05rem);font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1}
.hero-meta .v{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--graphite);font-weight:600}
[dir="rtl"] .hero-meta .v{letter-spacing:.02em}

.exclusive-plaque{position:relative;display:inline-flex;align-items:center;gap:15px;max-width:100%;padding:11px 20px 11px 15px;
  overflow:hidden;isolation:isolate;clip-path:polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%,0 10px);
  border:1px solid rgba(255,255,255,.18);background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.025) 50%,rgba(139,40,227,.08));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.13),0 14px 38px rgba(0,0,0,.22);color:var(--silver)}
.exclusive-plaque::before{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(165,88,240,.34),transparent 18% 82%,rgba(255,255,255,.16));opacity:.44}
.exclusive-plaque::after{content:"";position:absolute;inset:-30% auto -30% -45%;width:38%;z-index:-1;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.24),transparent);transform:skewX(-22deg);
  animation:plaqueSheen 7.5s var(--ease) infinite}
.exclusive-mark{display:grid;place-items:center;flex:none;width:35px;height:35px;clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);
  border:1px solid rgba(255,255,255,.2);background:linear-gradient(145deg,rgba(255,255,255,.16),rgba(139,40,227,.14) 58%,rgba(19,18,23,.9));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18),0 0 24px rgba(139,40,227,.18)}
.exclusive-mark svg{width:19px;height:19px;stroke:var(--white);stroke-width:1.55;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 0 8px rgba(255,255,255,.24))}
.exclusive-copy{display:flex;min-width:0;flex-direction:column;gap:3px}
.exclusive-label{font-size:10px;line-height:1;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--graphite)}
.exclusive-brand{font-size:13px;line-height:1.12;font-weight:800;letter-spacing:.11em;text-transform:uppercase;color:var(--white)}
[dir="rtl"] .exclusive-plaque{padding:11px 15px 11px 20px}
[dir="rtl"] .exclusive-label,[dir="rtl"] .exclusive-brand{letter-spacing:0;text-transform:none}
@keyframes plaqueSheen{0%,58%{transform:translateX(0) skewX(-22deg);opacity:0}68%{opacity:.7}100%{transform:translateX(430%) skewX(-22deg);opacity:0}}

/* ---------- Image placeholders ---------- */
.ph{position:relative;overflow:hidden;background:var(--ink-deep);border:1px solid var(--hairline);border-radius:var(--r-md);
  background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.022) 0 2px,transparent 2px 11px),
    radial-gradient(120% 100% at 80% 10%,rgba(139,40,227,.12),transparent 60%)}
.ph::after{content:attr(data-label);position:absolute;inset-inline-start:14px;inset-block-end:12px;
  font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:10.5px;letter-spacing:.04em;color:var(--graphite);
  background:rgba(0,0,0,.45);padding:5px 9px;border-radius:6px;border:1px solid var(--hairline);text-transform:uppercase;max-width:82%}
.ph .corner{position:absolute;inset-block-start:12px;inset-inline-end:12px;width:20px;height:20px;
  border-top:1px solid var(--graphite-line);border-inline-end:1px solid var(--graphite-line);opacity:.6}
/* ---------- Services (bento) ---------- */
.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{position:relative;overflow:hidden;display:flex;flex-direction:column;gap:16px;
  background:linear-gradient(180deg,var(--surface),#1d1c22);border:1px solid var(--hairline);border-radius:var(--r-lg);
  padding:30px 30px 28px;transition:transform var(--t),border-color var(--t),box-shadow var(--t);min-width:0}
.card::before{content:"";position:absolute;inset-block-start:0;inset-inline:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--purple),transparent);opacity:0;transition:opacity var(--t)}
.card::after{content:"";position:absolute;inset-block-start:-40%;inset-inline-end:-30%;width:60%;height:80%;
  background:radial-gradient(circle,var(--purple-glow),transparent 65%);opacity:0;transition:opacity .5s var(--ease);pointer-events:none}
.card:hover{transform:translateY(-6px);border-color:var(--hairline-2);box-shadow:0 30px 60px -34px rgba(0,0,0,.85)}
.card:hover::before{opacity:1}.card:hover::after{opacity:.7}
.card .cidx{position:absolute;inset-block-start:20px;inset-inline-end:26px;font-size:13px;font-weight:700;
  color:var(--graphite-line);letter-spacing:.1em;font-variant-numeric:tabular-nums}
.svc-feat{grid-column:span 7}
.svc-5{grid-column:span 5}
.svc-4{grid-column:span 4}
.svc-icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;border:1px solid var(--hairline);
  background:rgba(139,40,227,.08);color:var(--purple-bright)}
.svc-icon svg{width:25px;height:25px}
.card h3{font-size:1.42rem}
.svc-feat .card-title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}
.card .svc-desc{color:var(--silver);font-size:15px;max-width:44ch}
.svc-visual{position:relative;height:92px;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--hairline);
  background:linear-gradient(140deg,#141318,#292730 48%,#121116);box-shadow:inset 0 1px 0 rgba(255,255,255,.045)}
.ppf-visual{background:
  linear-gradient(120deg,rgba(255,255,255,.12),transparent 26%),
  repeating-linear-gradient(112deg,rgba(255,255,255,.045) 0 1px,transparent 1px 10px),
  linear-gradient(140deg,#15151a,#2a2730 50%,#111015)}
.ppf-visual::before{content:"";position:absolute;inset-inline-start:12%;inset-block-start:18%;width:74%;height:1px;background:linear-gradient(90deg,transparent,#fff,transparent);opacity:.3}
.ppf-visual span{position:absolute;width:14px;height:14px;border-radius:50%;border:1px solid rgba(255,255,255,.52);background:rgba(255,255,255,.12)}
.ppf-visual span:nth-child(1){inset-inline-start:22%;inset-block-start:42%}.ppf-visual span:nth-child(2){inset-inline-start:48%;inset-block-start:24%;width:10px;height:10px}.ppf-visual span:nth-child(3){inset-inline-start:70%;inset-block-start:52%;width:18px;height:18px}
.wrap-visual{display:flex;gap:8px;padding:13px;background:linear-gradient(120deg,#111015,#222127)}
.wrap-visual span{flex:1;border-radius:9px;box-shadow:inset 0 1px 0 rgba(255,255,255,.22)}
.wrap-visual span:nth-child(1){background:linear-gradient(145deg,#09090b,#76777c)}.wrap-visual span:nth-child(2){background:linear-gradient(145deg,#421020,#aa4f64)}.wrap-visual span:nth-child(3){background:linear-gradient(145deg,#182d25,#4b8a67)}.wrap-visual span:nth-child(4){background:linear-gradient(145deg,#33224d,#a558f0)}
.tint-visual{display:flex;align-items:flex-end;gap:10px;padding:14px;background:linear-gradient(120deg,#1f2024,#09090b)}
.tint-visual span{flex:1;border-radius:9px 9px 0 0;background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(0,0,0,.72));border:1px solid rgba(255,255,255,.08)}
.tint-visual span:nth-child(1){height:42%;opacity:.58}.tint-visual span:nth-child(2){height:66%;opacity:.76}.tint-visual span:nth-child(3){height:88%;opacity:.95}
.stance-visual::before{content:"";position:absolute;inset-inline:11%;inset-block-end:28px;height:26px;border-block-start:1px solid rgba(255,255,255,.42);border-radius:50% 50% 0 0}
.stance-visual::after{content:"";position:absolute;inset-inline:18%;inset-block-end:24px;height:1px;background:linear-gradient(90deg,transparent,#fff,transparent);opacity:.35}
.stance-visual span{position:absolute;inset-inline-start:58%;inset-block-start:22px;width:28%;height:2px;background:var(--purple-bright);box-shadow:0 0 18px var(--purple-glow);transform:skewX(-22deg)}
.headlight-visual{background:linear-gradient(120deg,#08080b,#18171d)}
.headlight-visual::before{content:"";position:absolute;inset-inline-start:12%;inset-block-start:33%;width:58px;height:26px;border:1px solid rgba(255,255,255,.32);border-radius:50% 8px 8px 50%;background:rgba(255,255,255,.05)}
.headlight-visual span{position:absolute;inset-inline-start:31%;height:2px;background:linear-gradient(90deg,rgba(255,255,255,.9),rgba(165,88,240,.5),transparent);transform-origin:left center}
.headlight-visual span:nth-child(1){inset-block-start:39%;width:58%;transform:rotate(-8deg)}.headlight-visual span:nth-child(2){inset-block-start:56%;width:62%;transform:rotate(8deg)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}
.chip{font-size:12.5px;color:var(--silver);border:1px solid var(--hairline);background:rgba(255,255,255,.015);
  padding:7px 13px;border-radius:100px;display:inline-flex;align-items:center;gap:7px}
.chip::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--purple-bright);flex:none}
.card-foot{margin-top:auto;padding-top:10px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.warranty-chip{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--silver);
  border:1px solid var(--hairline-2);padding:7px 12px;border-radius:100px}
[dir="rtl"] .warranty-chip{letter-spacing:0}
.ask-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#fff;transition:gap .25s var(--ease),color .25s}
.ask-link svg{width:15px;height:15px;color:var(--purple-bright);transition:transform .25s var(--ease)}
[dir="rtl"] .ask-link svg{transform:scaleX(-1)}
.ask-link:hover{color:var(--purple-bright)}.ask-link:hover svg{transform:translateX(4px)}
[dir="rtl"] .ask-link:hover svg{transform:scaleX(-1) translateX(4px)}
.svc-strip{height:90px;border-radius:var(--r-md);margin-top:2px}
.svc-strip.gloss{background:linear-gradient(120deg,#15151a,#2a2730 45%,#15151a),radial-gradient(circle at 30% 20%,rgba(255,255,255,.12),transparent 40%)}

/* ---------- Why wrap (bento) ---------- */
.why-bento{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:auto;gap:18px}
.why-intro{grid-column:span 5}
.why-media{grid-column:span 7;min-height:300px;border-radius:var(--r-lg)}
.why-cell{grid-column:span 4;background:linear-gradient(180deg,var(--surface),#1d1c22);border:1px solid var(--hairline);
  border-radius:var(--r-lg);padding:26px;display:flex;flex-direction:column;gap:10px;transition:transform var(--t),border-color var(--t);min-width:0}
.why-cell:hover{transform:translateY(-5px);border-color:var(--hairline-2)}
.why-ico{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;border:1px solid var(--hairline);
  background:rgba(139,40,227,.07);color:var(--purple-bright);margin-bottom:4px}
.why-ico svg{width:21px;height:21px}
.why-cell .wn{font-size:12px;font-weight:700;color:var(--purple-bright);letter-spacing:.12em}
.why-cell h4{font-size:1.12rem}
.why-cell p{font-size:14px;color:var(--graphite)}
.why-cell.wide{grid-column:span 8}

/* ---------- Materials (editorial archival) ---------- */
.finish-groups{display:flex;flex-direction:column;gap:46px}
.finish-group{display:grid;grid-template-columns:200px 1fr;gap:30px;align-items:start}
.fg-label{position:sticky;top:100px}
.fg-label .fgi{font-size:12px;font-weight:700;color:var(--graphite-line);letter-spacing:.1em;margin-bottom:10px}
.fg-label h3{font-size:1.3rem;letter-spacing:-.01em}
.fg-label .ct{display:block;margin-top:8px;font-size:11px;color:var(--graphite);font-weight:500;letter-spacing:.12em;text-transform:uppercase;font-family:ui-monospace,Menlo,monospace}
[dir="rtl"] .fg-label .ct{letter-spacing:.02em;font-family:var(--font-ar)}
.swatch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px}
.swatch{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--hairline);cursor:pointer;transition:transform .35s var(--ease-out),border-color .3s}
.swatch:hover,.swatch:focus-visible{transform:translateY(-5px);border-color:var(--hairline-2)}
.swatch .chip-c{aspect-ratio:1.4/1;position:relative}
.swatch .chip-c::after{content:"";position:absolute;inset:0;background:linear-gradient(125deg,rgba(255,255,255,.18),transparent 42%)}
.swatch.matte .chip-c::after{background:linear-gradient(125deg,rgba(255,255,255,.04),transparent 50%)}
.swatch.satin .chip-c::after{background:linear-gradient(125deg,rgba(255,255,255,.09),transparent 46%)}
.swatch .meta{padding:11px 13px;background:var(--surface);display:flex;flex-direction:column;gap:3px}
.swatch .nm{font-size:13px;font-weight:600;color:#fff}
.swatch .av{font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:700}
[dir="rtl"] .swatch .av{letter-spacing:0}
.av-available{color:#7fd6a3}.av-request{color:var(--silver)}.av-soon{color:var(--graphite)}
.finish-note{margin-top:34px;font-size:13.5px;color:var(--graphite);display:flex;gap:11px;align-items:flex-start}
.finish-note svg{width:17px;height:17px;color:var(--purple-bright);flex:none;margin-top:3px}

/* ---------- Warranty ---------- */
.warranty-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.wcard{grid-column:span 6;position:relative;overflow:hidden;background:linear-gradient(160deg,var(--surface-2),#1c1b21);
  border:1px solid var(--hairline);border-radius:var(--r-lg);padding:40px 36px}
.wcard .years{font-size:clamp(3.2rem,6.5vw,5rem);font-weight:800;line-height:1;letter-spacing:-.04em;color:#fff;display:flex;align-items:baseline;gap:10px}
.wcard .years span{font-size:1rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--purple-bright)}
[dir="rtl"] .wcard .years span{letter-spacing:0}
.wcard h3{margin:16px 0 8px;font-size:1.28rem}
.wcard p{font-size:14.5px;color:var(--graphite);max-width:44ch}
.wcard .ico{position:absolute;inset-block-start:32px;inset-inline-end:34px;color:var(--graphite-line);opacity:.55}
.wcard .ico svg{width:42px;height:42px}
.warranty-disc{grid-column:span 12;font-size:13.5px;color:var(--graphite);display:flex;gap:12px;align-items:flex-start;
  border:1px solid var(--hairline);background:rgba(255,255,255,.012);padding:18px 22px;border-radius:var(--r-md)}
.warranty-disc svg{width:18px;height:18px;color:var(--silver);flex:none;margin-top:2px}

/* ---------- Process ---------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}
.step{position:relative;padding-top:32px}
.step::before{content:"";position:absolute;top:0;inset-inline:0;height:1px;background:var(--hairline)}
.step::after{content:"";position:absolute;top:0;inset-inline-start:0;width:34px;height:1px;background:var(--purple-bright);box-shadow:0 0 8px var(--purple-glow)}
.step .n{font-size:12px;font-weight:700;letter-spacing:.2em;color:var(--purple-bright);margin-bottom:18px}
[dir="rtl"] .step .n{letter-spacing:.05em}
.step h3{font-size:1.35rem;margin-bottom:10px}
.step p{font-size:14.5px;color:var(--graphite)}

/* ---------- Gallery + before/after ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}
.ga{border-radius:var(--r-md);min-height:200px}
.ga-1{grid-column:span 8;min-height:360px}
.ga-2{grid-column:span 4;min-height:360px}
.ga-3,.ga-4,.ga-5{grid-column:span 4}

.ba-block{margin-top:50px}
.ba-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:22px;flex-wrap:wrap}
.ba{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--hairline);
  user-select:none;touch-action:none;cursor:ew-resize;background:var(--ink-deep)}
.ba-layer{position:absolute;inset:0}
.ba-after{background:radial-gradient(120% 120% at 70% 20%,rgba(139,40,227,.32),transparent 55%),linear-gradient(160deg,#2a2730,#141318)}
.ba-after::before{content:"";position:absolute;inset:0;mix-blend-mode:screen;
  background:repeating-linear-gradient(115deg,rgba(255,255,255,.05) 0 1px,transparent 1px 7px),linear-gradient(120deg,rgba(255,255,255,.15),transparent 40%)}
.ba-before{background:linear-gradient(160deg,#2a2a2c,#1a1a1b);filter:saturate(.5) brightness(.82)}
.ba-before::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(115deg,rgba(255,255,255,.025) 0 2px,transparent 2px 12px)}
.ba-clip{position:absolute;inset:0;clip-path:inset(0 50% 0 0);z-index:2}
.ba-tag{position:absolute;inset-block-start:16px;font-family:ui-monospace,Menlo,monospace;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;padding:6px 12px;border-radius:100px;background:rgba(0,0,0,.5);border:1px solid var(--hairline);color:var(--silver);z-index:4}
.ba-tag.before{inset-inline-start:16px}.ba-tag.after{inset-inline-end:16px}
.ba-cap{position:absolute;left:50%;inset-block-end:18px;transform:translateX(-50%);font-family:ui-monospace,Menlo,monospace;
  font-size:11px;color:var(--graphite);background:rgba(0,0,0,.45);padding:5px 10px;border-radius:6px;border:1px solid var(--hairline);z-index:4;white-space:nowrap}
.ba-handle{position:absolute;top:0;bottom:0;inset-inline-start:50%;width:2px;background:linear-gradient(var(--purple-bright),#fff,var(--purple-bright));
  transform:translateX(-50%);z-index:5;box-shadow:0 0 18px var(--purple-glow)}
.ba-knob{position:absolute;top:50%;inset-inline-start:50%;transform:translate(-50%,-50%);width:48px;height:48px;border-radius:50%;
  background:rgba(13,12,16,.85);border:1.5px solid var(--white);display:grid;place-items:center;backdrop-filter:blur(6px);box-shadow:0 6px 22px rgba(0,0,0,.55)}
.ba-knob svg{width:22px;height:22px;color:#fff}

/* ---------- Quote CTA ---------- */
.quote{position:relative;overflow:hidden;background:var(--ink-deep);border-block:1px solid var(--hairline)}
.quote-inner{position:relative;z-index:2;text-align:center;max-width:54ch;margin-inline:auto}
.quote h2{margin-bottom:0}.quote .lead{margin:0 auto 34px}
.quote-prompts{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:26px auto 32px}
.quote-prompts span{display:inline-flex;align-items:center;min-height:38px;padding:0 15px;border-radius:100px;
  border:1px solid var(--hairline);background:rgba(255,255,255,.035);color:var(--silver);font-size:13px;font-weight:700}
.quote-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.quote .glow{width:580px;height:580px;left:50%;top:30%;transform:translate(-50%,-50%)}

/* ---------- Location ---------- */
.loc-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,52px)}
.loc-info{min-width:0}
.loc-row{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--hairline);min-width:0}
.loc-row:last-child{border-bottom:none}
.loc-row > div{min-width:0}
.loc-row .ic{width:44px;height:44px;border-radius:12px;border:1px solid var(--hairline);display:grid;place-items:center;
  color:var(--purple-bright);flex:none;background:rgba(139,40,227,.07)}
.loc-row .ic svg{width:20px;height:20px}
.loc-row .lb{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite);font-weight:600;margin-bottom:4px}
[dir="rtl"] .loc-row .lb{letter-spacing:.02em}
.loc-row .vl{font-size:16px;color:#fff;font-weight:500;overflow-wrap:anywhere}
.loc-row a.vl:hover{color:var(--purple-bright)}
.loc-row .sub{font-size:13px;color:var(--graphite);margin-top:3px}
.loc-map{position:relative;border-radius:var(--r-lg);min-height:460px;overflow:hidden;border:1px solid var(--hairline);
  display:flex;align-items:flex-end;background:var(--ink-deep)}
.loc-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.65) contrast(1.05) brightness(.82)}
.loc-map::after{content:"";position:absolute;inset:0;pointer-events:none;background:
  linear-gradient(180deg,rgba(13,12,16,.1),rgba(13,12,16,.48)),
  radial-gradient(90% 70% at 80% 0,rgba(139,40,227,.16),transparent 58%)}
.loc-map .map-cta{margin:20px;position:relative;z-index:3;background:rgba(13,12,16,.78);backdrop-filter:blur(10px)}

/* ---------- Footer ---------- */
.footer{background:var(--ink-deeper);border-top:1px solid var(--hairline);padding-block:clamp(56px,7vw,88px) 30px}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:40px}
.footer-brand,.footer-col{min-width:0}
.footer-brand img{height:64px;width:auto;max-width:230px;margin-bottom:18px}
.footer-brand p{font-size:14px;color:var(--graphite);max-width:32ch}
.footer-col h4{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver);margin-bottom:18px;font-weight:600}
[dir="rtl"] .footer-col h4{letter-spacing:.02em}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-col a{font-size:14.5px;color:var(--graphite);transition:color .25s;overflow-wrap:anywhere}
.footer-col a:hover{color:#fff}
.footer-bottom{margin-top:clamp(40px,5vw,60px);padding-top:26px;border-top:1px solid var(--hairline);
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}
.footer-bottom p{font-size:12.5px;color:var(--graphite)}.footer-bottom .disc{max-width:54ch}
.footer-credit a{color:var(--silver);font-weight:600}.footer-credit a:hover{color:var(--purple-bright)}

/* ---------- Mobile sticky (compact elegant pill) ---------- */
.sticky-cta{position:fixed;z-index:50;display:none;inset-block-end:calc(18px + env(safe-area-inset-bottom));inset-inline-end:18px}
.sticky-cta a{display:inline-flex;align-items:center;gap:10px;height:54px;padding:0 22px 0 18px;border-radius:100px;
  background:#25D366;color:#0b3a22;font-weight:700;font-size:14.5px;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6),0 0 0 4px rgba(37,211,102,.16)}
.sticky-cta a svg{width:24px;height:24px;color:#0b3a22}
.sticky-cta .lbl{white-space:nowrap}

/* ---------- RTL / overflow guards ---------- */
.brand,.header-cta,.loc-row a[dir="ltr"],.footer-col a[dir="ltr"],.sticky-cta a{unicode-bidi:isolate}
[dir="rtl"] .brand,[dir="rtl"] .header-cta,[dir="rtl"] .loc-row a[dir="ltr"],[dir="rtl"] .footer-col a[dir="ltr"],[dir="rtl"] .sticky-cta a{direction:ltr}

/* ---------- Reveal (transform-only; always visible) ---------- */
@keyframes revealUp{from{transform:translateY(22px)}to{transform:none}}
.reveal{animation:revealUp .7s var(--ease) both}
.reveal.d1{animation-delay:.07s}.reveal.d2{animation-delay:.14s}.reveal.d3{animation-delay:.21s}
.reveal.d4{animation-delay:.28s}.reveal.d5{animation-delay:.35s}
@media (prefers-reduced-motion:reduce){.reveal,.hero-media::before,.exclusive-plaque::after{animation:none}}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .finish-group{grid-template-columns:1fr;gap:18px}
  .fg-label{position:static}
}
@media (max-width:1120px){
  .nav,.header-cta .lang,.header-cta .btn{display:none}
  .burger{display:flex}
}
@media (max-width:980px){
  .nav,.header-cta .lang,.header-cta .btn{display:none}
  .burger{display:flex}
  .svc-feat,.svc-5,.svc-4{grid-column:span 6}
  .why-intro,.why-media,.why-cell,.why-cell.wide{grid-column:span 12}
  .why-media{min-height:260px}
  .wcard{grid-column:span 12}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .loc-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:34px}
  .footer-brand{grid-column:span 2}
  .ga-1,.ga-2,.ga-3,.ga-4,.ga-5{grid-column:span 6;min-height:220px}
  .brand img{height:42px;max-width:150px}
}
@media (max-width:620px){
  body{font-size:16px}
  .hero h1{max-width:10ch}
  .h-display{font-size:2.55rem;line-height:1.07;letter-spacing:0}
  .hero .eyebrow{display:block;max-width:28ch;letter-spacing:.15em;line-height:1.55}
  .hero .eyebrow::before{display:inline-block;vertical-align:middle;margin-inline-end:12px;margin-bottom:3px}
  .hero .lead{max-width:29ch}
  .hero-pills{width:100%;max-width:29ch}
  .exclusive-plaque{gap:12px;padding:10px 15px 10px 12px}
  .exclusive-mark{width:31px;height:31px}
  .exclusive-mark svg{width:17px;height:17px}
  .exclusive-label{font-size:9px;letter-spacing:.18em}
  .exclusive-brand{font-size:12px;letter-spacing:.08em}
  .sticky-cta{display:block}
  .footer{padding-bottom:96px}
  .bento{gap:14px}
  .svc-feat,.svc-5,.svc-4{grid-column:span 12}
  .process-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(6,1fr)}
  .ga,.ga-1,.ga-2,.ga-3,.ga-4,.ga-5{grid-column:span 6;min-height:200px}
  .hero-meta{gap:14px 26px}.hero-meta .item{min-width:40%}
  .footer-top{grid-template-columns:1fr}.footer-brand{grid-column:span 1}
  .brand .desc{display:none}
  .footer-brand img{height:56px;max-width:210px}
  .loc-map{min-height:340px}
  .ba-cap{font-size:10px}
  .card{padding:26px 22px 24px}
  /* compact sticky shows icon only on very small screens */
  .sticky-cta .lbl{display:none}
  .sticky-cta a{padding:0;width:60px;height:60px;justify-content:center}
}
@media (max-width:380px){
  .hero-side{display:none}
}
