/* ============================================================
   OPULENCE BEAUTY — Shared Design System
   Black · Antique Gold · Soft Cream
   Display: Cormorant Garamond  ·  UI/Body: Jost
   ============================================================ */

:root{
  /* Color */
  --ink:        #0a0908;
  --ink-2:      #100e0b;
  --ink-3:      #16130e;
  --panel:      #1b1712;
  --line:       rgba(201,162,75,0.18);
  --line-soft:  rgba(244,239,230,0.10);

  --gold:       #c9a24b;
  --gold-soft:  #ddbd76;
  --gold-deep:  #9c7c34;
  --gold-glow:  rgba(201,162,75,0.30);

  --cream:      #f4efe6;
  --cream-dim:  rgba(244,239,230,0.74);
  --cream-mute: rgba(244,239,230,0.52);
  --cream-faint:rgba(244,239,230,0.30);
  --white:      #ffffff;

  /* Type */
  --font-display: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-sans: 'Jost', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Rhythm */
  --maxw: 1280px;
  --gutter: clamp(22px, 5vw, 80px);
  --section-y: clamp(72px, 11vw, 160px);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--ink);
  color:var(--cream);
  font-family:var(--font-sans);
  font-weight:300;
  font-size:17px;
  line-height:1.75;
  letter-spacing:.01em;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold); color:var(--ink); }

/* ---- Ambient grain + glow layer ---- */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(120% 80% at 12% -10%, rgba(201,162,75,0.10), transparent 55%),
    radial-gradient(90% 70% at 100% 110%, rgba(201,162,75,0.07), transparent 60%);
}
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.045; mix-blend-mode:screen;
  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='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   Typography helpers
   ============================================================ */
.display{ font-family:var(--font-display); font-weight:300; line-height:1.02; letter-spacing:.005em; }
h1,h2,h3{ font-family:var(--font-display); font-weight:300; margin:0; line-height:1.05; }
.h-xl{ font-size:clamp(3rem, 9vw, 7.5rem); }
.h-lg{ font-size:clamp(2.4rem, 6.2vw, 5rem); }
.h-md{ font-size:clamp(2rem, 4.4vw, 3.4rem); }
.h-sm{ font-size:clamp(1.6rem, 3vw, 2.3rem); }
.italic{ font-style:italic; }
.gold{ color:var(--gold); }
.gold-grad{
  background:linear-gradient(102deg,var(--gold-deep),var(--gold-soft) 42%,var(--gold) 70%,var(--gold-deep));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

.eyebrow{
  font-family:var(--font-sans); font-weight:400;
  font-size:.74rem; letter-spacing:.42em; text-transform:uppercase;
  color:var(--gold); display:inline-flex; align-items:center; gap:.9em;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:linear-gradient(90deg,transparent,var(--gold)); }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); }
.eyebrow.center::before{ background:linear-gradient(90deg,var(--gold),transparent) ; }

.lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--cream-dim); line-height:1.85; font-weight:300; }
.muted{ color:var(--cream-mute); }
p{ text-wrap:pretty; }

/* ============================================================
   Layout
   ============================================================ */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); position:relative; z-index:2; }
.section{ padding-block:var(--section-y); position:relative; z-index:2; }
.center{ text-align:center; }
.divider{ width:100%; height:1px; background:linear-gradient(90deg,transparent,var(--line),transparent); }

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  --pad: 18px 36px;
  display:inline-flex; align-items:center; justify-content:center; gap:.7em;
  font-family:var(--font-sans); font-weight:400; font-size:.78rem;
  letter-spacing:.26em; text-transform:uppercase; cursor:pointer;
  padding:var(--pad); border:1px solid var(--gold); color:var(--gold);
  background:transparent; border-radius:2px; position:relative; overflow:hidden;
  transition:color .5s var(--ease), border-color .5s var(--ease);
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(100deg,var(--gold-deep),var(--gold-soft));
  transform:translateY(101%); transition:transform .55s var(--ease-out);
}
.btn:hover{ color:var(--ink); border-color:var(--gold-soft); }
.btn:hover::after{ transform:translateY(0); }
.btn.solid{ background:linear-gradient(100deg,var(--gold-deep),var(--gold) 60%,var(--gold-soft)); color:var(--ink); border-color:transparent; }
.btn.solid::after{ background:linear-gradient(100deg,var(--gold-soft),var(--gold)); }
.btn.ghost{ border-color:var(--line); color:var(--cream-dim); }
.btn.ghost:hover{ color:var(--ink); border-color:var(--gold); }
.btn.lg{ --pad:21px 46px; font-size:.82rem; }

.txt-link{
  font-family:var(--font-sans); font-size:.78rem; letter-spacing:.24em; text-transform:uppercase;
  color:var(--gold); display:inline-flex; align-items:center; gap:.6em; position:relative; padding-bottom:4px;
}
.txt-link::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:100%; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.txt-link:hover::after{ transform:scaleX(1); }
.txt-link .ar{ transition:transform .45s var(--ease); }
.txt-link:hover .ar{ transform:translateX(6px); }

/* ============================================================
   Header / Nav
   ============================================================ */
.site-head{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px var(--gutter); gap:24px;
  transition:background .6s var(--ease), padding .6s var(--ease), border-color .6s var(--ease);
  border-bottom:1px solid transparent;
}
.site-head.scrolled{
  background:rgba(10,9,8,0.78); backdrop-filter:blur(14px) saturate(1.1);
  border-bottom-color:var(--line); padding-block:13px;
}
.brand{ display:flex; align-items:center; gap:14px; z-index:62; }
.brand img{ height:46px; width:auto; transition:height .6s var(--ease); }
.site-head.scrolled .brand img{ height:38px; }
.brand .wordmark{ font-family:var(--font-display); font-size:1.18rem; letter-spacing:.36em; text-transform:uppercase; color:var(--cream); line-height:1; padding-left:2px; }
.brand .wordmark small{ display:block; font-family:var(--font-sans); font-size:.5rem; letter-spacing:.5em; color:var(--gold); margin-top:5px; }

.nav{ display:flex; align-items:center; gap:clamp(18px,2vw,34px); }
.nav a{
  font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--cream-dim);
  position:relative; padding:6px 0; transition:color .4s var(--ease); white-space:nowrap;
}
.nav a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1px; width:100%; background:var(--gold); transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease); }
.nav a:hover, .nav a.active{ color:var(--cream); }
.nav a:hover::after, .nav a.active::after{ transform:scaleX(1); transform-origin:left; }
.nav a.active{ color:var(--gold); }

/* dropdown */
.has-sub{ position:relative; }
.submenu{
  position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(8px);
  min-width:230px; padding:14px; margin-top:14px;
  background:rgba(16,14,11,0.96); backdrop-filter:blur(14px);
  border:1px solid var(--line); border-radius:4px;
  display:flex; flex-direction:column; gap:2px;
  opacity:0; visibility:hidden; transition:all .4s var(--ease); z-index:70;
}
.has-sub:hover .submenu{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.submenu a{ padding:11px 14px; letter-spacing:.12em; border-radius:3px; color:var(--cream-dim); }
.submenu a::after{ display:none; }
.submenu a:hover{ background:rgba(201,162,75,0.10); color:var(--gold); }

.head-cta{ display:flex; align-items:center; gap:16px; }
.burger{ display:none; flex-direction:column; gap:5px; width:30px; height:22px; justify-content:center; background:none; border:none; cursor:pointer; z-index:62; }
.burger span{ display:block; height:1.5px; width:100%; background:var(--cream); transition:.4s var(--ease); }
.burger.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:58; background:rgba(8,7,6,0.97); backdrop-filter:blur(18px);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s; padding:80px 30px;
}
.drawer.open{ opacity:1; visibility:visible; }
.drawer a{ font-family:var(--font-display); font-size:clamp(1.7rem,7vw,2.6rem); color:var(--cream-dim); letter-spacing:.04em; transition:color .3s; }
.drawer a:hover, .drawer a.active{ color:var(--gold); }
.drawer .sub-label{ font-family:var(--font-sans); font-size:.66rem; letter-spacing:.4em; text-transform:uppercase; color:var(--gold); margin-top:22px; }

/* ============================================================
   Footer
   ============================================================ */
.site-foot{ position:relative; z-index:2; border-top:1px solid var(--line); background:var(--ink-2); padding-block:clamp(56px,8vw,90px) 34px; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:48px; }
.foot-brand img{ height:64px; margin-bottom:20px; }
.foot-col h4{ font-family:var(--font-sans); font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); margin:0 0 20px; font-weight:400; }
.foot-col a, .foot-col p{ display:block; font-size:.92rem; color:var(--cream-mute); margin:0 0 12px; transition:color .3s; }
.foot-col a:hover{ color:var(--gold); }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; margin-top:60px; padding-top:26px; border-top:1px solid var(--line-soft); font-size:.74rem; letter-spacing:.08em; color:var(--cream-faint); }
.foot-bottom a:hover{ color:var(--gold); }

/* ============================================================
   Reveal animations
   ============================================================ */
.reveal{ opacity:0; transform:translateY(38px); transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.1s; } .reveal.d2{ transition-delay:.2s; }
.reveal.d3{ transition-delay:.3s; } .reveal.d4{ transition-delay:.4s; } .reveal.d5{ transition-delay:.5s; }
.reveal-img{ overflow:hidden; }
.reveal-img img{ transform:scale(1.12); transition:transform 1.6s var(--ease-out); }
.reveal-img.in img{ transform:scale(1); }

@media (prefers-reduced-motion:reduce){
  .reveal,.reveal-img img{ transition:none !important; opacity:1 !important; transform:none !important; }
}

/* ============================================================
   Misc components shared across pages
   ============================================================ */
.pill{ display:inline-flex; align-items:center; gap:.55em; font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); border:1px solid var(--line); border-radius:100px; padding:8px 16px; }
.pill .dot{ width:5px; height:5px; border-radius:50%; background:var(--gold); }

/* price cards */
.tier{ border:1px solid var(--line); border-radius:5px; background:linear-gradient(180deg,rgba(27,23,18,0.6),rgba(16,14,11,0.4)); padding:36px 34px; position:relative; overflow:hidden; transition:border-color .5s var(--ease), transform .5s var(--ease); }
.tier::before{ content:""; position:absolute; inset:0; background:radial-gradient(120% 90% at 50% -20%, rgba(201,162,75,0.10), transparent 60%); opacity:0; transition:opacity .6s var(--ease); }
.tier:hover{ border-color:rgba(201,162,75,0.5); transform:translateY(-6px); }
.tier:hover::before{ opacity:1; }
.tier .t-name{ font-family:var(--font-display); font-size:1.7rem; color:var(--cream); }
.tier .t-price{ font-family:var(--font-display); font-size:2.4rem; color:var(--gold); line-height:1; }
.tier .t-meta{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--cream-mute); }

.note{ font-size:.85rem; color:var(--cream-mute); line-height:1.7; border-left:1px solid var(--line); padding-left:20px; }

/* generic media frame */
.frame{ position:relative; overflow:hidden; border-radius:4px; }
.frame::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px var(--line); border-radius:4px; pointer-events:none; }
.frame img{ width:100%; height:100%; object-fit:cover; }

@media (max-width:980px){
  .foot-grid{ grid-template-columns:1fr 1fr; gap:40px; }
  .nav, .head-cta .btn{ display:none; }
  .burger{ display:flex; }
}
@media (max-width:560px){
  .foot-grid{ grid-template-columns:1fr; }
  body{ font-size:16px; }
}
