/* ============================================================
   Sonzal — custom design layer (sits on top of Tailwind)
   Kashmir craft world: chinar crimson, saffron, walnut, Dal-lake teal
   ============================================================ */

:root{
  --ivory:#F8F2E6; --ivory-2:#F1E8D6;
  --walnut:#33231A; --walnut-2:#4A3526;
  --crimson:#8E2A23; --crimson-deep:#6E1F1A;
  --saffron:#D79A2B; --saffron-lt:#E9B85C;
  --teal:#1E5C56; --lake:#2C6E7F;
  --line:rgba(51,35,26,.14);
  --shadow-soft:0 18px 50px -20px rgba(51,35,26,.45);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{ -webkit-tap-highlight-color:transparent; }
html{ scroll-behavior:smooth; }
body{
  background:var(--ivory); color:var(--walnut);
  font-family:'Karla',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
.font-display{ font-family:'Marcellus',serif; }
.font-quote{ font-family:'Cormorant Garamond',serif; }

/* paper grain — barely-there texture so flat areas feel woven, not plastic */
body::before{
  content:""; position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.5;
  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='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
main, header, footer, .gov-strip{ position:relative; z-index:2; }

::selection{ background:var(--saffron); color:var(--walnut); }
::-webkit-scrollbar{ width:11px; }
::-webkit-scrollbar-track{ background:var(--ivory-2); }
::-webkit-scrollbar-thumb{ background:var(--crimson); border:3px solid var(--ivory-2); border-radius:99px; }

/* ---------- govt strip ---------- */
.gov-strip{ background:var(--walnut); color:var(--ivory); position:relative; z-index:40; }
.gov-dot{ width:8px;height:8px;border-radius:99px;background:var(--saffron);box-shadow:0 0 0 3px rgba(215,154,43,.25); }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(248,242,230,.82); backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--line); transition:box-shadow .4s var(--ease), background .4s var(--ease);
}
.site-header.scrolled{ box-shadow:0 10px 30px -18px rgba(51,35,26,.5); background:rgba(248,242,230,.94); }
.brand{ display:flex; align-items:center; gap:.6rem; }
.brand-mark{ color:var(--crimson); display:grid; place-items:center; transition:transform .6s var(--ease); }
.brand:hover .brand-mark{ transform:rotate(-12deg) scale(1.06); }
.brand-name{ font-family:'Marcellus',serif; font-size:1.5rem; line-height:1; color:var(--walnut); display:block; }
.brand-sub{ font-size:.56rem; letter-spacing:.2em; text-transform:uppercase; color:var(--teal); font-weight:700; display:block; margin-top:2px; }
.nav-link{ color:var(--walnut-2); position:relative; transition:color .25s; }
.nav-link::after{ content:""; position:absolute; left:0; bottom:-5px; height:2px; width:0; background:var(--crimson); transition:width .3s var(--ease); }
.nav-link:hover{ color:var(--crimson); } .nav-link:hover::after, .nav-link.is-active::after{ width:100%; }
.btn-basket{
  display:inline-flex; align-items:center; gap:.4rem; padding:.5rem .9rem; border-radius:99px;
  background:var(--crimson); color:var(--ivory); font-weight:700; font-size:.85rem;
  transition:transform .25s var(--ease), background .25s; box-shadow:0 8px 20px -10px rgba(142,42,35,.8);
}
.btn-basket:hover{ background:var(--crimson-deep); transform:translateY(-2px); }

/* ---------- buttons ---------- */
.btn-primary{
  position:relative; overflow:hidden; display:inline-flex; align-items:center; gap:.5rem;
  padding:.95rem 1.7rem; border-radius:99px; font-weight:700; background:var(--saffron); color:var(--walnut);
  transition:transform .3s var(--ease), box-shadow .3s; box-shadow:0 14px 30px -12px rgba(215,154,43,.9);
}
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 20px 38px -12px rgba(215,154,43,.95); }
.btn-primary::after{ /* sheen */
  content:""; position:absolute; top:0; left:-120%; width:60%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent); transform:skewX(-18deg);
}
.btn-primary:hover::after{ animation:sheen 1s var(--ease); }
@keyframes sheen{ to{ left:140%; } }
.btn-ghost{
  display:inline-flex; align-items:center; gap:.5rem; padding:.95rem 1.7rem; border-radius:99px; font-weight:700;
  border:1px solid rgba(248,242,230,.5); color:var(--ivory); transition:background .3s, transform .3s var(--ease);
}
.btn-ghost:hover{ background:rgba(248,242,230,.12); transform:translateY(-3px); }

/* ============================================================
   HERO — layered depth + parallax + entrance choreography
   ============================================================ */
.hero{
  position:relative; overflow:hidden; color:var(--ivory);
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(215,154,43,.32), transparent 55%),
    radial-gradient(90% 80% at 8% 110%, rgba(44,110,127,.45), transparent 60%),
    linear-gradient(160deg,#6E1F1A 0%, #8E2A23 52%, #7c241e 100%);
  perspective:1200px;
}
.hero-grain{ position:absolute; inset:0; opacity:.5; mix-blend-mode:overlay; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.06'/%3E%3C/svg%3E"); }
.hero-stage{ position:relative; z-index:3; transform-style:preserve-3d; }

/* floating paisley motifs at varying depth */
.motif{ position:absolute; color:rgba(248,242,230,.10); pointer-events:none; will-change:transform; }
.motif svg{ display:block; }
.motif.m1{ top:8%;  left:6%;  width:120px; animation:float 9s ease-in-out infinite; }
.motif.m2{ top:58%; left:2%;  width:90px;  color:rgba(215,154,43,.16); animation:float 11s ease-in-out infinite reverse; }
.motif.m3{ top:14%; right:9%; width:150px; color:rgba(248,242,230,.08); animation:float 13s ease-in-out infinite; }
.motif.m4{ bottom:8%; right:16%; width:80px; color:rgba(44,110,127,.30); animation:float 10s ease-in-out infinite reverse; }
@keyframes float{ 0%,100%{ transform:translateY(0) rotate(0); } 50%{ transform:translateY(-22px) rotate(6deg); } }

.eyebrow{ font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; font-weight:700; color:var(--saffron-lt); }
.hero h1{ font-family:'Marcellus',serif; line-height:1.04; letter-spacing:-.01em; }
.hero .ink-saffron{ color:var(--saffron-lt); position:relative; white-space:nowrap; }
.hero .ink-saffron::after{ content:""; position:absolute; left:0; right:0; bottom:.06em; height:.42em; background:rgba(215,154,43,.22); border-radius:6px; z-index:-1; transform:scaleX(0); transform-origin:left; animation:underline 1s var(--ease) 1.1s forwards; }
@keyframes underline{ to{ transform:scaleX(1); } }

/* entrance choreography */
[data-rise]{ opacity:0; transform:translateY(26px); }
.rise-go [data-rise]{ animation:rise .9s var(--ease) forwards; }
.rise-go [data-rise="1"]{ animation-delay:.05s; }
.rise-go [data-rise="2"]{ animation-delay:.18s; }
.rise-go [data-rise="3"]{ animation-delay:.32s; }
.rise-go [data-rise="4"]{ animation-delay:.46s; }
.rise-go [data-rise="5"]{ animation-delay:.6s; }
@keyframes rise{ to{ opacity:1; transform:none; } }

.scroll-cue{ position:absolute; bottom:22px; left:50%; transform:translateX(-50%); z-index:4; color:rgba(248,242,230,.7); }
.scroll-cue span{ display:block; width:1px; height:42px; margin:8px auto 0; background:linear-gradient(rgba(248,242,230,.7),transparent); animation:cue 1.8s ease-in-out infinite; transform-origin:top; }
@keyframes cue{ 0%,100%{ transform:scaleY(.3); opacity:.4; } 50%{ transform:scaleY(1); opacity:1; } }

/* hero glass stat card */
.glass{
  background:rgba(248,242,230,.10); border:1px solid rgba(248,242,230,.22);
  backdrop-filter:blur(10px); border-radius:20px; box-shadow:0 20px 50px -24px rgba(0,0,0,.6);
}

/* ---------- trust band count-up ---------- */
.stat-num{ font-family:'Marcellus',serif; line-height:1; }

/* ---------- GI marquee ---------- */
.marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:3rem; width:max-content; animation:marq 26s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-item{ display:inline-flex; align-items:center; gap:.6rem; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(248,242,230,.85); white-space:nowrap; }
.marquee-item::before{ content:"❧"; color:var(--saffron); }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ---------- scroll reveals ---------- */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.08s; }
.reveal[data-delay="2"]{ transition-delay:.16s; }
.reveal[data-delay="3"]{ transition-delay:.24s; }
.reveal[data-delay="4"]{ transition-delay:.32s; }

/* section eyebrow + heading rhythm */
.sec-eyebrow{ font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; font-weight:700; color:var(--crimson); }
.sec-title{ font-family:'Marcellus',serif; line-height:1.08; }

/* ---------- category 3D tilt cards ---------- */
.tilt{ transform-style:preserve-3d; transition:transform .3s var(--ease), box-shadow .3s; will-change:transform; }
.tilt .tilt-inner{ transform:translateZ(40px); }
.tilt .glare{ position:absolute; inset:0; border-radius:inherit; background:radial-gradient(circle at var(--gx,50%) var(--gy,0%), rgba(255,255,255,.35), transparent 45%); opacity:0; transition:opacity .3s; pointer-events:none; }
.tilt:hover .glare{ opacity:1; }

.cat-card{ position:relative; overflow:hidden; border-radius:20px; min-height:230px; display:flex; flex-direction:column; justify-content:flex-end; padding:1.4rem; color:var(--ivory); box-shadow:var(--shadow-soft); }
.cat-card .cat-bg{ position:absolute; inset:0; z-index:0; transition:transform .6s var(--ease); }
.cat-card:hover .cat-bg{ transform:scale(1.07); }
.cat-card .cat-tint{ position:absolute; inset:0; z-index:1; }

/* ---------- product cards ---------- */
.prod-card{ background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; display:flex; flex-direction:column; transition:transform .35s var(--ease), box-shadow .35s; }
.prod-card:hover{ transform:translateY(-7px); box-shadow:var(--shadow-soft); }
.prod-media{ position:relative; aspect-ratio:1/1; display:grid; place-items:center; overflow:hidden; background:linear-gradient(140deg,var(--crimson),var(--crimson-deep)); color:var(--saffron); }
.prod-media svg{ transition:transform .6s var(--ease); }
.prod-card:hover .prod-media svg{ transform:scale(1.12) rotate(-6deg); }
.badge{ position:absolute; top:.7rem; left:.7rem; z-index:2; font-size:.6rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; padding:.28rem .55rem; border-radius:6px; }
.badge-gi{ background:var(--saffron); color:var(--walnut); }
.badge-shg{ background:var(--teal); color:#fff; }
.chip{ padding:.5rem 1rem; border-radius:99px; border:1px solid var(--line); background:#fff; font-size:.85rem; font-weight:600; cursor:pointer; transition:all .25s var(--ease); }
.chip:hover{ border-color:var(--crimson); }
.chip.on{ background:var(--walnut); color:var(--ivory); border-color:var(--walnut); }

/* ---------- maker story band ---------- */
.makers{ background:
  radial-gradient(80% 120% at 100% 0%, rgba(44,110,127,.10), transparent 50%),
  linear-gradient(180deg,var(--ivory),var(--ivory-2)); }
.maker-quote{ font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:500; line-height:1.25; }
.thread{ height:2px; background:linear-gradient(90deg,transparent,var(--saffron),transparent); position:relative; }
.thread::after{ content:""; position:absolute; top:50%; left:0; width:9px; height:9px; border-radius:99px; background:var(--saffron); transform:translateY(-50%); box-shadow:0 0 0 4px rgba(215,154,43,.25); animation:bead 6s var(--ease) infinite; }
@keyframes bead{ 0%{ left:0; } 50%{ left:100%; } 100%{ left:0; } }

/* ---------- authenticity steps ---------- */
.step-no{ font-family:'Marcellus',serif; font-size:2.4rem; color:var(--saffron); line-height:1; }
.step-card{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:1.6rem; transition:transform .35s var(--ease), box-shadow .35s; }
.step-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-soft); }

/* ---------- footer ---------- */
.site-footer{ background:var(--walnut); color:var(--ivory); }
.foot-h{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--saffron); font-weight:700; margin-bottom:.7rem; }
.foot-link{ display:block; color:rgba(248,242,230,.72); font-size:.9rem; padding:.22rem 0; transition:color .2s, padding-left .2s; }
.foot-link:hover{ color:var(--ivory); padding-left:4px; }

/* ---------- cart drawer ---------- */
.drawer{ position:fixed; top:0; right:0; height:100dvh; width:min(410px,92vw); background:var(--ivory); z-index:90; box-shadow:-30px 0 60px -30px rgba(0,0,0,.5); transform:translateX(100%); transition:transform .45s var(--ease); display:flex; flex-direction:column; }
.drawer.open{ transform:none; }
.overlay{ position:fixed; inset:0; background:rgba(51,35,26,.5); backdrop-filter:blur(2px); z-index:80; opacity:0; pointer-events:none; transition:opacity .4s; }
.overlay.open{ opacity:1; pointer-events:auto; }

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  [data-rise], .reveal{ opacity:1 !important; transform:none !important; }
}
