/* ============================================================
   HoweTech-JSW Theme — theme.css
   Full front-end stylesheet ported from preview.html
   ============================================================ */

/* 1. CSS Custom Properties */
:root {
  --black:    #0C0C0C;
  --charcoal: #1A1A1A;
  --red:      #C41E3A;
  --red-dk:   #9E1830;
  --cream:    #F2F0EB;
  --white:    #FFFFFF;
  --gray-100: #EAEAEA;
  --gray-300: #9A9A9A;
  --font-d: 'Bebas Neue', sans-serif;
  --font-b: 'Barlow', sans-serif;
  --max:    1200px;
  --ease:   0.22s ease;
}

/* 2. Reset + Base */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  font-family: var(--font-b);
  background: var(--cream);
  color: var(--black);
  overflow-x: hidden;
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cline x1='16' y1='2' x2='16' y2='12' stroke='%23C41E3A' stroke-width='1.5'/%3E%3Cline x1='16' y1='20' x2='16' y2='30' stroke='%23C41E3A' stroke-width='1.5'/%3E%3Cline x1='2' y1='16' x2='12' y2='16' stroke='%23C41E3A' stroke-width='1.5'/%3E%3Cline x1='20' y1='16' x2='30' y2='16' stroke='%23C41E3A' stroke-width='1.5'/%3E%3Ccircle cx='16' cy='16' r='3.5' stroke='%23C41E3A' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") 16 16, crosshair;
}

a, button, [onclick], label, select, .bcard, .bpg__combo-link, .calc__btn, .calc__order-btn { cursor: pointer; }

/* 3. Skip Link (WCAG) */
.skip-link {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.skip-link:focus {
  position: fixed;
  top: 0;
  left: 0;
  width: auto;
  height: auto;
  background: var(--red);
  color: var(--white);
  font-family: var(--font-b);
  font-size: 1rem;
  font-weight: 600;
  padding: 0.75rem 1.5rem;
  z-index: 99999;
  outline: 3px solid var(--white);
  text-decoration: none;
}

/* 4. License Notice Card */
.htech-license-notice {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9990;
  background: #ff9800;
  color: #000;
  padding: 0.75rem 2.5rem;
}
.htech-license-notice__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.htech-license-notice__icon { font-size: 1.25rem; flex-shrink: 0; }
.htech-license-notice__body { flex: 1; font-size: 0.88rem; line-height: 1.5; }
.htech-license-notice__btn {
  display: inline-block;
  padding: 0.45rem 1.25rem;
  background: #000;
  color: #fff;
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  white-space: nowrap;
}
body.htech-unlicensed .hdr { top: 48px; }
body.htech-unlicensed .hero { padding-top: calc(96px + 48px + 3rem); }

/* 5. Back-to-Top Button */
#back-to-top {
  position: fixed;
  bottom: 6.5rem;
  right: 2rem;
  z-index: 200;
  width: 44px;
  height: 44px;
  background: var(--charcoal);
  border: 1.5px solid var(--red);
  color: var(--cream);
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.3s ease, transform 0.3s ease, background 0.2s ease;
  pointer-events: none;
  line-height: 1;
}
#back-to-top.vis { opacity: 1; transform: translateY(0); pointer-events: auto; }
#back-to-top:hover { background: var(--red); }

/* 6. Cookie Consent Banner */
.cookie-consent {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9989;
  background: var(--charcoal);
  border-top: 2px solid var(--red);
  padding: 1rem 2.5rem;
  transform: translateY(100%);
  transition: transform 0.4s ease;
}
.cookie-consent.visible { transform: translateY(0); }
.cookie-consent__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.cookie-consent__text { flex: 1; font-size: 0.82rem; color: var(--gray-300); line-height: 1.55; }
.cookie-consent__actions { display: flex; gap: 0.75rem; }
.cookie-consent__btn {
  padding: 0.5rem 1.25rem;
  font-family: var(--font-d);
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  cursor: pointer;
  border: 1.5px solid var(--red);
  transition: background 0.2s ease, color 0.2s ease;
}
.cookie-consent__btn--accept { background: var(--red); color: var(--white); }
.cookie-consent__btn--accept:hover { background: var(--red-dk); border-color: var(--red-dk); }
.cookie-consent__btn--decline { background: none; color: var(--cream); }
.cookie-consent__btn--decline:hover { background: rgba(255,255,255,0.08); }

/* 7. Preloader */
.preloader {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .5s ease .05s, visibility .5s ease .05s;
}
.preloader.gone { opacity: 0; visibility: hidden; pointer-events: none; }
.preloader__logo {
  width: 170px;
  filter: invert(1);
  animation: preloaderIn 1.5s cubic-bezier(.16,1,.3,1) forwards;
}

/* 8. Cursor Trailer */
#cursor-dot {
  position: fixed;
  top: 0;
  left: 0;
  width: 8px;
  height: 8px;
  background: var(--red);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9997;
  opacity: .6;
  will-change: transform;
}
@media (hover: none) { #cursor-dot { display: none; } }

/* 9. Scroll Progress Bar */
#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  width: 0%;
  background: var(--red);
  z-index: 9998;
  pointer-events: none;
}

/* 10. Age Gate */
.gate {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #000;
  background-image:
    linear-gradient(rgba(196,30,58,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(196,30,58,.04) 1px, transparent 1px);
  background-size: 36px 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .55s ease, visibility .55s ease;
}
.gate.gone { opacity: 0; visibility: hidden; pointer-events: none; }
.gate__box { text-align: center; padding: 2.5rem 2rem; max-width: 440px; }
.gate__logo { width: 210px; filter: invert(1); margin-bottom: 2.5rem; animation: fadeUp .6s ease both; }
.gate__title { font-family: var(--font-d); font-size: 2.6rem; letter-spacing: .1em; color: var(--cream); margin-bottom: .4rem; animation: fadeUp .6s .1s ease both; }
.gate__sub { font-size: .88rem; color: var(--gray-300); letter-spacing: .04em; line-height: 1.6; margin-bottom: 2.25rem; animation: fadeUp .6s .2s ease both; }
.gate__row { display: flex; align-items: center; justify-content: center; gap: .75rem; margin-bottom: 1.4rem; animation: fadeUp .6s .3s ease both; }
.gate__row input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--red); cursor: pointer; flex-shrink: 0; }
.gate__row label { font-size: .85rem; color: var(--cream); cursor: pointer; text-align: left; line-height: 1.5; }
.gate__btn { display: block; width: 100%; padding: .95rem 2rem; background: transparent; border: 2px solid #333; color: #444; font-family: var(--font-d); font-size: 1.35rem; letter-spacing: .12em; cursor: not-allowed; transition: all .3s ease; animation: fadeUp .6s .4s ease both; }
.gate__btn.lit { border-color: var(--red); background: var(--red); color: var(--white); cursor: pointer; }
.gate__btn.lit:hover { background: var(--red-dk); border-color: var(--red-dk); }

/* 11. Header */
.hdr {
  position: fixed;
  inset: 0 0 auto;
  z-index: 100;
  height: 96px;
  background: var(--black);
  border-bottom: 2px solid var(--red);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2.5rem;
}
.hdr > a { display: flex; align-items: center; line-height: 0; outline: none; flex-shrink: 0; }
.hdr__logo { height: 80px; filter: invert(1); display: block; mix-blend-mode: screen; }
.hdr__nav { display: flex; gap: 2.5rem; list-style: none; }
.hdr__nav a { font-family: var(--font-d); font-size: 1.05rem; letter-spacing: .1em; color: var(--cream); text-decoration: none; position: relative; padding-bottom: 3px; }
.hdr__nav a::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background: var(--red); transition: width .22s ease; }
.hdr__nav a:hover::after { width: 100%; }
.hdr__burger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.hdr__burger span { display: block; width: 24px; height: 2px; background: var(--cream); }
.hdr__back { display: flex; align-items: center; gap: .45rem; padding: .38rem 1rem .38rem .8rem; background: none; border: 1.5px solid rgba(255,255,255,.22); color: var(--cream); cursor: pointer; flex-shrink: 0; margin-right: .9rem; transition: border-color var(--ease), color var(--ease); }
.hdr__back:hover { border-color: var(--red); color: var(--red); }
.hdr__back-arrow { font-size: 1rem; line-height: 1; }
.hdr__back-label { font-family: var(--font-d); font-size: .82rem; letter-spacing: .14em; line-height: 1; }

/* Scroll spy active state */
.hdr__nav a.active { color: var(--white); }
.hdr__nav a.active::after { width: 100%; }

/* 12. Mobile Navigation */
.nav-mob {
  display: none;
  position: fixed;
  top: 96px;
  left: 0;
  right: 0;
  background: var(--black);
  border-bottom: 1px solid #222;
  z-index: 99;
  padding: 1.5rem 2.5rem;
}
.nav-mob.open { display: block; }
.nav-mob a {
  display: block;
  font-family: var(--font-d);
  font-size: 1.5rem;
  letter-spacing: .08em;
  color: var(--cream);
  text-decoration: none;
  padding: .65rem 0;
  border-bottom: 1px solid #1f1f1f;
}

/* 13. Hero */
.hero {
  min-height: 100vh;
  background-color: var(--black);
  background-image:
    radial-gradient(circle, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0,0,0,.55) 0%, rgba(0,0,0,.22) 50%, rgba(0,0,0,.65) 100%);
  background-size: 22px 22px, 100% 100%;
  background-position: top left, center;
  background-repeat: repeat, no-repeat;
  display: flex;
  align-items: center;
  padding: 96px 2.5rem 3rem;
  position: relative;
  overflow: hidden;
}
.hero__parallax-bg {
  position: absolute;
  top: -200px;
  bottom: -200px;
  left: 0;
  right: 0;
  background: url('../../hero-bg.jpg') center/cover no-repeat;
  will-change: transform;
  z-index: 0;
}
.hero__wm {
  position: absolute;
  right: -1rem;
  bottom: -2rem;
  font-family: var(--font-d);
  font-size: clamp(14rem, 28vw, 26rem);
  color: rgba(255,255,255,.04);
  letter-spacing: -.02em;
  line-height: 1;
  pointer-events: none;
  user-select: none;
  z-index: 1;
}
.hero::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 25%;
  width: 1px;
  height: 50%;
  background: linear-gradient(to bottom, transparent, rgba(196,30,58,.3), transparent);
  pointer-events: none;
  z-index: 1;
}
/* Hero grain overlay */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  opacity: .042;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px;
}
.hero__inner { position: relative; max-width: var(--max); margin: 0 auto; width: 100%; z-index: 2; }
.hero__eye { display: flex; align-items: center; gap: .75rem; font-size: .7rem; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; color: var(--red); margin-bottom: 1.25rem; }
.hero__eye::before { content: ''; display: block; width: 36px; height: 2px; background: var(--red); flex-shrink: 0; }
.hero__h1 { font-family: var(--font-d); font-size: clamp(3.2rem, 7.5vw, 7rem); line-height: .9; letter-spacing: .02em; color: var(--cream); }
.hero__h1 .red { color: var(--red); }
.hero__rule { width: 60px; height: 3px; background: var(--red); margin: 1.1rem 0 1rem; }
.hero__sub { font-size: .97rem; color: rgba(255,255,255,.72); line-height: 1.75; max-width: 480px; margin-bottom: 1.5rem; }
.hero__form { display: flex; max-width: 480px; }
.hero__form input { flex: 1; padding: 1rem 1.25rem; background: rgba(0,0,0,.55); border: 1.5px solid rgba(255,255,255,.35); border-right: none; color: var(--white); font-family: var(--font-b); font-size: .9rem; outline: none; transition: border-color var(--ease), background var(--ease); min-width: 0; }
.hero__form input::placeholder { color: rgba(255,255,255,.55); }
.hero__form input:focus { border-color: rgba(255,255,255,.8); background: rgba(0,0,0,.7); }
.hero__form button { padding: 1rem 1.5rem; background: var(--red); border: 1.5px solid var(--red); color: var(--white); font-family: var(--font-d); font-size: 1rem; letter-spacing: .1em; cursor: pointer; white-space: nowrap; transition: background var(--ease); }
.hero__form button:hover { background: var(--red-dk); border-color: var(--red-dk); }
.hero__fn { margin-top: .65rem; font-size: .72rem; color: rgba(255,255,255,.45); letter-spacing: .04em; }
.hero__scroll { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: .4rem; color: rgba(255,255,255,.4); font-size: .65rem; letter-spacing: .2em; text-transform: uppercase; animation: bounce 2s infinite; }
.hero__scroll::after { content: '↓'; font-size: 1rem; color: var(--red); }

/* Split text reveal */
.split-word { display: inline-block; opacity: 0; }
.split-word.reveal { animation: splitReveal .8s cubic-bezier(.16,1,.3,1) forwards; }

/* 14. Ticker / Marquee */
.ticker { background: var(--red); padding: .65rem 0; overflow: hidden; white-space: nowrap; }
.ticker__track { display: inline-block; animation: scroll-x 32s linear infinite; }
.ticker__item { display: inline; font-family: var(--font-d); font-size: .95rem; letter-spacing: .2em; color: rgba(255,255,255,.9); }
.ticker:hover .ticker__track { animation-play-state: paused; cursor: default; }

/* 15. Section Headers */
.sec-hd { max-width: var(--max); margin: 0 auto 3rem; }
.sec-eye { font-size: .7rem; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; color: var(--red); margin-bottom: .5rem; }
.sec-title { font-family: var(--font-d); font-size: clamp(2.4rem, 5vw, 4rem); letter-spacing: .04em; color: var(--black); line-height: 1; }
.sec-line { display: block; width: 100%; height: 3px; overflow: visible; margin-top: 8px; }
.sec-line line { stroke-dasharray: 600; stroke-dashoffset: 600; transition: stroke-dashoffset .9s cubic-bezier(.4,0,.2,1) .1s; }
.sec-hd.line-drawn .sec-line line { stroke-dashoffset: 0; }

/* 16. Brand Cards Grid */
.brands { padding: 5.5rem 2.5rem; background: var(--white); }
.brands__grid {
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.bcard {
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: 1.1rem 1.1rem .9rem;
  height: 170px;
  cursor: pointer;
  overflow: hidden;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .5s ease, transform .5s ease, box-shadow .22s ease;
}
.bcard.vis { opacity: 1; transform: translateY(0); }
.bcard:hover { box-shadow: 0 16px 40px rgba(0,0,0,.28); z-index: 2; }
.bcard--wide { grid-column: span 2; }
.bcard--full { grid-column: 1 / -1; height: 210px; }
.bcard__bg { position: absolute; inset: 0; transition: transform .35s ease; }
.bcard:hover .bcard__bg { transform: scale(1.05); }
.bcard__overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.72) 0%, rgba(0,0,0,.12) 55%, transparent 100%); }
.bcard__name { position: relative; font-family: var(--font-d); font-size: 1.3rem; letter-spacing: .06em; color: #fff; line-height: 1.05; z-index: 1; }
.bcard--wide .bcard__name,
.bcard--full .bcard__name { font-size: 1.65rem; }
.bcard__hint { position: absolute; top: .9rem; right: .9rem; font-size: .62rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.5); opacity: 0; transition: opacity .2s ease; z-index: 1; }
.bcard:hover .bcard__hint { opacity: 1; }
.bcard__tag { position: absolute; top: .9rem; left: .9rem; font-size: .6rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase; background: rgba(255,255,255,.15); color: rgba(255,255,255,.8); padding: .25rem .5rem; z-index: 1; }
.brands__note { max-width: var(--max); margin: 2rem auto 0; font-size: .78rem; color: var(--gray-300); letter-spacing: .03em; text-align: center; }

/* Card ripple */
.ripple { position: absolute; border-radius: 50%; pointer-events: none; animation: rippleOut .65s ease-out forwards; }

/* 17. Brand Filter Pills */
.brands__filters { max-width: var(--max); margin: 0 auto 2rem; display: flex; gap: .5rem; flex-wrap: wrap; }
.brands__filter-btn { font-family: var(--font-d); font-size: .82rem; letter-spacing: .1em; padding: .42rem 1.2rem; border: 1.5px solid #ccc; background: none; color: #888; cursor: pointer; transition: border-color .15s ease, color .15s ease, background .15s ease; }
.brands__filter-btn:hover { border-color: var(--red); color: var(--red); }
.brands__filter-btn.active { border-color: var(--red); background: var(--red); color: var(--white); }
.bcard.filtered-out { opacity: .12 !important; pointer-events: none !important; transition: opacity .3s ease !important; }

/* 18. About Section */
.about { background: var(--charcoal); padding: 8rem 2.5rem; clip-path: polygon(0 4%, 100% 0, 100% 96%, 0 100%); margin: -2.5rem 0; position: relative; }
.about__inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.7fr; gap: 6rem; align-items: center; }
.about__stats { display: flex; flex-direction: column; gap: 2.5rem; }
.stat__n { font-family: var(--font-d); font-size: 5rem; color: var(--cream); letter-spacing: .01em; line-height: 1; }
.stat__n em { color: var(--red); font-style: normal; }
.stat__n .stat__val { display: inline; }
.stat__l { font-size: .7rem; font-weight: 600; letter-spacing: .24em; text-transform: uppercase; color: var(--gray-300); margin-top: .2rem; }
.about__eye { font-size: .7rem; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; color: var(--red); margin-bottom: 1rem; }
.about__title { font-family: var(--font-d); font-size: clamp(2rem, 4vw, 3.2rem); color: var(--cream); letter-spacing: .04em; line-height: 1.05; margin-bottom: 1.5rem; }
.about__p { color: #aaa; font-size: .95rem; line-height: 1.8; max-width: 540px; }
.about__p + .about__p { margin-top: 1rem; }

/* 19. Pallet Calculator */
.calc { background: var(--charcoal); padding: 5rem 2.5rem; }
.calc__inner { max-width: var(--max); margin: 0 auto; }
.calc__head { margin-bottom: 2.5rem; }
.calc__eye { font-size: .7rem; font-weight: 700; letter-spacing: .28em; text-transform: uppercase; color: var(--red); margin-bottom: .5rem; }
.calc__title { font-family: var(--font-d); font-size: clamp(2.2rem, 4vw, 3.4rem); color: var(--cream); letter-spacing: .04em; line-height: 1; }
.calc__sub { color: #888; font-size: .88rem; margin-top: .6rem; line-height: 1.65; max-width: 560px; }
.calc__controls { display: grid; grid-template-columns: 1fr 1fr auto; gap: 1rem; align-items: end; margin-bottom: 1.75rem; }
.calc__group { display: flex; flex-direction: column; gap: .4rem; }
.calc__label { font-size: .65rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--gray-300); }
.calc__select, .calc__input { padding: .85rem 1rem; background: #111; border: 1.5px solid #333; color: var(--cream); font-family: var(--font-b); font-size: .9rem; outline: none; -webkit-appearance: none; appearance: none; transition: border-color .2s ease; width: 100%; }
.calc__select:focus, .calc__input:focus { border-color: var(--red); }
.calc__select option { background: #111; }
.calc__btn { padding: .85rem 2rem; background: var(--red); border: none; color: var(--white); font-family: var(--font-d); font-size: 1rem; letter-spacing: .12em; cursor: pointer; white-space: nowrap; transition: background .2s ease; }
.calc__btn:hover { background: var(--red-dk); }
.calc__result { background: #111; border-left: 3px solid var(--red); padding: 1.75rem 2rem; display: none; }
.calc__result.show { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.calc__stat-n { font-family: var(--font-d); font-size: 2.6rem; color: var(--cream); letter-spacing: .02em; }
.calc__stat-l { font-size: .65rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--gray-300); margin-top: .25rem; }
.calc__order-btn { grid-column: 1 / -1; margin-top: .5rem; display: inline-flex; align-items: center; gap: .6rem; background: none; border: 1.5px solid var(--red); color: var(--red); font-family: var(--font-d); font-size: .95rem; letter-spacing: .1em; padding: .75rem 1.5rem; cursor: pointer; transition: background .2s ease, color .2s ease; width: max-content; }
.calc__order-btn:hover { background: var(--red); color: var(--white); }

/* 20. Contact Section + Form */
.contact { padding: 7rem 2.5rem; background: var(--cream); }
.contact__inner { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.6fr; gap: 6rem; align-items: start; }
.contact__title { font-family: var(--font-d); font-size: clamp(2.5rem, 5vw, 3.8rem); letter-spacing: .04em; line-height: .95; color: var(--black); margin-bottom: 1.5rem; }
.contact__title .red { color: var(--red); }
.contact__body { color: #555; font-size: .93rem; line-height: 1.75; margin-bottom: 2rem; max-width: 320px; }
.cdet { display: flex; align-items: center; gap: .65rem; margin-bottom: .7rem; font-size: .88rem; color: var(--black); font-weight: 500; }
.cdet__icon { width: 34px; height: 34px; background: var(--gray-100); display: flex; align-items: center; justify-content: center; font-size: .9rem; flex-shrink: 0; }
.form { background: var(--white); padding: 2.25rem; border: 1px solid #E0DDD6; }
.frow { display: grid; grid-template-columns: 1fr 1fr; gap: .85rem; margin-bottom: .85rem; }
.ff { display: flex; flex-direction: column; gap: .35rem; }
.ff.full { grid-column: 1 / -1; }
.ff label { font-size: .68rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: #666; }
.ff input, .ff select, .ff textarea { padding: .7rem .9rem; border: 1.5px solid #D0D0D0; background: var(--cream); font-family: var(--font-b); font-size: .88rem; color: var(--black); outline: none; border-radius: 0; transition: border-color var(--ease); -webkit-appearance: none; appearance: none; width: 100%; }
.ff input:focus, .ff select:focus, .ff textarea:focus { border-color: var(--red); background: var(--white); }
.ff textarea { resize: vertical; min-height: 90px; }
.fork-q { border: none; margin-top: .5rem; }
.fork-q legend { font-size: .68rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: #666; margin-bottom: .55rem; display: block; }
.fork-q .radios { display: flex; gap: 1.5rem; }
.fork-q .radios label { display: flex; align-items: center; gap: .4rem; font-size: .88rem; font-weight: 400; letter-spacing: 0; text-transform: none; color: var(--black); cursor: pointer; }
.fork-q input[type="radio"] { accent-color: var(--red); width: 15px; height: 15px; }
.form__btn { display: block; width: 100%; margin-top: 1.4rem; padding: 1.05rem 2rem; background: var(--red); border: none; color: var(--white); font-family: var(--font-d); font-size: 1.15rem; letter-spacing: .12em; cursor: pointer; transition: background var(--ease); }
.form__btn:hover { background: var(--red-dk); }
.form__note { margin-top: .6rem; text-align: center; font-size: .7rem; color: var(--gray-300); letter-spacing: .04em; }

/* 21. Footer */
.footer { background: var(--black); border-top: 2px solid var(--red); padding: 2.5rem; }
.footer__inner { max-width: var(--max); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.footer__logo { height: 56px; filter: invert(1); }
.footer__copy { font-size: .78rem; color: var(--gray-300); text-align: right; }
.footer__credit { font-size: .7rem; color: #333; margin-top: .25rem; }

/* 22. Brand Page Template */
#mainPage { display: block; }
#brandPage { display: none; min-height: 100vh; background: var(--cream); animation: pageIn .38s ease; }

/* Brand page — renderer output layout */
.brand-page .brand-page-content { padding-top: 96px; }
@keyframes bpgWipe { to { transform: scaleX(0); } }
.brand-page .bpg__hero-wipe { animation: bpgWipe .8s cubic-bezier(.76,0,.24,1) .15s forwards; }
.bpg__jumpnav-btn.active { border-color: var(--red); color: var(--red); }

.bpg__topbar { position: sticky; top: 0; z-index: 100; height: 64px; background: var(--black); border-bottom: 2px solid var(--red); display: flex; align-items: center; justify-content: space-between; padding: 0 2.5rem; }
.bpg__back { display: flex; align-items: center; gap: .55rem; font-family: var(--font-d); font-size: .95rem; letter-spacing: .12em; color: var(--cream); background: none; border: 1px solid #333; padding: .45rem 1rem; cursor: pointer; transition: border-color var(--ease), color var(--ease); }
.bpg__back:hover { border-color: var(--red); color: var(--red); }
.bpg__back::before { content: '←'; }
.bpg__toplogo { height: 44px; filter: invert(1); }

.bpg__hero { height: 58vh; min-height: 360px; position: relative; display: flex; align-items: flex-end; overflow: hidden; }
.bpg__hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 7s ease; }
.bpg__hero.zoomed .bpg__hero-bg { transform: scale(1.07); }
.bpg__hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,.38) 55%, rgba(0,0,0,.18) 100%); }
.bpg__hero-content { position: relative; padding: 2.5rem 2.5rem 3rem; max-width: var(--max); margin: 0 auto; width: 100%; }
.bpg__badge { font-size: .62rem; font-weight: 700; letter-spacing: .3em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: .5rem; }
.bpg__name { font-family: var(--font-d); font-size: clamp(4.5rem, 11vw, 9rem); line-height: .88; letter-spacing: .02em; color: var(--white); }
.bpg__tagline { font-size: .95rem; color: rgba(255,255,255,.65); margin-top: .75rem; letter-spacing: .03em; }

.bpg__body { max-width: var(--max); margin: 0 auto; padding: 3.5rem 2.5rem 5.5rem; }
.bpg__body-grid { display: grid; grid-template-columns: 1fr 2.2fr; gap: 5rem; align-items: start; }
.bpg__body-grid > * { min-width: 0; }
.bpg__desc { font-size: .95rem; color: #444; line-height: 1.82; margin-bottom: 1.75rem; }
.bpg__note { background: var(--gray-100); padding: .9rem 1.1rem; font-size: .78rem; color: #555; line-height: 1.65; border-left: 3px solid var(--red); }
.bpg__cta { display: block; width: 100%; margin-top: 1.5rem; padding: 1rem 1.5rem; color: var(--white); font-family: var(--font-d); font-size: 1.1rem; letter-spacing: .12em; border: none; cursor: pointer; text-align: center; transition: filter .2s ease; }
.bpg__cta:hover { filter: brightness(.88); }

.bpg__table-wrap {}
.bpg__section-label { font-size: .62rem; font-weight: 700; letter-spacing: .25em; text-transform: uppercase; color: var(--red); margin-top: 0; margin-bottom: .5rem; padding-bottom: .4rem; border-bottom: 2px solid var(--gray-100); }
.sku-table { width: auto; min-width: 100%; border-collapse: collapse; font-size: .84rem; }
.sku-table th { background: var(--charcoal); color: var(--cream); font-family: var(--font-d); font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; padding: .7rem .9rem; text-align: left; white-space: nowrap; }
.sku-table td { padding: .55rem .9rem; border-bottom: 1px solid var(--gray-100); color: #333; white-space: nowrap; }
.sku-table tr:last-child td { border-bottom: none; }
.sku-table tr:hover td { background: #FAFAF8; }
.sku-table .price { font-weight: 700; color: var(--charcoal); }
.sku-table .group-row td { background: #F0EDE8; font-size: .62rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--red); padding: .35rem .9rem; border-bottom: none; }
.sku-scroll { overflow-x: auto; }
.sku-table thead tr th { position: static; }
.bpg__fine { margin-top: 1rem; font-size: .7rem; color: var(--gray-300); line-height: 1.65; }

/* Brand page hero wipe */
.bpg__hero-wipe { position: absolute; inset: 0; background: var(--black); z-index: 6; transform-origin: right; transform: scaleX(1); transition: transform .8s cubic-bezier(.76,0,.24,1) .05s; pointer-events: none; }
.bpg__hero.zoomed .bpg__hero-wipe { transform: scaleX(0); }

/* 23. Brand Page Jump Nav */
.bpg__jumpnav { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.25rem; }
.bpg__jumpnav-btn { font-size: .62rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; padding: .38rem .85rem; border: 1.5px solid var(--gray-100); background: none; color: #777; cursor: pointer; transition: border-color .15s ease, color .15s ease, background .15s ease; }
.bpg__jumpnav-btn:hover { border-color: var(--red); color: var(--red); }

/* Brand page combo callout */
.bpg__combo { margin-top: 1.25rem; background: #F5F3EF; padding: .9rem 1.1rem; border-top: 2px solid #E0DDD6; }
.bpg__combo-label { font-size: .58rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: #999; margin-bottom: .45rem; }
.bpg__combo-links { display: flex; flex-wrap: wrap; gap: .5rem; }
.bpg__combo-link { font-family: var(--font-d); font-size: .95rem; letter-spacing: .06em; color: var(--black); border-bottom: 2px solid var(--red); cursor: pointer; padding-bottom: 1px; transition: color .15s; }
.bpg__combo-link:hover { color: var(--red); }

/* 24. Floating CTA */
.float-cta {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 200;
  background: var(--red);
  color: var(--white);
  font-family: var(--font-d);
  font-size: 1rem;
  letter-spacing: .12em;
  padding: .85rem 1.75rem;
  border: none;
  cursor: pointer;
  border-radius: 50px;
  box-shadow: 0 6px 24px rgba(196,30,58,.45);
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .45s ease, transform .45s ease, background .2s ease;
  pointer-events: none;
}
.float-cta.vis { opacity: 1; transform: translateY(0); pointer-events: auto; }
.float-cta:hover { background: var(--red-dk); box-shadow: 0 10px 32px rgba(196,30,58,.6); transform: translateY(-2px); }

/* 25. Animations */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(7px); }
}
@keyframes scroll-x {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes rippleOut {
  from { transform: scale(0); opacity: .32; }
  to   { transform: scale(1); opacity: 0; }
}
@keyframes splitReveal {
  from { opacity: 0; transform: translateY(42px); clip-path: inset(0 0 100% 0); }
  to   { opacity: 1; transform: translateY(0); clip-path: inset(0 0 -8% 0); }
}
@keyframes pageIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes preloaderIn {
  0%   { opacity: 0; transform: scale(.6); }
  32%  { opacity: 1; transform: scale(1.04); }
  68%  { opacity: 1; transform: scale(1); }
  100% { opacity: 0; transform: scale(.97); }
}

/* 26. Toast Notification */
.toast {
  position: fixed;
  bottom: 5.5rem;
  right: 2rem;
  z-index: 300;
  background: var(--charcoal);
  color: var(--cream);
  font-family: var(--font-b);
  font-size: .82rem;
  padding: .85rem 1.25rem;
  border-left: 3px solid var(--red);
  transform: translateY(20px);
  opacity: 0;
  transition: transform .35s ease, opacity .35s ease;
  pointer-events: none;
  max-width: 260px;
  line-height: 1.5;
}
.toast.show { transform: translateY(0); opacity: 1; }

/* 27. Form Confirmation State */
.form-thanks { display: none; background: var(--white); border: 1px solid #E0DDD6; padding: 3rem 2.25rem; text-align: center; }
.form-thanks.show { display: block; animation: fadeUp .45s ease both; }
.form-thanks__check { width: 56px; height: 56px; background: var(--red); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.25rem; font-size: 1.5rem; color: white; }
.form-thanks__title { font-family: var(--font-d); font-size: 2rem; letter-spacing: .08em; color: var(--black); margin-bottom: .75rem; }
.form-thanks__body { font-size: .9rem; color: #555; line-height: 1.7; margin-bottom: 1.5rem; max-width: 340px; margin-left: auto; margin-right: auto; }
.form-thanks__contact { font-size: .82rem; color: #666; line-height: 2; }
.form-thanks__contact strong { color: var(--black); font-weight: 600; }

/* 28. Responsive Breakpoints */
@media (max-width: 960px) {
  .brands__grid { grid-template-columns: repeat(3, 1fr); }
  .bcard--full { grid-column: 1 / -1; }
  .about__inner { grid-template-columns: 1fr; gap: 3.5rem; }
  .about__stats { flex-direction: row; flex-wrap: wrap; gap: 2rem; }
  .contact__inner { grid-template-columns: 1fr; gap: 3rem; }
}

@media (max-width: 860px) {
  .bpg__body-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .bpg__body { padding: 2.5rem 1.5rem 4rem; }
  .bpg__hero-content { padding: 1.5rem 1.5rem 2rem; }
  .bpg__name { font-size: clamp(3.5rem, 15vw, 6rem); }
}

@media (max-width: 720px) {
  .calc__controls { grid-template-columns: 1fr; }
  .calc__result.show { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .hdr__nav { display: none; }
  .hdr__burger { display: flex; }
  .brands__grid { grid-template-columns: repeat(2, 1fr); }
  .bcard { height: 150px; }
  .bcard--full { height: 170px; }
  .hero__form { flex-direction: column; }
  .hero__form input { border-right: 1.5px solid rgba(255,255,255,.3); border-bottom: none; }
  .frow { grid-template-columns: 1fr; }
  .footer__inner { flex-direction: column; text-align: center; }
  .footer__copy { text-align: center; }
  .about { clip-path: none; padding: 5rem 2.5rem; margin: 0; }
  .sku-table th, .sku-table td { padding: .55rem .65rem; }
}

@media (max-width: 480px) {
  .bpg__body { padding: 2rem 1rem 3.5rem; }
  .bpg__hero-content { padding: 1.25rem 1rem 1.75rem; }
  .bpg__name { font-size: clamp(2.75rem, 12vw, 4.5rem); }
  .float-cta { font-size: .88rem; padding: .7rem 1.25rem; right: 1rem; bottom: 1.25rem; }
  .bpg__cta { font-size: 1rem; padding: .9rem 1rem; letter-spacing: .08em; }
}

@media (max-width: 400px) {
  .brands__grid { grid-template-columns: 1fr; }
  .bcard--wide, .bcard--full { grid-column: span 1; }
}
