/*
 * ============================================================
 * css/style.css  —  Carplus Website Styles
 * ============================================================
 */

/* ── 1. CSS VARIABLES (DARK MODE — default) ───────────────── */
:root {
  --red:    #E8000D;
  --red2:   #B0000A;
  --redg:   rgba(232,0,13,.14);
  --redb:   rgba(232,0,13,.32);
  --c0:  #09090F;
  --c1:  #0F0F18;
  --c2:  #161622;
  --c3:  #1D1D2C;
  --c4:  #252536;
  --c5:  #333348;
  --w:   #EAEAF8;
  --wm:  #7A7A9A;
  --wd:  #3A3A52;
  --bdr:  rgba(255,255,255,.07);
  --bdr2: rgba(255,255,255,.13);
  --green:  #00D98B;
  --yellow: #F5A623;
  --f1: 'Syne', sans-serif;
  --f2: 'Nunito Sans', sans-serif;
  --ease: cubic-bezier(.22,1,.36,1);
  --pad: clamp(64px,9vw,120px);
  /* loader/scrollbar bg */
  --loader-bg: var(--c0);
}

/* ── 1b. LIGHT MODE VARIABLES ─────────────────────────────── */
[data-theme="light"] {
  --c0:  #F4F4F8;
  --c1:  #EAEAEF;
  --c2:  #DFDFE8;
  --c3:  #D2D2DC;
  --c4:  #C4C4D0;
  --c5:  #B4B4C2;
  --w:   #111122;
  --wm:  #44445A;
  --wd:  #88889A;
  --bdr:  rgba(0,0,0,.08);
  --bdr2: rgba(0,0,0,.15);
  --loader-bg: #F4F4F8;
}
[data-theme="light"] body { background: var(--c0); color: var(--w); }
[data-theme="light"] #navbar.scrolled { background: rgba(244,244,248,.95); }
[data-theme="light"] .hero-bg { background: linear-gradient(145deg,var(--c0) 50%,var(--c2) 50%); }
[data-theme="light"] .hero-grid {
  background-image: linear-gradient(rgba(232,0,13,.06) 1px,transparent 1px),
                    linear-gradient(90deg,rgba(232,0,13,.06) 1px,transparent 1px);
}
[data-theme="light"] .ld-bar-wrap { background: var(--c3); }
[data-theme="light"] ::-webkit-scrollbar-track { background: var(--c1); }
[data-theme="light"] .marquee-strip { background: var(--c1); }
[data-theme="light"] .nav-links { background: var(--c1); }
[data-theme="light"] #footer { background: var(--c1); }
[data-theme="light"] .obd-card { background: var(--c2); }
[data-theme="light"] .obd-metric { background: var(--c3); }
[data-theme="light"] .obd-scan  { background: var(--c3); }
[data-theme="light"] .obd-code-row { background: var(--c3); }
[data-theme="light"] .obd-scanlines { background: repeating-linear-gradient(0deg,transparent,transparent 8px,rgba(0,0,0,.04) 8px,rgba(0,0,0,.04) 9px); }
[data-theme="light"] .svc-card { background: var(--c1); }
[data-theme="light"] .svc-card:hover { background: var(--c2); }
[data-theme="light"] .prod-card { background: var(--c2); }
[data-theme="light"] .prod-img-wrap { background: var(--c3); }
[data-theme="light"] .prod-spec { background: var(--c3); }
[data-theme="light"] .tool-card { background: var(--c2); }
[data-theme="light"] .tool-img-box { background: var(--c3); }
[data-theme="light"] .tool-img-box img { filter: brightness(.85) saturate(.9); }
[data-theme="light"] .testi-card { background: var(--c2); }
[data-theme="light"] .cf-box { background: var(--c2); }
[data-theme="light"] .field-group input,
[data-theme="light"] .field-group select,
[data-theme="light"] .field-group textarea { background: var(--c1); color: var(--w); }
[data-theme="light"] .team-card { background: var(--c2); }
[data-theme="light"] .photo-main img, [data-theme="light"] .photo-sm img { filter: brightness(.9) saturate(.95); }
[data-theme="light"] .ci-icon { background: var(--c3); }
[data-theme="light"] .map-box { background: var(--c3); }
[data-theme="light"] .hours-watermark { color: rgba(0,0,0,.04); }
[data-theme="light"] .loader-logo { color: var(--w); }
[data-theme="light"] #loader { background: var(--c0); }
[data-theme="light"] .hero-glow { background: radial-gradient(circle,rgba(232,0,13,.08) 0%,transparent 60%); }

/* ── 2. RESET ─────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html  { scroll-behavior:smooth; font-size:16px; }
body  { background:var(--c0); color:var(--w); font-family:var(--f2); line-height:1.65; overflow-x:hidden; }
img   { display:block; max-width:100%; }
a     { color:inherit; text-decoration:none; }
ul    { list-style:none; }
::-webkit-scrollbar            { width:4px; }
::-webkit-scrollbar-track      { background:var(--c0); }
::-webkit-scrollbar-thumb      { background:var(--red); border-radius:2px; }

/* ── 3. LAYOUT ────────────────────────────────────────────── */
.wrap { width:min(1200px,100% - 2.8rem); margin-inline:auto; }
.sec  { padding-block:var(--pad); }

/* ── 4. TYPOGRAPHY ────────────────────────────────────────── */
.kicker { display:inline-flex; align-items:center; gap:9px; font-size:.68rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--red); margin-bottom:.9rem; }
.kicker::before { content:''; width:18px; height:2px; background:var(--red); flex-shrink:0; }
.h1 { font-family:var(--f1); font-size:clamp(3.2rem,7vw,7rem); font-weight:800; line-height:.9; letter-spacing:-.02em; text-transform:uppercase; }
.h2 { font-family:var(--f1); font-size:clamp(2rem,4.5vw,3.8rem); font-weight:800; line-height:.95; letter-spacing:-.01em; text-transform:uppercase; }
.h3 { font-family:var(--f1); font-size:clamp(1.2rem,2vw,1.7rem); font-weight:700; text-transform:uppercase; }
.accent { color:var(--red); }
.rule   { width:44px; height:3px; background:var(--red); margin-block:.85rem 1.3rem; }

/* ── 5. BUTTONS ───────────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:12px 28px; font-family:var(--f2); font-size:.78rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; border:none; cursor:pointer; transition:all .25s var(--ease); clip-path:polygon(0 0,calc(100% - 11px) 0,100% 100%,11px 100%); position:relative; overflow:hidden; }
.btn::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(255,255,255,.13),transparent); transform:translateX(-100%); transition:transform .5s; }
.btn:hover::after { transform:translateX(100%); }
.btn-fill  { background:var(--red); color:#fff; }
.btn-fill:hover  { background:var(--red2); transform:translateY(-2px); }
.btn-line  { background:transparent; color:var(--w); border:1.5px solid var(--bdr2); }
.btn-line:hover  { border-color:var(--red); color:var(--red); background:var(--redg); }

/* ── 6. LOADER ────────────────────────────────────────────── */
#loader { position:fixed; inset:0; background:var(--c0); z-index:9000; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.5rem; transition:opacity .5s,visibility .5s; }
#loader.done { opacity:0; visibility:hidden; pointer-events:none; }
.ld-logo  { font-family:var(--f1); font-size:2.8rem; font-weight:800; letter-spacing:.05em; }
.ld-logo span { color:var(--red); }
.ld-bar-wrap { width:220px; height:2px; background:var(--c4); overflow:hidden; }
.ld-bar  { height:100%; background:var(--red); box-shadow:0 0 10px var(--red); animation:lbar 1.5s ease forwards; }
@keyframes lbar { from{width:0} to{width:100%} }
.ld-text { font-size:.62rem; letter-spacing:.22em; text-transform:uppercase; color:var(--wd); animation:blink .9s step-end infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.2} }

/* ── 7. NAVBAR ────────────────────────────────────────────── */
#navbar { position:fixed; top:0; left:0; right:0; z-index:800; transition:background .4s,border-color .4s; border-bottom:1px solid transparent; }
#navbar.scrolled { background:rgba(9,9,15,.94); backdrop-filter:blur(18px); border-bottom-color:var(--bdr); }
.nav-row { display:flex; align-items:center; justify-content:space-between; height:68px; }
.nav-logo { display:flex; align-items:center; gap:10px; cursor:pointer; user-select:none; }
.logo-sq  { width:36px; height:36px; background:var(--red); clip-path:polygon(0 0,calc(100% - 8px) 0,100% 100%,8px 100%); display:flex; align-items:center; justify-content:center; font-family:var(--f1); font-size:.95rem; font-weight:800; color:#fff; }
.logo-name { font-family:var(--f1); font-size:1.5rem; font-weight:800; letter-spacing:.05em; text-transform:uppercase; }
.logo-name span { color:var(--red); }
.nav-links { display:flex; align-items:center; gap:1.8rem; }
.nav-links a { font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--wm); transition:color .2s; position:relative; }
.nav-links a::after { content:''; position:absolute; left:0; bottom:-4px; width:0; height:2px; background:var(--red); transition:width .3s var(--ease); }
.nav-links a:hover,.nav-links a.active { color:var(--w); }
.nav-links a:hover::after,.nav-links a.active::after { width:100%; }
.nav-end { display:flex; align-items:center; gap:.8rem; }
.nav-admin-btn { font-size:.66rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--wm); padding:7px 14px; border:1px solid var(--bdr); background:none; cursor:pointer; transition:all .2s; text-decoration:none; display:inline-block; }
.nav-admin-btn:hover { color:var(--red); border-color:var(--redb); }

/* Theme toggle button */
.theme-btn { width:36px; height:36px; background:transparent; border:1px solid var(--bdr); border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:1rem; transition:all .2s; flex-shrink:0; padding:0; }
.theme-btn:hover { border-color:var(--redb); background:var(--redg); transform:scale(1.1); }

.burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.burger span { display:block; width:22px; height:2px; background:var(--w); transition:all .3s var(--ease); }
.burger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.burger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.burger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── 8. HERO ──────────────────────────────────────────────── */
#hero { position:relative; min-height:100vh; display:flex; align-items:center; padding-top:68px; overflow:hidden; }
.hero-bg   { position:absolute; inset:0; background:linear-gradient(145deg,var(--c0) 50%,var(--c2) 50%); z-index:0; }
.hero-grid { position:absolute; inset:0; z-index:0; pointer-events:none; background-image:linear-gradient(rgba(232,0,13,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(232,0,13,.04) 1px,transparent 1px); background-size:50px 50px; }
.hero-glow { position:absolute; top:-10%; right:-5%; width:650px; height:650px; z-index:0; pointer-events:none; background:radial-gradient(circle,rgba(232,0,13,.12) 0%,transparent 60%); transition:transform .1s; }
.hero-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; width:100%; }
.hero-badge { display:inline-flex; align-items:center; gap:9px; background:var(--redg); border:1px solid var(--redb); padding:6px 14px; font-size:.65rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:1.5rem; }
.hero-badge-dot { width:6px; height:6px; background:var(--red); border-radius:50%; animation:pdot 2s ease-in-out infinite; }
@keyframes pdot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.5)} }
.hero-title { font-family:var(--f1); font-size:clamp(3.4rem,7.5vw,7.5rem); font-weight:800; line-height:.88; letter-spacing:-.03em; text-transform:uppercase; margin-bottom:1.6rem; }
.hero-title .red { color:var(--red); display:block; }
.hero-sub { font-size:.93rem; color:var(--wm); line-height:1.8; max-width:460px; margin-bottom:2.4rem; }
.hero-btns { display:flex; gap:.9rem; flex-wrap:wrap; }
.hero-stats { display:flex; gap:2.5rem; margin-top:3.5rem; padding-top:2rem; border-top:1px solid var(--bdr); }
.stat-num { font-family:var(--f1); font-size:2.4rem; font-weight:800; line-height:1; }
.stat-num b { color:var(--red); font-weight:800; }
.stat-lbl { font-size:.66rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--wm); margin-top:3px; }

/* OBD Card */
.obd-card { background:var(--c2); border:1px solid var(--bdr2); padding:1.8rem; position:relative; overflow:hidden; }
.obd-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--red),transparent); }
.obd-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:1.3rem; }
.obd-title { font-size:.6rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--wm); }
.obd-status { display:flex; align-items:center; gap:6px; font-size:.58rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--green); }
.obd-status::before { content:''; width:6px; height:6px; background:var(--green); border-radius:50%; animation:pdot 1.5s ease-in-out infinite; }
.obd-metrics { display:grid; grid-template-columns:repeat(3,1fr); gap:.8rem; margin-bottom:1.2rem; }
.obd-metric { background:var(--c3); border:1px solid var(--bdr); padding:.85rem; text-align:center; }
.obd-m-val { font-family:var(--f1); font-size:1.45rem; font-weight:700; color:var(--red); line-height:1; }
.obd-m-lbl { font-size:.54rem; color:var(--wd); text-transform:uppercase; letter-spacing:.1em; margin-top:4px; }
.obd-scan  { position:relative; height:92px; background:var(--c3); border:1px solid var(--bdr); overflow:hidden; margin-bottom:1rem; }
.obd-beam  { position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--red),transparent); box-shadow:0 0 12px var(--red); animation:beam 2.6s ease-in-out infinite; }
@keyframes beam { 0%{top:0} 50%{top:calc(100% - 2px)} 100%{top:0} }
.obd-scanlines { position:absolute; inset:0; background:repeating-linear-gradient(0deg,transparent,transparent 8px,rgba(255,255,255,.015) 8px,rgba(255,255,255,.015) 9px); }
.obd-scan-label { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:.58rem; letter-spacing:.22em; text-transform:uppercase; color:var(--wd); font-weight:600; }
.obd-codes { display:flex; flex-direction:column; gap:.4rem; }
.obd-code-row { display:flex; align-items:center; gap:9px; background:var(--c3); padding:7px 11px; border:1px solid var(--bdr); font-size:.63rem; }
.obd-code { color:var(--red); font-weight:700; min-width:56px; font-family:monospace; }
.obd-desc { color:var(--wm); flex:1; }
.obd-ok   { color:var(--green); font-size:.58rem; }
.obd-warn { color:var(--yellow); font-size:.58rem; }

/* ── 9. MARQUEE ───────────────────────────────────────────── */
.marquee-strip { overflow:hidden; border-block:1px solid var(--bdr); background:var(--c1); padding:11px 0; }
.marquee-track { display:flex; width:max-content; animation:mqscroll 26s linear infinite; }
.marquee-track:hover { animation-play-state:paused; }
.marquee-item { display:flex; align-items:center; gap:9px; padding-right:3rem; font-size:.67rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--wd); white-space:nowrap; }
.marquee-dot  { width:4px; height:4px; background:var(--red); border-radius:50%; flex-shrink:0; }
@keyframes mqscroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── 10. ABOUT ────────────────────────────────────────────── */
#about { background:var(--c1); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
.photo-grid { display:grid; grid-template-columns:1fr 1fr; grid-template-rows:220px 160px; gap:6px; position:relative; }
.photo-main { grid-column:1/-1; overflow:hidden; background:var(--c3); border:1px solid var(--bdr); position:relative; }
.photo-sm   { overflow:hidden; background:var(--c3); border:1px solid var(--bdr); position:relative; }
.photo-main img,.photo-sm img { width:100%; height:100%; object-fit:cover; filter:brightness(.75) saturate(.85); transition:transform .6s var(--ease),filter .4s; }
.photo-main:hover img,.photo-sm:hover img { transform:scale(1.05); filter:brightness(.88) saturate(1); }
.photo-tint { position:absolute; inset:0; background:linear-gradient(135deg,var(--redg),transparent 60%); pointer-events:none; }
.photo-cap  { position:absolute; bottom:.7rem; left:.7rem; font-size:.58rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.65); background:rgba(0,0,0,.55); padding:3px 9px; backdrop-filter:blur(6px); }
.year-badge { position:absolute; top:-1rem; right:-1rem; background:var(--red); padding:1.1rem 1.3rem; z-index:5; clip-path:polygon(0 0,calc(100% - 8px) 0,100% 100%,8px 100%); text-align:center; }
.year-n { font-family:var(--f1); font-size:2rem; font-weight:800; color:#fff; line-height:1; }
.year-l { font-size:.58rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.7); margin-top:2px; }
.about-text p { font-size:.9rem; color:var(--wm); line-height:1.85; margin-bottom:1rem; }
.feature-grid { display:grid; grid-template-columns:1fr 1fr; gap:.55rem; margin:1.6rem 0 2rem; }
.feature-item { display:flex; align-items:center; gap:9px; font-size:.78rem; font-weight:700; color:var(--wm); }
.feature-item::before { content:''; width:3px; height:13px; background:var(--red); flex-shrink:0; }
.team-row { display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem; margin-top:2.5rem; padding-top:2rem; border-top:1px solid var(--bdr); }
.team-card { background:var(--c2); border:1px solid var(--bdr); padding:1rem .9rem; text-align:center; transition:border-color .3s; }
.team-card:hover { border-color:var(--redb); }
.team-av { width:54px; height:54px; border-radius:50%; margin:0 auto .65rem; overflow:hidden; border:2px solid var(--bdr2); background:var(--c4); display:flex; align-items:center; justify-content:center; font-family:var(--f1); font-size:1.3rem; font-weight:800; color:var(--red); }
.team-av img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.team-name { font-size:.8rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; }
.team-role { font-size:.63rem; color:var(--wm); margin-top:3px; }

/* ── 11. SERVICES ─────────────────────────────────────────── */
#services { background:var(--c0); }
.section-intro { max-width:520px; margin-bottom:3.5rem; }
.section-intro p { font-size:.9rem; color:var(--wm); line-height:1.75; }
.services-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(268px,1fr)); gap:1.5px; background:var(--bdr); border:1px solid var(--bdr); }
.svc-card { background:var(--c1); padding:2.1rem; position:relative; overflow:hidden; transition:background .28s; cursor:default; }
.svc-card::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:var(--red); transform:scaleX(0); transition:transform .4s var(--ease); }
.svc-card:hover { background:var(--c2); }
.svc-card:hover::before { transform:scaleX(1); }
.svc-icon { font-size:1.7rem; margin-bottom:1.1rem; display:block; transition:transform .3s; }
.svc-card:hover .svc-icon { transform:scale(1.15); }
.svc-name { font-family:var(--f1); font-size:1.1rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; margin-bottom:.55rem; transition:color .2s; }
.svc-card:hover .svc-name { color:var(--red); }
.svc-desc { font-size:.8rem; color:var(--wm); line-height:1.72; margin-bottom:1.1rem; }
.svc-price { font-family:var(--f1); font-size:1.05rem; color:var(--red); letter-spacing:.04em; }
.svc-unit  { font-family:var(--f2); font-size:.65rem; color:var(--wd); font-weight:500; }

/* ── 12. SHOP ─────────────────────────────────────────────── */
#shop { background:var(--c1); }
.shop-head { text-align:center; max-width:560px; margin:0 auto 4rem; }
.shop-head .kicker { justify-content:center; }
.shop-head .rule   { margin-inline:auto; }
.shop-head p { font-size:.88rem; color:var(--wm); line-height:1.75; margin-top:.5rem; }
.products-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(288px,1fr)); gap:1.5rem; }
.prod-card { background:var(--c2); border:1px solid var(--bdr); position:relative; overflow:hidden; transition:border-color .3s,transform .3s var(--ease); }
.prod-card:hover { border-color:var(--redb); transform:translateY(-5px); }
.prod-badge { position:absolute; top:.9rem; left:.9rem; z-index:3; padding:3px 10px; font-size:.6rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; clip-path:polygon(0 0,calc(100% - 5px) 0,100% 100%,5px 100%); }
.badge-hot  { background:var(--red);    color:#fff; }
.badge-new  { background:var(--green);  color:#000; }
.badge-sale { background:var(--yellow); color:#000; }
.prod-img-wrap { height:210px; background:var(--c3); border-bottom:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.prod-img-wrap img { width:100%; height:100%; object-fit:contain; padding:1rem; filter:drop-shadow(0 4px 18px rgba(232,0,13,.18)); transition:transform .4s var(--ease); }
.prod-card:hover .prod-img-wrap img { transform:scale(1.07); }
.prod-img-placeholder { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5rem; color:var(--wd); }
.prod-img-placeholder span { font-size:.62rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; }
.prod-body   { padding:1.2rem; }
.prod-brand  { font-size:.6rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--red); margin-bottom:.3rem; }
.prod-name   { font-family:var(--f1); font-size:1.05rem; font-weight:700; text-transform:uppercase; margin-bottom:.5rem; }
.prod-desc   { font-size:.76rem; color:var(--wm); line-height:1.65; margin-bottom:.9rem; }
.prod-specs  { display:flex; flex-wrap:wrap; gap:.35rem; margin-bottom:.9rem; }
.prod-spec   { font-size:.56rem; font-weight:700; background:var(--c4); border:1px solid var(--bdr); padding:3px 9px; color:var(--wm); letter-spacing:.04em; }
.prod-footer { display:flex; align-items:center; justify-content:space-between; padding-top:.9rem; border-top:1px solid var(--bdr); }
.prod-old    { font-size:.68rem; color:var(--wd); text-decoration:line-through; margin-bottom:1px; }
.prod-price  { font-family:var(--f1); font-size:1.35rem; font-weight:700; color:var(--w); line-height:1; }
.prod-enquire { font-size:.68rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; background:var(--red); color:#fff; padding:9px 18px; border:none; cursor:pointer; clip-path:polygon(0 0,calc(100% - 7px) 0,100% 100%,7px 100%); transition:background .22s; }
.prod-enquire:hover { background:var(--red2); }

/* ── 13. TOOLS ────────────────────────────────────────────── */
#tools { background:var(--c0); position:relative; overflow:hidden; }
.tools-watermark { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-family:var(--f1); font-size:20vw; font-weight:800; color:rgba(255,255,255,.018); pointer-events:none; user-select:none; white-space:nowrap; z-index:0; }
[data-theme="light"] .tools-watermark { color:rgba(0,0,0,.03); }
.tools-head { text-align:center; max-width:540px; margin:0 auto 3.8rem; position:relative; z-index:1; }
.tools-head .kicker { justify-content:center; }
.tools-head .rule   { margin-inline:auto; }
.tools-head p { font-size:.88rem; color:var(--wm); line-height:1.75; }
.tools-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:1.6rem; position:relative; z-index:1; }
.tool-card { background:var(--c2); border:1px solid var(--bdr); overflow:hidden; transition:border-color .3s,transform .3s var(--ease); }
.tool-card:hover { border-color:var(--redb); transform:translateY(-4px); }
.tool-card.featured { border-color:rgba(232,0,13,.35); }
.tool-img-box { height:160px; background:var(--c3); border-bottom:1px solid var(--bdr); display:flex; align-items:center; justify-content:center; overflow:hidden; position:relative; }
.tool-img-box img { width:100%; height:100%; object-fit:cover; filter:brightness(.72) saturate(.8); transition:filter .4s; }
.tool-card:hover .tool-img-box img { filter:brightness(.88) saturate(1); }
.tool-primary-badge { position:absolute; top:0; right:1.2rem; background:var(--red); padding:3px 11px; font-size:.58rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; }
.tool-body   { padding:1.5rem; }
.tool-brand  { font-family:var(--f1); font-size:1.7rem; font-weight:800; color:var(--red); line-height:1; }
.tool-model  { font-size:.58rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--wd); margin-bottom:1.1rem; }
.tool-name   { font-family:var(--f1); font-size:1rem; font-weight:700; text-transform:uppercase; margin-bottom:.6rem; }
.tool-desc   { font-size:.8rem; color:var(--wm); line-height:1.72; margin-bottom:1.1rem; }
.tool-feats  { display:flex; flex-direction:column; gap:.4rem; }
.tool-feat   { display:flex; align-items:center; gap:8px; font-size:.74rem; color:var(--wm); }
.tool-feat::before { content:'◆'; font-size:.34rem; color:var(--red); flex-shrink:0; }

/* ── 14. TESTIMONIALS ─────────────────────────────────────── */
#testimonials { background:var(--c1); }
.testi-head { text-align:center; max-width:480px; margin:0 auto 4rem; }
.testi-head .kicker { justify-content:center; }
.testi-head .rule   { margin-inline:auto; }
.testi-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:1.2rem; }
.testi-card { background:var(--c2); border:1px solid var(--bdr); padding:1.8rem; transition:border-color .3s,transform .3s var(--ease); }
.testi-card:hover { border-color:var(--redb); transform:translateY(-3px); }
.testi-stars  { letter-spacing:3px; color:var(--yellow); font-size:.8rem; margin-bottom:.8rem; }
.testi-quote  { font-family:var(--f1); font-size:2.8rem; font-weight:800; color:var(--red); opacity:.22; line-height:.8; margin-bottom:.8rem; }
.testi-text   { font-size:.83rem; color:var(--wm); line-height:1.82; margin-bottom:1.3rem; }
.testi-author { display:flex; align-items:center; gap:11px; }
.testi-av     { width:42px; height:42px; border-radius:50%; overflow:hidden; background:var(--c4); border:2px solid var(--bdr2); display:flex; align-items:center; justify-content:center; font-family:var(--f1); font-size:1.1rem; font-weight:800; color:var(--red); flex-shrink:0; }
.testi-av img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.testi-name   { font-size:.82rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; }
.testi-role   { font-size:.63rem; color:var(--wd); margin-top:2px; }

/* ── 15. CTA BAND ─────────────────────────────────────────── */
#cta-band { background:var(--red); padding-block:clamp(52px,7vw,88px); position:relative; overflow:hidden; }
#cta-band::before { content:''; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23000' fill-opacity='0.05'%3E%3Cpath d='M0 60L60 0H30L0 30M60 60V30L30 60'/%3E%3C/g%3E%3C/svg%3E"); }
.cta-inner { position:relative; z-index:1; text-align:center; max-width:640px; margin:0 auto; }
.cta-inner .h2 { color:#fff; margin-bottom:.8rem; }
.cta-inner p   { color:rgba(255,255,255,.82); font-size:.94rem; line-height:1.72; margin-bottom:2.4rem; }
.cta-btns { display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; }
.btn-white       { background:#fff; color:var(--red); clip-path:polygon(0 0,calc(100% - 12px) 0,100% 100%,12px 100%); padding:12px 28px; font-size:.78rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; border:none; cursor:pointer; transition:all .25s; display:inline-flex; align-items:center; gap:8px; }
.btn-white:hover { background:#ffe0e0; transform:translateY(-2px); }
.btn-white-ghost       { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.45); clip-path:polygon(0 0,calc(100% - 12px) 0,100% 100%,12px 100%); padding:10px 28px; font-size:.78rem; font-weight:800; letter-spacing:.12em; text-transform:uppercase; cursor:pointer; transition:all .25s; display:inline-flex; align-items:center; gap:8px; }
.btn-white-ghost:hover { border-color:#fff; background:rgba(255,255,255,.12); }

/* ── 16. CONTACT ──────────────────────────────────────────── */
#contact { background:var(--c0); }
.contact-grid { display:grid; grid-template-columns:1fr 1.55fr; gap:5rem; align-items:start; }
.contact-info > p { font-size:.9rem; color:var(--wm); line-height:1.78; margin-bottom:2rem; }
.ci-row { display:flex; gap:14px; align-items:flex-start; margin-bottom:1.5rem; }
.ci-icon { width:44px; height:44px; background:var(--c3); border:1px solid var(--bdr); clip-path:polygon(0 0,calc(100% - 8px) 0,100% 100%,8px 100%); display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.ci-label { font-size:.6rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--wd); margin-bottom:4px; }
.ci-value { font-size:.87rem; color:var(--w); line-height:1.5; }
.ci-value a { color:var(--w); }
.ci-value a:hover { color:var(--red); }
.hours-block { margin-top:1.8rem; }
.hours-block h4 { font-size:.62rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--wm); margin-bottom:.8rem; }
.hours-row { display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px solid var(--bdr); font-size:.83rem; }
.hours-day    { color:var(--wm); }
.hours-time   { color:var(--w); font-weight:600; }
.hours-closed { color:var(--red); }
.map-box { height:185px; background:var(--c3); border:1px solid var(--bdr); margin-top:1.8rem; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:.5rem; overflow:hidden; position:relative; }
.map-box iframe { position:absolute; inset:0; width:100%; height:100%; border:none; opacity:.85; }
.map-placeholder-text { font-size:.63rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--wd); text-align:center; }
.cf-box { background:var(--c2); border:1px solid var(--bdr2); padding:2.8rem; position:relative; }
.cf-box::before { content:''; position:absolute; top:0; left:0; right:0; height:2px; background:linear-gradient(90deg,transparent,var(--red),transparent); }
.cf-box h3 { font-family:var(--f1); font-size:1.4rem; text-transform:uppercase; margin-bottom:.3rem; }
.cf-box > p { font-size:.8rem; color:var(--wm); margin-bottom:1.9rem; }
.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:.9rem; }
.field-group { display:flex; flex-direction:column; gap:5px; margin-bottom:.9rem; }
.field-group label { font-size:.62rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--wm); }
.field-group label .req { color:var(--red); }
.field-group input,.field-group select,.field-group textarea { background:var(--c3); border:1px solid var(--bdr); padding:11px 13px; font-family:var(--f2); font-size:.83rem; color:var(--w); outline:none; transition:border-color .2s; width:100%; appearance:none; }
.field-group input:focus,.field-group select:focus,.field-group textarea:focus { border-color:var(--red); }
.field-group input::placeholder,.field-group textarea::placeholder { color:var(--wd); }
.field-group textarea { resize:vertical; min-height:112px; }
.field-group.error input,.field-group.error select,.field-group.error textarea { border-color:var(--red); }
.field-error { font-size:.66rem; color:var(--red); display:none; }
.field-group.error .field-error { display:block; }
.form-success { display:none; align-items:center; gap:9px; background:rgba(0,217,139,.09); border:1px solid rgba(0,217,139,.28); padding:.85rem 1.1rem; font-size:.8rem; color:var(--green); margin-top:.9rem; }
.form-success.visible { display:flex; }

/* ── 17. FOOTER ───────────────────────────────────────────── */
#footer { background:var(--c1); border-top:1px solid var(--bdr); }
.footer-cols { display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:3.5rem; padding-block:4rem; }
.footer-brand p { font-size:.82rem; color:var(--wd); line-height:1.72; max-width:265px; margin:.8rem 0 1.3rem; }
.footer-socials { display:flex; gap:.6rem; }
.footer-social { width:36px; height:36px; background:var(--c3); border:1px solid var(--bdr); clip-path:polygon(0 0,calc(100% - 6px) 0,100% 100%,6px 100%); display:flex; align-items:center; justify-content:center; font-size:.9rem; transition:all .2s; cursor:pointer; text-decoration:none; }
.footer-social:hover { background:var(--red); border-color:var(--red); }
.footer-col h4 { font-size:.65rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--w); margin-bottom:1.1rem; }
.footer-col ul { display:flex; flex-direction:column; gap:.65rem; }
.footer-col ul li a { font-size:.82rem; color:var(--wd); transition:color .2s; }
.footer-col ul li a:hover { color:var(--red); }
.footer-contact-list { display:flex; flex-direction:column; gap:.7rem; }
.footer-ci { display:flex; gap:9px; font-size:.79rem; color:var(--wd); align-items:flex-start; line-height:1.5; }
.footer-ci-icon { color:var(--red); flex-shrink:0; margin-top:1px; font-size:.85rem; }
.footer-ci a { color:var(--wd); }
.footer-ci a:hover { color:var(--red); }
.footer-bottom { border-top:1px solid var(--bdr); padding:1.3rem 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.8rem; }
.footer-copy { font-size:.72rem; color:var(--wd); }
.footer-copy span { color:var(--red); }
.footer-legal { display:flex; gap:1.3rem; }
.footer-legal a { font-size:.69rem; color:var(--wd); transition:color .2s; }
.footer-legal a:hover { color:var(--w); }

/* ── 18. BACK TO TOP ──────────────────────────────────────── */
#btt { position:fixed; bottom:1.8rem; right:1.8rem; width:46px; height:46px; background:var(--red); border:none; cursor:pointer; color:#fff; font-size:1rem; display:flex; align-items:center; justify-content:center; clip-path:polygon(0 0,calc(100% - 8px) 0,100% 100%,8px 100%); opacity:0; transform:translateY(16px); transition:all .3s; z-index:500; }
#btt.visible { opacity:1; transform:translateY(0); }
#btt:hover { background:var(--red2); }

/* ── 19. SCROLL REVEAL ────────────────────────────────────── */
.reveal { opacity:0; transform:translateY(26px); transition:opacity .65s var(--ease),transform .65s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}

/* ── 20. RESPONSIVE ───────────────────────────────────────── */
@media (max-width:1100px) { .footer-cols{grid-template-columns:1fr 1fr;gap:2.5rem;} }
@media (max-width:860px)  { .about-grid{grid-template-columns:1fr;} .contact-grid{grid-template-columns:1fr;} }
@media (max-width:768px) {
  .nav-links { position:fixed; top:68px; right:0; width:270px; height:calc(100vh - 68px); background:var(--c1); border-left:1px solid var(--bdr); flex-direction:column; align-items:flex-start; padding:2rem; gap:1.3rem; transform:translateX(100%); transition:transform .4s var(--ease); overflow-y:auto; }
  .nav-links.open { transform:translateX(0); }
  .nav-links a { font-size:.92rem; }
  .burger { display:flex; }
  .hero-inner { grid-template-columns:1fr; }
  .obd-card { display:none; }
  .hero-stats { flex-wrap:wrap; gap:1.5rem; }
  .photo-grid { grid-template-rows:170px 125px; }
  .team-row { grid-template-columns:1fr 1fr 1fr; }
  .footer-cols { grid-template-columns:1fr; gap:1.8rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .form-row-2 { grid-template-columns:1fr; }
  .cf-box { padding:1.5rem; }
}
@media (max-width:480px) {
  .hero-stats { flex-direction:column; gap:1rem; }
  .hero-btns  { flex-direction:column; }
  .cta-btns   { flex-direction:column; align-items:center; }
  .team-row   { grid-template-columns:1fr 1fr; }
}
