/* ============================================================
   NIGHTFURY — Singapore-designed cooling weighted blankets
   Shared design system
   Aesthetic: editorial wellness · cooling teal + night indigo
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400&family=Hanken+Grotesk:wght@300;400;500;600;700&display=swap');

:root{
  --bg:#EFF1F1;
  --bg-2:#E3E6E6;
  --paper:#FAFBFB;
  --ink:#1F2426;
  --ink-soft:#565C5E;
  --ink-faint:#8E9492;
  --night:#262B2D;
  --night-2:#181B1C;
  --aqua:#5F8B85;
  --aqua-bright:#9CBAB5;
  --aqua-glow:rgba(156,186,181,.42);
  --glacier:#CCD2D1;
  --sand:#CFC9BD;
  --sand-deep:#9C9282;
  --line:rgba(31,36,38,.14);
  --line-soft:rgba(31,36,38,.07);
  --white:#fff;

  --serif:'Fraunces',Georgia,serif;
  --sans:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,sans-serif;

  --r-sm:10px;
  --r:18px;
  --r-lg:28px;
  --r-xl:40px;

  --shadow-sm:0 2px 10px rgba(30,33,35,.07);
  --shadow:0 18px 50px -22px rgba(30,33,35,.28);
  --shadow-lg:0 40px 90px -40px rgba(30,33,35,.40);

  --maxw:1220px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--aqua);color:#fff}

/* grain overlay --------------------------------------------- */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;
  opacity:.32;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}

/* layout ---------------------------------------------------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
section{position:relative}
.eyebrow{
  font-size:12.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--aqua);display:inline-flex;align-items:center;gap:10px;margin-bottom:22px;
}
.eyebrow::before{content:"";width:26px;height:1.5px;background:var(--aqua);display:inline-block}
.eyebrow.light{color:var(--aqua-bright)}
.eyebrow.light::before{background:var(--aqua-bright)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.08;letter-spacing:-.015em}
h1{font-size:clamp(2.7rem,6.3vw,5.2rem)}
h2{font-size:clamp(2rem,4.3vw,3.5rem)}
h3{font-size:clamp(1.3rem,2vw,1.7rem)}
.lead{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-soft);line-height:1.6;font-weight:400}
em.acc{font-style:italic;color:var(--aqua);font-family:var(--serif)}

/* buttons --------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:11px;
  font-family:var(--sans);font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:17px 32px;border-radius:100px;transition:.4s var(--ease);
  white-space:nowrap;position:relative;
}
.btn svg{width:17px;height:17px;transition:transform .4s var(--ease)}
.btn-primary{background:var(--night);color:#fff}
.btn-primary:hover{background:var(--aqua);transform:translateY(-2px);box-shadow:0 16px 34px -14px var(--aqua-glow)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{border:1.5px solid var(--line);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.btn-light{background:#fff;color:var(--night)}
.btn-light:hover{background:var(--aqua-bright);transform:translateY(-2px)}
.btn-aqua{background:var(--aqua);color:#fff}
.btn-aqua:hover{background:var(--night);transform:translateY(-2px)}
.btn-block{width:100%}
.btn-lg{padding:20px 38px;font-size:16px}

/* ===========================================================
   NAVBAR
   =========================================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:.45s var(--ease);
}
.nav-inner{
  max-width:var(--maxw);margin:0 auto;padding:22px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  transition:.45s var(--ease);
}
.nav.scrolled{background:rgba(239,241,241,.82);backdrop-filter:blur(18px);box-shadow:0 1px 0 var(--line-soft)}
.nav.scrolled .nav-inner{padding-top:15px;padding-bottom:15px}
.logo{font-family:var(--serif);font-size:25px;font-weight:500;letter-spacing:.16em;display:flex;align-items:center;gap:11px}
.logo .dot{width:9px;height:9px;border-radius:50%;background:var(--aqua);position:relative}
.logo .dot::after{content:"";position:absolute;inset:-6px;border:1.5px solid var(--aqua);border-radius:50%;opacity:.4}
.nav-links{display:flex;align-items:center;gap:38px}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--ink-soft);transition:.3s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--aqua);transition:.35s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:18px}
.cart-btn{
  display:flex;align-items:center;gap:10px;background:var(--night);color:#fff;
  padding:12px 20px;border-radius:100px;font-size:14px;font-weight:600;transition:.35s var(--ease);
}
.cart-btn:hover{background:var(--aqua);transform:translateY(-1px)}
.cart-btn svg{width:17px;height:17px}
.cart-count{
  background:var(--aqua-bright);color:var(--night);min-width:21px;height:21px;border-radius:100px;
  display:grid;place-items:center;font-size:12px;font-weight:700;padding:0 6px;
}
.nav.scrolled .cart-count{background:var(--aqua);color:#fff}
.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:23px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ===========================================================
   HERO
   =========================================================== */
.hero{padding:158px 0 86px;position:relative;overflow:hidden}
.hero-mesh{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-mesh::before,.hero-mesh::after{content:"";position:absolute;border-radius:50%;filter:blur(80px)}
.hero-mesh::before{width:620px;height:620px;background:radial-gradient(circle,var(--aqua-glow),transparent 70%);top:-180px;right:-160px;opacity:.7}
.hero-mesh::after{width:520px;height:520px;background:radial-gradient(circle,rgba(200,206,205,.45),transparent 70%);bottom:-220px;left:-120px}
.hero-inner{display:grid;grid-template-columns:1.08fr .92fr;gap:56px;align-items:center;position:relative;z-index:2}
.hero-copy h1{font-size:clamp(3rem,6.5vw,5.4rem);margin:20px 0 26px}
.hero-copy .lead{max-width:486px;margin-bottom:38px;font-size:clamp(1.1rem,1.5vw,1.32rem)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.hero-trust{display:flex;gap:30px;flex-wrap:wrap}
.hero-trust .t{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:500;color:var(--ink-soft)}
.hero-trust .t svg{width:17px;height:17px;color:var(--aqua);flex-shrink:0}

/* product render */
.product-stage{position:relative;display:grid;place-items:center;min-height:480px}
.product-halo{position:absolute;width:118%;height:118%;border-radius:50%;
  background:radial-gradient(circle,rgba(156,186,181,.30),transparent 62%);filter:blur(20px);animation:breathe 7s var(--ease) infinite}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.06);opacity:1}}
.blanket-svg{width:100%;max-width:440px;filter:drop-shadow(0 40px 60px rgba(30,33,35,.28));position:relative;z-index:2}
.float-chip{
  position:absolute;background:rgba(250,251,251,.92);backdrop-filter:blur(10px);
  border:1px solid var(--line-soft);border-radius:16px;padding:13px 17px;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:11px;z-index:5;
}
.float-chip .ic{width:34px;height:34px;border-radius:10px;background:var(--aqua);color:#fff;display:grid;place-items:center;flex-shrink:0}
.float-chip .ic svg{width:17px;height:17px}
.float-chip b{font-size:14px;display:block;font-family:var(--serif);font-weight:500}
.float-chip span{font-size:12px;color:var(--ink-soft)}
.fc-1{top:34px;left:-22px;animation:floaty 5.5s var(--ease) infinite}
.fc-2{bottom:60px;right:-26px;animation:floaty 6.5s var(--ease) infinite .8s}
.fc-3{bottom:-6px;left:30px;animation:floaty 5s var(--ease) infinite 1.4s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}

/* marquee strip */
.strip{background:var(--night);color:#fff;padding:20px 0;overflow:hidden;white-space:nowrap}
.strip-track{display:inline-flex;gap:54px;animation:scroll 28s linear infinite}
.strip span{font-family:var(--serif);font-size:18px;display:inline-flex;align-items:center;gap:54px;color:rgba(255,255,255,.85)}
.strip span::after{content:"✦";color:var(--aqua-bright);font-size:13px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===========================================================
   SECTION SCAFFOLD
   =========================================================== */
.sec{padding:96px 0}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(2.1rem,4.6vw,3.7rem)}
.sec-head p{margin-top:18px;font-size:clamp(1.05rem,1.4vw,1.22rem)}
.sec-dark{background:var(--night);color:#fff}
.sec-dark .lead{color:rgba(255,255,255,.72)}
.sec-dark h2{color:#fff}
.sec-dark .sec-mesh{position:absolute;inset:0;overflow:hidden;z-index:0}
.sec-dark .sec-mesh::before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(95,139,133,.30),transparent 68%);filter:blur(60px);top:-160px;left:-120px}
.sec-dark .sec-mesh::after{content:"";position:absolute;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,206,205,.14),transparent 68%);filter:blur(60px);bottom:-180px;right:-140px}
.sec-dark .wrap{position:relative;z-index:2}

/* problem stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:10px}
.stat{padding:38px 32px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.10);border-radius:var(--r-lg)}
.stat .n{font-family:var(--serif);font-size:clamp(2.6rem,4.6vw,3.6rem);color:var(--aqua-bright);line-height:1}
.stat .l{margin-top:14px;color:rgba(255,255,255,.74);font-size:15px}

/* benefits grid */
.b-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.b-card{
  background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  padding:42px 36px;transition:.5s var(--ease);position:relative;overflow:hidden;
}
.b-card::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,var(--aqua-glow),transparent 55%);opacity:0;transition:.5s var(--ease)}
.b-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.b-card:hover::before{opacity:.4}
.b-card>*{position:relative;z-index:2}
.b-ic{width:54px;height:54px;border-radius:15px;background:var(--night);color:var(--aqua-bright);display:grid;place-items:center;margin-bottom:26px;transition:.5s var(--ease)}
.b-card:hover .b-ic{background:var(--aqua);color:#fff;transform:rotate(-6deg)}
.b-ic svg{width:24px;height:24px}
.b-card h3{margin-bottom:13px;font-size:1.42rem}
.b-card p{font-size:16px;color:var(--ink-soft);line-height:1.65}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:20px}
.step{position:relative;padding-top:34px}
.step .num{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--aqua);
  border:1.5px solid var(--aqua);width:40px;height:40px;border-radius:50%;display:grid;place-items:center;margin-bottom:24px}
.step h3{margin-bottom:13px;font-size:1.42rem}
.step p{font-size:16px;color:var(--ink-soft);line-height:1.65}
.step::before{content:"";position:absolute;top:54px;left:54px;right:-34px;height:1.5px;
  background:repeating-linear-gradient(90deg,var(--line) 0 6px,transparent 6px 12px)}
.step:last-child::before{display:none}

/* audience cards */
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.aud{
  border-radius:var(--r-lg);overflow:hidden;position:relative;min-height:440px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:38px;color:#fff;
  transition:.55s var(--ease);isolation:isolate;
}
.aud::before{content:"";position:absolute;inset:0;z-index:-2;transition:.7s var(--ease)}
.aud::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(20,22,23,.15) 0%,rgba(20,22,23,.55) 48%,rgba(20,22,23,.88) 100%)}
.aud:hover{transform:translateY(-8px)}
.aud:hover::before{transform:scale(1.07)}
.aud-1::before{background:linear-gradient(150deg,#3a4042,#202325)}
.aud-2::before{background:linear-gradient(150deg,#54625f,#23292a)}
.aud-3::before{background:linear-gradient(150deg,#6f6a60,#26292a)}
.aud .tag{font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--aqua-bright);margin-bottom:14px}
.aud h3{font-size:1.85rem;color:#fff;margin-bottom:14px}
.aud p{font-size:15.5px;color:rgba(255,255,255,.9);line-height:1.62}
.aud .deco{position:absolute;top:34px;right:34px;opacity:.18;z-index:-1}
.aud .deco svg{width:84px;height:84px}

/* showcase / CTA band */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.showcase-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:48px;box-shadow:var(--shadow)}
.spec-row{display:flex;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--line-soft);font-size:15px}
.spec-row:last-child{border:none}
.spec-row span:first-child{color:var(--ink-soft)}
.spec-row span:last-child{font-weight:600;font-family:var(--serif)}
.price-tag{display:flex;align-items:baseline;gap:12px;margin:6px 0 28px}
.price-tag .now{font-family:var(--serif);font-size:3rem;line-height:1}
.price-tag .was{font-size:1.1rem;color:var(--ink-faint);text-decoration:line-through}
.price-tag .save{background:var(--sand);color:var(--night);font-size:12px;font-weight:700;padding:5px 12px;border-radius:100px}

/* testimonials */
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.t-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:36px;transition:.4s var(--ease)}
.t-card:hover{box-shadow:var(--shadow);transform:translateY(-5px)}
.stars{color:var(--sand-deep);font-size:15px;letter-spacing:3px;margin-bottom:18px}
.t-card blockquote{font-family:var(--serif);font-size:1.12rem;line-height:1.55;color:var(--ink);margin-bottom:24px;font-weight:400}
.t-who{display:flex;align-items:center;gap:13px}
.t-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(140deg,var(--aqua),var(--night));color:#fff;
  display:grid;place-items:center;font-family:var(--serif);font-size:17px;font-weight:600}
.t-who b{font-size:14.5px;display:block}
.t-who span{font-size:13px;color:var(--ink-soft)}

/* faq */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;transition:.35s var(--ease)}
.faq-item.open{box-shadow:var(--shadow);border-color:transparent}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:27px 32px;text-align:left;font-family:var(--serif);font-size:1.22rem;font-weight:500}
.faq-q .pm{flex-shrink:0;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--line);
  display:grid;place-items:center;transition:.4s var(--ease);position:relative}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--ink);border-radius:2px}
.faq-q .pm::before{width:12px;height:1.7px}
.faq-q .pm::after{width:1.7px;height:12px;transition:.4s var(--ease)}
.faq-item.open .pm{background:var(--aqua);border-color:var(--aqua)}
.faq-item.open .pm::before,.faq-item.open .pm::after{background:#fff}
.faq-item.open .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a-in{padding:0 32px 28px;color:var(--ink-soft);font-size:16px;line-height:1.72}

/* newsletter / final cta */
.cta-band{background:var(--night);color:#fff;border-radius:var(--r-xl);padding:72px 60px;text-align:center;position:relative;overflow:hidden}
.cta-band .sec-mesh::before{top:-200px;left:50%;transform:translateX(-50%)}
.cta-band h2{color:#fff;max-width:620px;margin:0 auto 18px}
.cta-band p{color:rgba(255,255,255,.74);max-width:480px;margin:0 auto 36px}
.subscribe{display:flex;gap:12px;max-width:480px;margin:0 auto;position:relative;z-index:2}
.subscribe input{flex:1;padding:17px 22px;border-radius:100px;border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.07);color:#fff;font-family:var(--sans);font-size:15px;outline:none}
.subscribe input::placeholder{color:rgba(255,255,255,.5)}
.subscribe input:focus{border-color:var(--aqua-bright);background:rgba(255,255,255,.1)}

/* footer */
.footer{background:var(--night-2);color:rgba(255,255,255,.65);padding:78px 0 36px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .logo{color:#fff;margin-bottom:20px}
.footer-grid p{font-size:14.5px;line-height:1.7;max-width:280px}
.footer h4{font-family:var(--sans);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:22px;font-weight:600}
.footer-grid li{margin-bottom:13px}
.footer-grid a{font-size:14.5px;transition:.3s}
.footer-grid a:hover{color:var(--aqua-bright)}
.footer-bot{display:flex;justify-content:space-between;align-items:center;padding-top:30px;font-size:13px;flex-wrap:wrap;gap:14px}
.footer-bot .pays{display:flex;gap:10px;align-items:center}
.footer-bot .pays span{background:rgba(255,255,255,.08);padding:6px 12px;border-radius:8px;font-size:11px;font-weight:600;letter-spacing:.04em}

/* ===========================================================
   CART DRAWER
   =========================================================== */
.overlay{position:fixed;inset:0;background:rgba(20,22,23,.55);backdrop-filter:blur(4px);
  opacity:0;visibility:hidden;transition:.4s var(--ease);z-index:1500}
.overlay.show{opacity:1;visibility:visible}
.drawer{
  position:fixed;top:0;right:0;height:100%;width:440px;max-width:92vw;background:var(--bg);
  z-index:1600;transform:translateX(105%);transition:.55s var(--ease);display:flex;flex-direction:column;box-shadow:var(--shadow-lg);
}
.drawer.show{transform:translateX(0)}
.drawer-head{padding:28px 30px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line-soft)}
.drawer-head h3{font-size:1.4rem}
.x-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:.3s}
.x-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:rotate(90deg)}
.x-btn svg{width:16px;height:16px}
.drawer-body{flex:1;overflow-y:auto;padding:24px 30px}
.cart-empty{text-align:center;padding:80px 20px;color:var(--ink-soft)}
.cart-empty svg{width:60px;height:60px;color:var(--line);margin:0 auto 20px}
.ci{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line-soft)}
.ci-thumb{width:78px;height:78px;border-radius:14px;flex-shrink:0;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--glacier),var(--aqua));color:#fff}
.ci-thumb svg{width:34px;height:34px;opacity:.9}
.ci-info{flex:1;min-width:0}
.ci-info h4{font-family:var(--serif);font-size:1.05rem;font-weight:500;margin-bottom:4px}
.ci-meta{font-size:12.5px;color:var(--ink-soft);margin-bottom:12px}
.ci-bot{display:flex;justify-content:space-between;align-items:center}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:100px;overflow:hidden}
.qty button{width:30px;height:30px;display:grid;place-items:center;font-size:16px;color:var(--ink-soft);transition:.25s}
.qty button:hover{background:var(--ink);color:#fff}
.qty span{min-width:30px;text-align:center;font-size:14px;font-weight:600}
.ci-price{font-family:var(--serif);font-weight:600;font-size:1.05rem}
.ci-rm{font-size:12px;color:var(--ink-faint);text-decoration:underline;margin-top:8px;transition:.3s}
.ci-rm:hover{color:#c0584a}
.drawer-foot{padding:26px 30px;border-top:1px solid var(--line-soft);background:var(--paper)}
.dfoot-row{display:flex;justify-content:space-between;margin-bottom:12px;font-size:14.5px;color:var(--ink-soft)}
.dfoot-row.total{font-size:1.25rem;color:var(--ink);font-family:var(--serif);font-weight:600;
  padding-top:16px;margin-top:6px;border-top:1px solid var(--line);margin-bottom:22px}
.ship-note{font-size:12.5px;color:var(--aqua);margin:-2px 0 18px;display:flex;align-items:center;gap:7px}
.ship-note svg{width:14px;height:14px}

/* ===========================================================
   CHECKOUT MODAL
   =========================================================== */
.modal-wrap{position:fixed;inset:0;z-index:1700;display:grid;place-items:center;padding:24px;
  opacity:0;visibility:hidden;transition:.4s var(--ease)}
.modal-wrap.show{opacity:1;visibility:visible}
.modal{background:var(--bg);width:100%;max-width:920px;max-height:92vh;border-radius:var(--r-xl);
  overflow:hidden;display:grid;grid-template-columns:1.15fr .85fr;box-shadow:var(--shadow-lg);
  transform:translateY(24px) scale(.97);transition:.5s var(--ease)}
.modal-wrap.show .modal{transform:none}
.checkout-main{padding:44px;overflow-y:auto;min-height:0}
.checkout-side{background:var(--night);color:#fff;padding:44px 38px;overflow-y:auto;min-height:0;position:relative}
.checkout-side .sec-mesh::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(95,139,133,.32),transparent 68%);filter:blur(50px);top:-100px;right:-90px}
.ck-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px}
.ck-head h3{font-size:1.7rem}
.ck-head p{font-size:13.5px;color:var(--ink-soft);margin-top:4px}
.field{margin-bottom:18px}
.field label{display:block;font-size:12.5px;font-weight:600;letter-spacing:.04em;margin-bottom:8px;color:var(--ink-soft)}
.field input,.field select{
  width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;background:var(--paper);
  font-family:var(--sans);font-size:15px;color:var(--ink);outline:none;transition:.3s
}
.field input:focus,.field select:focus{border-color:var(--aqua);box-shadow:0 0 0 4px var(--aqua-glow)}

/* ----- Stripe Elements (embedded card fields) ----- */
.pay-label{display:block;font-size:12.5px;font-weight:600;letter-spacing:.04em;
  margin:6px 0 8px;color:var(--ink-soft)}
/* Block (NOT flex) — Stripe injects its iframe as a block child and
   needs the container to give it full width, otherwise it collapses. */
.stripe-field{
  display:block;width:100%;padding:15px 16px;border:1.5px solid var(--line);
  border-radius:12px;background:var(--paper);transition:.25s;min-height:52px}
.stripe-field.StripeElement--focus{border-color:var(--aqua);box-shadow:0 0 0 4px var(--aqua-glow)}
.stripe-field.StripeElement--invalid{border-color:#c0584a}
.stripe-field .__PrivateStripeElement,
.stripe-field iframe{width:100%!important;display:block!important}
.card-demo{padding:16px;border:1.5px dashed var(--line);border-radius:12px;
  background:var(--paper);font-size:13.5px;color:var(--ink-soft);line-height:1.55}
.card-errors{min-height:18px;margin-top:10px;font-size:13px;color:#c0584a}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.pay-tabs{display:flex;gap:10px;margin:8px 0 22px}
.pay-tab{flex:1;padding:14px 10px;border:1.5px solid var(--line);border-radius:14px;background:var(--paper);
  display:flex;flex-direction:column;align-items:center;gap:8px;font-size:12.5px;font-weight:600;
  color:var(--ink-soft);transition:.3s var(--ease)}
.pay-tab svg{height:20px;width:auto}
.pay-tab.active{border-color:var(--aqua);background:#fff;color:var(--ink);box-shadow:0 6px 18px -10px var(--aqua-glow)}
.pay-pane{display:none;animation:fade .4s var(--ease)}
.pay-pane.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.card-box{border:1.5px solid var(--line);border-radius:14px;padding:18px;background:var(--paper)}
.card-box .row{display:flex;gap:14px;margin-top:14px}
.card-box .row .field{flex:1;margin:0}
.pp-btn{width:100%;background:#ffc439;color:#003087;font-weight:800;font-size:17px;padding:16px;
  border-radius:100px;display:flex;align-items:center;justify-content:center;gap:6px;transition:.3s;font-family:var(--sans)}
.pp-btn:hover{filter:brightness(1.04);transform:translateY(-1px)}
.pp-btn i{font-style:italic;font-weight:800}
.pp-btn i.b{color:#003087}.pp-btn i.l{color:#0070ba}
.stripe-link{width:100%;background:#635bff;color:#fff;font-weight:700;font-size:16px;padding:17px;
  border-radius:100px;display:flex;align-items:center;justify-content:center;gap:10px;transition:.3s}
.stripe-link:hover{background:#5249e0;transform:translateY(-1px)}
.secure-row{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink-soft);margin-top:18px;justify-content:center}
.secure-row svg{width:15px;height:15px;color:var(--aqua)}
.os-line{display:flex;justify-content:space-between;font-size:14px;padding:11px 0;color:rgba(255,255,255,.78);border-bottom:1px solid rgba(255,255,255,.1)}
.os-line.tot{font-family:var(--serif);font-size:1.5rem;color:#fff;border:none;padding-top:20px;font-weight:600}
.os-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.os-item .th{width:54px;height:54px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center;flex-shrink:0}
.os-item .th svg{width:24px;height:24px;color:var(--aqua-bright)}
.os-item h5{font-family:var(--serif);font-size:15px;font-weight:500}
.os-item span{font-size:12px;color:rgba(255,255,255,.6)}
.os-perks{margin-top:30px;display:flex;flex-direction:column;gap:14px}
.os-perks .p{display:flex;gap:11px;font-size:13.5px;color:rgba(255,255,255,.8)}
.os-perks .p svg{width:17px;height:17px;color:var(--aqua-bright);flex-shrink:0}

/* success */
.ck-success{text-align:center;padding:50px 30px;display:none}
.ck-success.show{display:block;animation:fade .5s var(--ease)}
.ck-success .check{width:84px;height:84px;border-radius:50%;background:var(--aqua);color:#fff;
  display:grid;place-items:center;margin:0 auto 26px;animation:pop .6s var(--ease)}
.ck-success .check svg{width:38px;height:38px}
@keyframes pop{0%{transform:scale(0)}60%{transform:scale(1.15)}100%{transform:scale(1)}}
.ck-success h3{font-size:2rem;margin-bottom:14px}
.ck-success p{color:var(--ink-soft);max-width:380px;margin:0 auto 30px}

/* ===========================================================
   CHAT BOT
   =========================================================== */
.chat-fab{
  position:fixed;bottom:26px;right:26px;z-index:1400;width:62px;height:62px;border-radius:50%;
  background:var(--night);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow);
  transition:.45s var(--ease);
}
.chat-fab:hover{background:var(--aqua);transform:scale(1.06)}
.chat-fab svg{width:25px;height:25px;transition:.4s var(--ease)}
.chat-fab .close-ic{position:absolute;opacity:0;transform:rotate(-90deg)}
.chat-fab.open .open-ic{opacity:0;transform:rotate(90deg)}
.chat-fab.open .close-ic{opacity:1;transform:rotate(0)}
.chat-fab .ping{position:absolute;top:-2px;right:-2px;width:16px;height:16px;background:var(--aqua-bright);
  border:2.5px solid var(--bg);border-radius:50%;}
.chat-fab.open .ping{display:none}

.chat-win{
  position:fixed;bottom:100px;right:26px;z-index:1400;width:386px;max-width:92vw;height:560px;max-height:74vh;
  background:var(--bg);border-radius:24px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;
  overflow:hidden;opacity:0;visibility:hidden;transform:translateY(20px) scale(.96);transition:.45s var(--ease);
}
.chat-win.show{opacity:1;visibility:visible;transform:none}
.chat-top{background:var(--night);color:#fff;padding:22px 22px 24px;position:relative;overflow:hidden}
.chat-top .sec-mesh::before{content:"";position:absolute;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle,rgba(95,139,133,.36),transparent 65%);filter:blur(40px);top:-90px;right:-60px}
.chat-top .row{display:flex;align-items:center;gap:13px;position:relative;z-index:2}
.chat-av{width:44px;height:44px;border-radius:50%;background:linear-gradient(140deg,var(--aqua-bright),var(--aqua));
  display:grid;place-items:center;font-family:var(--serif);font-size:19px;font-weight:600;color:var(--night)}
.chat-top b{font-size:16px;display:block}
.chat-top .stat{font-size:12px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:6px;background:none;border:none;padding:0;margin-top:2px}
.chat-top .stat::before{content:"";width:7px;height:7px;border-radius:50%;background:#5fd6a0}
.chat-body{flex:1;overflow-y:auto;padding:22px 20px;display:flex;flex-direction:column;gap:14px;background:var(--bg)}
.msg{max-width:80%;padding:13px 17px;font-size:14.5px;line-height:1.55;border-radius:18px;animation:msgIn .4s var(--ease)}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg.bot{background:var(--paper);border:1px solid var(--line-soft);align-self:flex-start;border-bottom-left-radius:6px}
.msg.user{background:var(--night);color:#fff;align-self:flex-end;border-bottom-right-radius:6px}
.msg.bot a{color:var(--aqua);font-weight:600;text-decoration:underline}
.chips{display:flex;flex-wrap:wrap;gap:8px;padding:4px 20px 14px}
.chip{font-size:12.5px;font-weight:600;padding:9px 15px;border:1.5px solid var(--line);border-radius:100px;
  color:var(--ink-soft);background:var(--paper);transition:.3s var(--ease)}
.chip:hover{border-color:var(--aqua);color:var(--ink);background:#fff;transform:translateY(-1px)}
.chat-input{display:flex;gap:10px;padding:16px 18px;border-top:1px solid var(--line-soft);background:var(--paper)}
.chat-input input{flex:1;border:1.5px solid var(--line);border-radius:100px;padding:13px 18px;
  font-family:var(--sans);font-size:14px;outline:none;background:var(--bg)}
.chat-input input:focus{border-color:var(--aqua)}
.chat-send{width:44px;height:44px;border-radius:50%;background:var(--night);color:#fff;display:grid;place-items:center;flex-shrink:0;transition:.3s}
.chat-send:hover{background:var(--aqua)}
.chat-send svg{width:18px;height:18px}
.typing{display:flex;gap:5px;padding:15px 18px;background:var(--paper);border:1px solid var(--line-soft);
  border-radius:18px;border-bottom-left-radius:6px;align-self:flex-start;width:fit-content}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--ink-faint);animation:bounce 1.3s infinite}
.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}
@keyframes bounce{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}

/* ===========================================================
   SHOP PAGE
   =========================================================== */
.shop-hero{padding:150px 0 70px}
.config{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.config-visual{position:sticky;top:120px}
.cv-stage{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);
  padding:50px;display:grid;place-items:center;position:relative;overflow:hidden;min-height:460px}
.cv-stage .glow{position:absolute;width:80%;height:80%;border-radius:50%;
  background:radial-gradient(circle,var(--aqua-glow),transparent 65%);filter:blur(40px);transition:.6s var(--ease)}
.cv-thumbs{display:flex;gap:12px;margin-top:18px;justify-content:center}
.cv-thumb{width:64px;height:64px;border-radius:14px;border:2px solid var(--line);display:grid;place-items:center;
  cursor:pointer;transition:.3s;background:var(--paper)}
.cv-thumb.active{border-color:var(--aqua)}
.cv-thumb svg{width:28px;height:28px}
.config-panel .rating{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-size:14px;color:var(--ink-soft)}
.config-panel h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:10px}
.config-panel .sub{color:var(--ink-soft);margin-bottom:24px}
.cfg-price{display:flex;align-items:baseline;gap:14px;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid var(--line-soft)}
.cfg-price .now{font-family:var(--serif);font-size:2.6rem}
.cfg-price .was{font-size:1.1rem;color:var(--ink-faint);text-decoration:line-through}
.cfg-group{margin-bottom:28px}
.cfg-group .lbl{display:flex;justify-content:space-between;font-size:13px;font-weight:600;
  letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:14px}
.cfg-group .lbl span{color:var(--ink);text-transform:none;letter-spacing:0;font-weight:600}
.opts{display:flex;gap:11px;flex-wrap:wrap}
.opt{padding:13px 20px;border:1.5px solid var(--line);border-radius:14px;background:var(--paper);
  font-size:14px;font-weight:600;transition:.3s var(--ease);min-width:64px;text-align:center}
.opt small{display:block;font-weight:400;color:var(--ink-faint);font-size:11.5px;margin-top:2px}
.opt:hover{border-color:var(--ink-soft)}
.opt.active{border-color:var(--aqua);background:#fff;box-shadow:0 6px 18px -10px var(--aqua-glow);color:var(--ink)}
.swatch{width:46px;height:46px;border-radius:50%;border:3px solid transparent;outline:1.5px solid var(--line);
  outline-offset:2px;transition:.3s;cursor:pointer}
.swatch.active{outline-color:var(--aqua);outline-width:2px}
.sw-mist{background:linear-gradient(140deg,#cfd3cf,#a7afaa)}
.sw-glacier{background:linear-gradient(140deg,#c6cecd,#9aa8a6)}
.sw-sand{background:linear-gradient(140deg,#d8d2c4,#b3aa98)}
.sw-night{background:linear-gradient(140deg,#474d4e,#2a2f31)}
.cfg-actions{display:flex;gap:14px;margin:34px 0 22px}
.cfg-perks{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding-top:24px;border-top:1px solid var(--line-soft)}
.cfg-perks .p{display:flex;gap:10px;font-size:13.5px;color:var(--ink-soft);align-items:flex-start}
.cfg-perks .p svg{width:17px;height:17px;color:var(--aqua);flex-shrink:0;margin-top:2px}

/* shop info sections reuse .sec */
.compare-table{width:100%;border-collapse:collapse;background:var(--paper);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line-soft)}
.compare-table th,.compare-table td{padding:20px 24px;text-align:left;font-size:15px;border-bottom:1px solid var(--line-soft)}
.compare-table th{font-family:var(--serif);font-weight:500;font-size:1.05rem;background:var(--bg-2)}
.compare-table td:first-child{font-weight:600;color:var(--ink-soft);font-size:14px}
.compare-table .yes{color:var(--aqua);font-weight:700}
.compare-table .no{color:var(--ink-faint)}
.compare-table tr:last-child td{border-bottom:none}
.col-hl{background:rgba(156,186,181,.10)}

/* ===========================================================
   SUPPORT PAGE
   =========================================================== */
.support-hero{padding:150px 0 60px;text-align:center}
.support-hero h1{max-width:760px;margin:18px auto 22px}
.support-hero .lead{max-width:560px;margin:0 auto}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.contact-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-lg);
  padding:38px 32px;text-align:center;transition:.45s var(--ease)}
.contact-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.contact-card .ic{width:58px;height:58px;border-radius:16px;background:var(--night);color:var(--aqua-bright);
  display:grid;place-items:center;margin:0 auto 22px}
.contact-card .ic svg{width:25px;height:25px}
.contact-card h3{font-size:1.3rem;margin-bottom:10px}
.contact-card p{font-size:14px;color:var(--ink-soft);margin-bottom:18px}
.contact-card a{font-size:14px;font-weight:600;color:var(--aqua);display:inline-flex;align-items:center;gap:7px}
.contact-card a svg{width:14px;height:14px;transition:.3s}
.contact-card a:hover svg{transform:translateX(4px)}
.faq-cat{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:44px}
.faq-cat button{padding:11px 22px;border-radius:100px;border:1.5px solid var(--line);font-size:14px;
  font-weight:600;color:var(--ink-soft);transition:.3s var(--ease)}
.faq-cat button.active{background:var(--night);color:#fff;border-color:var(--night)}
.faq-cat button:hover{border-color:var(--ink)}
.care-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:10px}
.care-card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r);padding:30px 26px}
.care-card .n{font-family:var(--serif);color:var(--aqua);font-size:1.1rem;margin-bottom:14px}
.care-card h4{font-family:var(--serif);font-size:1.15rem;font-weight:500;margin-bottom:10px}
.care-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.6}

/* reveal animation */
/* Content is visible by default. Only when JS is healthy (html.js)
   do we hide-then-reveal on scroll, so a JS hiccup never blanks the page. */
.reveal{transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.js .reveal{opacity:0;transform:translateY(26px)}
html.js .reveal.in{opacity:1;transform:none}
html.js .reveal[data-d="1"]{transition-delay:.06s}
html.js .reveal[data-d="2"]{transition-delay:.12s}
html.js .reveal[data-d="3"]{transition-delay:.18s}
html.js .reveal[data-d="4"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1!important;transform:none!important;transition:none}
}

/* toast */
.toast{position:fixed;bottom:30px;left:50%;transform:translate(-50%,120px);z-index:1800;
  background:var(--night);color:#fff;padding:16px 26px;border-radius:100px;font-size:14.5px;font-weight:600;
  display:flex;align-items:center;gap:11px;box-shadow:var(--shadow-lg);transition:.5s var(--ease)}
.toast.show{transform:translate(-50%,0)}
.toast svg{width:18px;height:18px;color:var(--aqua-bright)}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media(max-width:1024px){
  /* minmax(0,1fr) stops a wide child (the blanket SVG) from forcing
     the grid track wider than the screen — fixes horizontal scroll. */
  .hero-inner,.config,.showcase,.footer-grid{grid-template-columns:minmax(0,1fr);gap:48px}
  .config-visual,.config-panel{position:static;min-width:0}
  .cv-stage{max-width:100%;min-height:0;padding:40px}
  .blanket-svg,.cv-stage svg{width:100%;height:auto;max-width:380px;display:block;margin:0 auto}
  .b-grid,.steps,.aud-grid,.t-grid,.stats{grid-template-columns:1fr 1fr}
  .care-grid{grid-template-columns:1fr 1fr}
  .modal{grid-template-columns:1fr;max-height:94vh}
  .checkout-side{display:none}
  .step::before{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  html,body{overflow-x:hidden;max-width:100%}
  body{font-size:16px}
  .wrap{padding:0 20px}
  .nav-links{display:none}
  .burger{display:flex}
  .nav-links.mob{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--bg);padding:24px 28px;gap:4px;box-shadow:var(--shadow);align-items:stretch}
  .nav-links.mob a{padding:14px 4px;font-size:1.05rem;border-bottom:1px solid var(--line-soft)}
  .nav-links.mob a:last-child{border-bottom:0}
  .hero{padding:140px 0 70px}
  .sec,.cta-band{padding:70px 0}
  .cta-band{padding:54px 24px}
  .b-grid,.steps,.aud-grid,.t-grid,.stats,.care-grid,.contact-grid,.cfg-perks{grid-template-columns:1fr}
  .subscribe{flex-direction:column}
  .subscribe input{text-align:center}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
  .hero-trust{gap:14px 22px}
  .checkout-main{padding:28px 20px}
  .field-row{grid-template-columns:1fr}
  .cv-stage{padding:30px}
  .nav-right .cart-btn span.lbl{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  h1{font-size:clamp(2.4rem,9vw,3.2rem)}
  /* full-width slide-over cart on phones */
  .drawer{width:100%;max-width:100%}
  .drawer-head,.drawer-body,.drawer-foot{padding-left:22px;padding-right:22px}
  /* comfortable tap targets */
  .opt{padding:14px 18px}
  .btn{min-height:48px}
  /* stack the configurator actions so 'Buy now' can't clip */
  .cfg-actions{flex-direction:column;gap:12px;margin:28px 0 20px}
  .cfg-actions .btn{width:100%;flex:none}
  .modal{border-radius:22px}
  .modal-wrap{padding:0}
  /* compare table fits the screen instead of side-scrolling */
  .compare-table th,.compare-table td{padding:11px 9px;font-size:12px;word-break:break-word}
  .compare-table th{font-size:12.5px}
  .compare-table td:first-child{font-size:11.5px}
  /* keep decorative hero bits inside the screen */
  .product-halo{max-width:100%}
  .float-chip{transform:scale(.92)}
}
@media(max-width:760px){
  .product-stage{min-height:0}
  .fc-1{top:10px;left:0}
  .fc-2{bottom:30px;right:0}
  .fc-3{bottom:-4px;left:6px}
}
@media(max-width:480px){
  .wrap{padding:0 16px}
  .logo{font-size:21px;letter-spacing:.12em}
  .footer-grid{grid-template-columns:1fr}
  .cfg-price .now{font-size:2.2rem}
  /* stack the proof chips neatly under the blanket instead of
     floating (where they'd clip on a narrow screen) */
  .product-stage{display:flex;flex-direction:column;align-items:center;gap:12px}
  .float-chip{position:relative;inset:auto;margin:0;transform:none!important;
    animation:none;width:auto;max-width:300px}
  .product-halo{display:none}
}
