/* ════════════════════════════════════════════════════════════════
   NexStore Marketing — UI Kit v2
   Editorial / quiet — competitor-grade visual anchors.
   ════════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body{
  margin:0; background:var(--canvas); color:var(--ink);
  font-family:var(--font-body);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01";
}
.wrap{ max-width:1400px; margin:0 auto; padding:0 40px; }
.italic-soft{ font-style:italic; font-weight:300; font-variation-settings:"opsz" 144; }
.link-u{ position:relative; text-decoration:none; }
.link-u::after{ content:''; position:absolute; left:0; right:0; bottom:-2px; height:1px; background:currentColor; opacity:.4; }

/* ── grain helper ── */
.grain{ position:relative; }
.grain::after{
  content:''; position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.95' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.12 0 0 0 0 0.08 0 0 0 0 0.06 0 0 0 0.4 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.4; pointer-events:none; mix-blend-mode:multiply; z-index:0;
}
.grain > *{ position:relative; z-index:1; }

/* ════════════════════════════════════════════════════════════════
   ANNOUNCEMENT + NAV
   ════════════════════════════════════════════════════════════════ */
.announce{ background:var(--ink); color:rgba(251,247,241,.9); text-align:center; padding:12px;
  font-size:11px; letter-spacing:0.28em; text-transform:uppercase; font-weight:500; }
.announce .sep{ margin:0 8px; color:var(--terra-300); }
.announce .o{ opacity:.6; }

nav.top{ position:sticky; top:0; z-index:40; background:rgba(251,247,241,0.85);
  backdrop-filter:blur(12px); border-bottom:1px solid rgba(26,20,18,0.08); }
nav.top .row{ height:80px; display:flex; align-items:center; justify-content:space-between; }
.brand{ display:flex; align-items:baseline; gap:8px; text-decoration:none; color:inherit; }
.brand .name{ font-family:var(--font-display); font-size:1.6rem; font-weight:500; letter-spacing:-0.02em; line-height:1; }
.brand .suf{ font-size:0.58rem; text-transform:uppercase; letter-spacing:0.3em; color:var(--terra-500); }
.nav-links{ display:flex; gap:40px; font-size:14px; }
.nav-links a{ color:var(--ink-soft); text-decoration:none; transition:color .2s; }
.nav-links a:hover{ color:var(--terra-500); }
.nav-actions{ display:flex; align-items:center; gap:16px; }
.nav-actions .signin{ font-size:14px; color:var(--ink-soft); text-decoration:none; }

.btn{ display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border-radius:9999px;
  font-size:14px; font-weight:500; border:none; cursor:pointer; text-decoration:none; transition:all .25s; }
.btn-dark{ background:var(--ink); color:var(--canvas); }
.btn-dark:hover{ background:var(--terra-500); }
.btn-primary{ background:var(--terra-500); color:var(--canvas); box-shadow:var(--shadow-warm-md); padding:14px 28px; }
.btn-primary:hover{ background:var(--terra-600); transform:translateY(-1px); }
.btn-outline{ padding:14px 28px; border-radius:9999px; border:1px solid rgba(26,20,18,0.18);
  background:transparent; color:var(--ink); font-weight:500; font-size:14px; text-decoration:none;
  display:inline-flex; align-items:center; gap:8px; cursor:pointer; transition:all .2s; }
.btn-outline:hover{ background:var(--ink); color:var(--canvas); border-color:var(--ink); }
.btn svg{ width:14px; height:14px; }

/* ════════════════════════════════════════════════════════════════
   HERO — drawn storefront on laptop, editorial style
   ════════════════════════════════════════════════════════════════ */
section.hero{ padding:48px 0 64px; position:relative; overflow:hidden; }
.hero-glow{ position:absolute; top:-10%; right:-15%; width:60%; height:110%;
  background:radial-gradient(ellipse at 60% 40%,rgba(184,69,31,.18) 0%,rgba(184,69,31,0) 55%);
  filter:blur(40px); pointer-events:none; }
.hero-glow-2{ position:absolute; bottom:-20%; left:-15%; width:55%; height:80%;
  background:radial-gradient(ellipse at center,rgba(63,94,63,.10) 0%,rgba(63,94,63,0) 60%);
  filter:blur(50px); pointer-events:none; }

.hero-rule-row{ display:flex; align-items:center; gap:18px; font-size:11px;
  letter-spacing:0.28em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:40px; }
.hero-rule-row .rule{ width:32px; height:1px; background:var(--terra-500); }
.hero-rule-row .dim{ color:var(--ink-faint); }

.hero-grid{ display:grid; grid-template-columns:5fr 7fr; gap:64px; align-items:center; }
.hero-copy h1{
  font-family:var(--font-display); font-weight:400;
  font-size:clamp(2.75rem, 5.5vw, 5.25rem);
  line-height:0.96; letter-spacing:-0.035em; margin:0 0 28px;
  text-wrap:balance; font-variation-settings:"opsz" 144;
}
.hero-copy h1 .ac{ font-style:italic; font-weight:300; color:var(--terra-500); }
.hero-copy p{ font-size:19px; line-height:1.55; color:var(--ink-soft); margin:0 0 36px; max-width:32rem; text-wrap:pretty; }
.hero-copy .cta{ display:flex; align-items:center; gap:24px; flex-wrap:wrap; margin-bottom:40px; }
.hero-copy .meta-row{ display:flex; align-items:center; gap:24px; padding-top:28px;
  border-top:1px solid rgba(26,20,18,0.10); }
.hero-copy .meta-row .item{ font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-muted);
  display:flex; align-items:center; gap:8px; }
.hero-copy .meta-row .item .pip{ width:6px; height:6px; border-radius:50%; background:var(--terra-500); }

/* ── scroll reveal motion ── */
.reveal{ opacity:0; transform:translateY(28px); transition: opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); }
.reveal.visible{ opacity:1; transform:translateY(0); }
.r-d1{ transition-delay:.08s; } .r-d2{ transition-delay:.16s; } .r-d3{ transition-delay:.24s; }
.r-d4{ transition-delay:.32s; } .r-d5{ transition-delay:.4s; } .r-d6{ transition-delay:.48s; }

/* the laptop visual */
.hero-visual{ position:relative; }
.hero-corner{ position:absolute; font-family:'Courier New',monospace; font-size:10px;
  letter-spacing:0.3em; text-transform:uppercase; color:var(--ink-muted);
  display:flex; align-items:center; gap:8px; }
.hero-corner.tl{ top:-22px; left:0; }
.hero-corner.tr{ top:-22px; right:0; }
.hero-corner .live{ width:6px; height:6px; border-radius:50%; background:var(--terra-500);
  animation:livePulse 2s ease-in-out infinite; }
@keyframes livePulse{ 0%,100%{ opacity:1;} 50%{ opacity:.4;} }

/* laptop body */
.laptop{ position:relative; }
.laptop-screen{
  background:var(--ink);
  border-radius:14px 14px 4px 4px;
  padding:14px 14px 0;
  box-shadow:
    0 30px 60px -20px rgba(26,20,18,.45),
    0 12px 30px -10px rgba(26,20,18,.20),
    inset 0 0 0 1px rgba(0,0,0,0.4);
  position:relative;
}
.laptop-screen::before{
  content:''; position:absolute; top:6px; left:50%; transform:translateX(-50%);
  width:60px; height:4px; background:rgba(255,255,255,0.05); border-radius:2px;
}
.laptop-bezel{ position:relative; border-radius:6px 6px 2px 2px; overflow:hidden; background:#fefbf6;
  aspect-ratio: 16/10; border:1px solid rgba(255,255,255,0.04); }
.laptop-base{
  height:14px; background:linear-gradient(to bottom,#e8dccc 0%,#c9bbab 50%,#9c8e7e 100%);
  border-radius:0 0 14px 14px;
  margin: -1px auto 0;
  width:108%;
  position:relative;
  box-shadow: 0 4px 8px -2px rgba(26,20,18,.18);
}
.laptop-base::before{
  content:''; position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:18%; height:5px; background:#a89a8a; border-radius:0 0 6px 6px;
}
/* small phone overlay */
.hero-phone{
  position:absolute; right:-32px; bottom:-40px;
  width:160px; aspect-ratio: 9/19;
  background:#1a1412; border-radius:24px; padding:6px;
  box-shadow:
    0 20px 40px -10px rgba(26,20,18,.45),
    0 0 0 1px rgba(0,0,0,0.5);
  transform:rotate(4deg);
}
.hero-phone-screen{ width:100%; height:100%; background:#fefbf6; border-radius:18px; overflow:hidden; position:relative; }

/* ════════════════════════════════════════════════════════════════
   STOREFRONT MOCK (used inside laptop and phone)
   ════════════════════════════════════════════════════════════════ */
.sf{ width:100%; height:100%; background:#fefbf6; display:flex; flex-direction:column; overflow:hidden; }
.sf-nav{ height:42px; flex-shrink:0; display:flex; align-items:center; justify-content:space-between; padding:0 28px;
  border-bottom:1px solid rgba(26,20,18,0.06); background:rgba(254,251,246,0.95); }
.sf-brand{ font-family:var(--font-display); font-size:15px; letter-spacing:-0.01em; }
.sf-links{ display:flex; gap:22px; font-size:9.5px; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-soft); }
.sf-cart{ font-size:9.5px; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-soft); display:flex; gap:6px; align-items:center; }
.sf-cart .b{ background:var(--ink); color:var(--canvas); width:16px; height:16px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:9px; letter-spacing:0; }

.sf-hero{ flex:1; padding:24px 28px 0; display:grid; grid-template-columns:1.05fr 1fr; gap:20px; align-items:center; }
.sf-eyb{ font-size:9px; letter-spacing:0.28em; text-transform:uppercase; color:var(--terra-500); margin-bottom:10px; }
.sf-h{ font-family:var(--font-display); font-weight:400; font-size:36px; line-height:0.96; letter-spacing:-0.03em;
  margin:0 0 12px; font-variation-settings:"opsz" 144; text-wrap:balance; }
.sf-h .acc{ font-style:italic; font-weight:300; color:var(--terra-500); }
.sf-p{ font-size:11px; line-height:1.55; color:var(--ink-soft); margin:0 0 16px; max-width:28ch; }
.sf-ctas{ display:flex; gap:8px; }
.sf-btn{ padding:7px 14px; border-radius:9999px; font-size:10px; letter-spacing:0.04em; text-decoration:none; font-weight:500; }
.sf-btn.p{ background:var(--ink); color:var(--canvas); }
.sf-btn.s{ border:1px solid rgba(26,20,18,0.18); color:var(--ink); }

.sf-img-wrap{ aspect-ratio:4/5; border-radius:10px; position:relative; overflow:hidden; box-shadow:var(--shadow-warm-md); }
.sf-img{ position:absolute; inset:0; }
.sf-img.linen{ background:linear-gradient(160deg,#dd9e6e 0%,#b8451f 60%,#7c2a0f 100%); }
.sf-img.linen::before{ content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 50% at 35% 30%,rgba(255,255,255,0.28) 0%,transparent 65%); }
.sf-img.linen::after{ content:''; position:absolute; inset:25% 18% auto auto; width:55%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle,rgba(255,232,200,0.25) 0%,transparent 60%); filter:blur(8px); }
.sf-tag{ position:absolute; left:12px; bottom:12px; background:rgba(20,16,16,0.6); backdrop-filter:blur(6px);
  color:#fefbf6; padding:5px 10px; border-radius:9999px; font-size:8.5px; letter-spacing:0.18em; text-transform:uppercase; }

/* product strip below hero */
.sf-strip{ padding:18px 28px 22px; display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.sf-card{ aspect-ratio:3/4; border-radius:8px; position:relative; overflow:hidden; }
.sf-card .lbl{ position:absolute; left:8px; bottom:6px; right:8px; font-size:8px; color:var(--canvas);
  text-shadow:0 1px 2px rgba(0,0,0,0.5); display:flex; justify-content:space-between; }
.sf-c1{ background:linear-gradient(150deg,#cc7a44,#7c2a0f); }
.sf-c2{ background:linear-gradient(150deg,#3a2f2a,#141010); }
.sf-c3{ background:linear-gradient(150deg,#dd9e6e,#9a3412); }
.sf-c4{ background:linear-gradient(150deg,#3f5e3f,#1a1412); }

/* phone storefront — simpler */
.hero-phone .sf-nav{ height:30px; padding:0 12px; }
.hero-phone .sf-brand{ font-size:11px; }
.hero-phone .sf-links, .hero-phone .sf-cart{ font-size:7px; gap:8px; }
.hero-phone .sf-cart .b{ width:12px; height:12px; font-size:7px; }
.hero-phone .sf-hero{ display:block; padding:12px 12px 0; }
.hero-phone .sf-h{ font-size:18px; margin-bottom:8px; }
.hero-phone .sf-p{ font-size:8px; margin-bottom:10px; }
.hero-phone .sf-img-wrap{ aspect-ratio:1.4/1; margin-top:10px; border-radius:6px; }
.hero-phone .sf-tag{ font-size:6.5px; padding:3px 6px; left:6px; bottom:6px; }
.hero-phone .sf-ctas{ gap:5px; }
.hero-phone .sf-btn{ padding:4px 8px; font-size:7.5px; }
.hero-phone .sf-strip, .hero-phone .sf-tag-row{ display:none; }

/* hero proof ribbon */
.hero-proof{ margin-top:48px; padding-top:32px; border-top:1px solid rgba(26,20,18,0.08);
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; }
.hero-proof .lbl{ font-size:10px; letter-spacing:0.28em; text-transform:uppercase; color:var(--ink-muted); }
.hero-proof .marks{ display:flex; align-items:center; gap:36px; flex-wrap:wrap; }
.hero-proof .mark{ font-family:var(--font-display); font-size:18px; font-style:italic; font-weight:300;
  color:var(--ink-soft); letter-spacing:-0.01em; opacity:.65; }

/* ════════════════════════════════════════════════════════════════
   TICKER
   ════════════════════════════════════════════════════════════════ */
.ticker{ border-top:1px solid rgba(26,20,18,0.10); border-bottom:1px solid rgba(26,20,18,0.10);
  background:var(--canvas-soft); overflow:hidden; padding:18px 0; }
.ticker-track{ display:flex; white-space:nowrap; font-size:12px; letter-spacing:0.22em;
  text-transform:uppercase; color:var(--ink-soft); font-weight:500;
  animation:marquee 60s linear infinite; }
.ticker-track > span{ padding:0 32px; display:inline-flex; align-items:center; gap:40px; }
.ticker-track .dot{ width:6px; height:6px; border-radius:50%; background:var(--terra-500); }
.ticker-track .ast{ color:var(--ink-faint); }
@keyframes marquee{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
