/* ============================================================
   HONGDA AMERICA — Homepage redesign (0619)
   Aesthetic: classic North-American manufacturer — steady,
   mature, trustworthy. Serif display + industrial grotesque.
   Three palettes selectable via <body data-theme="...">.
   ============================================================ */

/* ---------- palettes ---------- */
:root{
  --radius:4px;
  --ease:cubic-bezier(.22,.61,.26,1);
  --maxw:1280px;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:"Archivo",system-ui,-apple-system,sans-serif;
  --ok:#1f9d57;
  --paypal:#ffc439;
}

/* A — deep steel-navy + restrained brick red */
[data-theme="navy"]{
  --ink:#0c1923; --ink-soft:#14283a; --ink-deep:#081019;
  --surface:#eef1f5; --surface-2:#e3e9ef; --surface-3:#f7f9fb;
  --line:#d6dde5; --line-soft:#e4e9ee; --card:#ffffff;
  --text:#0c1923; --text-2:#34424e; --muted:#5d6c78;
  --accent:#c0392b; --accent-deep:#9b2a1e; --accent-soft:rgba(192,57,43,.10);
  --gold:#bd9748;
  --on-dark:#e9eef3; --on-dark-2:#aeb9c4; --on-dark-mut:#7f8c98;
  --line-dark:rgba(255,255,255,.12);
  --hero-overlay:linear-gradient(95deg,rgba(7,15,23,.90) 0%,rgba(7,15,23,.72) 38%,rgba(7,15,23,.30) 70%,rgba(7,15,23,.12) 100%),linear-gradient(0deg,rgba(7,15,23,.86) 0%,rgba(7,15,23,0) 46%);
  --grad-deep:linear-gradient(155deg,#14283a 0%,#0a151f 100%);
}
/* B — brand red led, refined */
[data-theme="red"]{
  --ink:#2a0e0c; --ink-soft:#3d1512; --ink-deep:#220a08;
  --surface:#f7f3f1; --surface-2:#efe7e3; --surface-3:#fcf9f8;
  --line:#e4d9d4; --line-soft:#eee5e1; --card:#ffffff;
  --text:#241715; --text-2:#4d3a36; --muted:#7a6862;
  --accent:#b21f24; --accent-deep:#8c1419; --accent-soft:rgba(178,31,36,.10);
  --gold:#c08a36;
  --on-dark:#f6e9e7; --on-dark-2:#d9b3af; --on-dark-mut:#a8817c;
  --line-dark:rgba(255,255,255,.13);
  --hero-overlay:linear-gradient(95deg,rgba(40,12,11,.92) 0%,rgba(120,22,22,.62) 42%,rgba(150,28,26,.30) 72%,rgba(40,12,11,.15) 100%),linear-gradient(0deg,rgba(34,10,9,.86) 0%,rgba(34,10,9,0) 46%);
  --grad-deep:linear-gradient(155deg,#7e1518 0%,#3a0c0b 100%);
}
/* C — warm neutral cream + terracotta brick */
[data-theme="warm"]{
  --ink:#1d1a14; --ink-soft:#2a2620; --ink-deep:#161310;
  --surface:#f4eee2; --surface-2:#eae2d2; --surface-3:#faf6ee;
  --line:#ddd3bf; --line-soft:#e8e0cf; --card:#fffdf7;
  --text:#221e16; --text-2:#4a4334; --muted:#776f5d;
  --accent:#b4452f; --accent-deep:#8f3422; --accent-soft:rgba(180,69,47,.11);
  --gold:#a9842f;
  --on-dark:#f0e9d9; --on-dark-2:#c8bda3; --on-dark-mut:#988e76;
  --line-dark:rgba(255,255,255,.12);
  --hero-overlay:linear-gradient(95deg,rgba(22,19,14,.88) 0%,rgba(28,24,17,.66) 40%,rgba(28,24,17,.28) 72%,rgba(28,24,17,.10) 100%),linear-gradient(0deg,rgba(22,19,14,.84) 0%,rgba(22,19,14,0) 48%);
  --grad-deep:linear-gradient(155deg,#2c2820 0%,#16130d 100%);
}

/* ---------- base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--surface);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;font-size:16px}
a{color:inherit;text-decoration:none}
img,svg,video{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.serif{font-family:var(--serif)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.04;letter-spacing:-.01em}

.eyebrow{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--accent);display:inline-block}
.eyebrow.on-dark{color:#fff}.eyebrow.on-dark::before{background:var(--accent)}

.section{padding:118px 0;position:relative}
.section-head{max-width:740px;margin-bottom:60px}
.section-head h2{font-size:clamp(34px,4.6vw,58px);margin:22px 0 0}
.section-head .lead{color:var(--muted);font-size:18px;margin-top:22px;max-width:580px;line-height:1.65}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.02em;padding:15px 27px;border:1.5px solid transparent;border-radius:var(--radius);cursor:pointer;transition:.4s var(--ease);white-space:nowrap}
.btn .arr{transition:transform .4s var(--ease)}.btn:hover .arr{transform:translateX(5px)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 26px -10px var(--accent)}
.btn-primary:hover{background:var(--accent-deep)}
.btn-dark{background:var(--ink);color:#fff}.btn-dark:hover{background:var(--ink-deep)}
.btn-outline{border-color:var(--line);color:var(--text);background:transparent}
.btn-outline:hover{border-color:var(--ink);background:var(--surface-3)}
.btn-ghost{border-color:rgba(255,255,255,.34);color:#fff}.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-lg{padding:18px 32px;font-size:15px}

/* ---------- theme switch bar ---------- */
.switchbar{background:var(--ink-deep);color:var(--on-dark-2);font-family:var(--sans);font-size:12.5px}
.switchbar .wrap{display:flex;align-items:center;justify-content:center;gap:14px;height:42px;flex-wrap:wrap}
.switchbar .lbl{letter-spacing:.16em;text-transform:uppercase;font-size:11px;color:var(--on-dark-mut)}
.switchbar a{padding:5px 13px;border:1px solid var(--line-dark);border-radius:40px;color:var(--on-dark-2);transition:.3s;letter-spacing:.02em}
.switchbar a:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.switchbar a.on{background:var(--accent);border-color:var(--accent);color:#fff}

/* ---------- utility bar ---------- */
.util{background:var(--ink);color:var(--on-dark-2);font-family:var(--sans);font-size:12.5px;border-bottom:1px solid var(--line-dark)}
.util .wrap{display:flex;justify-content:space-between;align-items:center;height:44px;gap:20px}
.util .left{display:flex;gap:28px}
.util .left span{display:inline-flex;gap:9px;align-items:center;letter-spacing:.03em}
.util .left .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.util .right{display:flex;gap:22px;align-items:center}
.util a:hover{color:#fff}
@media(max-width:880px){.util .left span:nth-child(2){display:none}.util{font-size:11.5px}}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:70;background:color-mix(in srgb,var(--surface) 86%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;height:80px;gap:40px}
.logo{display:flex;align-items:center;gap:13px}
.logo img{height:46px;width:auto}
.logo .wm{line-height:1}
.logo .wm b{font-family:var(--serif);font-weight:600;font-size:22px;letter-spacing:.01em;color:var(--text);display:block}
.logo .wm small{font-family:var(--sans);font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);display:block;margin-top:3px}
.menu{display:flex;gap:32px;margin-left:6px}
.menu a{font-family:var(--sans);font-size:15px;font-weight:500;color:var(--text-2);padding:8px 0;position:relative}
.menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--accent);transition:width .35s var(--ease)}
.menu a:hover{color:var(--text)}.menu a:hover::after{width:100%}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:20px}
.icon-btn{color:var(--text-2);cursor:pointer;transition:.3s;position:relative}.icon-btn:hover{color:var(--accent)}
.icon-btn .cartn{position:absolute;top:-7px;right:-9px;background:var(--accent);color:#fff;font-family:var(--sans);font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.burger{display:none;color:var(--text);cursor:pointer}
@media(max-width:1080px){.menu,.util{display:none}.burger{display:block}.nav-right .btn{display:none}}
.mobile{position:fixed;inset:0;z-index:90;background:var(--ink);transform:translateX(100%);transition:.45s var(--ease);display:flex;flex-direction:column;padding:32px 30px}
.mobile.open{transform:none}
.mobile .x{align-self:flex-end;color:#fff;cursor:pointer;font-size:30px}
.mobile a{color:#fff;font-family:var(--serif);font-size:30px;padding:15px 0;border-bottom:1px solid var(--line-dark)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--ink-deep)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;background:var(--hero-overlay)}
.hero-grain{position:absolute;inset:0;z-index:2;opacity:.5;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");mix-blend-mode:overlay}
.hero .wrap{position:relative;z-index:3;width:100%;padding-top:70px;padding-bottom:74px}
.hero-copy{max-width:720px}
.hero h1{font-size:clamp(48px,7vw,92px);font-weight:500;color:#fff;line-height:1.02;text-shadow:0 6px 40px rgba(0,0,0,.4)}
.hero h1 em{font-style:italic;color:#fff}
.hero h1 .accent-word{color:var(--accent);font-style:italic}
.hero-sub{color:var(--on-dark);font-size:19px;max-width:560px;margin:28px 0 38px;line-height:1.6;text-shadow:0 2px 16px rgba(0,0,0,.5)}
.hero-cta{display:flex;gap:15px;flex-wrap:wrap;align-items:center}
.play-link{display:inline-flex;align-items:center;gap:13px;color:#fff;font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.02em}
.play-link .pic{width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;transition:.35s var(--ease)}
.play-link:hover .pic{background:var(--accent);border-color:var(--accent);transform:scale(1.06)}
.hero-stats{display:flex;gap:0;margin-top:56px;border-top:1px solid rgba(255,255,255,.18);max-width:720px}
.hero-stats .hstat{padding:26px 40px 4px 0;margin-right:40px;border-right:1px solid rgba(255,255,255,.14)}
.hero-stats .hstat:last-child{border-right:0}
.hstat .n{font-family:var(--serif);font-weight:600;font-size:46px;line-height:1;color:#fff}
.hstat .n em{color:var(--accent);font-style:normal}
.hstat .l{font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--on-dark-2);margin-top:10px}
.hero-badge{position:absolute;right:32px;bottom:74px;z-index:3;display:inline-flex;align-items:center;gap:10px;background:rgba(0,0,0,.42);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);font-family:var(--sans);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:#fff;padding:11px 15px;border-radius:40px}
.hero-badge .lv{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:lv 1.9s infinite}
@keyframes lv{0%{box-shadow:0 0 0 0 var(--accent-soft)}70%{box-shadow:0 0 0 9px transparent}100%{box-shadow:0 0 0 0 transparent}}
@media(max-width:760px){.hero{min-height:86vh}.hero-stats{flex-wrap:wrap;gap:0}.hero-stats .hstat{padding:18px 26px 4px 0;margin-right:26px}.hstat .n{font-size:34px}.hero-badge{display:none}}

/* ---------- trust strip ---------- */
.trust{background:var(--ink);color:var(--on-dark);padding:34px 0}
.trust .wrap{display:flex;align-items:center;gap:42px;flex-wrap:wrap;justify-content:space-between}
.trust .lab{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--on-dark-mut);white-space:nowrap}
.cert-row{display:flex;gap:38px;align-items:center;flex-wrap:wrap}
.cert{display:flex;align-items:center;gap:11px;color:var(--on-dark);font-family:var(--serif);font-weight:600;font-size:21px;letter-spacing:.02em}
.cert svg{color:var(--accent)}
@media(max-width:760px){.trust .wrap{gap:22px}.cert{font-size:18px}.cert-row{gap:24px}}

/* ---------- on-the-ground triad (equipment/people/service) ---------- */
.ground{background:var(--surface-3);border-bottom:1px solid var(--line)}
.ground-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.gcol{background:var(--card);padding:46px 40px;position:relative;transition:.4s var(--ease)}
.gcol:hover{background:var(--surface-3)}
.gcol .gi{color:var(--accent);margin-bottom:24px}
.gcol .gnum{position:absolute;top:30px;right:34px;font-family:var(--serif);font-style:italic;font-size:20px;color:var(--line)}
.gcol h3{font-size:27px;margin-bottom:12px}
.gcol p{color:var(--muted);font-size:15px;line-height:1.65}
@media(max-width:820px){.ground-inner{grid-template-columns:1fr}}

/* ---------- equipment categories ---------- */
.cats{background:var(--surface)}
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cat{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--card);border:1px solid var(--line);min-height:300px;display:flex;flex-direction:column;justify-content:flex-end;transition:.45s var(--ease)}
.cat .cimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:.6s var(--ease);filter:saturate(.95)}
.cat::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(8,16,24,.9) 0%,rgba(8,16,24,.42) 46%,rgba(8,16,24,.06) 100%)}
.cat:hover{transform:translateY(-6px);box-shadow:0 30px 60px -28px rgba(8,16,24,.5)}
.cat:hover .cimg{transform:scale(1.07)}
.cat .cbody{position:relative;z-index:2;padding:28px 28px 26px;color:#fff}
.cat .cnum{font-family:var(--sans);font-size:12px;letter-spacing:.12em;color:rgba(255,255,255,.7)}
.cat h3{font-size:25px;color:#fff;margin:8px 0 6px}
.cat p{color:rgba(255,255,255,.82);font-size:14px}
.cat .go{margin-top:16px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.04em;color:#fff;display:inline-flex;gap:8px;align-items:center;opacity:0;transform:translateY(8px);transition:.4s var(--ease)}
.cat:hover .go{opacity:1;transform:none}
.cat .go .arr2{color:var(--accent)}
@media(max-width:900px){.cat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cat-grid{grid-template-columns:1fr}}

/* ---------- automation feature (lights-out factory) ---------- */
.auto{position:relative;background:var(--ink-deep);color:#fff;overflow:hidden}
.auto-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.32}
.auto::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(115deg,var(--ink-deep) 18%,rgba(8,16,24,.6) 60%,rgba(8,16,24,.25) 100%)}
.auto .wrap{position:relative;z-index:2}
.auto-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.auto h2{font-size:clamp(34px,4.6vw,58px);color:#fff;margin:22px 0 0}
.auto h2 em{font-style:italic;color:var(--accent)}
.auto .lead{font-size:18px;color:var(--on-dark);margin:24px 0 30px;max-width:520px}
.auto-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line-dark)}
.auto-list .ai{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--line-dark);align-items:flex-start}
.auto-list .ai .ic{color:var(--accent);flex:none;margin-top:2px}
.auto-list .ai b{font-family:var(--serif);font-weight:600;font-size:19px;color:#fff;display:block;margin-bottom:4px}
.auto-list .ai span{color:var(--on-dark-2);font-size:14.5px}
.auto-figure{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-dark);aspect-ratio:4/5;background:var(--grad-deep)}
.auto-figure img{width:100%;height:100%;object-fit:cover;opacity:.92}
.auto-figure .ftag{position:absolute;left:0;bottom:0;right:0;padding:22px;background:linear-gradient(0deg,rgba(6,12,18,.92),transparent);font-family:var(--sans)}
.auto-figure .ftag b{font-family:var(--serif);font-weight:600;font-size:21px;color:#fff;display:block}
.auto-figure .ftag span{color:var(--on-dark-2);font-size:13px;letter-spacing:.04em}
@media(max-width:900px){.auto-inner{grid-template-columns:1fr;gap:44px}.auto-figure{order:-1;aspect-ratio:16/10}}

/* ---------- featured machines ---------- */
.featured{background:var(--surface-2)}
.phead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:48px}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.45s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 56px -30px rgba(8,16,24,.45)}
.card .media{position:relative;aspect-ratio:4/3;overflow:hidden;border-bottom:1px solid var(--line);background:var(--surface-3)}
.card .media img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.card:hover .media img{transform:scale(1.05)}
.badge{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:6px 11px;border-radius:40px}
.badge.shop{background:var(--accent)}
.badge .pulse{width:6px;height:6px;border-radius:50%;background:#3ad17e;animation:lv 2s infinite}
.badge.shop .pulse{background:#fff}
.card .body{padding:22px 22px 24px}
.card .model{font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:.08em;color:var(--accent);text-transform:uppercase}
.card h3{font-size:22px;margin:9px 0 15px;line-height:1.08}
.specs{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--line);padding-top:15px;margin-bottom:18px}
.specs .row{display:flex;justify-content:space-between;font-size:13.5px}
.specs .row span:first-child{color:var(--muted);font-family:var(--sans);letter-spacing:.02em}
.specs .row span:last-child{font-weight:600;color:var(--text)}
.card .foot{display:flex;justify-content:space-between;align-items:center}
.card .price{font-family:var(--serif);font-weight:600;font-size:25px;color:var(--text)}
.card .price small{font-family:var(--sans);font-size:10.5px;color:var(--muted);font-weight:400;display:block;letter-spacing:.04em;text-transform:uppercase;margin-top:1px}
.card .quote{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.03em;color:var(--accent);display:inline-flex;gap:7px;align-items:center}
@media(max-width:980px){.prod-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.prod-grid{grid-template-columns:1fr}}

/* ---------- online shop band (parts / PayPal) ---------- */
.shopband{background:var(--accent);color:#fff;position:relative;overflow:hidden}
.shopband::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 160% at 90% 0%,rgba(255,255,255,.14),transparent 55%)}
.shopband .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:center;padding:64px 32px}
.shopband .eyebrow{color:rgba(255,255,255,.85)}.shopband .eyebrow::before{background:rgba(255,255,255,.6)}
.shopband h2{font-size:clamp(28px,3.6vw,44px);color:#fff;margin-top:18px;max-width:640px}
.shopband p{color:rgba(255,255,255,.9);font-size:16px;margin-top:16px;max-width:520px}
.shopband .pay{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;align-items:center}
.shopband .pay .chip{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);border-radius:6px;padding:11px 16px;font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.02em;color:#fff}
.shopband .shopcta{margin-top:26px;display:flex;gap:14px;flex-wrap:wrap}
.shopband .btn-white{background:#fff;color:var(--accent)}.shopband .btn-white:hover{background:var(--surface-2)}
@media(max-width:860px){.shopband .wrap{grid-template-columns:1fr;gap:30px}.shopband .pay{justify-content:flex-start}}

/* ---------- customer cases ---------- */
.cases{background:var(--surface)}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.45s var(--ease)}
.case:hover{transform:translateY(-6px);box-shadow:0 30px 56px -30px rgba(8,16,24,.4)}
.case .cmedia{position:relative;aspect-ratio:16/10;overflow:hidden}
.case .cmedia img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.case:hover .cmedia img{transform:scale(1.06)}
.case .ctag{position:absolute;top:14px;left:14px;background:rgba(8,16,24,.78);backdrop-filter:blur(4px);color:#fff;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:40px}
.case .cbody{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.case .cclient{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.case h3{font-size:23px;margin:10px 0 12px;line-height:1.12}
.case p{color:var(--muted);font-size:14.5px;line-height:1.65;flex:1}
.case .cresult{display:flex;gap:26px;margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.case .cresult .r .n{font-family:var(--serif);font-weight:600;font-size:30px;color:var(--accent);line-height:1}
.case .cresult .r .l{font-family:var(--sans);font-size:11.5px;letter-spacing:.04em;color:var(--muted);margin-top:5px}
@media(max-width:980px){.case-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.case-grid{grid-template-columns:1fr}}

/* logos / social proof row */
.logos{margin-top:60px;border-top:1px solid var(--line);padding-top:40px;text-align:center}
.logos .lab{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.logo-row{display:flex;flex-wrap:wrap;justify-content:center;gap:48px;align-items:center}
.logo-row span{font-family:var(--serif);font-weight:600;font-size:24px;color:var(--text-2);opacity:.55;letter-spacing:.01em;transition:.3s}
.logo-row span:hover{opacity:1;color:var(--text)}

/* ---------- testimonial / factory positioning ---------- */
.factory{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.factory .qmark{position:absolute;top:-40px;left:20px;font-family:var(--serif);font-style:italic;font-size:340px;color:rgba(255,255,255,.05);line-height:1;z-index:0}
.factory .wrap{position:relative;z-index:2}
.fact-grid{display:grid;grid-template-columns:1.45fr 1fr;gap:64px;align-items:center}
.fact-grid blockquote{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.3vw,40px);line-height:1.2;color:#fff}
.fact-grid blockquote em{font-style:italic;color:var(--accent)}
.q-by{margin-top:30px;font-family:var(--sans);font-size:14px;color:var(--on-dark-2);display:flex;align-items:center;gap:14px}
.q-by .av{width:46px;height:46px;border-radius:50%;background:var(--grad-deep);border:1px solid var(--line-dark);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;color:#fff}
.q-by b{color:#fff;display:block}
.fmetrics{display:flex;flex-direction:column;gap:1px;background:var(--line-dark);border:1px solid var(--line-dark);border-radius:var(--radius);overflow:hidden}
.fmetrics .m{background:var(--ink-soft);padding:26px 28px}
.fmetrics .m .n{font-family:var(--serif);font-weight:600;font-size:42px;line-height:1;color:#fff}
.fmetrics .m .n em{color:var(--accent);font-style:normal}
.fmetrics .m .l{font-family:var(--sans);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--on-dark-2);margin-top:8px}
@media(max-width:860px){.fact-grid{grid-template-columns:1fr;gap:40px}}

/* ---------- CTA ---------- */
.cta{background:var(--surface-3);position:relative;overflow:hidden;border-top:1px solid var(--line)}
.cta .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.3fr .7fr;gap:48px;align-items:center;padding:96px 32px}
.cta h2{font-size:clamp(32px,4.4vw,56px);max-width:640px}
.cta h2 em{font-style:italic;color:var(--accent)}
.cta .csub{color:var(--muted);font-size:17px;margin-top:18px;max-width:520px}
.cta .cright{display:flex;flex-direction:column;gap:14px;align-items:flex-start}
.cta .cnote{font-family:var(--sans);font-size:13px;color:var(--muted);display:flex;align-items:center;gap:9px}
.cta .cnote svg{color:var(--accent)}
@media(max-width:860px){.cta .wrap{grid-template-columns:1fr;gap:30px;padding:64px 32px}}

/* ---------- footer ---------- */
footer{background:var(--ink-deep);color:var(--on-dark-2);padding:80px 0 34px}
.f-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:48px;padding-bottom:54px;border-bottom:1px solid var(--line-dark)}
.f-about .logo .wm b{color:#fff}.f-about .logo img{filter:none}
.f-about p{font-size:14.5px;margin:22px 0 24px;max-width:320px;line-height:1.7}
.f-grid h4{font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-bottom:22px}
.f-grid ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.f-grid a{font-size:14.5px}.f-grid a:hover{color:#fff}
.f-contact div{display:flex;gap:11px;margin-bottom:14px;font-size:14px;align-items:flex-start}
.f-contact svg{color:var(--accent);flex:none;margin-top:2px}
.socials{display:flex;gap:11px;margin-top:24px}
.socials a{width:40px;height:40px;border:1px solid var(--line-dark);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:.3s}
.socials a:hover{border-color:var(--accent);background:var(--accent-soft);color:#fff}
.f-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:30px;gap:20px;flex-wrap:wrap;font-family:var(--sans);font-size:12.5px;color:var(--on-dark-mut)}
.f-bottom .pay{display:flex;gap:8px;align-items:center}
.f-bottom .pay .chip{border:1px solid var(--line-dark);border-radius:4px;padding:6px 10px;font-size:10.5px;letter-spacing:.04em;color:var(--on-dark-2)}
@media(max-width:880px){.f-grid{grid-template-columns:1fr 1fr}.f-about{grid-column:1/-1}}
@media(max-width:520px){.f-grid{grid-template-columns:1fr}}

/* ---------- reveal animations ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:.8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(24px);transition:.7s var(--ease)}
.stagger.in>*{opacity:1;transform:none}
.stagger.in>*:nth-child(2){transition-delay:.08s}
.stagger.in>*:nth-child(3){transition-delay:.16s}
.stagger.in>*:nth-child(4){transition-delay:.24s}
.stagger.in>*:nth-child(5){transition-delay:.32s}
.stagger.in>*:nth-child(6){transition-delay:.4s}
.hero-copy>*{opacity:0;transform:translateY(22px);animation:rise .9s var(--ease) forwards}
.hero-copy>*:nth-child(1){animation-delay:.1s}
.hero-copy>*:nth-child(2){animation-delay:.24s}
.hero-copy>*:nth-child(3){animation-delay:.38s}
.hero-copy>*:nth-child(4){animation-delay:.52s}
.hero-copy>*:nth-child(5){animation-delay:.66s}
@keyframes rise{to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal,.stagger>*,.hero-copy>*{opacity:1;transform:none}}

/* ============================================================
   INNER PAGES — product detail & parts shop (same design language)
   ============================================================ */

/* breadcrumb */
.crumb{background:var(--surface);border-bottom:1px solid var(--line)}
.crumb .wrap{display:flex;gap:11px;align-items:center;height:52px;font-family:var(--sans);font-size:13px;color:var(--muted);letter-spacing:.01em;flex-wrap:wrap}
.crumb a:hover{color:var(--accent)}
.crumb .sep{opacity:.5}
.crumb .cur{color:var(--text);font-weight:500}

/* ---- product top ---- */
.ptop{padding:56px 0 80px;background:var(--surface)}
.ptop-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:start}
.ptop-grid.even{grid-template-columns:1fr 1fr}

/* gallery */
.gallery .stage{position:relative;aspect-ratio:4/3.3;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface-3)}
.gallery.square .stage{aspect-ratio:1/1}
.gallery .stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.gallery .corner{position:absolute;width:20px;height:20px;border:2px solid var(--accent);z-index:2}
.gallery .corner.tl{top:14px;left:14px;border-right:0;border-bottom:0}
.gallery .corner.tr{top:14px;right:14px;border-left:0;border-bottom:0}
.gallery .corner.bl{bottom:14px;left:14px;border-right:0;border-top:0}
.gallery .corner.br{bottom:14px;right:14px;border-left:0;border-top:0}
.gallery .tag{position:absolute;top:18px;left:18px;z-index:2;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:rgba(8,16,24,.55);backdrop-filter:blur(4px);padding:6px 11px;border-radius:40px}
.gallery .stockpill{position:absolute;top:18px;right:18px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:#fff;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:7px 12px;border-radius:40px}
.gallery .stockpill .pulse{width:6px;height:6px;border-radius:50%;background:#3ad17e;animation:lv 2s infinite}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-top:13px}
.thumb{aspect-ratio:1;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.3s var(--ease);background:var(--surface-3)}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb:hover{border-color:var(--accent)}
.thumb.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}

/* info column */
.pinfo .model,.pinfo .sku{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.08em;color:var(--accent);text-transform:uppercase}
.pinfo h1{font-size:clamp(32px,4vw,50px);margin:12px 0 14px;line-height:1.04}
.rate{display:flex;align-items:center;gap:11px;font-family:var(--sans);font-size:13px;color:var(--muted);margin-bottom:20px}
.stars{color:var(--gold);letter-spacing:2px;font-size:15px}
.pinfo .lead{color:var(--text-2);font-size:16.5px;line-height:1.65;margin-bottom:28px;max-width:540px}

/* key specs */
.kspec{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:30px}
.kspec .k{background:var(--card);padding:20px 22px}
.kspec .k .l{font-family:var(--sans);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.kspec .k .v{font-family:var(--serif);font-weight:600;font-size:26px;margin-top:5px;color:var(--text);line-height:1.05}

/* quote box */
.quotebox{border:1px solid var(--line);border-left:3px solid var(--accent);background:var(--card);padding:26px;border-radius:var(--radius);margin-bottom:22px}
.quotebox .price{font-family:var(--serif);font-weight:600;font-size:32px;color:var(--text);line-height:1.1}
.quotebox .price small{display:block;font-family:var(--sans);font-size:12px;color:var(--muted);font-weight:400;letter-spacing:.02em;margin-top:4px}
.quote-cta{display:flex;gap:13px;margin-top:20px;flex-wrap:wrap}
.quote-cta .btn{flex:1;min-width:190px}
.assure{display:flex;gap:26px;flex-wrap:wrap;margin-top:22px}
.assure div{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--muted);font-family:var(--sans)}
.assure svg{color:var(--accent);flex:none}
@media(max-width:900px){.ptop-grid,.ptop-grid.even{grid-template-columns:1fr;gap:34px}}

/* ---- content sections ---- */
.psec{padding:80px 0;border-top:1px solid var(--line);background:var(--surface)}
.psec.alt{background:var(--surface-3)}
.psec.dark{background:var(--ink);color:#fff;border-top:none;position:relative;overflow:hidden}
.psec h2{font-size:clamp(28px,3.4vw,44px);margin:18px 0 32px}
.psec.dark h2{color:#fff}

.spec-cols{display:grid;grid-template-columns:1fr 1fr;gap:48px}
@media(max-width:760px){.spec-cols{grid-template-columns:1fr;gap:0}}
.spec-table{width:100%;border-collapse:collapse;font-size:15px}
.spec-table caption{text-align:left;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);padding:22px 0 12px}
.spec-table td{padding:14px 16px;border-bottom:1px solid var(--line)}
.spec-table td:first-child{font-family:var(--sans);font-size:13.5px;color:var(--muted);width:46%}
.spec-table td:last-child{font-weight:600;color:var(--text)}
.spec-table tr:hover td{background:var(--surface-3)}

.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.feat-grid .f{display:flex;gap:14px}
.feat-grid svg{color:var(--accent);flex:none;margin-top:2px}
.feat-grid b{font-family:var(--serif);font-weight:600;font-size:18px;display:block;margin-bottom:3px}
.feat-grid span{color:var(--muted);font-size:14px;line-height:1.6}
@media(max-width:680px){.feat-grid{grid-template-columns:1fr}}

.chips{display:flex;flex-wrap:wrap;gap:11px}
.chip-tag{border:1px solid var(--line);background:var(--card);border-radius:40px;padding:9px 18px;font-size:13.5px;font-family:var(--sans);color:var(--text-2)}
.chip-tag::before{content:"#";color:var(--accent);margin-right:5px}

/* downloads (dark) */
.downloads{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;position:relative;z-index:2}
.dl{display:flex;gap:14px;align-items:center;border:1px solid var(--line-dark);border-radius:var(--radius);padding:20px 22px;transition:.3s var(--ease);background:rgba(255,255,255,.02)}
.dl:hover{border-color:var(--accent);background:var(--accent-soft)}
.dl svg{color:var(--accent);flex:none}
.dl b{font-family:var(--serif);font-weight:600;font-size:16px;color:#fff}
.dl span{display:block;font-family:var(--sans);font-size:11px;color:var(--on-dark-2);letter-spacing:.04em;margin-top:3px}
@media(max-width:680px){.downloads{grid-template-columns:1fr}}

/* RFQ form */
.rfq{background:var(--surface-3)}
.rfq-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:56px;align-items:start}
.rfq aside h2{margin:16px 0 16px}
.rfq aside p{color:var(--muted);font-size:15px;margin-bottom:26px;line-height:1.65}
.rfq aside .li{display:flex;gap:11px;align-items:flex-start;margin-bottom:14px;font-size:14.5px;color:var(--text-2)}
.rfq aside .li svg{color:var(--ok);flex:none;margin-top:3px}
.rfq form{display:grid;grid-template-columns:1fr 1fr;gap:18px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.02em;color:var(--text-2)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:15px;padding:13px 15px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-3);color:var(--text);transition:.25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:var(--card);box-shadow:0 0 0 3px var(--accent-soft)}
.field textarea{resize:vertical;min-height:120px}
@media(max-width:840px){.rfq-grid{grid-template-columns:1fr;gap:36px}.rfq form{grid-template-columns:1fr}}

/* related */
.related{padding:80px 0;border-top:1px solid var(--line);background:var(--surface)}
.rel-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:34px;flex-wrap:wrap;gap:16px}
.related .card .body .foot{display:flex;justify-content:space-between;align-items:center}

/* ===== parts-shop specific ===== */
.priceline{display:flex;align-items:baseline;gap:14px;margin-bottom:12px}
.priceline .now{font-family:var(--serif);font-weight:600;font-size:48px;color:var(--text);line-height:1}
.priceline .was{font-family:var(--sans);color:var(--muted);text-decoration:line-through;font-size:17px}
.priceline .save{font-family:var(--sans);font-size:11px;font-weight:600;background:var(--accent);color:#fff;padding:5px 10px;border-radius:40px;letter-spacing:.04em}
.stock{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;font-weight:500;color:var(--ok);margin-bottom:26px}
.stock .pulse{width:9px;height:9px;border-radius:50%;background:var(--ok);animation:lv 2s infinite}
.opt{margin-bottom:22px}
.opt .lab{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;display:block}
.variants{display:flex;gap:11px;flex-wrap:wrap}
.variants .v{border:1px solid var(--line);background:var(--card);border-radius:var(--radius);padding:12px 18px;font-size:14px;cursor:pointer;transition:.25s var(--ease);font-family:var(--sans);color:var(--text-2)}
.variants .v.sel{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);color:var(--accent);font-weight:600}
.variants .v:hover{border-color:var(--accent)}
.buyrow{display:flex;gap:15px;align-items:stretch;margin:26px 0 13px}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:var(--radius);background:var(--card)}
.qty button{width:48px;align-self:stretch;background:none;border:none;font-size:21px;cursor:pointer;color:var(--text);font-family:var(--sans)}
.qty button:hover{color:var(--accent)}
.qty input{width:50px;text-align:center;border:none;font-family:var(--serif);font-weight:600;font-size:21px;background:none;color:var(--text)}
.qty input:focus{outline:none}
.buyrow .btn{flex:1}
.checkout-alt{margin-bottom:24px}
.btn-pp{background:var(--paypal);color:#172b4d}
.btn-pp:hover{filter:brightness(.96)}
.btn-pp b{font-family:var(--sans);font-style:italic;font-weight:700;letter-spacing:0;font-size:16px}
.btn-pp b span{color:#003087}.btn-pp b i{color:#0070ba}
.secure{display:flex;align-items:center;gap:11px;flex-wrap:wrap;font-family:var(--sans);font-size:12px;color:var(--muted);margin-bottom:24px}
.secure .chip{border:1px solid var(--line);border-radius:4px;padding:5px 9px;font-size:10.5px;background:var(--card)}
.fit{border:1px solid var(--line);border-left:3px solid var(--ok);background:var(--card);border-radius:var(--radius);padding:18px 20px}
.fit b{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ok);display:flex;gap:9px;align-items:center}
.fit p{font-size:14px;color:var(--muted);margin-top:9px;line-height:1.6}
.shiprow{display:flex;gap:26px;flex-wrap:wrap;margin-top:20px}
.shiprow div{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--muted);font-family:var(--sans)}
.shiprow svg{color:var(--accent);flex:none}
.compat{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:820px}
.compat .c{display:flex;gap:10px;align-items:center;border:1px solid var(--line);background:var(--card);border-radius:var(--radius);padding:14px 16px;font-family:var(--sans);font-size:14px}
.compat .c svg{color:var(--ok);flex:none}
@media(max-width:680px){.compat{grid-template-columns:1fr 1fr}}
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(150%);background:var(--ink);color:#fff;font-family:var(--sans);font-size:14px;padding:15px 24px;border-radius:var(--radius);border-left:3px solid var(--ok);transition:.45s var(--ease);z-index:95;box-shadow:0 20px 50px -20px rgba(0,0,0,.5)}
.toast.show{transform:translateX(-50%)}

/* ============================================================
   PAGE HEADER (category & about) — image band, no video
   ============================================================ */
.pagehdr{position:relative;overflow:hidden;background:var(--ink-deep);color:#fff}
.pagehdr img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.5}
.pagehdr::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(8,16,24,.92) 0%,rgba(8,16,24,.7) 46%,rgba(8,16,24,.4) 100%)}
.pagehdr .wrap{position:relative;z-index:2;padding:88px 32px 84px}
.pagehdr h1{font-size:clamp(38px,5.4vw,72px);color:#fff;line-height:1.03;max-width:880px}
.pagehdr h1 em{font-style:italic;color:var(--accent)}
.pagehdr .lead{color:var(--on-dark);font-size:18px;margin-top:22px;max-width:560px;line-height:1.65}
.pagehdr .hcrumb{display:flex;gap:11px;align-items:center;font-family:var(--sans);font-size:13px;color:var(--on-dark-2);margin-bottom:26px;flex-wrap:wrap}
.pagehdr .hcrumb a:hover{color:#fff}.pagehdr .hcrumb .sep{opacity:.5}.pagehdr .hcrumb .cur{color:#fff}
.pagehdr .hstatrow{display:flex;gap:0;margin-top:48px;border-top:1px solid rgba(255,255,255,.18);max-width:760px;flex-wrap:wrap}
.pagehdr .hstatrow .hstat{padding:24px 38px 4px 0;margin-right:38px;border-right:1px solid rgba(255,255,255,.14)}
.pagehdr .hstatrow .hstat:last-child{border-right:0;margin-right:0}
.pagehdr .hstatrow .n{font-family:var(--serif);font-weight:600;font-size:42px;color:#fff;line-height:1}
.pagehdr .hstatrow .n em{color:var(--accent);font-style:normal}
.pagehdr .hstatrow .l{font-family:var(--sans);font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--on-dark-2);margin-top:9px}
@media(max-width:680px){.pagehdr .hstatrow .hstat{padding:18px 24px 4px 0;margin-right:24px}.pagehdr .hstatrow .n{font-size:32px}}

/* ============================================================
   CATEGORY / LISTING PAGE
   ============================================================ */
.listing{padding:64px 0 90px;background:var(--surface)}
.listing-grid{display:grid;grid-template-columns:264px 1fr;gap:44px;align-items:start}
.filters{position:sticky;top:104px}
.fgroup{border-bottom:1px solid var(--line);padding:22px 0}
.fgroup:first-child{padding-top:0}
.fgroup h4{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text);margin-bottom:16px}
.fopt{display:flex;align-items:center;gap:11px;padding:7px 0;cursor:pointer;font-size:14.5px;color:var(--text-2);transition:.2s}
.fopt:hover{color:var(--text)}
.fopt .box{width:18px;height:18px;border:1.5px solid var(--line);border-radius:3px;flex:none;display:flex;align-items:center;justify-content:center;transition:.2s;background:var(--card)}
.fopt .box svg{opacity:0;color:#fff;transition:.2s}
.fopt.on .box{background:var(--accent);border-color:var(--accent)}
.fopt.on .box svg{opacity:1}
.fopt .count{margin-left:auto;font-family:var(--sans);font-size:12px;color:var(--muted)}
.fgroup .clearall{font-family:var(--sans);font-size:12.5px;color:var(--accent);cursor:pointer;margin-top:6px;display:inline-block}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid var(--line)}
.toolbar .rc{font-family:var(--sans);font-size:14px;color:var(--muted)}
.toolbar .rc b{color:var(--text);font-weight:600}
.toolbar .sort{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-size:13.5px;color:var(--muted)}
.toolbar .sort select{font-family:var(--sans);font-size:14px;padding:9px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);color:var(--text);cursor:pointer}
.list-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.filter-toggle{display:none}
@media(max-width:1040px){.list-grid{grid-template-columns:1fr 1fr}}
@media(max-width:900px){
  .listing-grid{grid-template-columns:1fr;gap:0}
  .filters{position:static;display:none;margin-bottom:26px}
  .filters.open{display:block}
  .filter-toggle{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;font-weight:600;padding:12px 18px;border:1.5px solid var(--line);border-radius:var(--radius);background:var(--card);color:var(--text);cursor:pointer;margin-bottom:22px}
}
@media(max-width:560px){.list-grid{grid-template-columns:1fr}}
.pagination{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:56px}
.pagination a{min-width:42px;height:42px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:var(--radius);font-family:var(--sans);font-size:14px;color:var(--text-2);background:var(--card);transition:.25s}
.pagination a:hover{border-color:var(--accent);color:var(--accent)}
.pagination a.on{background:var(--accent);border-color:var(--accent);color:#fff}
.pagination a.nav-a{font-weight:600}

/* ============================================================
   ABOUT / FACTORY PAGE
   ============================================================ */
.story{background:var(--surface)}
.story-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:start}
.story-grid h2{font-size:clamp(30px,4vw,52px);line-height:1.06}
.story-grid h2 em{font-style:italic;color:var(--accent)}
.story-body p{color:var(--text-2);font-size:17px;line-height:1.75;margin-bottom:22px}
.story-body p:first-child{font-size:20px;color:var(--text)}
.story-body .sign{margin-top:30px;display:flex;align-items:center;gap:16px;padding-top:26px;border-top:1px solid var(--line)}
.story-body .sign .nm{font-family:var(--serif)}
.story-body .sign .nm b{display:block;font-size:18px;font-weight:600}
.story-body .sign .nm span{font-family:var(--sans);font-size:13px;color:var(--muted)}
@media(max-width:880px){.story-grid{grid-template-columns:1fr;gap:34px}}

.statband{background:var(--ink);color:#fff}
.statband-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.statband .s{padding:64px 32px;border-right:1px solid var(--line-dark);position:relative}
.statband .s:last-child{border-right:0}
.statband .s .n{font-family:var(--serif);font-weight:600;font-size:clamp(44px,5vw,64px);color:#fff;line-height:1}
.statband .s .n em{color:var(--accent);font-style:normal}
.statband .s .l{font-family:var(--sans);font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--on-dark-2);margin-top:14px}
@media(max-width:760px){.statband-grid{grid-template-columns:1fr 1fr}.statband .s:nth-child(2){border-right:0}.statband .s{border-bottom:1px solid var(--line-dark)}}

.facility{background:var(--surface-2)}
.facility-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px}
.facility-grid figure{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.facility-grid figure img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.facility-grid figure:hover img{transform:scale(1.06)}
.facility-grid figure figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px;background:linear-gradient(0deg,rgba(8,16,24,.85),transparent);color:#fff;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.02em}
.facility-grid .big{grid-column:span 2;grid-row:span 2}
@media(max-width:880px){.facility-grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px}.facility-grid .big{grid-column:span 2}}
@media(max-width:520px){.facility-grid{grid-template-columns:1fr;grid-auto-rows:200px}.facility-grid .big{grid-column:span 1;grid-row:span 1}}

.timeline{background:var(--surface)}
.tline{border-top:1px solid var(--line)}
.tline .tl{display:grid;grid-template-columns:160px 1fr;gap:40px;padding:34px 0;border-bottom:1px solid var(--line);transition:.3s}
.tline .tl:hover{background:var(--surface-3)}
.tline .tl .yr{font-family:var(--serif);font-weight:600;font-size:34px;color:var(--accent);line-height:1}
.tline .tl .ev b{font-family:var(--serif);font-weight:600;font-size:21px;display:block;margin-bottom:7px}
.tline .tl .ev p{color:var(--muted);font-size:15px;line-height:1.65;max-width:620px}
@media(max-width:680px){.tline .tl{grid-template-columns:1fr;gap:10px;padding:26px 0}.tline .tl .yr{font-size:28px}}

/* ============================================================
   CART / CHECKOUT PAGE
   ============================================================ */
.cartpage{padding:56px 0 96px;background:var(--surface)}
.cart-top{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:38px}
.cart-top h1{font-size:clamp(34px,4.4vw,54px)}
.cart-top .cnt{font-family:var(--sans);font-size:14px;color:var(--muted)}
.cart-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:48px;align-items:start}
.cart-items{border-top:1px solid var(--line)}
.citem{display:grid;grid-template-columns:104px 1fr auto;gap:24px;align-items:center;padding:26px 0;border-bottom:1px solid var(--line)}
.citem .cimg{width:104px;height:104px;border-radius:var(--radius);object-fit:cover;border:1px solid var(--line);background:var(--surface-3)}
.citem .ci-info .model{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.citem .ci-info h3{font-size:20px;margin:6px 0 8px;line-height:1.1}
.citem .ci-info .meta{font-family:var(--sans);font-size:13px;color:var(--muted);display:flex;gap:16px;flex-wrap:wrap}
.citem .ci-info .rm{margin-top:12px;display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-size:12.5px;color:var(--muted);cursor:pointer;transition:.2s}
.citem .ci-info .rm:hover{color:var(--accent)}
.citem .ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.citem .ci-price{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--text)}
.citem .qty{transform:scale(.92);transform-origin:right}
@media(max-width:620px){.citem{grid-template-columns:80px 1fr;gap:16px}.citem .cimg{width:80px;height:80px}.citem .ci-right{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center}}
.cart-actions{display:flex;justify-content:space-between;align-items:center;margin-top:26px;flex-wrap:wrap;gap:14px}
.cart-actions a{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--accent);display:inline-flex;gap:8px;align-items:center}

.summary{position:sticky;top:104px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.summary h3{font-size:23px;margin-bottom:20px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.srow{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-family:var(--sans);font-size:14.5px;color:var(--muted)}
.srow .v{color:var(--text);font-weight:600}
.srow .free{color:var(--ok);font-weight:600}
.srow.total{border-top:1px solid var(--line);margin-top:12px;padding-top:20px}
.srow.total .lab{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--text)}
.srow.total .v{font-family:var(--serif);font-weight:600;font-size:28px;color:var(--text)}
.promo{display:flex;gap:10px;margin:18px 0}
.promo input{flex:1;font-family:var(--sans);font-size:14px;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-3);color:var(--text)}
.promo input:focus{outline:none;border-color:var(--accent);background:var(--card)}
.promo button{font-family:var(--sans);font-size:13px;font-weight:600;padding:0 18px;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);color:var(--text);cursor:pointer;transition:.25s}
.promo button:hover{border-color:var(--accent);color:var(--accent)}
.summary .btn{width:100%;margin-top:8px}
.summary .or{text-align:center;font-family:var(--sans);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:14px 0;position:relative}
.summary .or::before,.summary .or::after{content:"";position:absolute;top:50%;width:38%;height:1px;background:var(--line)}
.summary .or::before{left:0}.summary .or::after{right:0}
.summary .secure{justify-content:center;margin:18px 0 0}
.summary .ship-note{font-family:var(--sans);font-size:12.5px;color:var(--muted);text-align:center;margin-top:16px;display:flex;align-items:center;justify-content:center;gap:8px}
.summary .ship-note svg{color:var(--ok)}
@media(max-width:900px){.cart-grid{grid-template-columns:1fr;gap:36px}.summary{position:static}}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contactpage{padding:56px 0 96px;background:var(--surface)}
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:60px;align-items:start}
.cinfo .lead{color:var(--muted);font-size:17px;line-height:1.7;margin:18px 0 30px;max-width:440px}
.cinfo-card{display:flex;gap:16px;padding:22px 24px;border:1px solid var(--line);border-radius:var(--radius);background:var(--card);margin-bottom:16px;transition:.3s var(--ease)}
.cinfo-card:hover{border-color:var(--accent);box-shadow:0 16px 36px -24px rgba(8,16,24,.5)}
.cinfo-card .ic{width:46px;height:46px;border-radius:var(--radius);background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex:none}
.cinfo-card .lab{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.cinfo-card b{font-family:var(--serif);font-weight:600;font-size:19px;display:block;margin:4px 0 3px}
.cinfo-card a:hover{color:var(--accent)}
.cinfo-card p{font-size:14px;color:var(--muted);line-height:1.6}
.hours{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface-3);padding:20px 24px;margin-top:6px}
.hours h4{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text);margin-bottom:14px}
.hours .hr{display:flex;justify-content:space-between;font-family:var(--sans);font-size:14px;padding:6px 0;color:var(--text-2)}
.hours .hr span:last-child{color:var(--muted)}
.contact-form{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:34px}
.contact-form .fh{margin-bottom:24px}
.contact-form .fh h2{font-size:30px}
.contact-form .fh p{color:var(--muted);font-size:15px;margin-top:8px}
.contact-form form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.mapbox{position:relative;margin-top:64px;height:340px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:
  radial-gradient(120% 120% at 50% 0%,var(--surface-3),var(--surface-2))}
.mapbox .grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:48px 48px;opacity:.7}
.mapbox .road{position:absolute;background:var(--line)}
.mapbox .r1{top:42%;left:0;right:0;height:10px}
.mapbox .r2{top:0;bottom:0;left:38%;width:10px}
.mapbox .pin{position:absolute;top:42%;left:38%;transform:translate(-50%,-100%);color:var(--accent);filter:drop-shadow(0 6px 10px rgba(0,0,0,.3))}
.mapbox .pin .dot{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px var(--accent-soft);position:absolute;left:50%;top:100%;transform:translate(-50%,-4px)}
.mapbox .card-pin{position:absolute;top:42%;left:38%;transform:translate(20px,-50%);background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;box-shadow:0 16px 40px -16px rgba(8,16,24,.4);max-width:240px}
.mapbox .card-pin b{font-family:var(--serif);font-weight:600;font-size:16px;display:block}
.mapbox .card-pin span{font-family:var(--sans);font-size:13px;color:var(--muted)}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:40px}.contact-form form{grid-template-columns:1fr}.mapbox .card-pin{display:none}}
