  :root{
    --void:#0a0e12;
    --panel:#141c23;
    --panel-edge:#22303a;
    --cyan:#3ff0e8;
    --cyan-dim:#1f4d4a;
    --boost:#ff4429;
    --ink:#f0f4f4;
    --ink-dim:#a8bfbf;
    --display: 'Anton', sans-serif;
    --body: 'Inter', sans-serif;
    --mono: 'JetBrains Mono', monospace;
  }

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

  html{ scroll-behavior:smooth; }

  body{
    background:var(--void);
    color:var(--ink);
    font-family:var(--body);
    line-height:1.6;
    overflow-x:hidden;
  }

  /* ===== Boost gauge — fixed, signature element ===== */
  .gauge-wrap{
    position:fixed;
    top:50%;
    right:24px;
    transform:translateY(-50%);
    width:88px;
    height:88px;
    z-index:50;
    pointer-events:none;
    opacity:0;
    transition:opacity .6s ease;
  }
  .gauge-wrap.show{ opacity:1; }
  .gauge-wrap svg{ width:100%; height:100%; }
  .gauge-track{ fill:none; stroke:var(--panel-edge); stroke-width:6; }
  .gauge-fill{ fill:none; stroke:var(--cyan); stroke-width:6; stroke-linecap:round;
    transition: stroke-dashoffset .25s linear, stroke .25s linear; }
  .gauge-needle-label{
    fill:var(--ink); font-family:var(--mono); font-size:14px; font-weight:700;
    text-anchor:middle; dominant-baseline:central;
  }
  .gauge-sub{
    fill:var(--ink-dim); font-family:var(--mono); font-size:6px;
    text-anchor:middle; letter-spacing:1px;
  }
  @media (max-width:880px){ .gauge-wrap{ display:none; } }

  /* ===== Top bar ===== */
  .topbar{
    position:fixed; top:0; left:0; right:0; z-index:100;
    display:flex; align-items:center; justify-content:space-between;
    padding:18px 28px;
    background:rgba(10,14,18,.75);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(63,240,232,.08);
  }
  .topbar .mark{
    font-family:var(--display);
    font-size:1.3rem;
    letter-spacing:2px;
    color:var(--ink);
    text-decoration:none;
    display:flex;
    align-items:center;
    gap:10px;
  }
  .topbar .mark img{
    width:40px;
    height:40px;
    display:block;
    flex-shrink:0;
  }
  .topbar .mark .word{ letter-spacing:2px; }
  .topbar .mark span{ color:var(--cyan); }
  .topbar .call{
    font-family:var(--mono);
    font-size:.78rem;
    color:var(--cyan);
    text-decoration:none;
    border:1px solid var(--cyan-dim);
    padding:8px 16px;
    border-radius:2px;
    letter-spacing:1px;
    transition:.2s;
    white-space:nowrap;
  }
  .topbar .call:hover{ background:var(--cyan); color:var(--void); }

  .topnav{
    display:flex;
    align-items:center;
    gap:28px;
  }
  .topnav a{
    font-family:var(--mono);
    font-size:.78rem;
    letter-spacing:1px;
    color:var(--ink-dim);
    text-decoration:none;
    text-transform:uppercase;
    transition:color .2s ease;
  }
  .topnav a:hover{ color:var(--cyan); }
  .burger{
    display:none;
    flex-direction:column;
    justify-content:center;
    gap:5px;
    width:36px; height:36px;
    background:none;
    border:1px solid var(--cyan-dim);
    border-radius:2px;
    cursor:pointer;
    padding:8px;
  }
  .burger span{
    display:block;
    height:1px;
    background:var(--cyan);
    border-radius:1px;
    transition:transform .25s ease, opacity .2s ease;
  }
  .burger.open span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
  .burger.open span:nth-child(2){ opacity:0; }
  .burger.open span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }

  .mobile-menu{
    display:none;
    position:fixed;
    top:61px; left:0; right:0;
    background:rgba(10,14,18,.97);
    backdrop-filter:blur(16px);
    border-bottom:1px solid rgba(63,240,232,.12);
    z-index:99;
    padding:0;
    flex-direction:column;
  }
  .mobile-menu.open{ display:flex; }
  .mobile-menu a{
    font-family:var(--mono);
    font-size:.85rem;
    letter-spacing:2px;
    color:var(--ink-dim);
    text-decoration:none;
    text-transform:uppercase;
    padding:18px 28px;
    border-bottom:1px solid rgba(63,240,232,.07);
    transition:color .2s, background .2s;
  }
  .mobile-menu a:last-child{ border-bottom:none; }
  .mobile-menu a:hover{ color:var(--cyan); background:rgba(63,240,232,.04); }

  @media (max-width:880px){
    .topnav{ display:none; }
    .burger{ display:flex; }
  }

  /* ===== Hero ===== */
  .hero{
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    padding:120px 8vw 80px;
    overflow:hidden;
  }
  .hero-bg{
    position:fixed; inset:0;
    z-index:-1;
    background-image:url('hero-skyline.jpg');
    background-size:cover;
    background-position:center 40%;
    opacity:.52;
    filter:grayscale(.15) contrast(1.05) brightness(1);
  }
  .hero::after{
    content:'';
    position:absolute; inset:0;
    background:linear-gradient(100deg, rgba(8,11,13,.82) 30%, rgba(8,11,13,.35) 65%, rgba(8,11,13,.08) 100%);
  }
  .hero-grid{
    position:absolute; inset:0;
    background-image:
      repeating-linear-gradient(0deg, transparent, transparent 38px, rgba(63,240,232,.025) 39px),
      repeating-linear-gradient(90deg, transparent, transparent 38px, rgba(63,240,232,.025) 39px);
    pointer-events:none;
  }
  .hero-mark{
    position:absolute;
    bottom:-8%;
    right:-4%;
    width:min(34vw, 420px);
    height:min(34vw, 420px);
    opacity:.06;
    z-index:1;
    pointer-events:none;
  }
  @media (max-width:880px){ .hero-mark{ display:none; } }

  /* ===== Speed lines — motion signature ===== */
  .speed-lines{
    position:absolute;
    inset:0;
    overflow:hidden;
    pointer-events:none;
    z-index:1;
  }
  .speed-line{
    position:absolute;
    height:1px;
    width:140px;
    background:linear-gradient(90deg, transparent, var(--cyan), transparent);
    opacity:0;
    animation: streak 3.2s ease-in infinite;
  }
  .speed-line.fast{ animation-duration: 1.8s; background:linear-gradient(90deg, transparent, var(--boost), transparent); }
  .speed-line.slow{ animation-duration: 4.6s; width:220px; }

  @keyframes streak{
    0%{ transform:translateX(-200px); opacity:0; }
    8%{ opacity:.55; }
    35%{ opacity:.25; }
    60%{ opacity:0; }
    100%{ transform:translateX(calc(100vw + 200px)); opacity:0; }
  }

  @media (prefers-reduced-motion: reduce){
    .speed-line{ display:none; }
  }
  .hero-content{ position:relative; z-index:2; max-width:680px; }
  .eyebrow{
    font-family:var(--mono);
    font-size:.78rem;
    letter-spacing:4px;
    color:var(--cyan);
    text-transform:uppercase;
    display:flex; align-items:center; gap:12px;
    margin-bottom:22px;
  }
  .eyebrow::before{
    content:'';
    display:inline-block;
    width:32px; height:1px;
    background:var(--cyan);
  }
  .hero h1{
    font-family:var(--display);
    font-size:clamp(3.2rem, 9vw, 7rem);
    line-height:0.98;
    letter-spacing:1px;
    text-transform:uppercase;
    margin-bottom:24px;
  }
  .hero h1 .accent{ color:var(--cyan); }
  .hero p{
    font-size:1.05rem;
    color:var(--ink-dim);
    max-width:480px;
    margin-bottom:38px;
  }
  .hero-ctas{ display:flex; gap:16px; flex-wrap:wrap; }
  .btn{
    font-family:var(--mono);
    font-weight:700;
    font-size:.85rem;
    letter-spacing:1.5px;
    text-transform:uppercase;
    padding:17px 32px;
    border-radius:2px;
    text-decoration:none;
    display:inline-flex;
    align-items:center;
    gap:10px;
    transition:.2s;
    border:1px solid transparent;
  }
  .btn-primary{ background:var(--cyan); color:var(--void); }
  .btn-primary:hover{ background:#7ffaf4; transform:translateY(-2px); }
  .btn-ghost{ border-color:rgba(240,244,244,.2); color:var(--ink); }
  .btn-ghost:hover{ border-color:var(--cyan); color:var(--cyan); }

  .hero-readout{
    position:absolute; bottom:48px; left:8vw; z-index:2;
    display:flex; gap:36px; flex-wrap:wrap;
  }
  .readout-item{ font-family:var(--mono); }
  .readout-item .num{ font-size:1.6rem; color:var(--cyan); font-weight:700; display:block; margin-bottom:4px; }
  .readout-item .lbl{ font-size:.7rem; color:var(--ink-dim); letter-spacing:2px; text-transform:uppercase; display:block; }

  @media (max-width:720px){
    .hero{ padding:100px 6vw 60px; align-items:flex-start; padding-top:140px;}
    .hero-readout{ position:static; margin-top:48px; left:0; }
  }

  /* ===== Section frame ===== */
  section{ position:relative; padding:110px 8vw; }
  .section-head{ margin-bottom:64px; max-width:640px; }
  .section-head .eyebrow{ margin-bottom:18px; }
  .section-head h2{
    font-family:var(--display);
    font-size:clamp(2.2rem, 5vw, 4rem);
    text-transform:uppercase;
    line-height:1.05;
    letter-spacing:.5px;
  }
  .section-head h2 .accent{ color:var(--cyan); }
  .section-head .lede{
    margin-top:18px;
    color:var(--ink-dim);
    font-size:1.02rem;
    max-width:540px;
  }

  /* ===== Divider — diagonal tick, echoing the brand artwork ===== */
  .divider{
    height:64px;
    width:100%;
    position:relative;
    overflow:hidden;
  }
  .divider svg{ width:100%; height:100%; display:block; }
  .divider polyline{
    animation: chevron-pulse 2.4s ease-in-out infinite;
  }
  .divider polyline:nth-child(3){ animation-delay:.15s; }
  .divider polyline:nth-child(4){ animation-delay:.3s; }
  @keyframes chevron-pulse{
    0%, 100%{ transform:translateX(0); }
    50%{ transform:translateX(10px); }
  }
  @media (prefers-reduced-motion: reduce){
    .divider polyline{ animation:none; }
  }

  /* ===== Services — dyno sheet ===== */
  .dyno-sheet{
    border:1px solid var(--panel-edge);
    background:var(--panel);
    border-radius:4px;
    overflow:hidden;
  }
  .dyno-row{
    display:grid;
    grid-template-columns:1fr auto;
    align-items:baseline;
    gap:24px;
    padding:26px 32px;
    border-bottom:1px dashed var(--panel-edge);
    transition: padding-left .25s ease, background .25s ease;
  }
  .dyno-row:hover{
    padding-left:44px;
    background:rgba(63,240,232,.03);
  }
  .dyno-row:last-child{ border-bottom:none; }
  .dyno-row .label{
    font-size:1.05rem;
    font-weight:600;
  }
  .dyno-row .label small{
    display:block;
    font-family:var(--mono);
    font-size:.75rem;
    color:var(--ink-dim);
    font-weight:400;
    margin-top:4px;
    letter-spacing:.5px;
  }
  .dyno-row .price{
    font-family:var(--mono);
    font-size:1.4rem;
    font-weight:700;
    color:var(--cyan);
    white-space:nowrap;
  }
  .dyno-row.featured{
    background:linear-gradient(90deg, rgba(63,240,232,.06), transparent);
    position:relative;
  }
  .dyno-row.featured::before{
    content:'BEST VALUE';
    position:absolute;
    top:-1px; right:32px;
    font-family:var(--mono);
    font-size:.62rem;
    letter-spacing:2px;
    color:var(--void);
    background:var(--cyan);
    padding:4px 10px;
    border-radius:0 0 3px 3px;
  }
  .dyno-row.featured .price{ color:var(--boost); }
  .dyno-row.note .label{ font-style:italic; color:var(--ink-dim); font-weight:400; }
  .dyno-row.note .price{ color:var(--ink-dim); font-size:1rem; }

  .services-foot{
    margin-top:24px;
    font-family:var(--mono);
    font-size:.8rem;
    color:var(--ink-dim);
    letter-spacing:.5px;
  }
  .services-foot strong{ color:var(--cyan); }

  /* ===== Vehicle Finder / Viezu partner section ===== */
  .finder-grid{
    display:grid;
    grid-template-columns: 1fr 1.15fr;
    gap:48px;
    align-items:start;
  }
  .finder-intro .badge-row{
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:20px;
  }
  .finder-intro .badge-row img{ width:36px; height:36px; opacity:.9; }
  .finder-intro .badge-row .partner-tag{
    font-family:var(--mono);
    font-size:.72rem;
    letter-spacing:1.5px;
    color:var(--cyan);
    text-transform:uppercase;
    border:1px solid var(--cyan-dim);
    padding:5px 12px;
    border-radius:2px;
  }
  .finder-intro p{ color:var(--ink-dim); margin-bottom:16px; font-size:.98rem; max-width:480px; }
  .finder-trust{
    display:grid;
    grid-template-columns:repeat(2, 1fr);
    gap:14px;
    margin-top:28px;
  }
  .finder-trust .trust-item{
    border:1px solid var(--panel-edge);
    border-radius:3px;
    padding:14px 16px;
    font-family:var(--mono);
    font-size:.78rem;
    color:var(--ink-dim);
    line-height:1.5;
  }
  .finder-trust .trust-item strong{
    display:block;
    color:var(--ink);
    font-family:var(--body);
    font-size:.92rem;
    font-weight:600;
    margin-bottom:2px;
  }

  .finder-card{
    background:var(--panel);
    border:1px solid var(--panel-edge);
    border-radius:4px;
    padding:36px;
  }
  .finder-card .finder-head{
    display:flex;
    justify-content:space-between;
    align-items:baseline;
    margin-bottom:24px;
    gap:12px;
    flex-wrap:wrap;
  }
  .finder-card .finder-head h3{
    font-family:var(--display);
    font-size:1.5rem;
    text-transform:uppercase;
    letter-spacing:.5px;
  }
  .finder-card .finder-head span{
    font-family:var(--mono);
    font-size:.7rem;
    color:var(--ink-dim);
    letter-spacing:1px;
  }
  .finder-fields{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
    margin-bottom:22px;
  }
  .finder-field{ display:flex; flex-direction:column; gap:7px; }
  .finder-field label{
    font-family:var(--mono);
    font-size:.68rem;
    letter-spacing:1.5px;
    text-transform:uppercase;
    color:var(--ink-dim);
  }
  .finder-field select,
  .finder-field input[type="text"]{
    appearance:none;
    background:var(--void);
    border:1px solid var(--panel-edge);
    color:var(--ink);
    font-family:var(--body);
    font-size:.92rem;
    padding:12px 14px;
    border-radius:2px;
    cursor:pointer;
    transition:border-color .2s ease;
  }
  .finder-field select{
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%233ff0e8'/%3E%3C/svg%3E");
    background-repeat:no-repeat;
    background-position:right 14px center;
  }
  .finder-field input[type="text"]{ cursor:text; }
  .finder-field input[type="text"]::placeholder{ color:var(--ink-dim); opacity:.6; }
  .finder-field select:focus,
  .finder-field input[type="text"]:focus{ outline:none; border-color:var(--cyan); }
  .finder-field select:disabled,
  .finder-field input[type="text"]:disabled{ opacity:.4; cursor:not-allowed; }

  .finder-submit{
    width:100%;
    font-family:var(--mono);
    font-weight:700;
    font-size:.85rem;
    letter-spacing:1.5px;
    text-transform:uppercase;
    padding:16px 0;
    border-radius:2px;
    border:none;
    background:var(--cyan);
    color:var(--void);
    cursor:pointer;
    transition:.2s;
  }
  .finder-submit:hover{ background:#7ffaf4; }
  .finder-submit:disabled{ opacity:.4; cursor:not-allowed; }

  .finder-note{
    margin-top:16px;
    font-family:var(--mono);
    font-size:.72rem;
    color:var(--ink-dim);
    line-height:1.6;
  }
  .finder-note a{ color:var(--cyan); text-decoration:none; }
  .finder-note a:hover{ text-decoration:underline; }

  @media (max-width:880px){
    .finder-grid{ grid-template-columns:1fr; gap:36px; }
    .finder-fields{ grid-template-columns:1fr; }
    .finder-trust{ grid-template-columns:1fr; }
  }

  /* ===== Showcase ===== */
  .showcase{
    display:grid;
    grid-template-columns: 1.3fr 1fr;
    gap:2px;
    border:1px solid var(--panel-edge);
    border-radius:4px;
    overflow:hidden;
  }
  .showcase-img{
    position:relative;
    min-height:480px;
  }
  .showcase-img .bg{
    position:absolute; inset:0;
    background-image:url('hero-taillights.jpg');
    background-size:cover;
    background-position:center 40%;
  }
  .showcase-img::after{
    content:'';
    position:absolute; inset:0;
    background:linear-gradient(180deg, transparent 60%, rgba(8,11,13,.75));
  }
  .showcase-img .tag{
    position:absolute; bottom:24px; left:24px; z-index:2;
    font-family:var(--mono);
    font-size:.75rem;
    letter-spacing:2px;
    color:var(--cyan);
    text-transform:uppercase;
  }
  .showcase-text{
    background:var(--panel);
    padding:48px;
    display:flex;
    flex-direction:column;
    justify-content:center;
  }
  .showcase-text h3{
    font-family:var(--display);
    font-size:clamp(2rem, 4vw, 3rem);
    text-transform:uppercase;
    line-height:1.05;
    margin-bottom:20px;
  }
  .showcase-text h3 .accent{ color:var(--cyan); }
  .showcase-text p{ color:var(--ink-dim); margin-bottom:14px; font-size:.98rem; }
  .showcase-tagline{
    margin-top:18px;
    font-family:var(--mono);
    font-size:.78rem;
    letter-spacing:2px;
    color:var(--boost);
    text-transform:uppercase;
  }

  @media (max-width:880px){
    .showcase{ grid-template-columns:1fr; }
    .showcase-img{ min-height:320px; }
  }

  /* ===== Process ===== */
  .process-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:1px;
    background:var(--panel-edge);
    border:1px solid var(--panel-edge);
    border-radius:4px;
    overflow:hidden;
  }
  .process-step{
    background:var(--panel);
    padding:40px 32px;
    transition: transform .25s ease, background .25s ease;
  }
  .process-step:hover{
    transform:translateX(6px);
    background:#121a20;
  }
  .process-step .step-id{
    font-family:var(--mono);
    font-size:.75rem;
    color:var(--cyan);
    letter-spacing:2px;
    margin-bottom:18px;
    display:block;
  }
  .process-step h4{
    font-family:var(--display);
    font-size:1.4rem;
    text-transform:uppercase;
    margin-bottom:12px;
    letter-spacing:.5px;
  }
  .process-step p{ color:var(--ink-dim); font-size:.92rem; }

  @media (max-width:880px){
    .process-grid{ grid-template-columns:1fr; }
  }

  /* ===== Contact ===== */
  .contact-wrap{
    display:grid;
    grid-template-columns:1.1fr 1fr;
    gap:64px;
    align-items:start;
  }
  .contact-card{
    border:1px solid var(--panel-edge);
    background:var(--panel);
    border-radius:4px;
    padding:40px;
  }
  .contact-row{
    display:flex;
    gap:18px;
    align-items:flex-start;
    padding:18px 0;
    border-bottom:1px solid var(--panel-edge);
  }
  .contact-row:last-child{ border-bottom:none; }
  .contact-row .icon{
    width:40px; height:40px;
    border:1px solid var(--cyan-dim);
    border-radius:2px;
    display:flex; align-items:center; justify-content:center;
    flex-shrink:0;
    color:var(--cyan);
    font-family:var(--mono);
    font-weight:700;
  }
  .contact-row .info .k{
    font-family:var(--mono);
    font-size:.7rem;
    letter-spacing:2px;
    color:var(--ink-dim);
    text-transform:uppercase;
    margin-bottom:6px;
  }
  .contact-row .info .v{ font-size:1.05rem; font-weight:600; }
  .contact-row .info .v a{ color:var(--ink); text-decoration:none; }
  .contact-row .info .v a:hover{ color:var(--cyan); }
  .contact-row .info .v small{
    display:block; font-weight:400; color:var(--ink-dim); font-size:.85rem; margin-top:2px;
  }

  .contact-cta h2{
    font-family:var(--display);
    font-size:clamp(2.2rem, 5vw, 3.6rem);
    text-transform:uppercase;
    line-height:1.05;
    margin-bottom:22px;
  }
  .contact-cta h2 .accent{ color:var(--cyan); }
  .contact-cta p{ color:var(--ink-dim); margin-bottom:32px; max-width:440px; }
  .contact-cta .btn-primary{ background:var(--boost); color:var(--void); }
  .contact-cta .btn-primary:hover{ background:#ff7a64; }

  @media (max-width:880px){
    .contact-wrap{ grid-template-columns:1fr; gap:48px; }
  }

  /* ===== Footer ===== */
  footer{
    border-top:1px solid var(--panel-edge);
    padding:36px 8vw;
    display:flex;
    justify-content:space-between;
    align-items:center;
    flex-wrap:wrap;
    gap:16px;
    font-family:var(--mono);
    font-size:.75rem;
    color:var(--ink-dim);
    letter-spacing:1px;
  }
  footer .mark{
    color:var(--cyan);
    font-family:var(--display);
    font-size:1rem;
    letter-spacing:2px;
    display:flex;
    align-items:center;
    gap:10px;
  }
  footer .mark img{ width:24px; height:24px; opacity:.8; }

  /* Reveal on scroll — progressive enhancement only */
  .js .reveal{
    opacity:0;
    transform:translateY(28px);
    transition:opacity .7s ease, transform .7s ease;
  }
  .js .reveal.in{ opacity:1; transform:translateY(0); }

  /* Focus visibility */
  a:focus-visible, button:focus-visible{
    outline:2px solid var(--cyan);
    outline-offset:3px;
  }

  @media (prefers-reduced-motion: reduce){
    *{ transition:none !important; scroll-behavior:auto !important; }
  }

/* ===== MERCH PAGE ===== */

.merch-hero{
  position:relative;
  min-height:52vh;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:140px 8vw 0;
  overflow:hidden;
}
.merch-hero .hero-bg{
  position:absolute; inset:0;
  z-index:0;
  opacity:.35;
}
.merch-hero .hero-grid{ position:absolute; inset:0; z-index:1; }
.merch-hero::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,14,18,.6) 0%, rgba(10,14,18,.92) 100%);
  z-index:2;
}
.merch-hero-content{
  position:relative; z-index:3;
  max-width:640px;
  padding-bottom:40px;
}
.merch-hero-content h1{
  font-family:var(--display);
  font-size:clamp(3rem,8vw,6rem);
  line-height:.95;
  letter-spacing:2px;
  margin:16px 0 18px;
  color:var(--ink);
}
.merch-hero-content p{
  font-size:1.05rem;
  color:var(--ink-dim);
  max-width:480px;
}

/* Coming soon banner */
.merch-coming-soon{
  position:relative; z-index:3;
  background:rgba(63,240,232,.06);
  border-top:1px solid rgba(63,240,232,.18);
  border-bottom:1px solid rgba(63,240,232,.18);
  padding:28px 8vw;
  margin:0 -8vw;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:16px 32px;
}
.cs-pill{
  font-family:var(--mono);
  font-size:.7rem;
  letter-spacing:2px;
  color:var(--void);
  background:var(--cyan);
  padding:5px 12px;
  border-radius:2px;
  white-space:nowrap;
  flex-shrink:0;
}
.merch-coming-soon p{
  font-size:.9rem;
  color:var(--ink-dim);
  margin:0;
  flex:1;
  min-width:200px;
}
.cs-form{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.cs-form input{
  font-family:var(--mono);
  font-size:.82rem;
  background:rgba(255,255,255,.05);
  border:1px solid var(--panel-edge);
  color:var(--ink);
  padding:10px 16px;
  border-radius:2px;
  outline:none;
  width:220px;
  transition:border .2s;
}
.cs-form input:focus{ border-color:var(--cyan); }
.cs-form button{
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:1px;
  background:var(--cyan);
  color:var(--void);
  border:none;
  padding:10px 20px;
  border-radius:2px;
  cursor:pointer;
  text-transform:uppercase;
  transition:background .2s;
}
.cs-form button:hover{ background:#7ffaf4; }
.cs-confirm{
  font-family:var(--mono);
  font-size:.85rem;
  color:var(--cyan);
  letter-spacing:1px;
}

/* Filter bar */
.merch-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:40px 8vw 0;
}
.mf-btn{
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:1px;
  text-transform:uppercase;
  background:none;
  border:1px solid var(--panel-edge);
  color:var(--ink-dim);
  padding:8px 18px;
  border-radius:2px;
  cursor:pointer;
  transition:all .2s;
}
.mf-btn:hover{ border-color:var(--cyan); color:var(--cyan); }
.mf-btn.active{ background:var(--cyan); color:var(--void); border-color:var(--cyan); }

/* Product grid */
.merch-grid-wrap{
  padding:40px 8vw 80px;
}
.merch-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:24px;
}
.merch-card{
  background:var(--panel);
  border:1px solid var(--panel-edge);
  border-radius:3px;
  overflow:hidden;
  transition:transform .25s ease, border-color .25s ease;
}
.merch-card:hover{
  transform:translateY(-4px);
  border-color:var(--cyan-dim);
}
.merch-img{
  position:relative;
  aspect-ratio:4/3;
  background:var(--void);
  overflow:hidden;
}
.merch-img-placeholder{
  position:absolute; inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px dashed rgba(63,240,232,.2);
  margin:16px;
  border-radius:2px;
}
.merch-img-placeholder span{
  font-family:var(--mono);
  font-size:.65rem;
  letter-spacing:2px;
  color:rgba(63,240,232,.25);
  text-align:center;
  line-height:1.8;
}
.merch-badge{
  position:absolute;
  top:12px; right:12px;
  font-family:var(--mono);
  font-size:.62rem;
  letter-spacing:2px;
  background:var(--boost);
  color:#fff;
  padding:4px 9px;
  border-radius:2px;
}
.merch-info{
  padding:18px 20px 20px;
}
.merch-cat{
  font-family:var(--mono);
  font-size:.65rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:6px;
}
.merch-name{
  font-family:var(--body);
  font-size:1rem;
  font-weight:600;
  color:var(--ink);
  margin-bottom:8px;
  line-height:1.3;
}
.merch-sizes{
  font-family:var(--mono);
  font-size:.68rem;
  color:var(--ink-dim);
  letter-spacing:.5px;
  margin-bottom:16px;
}
.merch-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.merch-price{
  font-family:var(--mono);
  font-size:1.1rem;
  font-weight:700;
  color:var(--ink);
}
.merch-btn{
  font-family:var(--mono);
  font-size:.7rem;
  letter-spacing:1px;
  text-transform:uppercase;
  padding:8px 16px;
  border-radius:2px;
  border:1px solid var(--panel-edge);
  background:none;
  color:var(--ink-dim);
  cursor:not-allowed;
  white-space:nowrap;
}
.merch-btn:not([disabled]){
  border-color:var(--cyan);
  color:var(--cyan);
  cursor:pointer;
  transition:all .2s;
}
.merch-btn:not([disabled]):hover{
  background:var(--cyan);
  color:var(--void);
}

/* Bottom CTA strip */
.merch-cta-strip{
  background:var(--panel);
  border-top:1px solid var(--panel-edge);
  border-bottom:1px solid var(--panel-edge);
  padding:60px 8vw;
}
.merch-cta-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:32px;
  max-width:900px;
}
.merch-cta-inner h3{
  font-family:var(--display);
  font-size:clamp(1.6rem,3vw,2.4rem);
  letter-spacing:1px;
  margin:10px 0 10px;
  color:var(--ink);
}
.merch-cta-inner p{
  color:var(--ink-dim);
  max-width:460px;
}

/* Responsive */
@media(max-width:600px){
  .merch-coming-soon{ flex-direction:column; align-items:flex-start; }
  .cs-form{ width:100%; }
  .cs-form input{ width:100%; }
  .merch-grid{ grid-template-columns:1fr 1fr; gap:14px; }
  .merch-cta-inner{ flex-direction:column; }
}
@media(max-width:400px){
  .merch-grid{ grid-template-columns:1fr; }
}

/* ===== Merch product photos ===== */
.merch-photo{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center;
  opacity:0;
  transition:opacity .35s ease;
}
.merch-photo.active{ opacity:1; }

/* Front/back image toggle */
.merch-img-switch{ position:relative; }
.merch-img-toggle{
  position:absolute;
  bottom:10px; left:10px;
  display:flex;
  gap:6px;
  z-index:3;
}
.mit-btn{
  font-family:var(--mono);
  font-size:.62rem;
  letter-spacing:1px;
  text-transform:uppercase;
  padding:5px 10px;
  border-radius:2px;
  border:1px solid rgba(63,240,232,.4);
  background:rgba(10,14,18,.75);
  color:var(--ink-dim);
  cursor:pointer;
  transition:all .2s;
  backdrop-filter:blur(4px);
}
.mit-btn.active,
.mit-btn:hover{
  background:var(--cyan);
  color:var(--void);
  border-color:var(--cyan);
}
