/* ============================================================
   Auckland Valuable Cars (AVC) — global styles
   Direction 1b: bold editorial. Archivo + serif logo.
   ============================================================ */

:root{
  --ink:#013440;      /* primary dark */
  --navy:#234D68;     /* secondary */
  --slate:#566B81;    /* muted */
  --coral:#F66C89;    /* CTA / accent */
  --pink:#F27798;     /* secondary accent */
  --paper:#f4f1ec;    /* warm off-white */
  --line:rgba(1,52,64,.12);
  --line-d:rgba(255,255,255,.15);
  --on-dark:#bcd0d3;
  --on-dark-soft:#9fb6b9;
  --shadow:0 18px 40px -22px rgba(1,52,64,.55);
  --r:10px;
  --wrap:1200px;
}

/* ---------- reset ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{
  margin:0;background:#fff;color:var(--ink);
  font-family:'Archivo',system-ui,-apple-system,sans-serif;
  font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}
.serif{font-family:Georgia,'Times New Roman',serif}
h1,h2,h3,h4{margin:0;font-weight:900;letter-spacing:-.02em;line-height:1.02;text-wrap:balance}
p{margin:0;text-wrap:pretty}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px}
.lbl{font-weight:800;font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.coral{color:var(--coral)}
.only-zh{display:none}
html[lang="zh"] .only-en{display:none}
html[lang="zh"] .only-zh{display:revert}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 24px;border-radius:8px;border:none;
  font-weight:800;font-size:14px;letter-spacing:.01em;
  transition:transform .15s ease, background .15s ease, color .15s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-coral{background:var(--coral);color:#fff}
.btn-coral:hover{background:var(--pink)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--navy)}
.btn-line{background:transparent;border:1.6px solid currentColor}
.btn-line.on-dark{color:#fff}
.btn-block{justify-content:center;width:100%}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-head{position:sticky;top:0;z-index:60;background:var(--ink);color:#fff}
.nav{display:flex;align-items:center;gap:26px;min-height:70px;max-width:none}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{
  width:44px;height:44px;border-radius:9px;background:var(--coral);
  display:flex;align-items:center;justify-content:center;flex:none;
}
.brand .mark span{color:var(--ink);font-weight:700;font-size:18px}
.brand b{display:block;font-weight:900;font-size:14px;letter-spacing:.06em;line-height:1.1}
.brand small{display:block;font-size:9.5px;letter-spacing:.2em;color:var(--on-dark);font-weight:700}
.nav-links{display:flex;gap:22px;margin-left:8px}
.nav-links a{font-weight:700;font-size:14px;color:var(--on-dark);padding:6px 0;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}
.nav-links a:hover,.nav-links a.active{color:#fff;border-color:var(--coral)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:8px}
/* header contact icon links */
.nav-ico{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;transition:background .15s}
.nav-ico:hover{background:rgba(255,255,255,.12)}
.nav-ico svg{width:18px;height:18px;flex:none}
.lang-toggle{display:flex;border:1px solid var(--line-d);border-radius:30px;overflow:hidden}
.lang-toggle button{background:transparent;color:var(--on-dark);border:none;padding:5px 11px;font-weight:800;font-size:11px}
.lang-toggle button.on{background:var(--coral);color:#fff}
.nav-burger{display:none;background:transparent;border:none;color:#fff;flex-direction:column;gap:5px;padding:8px}
.nav-burger span{width:24px;height:2.5px;background:#fff;border-radius:2px;transition:.2s}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{background:var(--ink);color:#fff}
.hero-grid{display:grid;grid-template-columns:1fr 1.8fr;align-items:stretch;gap:56px}
.hero-copy{padding:36px 0;display:flex;flex-direction:column;justify-content:center;max-width:560px}
.hero h1{font-size:72px;letter-spacing:-.035em;line-height:.92}
.hero h1 .stk{display:block;white-space:nowrap;line-height:.92;margin:-.04em 0}
.hero p{color:var(--on-dark);font-size:17px;line-height:1.55;margin:22px 0 30px;max-width:420px}
/* hero search bar */
.hero-search{display:flex;align-items:stretch;margin-top:4px}
.hero-search-input{flex:1;padding:14px 18px;border:none;border-radius:8px 0 0 8px;font-family:inherit;font-size:15px;font-weight:600;color:var(--ink);background:#fff;outline:none}
.hero-search-input::placeholder{color:var(--slate);font-weight:500}
.hero-search-btn{background:var(--coral);color:#fff;border:none;border-radius:0 8px 8px 0;padding:0 20px;cursor:pointer;display:flex;align-items:center;transition:background .15s}
.hero-search-btn:hover{background:var(--pink)}
/* hero media – carousel */
.hero-media{position:relative;overflow:hidden;height:100%;align-self:stretch}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;object-position:center bottom}

/* ============================================================
   BODY TYPES (big words)
   ============================================================ */
.bodytypes{border-bottom:none;background:var(--paper)}
.bodytypes-row{display:flex;flex-wrap:wrap;gap:6px 30px;padding:20px 0;align-items:baseline}
.bt-word{
  font-weight:900;font-size:clamp(26px,3.4vw,38px);letter-spacing:-.03em;
  color:var(--slate);transition:color .15s ease;
}
a.bt-word:hover,a.bt-word:focus,.bt-word.on{color:var(--coral)}

/* ============================================================
   SECTION + CARDS
   ============================================================ */
.section{padding:56px 0}
.sec-head{display:flex;align-items:flex-end;gap:18px;margin-bottom:26px}
.sec-head h2{font-size:clamp(28px,3.6vw,40px)}
.sec-head .more{margin-left:auto;font-weight:800;font-size:14px;color:var(--navy);white-space:nowrap}
.sec-head .more:hover{color:var(--coral)}
.sec-head .lead{margin-top:14px;max-width:620px;color:var(--navy);font-size:15.5px;line-height:1.6;font-weight:500}

.pick-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:18px}
.pick-actions{margin-top:24px;max-width:320px}

/* car card */
.card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .media{position:relative;aspect-ratio:4/3;background:#e7ecee}
.card .media img{width:100%;height:100%;object-fit:cover}
.card .tag{position:absolute;top:10px;left:10px;background:var(--ink);color:#fff;font-weight:800;font-size:11px;letter-spacing:.04em;padding:5px 10px;border-radius:6px}
.card .tag.fuel{background:var(--coral)}
.card-body{padding:15px 16px 17px;display:flex;flex-direction:column;flex:1}
.card .yr{font-weight:800;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--slate)}
.card .nm{font-weight:900;font-size:18px;margin:3px 0 0;letter-spacing:-.01em}
.card .price{font-weight:900;font-size:24px;margin-top:10px;letter-spacing:-.02em}
.card .price small{font-size:11px;font-weight:700;color:var(--slate);margin-left:5px;letter-spacing:0}
.card .specs{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.card .specs span{font-weight:700;font-size:11px;color:var(--navy);background:rgba(86,107,129,.1);padding:4px 9px;border-radius:6px}
.card .go{margin-top:14px;font-weight:800;font-size:13px;color:var(--coral)}

/* big featured card */
.pick-main .media{aspect-ratio:5/2}
.pick-main .nm{font-size:24px}
.pick-main .price{font-size:30px}

/* horizontal mini card */
.card-h{flex-direction:row;align-items:stretch}
.card-h .media{width:150px;flex:none;aspect-ratio:auto}
.card-h .card-body{padding:14px 16px}
.card-h .nm{font-size:16px}
.card-h .price{font-size:19px;margin-top:6px}

/* ============================================================
   VISIT / "come say hi"  (shorter)
   ============================================================ */
.visit{display:grid;grid-template-columns:6fr 4fr}
.visit-copy{background:var(--pink);color:var(--ink);padding:12px 0}
.visit-copy .inner{max-width:560px;margin-left:max(0px, calc((100vw - var(--wrap)) / 2));margin-right:auto;padding:0 28px}
.visit-copy h3{font-size:clamp(24px,2.8vw,30px);margin:0 0 4px;line-height:1.2}
.visit-info-row{display:flex;gap:40px;margin:8px 0 0}
.visit-hours{display:flex;flex-direction:column;gap:5px;font-weight:700;font-size:14.5px}
.visit-hours div{display:flex;gap:8px}
.visit-hours b{font-weight:900}
.visit-copy .addr{font-weight:900;font-size:15px;border-bottom:none;display:inline-flex;align-items:center;gap:6px;padding-bottom:1px}
.visit-copy .addr svg{width:16px;height:16px;flex:none}
.visit-contact{display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.visit-contact > a{font-weight:800;font-size:14.5px;color:var(--ink);border-bottom:none;display:inline-flex;align-items:center;gap:6px}
.visit-contact > a svg{width:16px;height:16px;flex:none}

/* ---------- marquee ---------- */
.marquee{background:var(--coral);color:var(--ink);overflow:hidden;white-space:nowrap;padding:0}
.marquee__track{display:flex;align-items:center;animation:marquee 28s linear infinite;width:max-content;gap:26px}
.marquee__track .seg{display:flex;align-items:center;flex-shrink:0;padding:13px 0;gap:26px}
.marquee__track .seg span{font-weight:900;font-size:15px;letter-spacing:.04em}
.marquee__track .seg b{color:#fff;font-size:13px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}
.visit-contact .vc-social{display:flex;gap:8px}
.visit-contact .vc-social a{width:34px;height:34px;border-radius:8px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.visit-contact .vc-social a:hover{background:var(--coral);color:var(--ink)}
.visit-map{height:100%;min-height:200px;background:#e7ecee}
.visit-map iframe{width:100%;height:100%;min-height:200px;border:0;display:block}

/* ============================================================
   FOOTER
   ============================================================ */
.site-foot{background:var(--ink);color:var(--on-dark-soft)}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding:52px 0 40px}
.foot-brand .mark{width:48px;height:48px;border-radius:10px;background:var(--coral);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.foot-brand .mark span{color:var(--ink);font-weight:700;font-size:20px}
.foot-brand p{font-size:13.5px;line-height:1.6;max-width:260px;color:var(--on-dark)}
.foot-col h4{color:#fff;font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:14px;font-weight:800}
.foot-col a,.foot-col p{display:block;font-size:14px;font-weight:600;color:var(--on-dark);margin-bottom:9px;line-height:1.4}
.foot-col a:hover{color:var(--coral)}
.foot-social{display:flex;gap:9px;margin-top:6px}
.foot-social a{width:28px;height:28px;border-radius:6px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:11px;margin:0}
.foot-social a:hover{background:var(--coral);color:var(--ink)}
.foot-bot{border-top:1px solid var(--line-d);padding-top:8px;padding-bottom:8px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;max-width:none}
.foot-bot .dim{color:var(--slate)}

/* ============================================================
   STOCK PAGE
   ============================================================ */
.page-head{background:var(--ink);color:#fff;padding:12px 0 8px}
.page-head h1{font-size:clamp(32px,4.5vw,52px)}
.page-head p{color:var(--on-dark);margin-top:10px;font-size:16px}

.filterbar{position:sticky;top:70px;z-index:50;background:var(--paper);border-bottom:1px solid var(--line);padding:16px 0}
.filterbar .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.search{flex:1;min-width:200px;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:0 12px}
.search input{flex:1;border:none;outline:none;padding:12px 4px;font-weight:600;font-size:14px;background:transparent;color:var(--ink)}
.sel{background:#fff;border:1px solid var(--line);border-radius:8px;padding:11px 12px;font-weight:700;font-size:13.5px;color:var(--ink)}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:13px}
.chip{
  border:none;border-radius:30px;padding:9px 16px;font-weight:800;font-size:13px;
  background:var(--ink);color:#fff;transition:background .15s,color .15s,transform .12s;
}
.chip:hover{transform:translateY(-1px)}
.chip.on{background:var(--coral);color:#fff}                 /* selected → pink */
.chip.is-empty{background:rgba(86,107,129,.16);color:#9aa8b4;pointer-events:none;cursor:default} /* no cars → grey */
.chip .n{opacity:.7;margin-left:5px;font-size:11px}

.stock-meta{display:flex;align-items:center;gap:12px;padding:24px 0 6px}
.stock-meta .count{font-weight:900;font-size:18px}
.stock-meta .count .dim{color:var(--slate);font-weight:700}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding:18px 0 64px}
.empty{padding:60px 0;text-align:center;color:var(--slate)}
.empty b{display:block;color:var(--ink);font-size:20px;font-weight:900;margin-bottom:6px}

/* ============================================================
   VEHICLE DETAIL
   ============================================================ */
.crumbs{padding:18px 0;font-size:13px;font-weight:700;color:var(--slate)}
.crumbs a:hover{color:var(--coral)}
.detail{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;padding:8px 0 60px;align-items:start}
.gal-main-wrap{position:relative}
.gallery .main{aspect-ratio:16/10;border-radius:14px;overflow:hidden;background:#e7ecee;border:1px solid var(--line)}
.gallery .main img{width:100%;height:100%;object-fit:cover}
.gal-arr{position:absolute;top:50%;transform:translateY(-50%);background:rgba(1,52,64,.5);color:#fff;border:none;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background .15s}
.gal-arr:hover{background:rgba(1,52,64,.75)}
.gal-arr--prev{left:10px}
.gal-arr--next{right:10px}
.thumbs-wrap{margin-top:10px}
.gallery .thumbs{display:flex;gap:10px}
.gallery .thumbs button{flex:1 1 0;min-width:80px;aspect-ratio:4/3;border-radius:9px;overflow:hidden;border:2px solid transparent;background:#e7ecee;padding:0}
.gallery .thumbs button.on{border-color:var(--coral)}
.gallery .thumbs img{width:100%;height:100%;object-fit:cover}
.thumbs-more{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin-top:8px}
.thumbs-more-btn{background:rgba(86,107,129,.12);color:var(--ink);border:none;border-radius:6px;padding:4px 10px;font-weight:700;font-size:13px;cursor:pointer}
.thumbs-more-btn:disabled{opacity:.3;cursor:default}
.thumbs-more #thumbs-label{font-weight:700;font-size:12px;color:var(--slate);min-width:42px;text-align:center}

.dpanel{position:sticky;top:90px;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.dpanel .top{padding:22px 22px 20px;border-bottom:1px solid var(--line)}
.dpanel .yr{font-weight:800;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--slate)}
.dpanel h1{font-size:30px;margin:5px 0 0}
.dpanel .price{font-size:38px;font-weight:900;letter-spacing:-.02em;margin-top:14px}
.dpanel .price small{font-size:13px;font-weight:700;color:var(--slate);margin-left:6px}
.dpanel .cta{padding:18px 22px;display:flex;flex-direction:column;gap:10px;background:var(--paper)}
.spec-table{padding:6px 22px 18px}
.spec-table div{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.spec-table div:last-child{border-bottom:none}
.spec-table .k{color:var(--slate);font-weight:600}
.spec-table .v{font-weight:800}
.dblurb{padding:8px 0 0}
.dblurb h3{font-size:20px;margin-bottom:10px}
.dblurb p{color:var(--navy);font-size:15.5px;line-height:1.6;max-width:620px}

/* ============================================================
   ABOUT
   ============================================================ */
.about-hero{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.about-hero .copy{padding:56px 40px 56px 0;max-width:560px;margin-left:auto}
.about-hero h1{font-size:clamp(34px,4.5vw,54px)}
.about-hero p{color:var(--navy);font-size:16px;line-height:1.6;margin-top:18px}
.about-hero .media{min-height:360px;background:#e7ecee}
.about-hero .media img{width:100%;height:100%;object-fit:cover}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding-top:8px}
.value{border:1px solid var(--line);border-radius:12px;padding:24px 22px}
.value .num{font-weight:900;font-size:13px;color:var(--coral);letter-spacing:.1em}
.value h3{font-size:20px;margin:10px 0 8px}
.value p{color:var(--navy);font-size:14.5px;line-height:1.55}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden}
.contact-info{padding:36px 32px;display:flex;flex-direction:column;gap:22px}
.ci-item .lbl{color:var(--coral);margin-bottom:5px;display:flex;align-items:center;gap:6px}
.ci-item .lbl svg{width:14px;height:14px;flex:none;color:var(--coral)}
.ci-item a,.ci-item p{font-weight:800;font-size:18px;color:var(--ink)}
.ci-item .sub{font-weight:600;font-size:13.5px;color:var(--slate);margin-top:3px}
.contact-map{min-height:380px;background:#e7ecee}
.contact-map iframe{width:100%;height:100%;min-height:380px;border:0}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:960px){
  .pick-row{grid-template-columns:repeat(2,1fr)}
  .visit{grid-template-columns:1fr}
  .visit-copy .inner{margin:0;padding:0 28px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .detail{grid-template-columns:1fr}
  .dpanel{position:static}
  .about-hero{grid-template-columns:1fr}
  .about-hero .copy{padding:40px 28px;margin:0}
  .about-hero .media{min-height:240px}
  .values{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .hero-grid{grid-template-columns:1fr}
  .hero-copy{padding:40px 0 36px}
  .hero h1{font-size:48px;line-height:.9}
  .hero-media{min-height:280px}
  .hero-search-input{font-size:14px}
}
@media (max-width:760px){
  .nav-links{display:none}
  .nav-ico.nav-ico--phone{display:none}
  .nav-burger{display:flex}
  .site-head.open .nav-links{
    display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;
    background:var(--ink);padding:14px 28px 22px;gap:6px;border-top:1px solid var(--line-d);
  }
  .site-head.open .nav-links a{padding:11px 0;font-size:16px}
  .filterbar{top:70px}
}
@media (max-width:560px){
  .wrap{padding:0 18px}
  .grid{grid-template-columns:1fr}
  .card-h .media{width:120px}
  .foot-top{grid-template-columns:1fr}
  .hero h1{font-size:46px;line-height:.9}
}
