/* ============================================================
   PLEJO TAXI — "Coastal Premium" design system
   black · gold · paper · Space Grotesk / Inter / Space Mono
   Shared across every page. Photo areas are .ph placeholders
   until real photography is dropped in.
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0B0B0D;--ink-2:#101015;--panel:#141418;--panel-2:#1A1A20;
  --line:#2A2A31;--line-2:#36363E;
  --gold:#C9A24B;--gold-hi:#E7CE93;--gold-lo:#A57F2D;--gold-glow:rgba(201,162,75,.16);
  --paper:#F4F1EA;--paper-2:#ECE7DB;--ink-on-paper:#16161A;--mut-on-paper:#6c6c75;
  --mut:#9B9BA4;--mut-2:#6E6E77;
  --disp:"Space Grotesk",sans-serif;--body:"Inter",sans-serif;--mono:"Space Mono",monospace;
  --pad-x:clamp(20px,4vw,56px);--maxw:1240px;
  --r:16px;--r-lg:22px;
}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{background:var(--ink);color:var(--paper);font-family:var(--body);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--gold);color:var(--ink)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.mono{font-family:var(--mono)}
.gold{color:var(--gold)}

/* ---------- type ---------- */
.kicker{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold-hi)}
.kicker::before{content:"";width:22px;height:1px;background:var(--gold)}
.on-paper .kicker{color:var(--gold-lo)}
h1,h2,h3{font-family:var(--disp);font-weight:700;letter-spacing:-.02em;line-height:1.02;text-wrap:balance}
.h1{font-size:clamp(44px,7vw,96px);line-height:.96}
.h2{font-size:clamp(30px,4.2vw,52px)}
.h3{font-size:clamp(21px,2.2vw,27px)}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--mut);max-width:60ch;text-wrap:pretty}
.on-paper .lead{color:var(--mut-on-paper)}
.sub{font-size:clamp(16px,1.5vw,21px);color:#e3e3e8;max-width:52ch;text-wrap:pretty}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--disp);font-weight:700;
  font-size:15px;border-radius:12px;padding:13px 20px;cursor:pointer;border:1px solid transparent;transition:.16s;white-space:nowrap}
.btn svg{flex:none}
.btn-lg{padding:16px 26px;font-size:16px}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-hi)}
.btn-outline{border-color:var(--line-2);color:#ededf2;background:rgba(255,255,255,.02)}
.btn-outline:hover{border-color:var(--gold);color:#fff}
.on-paper .btn-outline{border-color:#cfc8b8;color:var(--ink-on-paper);background:transparent}
.on-paper .btn-outline:hover{border-color:var(--gold-lo)}
.btn-wa{background:#1f3d2e;color:#d8f3e3;border-color:#2c5641}
.btn-wa:hover{background:#28503c;color:#fff}
.btn-ghost{color:var(--gold-hi)}
.btn-ghost:hover{color:#fff}

/* ---------- sections ---------- */
.section{padding:clamp(64px,9vw,116px) 0;position:relative}
.section.on-paper{background:var(--paper);color:var(--ink-on-paper)}
.section.on-paper h1,.section.on-paper h2,.section.on-paper h3{color:var(--ink-on-paper)}
.section.on-dark{background:var(--ink-2)}
.shead{max-width:64ch;margin-bottom:clamp(34px,4vw,52px)}
.shead.center{margin-left:auto;margin-right:auto;text-align:center}
.shead .h2{margin:18px 0 0}
.shead .lead{margin-top:18px}

/* ---------- brand mark ---------- */
.brand{display:inline-flex;flex-direction:column;line-height:.9}
.brand .wm{font-family:var(--disp);font-weight:700;font-size:25px;letter-spacing:.06em;color:#fff}
.brand .chk{height:5px;margin-top:5px;width:100%;
  background:conic-gradient(var(--gold) 90deg,transparent 0 180deg,var(--gold) 0 270deg,transparent 0);background-size:5px 5px}
.on-paper .brand .wm{color:var(--ink-on-paper)}

/* ---------- photo placeholder ---------- */
.ph{position:relative;overflow:hidden;background:
  radial-gradient(70% 60% at 70% 25%,rgba(201,162,75,.12),transparent 60%),
  repeating-linear-gradient(125deg,#1b1b21 0 28px,#16161b 28px 56px)}
.ph::after{content:attr(data-label);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.30);
  text-align:center;width:80%;line-height:1.5}
.ph.light{background:
  radial-gradient(70% 60% at 70% 25%,rgba(165,127,45,.14),transparent 60%),
  repeating-linear-gradient(125deg,#e3ddcd 0 28px,#dcd5c3 28px 56px)}
.ph.light::after{color:rgba(0,0,0,.32)}

/* ---------- design graphics (geometric panels in place of photos) ---------- */
.gfx{position:relative;overflow:hidden;background:linear-gradient(157deg,#1b1b22 0%,#0f0f14 72%)}
.gfx.light{background:linear-gradient(157deg,#e8e2d2 0%,#d7d0be 76%)}
.gfx .gfxsvg{position:absolute;inset:0;width:100%;height:100%;display:block;color:#c9a24b}
.gfx.light .gfxsvg{color:#9c7d2e}
.gfx-grid{background:radial-gradient(rgba(255,255,255,.05) 1px,transparent 1.6px) 0 0/22px 22px,linear-gradient(157deg,#17171d,#0e0e12)}
.gfx-grid.light{background:radial-gradient(rgba(0,0,0,.07) 1px,transparent 1.6px) 0 0/22px 22px,linear-gradient(157deg,#e8e2d2,#d7d0be)}
.gfx-route{background:radial-gradient(rgba(255,255,255,.045) 1px,transparent 1.5px) 0 0/26px 26px,linear-gradient(157deg,#1b1b22,#0f0f14)}
.gfx:not(.light)::after{content:"";position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 90px 14px rgba(0,0,0,.34)}

/* real photography dropped into a .photo / .sphoto slot */
.photo.img,.sphoto.img{background-size:cover;background-position:center;background-repeat:no-repeat;
  /* editorial grade: tame phone-camera colour, deepen blacks, add warmth */
  filter:saturate(.8) contrast(1.07) brightness(.92) sepia(.06)}
.photo.img::after,.sphoto.img::after{content:"";position:absolute;inset:0;pointer-events:none;
  /* vignette + directional darken — pulls the eye to the car, buries busy edges */
  background:
    radial-gradient(125% 90% at 44% 46%,transparent 34%,rgba(6,6,8,.58) 100%),
    linear-gradient(205deg,rgba(6,6,8,.5) 0%,transparent 34%);
  box-shadow:inset 0 0 130px 30px rgba(6,6,8,.6)}
.photo.img::before,.sphoto.img::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;
  /* fine film grain over the photo masks compression noise & banding */
  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='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:170px 170px;opacity:.13;mix-blend-mode:overlay}

/* depth — soft gradient drop-shadows make image & graphic panels read cleaner */
.split .sphoto{box-shadow:0 36px 76px -30px rgba(0,0,0,.74),0 16px 36px -20px rgba(0,0,0,.5),0 2px 8px -3px rgba(0,0,0,.4)}
.svc{box-shadow:0 24px 52px -30px rgba(0,0,0,.62)}
.svc:hover{box-shadow:0 36px 64px -28px rgba(0,0,0,.72)}
.split .sphoto.img,.split .sphoto.gfx{position:relative}
.split .sphoto.img::after{box-shadow:inset 0 0 130px 30px rgba(6,6,8,.6),inset 0 -60px 80px -40px rgba(6,6,8,.7)}

/* ============================================================
   NAV
   ============================================================ */
nav.site{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .25s,border-color .25s,backdrop-filter .25s}
nav.site .row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px var(--pad-x);
  max-width:1340px;margin:0 auto}
nav.site.scrolled,nav.site.solid{background:rgba(11,11,13,.86);backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line)}
nav.site .links{display:flex;gap:30px;list-style:none;font-size:14.5px;font-weight:500}
nav.site .links a{color:#dadade;text-shadow:0 1px 8px rgba(0,0,0,.4);transition:.15s;position:relative;padding:4px 0}
nav.site .links a:hover{color:#fff}
nav.site .links a.active{color:var(--gold-hi)}
nav.site .links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--gold)}
nav.site .navcta{display:flex;align-items:center;gap:12px}
nav.site .lang{font-family:var(--mono);font-size:12px;color:#b4b4bc}
nav.site .lang b{color:#fff}
nav.site .lang a:hover{color:var(--gold-hi)}
.navtoggle{display:none;width:44px;height:44px;border-radius:11px;border:1px solid var(--line-2);background:rgba(255,255,255,.05);
  color:#fff;align-items:center;justify-content:center;cursor:pointer;transition:.15s}
.navtoggle:hover{border-color:var(--gold);color:var(--gold-hi)}
/* Mobile / tablet menu — full-screen overlay that matches the dark-luxe page
   (was a cramped semi-transparent dropdown). Toggled by `.open` in chrome.js. */
.navmenu{display:none;position:fixed;inset:0;z-index:1;background:var(--ink);
  padding:108px var(--pad-x) 48px;overflow-y:auto}
.navmenu.open{display:flex;flex-direction:column;justify-content:center}
.navmenu a{display:block;text-align:center;padding:20px 0;color:#eaeaef;border-bottom:1px solid var(--line);
  font-family:var(--disp);font-weight:600;font-size:clamp(23px,5.4vw,32px);letter-spacing:.005em;transition:color .15s}
.navmenu a:last-of-type{border-bottom:0}
.navmenu a:hover,.navmenu a:active{color:var(--gold-hi)}
.navmenu .mrow{display:flex;gap:12px;margin:36px auto 0;width:100%;max-width:460px}
.navmenu .mrow .btn{flex:1;justify-content:center;font-size:15px;padding:15px 18px}
@media (max-width:980px){
  nav.site .row{position:relative;z-index:2}
  nav.site .links,nav.site .lang,nav.site .navcta .btn{display:none}
  nav.site .navcta .btn.keep{display:inline-flex}
  .navtoggle{display:flex}
}

/* ============================================================
   HERO (full-bleed coastal + glass search bar)
   ============================================================ */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--pad-x) clamp(28px,4vw,46px);overflow:hidden}
.hero .photo{position:absolute;inset:0;z-index:0}
/* dim the hero car a touch — softens light so surface impurities don't read */
.hero .photo.img{filter:saturate(.78) contrast(1.05) brightness(.82) sepia(.06)}
.hero .scrim{position:absolute;inset:0;z-index:1;background:
  /* even flat darken — overall dim that hides imperfections on the car */
  linear-gradient(180deg,rgba(8,8,10,.22),rgba(8,8,10,.22)),
  /* soft vignette pulls light off the busy edges, keeps centre readable */
  radial-gradient(125% 95% at 50% 44%,transparent 38%,rgba(6,6,8,.55) 100%),
  /* top + bottom shadow ramp for legible nav and headline */
  linear-gradient(180deg,rgba(8,8,10,.74) 0%,rgba(8,8,10,.26) 28%,rgba(8,8,10,.58) 60%,rgba(8,8,10,.985) 100%)}
.hero .wrap{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto}
.hero .h1{margin:18px 0 0;max-width:15ch}
.hero .h1 .g{color:var(--gold)}
.hero .sub{margin-top:20px;text-shadow:0 1px 12px rgba(0,0,0,.45)}
.hero .proof{display:flex;align-items:center;gap:14px;margin-top:26px;flex-wrap:wrap}
.hero .proof .av{display:flex}
.hero .proof .av .a{width:38px;height:38px;border-radius:50%;border:2px solid var(--ink);margin-left:-10px;
  background:repeating-linear-gradient(135deg,#2a2a31,#2a2a31 5px,#212127 5px,#212127 10px)}
.hero .proof .av .a:first-child{margin-left:0}
.hero .proof .pt{font-size:13.5px;color:#dcdce2}
.hero .proof .pt b{color:#fff}
.hero .proof .star{color:var(--gold);letter-spacing:1px}

/* search bar */
.searchbar{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:30px auto 0;
  background:rgba(20,20,24,.72);backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);
  border:1px solid rgba(255,255,255,.10);border-radius:18px;box-shadow:0 30px 70px -25px rgba(0,0,0,.7);
  display:grid;grid-template-columns:1.3fr 1.3fr 1fr .9fr auto;align-items:stretch;padding:8px}
.searchbar .sf{position:relative;padding:12px 18px;border-right:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;gap:5px;justify-content:center}
.searchbar .sf:last-of-type{border-right:0}
.searchbar .sf label{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--mut);
  display:flex;align-items:center;gap:7px}
.searchbar .sf label svg{color:var(--gold)}
.searchbar .sf input,.searchbar .sf select{background:transparent;border:0;outline:none;color:#fff;font-family:var(--body);
  font-size:16px;font-weight:600;width:100%}
.searchbar .sf input::placeholder{color:#6c6c75;font-weight:400}
.searchbar .sf select{appearance:none;cursor:pointer}
.searchbar .sf select option{background:#16161b;color:#fff}
.searchbar .sf-cf{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;background:transparent;
  border:0;outline:none;color:#fff;font-family:var(--body);font-size:16px;font-weight:600;cursor:pointer;padding:0;text-align:left}
.searchbar .sf-cf .sf-v{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.searchbar .sf-cf svg{flex:none;color:var(--mut);width:15px;height:15px}
.searchbar .sf-cf:hover .sf-v{color:var(--gold-hi)}
.searchbar .sf-cf.empty .sf-v{color:#6c6c75;font-weight:400}
.searchbar .sf input[type=date]::-webkit-calendar-picker-indicator,
.searchbar .sf input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.6) sepia(1) saturate(2) hue-rotate(5deg)}
.searchbar .sbtn{margin:0;border:0;border-radius:13px;background:var(--gold);color:var(--ink);font-family:var(--disp);
  font-weight:700;font-size:16px;padding:0 26px;cursor:pointer;display:flex;align-items:center;gap:10px;transition:.16s;min-height:62px}
.searchbar .sbtn:hover{background:var(--gold-hi)}
.barnote{display:flex;justify-content:center;gap:22px;flex-wrap:wrap;margin:16px auto 0;max-width:var(--maxw);
  font-family:var(--mono);font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#b4b4bc}
.barnote span{display:inline-flex;align-items:center;gap:8px}
.barnote svg{color:var(--gold);flex:none}
@media (max-width:880px){
  .searchbar{grid-template-columns:1fr 1fr;gap:2px}
  .searchbar .sf{border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}
  .searchbar .sbtn{grid-column:1/-1;min-height:54px;justify-content:center;margin-top:4px}
}

/* page hero (inner pages) */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;padding:130px var(--pad-x) clamp(40px,5vw,64px);overflow:hidden}
.phero .photo{position:absolute;inset:0;z-index:0}
.phero .scrim{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(8,8,10,.66) 0%,rgba(8,8,10,.25) 40%,rgba(8,8,10,.92) 100%)}
.phero .wrap{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%}
.phero .h1{font-size:clamp(38px,6vw,76px);margin:16px 0 0;max-width:16ch}
.phero .sub{margin-top:18px}

/* ---------- trust strip ---------- */
.trust{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust .row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px;padding:20px var(--pad-x);
  max-width:var(--maxw);margin:0 auto}
.trust .item{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;
  text-transform:uppercase;color:#a7a7af}
.trust .item svg{color:var(--gold);flex:none}

/* ---------- service cards ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc{position:relative;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--panel);
  min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;transition:.2s}
.svc:hover{border-color:var(--line-2);transform:translateY(-3px)}
.svc .photo{position:absolute;inset:0;z-index:0}
.svc .gr{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(11,11,13,.30) 0%,rgba(11,11,13,.55) 45%,rgba(11,11,13,.95) 100%)}
.svc>*{position:relative;z-index:2}
.svc .tag{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-hi)}
.svc h3{margin:12px 0 0;color:#fff}
.svc p{color:#cfcfd6;font-size:14.5px;margin-top:10px;max-width:46ch}
.svc .more{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-family:var(--disp);font-weight:700;
  font-size:14px;color:var(--gold-hi)}
.svc .more svg{transition:transform .16s}
.svc:hover .more svg{transform:translateX(3px)}
@media (max-width:760px){.svc-grid{grid-template-columns:1fr}}

/* ---------- feature/why grid ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.why-item{display:flex;flex-direction:column;gap:12px}
.why-item .ic{width:46px;height:46px;border-radius:12px;border:1px solid var(--line);background:rgba(201,162,75,.06);
  display:flex;align-items:center;justify-content:center;color:var(--gold)}
.on-paper .why-item .ic{border-color:#d8d1c0;background:rgba(165,127,45,.08)}
.why-item h3{font-size:19px}
.why-item p{font-size:14.5px;color:var(--mut)}
.on-paper .why-item p{color:var(--mut-on-paper)}
@media (max-width:820px){.why-grid{grid-template-columns:1fr}}

/* ---------- step list ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.step{border:1px solid var(--line);border-radius:var(--r);padding:26px;background:var(--panel)}
.on-paper .step{background:#fff;border-color:#e2dccc}
.step .node{width:38px;height:38px;border-radius:10px;background:var(--gold);color:var(--ink);font-family:var(--disp);
  font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center}
.step h3{font-size:19px;margin:16px 0 0}
.step p{font-size:14.5px;color:var(--mut);margin-top:9px}
.on-paper .step p{color:var(--mut-on-paper)}
@media (max-width:820px){.steps{grid-template-columns:1fr}}

/* ---------- destination chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;padding:11px 17px;
  font-size:14px;font-weight:500;color:#e6e6ea;background:rgba(255,255,255,.02);transition:.15s;cursor:pointer}
.chip:hover{border-color:var(--gold);color:#fff}
.on-paper .chip{border-color:#d8d1c0;color:var(--ink-on-paper);background:transparent}
.on-paper .chip:hover{border-color:var(--gold-lo)}

/* ---------- route cards ---------- */
.routes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rcard{border:1px solid var(--line);border-radius:var(--r);padding:22px;background:var(--panel);transition:.18s;
  display:flex;flex-direction:column;cursor:pointer}
.rcard:hover{border-color:var(--gold);transform:translateY(-3px)}
.rcard .ends{display:flex;justify-content:space-between;gap:10px}
.rcard .place{font-family:var(--disp);font-weight:700;font-size:16px;color:#fff}
.rcard .routeline{display:flex;align-items:center;gap:10px;margin:14px 0}
.rcard .routeline .tag{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--gold-hi);
  background:rgba(201,162,75,.10);border:1px solid rgba(201,162,75,.3);border-radius:5px;padding:4px 7px}
.rcard .routeline .line{flex:1;height:1px;background:repeating-linear-gradient(90deg,var(--gold) 0 5px,transparent 5px 10px);opacity:.6}
.rcard .meta{font-size:13px;color:var(--mut);line-height:1.45}
.rcard .inc{display:flex;flex-wrap:wrap;gap:6px;margin:14px 0 16px}
.rcard .inc span{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:#b9b9c0;
  border:1px solid var(--line);border-radius:5px;padding:4px 7px}
.rcard .quote{margin-top:auto;display:inline-flex;align-items:center;gap:7px;font-family:var(--disp);font-weight:700;
  font-size:13.5px;color:var(--gold-hi)}
.rcard:hover .quote svg{transform:translateX(3px)}
.rcard .quote svg{transition:transform .16s}
@media (max-width:900px){.routes-grid{grid-template-columns:1fr}}

/* ---------- split feature (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);align-items:center}
.split.rev .scopy{order:2}
.split .sphoto{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;min-height:320px}
.split .scopy .h2{margin:16px 0 0}
.split .scopy .lead{margin-top:16px}
.split .ticks{list-style:none;margin:24px 0 0;display:flex;flex-direction:column;gap:13px}
.split .ticks li{display:flex;gap:12px;font-size:15px;color:#d6d6dc}
.on-paper .split .ticks li{color:#3a3a40}
.split .ticks svg{flex:none;color:var(--gold);margin-top:3px}
.split .scta{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:860px){.split{grid-template-columns:1fr}.split.rev .scopy{order:0}}

/* ---------- testimonials ---------- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.tcard{border:1px solid var(--line);border-radius:var(--r);padding:24px;background:var(--panel);display:flex;flex-direction:column}
.on-paper .tcard{background:#fff;border-color:#e2dccc}
.tcard .star{color:var(--gold);letter-spacing:2px;font-size:14px}
.tcard p{font-size:15px;color:#dcdce2;margin:14px 0 18px;line-height:1.55}
.on-paper .tcard p{color:#33333a}
.tcard .who{display:flex;align-items:center;gap:11px;margin-top:auto}
.tcard .who .a{width:38px;height:38px;border-radius:50%;background:repeating-linear-gradient(135deg,#2a2a31,#2a2a31 5px,#212127 5px,#212127 10px);flex:none}
.on-paper .tcard .who .a{background:repeating-linear-gradient(135deg,#e0dacb,#e0dacb 5px,#d6cfbd 5px,#d6cfbd 10px)}
.tcard .who b{font-size:14px;color:#fff;display:block}
.on-paper .tcard .who b{color:var(--ink-on-paper)}
.tcard .who small{font-family:var(--mono);font-size:11px;color:var(--mut)}
@media (max-width:900px){.tgrid{grid-template-columns:1fr}}

/* ---------- mid CTA ---------- */
.midcta{text-align:center}
.midcta .h2{margin:18px auto 0}
.midcta .lead{margin:16px auto 0}
.midcta .ctas{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:30px}

/* ---------- FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:0;max-width:860px}
.faq details{border-top:1px solid var(--line);padding:20px 0}
.on-paper .faq details{border-color:#ddd6c6}
.faq details:last-child{border-bottom:1px solid var(--line)}
.on-paper .faq details:last-child{border-color:#ddd6c6}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;gap:18px;align-items:center;
  font-family:var(--disp);font-weight:600;font-size:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{width:24px;height:24px;flex:none;position:relative}
.faq summary .pl::before,.faq summary .pl::after{content:"";position:absolute;background:var(--gold);border-radius:2px}
.faq summary .pl::before{left:0;right:0;top:11px;height:2px}
.faq summary .pl::after{top:0;bottom:0;left:11px;width:2px;transition:.2s}
.faq details[open] summary .pl::after{transform:scaleY(0)}
.faq p{font-size:15px;color:var(--mut);margin-top:14px;max-width:72ch}
.on-paper .faq p{color:var(--mut-on-paper)}

/* ============================================================
   FOOTER
   ============================================================ */
footer.site{background:var(--ink);border-top:1px solid var(--line);padding:clamp(48px,6vw,72px) 0 30px}
footer.site .fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px}
footer.site .fbrand .brand{margin-bottom:18px}
footer.site .fbrand p{font-size:14px;color:var(--mut);max-width:42ch}

/* google rating badge (footer + reusable) */
.grate{display:inline-flex;align-items:center;gap:12px;margin-top:20px;padding:11px 15px;border:1px solid var(--line);
  border-radius:13px;background:rgba(255,255,255,.02)}
.grate .glogo{width:26px;height:26px;flex:none}
.grate .gnum{font-family:var(--disp);font-weight:700;font-size:19px;color:#fff;line-height:1}
.grate .gstars{color:var(--gold);letter-spacing:1px;font-size:13px;line-height:1}
.grate .gsub{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--mut);margin-top:3px}
.grate a.gmore{font-size:13px;color:var(--gold-hi);font-weight:600;white-space:nowrap}
.grate a.gmore:hover{color:#fff}
.on-paper .grate{border-color:#ddd6c6;background:#fff}
.on-paper .grate .gnum{color:var(--ink-on-paper)}

/* social bubbles — round circles, like the floating buttons */
.social{display:flex;gap:12px;margin-top:22px;align-items:center}
.social .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mut-2);margin-right:2px}
.social a{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;
  border:1px solid var(--line-2);background:rgba(255,255,255,.03);color:#e6e6ea;transition:.16s}
.social a:hover{transform:translateY(-3px);border-color:transparent;color:#fff;box-shadow:0 12px 26px -8px rgba(0,0,0,.6)}
.social a.wa:hover{background:#25D366}
.social a.fb:hover{background:#1877F2}
.social a.gg:hover{background:#EA4335}
.social a.ig:hover{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.social a.ml:hover{background:var(--gold);color:var(--ink)}
.on-paper .social a{border-color:#d8d1c0;background:#fff;color:#33333a}
footer.site .areas{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
footer.site .areas a{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#9a9aa2;
  border:1px solid var(--line);border-radius:6px;padding:5px 9px}
footer.site .areas a:hover{border-color:var(--gold);color:var(--gold-hi)}
footer.site .ct{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
footer.site .fcol ul{list-style:none;display:flex;flex-direction:column;gap:11px}
footer.site .fcol a{font-size:14.5px;color:#c6c6cc}
footer.site .fcol a:hover{color:#fff}
footer.site .fbot{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  margin-top:clamp(36px,5vw,56px);padding-top:24px;border-top:1px solid var(--line);
  font-size:12.5px;color:var(--mut-2)}
footer.site .fbot .lks{display:flex;gap:18px}
footer.site .fbot a:hover{color:#fff}
@media (max-width:860px){footer.site .fgrid{grid-template-columns:1fr 1fr}footer.site .fbrand{grid-column:1/-1}}
@media (max-width:520px){footer.site .fgrid{grid-template-columns:1fr}}

/* ============================================================
   FLOATING CTA + MOBILE BAR
   ============================================================ */
.fcta{position:fixed;right:20px;bottom:24px;z-index:55;display:flex;flex-direction:column;gap:12px}
.fcta a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 30px -8px rgba(0,0,0,.6);transition:.16s;position:relative}
.fcta a:hover{transform:translateY(-2px)}
.fcta .wa{background:#25D366;color:#fff}
.fcta .ph{background:var(--gold);color:var(--ink)}
.fcta a .tip{position:absolute;right:66px;top:50%;transform:translateY(-50%);background:var(--ink-2);color:#fff;
  font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:7px 11px;border-radius:8px;border:1px solid var(--line);
  white-space:nowrap;opacity:0;pointer-events:none;transition:.15s}
.fcta a:hover .tip{opacity:1}
@media (max-width:680px){.fcta{display:none}}

.mbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:55;background:rgba(11,11,13,.95);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--line);
  grid-template-columns:1fr 1fr 1fr;gap:1px;padding:8px}
.mbar a,.mbar button{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--disp);font-weight:700;
  font-size:14px;padding:13px;border-radius:10px;border:0;background:transparent;color:#e6e6ea;cursor:pointer}
.mbar .book{background:var(--gold);color:var(--ink)}
.mbar a svg,.mbar button svg{flex:none}
@media (max-width:680px){.mbar{display:grid}body{padding-bottom:70px}}

/* ============================================================
   BOOKING MODAL
   ============================================================ */
.bd-overlay{position:fixed;inset:0;z-index:90;background:rgba(6,6,8,.72);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px}
.bd-overlay.on{display:flex}
.bd{background:linear-gradient(180deg,#17171c,#121216);border:1px solid var(--line-2);border-radius:20px;
  width:min(520px,100%);max-height:92vh;overflow:auto;box-shadow:0 40px 90px -30px rgba(0,0,0,.85)}
.bd .bdh{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;border-bottom:1px solid var(--line)}
.bd .bdh .t{font-family:var(--disp);font-weight:700;font-size:20px}
.bd .bdh .t small{display:block;font-family:var(--body);font-weight:400;font-size:13px;color:var(--mut);margin-top:3px}
.bd .x{width:38px;height:38px;border-radius:9px;border:1px solid var(--line-2);background:#15151a;color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:18px}
.bd .x:hover{border-color:var(--gold)}
.bd form{padding:22px 24px;display:flex;flex-direction:column;gap:14px}
.bd .seg{display:flex;gap:6px;background:#0e0e12;border:1px solid var(--line);border-radius:11px;padding:5px}
.bd .seg button{flex:1;font-family:var(--body);font-size:13.5px;font-weight:600;color:var(--mut);background:transparent;
  border:0;border-radius:7px;padding:10px;cursor:pointer;transition:.15s}
.bd .seg button.on{background:var(--gold);color:var(--ink)}
.bd .fld label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--mut-2);margin-bottom:6px}
.bd .fld input,.bd .fld select{width:100%;background:#0f0f13;border:1px solid var(--line);border-radius:11px;
  padding:13px 14px;color:#fff;font-family:var(--body);font-size:15px;font-weight:500;outline:none}
.bd .fld input:focus,.bd .fld select:focus{border-color:var(--gold)}
.bd .fld input::placeholder{color:#54545d}
.bd .fld select{appearance:none;cursor:pointer}
.bd .fld select option{background:#16161b}
.bd .fld input[type=date]::-webkit-calendar-picker-indicator,
.bd .fld input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.6) sepia(1) saturate(2) hue-rotate(5deg)}
.bd .two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bd .submit{margin-top:4px;border:0;border-radius:12px;background:var(--gold);color:var(--ink);font-family:var(--disp);
  font-weight:700;font-size:16px;padding:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px}
.bd .submit:hover{background:var(--gold-hi)}
.bd .note{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.05em;text-transform:uppercase;color:var(--mut);text-align:center}
.bd .note svg{color:var(--gold);flex:none}

/* booking: direction sub-toggle (subtler than the gold service seg) */
.bkform .dirseg{margin-top:-4px}
.bkform .seg.dirseg button.on{background:#26262d;color:#fff;box-shadow:inset 0 0 0 1px var(--line-2)}
.bkform .air-block{display:grid}

/* booking: alternate send channels */
.bkform .sendlbl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mut-2);
  text-align:center;margin:2px 0 -2px;position:relative}
.bkform .chgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.bkform .chgrid .ch{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:64px;
  padding:10px 6px;border:1px solid var(--line-2);border-radius:12px;background:#101015;color:var(--mut);
  font-family:var(--body);font-size:11.5px;font-weight:600;cursor:pointer;transition:.15s}
.bkform .chgrid .ch svg{width:19px;height:19px}
.bkform .chgrid .ch:hover{border-color:var(--gold);color:#fff;background:#15151b}
.bkform .chgrid .ch.call{border-color:rgba(212,175,85,.4);color:var(--gold-hi)}
.bkform .chgrid .ch.call:hover{background:rgba(212,175,85,.08);color:#fff}
@media (max-width:460px){.bkform .chgrid{grid-template-columns:repeat(2,1fr)}}

/* toast */
.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);z-index:120;
  background:#16161b;border:1px solid var(--line-2);color:#fff;border-radius:12px;padding:13px 18px;
  font-family:var(--body);font-size:14px;font-weight:500;max-width:min(420px,90vw);text-align:center;
  box-shadow:0 24px 60px -20px rgba(0,0,0,.8);opacity:0;pointer-events:none;transition:.28s cubic-bezier(.2,.7,.2,1)}
.toast.on{opacity:1;transform:translate(-50%,0)}

/* ---------- custom form controls (selects / calendar / time / geo) ---------- */
.bkform .fld label{display:flex;align-items:center;justify-content:space-between;gap:8px}
.bkform .fld label .geo{font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:0;text-transform:none;
  color:var(--gold-hi);background:transparent;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:0}
.bkform .fld label .geo svg{width:12px;height:12px}
.bkform .fld label .geo:hover{color:#fff}
.bkform .fld label .geo:disabled{opacity:.55;cursor:default}
.bkform .cf{width:100%;background:#0f0f13;border:1px solid var(--line);border-radius:11px;padding:13px 14px;color:#fff;
  font-family:var(--body);font-size:15px;font-weight:500;display:flex;align-items:center;justify-content:space-between;gap:10px;
  cursor:pointer;text-align:left;outline:none}
.bkform .cf:hover{border-color:var(--line-2)}
.bkform .cf:focus-visible{border-color:var(--gold)}
.bkform .cf>svg{flex:none;color:var(--mut)}
.bkform .cfpick:not(.filled) .cf-v{color:#54545d}
.bkform .csel{position:relative}

.cpop{position:fixed;z-index:130;background:#16161b;border:1px solid var(--line-2);border-radius:14px;
  box-shadow:0 30px 70px -24px rgba(0,0,0,.85);overflow:hidden;animation:cpop .15s ease}
@keyframes cpop{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

.cmenu{display:flex;flex-direction:column;min-width:210px;max-height:262px;overflow:auto;padding:6px}
.cmenu .citem{text-align:left;background:transparent;border:0;color:#cfcfd6;font-family:var(--body);font-size:14.5px;
  padding:11px 12px;border-radius:9px;cursor:pointer}
.cmenu .citem:hover{background:#1f1f26;color:#fff}
.cmenu .citem.on{background:var(--gold);color:var(--ink);font-weight:600}

.cal{width:286px;padding:14px}
.cal-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-h .cal-t{font-family:var(--disp);font-weight:600;font-size:15px;color:#fff}
.cal-h .cnav{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#101015;color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center}
.cal-h .cnav:hover{border-color:var(--gold)}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}
.cal-dow span{text-align:center;font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--mut-2);padding:4px 0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-grid .cd{aspect-ratio:1;border:0;background:transparent;color:#d8d8de;font-family:var(--body);font-size:13.5px;
  border-radius:8px;cursor:pointer}
.cal-grid .cd:hover{background:#23232a;color:#fff}
.cal-grid .cd.empty{visibility:hidden;cursor:default}
.cal-grid .cd.past{color:#3a3a42;cursor:default}
.cal-grid .cd.past:hover{background:transparent}
.cal-grid .cd.today{box-shadow:inset 0 0 0 1px var(--line-2)}
.cal-grid .cd.sel{background:var(--gold);color:var(--ink);font-weight:700}

.tpick{width:208px;padding:12px}
.tp-head{display:flex}
.tp-head span{flex:1;text-align:center;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--mut-2);padding-bottom:6px}
.tp-cols{display:flex;gap:8px;height:188px}
.tp-col{flex:1;overflow:auto;scroll-snap-type:y proximity;display:flex;flex-direction:column;gap:3px;padding:3px;
  background:#0e0e12;border:1px solid var(--line);border-radius:10px}
.tp-col::-webkit-scrollbar{width:0}
.tp-i{scroll-snap-align:center;border:0;background:transparent;color:#cfcfd6;font-family:var(--body);font-size:15px;
  padding:9px 0;border-radius:7px;cursor:pointer;text-align:center;flex:none}
.tp-i:hover{background:#1f1f26;color:#fff}
.tp-i.on{background:var(--gold);color:var(--ink);font-weight:700}

/* ---------- reveal-on-scroll ----------
   Hidden start-state gated behind html.plejo-js (set by an inline head flag the
   instant JS runs). No JS / blocked chrome.js → content stays fully visible
   instead of stuck hidden below the fold. chrome.js's reveals() adds .in. */
.plejo-js .reveal{opacity:0;transform:translateY(16px);transition:opacity .55s cubic-bezier(.2,.6,.2,1),transform .55s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
