/* ============================================================
   LoomQueen — Launch page
   Palette pulled from the logo: wine, antique gold, warm cream
   ============================================================ */
:root{
  --wine:        #5E1A2B;
  --wine-deep:   #44121F;
  --wine-soft:   #7A2436;
  --gold:        #C29A4B;
  --gold-light:  #E8CE8A;
  --gold-deep:   #A57E33;
  --cream:       #F7F3EC;
  --cream-warm:  #EFE7DA;
  --ink:         #2A1A1E;
  --paper:       #FBF8F2;

  --grad-gold: linear-gradient(135deg, var(--gold-light) 0%, var(--gold) 45%, var(--gold-deep) 100%);
  --shadow-soft: 0 24px 60px -28px rgba(68,18,31,.45);

  --serif: "Cormorant Garamond", Georgia, serif;
  --roman: "Marcellus", "Cormorant Garamond", serif;
  --body:  "Mulish", -apple-system, sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* ---------- grain overlay ---------- */
.grain{
  position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ---------- header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px clamp(20px,5vw,64px);
  transition:background .4s ease, box-shadow .4s ease, padding .4s ease;
}
.site-header.scrolled{
  background:rgba(251,248,242,.88);
  backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(94,26,43,.08);
  padding-top:12px; padding-bottom:12px;
}
.brand__logo{
  height:48px; width:auto; border-radius:6px;
  transition:height .4s ease;
  mix-blend-mode:multiply;
}
.site-header.scrolled .brand__logo{ height:40px; }

.nav{ display:flex; align-items:center; gap:clamp(16px,3vw,36px); }
.nav a{
  font-family:var(--roman); font-size:.95rem; letter-spacing:.04em;
  color:var(--wine); opacity:.85; transition:opacity .25s;
}
.nav a:hover{ opacity:1; }
.nav__cta{
  border:1px solid var(--gold);
  padding:8px 20px; border-radius:999px;
  color:var(--wine)!important; opacity:1!important;
}
.nav__cta:hover{ background:var(--gold); color:#fff!important; }

@media(max-width:620px){
  .nav a:not(.nav__cta){ display:none; }
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--roman); font-size:1rem; letter-spacing:.03em;
  padding:15px 30px; border-radius:999px; cursor:pointer;
  border:1px solid transparent; transition:transform .25s ease, box-shadow .25s ease, background .3s;
}
.btn--gold{
  background:var(--grad-gold); color:var(--wine-deep);
  box-shadow:0 14px 30px -12px rgba(165,126,51,.7);
}
.btn--gold:hover{ transform:translateY(-3px); box-shadow:0 20px 38px -12px rgba(165,126,51,.85); }
.btn--ghost{
  background:transparent; color:#fff; border-color:rgba(255,255,255,.5);
}
.btn--ghost:hover{ background:rgba(255,255,255,.12); border-color:#fff; }

/* ---------- hero ---------- */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:center;
  padding:140px clamp(20px,7vw,110px) 90px;
  overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__img{
  width:100%; height:100%; object-fit:cover; object-position:center right;
  animation:slowZoom 22s ease-out forwards;
}
@media(max-width:768px){
  /* Solid gold for the accent line — must override -webkit-text-fill-color too */
  .hero__title--accent{
    color: var(--gold-light) !important;
    -webkit-text-fill-color: var(--gold-light) !important;
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
    text-shadow: 0 2px 12px rgba(0,0,0,.4);
  }

  /* Hide the banner (which has the logo baked in) on mobile.
     Use the bedsheets product photo as a clean background instead. */
  .hero__img{ display:none; }
  .hero__media{
    background:url("/assets/products/bedsheets.jpg") center center / cover no-repeat;
  }
  .hero__scrim{
    background:
      linear-gradient(180deg, rgba(44,12,19,.78) 0%, rgba(44,12,19,.65) 50%, rgba(44,12,19,.80) 100%);
  }
}
@keyframes slowZoom{ from{ transform:scale(1.08); } to{ transform:scale(1); } }
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(53,12,21,.86) 0%, rgba(68,18,31,.62) 38%, rgba(68,18,31,.12) 72%, rgba(68,18,31,0) 100%),
    linear-gradient(0deg, rgba(44,12,19,.55), rgba(44,12,19,0) 40%);
}

.hero__content{ max-width:640px; color:var(--cream); position:relative; }

.eyebrow{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--roman); letter-spacing:.32em; text-transform:uppercase;
  font-size:.78rem; color:var(--gold-light); margin-bottom:26px;
}
.eyebrow__line{ width:46px; height:1px; background:var(--gold); display:inline-block; }
.eyebrow__badge{
  background:var(--grad-gold);
  color:var(--wine-deep);
  padding:5px 14px; border-radius:999px;
  letter-spacing:.18em; font-size:.72rem; font-weight:600;
  box-shadow:0 4px 16px -4px rgba(165,126,51,.7);
  animation:badgePulse 2.8s ease-in-out infinite;
}
@keyframes badgePulse{
  0%,100%{ box-shadow:0 4px 16px -4px rgba(165,126,51,.7); }
  50%{ box-shadow:0 4px 28px 2px rgba(165,126,51,.95); }
}

.hero__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.9rem,7vw,5.4rem); line-height:1.02;
  letter-spacing:.005em;
}
.hero__title span{ display:block; }
.hero__title--accent{
  font-style:italic; color:transparent;
  background:var(--grad-gold); -webkit-background-clip:text; background-clip:text;
}

.hero__sub{
  margin:26px 0 36px; max-width:30em;
  font-size:clamp(1rem,1.4vw,1.18rem); font-weight:300;
  color:rgba(247,243,236,.9);
}

.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; }

.hero__chips{
  display:flex; flex-wrap:wrap; gap:10px; margin-top:42px;
}
.hero__chips span{
  font-family:var(--roman); font-size:.82rem; letter-spacing:.04em;
  padding:7px 16px; border-radius:999px;
  border:1px solid rgba(232,206,138,.35);
  color:var(--gold-light); background:rgba(94,26,43,.25);
  backdrop-filter:blur(4px);
}

.scroll-cue{
  position:absolute; bottom:30px; left:50%; transform:translateX(-50%);
  width:26px; height:42px; border:1px solid rgba(232,206,138,.6); border-radius:14px;
}
.scroll-cue span{
  position:absolute; top:8px; left:50%; transform:translateX(-50%);
  width:4px; height:8px; border-radius:2px; background:var(--gold-light);
  animation:scrollDot 1.8s ease-in-out infinite;
}
@keyframes scrollDot{ 0%,100%{ opacity:0; top:8px; } 50%{ opacity:1; top:22px; } }

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(22px); animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards; animation-delay:var(--d,0s); }
@keyframes rise{ to{ opacity:1; transform:none; } }
@media(prefers-reduced-motion:reduce){
  .reveal{ animation:none; opacity:1; transform:none; }
  .hero__img{ animation:none; }
}

/* ---------- marquee ---------- */
.marquee{
  background:var(--wine); color:var(--gold-light); overflow:hidden;
  padding:14px 0; border-top:1px solid var(--gold-deep); border-bottom:1px solid var(--gold-deep);
}
.marquee__track{
  display:inline-flex; gap:34px; align-items:center; white-space:nowrap;
  font-family:var(--roman); letter-spacing:.18em; text-transform:uppercase; font-size:.85rem;
  animation:slide 26s linear infinite;
}
.marquee .dot{ color:var(--gold); }
@keyframes slide{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

/* ---------- collections ---------- */
.collections{ padding:clamp(70px,9vw,130px) clamp(20px,6vw,90px); background:var(--cream); }

.section-head{ max-width:680px; margin:0 auto clamp(40px,6vw,70px); text-align:center; }
.kicker{
  font-family:var(--roman); text-transform:uppercase; letter-spacing:.3em;
  font-size:.78rem; color:var(--gold-deep); margin-bottom:14px;
}
.kicker--gold{ color:var(--gold-light); }
.section-title{
  font-family:var(--serif); font-weight:500; color:var(--wine);
  font-size:clamp(2rem,4.5vw,3.2rem); line-height:1.1;
}
.section-lead{ margin-top:18px; color:rgba(42,26,30,.72); font-weight:300; font-size:1.05rem; }

.grid{
  display:grid; gap:18px; max-width:1180px; margin:0 auto;
  grid-template-columns:repeat(3,1fr); grid-auto-rows:260px;
}
.card{
  position:relative; overflow:hidden; border-radius:18px;
  box-shadow:var(--shadow-soft);
  opacity:0; transform:translateY(28px);
  animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay:calc(var(--i) * .08s);
}
.card--tall{ grid-row:span 2; }
.card--wide{ grid-column:span 2; }
@media(prefers-reduced-motion:reduce){ .card{ animation:none; opacity:1; transform:none; } }

.card__img{
  position:absolute; inset:0;
  background:linear-gradient(135deg,var(--wine-soft),var(--wine-deep));
  background-size:cover; background-position:center;
  transition:transform .9s cubic-bezier(.2,.7,.2,1);
}
/* woven fallback pattern — strong when no photo, faint once a photo loads */
.card__img::before{
  content:""; position:absolute; inset:0; opacity:.22;
  background-image:
    repeating-linear-gradient(45deg, var(--gold) 0 2px, transparent 2px 11px),
    repeating-linear-gradient(-45deg, var(--gold) 0 2px, transparent 2px 11px);
  mix-blend-mode:overlay; transition:opacity .6s ease;
}
.card__img.is-loaded::before{ opacity:.06; }
.card:hover .card__img{ transform:scale(1.07); }

/* warm wine/gold color grade — unifies every photo (and Sahil's future ones)
   with the brand palette so nothing looks like cold stock */
.card::before{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(150deg, rgba(94,26,43,.42) 0%, rgba(94,26,43,.08) 45%, rgba(194,154,75,.30) 100%);
  mix-blend-mode:multiply;
}
.card::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(to top, rgba(44,12,19,.85) 0%, rgba(44,12,19,.18) 55%, transparent 100%);
}
.card__body{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:24px; color:var(--cream); }
.card__body h3{ font-family:var(--serif); font-weight:600; font-size:1.55rem; line-height:1.1; }
.card__body p{ font-size:.9rem; font-weight:300; color:rgba(247,243,236,.85); margin-top:4px; }

@media(max-width:860px){
  .grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:220px; }
  .card--wide{ grid-column:span 2; }
  .card--tall{ grid-row:span 1; }
}
@media(max-width:540px){
  .grid{ grid-template-columns:1fr; grid-auto-rows:230px; }
  .card--wide{ grid-column:span 1; }
}

/* ---------- heritage ---------- */
.heritage{
  position:relative; background:var(--wine); color:var(--cream);
  padding:clamp(80px,11vw,150px) clamp(20px,6vw,90px); text-align:center; overflow:hidden;
}
.heritage::before,.heritage::after{
  content:""; position:absolute; width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(194,154,75,.22), transparent 70%);
}
.heritage::before{ top:-160px; left:-120px; }
.heritage::after{ bottom:-180px; right:-140px; }
.heritage__inner{ position:relative; max-width:760px; margin:0 auto; }
.crown{ font-size:2.4rem; color:var(--gold-light); display:block; margin-bottom:14px; }
.heritage__title{
  font-family:var(--serif); font-weight:500; font-style:italic;
  font-size:clamp(1.9rem,4.5vw,3.1rem); line-height:1.2; margin:6px 0 22px;
}
.heritage__text{ font-weight:300; font-size:1.1rem; color:rgba(247,243,236,.82); max-width:38em; margin:0 auto; }
.heritage__divider{ display:flex; align-items:center; justify-content:center; gap:14px; margin-top:34px; color:var(--gold); }
.heritage__divider span{ width:70px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
.heritage__divider span:last-child{ background:linear-gradient(90deg,var(--gold),transparent); }

/* ---------- contact ---------- */
.contact{ padding:clamp(70px,9vw,130px) clamp(20px,6vw,90px); background:var(--cream); }
.contact__card{
  max-width:680px; margin:0 auto; text-align:center;
  background:var(--paper); border:1px solid rgba(194,154,75,.3);
  border-radius:24px; padding:clamp(34px,5vw,60px);
  box-shadow:var(--shadow-soft);
}
.contact__title{ font-family:var(--serif); font-weight:500; color:var(--wine); font-size:clamp(1.9rem,4vw,2.8rem); }
.contact__lead{ margin:14px auto 30px; color:rgba(42,26,30,.72); font-weight:300; max-width:34em; }

.signup{ display:flex; gap:10px; max-width:460px; margin:0 auto; }
.signup input{
  flex:1; padding:15px 20px; border-radius:999px; border:1px solid rgba(94,26,43,.25);
  font-family:var(--body); font-size:1rem; background:#fff; color:var(--ink);
}
.signup input:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(194,154,75,.2); }
.signup__note{ min-height:1.4em; margin-top:14px; font-size:.9rem; color:var(--wine); font-weight:500; }

.contact__direct{
  display:flex; flex-wrap:wrap; justify-content:center; gap:10px 26px; margin-top:30px;
  padding-top:26px; border-top:1px solid rgba(194,154,75,.25);
  font-family:var(--roman); font-size:.98rem; color:var(--wine);
}
.contact__direct a{ position:relative; }
.contact__direct a:hover{ color:var(--gold-deep); }
.contact__icon-link{
  display:inline-flex; align-items:center; gap:8px;
}
.contact__icon-link svg{
  flex-shrink:0; color:var(--gold-deep); transition:color .25s;
}
.contact__icon-link:hover svg{ color:var(--wine); }
.contact__address{
  display:flex; align-items:center; justify-content:center; gap:7px;
  margin-top:18px; font-size:.92rem; color:rgba(42,26,30,.6);
}
.contact__address svg{ color:var(--gold-deep); }

@media(max-width:480px){
  .signup{ flex-direction:column; }
  .signup .btn{ justify-content:center; }
}

/* ---------- footer ---------- */
.site-footer{ background:var(--wine-deep); color:var(--cream); text-align:center; padding:54px 20px 40px; }
.footer__logo{ height:64px; width:auto; margin:0 auto 14px; border-radius:8px; mix-blend-mode:screen; opacity:.95; }
.footer__tag{ font-family:var(--serif); font-style:italic; font-size:1.3rem; color:var(--gold-light); }
.footer__meta{ margin-top:12px; font-size:.85rem; font-weight:300; color:rgba(247,243,236,.78); letter-spacing:.02em; }
.footer__copy{ margin-top:8px; font-size:.8rem; font-weight:300; color:rgba(247,243,236,.5); letter-spacing:.02em; }
