/* =============================================
   LUXURY MATTRESS WAREHOUSE
   Black & Red — Complete Design System
   ============================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

:root{
  --bg:#080808;
  --bg-card:#111;
  --bg-card-hover:#181818;
  --bg-elevated:#1a1a1a;
  --border:#222;
  --border-hover:#333;
  --red:#c41e3a;
  --red-bright:#e8344e;
  --red-dark:#8b1528;
  --red-glow:0 0 30px rgba(196,30,58,.25);
  --white:#fff;
  --text:#e8e8e8;
  --text-muted:#999;
  --text-dim:#666;
  --light-bg:#f7f7f7;
  --light-border:#e5e5e5;
  --light-text:#222;
  --light-muted:#555;
  --ff-display:'Bodoni Moda',Georgia,serif;
  --ff-body:'Montserrat',-apple-system,sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
  --max-w:1140px;
}

body{
  font-family:var(--ff-body);
  font-size:15px;
  line-height:1.7;
  color:var(--text);
  background:var(--bg);
  overflow-x:hidden;
}
/* Promo banner styles are injected by JS */

/* Scroll Reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}
.reveal-delay-6{transition-delay:.6s}
.reveal-delay-7{transition-delay:.7s}
.reveal-delay-8{transition-delay:.8s}

img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:all .3s var(--ease)}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit}

.container{max-width:var(--max-w);margin:0 auto;padding:0 32px}
.text-red{color:var(--red)}

/* =============================================
   SHARED TYPOGRAPHY
   ============================================= */
.section-label{
  display:block;
  font-size:.65rem;
  font-weight:700;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--red);
  margin-bottom:14px;
}
.section-title{
  font-family:var(--ff-display);
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:700;
  line-height:1.2;
  margin-bottom:14px;
}
.section-subtitle{
  font-size:.95rem;
  color:var(--text-muted);
  max-width:540px;
  line-height:1.7;
}
.section-header--center{text-align:center;margin-bottom:56px}
.section-header--center .section-subtitle{margin:0 auto}

/* =============================================
   BUTTONS
   ============================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:15px 34px;border:2px solid transparent;
  transition:all .3s var(--ease);white-space:nowrap;position:relative;
}
.btn--red{background:var(--red);color:var(--white);border-color:var(--red)}
.btn--red:hover{background:var(--red-bright);border-color:var(--red-bright);transform:translateY(-2px);box-shadow:var(--red-glow)}
.btn--outline-red{background:transparent;color:var(--red);border-color:var(--red)}
.btn--outline-red:hover{background:var(--red);color:var(--white);transform:translateY(-2px)}
.btn--white-outline{background:transparent;color:var(--white);border-color:rgba(255,255,255,.35)}
.btn--white-outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn--sm{padding:12px 26px;font-size:.72rem}
.btn--full{width:100%}
.btn-loader{display:none;width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}
.btn--loading .btn-text{visibility:hidden}
.btn--loading .btn-loader{display:inline-block;position:absolute}
@keyframes spin{to{transform:rotate(360deg)}}

/* =============================================
   MOBILE CALL BUTTON
   ============================================= */
.mobile-call-btn{
  display:none;position:fixed;bottom:24px;right:24px;z-index:900;
  background:var(--red);color:#fff;width:56px;height:56px;border-radius:50%;
  align-items:center;justify-content:center;
  box-shadow:0 4px 24px rgba(196,30,58,.4);
  animation:callPulse 2.5s ease-in-out infinite;
}
.mobile-call-btn span{display:none}
@keyframes callPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* =============================================
   NAVIGATION
   ============================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 0;background:transparent;transition:all .4s var(--ease);
}
body.has-promo-banner .nav{top:44px}
@media(max-width:600px){body.has-promo-banner .nav{top:60px}}
.nav--scrolled{
  background:rgba(8,8,8,.95);backdrop-filter:blur(16px);
  padding:12px 0;border-bottom:1px solid var(--border);
}
.nav__inner{
  max-width:var(--max-w);margin:0 auto;padding:0 32px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav__logo{display:flex;align-items:center;gap:10px;color:#fff}
.nav__logo-lm{font-family:var(--ff-display);font-size:1.5rem;font-weight:800;color:var(--red)}
.nav__logo-text{display:flex;flex-direction:column;line-height:1.15}
.nav__logo-name{font-family:var(--ff-display);font-size:.95rem;font-weight:600}
.nav__logo-tag{font-size:.55rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--red);margin-top:1px}

.nav__menu{display:flex;align-items:center;gap:2px}
.nav__link{
  color:rgba(255,255,255,.6);font-size:.75rem;font-weight:600;
  padding:8px 14px;letter-spacing:.04em;text-transform:uppercase;
}
.nav__link:hover{color:#fff}
.nav__cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--red);color:#fff;font-size:.72rem;font-weight:700;
  letter-spacing:.04em;padding:10px 18px;margin-left:10px;
}
.nav__cta:hover{background:var(--red-bright)}
.nav__toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__toggle span{width:20px;height:2px;background:#fff;transition:all .3s var(--ease)}
.nav__toggle.active span:nth-child(1){transform:rotate(45deg) translate(3.5px,3.5px)}
.nav__toggle.active span:nth-child(2){opacity:0}
.nav__toggle.active span:nth-child(3){transform:rotate(-45deg) translate(3.5px,-3.5px)}

/* =============================================
   HERO
   ============================================= */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:140px 32px 100px;
  background:var(--bg);overflow:hidden;text-align:center;
}
.hero__bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 30%,rgba(196,30,58,.06),transparent 60%),
    radial-gradient(ellipse 80% 60% at 50% 90%,rgba(196,30,58,.03),transparent 40%);
}
.hero__content{position:relative;z-index:2;max-width:760px;margin:0 auto}
.hero__badge{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(196,30,58,.08);border:1px solid rgba(196,30,58,.2);
  padding:10px 22px;margin-bottom:32px;
  font-size:.75rem;font-weight:600;color:rgba(255,255,255,.75);
}
.hero__badge-stars{color:var(--red-bright);font-size:1rem;letter-spacing:2px}
.hero__title{
  font-family:var(--ff-display);
  font-size:clamp(2.4rem,6vw,4.2rem);
  font-weight:700;color:#fff;line-height:1.1;margin-bottom:24px;
}
.hero__title-accent{display:block;color:var(--red-bright);font-style:italic;margin-top:4px}
.hero__sub{
  max-width:560px;margin:0 auto 36px;
  font-size:1rem;color:var(--text-muted);line-height:1.8;
}
.hero__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}
.hero__trust{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.hero__trust-item{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-dim)}
.hero__trust-item svg{color:var(--red);width:18px;height:18px}

/* =============================================
   PROOF BAR
   ============================================= */
.proof-bar{background:var(--red);border-top:1px solid rgba(255,255,255,.1)}
.proof-bar__inner{
  max-width:var(--max-w);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
}
.proof-bar__item{padding:26px 16px;text-align:center}
.proof-bar__num{display:block;font-family:var(--ff-display);font-size:1.8rem;font-weight:700;color:#fff;line-height:1}
.proof-bar__label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:4px;display:block}
.proof-bar__divider{display:none}

/* =============================================
   ABOUT
   ============================================= */
.about{padding:100px 0;background:var(--light-bg)}
.about .section-title{color:var(--light-text)}
.about .section-label{color:var(--red)}
.about__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center}
.about__media{position:relative}
.about__img-main{overflow:hidden;border-radius:4px;box-shadow:0 16px 48px rgba(0,0,0,.1)}
.about__img-main img{width:100%;height:320px;object-fit:cover}
.about__img-secondary{
  position:absolute;bottom:-24px;right:-16px;width:44%;
  border:4px solid var(--light-bg);border-radius:4px;overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.12);
}
.about__img-secondary img{width:100%;height:160px;object-fit:cover}
.about__experience-badge{
  position:absolute;top:-16px;left:-16px;
  background:var(--red);color:#fff;padding:18px 20px;text-align:center;
}
.about__experience-num{display:block;font-family:var(--ff-display);font-size:2rem;font-weight:700;line-height:1}
.about__experience-text{font-size:.55rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-top:2px}

.about__lead{font-size:1.05rem;font-weight:500;color:var(--light-text);margin-bottom:12px}
.about__content p{color:var(--light-muted);margin-bottom:14px;font-size:.92rem}
.about__features{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:24px 0 28px}
.about__feature{display:flex;gap:12px;align-items:flex-start}
.about__feature-icon{
  width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:rgba(196,30,58,.07);border-radius:4px;
}
.about__feature-icon svg{color:var(--red);width:20px;height:20px}
.about__feature strong{display:block;font-size:.8rem;color:var(--light-text)}
.about__feature span{font-size:.72rem;color:var(--light-muted)}

/* =============================================
   BRANDS
   ============================================= */
.brands{padding:100px 0;background:var(--bg)}
.brands__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.brand-card{
  background:var(--bg-card);border:1px solid var(--border);
  overflow:hidden;transition:all .4s var(--ease);
  display:flex;flex-direction:column;
}
.brand-card:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:var(--red-glow)}
.brand-card__header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border);
}
.brand-card__logo{height:24px;width:auto;max-width:100px;filter:brightness(0) invert(1);object-fit:contain}
.brand-card__logo-text{font-family:var(--ff-display);font-size:1.2rem;font-weight:600;color:#fff;font-style:italic}
.brand-card__tier{
  font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--red-bright);border:1px solid rgba(196,30,58,.3);padding:3px 8px;
}
.brand-card__image{height:180px;overflow:hidden;background:var(--bg)}
.brand-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.brand-card:hover .brand-card__image img{transform:scale(1.05)}
.brand-card__body{padding:20px;flex:1}
.brand-card__body h3{font-family:var(--ff-display);font-size:1.2rem;font-weight:700;color:#fff;margin-bottom:8px}
.brand-card__body p{font-size:.84rem;color:var(--text-muted);line-height:1.6;margin-bottom:12px}
.brand-card__features{display:flex;gap:8px;flex-wrap:wrap}
.brand-card__features li{font-size:.62rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-dim);background:rgba(255,255,255,.04);padding:3px 8px;border:1px solid var(--border)}
.brand-card__cta{
  display:block;width:100%;padding:14px;
  background:rgba(196,30,58,.06);border-top:1px solid var(--border);
  color:var(--red-bright);font-size:.72rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;text-align:center;
  transition:all .3s var(--ease);margin-top:auto;
}
.brand-card__cta:hover{background:var(--red);color:#fff}

/* =============================================
   PRODUCTS
   ============================================= */
.products{padding:100px 0;background:var(--light-bg)}
.products .section-title{color:var(--light-text)}
.products__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:0}
.product-card{
  background:#fff;border:1px solid var(--light-border);overflow:hidden;
  transition:all .4s var(--ease);position:relative;display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.08);border-color:var(--red)}
.product-card--featured{grid-column:span 1}
.product-card__badge{
  position:absolute;top:12px;left:12px;z-index:2;
  background:var(--red);color:#fff;font-size:.6rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;
}
.product-card__img{overflow:hidden;background:var(--light-border)}
.product-card__img img{width:100%;height:100%;min-height:200px;object-fit:cover;transition:transform .5s var(--ease)}
.product-card__img img{height:200px}
.product-card:hover .product-card__img img{transform:scale(1.03)}
.product-card__content{padding:24px;display:flex;flex-direction:column;justify-content:center}
.product-card__content h3{font-family:var(--ff-display);font-size:1.2rem;font-weight:700;color:var(--light-text);margin-bottom:8px}
.product-card__content p{font-size:.86rem;color:var(--light-muted);margin-bottom:14px;line-height:1.6}
.product-card__price{margin-bottom:14px}
.product-card__brand{display:block;font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:4px}
.product-card__price-old{display:block;font-size:.78rem;color:#999;text-decoration:line-through}
.product-card__price-new{font-family:var(--ff-display);font-size:1.6rem;font-weight:700;color:var(--red)}

.products__more{text-align:center;margin-top:48px;padding-top:40px;border-top:1px solid var(--light-border)}
.products__more p{font-size:.92rem;color:var(--light-muted);margin-bottom:20px}
.products__more .btn{margin:0 8px}

/* =============================================
   OFFERS
   ============================================= */
.offers{padding:100px 0;background:var(--bg)}
.offers .section-title{color:#fff}
.offers__grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:20px}
.offer-card{
  background:var(--bg-card);border:1px solid var(--border);
  padding:32px 24px;text-align:center;transition:all .3s var(--ease);
  position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;
}
.offer-card:hover{border-color:var(--red);transform:translateY(-3px)}
.offer-card--primary{background:linear-gradient(135deg,rgba(196,30,58,.1),rgba(8,8,8,1));border-color:rgba(196,30,58,.3)}
.offer-card__ribbon{
  position:absolute;top:14px;right:-26px;
  background:var(--red);color:#fff;font-size:.55rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;padding:4px 32px;transform:rotate(45deg);
}
.offer-card__value{font-family:var(--ff-display);font-size:2.2rem;font-weight:700;color:var(--red-bright);margin-bottom:8px}
.offer-card h3{font-family:var(--ff-display);font-size:1.1rem;font-weight:600;color:#fff;margin-bottom:10px}
.offer-card p{font-size:.84rem;color:var(--text-muted);margin-bottom:18px;line-height:1.6}

/* =============================================
   REVIEWS
   ============================================= */
.reviews{padding:100px 0;background:var(--bg-card)}
.reviews .section-title{color:#fff}
.reviews__header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px;gap:32px;flex-wrap:wrap}
.reviews__header-left{flex:1}
.reviews__header-right{text-align:right}
.reviews__score-num{font-family:var(--ff-display);font-size:2.6rem;font-weight:700;color:#fff;line-height:1}
.reviews__score-stars{color:var(--red-bright);font-size:1.1rem;letter-spacing:3px;margin:4px 0}
.reviews__score-count{font-size:.68rem;color:var(--text-dim);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.reviews__platforms{display:flex;gap:8px;margin-top:12px;justify-content:flex-end}
.reviews__platform{
  display:flex;align-items:center;gap:5px;padding:7px 12px;
  border:1px solid var(--border);color:var(--text-dim);
  font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
}
.reviews__platform:hover{border-color:var(--red);color:var(--red-bright)}
.reviews__platform svg{width:18px;height:18px}

.reviews__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:40px}
.review-card{background:var(--bg-elevated);border:1px solid var(--border);padding:24px;transition:all .3s}
.review-card:hover{border-color:rgba(196,30,58,.25)}
.review-card__stars{color:var(--red-bright);font-size:.9rem;letter-spacing:2px;margin-bottom:12px}
.review-card p{font-size:.88rem;color:var(--text-muted);line-height:1.7;font-style:italic;margin-bottom:16px}
.review-card footer{display:flex;align-items:center;gap:10px}
.review-card__avatar{
  width:34px;height:34px;background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-display);font-weight:700;font-size:.85rem;border-radius:50%;
}
.review-card cite{display:block;font-style:normal;font-size:.82rem;font-weight:600;color:#fff}
.review-card footer span{font-size:.68rem;color:var(--text-dim)}
.reviews__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.reviews__cta .btn--outline-red{color:var(--red-bright);border-color:rgba(196,30,58,.35)}
.reviews__cta .btn--outline-red:hover{background:var(--red);color:#fff;border-color:var(--red)}

/* =============================================
   CONTACT
   ============================================= */
.contact{padding:100px 0;background:var(--light-bg)}
.contact .section-title{color:var(--light-text)}
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.contact__intro{font-size:.95rem;color:var(--light-muted);margin-bottom:28px;line-height:1.7}
.contact__details{margin-bottom:24px}
.contact__detail{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--light-border)}
.contact__detail:last-child{border-bottom:none}
.contact__detail svg{color:var(--red);flex-shrink:0;margin-top:2px;width:20px;height:20px}
.contact__detail strong{display:block;font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#999;margin-bottom:2px}
.contact__detail p,.contact__detail a{font-size:.88rem;color:var(--light-text);line-height:1.5}
.contact__detail a:hover{color:var(--red)}
.contact__actions{display:flex;gap:12px;flex-wrap:wrap}

.contact-form{background:#fff;border:1px solid var(--light-border);padding:32px;box-shadow:0 4px 24px rgba(0,0,0,.04)}
.contact-form h3{font-family:var(--ff-display);font-size:1.3rem;font-weight:700;color:var(--light-text);margin-bottom:4px}
.contact-form>p{font-size:.84rem;color:var(--light-muted);margin-bottom:22px}
.form-field{margin-bottom:14px}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:13px 14px;border:1px solid var(--light-border);
  background:var(--light-bg);font-size:.88rem;color:var(--light-text);outline:none;
  transition:border-color .3s;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--red)}
.form-field textarea{resize:vertical;min-height:70px}
.form-field select{cursor:pointer;-webkit-appearance:none;appearance:none}
.form-status{margin-top:10px;padding:10px 14px;font-size:.82rem;font-weight:500;display:none}
.form-status--success{display:block;background:#f0fdf4;color:#15803d;border:1px solid #bbf7d0}
.form-status--error{display:block;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}
.form-disclaimer{font-size:.7rem;color:#999;margin-top:10px;text-align:center}

/* =============================================
   MAP
   ============================================= */
.map-section{line-height:0;border-top:1px solid var(--light-border)}
.map-section iframe{width:100%;display:block}

/* =============================================
   FOOTER
   ============================================= */
.footer{background:var(--bg);padding:72px 0 36px;color:var(--text-dim);border-top:1px solid var(--border)}
.footer__top{display:grid;grid-template-columns:1.2fr 2fr;gap:48px;margin-bottom:44px}
.footer__brand p{font-size:.84rem;line-height:1.7;margin-top:14px}
.footer__brand .nav__logo{margin-bottom:0}
.footer__social{display:flex;gap:8px;margin-top:18px}
.footer__social a{
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);color:var(--text-dim);transition:all .3s;
}
.footer__social a:hover{border-color:var(--red);color:var(--red-bright)}
.footer__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer__col h4{font-size:.62rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px}
.footer__col a,.footer__col span{display:block;font-size:.82rem;margin-bottom:7px}
.footer__col a:hover{color:var(--red-bright)}
.footer__bottom{border-top:1px solid var(--border);padding-top:24px;display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-dim)}

/* =============================================
   MODAL
   ============================================= */
.modal{display:none;position:fixed;inset:0;z-index:10000;align-items:center;justify-content:center;padding:24px}
.modal.active{display:flex}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(4px)}
.modal__content{
  position:relative;background:#fff;padding:36px;
  max-width:420px;width:100%;max-height:90vh;overflow-y:auto;
  animation:modalIn .3s var(--ease);
}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}
.modal__close{position:absolute;top:10px;right:14px;font-size:1.8rem;color:#999;line-height:1}
.modal__close:hover{color:var(--red)}
.modal__content h3{font-family:var(--ff-display);font-size:1.3rem;font-weight:700;color:var(--light-text);margin-bottom:4px}
.modal__content>p{font-size:.86rem;color:var(--light-muted);margin-bottom:20px}
.modal__content .form-field input{background:var(--light-bg);border:1px solid var(--light-border);color:var(--light-text)}
.modal__content .form-field input:focus{border-color:var(--red)}
.modal__phone{margin-top:14px;text-align:center;font-size:.84rem;color:var(--light-muted)}
.modal__phone a{color:var(--red);font-weight:700}

/* =============================================
   WHY US
   ============================================= */
.why-us{padding:100px 0;background:var(--bg-card)}
.why-us .section-title{color:#fff}
.why-us__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.why-us__card{
  background:var(--bg-elevated);border:1px solid var(--border);padding:32px 24px;text-align:center;
  transition:all .3s var(--ease);
}
.why-us__card:hover{border-color:var(--red);transform:translateY(-4px)}
.why-us__card-icon{font-size:2.2rem;margin-bottom:16px}
.why-us__card h3{font-family:var(--ff-display);font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:8px}
.why-us__card p{font-size:.84rem;color:var(--text-muted);line-height:1.6}

/* =============================================
   QUIZ
   ============================================= */
.quiz{padding:100px 0;background:var(--bg)}
.quiz .section-title{color:#fff}
.quiz .section-subtitle{color:var(--text-muted)}
.quiz__wrapper{max-width:720px;margin:0 auto;text-align:center}
.quiz__header{margin-bottom:40px}
.quiz__step{display:none}
.quiz__step.active{display:block;animation:fadeIn .4s var(--ease)}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.quiz__step-count{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.quiz__question{font-family:var(--ff-display);font-size:1.5rem;font-weight:600;color:#fff;margin-bottom:28px}
.quiz__options{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.quiz__option{
  background:var(--bg-card);border:2px solid var(--border);padding:20px 16px;
  text-align:center;transition:all .3s var(--ease);cursor:pointer;color:#fff;
}
.quiz__option:hover{border-color:var(--red);background:var(--bg-elevated)}
.quiz__option.selected{border-color:var(--red);background:rgba(196,30,58,.1);box-shadow:var(--red-glow)}
.quiz__option-icon{display:block;font-size:1.8rem;margin-bottom:8px}
.quiz__option-label{display:block;font-size:.88rem;font-weight:700;margin-bottom:4px}
.quiz__option-desc{display:block;font-size:.72rem;color:var(--text-muted)}
.quiz__progress{height:3px;background:var(--border);margin-top:32px;overflow:hidden}
.quiz__progress-bar{height:100%;background:var(--red);transition:width .4s var(--ease)}
.quiz__results-header{margin-bottom:28px}
.quiz__results-title{font-family:var(--ff-display);font-size:1.8rem;font-weight:700;color:#fff;margin-bottom:8px}
.quiz__results-subtitle{font-size:.92rem;color:var(--text-muted)}
.quiz__results-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}
.quiz__result-card{
  background:var(--bg-card);border:1px solid var(--border);padding:24px 20px;text-align:center;
  animation:fadeIn .5s var(--ease) both;
}
.quiz__result-rank{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red-bright);margin-bottom:8px}
.quiz__result-card h4{font-family:var(--ff-display);font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:4px}
.quiz__result-model{font-size:.8rem;color:var(--text-muted);margin-bottom:8px}
.quiz__result-why{font-size:.78rem;color:var(--text-dim);line-height:1.5;margin-bottom:12px}
.quiz__result-price{margin-bottom:14px}
.quiz__result-retail{font-size:.75rem;color:var(--text-dim);text-decoration:line-through;margin-right:8px}
.quiz__result-our{font-family:var(--ff-display);font-size:1.3rem;font-weight:700;color:var(--red-bright)}
.quiz__results-cta{text-align:center}
.quiz__results-cta p{font-size:.88rem;color:var(--text-muted);margin-bottom:16px}
.quiz__results-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.quiz__restart{background:none;border:none;color:var(--text-dim);font-size:.78rem;cursor:pointer;text-decoration:underline}
.quiz__restart:hover{color:var(--red)}

/* =============================================
   FINANCING
   ============================================= */
.financing{padding:100px 0;background:var(--bg-card)}
.financing .section-title{color:#fff}
.financing__inner{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
.financing__content p{font-size:.92rem;color:var(--text-muted);margin-bottom:20px;line-height:1.7}
.financing__list{margin-bottom:28px}
.financing__list li{
  padding:8px 0 8px 24px;font-size:.88rem;color:var(--text);position:relative;
}
.financing__list li::before{content:'✓';position:absolute;left:0;color:var(--red-bright);font-weight:700}
.financing__calc{
  background:var(--bg-elevated);border:1px solid var(--border);padding:36px;text-align:center;
}
.financing__calc-header{font-size:.65rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px}
.financing__calc-price{font-family:var(--ff-display);font-size:2.4rem;font-weight:700;color:#fff;margin-bottom:4px}
.financing__calc-monthly{font-size:1.1rem;color:var(--red-bright);margin-bottom:8px}
.financing__calc-monthly strong{font-size:1.5rem}
.financing__calc-terms{font-size:.75rem;color:var(--text-dim)}

/* Tempur-Pedic placeholder image */
.brand-placeholder{
  height:180px;background:linear-gradient(135deg,#1a0a0e,#0a0a0a);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-display);font-size:1.4rem;font-weight:700;
  color:rgba(255,255,255,.15);letter-spacing:.08em;
}

/* =============================================
   RESPONSIVE
   ============================================= */
@media(max-width:1024px){
  .brands__grid{grid-template-columns:1fr}
  .offers__grid{grid-template-columns:1fr 1fr}
  .offers__grid .offer-card:first-child{grid-column:1/-1}
  .reviews__header{flex-direction:column;align-items:flex-start}
  .reviews__header-right{text-align:left}
  .reviews__platforms{justify-content:flex-start}
  .why-us__grid{grid-template-columns:1fr 1fr}
  .quiz__results-cards{grid-template-columns:1fr}
  .financing__inner{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
}

@media(max-width:768px){
  .mobile-call-btn{display:flex}
  .nav__toggle{display:flex}
  .nav__menu{
    position:fixed;inset:0;background:rgba(8,8,8,.98);
    flex-direction:column;align-items:center;justify-content:center;gap:8px;
    opacity:0;pointer-events:none;transition:opacity .3s;z-index:99;
  }
  .nav__menu.active{opacity:1;pointer-events:all}
  .nav__link{font-size:1rem;padding:12px 20px;color:#fff}
  .nav__cta{margin:16px 0 0}

  .hero{padding:130px 24px 80px}
  .hero__title{font-size:clamp(2rem,7vw,3rem)}
  .hero__actions{flex-direction:column;align-items:center}
  .hero__actions .btn{width:100%;max-width:320px}
  .hero__trust{flex-direction:column;gap:10px}

  .proof-bar__inner{grid-template-columns:1fr 1fr}

  .about__grid{grid-template-columns:1fr;gap:40px}
  .about__img-secondary{position:static;width:55%;margin-top:-30px;margin-left:auto}
  .about__experience-badge{top:auto;bottom:-16px;left:auto;right:16px}
  .about__features{grid-template-columns:1fr}

  .brands__grid{grid-template-columns:1fr}
  .products__grid{grid-template-columns:1fr}
  .products__more .btn{display:block;margin:8px auto;max-width:280px}
  .offers__grid{grid-template-columns:1fr}
  .reviews__grid{grid-template-columns:1fr}
  .contact__grid{grid-template-columns:1fr}
  .why-us__grid{grid-template-columns:1fr}
  .quiz__options{grid-template-columns:1fr}
  .quiz__results-cards{grid-template-columns:1fr}
  .financing__inner{grid-template-columns:1fr}
  .footer__nav{grid-template-columns:1fr 1fr}
  .footer__bottom{flex-direction:column;gap:6px;text-align:center}
}

@media(max-width:480px){
  .proof-bar__inner{grid-template-columns:1fr 1fr}
  .proof-bar__item{padding:18px 12px}
  .proof-bar__num{font-size:1.4rem}
  .hero__badge{font-size:.68rem;padding:8px 14px}
  .contact-form{padding:24px}
  .modal__content{padding:28px}
}
