/* ============================================================
   NOYOLA CREATIONS - shared design system
   Editorial luxury · red & black · futuristic florals
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;0,6..96,600;0,6..96,700;1,6..96,400;1,6..96,500&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Italiana&family=Space+Grotesk:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  /* palette */
  --bg:        #0d0a09;          /* warm near-black */
  --bg-deep:   #060404;
  --surface:   #161110;
  --surface-2: #1d1614;
  --line:      rgba(241,232,224,.12);
  --line-soft: rgba(241,232,224,.07);
  --ink:       #f4ece4;          /* off-white */
  --ink-dim:   #b6a79c;
  --muted:     #82736a;

  /* signature red (tweakable) */
  --red:       #e11423;
  --red-deep:  #8a0c14;
  --red-soft:  rgba(225,20,35,.14);
  --red-glow:  rgba(225,20,35,.45);

  /* type */
  --display: 'Bodoni Moda', Georgia, serif;
  --ui:      'Space Grotesk', system-ui, sans-serif;
  --mono:    'Space Mono', ui-monospace, monospace;

  /* rhythm (tweakable density) */
  --pad-section: 132px;
  --maxw: 1320px;
  --radius: 2px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--ui);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

::selection{ background:var(--red); color:#fff; }

/* ---------- utilities ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 40px; }
.label{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-dim);
}
.label--red{ color:var(--red); }
.eyebrow{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--mono); font-size:11px; letter-spacing:.32em;
  text-transform:uppercase; color:var(--red);
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--red); display:inline-block; }

h1,h2,h3{ font-family:var(--display); font-weight:500; margin:0; line-height:1.02; letter-spacing:-.01em; }
.serif-italic{ font-style:italic; font-weight:400; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:12px;
  font-family:var(--mono); font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  padding:17px 30px; border:1px solid var(--line); background:transparent; color:var(--ink);
  border-radius:var(--radius); transition:.45s cubic-bezier(.2,.7,.3,1); position:relative;
}
.btn .arr{ transition:transform .45s cubic-bezier(.2,.7,.3,1); }
.btn:hover .arr{ transform:translateX(5px); }
.btn--solid{ background:var(--red); border-color:var(--red); color:#fff; }
.btn--solid:hover{ background:#fff; border-color:#fff; color:#111; box-shadow:0 0 0 1px #fff, 0 18px 50px -20px var(--red-glow); }
.btn--ghost:hover{ border-color:var(--ink); }
.btn--block{ width:100%; }

/* ---------- top nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px 40px;
  background:linear-gradient(to bottom, rgba(13,10,9,.92), rgba(13,10,9,.5) 70%, transparent);
  backdrop-filter:blur(6px);
  transition:background .4s, padding .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.solid{ background:rgba(8,5,5,.93); border-bottom-color:var(--line-soft); padding:16px 40px; }
.brand{ display:flex; align-items:baseline; gap:11px; }
.brand b{ font-family:var(--display); font-weight:600; font-size:23px; letter-spacing:.02em; }
.brand .tld{ font-family:var(--mono); font-size:10px; letter-spacing:.34em; color:var(--red); text-transform:uppercase; }
.nav-links{ display:flex; gap:38px; }
.nav-links a{
  font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-dim);
  position:relative; padding:4px 0; transition:color .3s;
}
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--red); transition:width .35s; }
.nav-links a:hover{ color:var(--ink); }
.nav-links a:hover::after{ width:100%; }
.nav-cart{
  display:flex; align-items:center; gap:10px;
  font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink);
  border:1px solid var(--line); padding:11px 16px; border-radius:var(--radius); transition:.3s;
}
.nav-cart:hover{ border-color:var(--red); color:var(--red); }
.nav-cart .count{
  min-width:19px; height:19px; padding:0 5px; display:inline-flex; align-items:center; justify-content:center;
  background:var(--red); color:#fff; border-radius:99px; font-size:10px; font-weight:700;
}

/* ---------- section heading ---------- */
.sec{ padding:var(--pad-section) 0; position:relative; }
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:40px; margin-bottom:54px; }
.sec-head h2{ font-size:clamp(36px,5vw,68px); }
.sec-head p{ max-width:38ch; color:var(--ink-dim); font-size:15px; margin:0; }
.hairline{ height:1px; background:var(--line); width:100%; }

/* ---------- footer ---------- */
.foot{ border-top:1px solid var(--line); padding:90px 0 44px; background:var(--bg-deep); }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; margin-bottom:70px; }
.foot h4{ font-family:var(--mono); font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--red); margin:0 0 22px; }
.foot ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:13px; }
.foot ul a{ color:var(--ink-dim); font-size:14px; transition:color .3s; }
.foot ul a:hover{ color:var(--ink); }
.foot .big{ font-family:var(--display); font-size:30px; max-width:16ch; line-height:1.12; }
.foot-base{ display:flex; justify-content:space-between; align-items:center; padding-top:28px; border-top:1px solid var(--line-soft); }
.foot-base span{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; color:var(--muted); text-transform:uppercase; }

/* ---------- reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity 1s cubic-bezier(.2,.7,.3,1), transform 1s cubic-bezier(.2,.7,.3,1); }
.reveal.in{ opacity:1; transform:none; }

@media (max-width:900px){
  :root{ --pad-section:84px; }
  .wrap{ padding:0 22px; }
  .nav{ padding:16px 22px; }
  .nav-links{ display:none; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:34px; }
}
