/* =========================================================
   FIFTY BAR VAPE — Main Stylesheet
   Aesthetic: Bold American Industrial / Street-Luxury
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@400;600;700&family=Barlow:wght@300;400;500;600&display=swap');

:root {
  --red:       #D4282A;
  --red-dark:  #A81F21;
  --red-light: #FF3B3D;
  --black:     #0A0A0A;
  --dark:      #131313;
  --dark-2:    #1C1C1C;
  --dark-3:    #262626;
  --mid:       #3A3A3A;
  --silver:    #B0B0B0;
  --white:     #F5F5F0;
  --cream:     #EDE8DF;
  --gold:      #C9A84C;
  --font-display: 'Bebas Neue', 'Impact', sans-serif;
  --font-cond: 'Barlow Condensed', sans-serif;
  --font-body: 'Barlow', sans-serif;
  --radius:    4px;
  --shadow:    0 4px 24px rgba(0,0,0,.45);
  --transition: .22s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family: var(--font-body);
  background: var(--black);
  color: var(--white);
  overflow-x: hidden;
  line-height: 1.6;
}
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:var(--font-body); }
ul { list-style:none; }

/* ── AGE GATE ── */
#age-gate {
  position:fixed; inset:0; z-index:9999;
  background: var(--black);
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:24px;
  padding: 24px;
  text-align:center;
}
#age-gate .ag-logo {
  font-family: var(--font-display);
  font-size: clamp(36px,8vw,72px);
  letter-spacing: .04em;
  color: var(--white);
}
#age-gate .ag-logo span { color: var(--red); }
#age-gate p {
  font-family: var(--font-cond);
  font-size: 18px;
  color: var(--silver);
  max-width: 440px;
  letter-spacing:.04em;
}
#age-gate .ag-warning {
  font-size:12px; color:var(--mid); max-width:480px; line-height:1.5;
}
.ag-btns { display:flex; gap:16px; flex-wrap:wrap; justify-content:center; }
.ag-btns button {
  padding: 14px 40px;
  font-family: var(--font-cond);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border: none;
  border-radius: var(--radius);
  transition: var(--transition);
}
.ag-btn-yes { background:var(--red); color:#fff; }
.ag-btn-yes:hover { background:var(--red-light); transform:translateY(-2px); }
.ag-btn-no { background:var(--dark-3); color:var(--silver); }
.ag-btn-no:hover { background:var(--mid); }

/* ── ANNOUNCEMENT BAR ── */
.ann-bar {
  background: var(--red);
  text-align:center;
  padding: 9px 16px;
  font-family: var(--font-cond);
  font-size: 14px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
}
.ann-bar a { text-decoration:underline; }

/* ── HEADER ── */
.site-header {
  position:sticky; top:0; z-index:800;
  background: rgba(10,10,10,.96);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: 0 32px;
  height: 68px;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
}
.header-logo {
  display:flex; align-items:center; gap:12px;
  text-decoration:none;
  flex-shrink:0;
}
.header-logo svg { height:42px; width:auto; }
.header-logo-text {
  display:flex; flex-direction:column; line-height:1.1;
}
.header-logo-text strong {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing:.06em;
  color:var(--white);
}
.header-logo-text span {
  font-family: var(--font-cond);
  font-size: 11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--red);
}
.site-nav { display:flex; align-items:center; gap:4px; }
.site-nav a {
  font-family: var(--font-cond);
  font-size: 15px;
  font-weight:600;
  letter-spacing:.06em;
  text-transform:uppercase;
  color: var(--silver);
  padding: 8px 14px;
  border-radius: var(--radius);
  transition: var(--transition);
  position:relative;
}
.site-nav a:hover, .site-nav a.active { color:var(--white); }
.site-nav a.active::after {
  content:''; position:absolute; bottom:2px; left:14px; right:14px;
  height:2px; background:var(--red); border-radius:2px;
}
.header-cta {
  background: var(--red);
  color: #fff !important;
  padding: 9px 20px !important;
  border-radius: var(--radius) !important;
}
.header-cta:hover { background:var(--red-light) !important; }
.header-phone {
  font-family: var(--font-cond);
  font-size:14px; font-weight:700;
  letter-spacing:.04em;
  color:var(--silver);
  white-space:nowrap;
}
.header-phone a:hover { color:var(--red); }

/* ── HAMBURGER ── */
.hamburger {
  display:none; background:none; border:none;
  flex-direction:column; gap:5px; padding:4px;
}
.hamburger span {
  display:block; width:24px; height:2px;
  background:var(--white);
  transition: var(--transition);
  transform-origin:center;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── MOBILE NAV ── */
.mobile-nav {
  display:none; position:fixed; inset:68px 0 0;
  background:var(--dark);
  z-index:700;
  flex-direction:column;
  padding:24px;
  gap:8px;
  overflow-y:auto;
  border-top:1px solid rgba(255,255,255,.08);
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
  font-family:var(--font-cond);
  font-size:22px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--silver);
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
  transition: var(--transition);
}
.mobile-nav a:hover { color:var(--white); padding-left:8px; }
.mobile-nav a.highlight { color:var(--red); }

/* ── HERO ── */
.hero {
  position:relative; min-height:90vh;
  display:flex; align-items:center;
  overflow:hidden;
  background: var(--dark);
}
.hero-bg {
  position:absolute; inset:0;
  background: linear-gradient(135deg, #0A0A0A 0%, #1a0505 50%, #0A0A0A 100%);
}
.hero-bg-pattern {
  position:absolute; inset:0; opacity:.04;
  background-image: repeating-linear-gradient(
    0deg, transparent, transparent 48px, rgba(255,255,255,.6) 48px, rgba(255,255,255,.6) 50px
  ), repeating-linear-gradient(
    90deg, transparent, transparent 48px, rgba(255,255,255,.6) 48px, rgba(255,255,255,.6) 50px
  );
}
.hero-accent {
  position:absolute; right:-100px; top:-60px;
  width:600px; height:600px;
  background: radial-gradient(circle, rgba(212,40,42,.18) 0%, transparent 70%);
  pointer-events:none;
}
.hero-content {
  position:relative; z-index:2;
  max-width:1200px; margin:0 auto;
  padding:80px 32px;
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center; gap:64px;
}
.hero-eyebrow {
  font-family: var(--font-cond);
  font-size:13px; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--red);
  margin-bottom:16px;
  display:flex; align-items:center; gap:10px;
}
.hero-eyebrow::before {
  content:''; display:block; width:24px; height:2px;
  background:var(--red);
}
.hero h1 {
  font-family: var(--font-display);
  font-size: clamp(52px,7vw,96px);
  line-height:.92;
  letter-spacing:.02em;
  color: var(--white);
  margin-bottom:24px;
}
.hero h1 em { color:var(--red); font-style:normal; }
.hero-sub {
  font-size: 17px;
  color: var(--silver);
  max-width:440px;
  line-height:1.7;
  margin-bottom:36px;
}
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; }
.hero-stats {
  display:flex; gap:32px; margin-top:48px; flex-wrap:wrap;
}
.hero-stat { display:flex; flex-direction:column; }
.hero-stat strong {
  font-family: var(--font-display);
  font-size:36px; color:var(--white);
  line-height:1;
}
.hero-stat span {
  font-family:var(--font-cond);
  font-size:13px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--silver);
}
.hero-visual {
  position:relative;
  display:flex; align-items:center; justify-content:center;
}
.hero-visual-bg {
  position:absolute;
  width:480px; height:480px;
  background: radial-gradient(circle, rgba(212,40,42,.12) 0%, transparent 65%);
  border-radius:50%;
}
.hero-device-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:16px; position:relative; z-index:2;
  max-width:380px;
}
.hero-device-card {
  background: var(--dark-2);
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px; padding:20px 16px;
  text-align:center;
  transition: var(--transition);
  cursor:pointer;
}
.hero-device-card:hover {
  border-color:var(--red);
  transform:translateY(-4px);
  box-shadow: 0 8px 32px rgba(212,40,42,.2);
}
.hero-device-icon {
  font-size:36px; margin-bottom:8px;
}
.hero-device-card h3 {
  font-family:var(--font-cond);
  font-size:14px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--white); margin-bottom:4px;
}
.hero-device-card p {
  font-size:12px; color:var(--silver);
}
.hero-device-card.featured {
  grid-column:1/-1;
  background:linear-gradient(135deg,var(--dark-2),var(--dark-3));
  border-color:var(--red);
}

/* ── BUTTONS ── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-cond);
  font-size:16px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  padding:13px 28px;
  border-radius:var(--radius);
  border:2px solid transparent;
  transition: var(--transition);
  white-space:nowrap;
  cursor:pointer;
}
.btn-primary { background:var(--red); color:#fff; border-color:var(--red); }
.btn-primary:hover { background:var(--red-light); border-color:var(--red-light); transform:translateY(-2px); box-shadow:0 6px 20px rgba(212,40,42,.35); }
.btn-outline { background:transparent; color:var(--white); border-color:rgba(255,255,255,.3); }
.btn-outline:hover { border-color:var(--white); background:rgba(255,255,255,.06); }
.btn-gold { background:var(--gold); color:var(--black); border-color:var(--gold); }
.btn-gold:hover { background:#e0bb5c; transform:translateY(-2px); }
.btn-sm { font-size:13px; padding:9px 18px; }
.btn-lg { font-size:18px; padding:16px 36px; }
.btn svg { width:18px; height:18px; flex-shrink:0; }

/* ── SECTION COMMONS ── */
section { padding:96px 32px; }
.section-inner { max-width:1200px; margin:0 auto; }
.section-label {
  font-family:var(--font-cond);
  font-size:12px; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--red); margin-bottom:12px;
  display:flex; align-items:center; gap:10px;
}
.section-label::before { content:''; display:block; width:20px; height:2px; background:var(--red); }
.section-title {
  font-family:var(--font-display);
  font-size: clamp(36px,5vw,64px);
  letter-spacing:.02em;
  color:var(--white);
  line-height:1.0;
  margin-bottom:16px;
}
.section-title em { color:var(--red); font-style:normal; }
.section-sub {
  font-size:16px; color:var(--silver);
  max-width:560px; line-height:1.7;
  margin-bottom:48px;
}

/* ── CATEGORIES GRID ── */
.cats-section { background:var(--dark); }
.cats-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
  margin-top:48px;
}
.cat-card {
  position:relative; overflow:hidden;
  aspect-ratio:4/3;
  background:var(--dark-2);
  cursor:pointer;
  display:flex; align-items:flex-end;
}
.cat-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.1) 60%);
  z-index:1;
  transition:var(--transition);
}
.cat-card:hover::before { background:linear-gradient(to top,rgba(212,40,42,.8) 0%,rgba(0,0,0,.2) 70%); }
.cat-card-bg {
  position:absolute; inset:0;
  background: var(--dark-3);
  display:flex; align-items:center; justify-content:center;
  font-size:80px;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
}
.cat-card:hover .cat-card-bg { transform:scale(1.06); }
.cat-card-info {
  position:relative; z-index:2;
  padding:24px;
  transform:translateY(8px);
  transition: var(--transition);
}
.cat-card:hover .cat-card-info { transform:translateY(0); }
.cat-card-info h3 {
  font-family:var(--font-display);
  font-size:28px; letter-spacing:.04em;
  color:var(--white); margin-bottom:4px;
}
.cat-card-info p {
  font-family:var(--font-cond);
  font-size:13px; letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.cat-card-arrow {
  position:absolute; top:20px; right:20px; z-index:2;
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.1);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateX(8px);
  transition:var(--transition);
  color:var(--white);
}
.cat-card:hover .cat-card-arrow { opacity:1; transform:translateX(0); }
.cat-card.featured { grid-column:span 2; }

/* ── FEATURED PRODUCTS ── */
.products-section { background:var(--black); }
.products-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  flex-wrap:wrap; gap:16px; margin-bottom:48px;
}
.products-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.product-card {
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,.06);
  border-radius:8px;
  overflow:hidden;
  transition: var(--transition);
  display:flex; flex-direction:column;
}
.product-card:hover {
  border-color:rgba(212,40,42,.4);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.5);
}
.product-card-img {
  position:relative;
  background: var(--dark-3);
  aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  font-size:56px;
}
.product-card-img img {
  width:100%; height:100%;
  object-fit:cover;
  transition: transform .5s ease;
}
.product-card:hover .product-card-img img { transform:scale(1.05); }
.product-badge {
  position:absolute; top:12px; left:12px;
  background:var(--red);
  color:#fff;
  font-family:var(--font-cond);
  font-size:11px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  padding:4px 10px;
  border-radius:2px;
}
.product-card-body { padding:16px; flex:1; display:flex; flex-direction:column; }
.product-cat-tag {
  font-family:var(--font-cond);
  font-size:11px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--red); margin-bottom:6px;
}
.product-card-body h3 {
  font-family:var(--font-cond);
  font-size:18px; font-weight:700;
  letter-spacing:.03em;
  color:var(--white); margin-bottom:6px;
  line-height:1.2;
}
.product-card-body p {
  font-size:13px; color:var(--silver);
  line-height:1.5; flex:1;
  margin-bottom:14px;
}
.product-card-footer {
  display:flex; align-items:center; justify-content:space-between;
  gap:8px;
}
.product-price {
  font-family:var(--font-display);
  font-size:26px; color:var(--white);
}
.product-card .btn-sm { font-size:12px; padding:8px 14px; }
.stock-badge {
  font-family:var(--font-cond);
  font-size:11px; font-weight:600; letter-spacing:.06em;
  color:#4CAF50;
  display:flex; align-items:center; gap:4px;
}
.stock-badge::before { content:''; display:inline-block; width:6px; height:6px; border-radius:50%; background:#4CAF50; }

/* ── WHY CHOOSE ── */
.why-section {
  background: var(--dark);
  position:relative; overflow:hidden;
}
.why-section::before {
  content:''; position:absolute; left:-200px; top:-200px;
  width:600px; height:600px;
  background:radial-gradient(circle, rgba(212,40,42,.08) 0%, transparent 70%);
  pointer-events:none;
}
.why-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.why-features { display:flex; flex-direction:column; gap:32px; }
.why-feature { display:flex; gap:20px; }
.why-feature-icon {
  width:52px; height:52px; border-radius:8px;
  background:rgba(212,40,42,.12);
  border:1px solid rgba(212,40,42,.25);
  display:flex; align-items:center; justify-content:center;
  font-size:24px; flex-shrink:0;
  color:var(--red);
}
.why-feature-text h3 {
  font-family:var(--font-cond);
  font-size:18px; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase;
  color:var(--white); margin-bottom:6px;
}
.why-feature-text p { font-size:14px; color:var(--silver); line-height:1.6; }
.why-visual {
  position:relative;
  display:flex; flex-direction:column; gap:16px;
}
.commitment-card {
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px; padding:28px;
  position:relative; overflow:hidden;
}
.commitment-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0;
  width:3px; background:var(--red);
}
.commitment-card h3 {
  font-family:var(--font-display);
  font-size:28px; letter-spacing:.04em;
  color:var(--white); margin-bottom:10px;
}
.commitment-card p { font-size:14px; color:var(--silver); line-height:1.6; }
.commitment-stat {
  background:var(--red);
  border-radius:8px; padding:24px 28px;
  display:flex; align-items:center; gap:20px;
}
.commitment-stat strong {
  font-family:var(--font-display);
  font-size:52px; color:#fff;
  line-height:1;
}
.commitment-stat div { flex:1; }
.commitment-stat span {
  font-family:var(--font-cond);
  font-size:15px; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase;
  color:rgba(255,255,255,.85);
}

/* ── HOW TO ORDER STRIP ── */
.order-strip {
  background: var(--red);
  padding: 64px 32px;
}
.order-strip-inner {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1fr;
  gap:48px; align-items:center;
}
.order-strip h2 {
  font-family:var(--font-display);
  font-size:clamp(32px,5vw,56px);
  color:#fff; line-height:1.0;
  letter-spacing:.02em;
}
.order-strip p { color:rgba(255,255,255,.8); font-size:16px; margin-top:12px; line-height:1.6; }
.order-steps { display:flex; flex-direction:column; gap:20px; }
.order-step { display:flex; gap:16px; align-items:flex-start; }
.step-num {
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display);
  font-size:18px; color:#fff;
  flex-shrink:0;
}
.step-text h4 {
  font-family:var(--font-cond);
  font-size:16px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  color:#fff; margin-bottom:2px;
}
.step-text p { font-size:13px; color:rgba(255,255,255,.7); }

/* ── PAYMENT METHODS ── */
.payments-row {
  display:flex; flex-wrap:wrap; gap:12px;
  align-items:center; margin-top:24px;
}
.payment-chip {
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  border-radius:20px; padding:6px 16px;
  font-family:var(--font-cond);
  font-size:13px; font-weight:600;
  letter-spacing:.06em; color:#fff;
  display:flex; align-items:center; gap:6px;
}

/* ── NEWSLETTER ── */
.newsletter-section {
  background:var(--dark-2);
  padding:72px 32px;
  text-align:center;
}
.newsletter-form {
  display:flex; gap:12px;
  max-width:440px; margin:32px auto 0;
}
.newsletter-form input {
  flex:1;
  background:var(--dark-3);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);
  padding:13px 18px;
  font-family:var(--font-body);
  font-size:15px; color:var(--white);
  outline:none;
  transition:var(--transition);
}
.newsletter-form input::placeholder { color:var(--mid); }
.newsletter-form input:focus { border-color:var(--red); }
.newsletter-form .btn { flex-shrink:0; }

/* ── FOOTER ── */
.site-footer {
  background:var(--dark);
  border-top:1px solid rgba(255,255,255,.07);
  padding:64px 32px 32px;
}
.footer-grid {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; margin-bottom:48px;
}
.footer-brand-logo {
  font-family:var(--font-display);
  font-size:32px; letter-spacing:.06em;
  color:var(--white); margin-bottom:12px;
}
.footer-brand-logo span { color:var(--red); }
.footer-brand p { font-size:14px; color:var(--silver); line-height:1.7; max-width:280px; }
.footer-contact-item {
  display:flex; gap:10px; align-items:flex-start;
  margin-top:16px;
}
.footer-contact-item svg { color:var(--red); flex-shrink:0; margin-top:2px; }
.footer-contact-item span { font-size:14px; color:var(--silver); }
.footer-contact-item a { color:var(--silver); transition:var(--transition); }
.footer-contact-item a:hover { color:var(--red); }
.footer-col h4 {
  font-family:var(--font-cond);
  font-size:13px; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--red); margin-bottom:20px;
}
.footer-col ul { display:flex; flex-direction:column; gap:10px; }
.footer-col ul a {
  font-size:14px; color:var(--silver);
  transition:var(--transition);
}
.footer-col ul a:hover { color:var(--white); padding-left:4px; }
.footer-bottom {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.07);
}
.footer-copy {
  font-size:13px; color:var(--mid);
  font-family:var(--font-cond); letter-spacing:.04em;
}
.footer-legal { display:flex; gap:16px; }
.footer-legal a {
  font-size:12px; color:var(--mid);
  font-family:var(--font-cond); letter-spacing:.06em;
  text-transform:uppercase;
  transition:var(--transition);
}
.footer-legal a:hover { color:var(--silver); }
.footer-age-notice {
  width:100%;
  font-size:11px; color:var(--mid); text-align:center;
  margin-top:16px; line-height:1.5;
}

/* ── SHOP PAGE ── */
.shop-hero {
  background:var(--dark);
  padding:72px 32px 48px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.shop-hero-inner { max-width:1200px; margin:0 auto; }
.breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-family:var(--font-cond);
  font-size:13px; letter-spacing:.06em;
  color:var(--mid); margin-bottom:24px;
}
.breadcrumb a { color:var(--silver); transition:var(--transition); }
.breadcrumb a:hover { color:var(--red); }
.breadcrumb span { color:var(--mid); }
.filter-bar {
  display:flex; gap:8px; flex-wrap:wrap;
  margin:32px 0;
}
.filter-btn {
  background:var(--dark-3);
  border:1px solid rgba(255,255,255,.08);
  color:var(--silver);
  font-family:var(--font-cond);
  font-size:13px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  padding:8px 20px;
  border-radius:20px;
  cursor:pointer;
  transition:var(--transition);
}
.filter-btn:hover, .filter-btn.active {
  background:var(--red); border-color:var(--red); color:#fff;
}
.shop-grid-section { background:var(--black); padding:64px 32px; }
.shop-grid {
  max-width:1200px; margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:20px;
}

/* ── INNER PAGE HERO ── */
.page-hero {
  background:var(--dark);
  padding:64px 32px 48px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.page-hero-inner { max-width:1200px; margin:0 auto; }

/* ── FAQ ── */
.faq-section { background:var(--black); }
.faq-list { max-width:800px; margin:0 auto; }
.faq-item {
  border-bottom:1px solid rgba(255,255,255,.08);
}
.faq-question {
  width:100%; background:none; border:none;
  display:flex; align-items:center; justify-content:space-between;
  gap:16px;
  padding:22px 0;
  font-family:var(--font-cond);
  font-size:18px; font-weight:600;
  letter-spacing:.02em;
  color:var(--white);
  text-align:left;
  cursor:pointer;
  transition:var(--transition);
}
.faq-question:hover { color:var(--red); }
.faq-question svg {
  flex-shrink:0; transition:transform .3s ease;
}
.faq-item.open .faq-question svg { transform:rotate(180deg); }
.faq-answer {
  max-height:0; overflow:hidden;
  transition:max-height .35s ease, padding .35s ease;
}
.faq-answer-inner {
  font-size:15px; color:var(--silver);
  line-height:1.7; padding-bottom:20px;
}
.faq-item.open .faq-answer { max-height:400px; }

/* ── CONTACT ── */
.contact-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:64px; align-items:start;
}
.contact-info { display:flex; flex-direction:column; gap:28px; }
.contact-card {
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px; padding:24px;
  display:flex; gap:16px;
}
.contact-card-icon {
  width:48px; height:48px;
  background:rgba(212,40,42,.12);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; flex-shrink:0; color:var(--red);
}
.contact-card-text h4 {
  font-family:var(--font-cond);
  font-size:15px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--white); margin-bottom:6px;
}
.contact-card-text p, .contact-card-text a {
  font-size:14px; color:var(--silver);
  line-height:1.5;
}
.contact-card-text a:hover { color:var(--red); }
.contact-form-wrap {
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px; padding:32px;
}
.contact-form-wrap h3 {
  font-family:var(--font-display);
  font-size:32px; letter-spacing:.04em;
  color:var(--white); margin-bottom:24px;
}
.form-group { margin-bottom:20px; }
.form-group label {
  display:block;
  font-family:var(--font-cond);
  font-size:13px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--silver); margin-bottom:8px;
}
.form-group input, .form-group textarea, .form-group select {
  width:100%;
  background:var(--dark-3);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);
  padding:12px 16px;
  font-family:var(--font-body);
  font-size:15px; color:var(--white);
  outline:none;
  transition:var(--transition);
  -webkit-appearance:none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:var(--mid); }
.form-group input:focus,
.form-group textarea:focus { border-color:var(--red); background:var(--dark-2); }
.form-group textarea { resize:vertical; min-height:130px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-note { font-size:12px; color:var(--mid); margin-top:16px; }

/* ── ABOUT ── */
.about-story-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:80px; align-items:center;
}
.about-story-text h2 {
  font-family:var(--font-display);
  font-size:clamp(36px,5vw,60px);
  letter-spacing:.02em; color:var(--white);
  line-height:1.0; margin-bottom:24px;
}
.about-story-text h2 em { color:var(--red); font-style:normal; }
.about-story-text p { font-size:15px; color:var(--silver); line-height:1.75; margin-bottom:16px; }
.about-visual {
  display:flex; flex-direction:column; gap:16px;
}
.about-stat-card {
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,.07);
  border-radius:8px; padding:24px;
  display:flex; align-items:center; gap:20px;
}
.about-stat-card strong {
  font-family:var(--font-display);
  font-size:48px; color:var(--red); line-height:1;
  flex-shrink:0;
}
.about-stat-card div { font-size:14px; color:var(--silver); line-height:1.5; }
.about-stat-card div strong { font-size:16px; color:var(--white); display:block; font-family:var(--font-cond); font-weight:700; letter-spacing:.04em; }
.values-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:48px;
}
.value-card {
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,.06);
  border-radius:8px; padding:28px;
  text-align:center;
  transition:var(--transition);
}
.value-card:hover { border-color:rgba(212,40,42,.3); transform:translateY(-4px); }
.value-icon { font-size:40px; margin-bottom:16px; }
.value-card h3 {
  font-family:var(--font-cond);
  font-size:18px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  color:var(--white); margin-bottom:10px;
}
.value-card p { font-size:13px; color:var(--silver); line-height:1.6; }

/* ── HOW TO ORDER ── */
.order-steps-big { display:flex; flex-direction:column; gap:0; max-width:800px; margin:0 auto; }
.order-step-big {
  display:grid; grid-template-columns:80px 1fr;
  gap:32px; align-items:start;
  padding:40px 0;
  border-bottom:1px solid rgba(255,255,255,.07);
  position:relative;
}
.order-step-big:last-child { border-bottom:none; }
.step-num-big {
  width:64px; height:64px; border-radius:50%;
  border:2px solid var(--red);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display);
  font-size:28px; color:var(--red);
  flex-shrink:0;
}
.step-content h3 {
  font-family:var(--font-display);
  font-size:28px; letter-spacing:.04em;
  color:var(--white); margin-bottom:12px;
}
.step-content p { font-size:15px; color:var(--silver); line-height:1.7; }
.step-content ul { margin-top:12px; display:flex; flex-direction:column; gap:6px; }
.step-content ul li {
  font-size:14px; color:var(--silver);
  padding-left:16px; position:relative;
}
.step-content ul li::before {
  content:''; position:absolute; left:0; top:9px;
  width:5px; height:5px; border-radius:50%;
  background:var(--red);
}

/* ── POLICY PAGES ── */
.policy-section { background:var(--black); }
.policy-content {
  max-width:780px; margin:0 auto;
}
.policy-content h2 {
  font-family:var(--font-cond);
  font-size:22px; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase;
  color:var(--white); margin:36px 0 12px;
  padding-top:8px;
  border-top:1px solid rgba(255,255,255,.07);
}
.policy-content h2:first-child { border-top:none; margin-top:0; }
.policy-content p { font-size:15px; color:var(--silver); line-height:1.8; margin-bottom:16px; }
.policy-content ul { padding-left:20px; margin-bottom:16px; }
.policy-content ul li { font-size:15px; color:var(--silver); line-height:1.7; margin-bottom:8px; list-style:disc; }
.policy-content a { color:var(--red); }

/* ── TOAST ── */
.toast {
  position:fixed; bottom:24px; right:24px; z-index:9000;
  background:var(--dark-2);
  border:1px solid rgba(255,255,255,.1);
  border-left:3px solid var(--red);
  border-radius:6px; padding:16px 24px;
  font-family:var(--font-cond);
  font-size:15px; font-weight:600;
  letter-spacing:.04em; color:var(--white);
  box-shadow:var(--shadow);
  transform:translateY(100px); opacity:0;
  transition: transform .35s ease, opacity .35s ease;
  max-width:320px;
}
.toast.show { transform:translateY(0); opacity:1; }
.toast.success { border-left-color:#4CAF50; }

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  .hero-content { grid-template-columns:1fr; gap:48px; }
  .hero-visual { display:none; }
  .cats-grid { grid-template-columns:repeat(2,1fr); }
  .cat-card.featured { grid-column:span 1; }
  .products-grid { grid-template-columns:repeat(3,1fr); }
  .why-grid { grid-template-columns:1fr; gap:48px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .order-strip-inner { grid-template-columns:1fr; gap:32px; }
  .about-story-grid { grid-template-columns:1fr; gap:48px; }
  .values-grid { grid-template-columns:repeat(2,1fr); }
  .contact-grid { grid-template-columns:1fr; }
  .shop-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:768px) {
  section { padding:64px 20px; }
  .site-header { padding:0 20px; }
  .site-nav, .header-phone { display:none; }
  .hamburger { display:flex; }
  .hero-content { padding:60px 20px; }
  .hero h1 { font-size:clamp(40px,12vw,72px); }
  .cats-grid { grid-template-columns:1fr 1fr; gap:2px; }
  .products-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .shop-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .footer-grid { grid-template-columns:1fr; gap:32px; }
  .newsletter-form { flex-direction:column; }
  .newsletter-form input, .newsletter-form .btn { width:100%; }
  .form-row { grid-template-columns:1fr; }
  .order-step-big { grid-template-columns:56px 1fr; gap:20px; }
  .values-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
}
@media (max-width:480px) {
  .cats-grid { grid-template-columns:1fr; }
  .products-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .shop-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .hero-stats { gap:20px; }
  .hero-actions { flex-direction:column; }
  .hero-actions .btn { width:100%; justify-content:center; }
}
