/* ===================================================================
   Otoderici — v5 (redesign): quiet luxury, craft workshop feel
   Less sections, more whitespace, one idea per block, photos lead.
   =================================================================== */

/* -------- Tokens -------- */
:root{
  /* Ink scale */
  --ink:#0F0F10;
  --ink-2:#1A1A1C;
  --ink-3:#2A2A2D;
  --text:#1F1F22;
  --body:#3A3A3F;

  /* Muted / lines */
  --muted:#6B7280;
  --muted-2:#8B919C;
  --line:#ECE9E4;        /* warm off-white line (paper feel) */
  --line-2:#D8D3CA;      /* stronger paper */

  /* Surfaces */
  --bg:#FDFCFA;          /* slightly warm paper */
  --paper:#F7F4EF;       /* warmer paper for alt sections */
  --soft:#FAF8F4;
  --dark:#0E0E10;
  --dark-2:#17171A;

  /* Accent — cognac / leather */
  --tan:#A0723E;
  --tan-2:#8B5E30;
  --tan-soft:#F2E7D5;
  --tan-faint:#F9F3E8;

  /* Semantic */
  --wa:#25d366;

  /* Shape */
  --r:12px;
  --r-sm:8px;
  --r-lg:20px;
  --container:1180px;

  /* Motion */
  --ease:cubic-bezier(.2,.8,.2,1);
  --dur:.25s;

  /* Type families */
  --ff-sans:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --ff-serif:"Iowan Old Style","Palatino Linotype","Book Antiqua",Palatino,Georgia,serif;
}

/* -------- Reset + base -------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--ff-sans);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none;transition:color var(--dur) var(--ease)}
a:hover{color:var(--tan-2)}
button{font:inherit}

h1,h2,h3,h4{
  margin:0 0 .4em;
  line-height:1.14;
  color:var(--ink);
  letter-spacing:-.018em;
  font-weight:700;
}
h1{font-family:var(--ff-serif);font-weight:500;font-size:clamp(2.1rem, 5vw, 3.6rem);letter-spacing:-.015em;line-height:1.08}
h2{font-family:var(--ff-serif);font-weight:500;font-size:clamp(1.6rem, 3vw, 2.3rem);letter-spacing:-.012em;line-height:1.15}
h3{font-size:1.1rem;font-weight:600;letter-spacing:0}
p{margin:0 0 1em}
p:last-child{margin-bottom:0}

/* -------- Layout helpers -------- */
.container{max-width:var(--container);margin:0 auto;padding:0 1.3rem}
@media (min-width:700px){.container{padding:0 1.6rem}}
.container-sm{max-width:780px;margin:0 auto;padding:0 1.3rem}
.container-md{max-width:960px;margin:0 auto;padding:0 1.3rem}

.muted{color:var(--muted)}
.lead{font-size:1.08rem;color:var(--body);max-width:62ch;line-height:1.7}
.kicker{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;font-weight:600;color:var(--tan-2);
  text-transform:uppercase;letter-spacing:.2em;
  margin-bottom:.6rem;
}
.kicker::before{content:"";display:inline-block;width:18px;height:1px;background:var(--tan)}
.eyebrow{color:var(--tan-2);font-family:var(--ff-serif);font-style:italic;font-weight:500}

.section{padding:5rem 0}
.section.sm{padding:3.5rem 0}
.section.alt{background:var(--paper)}
.section.dark{background:var(--dark);color:#E6E3DD}
.section.dark h1,.section.dark h2,.section.dark h3{color:#fff}
.section.dark .muted,.section.dark .lead{color:#A8A89B}
.section-head{margin-bottom:2.4rem;max-width:640px}
.section-head.center{margin:0 auto 2.4rem;text-align:center}
.section-head h2{margin:.4rem 0 .6rem}

.skip{position:absolute;left:-999px}
.skip:focus{left:0;top:0;background:#000;color:#fff;padding:.5rem 1rem;z-index:200}

/* Reveal on scroll (CSS + JS driven) */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.no-reveal .reveal,html.no-js .reveal{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* -------- Header -------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(253,252,250,.85);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .2s var(--ease),background .2s var(--ease);
}
.site-header.scrolled{background:rgba(253,252,250,.97);box-shadow:0 1px 0 rgba(0,0,0,.04)}
.nav-row{display:flex;align-items:center;gap:1rem;padding:.7rem 0;min-height:68px}
.brand{display:inline-flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand img{height:40px;width:40px;transition:transform var(--dur) var(--ease)}
.brand:hover img{transform:scale(1.05)}
.brand .brand-text{line-height:1.1}
.brand .brand-name{font-family:var(--ff-serif);font-weight:500;font-size:1.25rem;color:var(--ink);letter-spacing:-.01em}
.brand .brand-tag{display:block;font-size:.68rem;color:var(--muted);margin-top:.18rem;text-transform:uppercase;letter-spacing:.18em;font-weight:500}

.primary-nav{margin-left:auto}
.primary-nav ul{list-style:none;display:flex;gap:.1rem;margin:0;padding:0}
.primary-nav a{display:block;color:var(--body);padding:.55rem 1rem;border-radius:999px;font-size:.95rem;font-weight:500;transition:color var(--dur) var(--ease),background var(--dur) var(--ease)}
.primary-nav a:hover{color:var(--ink);background:var(--soft)}
.primary-nav .active{color:var(--ink);background:var(--tan-faint)}
.has-mega{position:relative}
.mega{
  display:none;position:absolute;top:calc(100% + .3rem);left:-.5rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:.5rem;min-width:260px;box-shadow:0 24px 44px rgba(0,0,0,.08);
}
.has-mega:hover .mega,.has-mega:focus-within .mega{display:block}
.mega ul{flex-direction:column;gap:0;padding:0}
.mega a{border-radius:var(--r-sm)}
.cta-header{
  margin-left:.6rem;display:inline-flex;align-items:center;gap:.5rem;
  padding:.55rem 1.1rem;border-radius:999px;
  background:var(--ink);color:#fff;font-weight:600;font-size:.88rem;
  transition:transform .12s var(--ease), background .18s var(--ease);
}
.cta-header:hover{background:var(--tan);color:#fff;transform:translateY(-1px)}
.cta-header svg{color:#fff}

.nav-toggle{display:none;background:transparent;border:0;padding:.55rem;cursor:pointer;margin-left:auto}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;transition:transform .22s var(--ease),opacity .2s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:960px){
  .primary-nav{
    position:fixed;top:68px;left:0;right:0;bottom:0;
    background:var(--bg);padding:1.4rem 1.5rem 2rem;overflow-y:auto;
    display:none;z-index:55;
  }
  .primary-nav.open{display:block}
  .primary-nav ul{flex-direction:column;gap:0}
  .primary-nav li{border-bottom:1px solid var(--line)}
  .primary-nav li:last-child{border-bottom:0}
  .primary-nav a{padding:.95rem .2rem;font-size:1.1rem;border-radius:0}
  .primary-nav a:hover{background:transparent}
  .mega{position:static;border:0;box-shadow:none;padding:.2rem 0 .5rem 1rem;background:transparent}
  .mega a{padding:.65rem .2rem;font-size:1rem}
  .cta-header{display:none}
  .nav-toggle{display:block}
  .brand .brand-tag{display:none}
  body.nav-open{overflow:hidden}
}

/* -------- Buttons -------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.82rem 1.35rem;border-radius:999px;border:1px solid transparent;
  font-weight:600;font-size:.95rem;cursor:pointer;text-decoration:none;line-height:1.1;
  transition:transform .12s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease);
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:var(--tan);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-tan{background:var(--tan);color:#fff}
.btn-tan:hover{background:var(--tan-2);color:#fff}
.btn-wa{background:var(--wa);color:#06301b}
.btn-wa:hover{background:#1cb859;color:#06301b}
.btn-text{
  padding:.35rem 0;background:transparent;color:var(--ink);border:0;
  border-bottom:1px solid var(--ink);border-radius:0;font-weight:500;
}
.btn-text:hover{color:var(--tan-2);border-color:var(--tan-2);transform:none}
.btn-lg{padding:1.05rem 1.8rem;font-size:1.02rem}
.btn-sm{padding:.5rem 1rem;font-size:.85rem}
.w-100{width:100%}

/* -------- Hero -------- */
.hero{
  position:relative;
  padding:3.5rem 0 4rem;
  background:var(--bg);
  overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.1fr .9fr;gap:3.5rem;align-items:center;
}
.hero-copy h1{margin:0 0 1.1rem;color:var(--ink)}
.hero-copy h1 em{font-style:italic;color:var(--tan-2)}
.hero-copy .lead{max-width:46ch;font-size:1.13rem;margin:0 0 1.8rem}
.hero-ctas{display:flex;gap:.7rem;flex-wrap:wrap}
.hero-meta{
  margin-top:2.2rem;display:flex;gap:2rem;flex-wrap:wrap;
  padding-top:1.6rem;border-top:1px solid var(--line);
}
.hero-meta .m{display:flex;flex-direction:column;min-width:0}
.hero-meta .m b{font-family:var(--ff-serif);font-weight:500;font-size:1.5rem;color:var(--ink);line-height:1}
.hero-meta .m span{font-size:.78rem;color:var(--muted);margin-top:.35rem;text-transform:uppercase;letter-spacing:.12em;font-weight:500}

.hero-visual{
  position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  background:var(--paper);
  box-shadow:0 40px 80px rgba(0,0,0,.1);
}
.hero-visual img{width:100%;height:100%;object-fit:cover;object-position:center 40%;transition:transform 1s var(--ease)}
.hero-visual:hover img{transform:scale(1.03)}
.hero-visual .badge{
  position:absolute;left:1.1rem;top:1.1rem;
  background:rgba(255,255,255,.94);color:var(--ink);
  padding:.45rem .8rem;border-radius:999px;font-size:.76rem;font-weight:600;
  display:inline-flex;align-items:center;gap:.4rem;
  box-shadow:0 4px 14px rgba(0,0,0,.1);
}
.hero-visual .badge svg{color:var(--tan)}
.hero-visual .quote{
  position:absolute;left:1.3rem;right:1.3rem;bottom:1.3rem;
  padding:1rem 1.3rem;background:rgba(15,15,16,.82);color:#fff;
  border-radius:var(--r);font-size:.92rem;line-height:1.5;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}

@media (max-width:900px){
  .hero{padding:2.5rem 0 3rem}
  .hero-grid{grid-template-columns:1fr;gap:2rem}
  .hero-visual{aspect-ratio:4/3;order:-1}
}

/* -------- Vehicle picker (inline, clean) -------- */
.vpicker{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:1.6rem;
  box-shadow:0 20px 40px rgba(0,0,0,.05);
  position:relative;
  margin-top:-3rem; /* overlap into next section */
  z-index:2;
}
.vpicker::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--tan);border-radius:var(--r-lg) var(--r-lg) 0 0}
.vpicker-head{display:flex;align-items:center;gap:.85rem;margin-bottom:1.2rem}
.vpicker-head .ico{
  width:46px;height:46px;border-radius:12px;
  background:var(--tan-faint);color:var(--tan-2);
  display:grid;place-items:center;flex-shrink:0;
}
.vpicker-head h3{margin:0;font-family:var(--ff-serif);font-weight:500;font-size:1.3rem;letter-spacing:-.01em}
.vpicker-head p{margin:0;color:var(--muted);font-size:.9rem}

.vpicker-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr)) 1.3fr;gap:.7rem;align-items:end}
.vpicker-field{display:flex;flex-direction:column;gap:.35rem;min-width:0}
.vpicker-field label{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.vpicker-field select{
  padding:.8rem 1rem;border:1px solid var(--line-2);border-radius:var(--r-sm);
  font:inherit;font-weight:500;background:#fff;color:var(--ink);
  appearance:none;width:100%;min-width:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 20 20'><path fill='%230F0F10' d='M5 8l5 5 5-5z'/></svg>");
  background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.2rem;
  transition:border-color .18s var(--ease),box-shadow .18s var(--ease);
}
.vpicker-field select:focus{outline:0;border-color:var(--tan);box-shadow:0 0 0 3px rgba(160,114,62,.18)}
.vpicker-field select:disabled{background-color:var(--soft);color:var(--muted-2);cursor:not-allowed}
.vpicker-actions{display:flex;gap:.5rem;min-width:0}
.vpicker-actions .btn{flex:1;min-width:0;height:48px;padding:.8rem .9rem}
.vpicker-actions .btn svg{flex-shrink:0}
.vpicker-msg{margin-top:.9rem;padding:.75rem 1rem;background:var(--tan-faint);border-left:3px solid var(--tan);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:.92rem;display:none}
.vpicker-msg.show{display:block}
.vpicker-msg strong{color:var(--ink)}
.vpicker-msg a{color:var(--tan-2);border-bottom:1px solid var(--tan-2);margin-left:.4rem}
.vpicker-hint{margin-top:1rem;font-size:.88rem;color:var(--muted)}

@media (max-width:960px){.vpicker-grid{grid-template-columns:1fr 1fr;gap:.6rem}.vpicker-actions{grid-column:1/-1;flex-direction:row}}
@media (max-width:520px){.vpicker-grid{grid-template-columns:1fr}.vpicker-actions{flex-direction:column}}

/* -------- Gallery tiles (uniform 4:3, harmonious) -------- */
/* Single unified grid — consistent tile size regardless of source aspect ratio.
   Thumbnails are server-side 800×600 center-crops (uniform), full image opens in lightbox. */
.gallery-grid,
.work-gallery{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:.85rem;
}
.gallery-grid a,
.work-gallery a{
  position:relative;display:block;
  aspect-ratio:4/3;
  overflow:hidden;border-radius:var(--r);
  background:var(--paper);border:1px solid var(--line);
  cursor:zoom-in;
  transition:border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.gallery-grid a:hover,
.work-gallery a:hover{
  border-color:var(--ink-3);
  box-shadow:0 14px 30px rgba(0,0,0,.08);
  transform:translateY(-2px);
}
.gallery-grid a::after,
.work-gallery a::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.45));
  opacity:0;transition:opacity .25s var(--ease);
}
.gallery-grid a:hover::after,
.work-gallery a:hover::after{opacity:1}
.gallery-grid img,
.work-gallery img{
  width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .55s var(--ease);
}
.gallery-grid a:hover img,
.work-gallery a:hover img{transform:scale(1.05)}

/* Optional overlay caption on hover */
.gallery-grid a .tile-cap,
.work-gallery a .tile-cap{
  position:absolute;inset:auto 0 0 0;padding:.9rem 1rem;
  color:#fff;font-size:.82rem;font-weight:500;line-height:1.3;
  opacity:0;transform:translateY(6px);
  transition:opacity .25s var(--ease), transform .25s var(--ease);
  pointer-events:none;z-index:1;
}
.gallery-grid a:hover .tile-cap,
.work-gallery a:hover .tile-cap{opacity:1;transform:none}
.gallery-grid a .tile-cap small,
.work-gallery a .tile-cap small{display:block;font-weight:400;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;opacity:.85}

/* Gallery feature (single hero image) */
.gallery-hero{
  aspect-ratio:16/9;border-radius:var(--r-lg);overflow:hidden;
  position:relative;background:var(--paper);border:1px solid var(--line);
  margin-bottom:1.2rem;cursor:zoom-in;
}
.gallery-hero img{width:100%;height:100%;object-fit:cover}
.gallery-hero .caption{
  position:absolute;inset:auto 0 0 0;padding:1.2rem 1.6rem;
  background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.75) 100%);color:#fff;
}
.gallery-hero .caption small{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;opacity:.8;margin-bottom:.2rem}

.gallery-showall{text-align:center;margin-top:1.4rem}

/* -------- Services (clean list) -------- */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.svc{
  display:block;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  color:var(--ink);position:relative;overflow:hidden;
  transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.svc:hover{border-color:var(--ink-3);transform:translateY(-3px);box-shadow:0 16px 30px rgba(0,0,0,.06);text-decoration:none}
.svc:not(.has-img){padding:1.8rem 1.6rem}
.svc.has-img{padding-bottom:1.5rem}
.svc-cover{aspect-ratio:16/10;overflow:hidden;background:var(--paper)}
.svc-cover img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc.has-img:hover .svc-cover img{transform:scale(1.05)}
.svc.has-img .svc-ic,
.svc.has-img h3,
.svc.has-img p,
.svc.has-img .svc-more{margin-left:1.6rem;margin-right:1.6rem}
.svc.has-img .svc-ic{margin-top:-28px;position:relative;z-index:2;background:#fff}
.svc .svc-ic{
  width:52px;height:52px;border-radius:14px;
  background:var(--tan-faint);color:var(--tan-2);
  display:grid;place-items:center;margin-bottom:1rem;
  border:1px solid var(--line);
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.svc:hover .svc-ic{background:var(--ink);color:#fff;border-color:var(--ink)}
.svc h3{margin:.2rem 0 .35rem;font-size:1.08rem;font-weight:600}
.svc p{margin:0 0 .2rem;color:var(--muted);font-size:.93rem}
.svc .svc-more{display:inline-flex;align-items:center;gap:.3rem;margin-top:.8rem;font-size:.85rem;font-weight:600;color:var(--tan-2)}
.svc .svc-more svg{transition:transform var(--dur) var(--ease)}
.svc:hover .svc-more svg{transform:translateX(3px)}

/* -------- Process (3 steps) -------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;position:relative}
.steps::before{
  content:"";position:absolute;top:28px;left:15%;right:15%;height:1px;
  background:repeating-linear-gradient(to right,var(--line-2) 0 6px,transparent 6px 12px);
  z-index:0;
}
.step{position:relative;z-index:1;text-align:center;padding:0 .6rem}
.step .step-num{
  width:56px;height:56px;border-radius:50%;
  background:#fff;color:var(--ink);border:1px solid var(--line);
  display:grid;place-items:center;margin:0 auto .9rem;
  font-family:var(--ff-serif);font-weight:500;font-size:1.3rem;letter-spacing:-.01em;
  box-shadow:0 4px 16px rgba(0,0,0,.05);
}
.step h3{margin:.2rem 0 .35rem;font-size:1.02rem;font-weight:600}
.step p{margin:0;color:var(--muted);font-size:.92rem}
@media (max-width:760px){.steps{grid-template-columns:1fr;gap:1.8rem}.steps::before{display:none}}

/* -------- Models / car cards (pop-card) -------- */
.cars{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.car{
  display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  color:var(--ink);transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.car:hover{border-color:var(--ink);transform:translateY(-3px);box-shadow:0 16px 30px rgba(0,0,0,.06);text-decoration:none}
.car .car-img{
  aspect-ratio:4/3;overflow:hidden;
  background:linear-gradient(180deg,#F4F0E9 0%,#ECE6DB 100%);
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.car .car-img img{width:100%;height:100%;object-fit:contain;padding:.6rem;transition:transform var(--dur) var(--ease)}
.car:hover .car-img img{transform:scale(1.04)}
.car .car-body{padding:1rem 1.2rem}
.car .car-brand{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.car .car-name{font-family:var(--ff-serif);font-weight:500;font-size:1.1rem;margin:.18rem 0 .3rem;letter-spacing:-.01em}
.car .car-meta{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.3rem}
.car .car-meta svg{transition:transform var(--dur) var(--ease)}
.car:hover .car-meta svg{transform:translateX(3px)}

/* -------- Brands (cells) -------- */
.brands-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.6rem}
.brand-cell{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;
  padding:1.2rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  min-height:120px;text-align:center;font-weight:500;color:var(--ink);
  transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.brand-cell:hover{border-color:var(--ink);transform:translateY(-2px);text-decoration:none}
.brand-cell img{max-height:46px;max-width:90px;object-fit:contain;filter:grayscale(.25);transition:filter var(--dur) var(--ease)}
.brand-cell:hover img{filter:none}
.brand-cell .name{font-size:.86rem;color:var(--muted)}

/* -------- Materials strip -------- */
.materials{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.6rem}
.material{
  position:relative;aspect-ratio:1/1;border-radius:var(--r);overflow:hidden;
  background:var(--paper);border:1px solid var(--line);cursor:pointer;
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.material:hover{transform:translateY(-3px);border-color:var(--ink)}
.material img{width:100%;height:100%;object-fit:cover}
.material .mat-name{
  position:absolute;inset:auto 0 0 0;padding:.9rem .75rem .65rem;
  background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.8) 100%);
  color:#fff;font-size:.77rem;font-weight:500;line-height:1.3;
}

/* -------- Page head -------- */
.page-head{padding:2.8rem 0 1.6rem;background:var(--paper);border-bottom:1px solid var(--line)}
.page-head.center{text-align:center}
.crumbs{color:var(--muted);font-size:.84rem;margin-bottom:.6rem;display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--ink)}
.crumbs>*+*::before{content:"›";opacity:.45;margin-right:.35rem}
.page-head h1{margin:.1rem 0 .5rem}
.page-head .lead{font-size:1.08rem}
.brand-head-row{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.brand-head-row .brand-logo{
  height:68px;width:auto;max-width:140px;
  background:#fff;padding:.45rem .7rem;border-radius:var(--r);border:1px solid var(--line);object-fit:contain;
}

/* -------- Meta row (badges/pills) -------- */
.meta-row{list-style:none;padding:0;margin:.9rem 0 0;display:flex;gap:.5rem;flex-wrap:wrap}
.meta-row li{
  display:inline-flex;align-items:center;gap:.4rem;
  background:#fff;border:1px solid var(--line);border-radius:999px;padding:.42rem .9rem;font-size:.85rem;font-weight:500;color:var(--ink);
}
.meta-row li svg{color:var(--tan-2)}

/* -------- Two-column content -------- */
.two-col{display:grid;grid-template-columns:1fr 320px;gap:2.5rem}
@media (max-width:900px){.two-col{grid-template-columns:1fr;gap:2rem}}

.rich{line-height:1.75;color:var(--body)}
.rich h2{margin-top:2rem;color:var(--ink)}
.rich h3{margin-top:1.6rem;color:var(--ink)}
.rich ul{padding-left:1.2rem}
.rich ul li{margin-bottom:.3rem}
.rich a{color:var(--tan-2);border-bottom:1px solid var(--tan-2)}
.rich a:hover{color:var(--ink);border-bottom-color:var(--ink)}

/* Side CTA (contextual) */
.side-cta{position:sticky;top:92px}
.side-cta .box{
  background:var(--ink);color:#E6E3DD;
  border-radius:var(--r-lg);padding:1.7rem;
}
.side-cta .box h3{color:#fff;font-family:var(--ff-serif);font-weight:500;font-size:1.2rem}
.side-cta .box p{color:#B5B1A7;margin:.3rem 0 1.1rem}
.side-cta .box .btn-primary{background:#fff;color:var(--ink);width:100%}
.side-cta .box .btn-primary:hover{background:var(--tan);color:#fff}
.side-cta .box hr{border:0;border-top:1px solid #242425;margin:1.1rem 0}
.side-cta .box .line{display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem;margin:.5rem 0;color:#B5B1A7}
.side-cta .box .line svg{color:#7E7D72;flex-shrink:0;margin-top:.2rem}
.side-cta .box .line a{color:#fff;border-bottom:1px dashed rgba(255,255,255,.25)}
.side-cta .box .line a:hover{color:#fff;border-bottom-color:#fff}
.side-cta .box .line strong{color:#fff}

/* -------- Service list rows (simpler) -------- */
.service-list{display:grid;gap:.55rem}
.service-row{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:1rem 1.25rem;color:var(--ink);
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.service-row:hover{border-color:var(--ink);text-decoration:none;transform:translateX(3px)}
.service-row .dur{background:var(--tan-faint);color:var(--tan-2);border-radius:999px;padding:.28rem .8rem;font-size:.78rem;font-weight:600;white-space:nowrap}

/* -------- FAQ -------- */
.faq{display:grid;gap:.5rem}
.faq details{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:1rem 1.25rem;transition:border-color var(--dur) var(--ease);
}
.faq details[open]{border-color:var(--ink-3)}
.faq summary{font-weight:600;cursor:pointer;list-style:none;padding-right:1.8rem;position:relative;color:var(--ink)}
.faq summary::after{
  content:"+";position:absolute;right:.2rem;top:50%;transform:translateY(-50%);
  font-weight:300;font-size:1.5rem;line-height:1;color:var(--muted);transition:transform var(--dur) var(--ease),color var(--dur) var(--ease);
}
.faq details[open] summary::after{content:"−";color:var(--ink);transform:translateY(-50%) rotate(0deg)}
.faq details>div{margin-top:.7rem;color:var(--body);line-height:1.7}

/* -------- Vehicle tree (brand page models) -------- */
.vtree{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.vtree-head{padding:1rem 1.2rem;border-bottom:1px solid var(--line);background:var(--soft)}
.vtree-search{position:relative;display:block}
.vtree-search input{width:100%;padding:.8rem 1rem .8rem 2.7rem;border:1px solid var(--line-2);border-radius:var(--r-sm);background:#fff;font:inherit}
.vtree-search input:focus{outline:0;border-color:var(--tan);box-shadow:0 0 0 3px rgba(160,114,62,.18)}
.vtree-search::before{content:"";position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:16px;height:16px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'><circle cx='11' cy='11' r='8'/><path d='M21 21l-4.35-4.35'/></svg>") center/contain no-repeat}
.vtree-body{padding:.4rem}
.vtree-node details{border-bottom:1px solid var(--line)}
.vtree-node details:last-child{border-bottom:0}
.vtree-node summary{list-style:none;display:flex;align-items:center;gap:.8rem;padding:.75rem .85rem;cursor:pointer;font-weight:500;border-radius:var(--r-sm);transition:background .12s}
.vtree-node summary:hover{background:var(--soft)}
.vtree-node summary::before{content:"›";color:var(--muted);transition:transform var(--dur) var(--ease);display:inline-block;width:14px;font-size:1.2rem;line-height:1}
.vtree-node details[open] summary::before{transform:rotate(90deg);color:var(--ink)}
.vtree-node .vtree-img{width:36px;height:36px;border-radius:6px;object-fit:contain;background:var(--paper);padding:3px;flex-shrink:0}
.vtree-node .v-count{margin-left:auto;font-size:.78rem;color:var(--muted);font-weight:500}
.vtree-child{padding:.2rem 0 .5rem 2.2rem;display:grid;gap:.1rem}
.vtree-leaf{display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:var(--r-sm);color:var(--ink);font-weight:500;font-size:.92rem;transition:background .12s}
.vtree-leaf:hover{background:var(--soft);text-decoration:none}
.vtree-leaf img{width:28px;height:28px;border-radius:4px;object-fit:contain;background:var(--paper)}
.vtree-empty{padding:2rem;text-align:center;color:var(--muted)}
.vtree-node[hidden],.vtree-leaf[hidden]{display:none!important}

/* -------- CTA band -------- */
.cta-band{
  background:var(--dark);color:#E6E3DD;padding:3.2rem 0;
  position:relative;overflow:hidden;
  background-image:
    radial-gradient(50% 60% at 85% 30%, rgba(160,114,62,.14), transparent 60%),
    linear-gradient(180deg,#0E0E10 0%, #161618 100%);
}
.cta-row{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;position:relative;z-index:1}
.cta-row h2{color:#fff;margin:0 0 .3rem}
.cta-row p{color:#B5B1A7;margin:0;max-width:56ch}
.cta-row .btn-primary{background:#fff;color:var(--ink)}
.cta-row .btn-primary:hover{background:var(--tan);color:#fff}

/* -------- Branches (public contact/branches page) -------- */
.branches-layout{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}
.branch-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  display:flex;flex-direction:column;transition:border-color var(--dur) var(--ease),transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.branch-card:hover{border-color:var(--ink);transform:translateY(-3px);box-shadow:0 20px 40px rgba(0,0,0,.06)}
.branch-card .bc-img{aspect-ratio:16/10;background:var(--paper);overflow:hidden}
.branch-card .bc-img img{width:100%;height:100%;object-fit:cover}
.branch-card .bc-body{padding:1.4rem 1.5rem 1.5rem}
.branch-card h3{font-family:var(--ff-serif);font-weight:500;font-size:1.3rem;margin:0 0 .4rem}
.branch-card .bc-meta{color:var(--muted);font-size:.88rem;display:flex;align-items:center;gap:.35rem;margin:0 0 .9rem}
.branch-card .bc-meta svg{color:var(--tan-2)}
.branch-card p{margin:.3rem 0;color:var(--body);font-size:.92rem}
.branch-card .bc-actions{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:1rem}

/* -------- Footer (very clean) -------- */
.site-footer{
  background:var(--dark);color:#C4C1B7;
  padding:3.5rem 0 1rem;margin-top:0;
}
.foot-top{
  display:grid;grid-template-columns:1.6fr repeat(3,1fr);gap:2.4rem;
  padding-bottom:2.2rem;border-bottom:1px solid #202023;
}
.foot-brand{display:flex;gap:.8rem;margin-bottom:.9rem;align-items:center}
.foot-brand img{width:44px;height:44px;background:#fff;border-radius:10px;padding:5px}
.foot-brand strong{font-family:var(--ff-serif);font-weight:500;color:#fff;font-size:1.15rem;display:block;line-height:1.15}
.foot-brand span{display:block;font-size:.68rem;color:#7E7D72;margin-top:.2rem;text-transform:uppercase;letter-spacing:.14em}
.foot-desc{font-size:.9rem;line-height:1.65;color:#9C9A8F;max-width:34ch;margin:0 0 1rem}
.foot-socials{display:flex;gap:.4rem}
.foot-socials a{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:#1A1A1C;color:#fff;border:1px solid #242425;
  transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.foot-socials a:hover{background:var(--tan);border-color:var(--tan);transform:translateY(-2px)}

.foot-col h4{color:#fff;font-size:.78rem;font-weight:600;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.18em}
.foot-col ul{list-style:none;padding:0;margin:0;display:grid;gap:.45rem}
.foot-col a{color:#9C9A8F;font-size:.92rem;transition:color var(--dur) var(--ease)}
.foot-col a:hover{color:#fff}

.foot-branch-card{margin-bottom:1.2rem}
.foot-branch-card h5{color:#fff;font-size:.92rem;font-weight:600;margin:0 0 .4rem}
.foot-branch-card .bline{display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;color:#9C9A8F;margin:.25rem 0}
.foot-branch-card .bline svg{color:#7E7D72;flex-shrink:0;margin-top:.2rem}
.foot-branch-card .bactions{display:flex;gap:.3rem;margin-top:.6rem;flex-wrap:wrap}
.foot-branch-card .bactions a{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.38rem .7rem;border-radius:999px;
  background:#1A1A1C;border:1px solid #242425;
  font-size:.78rem;font-weight:500;color:#D1CEC4;
  transition:all var(--dur) var(--ease);
}
.foot-branch-card .bactions a:hover{background:var(--tan);border-color:var(--tan);color:#fff}
.foot-branch-card .bactions .wa{background:var(--wa);color:#06301b;border-color:transparent}
.foot-branch-card .bactions .wa:hover{background:#1cb859;color:#06301b}

.foot-bot{
  display:flex;justify-content:space-between;gap:1rem;padding-top:1rem;margin-top:1rem;
  border-top:1px solid #202023;color:#7E7D72;font-size:.82rem;flex-wrap:wrap;
}

@media (max-width:960px){.foot-top{grid-template-columns:1fr 1fr;gap:1.8rem}}
@media (max-width:600px){.foot-top{grid-template-columns:1fr}}

/* -------- WhatsApp floating -------- */
.wa-float{
  position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;
  background:var(--wa);color:#fff;display:grid;place-items:center;z-index:60;
  box-shadow:0 14px 28px rgba(37,211,102,.36),0 4px 10px rgba(37,211,102,.24);
  transition:transform .18s var(--ease);
}
.wa-float:hover{transform:scale(1.08)}
.wa-float::before{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  border:2px solid rgba(37,211,102,.4);
  animation:pulse 2.4s var(--ease) infinite;
}
@keyframes pulse{0%{transform:scale(.94);opacity:0}20%{opacity:1}100%{transform:scale(1.24);opacity:0}}
@media (prefers-reduced-motion:reduce){.wa-float::before{animation:none}}

/* -------- Lightbox v2 -------- */
.lb{
  position:fixed;inset:0;z-index:200;
  background:rgba(10,10,10,.94);
  display:grid;place-items:center;padding:1rem;
  animation:lb-in .2s var(--ease);
  -webkit-user-select:none;user-select:none;
}
.lb-stage{position:relative;max-width:100%;max-height:92vh;display:flex;align-items:center;justify-content:center}
.lb-img{max-width:100%;max-height:92vh;border-radius:var(--r);box-shadow:0 30px 60px rgba(0,0,0,.6);display:block;transition:opacity .22s var(--ease)}
.lb-img.swap{opacity:0}
.lb-close,.lb-prev,.lb-next{
  position:absolute;display:grid;place-items:center;
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15);
  cursor:pointer;transition:background var(--dur) var(--ease),transform var(--dur) var(--ease);
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.18);transform:scale(1.05)}
.lb-close{top:20px;right:20px;font-size:1.5rem;font-weight:300}
.lb-prev{left:20px;top:50%;transform:translateY(-50%)}
.lb-prev:hover{transform:translateY(-50%) scale(1.05)}
.lb-next{right:20px;top:50%;transform:translateY(-50%)}
.lb-next:hover{transform:translateY(-50%) scale(1.05)}
.lb-count{
  position:absolute;top:24px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.5);color:#fff;padding:.4rem 1rem;border-radius:999px;
  font-size:.82rem;font-weight:500;letter-spacing:.02em;
  border:1px solid rgba(255,255,255,.1);
}
.lb-caption{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,.6);color:#fff;padding:.5rem 1rem;border-radius:var(--r-sm);
  font-size:.88rem;max-width:80vw;text-align:center;
  border:1px solid rgba(255,255,255,.08);
}
@keyframes lb-in{from{opacity:0}to{opacity:1}}
@media (max-width:700px){
  .lb-close{top:12px;right:12px;width:40px;height:40px}
  .lb-prev{left:8px;width:40px;height:40px}
  .lb-next{right:8px;width:40px;height:40px}
  .lb-count{top:16px;font-size:.76rem;padding:.32rem .8rem}
  .lb-caption{bottom:16px;font-size:.82rem}
}

/* -------- Maintenance page-specific (fall-through styles) -------- */
.maint-wrap{min-height:100vh;display:grid;place-items:center;padding:2rem 1rem;background:var(--dark);color:#fff}

/* -------- Misc utility -------- */
.text-center{text-align:center}
.muted{color:var(--muted)}
hr.ornament{border:0;height:1px;background:linear-gradient(90deg,transparent,var(--line-2),transparent);margin:3rem auto;max-width:400px}

/* Accessibility: focus */
:focus-visible{outline:2px solid var(--tan);outline-offset:2px;border-radius:4px}

/* ===================================================================
   Filter Chips — Apple-style sticky breadcrumb (Faz 2)
   =================================================================== */
.filter-chips{
  position:sticky;top:68px;z-index:45;
  background:rgba(253,252,250,.92);
  -webkit-backdrop-filter:saturate(160%) blur(12px);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--line);
  padding:.55rem 0;
}
.chips-row{
  display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;
}
.chip-home{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:999px;
  color:var(--muted);background:transparent;
  flex-shrink:0;transition:color var(--dur) var(--ease),background var(--dur) var(--ease);
}
.chip-home:hover{color:var(--ink);background:rgba(0,0,0,.05)}
.chip{
  display:inline-flex;align-items:stretch;
  background:#fff;border:1px solid var(--line-2);
  border-radius:999px;overflow:hidden;
  transition:border-color var(--dur) var(--ease),background var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
  font-size:.86rem;line-height:1;
}
.chip:hover{border-color:var(--ink);box-shadow:0 1px 6px rgba(0,0,0,.06)}
.chip-body{
  padding:.45rem .85rem;color:var(--ink);font-weight:500;text-decoration:none;
  display:inline-flex;align-items:center;
}
.chip-body:hover{color:var(--ink)}
.chip-current{background:var(--ink);border-color:var(--ink);box-shadow:0 1px 6px rgba(0,0,0,.18)}
.chip-current .chip-body{color:#fff}
.chip-current:hover{border-color:var(--ink)}
.chip-remove{
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 .55rem;color:var(--muted-2);text-decoration:none;
  font-size:1rem;line-height:1;border-left:1px solid var(--line);
  transition:color var(--dur) var(--ease),background var(--dur) var(--ease);
  font-family:var(--ff-sans);
}
.chip-remove:hover{color:var(--ink);background:rgba(0,0,0,.05)}
.chip-sep{color:var(--muted-2);font-size:1rem;user-select:none;line-height:1}

@media (max-width:700px){
  .filter-chips{padding:.45rem 0}
  .chip{font-size:.78rem}
  .chip-body{padding:.4rem .7rem}
  .chip-remove{padding:0 .45rem}
  .chips-row{gap:.3rem}
}
@media (max-width:520px){
  .chips-row{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}
  .chips-row::-webkit-scrollbar{display:none}
  .chip,.chip-home,.chip-sep{flex-shrink:0}
}

/* Chip bar is inside <main>; reduce top padding of page-head right after it */
.filter-chips + .page-head{padding-top:1rem}

/* ===================================================================
   Service-card meta (Faz 4) — small "duration · garanti" line
   =================================================================== */
.svc .svc-meta{
  display:block;
  font-size:.74rem;
  color:var(--muted);
  margin:.5rem 0 0;
  padding-top:.5rem;
  border-top:1px solid var(--line);
  line-height:1.3;
}
.svc .svc-meta svg{vertical-align:-.15em;margin-right:.15rem}
.svc.has-img .svc-meta{color:rgba(255,255,255,.78);border-top-color:rgba(255,255,255,.18)}

/* ===================================================================
   Quick Facts (Tier 4) — AI-friendly structured summary block (Faz 3)
   =================================================================== */
.quick-facts{padding:1.6rem 0;background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.qf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem 1.4rem;margin:0;padding:0}
.qf-item{margin:0;padding:0}
.qf-item dt{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 .15rem}
.qf-item dd{margin:0;font-size:.95rem;color:var(--ink);line-height:1.4;font-weight:500}
@media (max-width:600px){
  .quick-facts{padding:1.2rem 0}
  .qf-grid{grid-template-columns:repeat(2,1fr);gap:.9rem 1rem}
  .qf-item dd{font-size:.88rem}
}
