/* ============================================================
   Khalli — Luxury design system
   Direction A: Dark "after-hours" (warm espresso-black + brass)
   60 / 30 / 10 — base / neutral text / accent
   ============================================================ */

:root{
  /* 60% base */
  --bg:        #14110D;   /* warm espresso-black, never pure #000 */
  --bg-2:      #1A1611;   /* raised panels */
  --card:      #1D1812;   /* cards */
  --card-2:    #221C15;

  /* 30% neutral text */
  --text:      #F3ECE0;   /* warm off-white */
  --muted:     #A89C8B;   /* muted stone, secondary */
  --muted-dim: #877B6B;

  /* 10% accent — single champagne / brushed brass, used sparingly */
  --brass:     #C2A05B;
  --brass-dim: #9E8147;

  /* hairlines */
  --line:      rgba(194,160,91,.16);   /* brass hairline */
  --line-soft: rgba(243,236,224,.07);  /* neutral hairline */
  --line-mid:  rgba(194,160,91,.30);

  /* type */
  --display:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --body:'Inter', system-ui, -apple-system, sans-serif;

  /* motion — slow, unhurried easing */
  --ease: cubic-bezier(.22,.61,.36,1);
  --slow: .8s;
  --med:  .5s;

  /* layout */
  --maxw: 1180px;
  --pad: 26px;
}

/* Arabic swaps the type families */
html[dir="rtl"]{
  --display:'Reem Kufi', 'Cormorant Garamond', serif;
  --body:'IBM Plex Sans Arabic', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-size:16px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* faint warm light from above — the "after-hours" glow, very subtle */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 50% at 78% -6%, rgba(194,160,91,.10), transparent 70%),
    radial-gradient(50% 45% at 6% 104%, rgba(194,160,91,.05), transparent 70%);
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(194,160,91,.25);color:var(--text)}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--body);
  font-size:.72rem;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--brass);
  font-weight:500;
  display:inline-block;
}
html[dir="rtl"] .eyebrow{letter-spacing:.04em;font-size:.82rem}

h1,h2,h3{font-family:var(--display);font-weight:500;color:var(--text)}

/* hairline divider */
.rule{height:1px;background:var(--line);border:0;margin:0}

/* ---------- nav ---------- */
nav{
  position:sticky;top:0;z-index:60;
  backdrop-filter:saturate(120%) blur(14px);
  background:color-mix(in srgb, var(--bg) 84%, transparent);
  border-bottom:1px solid var(--line-soft);
  transition:border-color var(--med) var(--ease);
}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:baseline;gap:10px}
.brand .lat{font-family:var(--display);font-weight:600;font-size:1.7rem;letter-spacing:.01em}
.brand .ar{font-family:'Reem Kufi',serif;color:var(--brass);font-size:1.25rem;font-weight:500}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a:not(.lang){
  font-size:.84rem;letter-spacing:.04em;color:var(--muted);
  position:relative;transition:color var(--med) var(--ease);
}
.nav-links a:not(.lang):hover{color:var(--text)}
.nav-links a:not(.lang)::after{
  content:"";position:absolute;left:0;bottom:-6px;height:1px;width:0;
  background:var(--brass);transition:width var(--med) var(--ease);
}
.nav-links a:not(.lang):hover::after{width:100%}
.lang{
  font-family:var(--body);
  border:1px solid var(--line-mid);background:transparent;color:var(--text);
  font-size:.76rem;letter-spacing:.08em;font-weight:500;
  padding:9px 16px;border-radius:999px;cursor:pointer;
  transition:all var(--med) var(--ease);
}
.lang:hover{border-color:var(--brass);color:var(--brass)}
@media(max-width:860px){
  .nav-links a:not(.lang){display:none}
  .nav-in{height:64px}
}

/* ---------- buttons ---------- */
.btn{
  font-family:var(--body);font-weight:500;font-size:.92rem;letter-spacing:.02em;
  border-radius:2px;padding:16px 30px;cursor:pointer;border:1px solid transparent;
  display:inline-flex;align-items:center;gap:10px;
  transition:all var(--slow) var(--ease);
}
.btn-primary{
  background:var(--brass);color:#1A140A;border-color:var(--brass);font-weight:600;
}
.btn-primary:hover{
  background:transparent;color:var(--brass);
}
.btn-ghost{background:transparent;border-color:var(--line-mid);color:var(--text)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass)}
.btn .arrow{transition:transform var(--med) var(--ease)}
html[dir="rtl"] .btn .arrow{transform:scaleX(-1)}
.btn:hover .arrow{transform:translateX(4px)}
html[dir="rtl"] .btn:hover .arrow{transform:scaleX(-1) translateX(4px)}

/* ---------- hero ---------- */
header{padding:80px 0 70px;position:relative}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center}
@media(max-width:960px){.hero{grid-template-columns:1fr;gap:50px}}
.hero h1{
  font-size:clamp(2.9rem,6.4vw,5.1rem);
  line-height:1.02;letter-spacing:-.01em;
  margin:24px 0 26px;font-weight:500;
}
.hero h1 .hl{font-style:italic;color:var(--brass)}
html[dir="rtl"] .hero h1{line-height:1.28;letter-spacing:0;font-weight:500}
html[dir="rtl"] .hero h1 .hl{font-style:normal}
.hero-tagline{
  display:flex;align-items:center;gap:4px;flex-wrap:wrap;
  margin:0 0 26px;font-family:var(--display);font-style:italic;
  font-size:1.3rem;color:var(--brass);letter-spacing:.01em;
}
.hero-tagline .ar{font-family:'Reem Kufi',serif;font-style:normal}
html[dir="rtl"] .hero-tagline{font-style:normal;font-size:1.4rem}
.lede{font-size:1.12rem;line-height:1.8;color:var(--muted);max-width:33em}
.lede b{color:var(--text);font-weight:500}
.price-chip{
  display:inline-flex;align-items:baseline;gap:9px;margin:32px 0 6px;
  font-size:.9rem;color:var(--muted);letter-spacing:.04em;
}
.price-chip b{font-family:var(--display);font-size:1.5rem;color:var(--brass);font-weight:600;letter-spacing:0}
.price-chip .sep{width:1px;height:18px;background:var(--line-mid);margin:0 4px;align-self:center}
.cta-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:26px}

/* ---------- request-builder phone ---------- */
.phone{
  justify-self:center;width:374px;max-width:100%;
  background:linear-gradient(170deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:26px;
  padding:22px 18px 24px;
  box-shadow:0 50px 100px -40px rgba(0,0,0,.8), inset 0 1px 0 rgba(243,236,224,.04);
  position:relative;
}
.pb-top{display:flex;align-items:center;gap:12px;padding:4px 6px 18px;border-bottom:1px solid var(--line-soft)}
.pb-av{
  width:42px;height:42px;border-radius:50%;flex:none;
  background:linear-gradient(140deg,var(--brass),var(--brass-dim));
  display:grid;place-items:center;font-family:var(--display);font-weight:600;color:#1A140A;font-size:1.1rem;
}
.pb-top .who{font-weight:600;font-size:.92rem;color:var(--text)}
.pb-top .st{font-size:.7rem;color:var(--muted);letter-spacing:.03em}
.pb-top .st .dot{color:var(--brass)}
.pb-q{font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--text);margin:20px 6px 14px}
html[dir="rtl"] .pb-q{font-style:normal}
.pb-chips{display:flex;flex-wrap:wrap;gap:9px;padding:0 4px}
.pb-chip{
  font-size:.82rem;font-weight:400;color:var(--muted);
  background:transparent;border:1px solid var(--line-mid);border-radius:999px;
  padding:9px 15px;transition:all var(--slow) var(--ease);
}
.pb-chip.sel{
  background:var(--brass);color:#1A140A;border-color:var(--brass);font-weight:500;
}
.pb-card{
  margin-top:18px;background:rgba(20,17,13,.6);
  border:1px solid var(--line);border-radius:14px;padding:17px 18px;min-height:104px;
  opacity:0;transform:translateY(12px);
  transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease);
}
.pb-card.show{opacity:1;transform:none}
.pb-card .lbl{
  font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--brass);font-weight:500;margin-bottom:11px;
}
html[dir="rtl"] .pb-card .lbl{letter-spacing:.02em;font-size:.72rem}
.pb-en{font-size:.92rem;line-height:1.55;color:var(--text);margin-bottom:8px}
.pb-ar{font-family:'Reem Kufi',serif;font-size:.92rem;line-height:1.7;color:var(--muted);direction:rtl;text-align:right}
.pb-confirm{
  display:flex;align-items:center;gap:11px;margin-top:16px;padding:0 6px;
  opacity:0;transform:translateY(6px);
  transition:opacity var(--med) var(--ease),transform var(--med) var(--ease);
  font-size:.84rem;color:var(--text);font-weight:400;
}
.pb-confirm.show{opacity:1;transform:none}
.pb-confirm .mini{
  width:26px;height:26px;border-radius:50%;flex:none;
  background:var(--brass);color:#1A140A;
  display:grid;place-items:center;font-weight:700;font-size:.72rem;
}

/* ---------- value strip ---------- */
.valuestrip{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.valuestrip .wrap{
  padding:54px var(--pad);text-align:center;
}
.valuestrip p{
  font-family:var(--display);font-weight:400;font-style:italic;
  font-size:clamp(1.5rem,3.6vw,2.4rem);line-height:1.3;color:var(--text);
  max-width:24em;margin-inline:auto;
}
html[dir="rtl"] .valuestrip p{font-style:normal}
.valuestrip .ar{display:block;color:var(--brass);font-family:'Reem Kufi',serif;font-style:normal;font-size:.7em;margin-top:14px}

/* ---------- sections ---------- */
section{padding:120px 0;position:relative}
section + section{border-top:1px solid var(--line-soft)}
.sec-head{max-width:42em;margin-bottom:64px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head h2{
  font-size:clamp(2.1rem,4.4vw,3.3rem);line-height:1.08;letter-spacing:-.01em;
  margin-top:18px;font-weight:500;
}
html[dir="rtl"] .sec-head h2{line-height:1.32;letter-spacing:0}

/* ---------- how it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{background:var(--bg);padding:42px 38px}
.step .n{
  font-family:var(--display);font-style:italic;font-size:2.4rem;color:var(--brass);
  line-height:1;margin-bottom:24px;font-weight:500;
}
html[dir="rtl"] .step .n{font-style:normal}
.step h3{font-size:1.5rem;font-weight:500;margin-bottom:12px;line-height:1.2}
.step p{color:var(--muted);font-size:.98rem}

/* ---------- package handling ---------- */
.package{display:grid;grid-template-columns:1fr .92fr;gap:70px;align-items:center}
@media(max-width:900px){.package{grid-template-columns:1fr;gap:46px}}
.package .copy h2{
  font-size:clamp(2rem,4.2vw,3rem);line-height:1.1;letter-spacing:-.01em;margin:18px 0 22px;font-weight:500;
}
html[dir="rtl"] .package .copy h2{line-height:1.3;letter-spacing:0}
.package .copy p{color:var(--muted);font-size:1.06rem;max-width:34em}
.package .copy p b{color:var(--text);font-weight:500}

/* incoming-call / handover motif */
.callcard{
  background:linear-gradient(170deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:22px;padding:38px 34px;
  box-shadow:0 50px 100px -50px rgba(0,0,0,.8);
  max-width:380px;margin-inline:auto;
}
.callcard .incoming{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
html[dir="rtl"] .callcard .incoming{letter-spacing:.04em;font-size:.78rem}
.callcard .caller{display:flex;align-items:center;gap:16px;margin-bottom:30px}
.ring{
  width:62px;height:62px;border-radius:50%;flex:none;position:relative;
  background:rgba(194,160,91,.1);border:1px solid var(--line-mid);
  display:grid;place-items:center;color:var(--brass);
}
.ring svg{width:26px;height:26px}
.ring::before,.ring::after{
  content:"";position:absolute;inset:-1px;border-radius:50%;border:1px solid var(--brass);
  opacity:0;animation:pulse 2.6s var(--ease) infinite;
}
.ring::after{animation-delay:1.3s}
@keyframes pulse{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.7);opacity:0}}
.callcard .caller .meta .t1{font-size:1.02rem;color:var(--text);font-weight:500}
.callcard .caller .meta .t2{font-size:.82rem;color:var(--muted)}
.callcard .answer{
  border-top:1px solid var(--line-soft);padding-top:22px;
}
.callcard .answer .lbl{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);margin-bottom:10px}
html[dir="rtl"] .callcard .answer .lbl{letter-spacing:.02em;font-size:.72rem}
.callcard .answer .ar-line{font-family:'Reem Kufi',serif;direction:rtl;text-align:right;font-size:1.05rem;color:var(--text);line-height:1.7;margin-bottom:6px}
.callcard .answer .en-line{font-size:.88rem;color:var(--muted)}

/* ---------- companion ---------- */
.companion{display:grid;grid-template-columns:1.04fr .96fr;gap:64px;align-items:center}
@media(max-width:900px){.companion{grid-template-columns:1fr;gap:42px}}
.companion .quote{
  background:linear-gradient(160deg,var(--card-2),var(--bg-2));
  border:1px solid var(--line);border-radius:22px;padding:48px 42px;position:relative;
}
.companion .quote .ar-big{font-family:'Reem Kufi',serif;font-size:2rem;color:var(--brass);margin-bottom:18px;direction:rtl;line-height:1.4}
.companion .quote p{color:var(--muted);font-size:1.08rem;line-height:1.75}
.companion .copy h2{font-size:clamp(1.9rem,4vw,2.8rem);line-height:1.1;letter-spacing:-.01em;margin:18px 0 18px;font-weight:500}
html[dir="rtl"] .companion .copy h2{line-height:1.32;letter-spacing:0}
.companion .copy p{color:var(--muted);font-size:1.08rem;max-width:32em}

/* ---------- handles grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-soft);border:1px solid var(--line-soft)}
@media(max-width:820px){.grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.grid{grid-template-columns:1fr}}
.chip2{
  background:var(--bg);padding:26px 24px;font-weight:400;font-size:1.02rem;color:var(--text);
  display:flex;align-items:center;gap:14px;transition:background var(--med) var(--ease);
}
.chip2:hover{background:var(--bg-2)}
.chip2 .dot{width:6px;height:6px;border-radius:50%;background:var(--brass);flex:none;opacity:.6}
.chip2.star{background:linear-gradient(120deg,var(--card-2),var(--bg))}
.chip2.star .dot{width:8px;height:8px;opacity:1;box-shadow:0 0 0 4px rgba(194,160,91,.12)}
.chip2.star span{color:var(--brass);font-weight:500}

/* ---------- membership ---------- */
.cadence{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:840px;margin-inline:auto}
@media(max-width:680px){.cadence{grid-template-columns:1fr}}
.cad{
  background:linear-gradient(165deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:18px;padding:42px 36px;position:relative;
  transition:border-color var(--slow) var(--ease),transform var(--slow) var(--ease);
}
.cad:hover{border-color:var(--line-mid)}
.cad.feature{border-color:var(--line-mid)}
.cad .tag{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);font-weight:500}
html[dir="rtl"] .cad .tag{letter-spacing:.03em;font-size:.8rem}
.cad .big{font-family:var(--display);font-weight:600;font-size:3.4rem;line-height:1;margin:22px 0 6px;letter-spacing:-.01em}
.cad .big small{font-family:var(--body);font-size:.92rem;color:var(--muted);font-weight:400;letter-spacing:.02em}
.cad p{color:var(--muted);font-size:.98rem;margin-top:14px}
.cad-note{text-align:center;color:var(--muted-dim);font-size:.96rem;margin-top:30px;max-width:600px;margin-inline:auto}
.cad-note b{color:var(--text);font-weight:500}

/* ---------- reserve / waitlist ---------- */
.waitwrap{max-width:660px;margin-inline:auto}
.wl-head{text-align:center;margin-bottom:44px}
.wl-head h2{font-size:clamp(2.3rem,5vw,3.6rem);letter-spacing:-.01em;font-weight:500;line-height:1.05}
html[dir="rtl"] .wl-head h2{letter-spacing:0;line-height:1.25}
.wl-head p{color:var(--muted);font-size:1.08rem;margin-top:16px;max-width:30em;margin-inline:auto}
.wl-quick{
  display:inline-flex;align-items:center;gap:8px;margin-top:18px;
  font-size:.78rem;letter-spacing:.08em;color:var(--brass);
  border:1px solid var(--line-mid);border-radius:999px;padding:8px 16px;
}
html[dir="rtl"] .wl-quick{letter-spacing:.02em;font-size:.84rem}
form.wl{
  background:linear-gradient(170deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:20px;padding:40px 38px;display:grid;gap:20px;
}
@media(max-width:560px){form.wl{padding:30px 24px}}
.field{display:grid;gap:9px;text-align:start}
.field.row2{grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:560px){.field.row2{grid-template-columns:1fr}}
.field-group{display:grid;gap:9px}
.field label{font-size:.82rem;font-weight:500;color:var(--text);letter-spacing:.02em}
.field label .opt{color:var(--muted-dim);font-weight:400;font-size:.78rem}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:.96rem;color:var(--text);
  background:rgba(20,17,13,.7);border:1px solid var(--line-mid);border-radius:3px;
  padding:14px 15px;width:100%;outline:none;
  transition:border-color var(--med) var(--ease),box-shadow var(--med) var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-dim)}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--brass);box-shadow:0 0 0 3px rgba(194,160,91,.1);
}
.field select{appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A89C8B' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 15px center;padding-right:38px;
}
html[dir="rtl"] .field select{background-position:left 15px center;padding-right:15px;padding-left:38px}
.field textarea{min-height:80px;resize:vertical;line-height:1.6}

/* map (drop a pin) */
.map-field{display:grid;gap:9px}
#pinmap{height:260px;width:100%;border:1px solid var(--line-mid);border-radius:3px;background:var(--bg-2);z-index:1}
.map-hint{font-size:.78rem;color:var(--muted-dim)}
.map-hint b{color:var(--brass);font-weight:500}

.wl .btn-primary{justify-content:center;margin-top:6px;padding:17px}
.wl-note{font-size:.78rem;color:var(--muted-dim);text-align:center;line-height:1.6}

/* success state */
.wl-success{
  display:none;text-align:center;padding:54px 38px;
  background:linear-gradient(170deg,var(--card-2),var(--card));
  border:1px solid var(--line);border-radius:20px;
}
.wl-success.show{display:block;animation:fadeUp var(--slow) var(--ease)}
.wl-success .tick{
  width:64px;height:64px;border-radius:50%;margin:0 auto 24px;
  background:rgba(194,160,91,.12);border:1px solid var(--line-mid);
  display:grid;place-items:center;color:var(--brass);font-size:1.6rem;
}
.wl-success h3{font-family:var(--display);font-size:2rem;font-weight:500;margin-bottom:12px}
.wl-success p{color:var(--muted);max-width:26em;margin-inline:auto}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- FAQ ---------- */
.faq{max-width:800px;margin-inline:auto}
details{border-bottom:1px solid var(--line-soft);padding:26px 4px}
details:first-of-type{border-top:1px solid var(--line-soft)}
summary{
  cursor:pointer;font-family:var(--display);font-weight:500;font-size:1.4rem;
  list-style:none;display:flex;justify-content:space-between;gap:20px;align-items:center;
  color:var(--text);transition:color var(--med) var(--ease);
}
html[dir="rtl"] summary{font-size:1.3rem}
summary:hover{color:var(--brass)}
summary::-webkit-details-marker{display:none}
summary .pm{color:var(--brass);font-size:1.4rem;flex:none;transition:transform var(--slow) var(--ease);font-family:var(--body);font-weight:300}
details[open] summary .pm{transform:rotate(45deg)}
details p{color:var(--muted);margin-top:16px;font-size:1.02rem;max-width:62em}

/* ---------- final CTA ---------- */
.final{text-align:center}
.final h2{font-family:var(--display);font-weight:500;font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:-.01em;line-height:1.02}
html[dir="rtl"] .final h2{letter-spacing:0;line-height:1.2}
.final h2 .hl{font-style:italic;color:var(--brass)}
html[dir="rtl"] .final h2 .hl{font-style:normal}
.final p{color:var(--muted);font-size:1.16rem;margin:22px auto 40px;max-width:30em}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:50px 0;color:var(--muted-dim);font-size:.84rem}
footer .wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}
footer .brand .lat{font-size:1.3rem}
footer .brand .ar{font-size:1rem}
footer .f-right{display:flex;gap:24px;align-items:center}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}

/* ---------- mobile / responsive refinements ---------- */
@media(max-width:760px){
  :root{ --pad:20px }
  section{padding:78px 0}
  .sec-head{margin-bottom:44px}
  header{padding:40px 0 56px}
  .valuestrip .wrap{padding:40px var(--pad)}

  .nav-in{height:62px}
  .brand .lat{font-size:1.45rem}
  .brand .ar{font-size:1.05rem}

  .hero{gap:36px}
  .lede{font-size:1.04rem}
  .price-chip{margin-top:26px}
  .cta-row .btn{flex:1 1 auto;justify-content:center}

  .phone{width:100%;max-width:360px;padding:18px 14px 20px}

  .step{padding:34px 28px}
  .companion .quote{padding:34px 26px}
  .companion .quote .ar-big{font-size:1.7rem}
  .callcard{padding:30px 24px}
  .cad{padding:34px 28px}
  .cad .big{font-size:2.9rem}

  form.wl{padding:28px 20px}
  #pinmap{height:220px}

  summary{font-size:1.2rem}
  details p{font-size:.98rem}

  footer .wrap{flex-direction:column;align-items:flex-start;gap:10px}
  footer .f-right{flex-direction:column;align-items:flex-start;gap:6px}
}

@media(max-width:480px){
  .hero h1{font-size:clamp(2.5rem,11vw,3rem)}
  .valuestrip p{font-size:1.35rem}
  .cta-row{gap:12px}
  .btn{padding:15px 22px;width:100%;justify-content:center}
  .price-chip b{font-size:1.35rem}
}

/* avoid hover-stuck states on touch devices */
@media(hover:none){
  .btn-primary:hover{background:var(--brass);color:#1A140A}
  .chip2:hover{background:var(--bg)}
}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .ring::before,.ring::after{display:none}
}
