/* ===========================================================
   ΧΑΡΑΛΑΜΠΙΔΗΣ — Professional car services
   v1.0 · 2026-05-02 · Shared design system
   =========================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Brand palette */
  --lav:#9DA0D6;
  --lav-glow:#B0B3E2;
  --lav-deep:#7B7FBE;
  --lav-soft:#E8E9F5;
  --lav-soft-2:#F4F4FA;
  --ink:#0A0A0A;
  --ink-2:#1A1A22;
  --n900:#181820;
  --n700:#3F3F4A;
  --n500:#7A7A85;
  --n400:#9292A0;
  --n300:#D4D4DA;
  --n200:#E5E5EB;
  --n100:#F5F5F8;
  --bg:#FFFFFF;
  --bg-off:#FAFAFC;

  /* Layout */
  --maxw:1400px;
  --pad:clamp(1.25rem,4vw,3rem);

  /* Type */
  --font-sans:'Manrope',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono','Space Grotesk',monospace;
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  font-size:16px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit}
::selection{background:var(--lav);color:var(--bg)}

/* ============ Type system ============ */
.display-xl{font-family:var(--font-sans);font-weight:800;font-size:clamp(3rem,10vw,8.5rem);line-height:.92;letter-spacing:-0.045em;text-transform:uppercase}
/* Hero headline: black + mauve, NO outline. Plain spans = ink black,
   .lav-text spans = mauve. No -webkit-text-stroke anywhere. */
.hero .display-xl{
  color:var(--ink);
  -webkit-text-stroke:0;
  text-shadow:0 1px 18px rgba(255,255,255,.6);
}
.hero .display-xl .lav-text{
  color:var(--lav-deep);
  -webkit-text-stroke:0;
  text-shadow:0 1px 16px rgba(255,255,255,.7);
}
.hero .display-xl .stroked-text{
  color:var(--lav-deep);
  -webkit-text-stroke:0;
  text-shadow:0 1px 16px rgba(255,255,255,.7);
}
.display-1{font-family:var(--font-sans);font-weight:600;font-size:clamp(2.25rem,5.5vw,4.5rem);line-height:1;letter-spacing:-0.03em}
.display-2{font-family:var(--font-sans);font-weight:500;font-size:clamp(1.75rem,3.6vw,2.75rem);line-height:1.05;letter-spacing:-0.02em}
.h2{font-family:var(--font-sans);font-weight:500;font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.15;letter-spacing:-0.018em}
.h3{font-family:var(--font-sans);font-weight:500;font-size:clamp(1.2rem,2vw,1.5rem);line-height:1.2;letter-spacing:-0.015em}
.lead{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--n700);max-width:60ch;line-height:1.6}
.eyebrow{font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--lav-deep)}
.label{font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--n500)}
.num-mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.lav-text{color:var(--lav-deep)}
.stroked-text{
  color:var(--lav-deep);
  -webkit-text-stroke:1.5px var(--ink);
  text-shadow:0 2px 0 rgba(10,10,10,.06);
}
@supports not (-webkit-text-stroke: 1px black){
  .stroked-text{color:var(--lav-deep);text-shadow:1px 0 0 var(--ink), -1px 0 0 var(--ink), 0 1px 0 var(--ink), 0 -1px 0 var(--ink)}
}

/* ============ Layout ============ */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{padding-block:clamp(4.5rem,9vw,8rem)}

/* ============ Nav ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  backdrop-filter:saturate(1.4) blur(14px);
  -webkit-backdrop-filter:saturate(1.4) blur(14px);
  background:rgba(255,255,255,.78);
  border-bottom:1px solid transparent;
  transition:border-color .3s, background-color .3s, padding .3s;
}
.nav.scrolled{border-bottom-color:var(--n200);background:rgba(255,255,255,.95)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.85rem var(--pad);max-width:var(--maxw);margin:0 auto;gap:1.5rem;transition:padding .3s}
.nav.scrolled .nav-inner{padding-block:.7rem}
.logo-link{display:flex;align-items:center;gap:.65rem;flex-shrink:0;transition:transform .3s}
.logo-link:hover{transform:translateY(-1px)}
.logo-img{height:42px;width:auto;display:block;transition:height .3s}
.nav.scrolled .logo-img{height:38px}

.nav-links{display:flex;gap:.4rem;align-items:center}
.nav-link{
  font-family:var(--font-sans);font-size:.86rem;font-weight:500;
  color:var(--n700);
  padding:.55rem .85rem;border-radius:6px;
  transition:color .25s, background-color .25s;
  position:relative;
}
.nav-link:hover{color:var(--ink);background:var(--lav-soft-2)}
.nav-link.current{color:var(--lav-deep);background:var(--lav-soft-2)}
.nav-link.current::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.25rem;
  height:1.5px;background:var(--lav-deep);
}

.nav-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.7rem 1.2rem;
  background:var(--ink);color:var(--bg);
  font-family:var(--font-sans);font-size:.82rem;font-weight:600;letter-spacing:.02em;
  border-radius:8px;
  transition:transform .25s, background-color .25s, box-shadow .35s;
  flex-shrink:0;
}
.nav-cta:hover{transform:translateY(-2px);background:var(--lav-deep);box-shadow:0 10px 26px -8px rgba(123,127,190,.55)}
.nav-cta svg{width:14px;height:14px}

/* Language toggle */
.lang-toggle{
  flex-shrink:0;
  font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.1em;
  color:var(--ink);background:transparent;
  border:1.5px solid var(--n300);border-radius:6px;
  padding:.5rem .7rem;cursor:pointer;min-width:42px;
  transition:border-color .25s, background-color .25s, color .25s;
  -webkit-tap-highlight-color:transparent;
}
.lang-toggle:hover{border-color:var(--lav-deep);color:var(--lav-deep);background:var(--lav-soft-2)}
@media(max-width:920px){
  .lang-toggle{order:3;padding:.4rem .55rem;font-size:.66rem;min-width:34px}
}

/* Mobile menu */
.nav-toggle{display:none;width:42px;height:42px;align-items:center;justify-content:center;border-radius:6px;background:transparent;color:var(--ink);flex-shrink:0}
.nav-toggle:hover{background:var(--lav-soft-2)}
.nav-toggle svg{width:22px;height:22px}
.nav-drawer-backdrop{
  position:fixed;inset:0;background:rgba(10,10,10,.55);
  opacity:0;visibility:hidden;
  transition:opacity .3s, visibility .3s;
  z-index:150;
  cursor:pointer;
}
.nav-drawer-backdrop.open{opacity:1;visibility:visible}
/* X close button inside drawer — hidden on desktop, shown on mobile */
.drawer-close{display:none}
@media(max-width:920px){
  .nav-inner{gap:.5rem}
  .nav-toggle{display:inline-flex;order:1}
  .logo-link{order:2;margin:0 auto;flex:0 0 auto}
  .logo-img{height:38px}
  .nav-cta{order:4;flex-shrink:0}
  .nav-links{
    position:fixed;top:0;left:0;
    height:100svh;width:min(82vw, 360px);
    background:#fff;
    flex-direction:column;align-items:stretch;
    gap:.2rem;padding:5.5rem 1.4rem 2rem;
    transform:translateX(-100%);
    transition:transform .38s cubic-bezier(.65,0,.35,1);
    z-index:200;
    box-shadow:0 0 40px rgba(10,10,10,.18);
    overflow-y:auto;
  }
  .nav-links.open{transform:translateX(0);pointer-events:auto}
  /* X close button — top-left of drawer, where the hamburger was */
  .drawer-close{
    display:flex;align-items:center;justify-content:center;
    position:absolute;top:1rem;left:1rem;
    width:44px;height:44px;border-radius:8px;
    background:var(--lav-soft-2);color:var(--ink);
    border:none;cursor:pointer;z-index:3;
    -webkit-tap-highlight-color:transparent;
  }
  .drawer-close:active{background:var(--lav-soft)}
  .drawer-close svg{width:22px;height:22px;pointer-events:none}
  .nav-link{display:block;padding:1.1rem .9rem;font-size:1.05rem;border-radius:10px;width:100%;text-align:left;border-bottom:1px solid var(--n200);border-radius:0;pointer-events:auto;position:relative;z-index:1}
  .nav-link:last-of-type{border-bottom:none}
  .nav-link.current{background:transparent;color:var(--lav-deep)}
  .nav-link.current::after{display:none}
  .nav-cta{padding:.55rem .85rem;font-size:.75rem}
  .nav-cta span.cta-text{display:none}
  /* drawer footer contact info */
  .nav-links::after{
    content:"Θερμά Σερρών · Τ.Κ. 62200";
    font-family:var(--font-mono);font-size:.6rem;
    letter-spacing:.2em;text-transform:uppercase;
    color:var(--n500);
    margin-top:auto;padding:1.2rem .9rem 0;
    border-top:1px solid var(--n200);
    display:block;
  }
  body.drawer-open{overflow:hidden}
}

/* ============ Floating mobile contact FAB ============ */
.mob-fab{display:none}
@media(max-width:760px){
  .mob-fab{
    display:block;position:fixed;
    right:1rem;
    bottom:max(1rem, env(safe-area-inset-bottom));
    z-index:140;
  }
  .mob-fab-menu{max-height:80svh;overflow-y:auto}
  /* keep last section content from sitting under FAB */
  .foot{padding-bottom:calc(2.5rem + 56px + env(safe-area-inset-bottom, 0px))}
  .mob-fab-btn{
    width:56px;height:56px;border-radius:50%;
    background:var(--ink);color:#fff;
    box-shadow:0 10px 26px rgba(10,10,10,.32), 0 0 0 6px rgba(157,160,214,.15);
    display:flex;align-items:center;justify-content:center;
    border:none;cursor:pointer;
    transition:background .25s, transform .25s, box-shadow .25s;
    position:relative;z-index:2;
  }
  .mob-fab-btn:hover{transform:translateY(-1px)}
  .mob-fab-btn svg{width:24px;height:24px;transition:opacity .2s, transform .25s}
  .mob-fab-btn .mfb-ico-close{position:absolute;opacity:0;transform:rotate(-45deg)}
  .mob-fab.open .mob-fab-btn{background:var(--lav-deep)}
  .mob-fab.open .mob-fab-btn .mfb-ico-call{opacity:0;transform:rotate(45deg)}
  .mob-fab.open .mob-fab-btn .mfb-ico-close{opacity:1;transform:rotate(0)}
  .mob-fab-menu{
    position:absolute;bottom:68px;right:0;
    background:#fff;border-radius:14px;
    border:1px solid var(--n200);
    box-shadow:0 18px 48px rgba(10,10,10,.20);
    padding:.5rem;
    display:flex;flex-direction:column;
    min-width:240px;
    transform:translateY(10px) scale(.94);
    transform-origin:bottom right;
    opacity:0;visibility:hidden;
    transition:transform .28s cubic-bezier(.34,1.4,.64,1), opacity .22s, visibility .22s;
  }
  .mob-fab.open .mob-fab-menu{transform:translateY(0) scale(1);opacity:1;visibility:visible}
  .mfm-item{
    display:flex;gap:.85rem;align-items:center;
    padding:.8rem .85rem;
    border-radius:10px;
    color:var(--ink);
    transition:background .18s;
    text-decoration:none;
  }
  .mfm-item:hover,.mfm-item:focus-visible{background:var(--lav-soft-2)}
  .mfm-item svg{width:22px;height:22px;color:var(--lav-deep);flex-shrink:0}
  .mfm-text{display:flex;flex-direction:column;line-height:1.2;text-align:left}
  .mfm-key{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--n500);font-family:var(--font-mono);margin-bottom:.15rem}
  .mfm-val{font-size:.95rem;font-weight:500;color:var(--ink)}
}

/* ============ Buttons ============ */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:1rem 1.6rem;
  font-family:var(--font-sans);font-size:.92rem;font-weight:600;letter-spacing:.02em;
  border-radius:8px;
  transition:transform .25s, background-color .25s, color .25s, box-shadow .35s, border-color .25s;
  cursor:pointer;
}
.btn-primary{background:var(--ink);color:var(--bg)}
.btn-primary:hover{background:var(--lav-deep);transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(123,127,190,.55)}
.btn-lav{background:var(--lav);color:var(--ink)}
.btn-lav:hover{background:var(--lav-glow);transform:translateY(-2px);box-shadow:0 12px 28px -8px rgba(157,160,214,.65)}
.btn-line{background:transparent;color:var(--ink);border:1.5px solid var(--n300)}
.btn-line:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--lav-deep);padding:.6rem 0;border-radius:0}
.btn-ghost::after{content:" →";transition:transform .25s;display:inline-block}
.btn-ghost:hover::after{transform:translateX(4px)}
.btn svg{width:16px;height:16px}

/* ============ Hero variants (white-bg, lavender accent) ============ */
.hero{
  min-height:92svh;position:relative;
  padding-top:7rem;padding-bottom:4rem;
  display:flex;flex-direction:column;justify-content:center;
  background:radial-gradient(ellipse at 75% 30%, rgba(157,160,214,.13) 0%, rgba(255,255,255,1) 60%);
  overflow:hidden;
}
.grid-bg{
  position:absolute;inset:0;pointer-events:none;opacity:.55;
  background-image:
    linear-gradient(to right, rgba(157,160,214,.09) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(157,160,214,.09) 1px, transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center, rgba(0,0,0,1) 25%, rgba(0,0,0,0) 80%);
}
.hero-mark{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-55%) scale(1);
  width:clamp(280px,55vw,720px);
  opacity:.07;
  z-index:0;
  animation:floatMark 16s ease-in-out infinite;
  pointer-events:none;
}
@keyframes floatMark{
  0%,100%{transform:translate(-50%,-55%) scale(1) rotate(0deg)}
  50%{transform:translate(-50%,-58%) scale(1.04) rotate(-1.2deg)}
}
.hero-inner{position:relative;z-index:2}
.hero-eyebrow{display:flex;align-items:center;gap:.7rem;margin-bottom:2rem}
.hero-eyebrow .pulse{width:8px;height:8px;border-radius:50%;background:var(--lav);box-shadow:0 0 0 0 rgba(157,160,214,.7);animation:pulse 2s ease-out infinite;flex-shrink:0}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(157,160,214,.55)}70%{box-shadow:0 0 0 12px rgba(157,160,214,0)}100%{box-shadow:0 0 0 0 rgba(157,160,214,0)}}

.hero-row-2{display:grid;grid-template-columns:1fr;gap:2rem;align-items:end;margin-top:2.5rem}
@media(min-width:880px){.hero-row-2{grid-template-columns:1.4fr 1fr}}
.hero-tagline{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--n700);max-width:60ch;line-height:1.6}
.hero-tagline strong{color:var(--ink);font-weight:500}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.7rem}

.hero-foot{
  margin-top:4.5rem;
  border-top:1px solid var(--n200);
  padding-top:1.2rem;
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;
}
@media(min-width:880px){.hero-foot{grid-template-columns:repeat(4,1fr)}}
.hf-cell{display:flex;flex-direction:column;gap:.4rem}
.hf-key{font-family:var(--font-mono);font-size:.65rem;color:var(--n500);letter-spacing:.18em;text-transform:uppercase}
.hf-val{font-family:var(--font-sans);font-size:1rem;color:var(--ink);font-weight:500}

/* Mobile hero centering */
@media(max-width:760px){
  .hero{text-align:center;min-height:auto;padding-top:6rem;padding-bottom:3rem}
  .hero-eyebrow{justify-content:center}
  .hero-row-2{text-align:left}
  .hero-tagline{margin-inline:auto}
  .hero-ctas{justify-content:center}
  .hero-foot{text-align:left}
  .hero-mark{opacity:.05}
}

/* ============ Section heads ============ */
.sec-head{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:3.5rem;align-items:end}
@media(min-width:880px){.sec-head{grid-template-columns:1fr 1fr}}
.sec-head .right{font-size:1rem;color:var(--n700);line-height:1.6;max-width:50ch;justify-self:start}
@media(min-width:880px){.sec-head .right{justify-self:end;text-align:right}}
@media(max-width:760px){
  .sec-head{text-align:center}
  .sec-head .right{margin-inline:auto;text-align:center}
}

/* ============ Tile cards ============ */
.tiles-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:.7rem}
@media(min-width:760px){.tiles-grid{grid-template-columns:1fr 1fr;gap:1rem}}
@media(min-width:1180px){.tiles-grid.cols-3{grid-template-columns:repeat(3,1fr)}}

/* Vehicle / fleet grids — replaces inline auto-fit grids on emporia + rentals */
.vehicle-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:.7rem}
@media(min-width:760px){.vehicle-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}}
.tile{
  position:relative;
  background:var(--bg);
  border:1px solid var(--n200);
  padding:2.5rem;
  border-radius:14px;
  overflow:hidden;
  transition:border-color .35s, transform .35s, box-shadow .35s;
  cursor:pointer;
  min-height:280px;
  display:flex;flex-direction:column;justify-content:space-between;
}
.tile::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(157,160,214,.18) 0%, transparent 50%);
  opacity:0;transition:opacity .35s;pointer-events:none;
}
.tile:hover{border-color:var(--lav);transform:translateY(-4px);box-shadow:0 24px 50px -16px rgba(123,127,190,.18)}
.tile:hover::after{opacity:1}

.tile-head{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1}
.tile-num{font-family:var(--font-mono);font-size:.7rem;color:var(--lav-deep);letter-spacing:.12em;font-variant-numeric:tabular-nums}
.tile-icon{width:24px;height:24px;color:var(--n400);transition:color .3s, transform .3s}
.tile:hover .tile-icon{color:var(--lav-deep);transform:translate(2px,-2px)}
.tile-body{margin-top:auto;position:relative;z-index:1}
.tile-title{font-family:var(--font-sans);font-weight:600;font-size:1.6rem;color:var(--ink);letter-spacing:-0.02em;margin-bottom:.7rem;line-height:1.1}
.tile-desc{font-size:.92rem;color:var(--n700);line-height:1.55;margin-bottom:1.4rem}
.tile-cta{
  display:inline-flex;align-items:center;gap:.5rem;align-self:flex-start;
  font-family:var(--font-mono);font-size:.72rem;
  color:var(--lav-deep);letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  background:var(--lav-soft-2);border:1px solid var(--lav-soft);
  padding:.6rem 1rem;border-radius:99px;
  transition:gap .25s, background-color .25s, border-color .25s;
}
.tile:hover .tile-cta{gap:.8rem;background:var(--lav);border-color:var(--lav);color:var(--ink)}
.tile-cta svg{width:13px;height:13px;transition:transform .25s}
.tile:hover .tile-cta svg{transform:translateX(3px)}

/* Mobile-first compact tile (2x2 grid on phone) */
@media(max-width:760px){
  .tile{padding:1.05rem .85rem;min-height:180px;border-radius:11px}
  .tile-num{font-size:.58rem;letter-spacing:.1em}
  .tile-icon{width:20px;height:20px}
  .tile-title{font-size:1.05rem;margin-bottom:.4rem;letter-spacing:-0.015em}
  .tile-desc{font-size:.74rem;line-height:1.42;margin-bottom:.7rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
  .tile-cta{font-size:.66rem;letter-spacing:.08em;gap:.4rem;padding:.55rem .9rem;width:100%;justify-content:center}
  .tile-cta svg{width:12px;height:12px}
  /* Hero CTA buttons: big, full-width, easy to tap on phones */
  .hero-ctas{flex-direction:column;align-items:stretch;width:100%;gap:.6rem}
  .hero-ctas .btn{width:100%;justify-content:center;min-height:52px;font-size:1rem;padding:.95rem 1.4rem}
  .hero-centered .hero-ctas{align-items:stretch}
}

/* ============ Marquee ============ */
.marquee{
  background:var(--bg-off);
  border-block:1px solid var(--n200);
  padding:1.5rem 0;
  overflow:hidden;
  white-space:nowrap;
  mask-image:linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}
.marquee-inner{
  display:inline-block;
  animation:marquee 50s linear infinite;
  font-family:var(--font-sans);font-weight:600;font-size:clamp(1.5rem,2.5vw,2.2rem);
  letter-spacing:-0.02em;text-transform:uppercase;
  color:var(--n400);
}
.marquee-inner span{margin-inline:1.5rem}
.marquee-inner span.lav{color:var(--lav-deep)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-inner .dot{display:inline-block;width:6px;height:6px;background:var(--lav);border-radius:50%;vertical-align:middle;margin-inline:1.2rem}

/* ============ Stats ============ */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:3rem}
@media(min-width:880px){.stats-grid{grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--n200)}}
.stat{padding:2rem 0}
@media(min-width:880px){.stat{padding:2.4rem 1.6rem;border-right:1px solid var(--n200)}.stat:last-child{border-right:none}.stat:first-child{padding-left:0}.stat:last-child{padding-right:0}}
.stat-num{font-family:var(--font-sans);font-weight:300;font-size:clamp(2.5rem,5vw,4rem);line-height:1;color:var(--ink);letter-spacing:-0.04em;font-variant-numeric:tabular-nums}
.stat-num .small{color:var(--lav-deep);font-size:.5em;margin-left:.15em}
.stat-label{font-family:var(--font-mono);font-size:.7rem;color:var(--n500);letter-spacing:.18em;text-transform:uppercase;margin-top:.8rem;line-height:1.5}

/* ============ Quote / About band ============ */
.why-quote{
  font-family:var(--font-sans);font-weight:300;
  font-size:clamp(1.7rem,3.5vw,2.8rem);line-height:1.2;letter-spacing:-0.02em;
  color:var(--ink);
  max-width:24ch;
}
.why-quote .lav{color:var(--lav-deep)}

/* ============ Service cards ============ */
.svc-cards{display:grid;grid-template-columns:repeat(2, 1fr);gap:.55rem}
@media(min-width:760px){.svc-cards{grid-template-columns:1fr 1fr;gap:.8rem}}
@media(min-width:1180px){.svc-cards{grid-template-columns:1fr 1fr 1fr}}
.svc-card{
  background:var(--bg);
  border:1px solid var(--n200);
  padding:1.6rem 1.8rem;
  border-radius:10px;
  transition:border-color .3s, background-color .3s, transform .25s, box-shadow .3s;
  position:relative;
}
.svc-card:hover{border-color:var(--lav);background:var(--bg-off);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(123,127,190,.22)}
.svc-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.65rem}
.svc-num{font-family:var(--font-mono);font-size:.72rem;color:var(--lav-deep);letter-spacing:.1em;font-variant-numeric:tabular-nums}
.svc-tag{font-family:var(--font-mono);font-size:.62rem;color:var(--n500);letter-spacing:.15em;text-transform:uppercase;border:1px solid var(--n200);padding:.18rem .55rem;border-radius:99px;background:var(--bg-off)}
.svc-name{font-family:var(--font-sans);font-weight:500;font-size:1.1rem;color:var(--ink);letter-spacing:-0.01em;margin-bottom:.4rem;line-height:1.2}
.svc-desc{font-size:.86rem;color:var(--n700);line-height:1.5}
@media(max-width:760px){
  .svc-card{padding:.95rem .85rem;border-radius:9px}
  .svc-card-head{margin-bottom:.45rem}
  .svc-num{font-size:.62rem}
  .svc-tag{display:none}
  .svc-name{font-size:.92rem;margin-bottom:.3rem;line-height:1.18}
  .svc-desc{font-size:.74rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
}

/* ============ Equipment grid ============ */
.eq-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:1px;background:var(--n200);border:1px solid var(--n200);border-radius:14px;overflow:hidden}
@media(min-width:760px){.eq-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1100px){.eq-grid{grid-template-columns:repeat(3,1fr)}}
.eq-cell{
  background:var(--bg);padding:2.2rem;
  transition:background-color .35s;
  position:relative;
  min-height:200px;
  display:flex;flex-direction:column;
}
.eq-cell:hover{background:var(--lav-soft-2)}
.eq-cell:hover .eq-arrow{transform:translate(3px,-3px);color:var(--lav-deep)}
.eq-num{font-family:var(--font-mono);font-size:.7rem;color:var(--lav-deep);letter-spacing:.1em;margin-bottom:1rem}
.eq-icon{width:36px;height:36px;color:var(--lav-deep);margin-bottom:1.2rem;margin-top:auto}
.eq-name{font-family:var(--font-sans);font-weight:500;font-size:1.1rem;color:var(--ink);letter-spacing:-0.01em;margin-bottom:.4rem}
.eq-detail{font-size:.86rem;color:var(--n700);line-height:1.5}
.eq-arrow{position:absolute;top:1.6rem;right:1.6rem;width:18px;height:18px;color:var(--n400);transition:transform .3s, color .3s}
@media(max-width:760px){
  .eq-cell{padding:1.05rem .85rem;min-height:165px}
  .eq-num{font-size:.58rem;margin-bottom:.55rem;letter-spacing:.08em}
  .eq-icon{width:26px;height:26px;margin-bottom:.6rem}
  .eq-name{font-size:.95rem;margin-bottom:.3rem}
  .eq-detail{font-size:.74rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .eq-arrow{top:.85rem;right:.85rem;width:14px;height:14px}
}

/* ============ Premium preloader ============ */
.pre-load{
  position:fixed;inset:0;z-index:9999;
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .55s ease, visibility .55s;
}
.pre-load.done{opacity:0;visibility:hidden;pointer-events:none}
.pre-load-inner{
  display:flex;flex-direction:column;align-items:center;gap:1.4rem;
  animation:preloadIn .85s cubic-bezier(.22,1,.36,1) both;
}
.pre-load-logo{
  width:clamp(200px, 32vw, 320px);height:auto;
  filter:drop-shadow(0 8px 38px rgba(157,160,214,.22));
}
.pre-load-tag{
  font-family:var(--font-mono);font-size:.7rem;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--n500);
}
.pre-load-bar{
  width:140px;height:2px;
  background:rgba(157,160,214,.18);
  border-radius:2px;overflow:hidden;
  margin-top:.4rem;position:relative;
}
.pre-load-bar::after{
  content:"";position:absolute;left:-40%;top:0;
  width:40%;height:100%;
  background:linear-gradient(90deg, transparent 0%, var(--lav) 30%, var(--ink) 100%);
  animation:preloadBar 1.15s cubic-bezier(.65,0,.35,1) infinite;
  border-radius:2px;
}
@keyframes preloadIn{
  from{opacity:0;transform:translateY(18px) scale(.96)}
  to{opacity:1;transform:none}
}
@keyframes preloadBar{
  0%{left:-40%}
  100%{left:140%}
}
@media (prefers-reduced-motion: reduce){
  .pre-load-inner,.pre-load-bar::after{animation:none}
  .pre-load-bar::after{left:0;width:100%;background:var(--lav-deep)}
}
@media(max-width:760px){
  .pre-load-logo{width:clamp(180px, 56vw, 260px)}
  .pre-load-tag{font-size:.6rem;letter-spacing:.26em}
}

/* ============ Real showcase grid (workshop + fleet photos) ============ */
.showcase-grid{
  display:grid;grid-template-columns:repeat(2, 1fr);gap:.7rem;
}
@media(min-width:760px){.showcase-grid{gap:1rem}}
@media(min-width:1100px){.showcase-grid{grid-template-columns:repeat(4, 1fr)}}
.sc-tile{
  position:relative;margin:0;
  aspect-ratio:4/3;
  border-radius:12px;overflow:hidden;
  background:var(--n200);
  isolation:isolate;
}
.sc-tile img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .6s cubic-bezier(.22,1,.36,1);
}
.sc-tile:hover img{transform:scale(1.05)}
.sc-tile figcaption{
  position:absolute;left:0;right:0;bottom:0;z-index:1;
  padding:.85rem 1rem;
  background:linear-gradient(to top, rgba(10,10,10,.78) 0%, rgba(10,10,10,.55) 60%, rgba(10,10,10,0) 100%);
  color:#fff;
  display:flex;flex-direction:column;line-height:1.2;
}
.sc-key{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--lav);margin-bottom:.2rem;font-weight:500}
.sc-val{font-family:var(--font-sans);font-size:.95rem;font-weight:500}
@media(max-width:760px){
  .sc-tile{border-radius:10px;aspect-ratio:1/1}
  .sc-tile figcaption{padding:.55rem .65rem}
  .sc-key{font-size:.5rem;letter-spacing:.14em}
  .sc-val{font-size:.8rem}
}

/* ============ Workshop hero banner (contact.html) ============ */
.workshop-banner{
  position:relative;width:100%;aspect-ratio:21/9;
  border-radius:14px;overflow:hidden;
  margin:0 0 clamp(2rem, 4vw, 3.5rem);
  background:var(--n200);
}
.workshop-banner img{width:100%;height:100%;object-fit:cover;display:block}
.workshop-banner-caption{
  position:absolute;left:1.4rem;bottom:1.2rem;right:1.4rem;z-index:1;color:#fff;
  text-shadow:0 2px 24px rgba(0,0,0,.6);
}
.workshop-banner-caption .wbk{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--lav);margin-bottom:.3rem;display:block}
.workshop-banner-caption .wbv{font-family:var(--font-sans);font-size:clamp(1.05rem, 2vw, 1.4rem);font-weight:500}
.workshop-banner::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top, rgba(10,10,10,.55) 0%, rgba(10,10,10,.05) 50%, rgba(10,10,10,0) 100%);
  pointer-events:none;
}
@media(max-width:760px){
  .workshop-banner{aspect-ratio:4/3;border-radius:10px}
  .workshop-banner-caption{left:.9rem;right:.9rem;bottom:.8rem}
}

/* ============ Smart photo placeholders ============ */
.ph{
  position:relative;
  aspect-ratio:var(--ph-ratio,16/10);
  background:linear-gradient(135deg, var(--lav-soft) 0%, var(--lav-soft-2) 100%);
  border:1px solid var(--n200);
  border-radius:14px;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  isolation:isolate;
}
.ph::before{
  content:"";position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(45deg, transparent 0, transparent 14px, rgba(157,160,214,.18) 14px, rgba(157,160,214,.18) 15px);
  opacity:.6;z-index:0;
}
.ph-mark{
  width:50%;max-width:140px;
  opacity:.4;z-index:1;
  filter:saturate(0.6);
}
.ph-label{
  position:absolute;left:1rem;bottom:1rem;
  font-family:var(--font-mono);font-size:.65rem;
  color:var(--lav-deep);
  letter-spacing:.14em;text-transform:uppercase;
  background:rgba(255,255,255,.92);
  padding:.4rem .7rem;
  border-radius:6px;
  z-index:2;
  border:1px solid var(--n200);
  font-weight:500;
}
.ph-sm{--ph-ratio:1/1}
.ph-wide{--ph-ratio:21/9}
.ph-portrait{--ph-ratio:3/4}

/* Filled photo tile — replaces the placeholder gradient/pattern when an image is present */
.ph-img{background:transparent}
.ph-img::before{display:none}
.ph-img > img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;z-index:1;
}
.ph-img .ph-mark,
.ph-img .ph-label{display:none}

/* Non-clickable, non-saveable car tile (CSS background-image, not <img>) */
.ph-bg{
  background-size:cover;background-position:center;background-repeat:no-repeat;
  -webkit-user-select:none;user-select:none;-webkit-user-drag:none;
  pointer-events:none;
}
.ph-bg::before{display:none}
.ph-bg .ph-mark,
.ph-bg .ph-label{display:none}

/* ============ Hero background video ============ */
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center center;
  z-index:0;opacity:.62;
  pointer-events:none;
  filter:saturate(.92) contrast(1.04);
}
.hero-video-mask{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(to bottom, rgba(255,255,255,.55) 0%, rgba(255,255,255,.05) 22%, rgba(255,255,255,.05) 70%, rgba(255,255,255,.88) 100%),
    linear-gradient(to right, rgba(255,255,255,.30) 0%, rgba(255,255,255,0) 14%, rgba(255,255,255,0) 86%, rgba(255,255,255,.30) 100%);
}
@media (prefers-reduced-motion: reduce){.hero-video{display:none}}
@media (max-width:760px){
  .hero-video{opacity:.55}
  .hero-video-mask{
    background:
      linear-gradient(to bottom, rgba(255,255,255,.50) 0%, rgba(255,255,255,.10) 18%, rgba(255,255,255,.10) 72%, rgba(255,255,255,.92) 100%);
  }
}

/* ============ Centered hero variant (index only) ============ */
.hero-centered{text-align:center;padding-top:6rem}
.hero-centered .hero-inner{position:relative;z-index:2}
.hero-centered .hero-stack{display:flex;flex-direction:column;align-items:center;gap:1.4rem}
.hero-logo{
  width:clamp(220px, 26vw, 360px);max-width:100%;height:auto;
  display:block;margin:0 auto .25rem;
  filter:drop-shadow(0 4px 28px rgba(157,160,214,.18));
}
.hero-tagline-pro{
  font-family:var(--font-mono);font-size:.72rem;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--n500);
  margin-top:-.5rem;margin-bottom:1.4rem;
  display:inline-block;
}
.hero-centered .hero-eyebrow{justify-content:center}
.hero-centered .hero-tagline{margin-inline:auto;text-align:center;max-width:62ch}
.hero-centered .hero-ctas{justify-content:center;flex-wrap:wrap}
.hero-centered .hero-foot{margin-top:4rem}
@media(max-width:760px){
  .hero-centered{padding-top:5.5rem;padding-bottom:2rem;min-height:auto}
  .hero-centered .hero-stack{gap:1rem}
  .hero-logo{width:clamp(190px, 56vw, 280px)}
  .hero-tagline-pro{font-size:.62rem;letter-spacing:.26em;margin-bottom:.8rem}
  .hero-centered .hero-foot{margin-top:2.5rem;text-align:left}
  .hero .display-xl{text-shadow:0 1px 14px rgba(255,255,255,.7)}
}

/* ============ Channels (contact band) ============ */
.ch-grid{display:grid;grid-template-columns:1fr;gap:.7rem}
@media(min-width:600px){.ch-grid{grid-template-columns:1fr 1fr}}
.ch{
  background:var(--bg);
  border:1px solid var(--n200);
  padding:1.6rem 1.8rem;
  border-radius:12px;
  transition:border-color .3s, transform .3s, box-shadow .35s, background-color .3s;
  display:flex;flex-direction:column;gap:.5rem;
  min-height:130px;
  position:relative;
}
.ch:hover{border-color:var(--lav);transform:translateY(-3px);box-shadow:0 16px 40px -10px rgba(123,127,190,.18);background:var(--bg-off)}
.ch-key{font-family:var(--font-mono);font-size:.66rem;color:var(--n500);letter-spacing:.18em;text-transform:uppercase}
.ch-val{font-family:var(--font-sans);font-weight:500;font-size:clamp(1rem,1.6vw,1.25rem);color:var(--ink);letter-spacing:-0.01em;line-height:1.2;word-break:break-word}
.ch-icon{width:18px;height:18px;color:var(--n400);align-self:flex-end;margin-top:auto;transition:color .3s, transform .3s}
.ch:hover .ch-icon{color:var(--lav-deep);transform:translate(3px,-3px)}

/* ============ Contact band ============ */
.contact-band{background:var(--ink);color:var(--bg);position:relative;overflow:hidden}
.contact-band .eyebrow{color:var(--lav)}
.contact-band h2{color:var(--bg);margin-bottom:1.5rem}
.contact-band p{color:#A8A8B5}
.contact-band .ch{background:#16161E;border-color:#2A2A35;color:var(--bg)}
.contact-band .ch:hover{background:#1A1A24;border-color:var(--lav-deep);box-shadow:0 16px 40px -10px rgba(0,0,0,.5)}
.contact-band .ch-key{color:#7A7A85}
.contact-band .ch-val{color:var(--bg)}
.contact-band .ch-icon{color:#5E5E6B}
.contact-band .ch:hover .ch-icon{color:var(--lav)}
.contact-band-mark{position:absolute;right:-5%;bottom:-30%;width:560px;opacity:.05;pointer-events:none}

/* ============ Footer ============ */
.foot{background:var(--ink);color:#76767E;padding:2.5rem 0;border-top:1px solid #2A2A35;font-size:.84rem}
.foot-inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem}
.foot a{color:var(--lav);transition:color .2s}
.foot a:hover{color:var(--lav-glow)}
.foot .creds{display:flex;gap:1.4rem;flex-wrap:wrap}

/* ============ Reveal animations ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 1s ease, transform 1s ease}
.reveal.in{opacity:1;transform:none}
.reveal-stagger > *{opacity:0;transform:translateY(18px);transition:opacity .9s ease, transform .9s ease}
.reveal-stagger.in > *{opacity:1;transform:none}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.4s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.47s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.54s}
.reveal-stagger.in > *:nth-child(9){transition-delay:.61s}
.reveal-stagger.in > *:nth-child(10){transition-delay:.68s}
.reveal-stagger.in > *:nth-child(11){transition-delay:.75s}

@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-stagger > *{opacity:1;transform:none;transition:none}
  .hero-mark{animation:none}
  .pulse{animation:none}
  .marquee-inner{animation:none}
  html{scroll-behavior:auto}
}
