/* SARMARI'S — boutique skincare. Neutral base, one purple accent from the logo. */
:root{
  --cream:#F6F2EA; --stone:#EFE9DE; --sand:#E4DCCB;
  --ink:#211D1A; --muted:#6E655B; --line:rgba(33,29,26,.10);
  --accent:#5E3E82; --accent-hover:#4c3068; --gold:#B08A3C;
  --white:#fff;
  --serif:"Fraunces",Georgia,serif; --sans:"Inter",system-ui,sans-serif;
  --container:min(1180px,90vw); --narrow:min(760px,90vw);
  --r:14px; --pad:clamp(4.5rem,9vw,8rem);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);
  line-height:1.7;font-weight:300;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.08;letter-spacing:-.02em}
.container{width:var(--container);margin-inline:auto}
.narrow{width:var(--narrow);margin-inline:auto}
section{padding:var(--pad) 0}
.eyebrow{font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);font-weight:500}
.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--muted);max-width:56ch}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);
  font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  padding:1.05rem 2.1rem;border-radius:100px;border:1px solid transparent;
  cursor:pointer;transition:background .3s ease,color .3s ease,transform .2s ease,border-color .3s ease}
.btn-solid{background:var(--accent);color:#fff}
.btn-solid:hover{background:var(--accent-hover);transform:translateY(-2px)}
.btn-ghost{border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-light{border-color:rgba(255,255,255,.5);color:#fff}
.btn-light:hover{background:#fff;color:var(--ink)}
.btn:active{transform:scale(.98)}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

/* ---- nav ---- */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;
  justify-content:space-between;padding:1.15rem clamp(1.25rem,5vw,3rem);
  transition:background .4s ease,backdrop-filter .4s ease,box-shadow .4s ease}
.nav.scrolled{background:rgba(246,242,234,.82);backdrop-filter:blur(18px);
  box-shadow:0 1px 0 var(--line)}
.nav.on-dark:not(.scrolled){color:#fff}
.nav.on-dark:not(.scrolled) .brand{color:#fff}
.brand{display:flex;align-items:center;gap:.65rem;font-family:var(--serif);
  font-size:1.4rem;letter-spacing:.04em}
.brand img{width:38px;height:38px;border-radius:50%}
.nav-links{display:flex;align-items:center;gap:2.2rem;font-size:.82rem;
  letter-spacing:.1em;text-transform:uppercase}
.nav-links a{position:relative;padding:.3rem 0;font-weight:400}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;
  background:var(--accent);transition:width .3s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;font-size:1.5rem;color:inherit}
.mobile-menu{position:fixed;inset:0;z-index:99;background:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;
  font-family:var(--serif);font-size:2rem;transform:translateY(-100%);
  transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.mobile-menu.open{transform:none}

/* ---- hero ---- */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;
  color:#fff;overflow:hidden;
  background:radial-gradient(120% 100% at 70% 20%,#6a4a86 0%,#3a2c52 45%,#211a2e 100%)}
.hero::after{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 25% 80%,rgba(176,138,60,.25),transparent 70%);pointer-events:none}
.hero .container{position:relative;z-index:2;padding-block:8rem 4rem}
.hero h1{font-size:clamp(3rem,8vw,6.5rem);max-width:14ch}
.hero .lead{color:rgba(255,255,255,.7);margin:1.75rem 0 2.5rem;max-width:48ch}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap}

/* ---- generic section headers ---- */
.head{max-width:60ch;margin-bottom:3.5rem}
.head h2{font-size:clamp(2rem,4vw,3.25rem);margin:.6rem 0 1rem}
.section-dark{background:var(--ink);color:var(--cream)}
.section-dark .lead{color:rgba(255,255,255,.65)}
.section-stone{background:var(--stone)}

/* ---- product grid ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem}
.card{background:var(--white);border-radius:var(--r);overflow:hidden;
  border:1px solid var(--line);transition:transform .4s ease,box-shadow .4s ease}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 50px -24px rgba(33,29,26,.35)}
.card-img{aspect-ratio:4/5;position:relative;display:flex;align-items:flex-end;padding:1.4rem}
.card-img .letter{font-family:var(--serif);font-size:3.4rem;color:rgba(255,255,255,.9)}
.card-body{padding:1.5rem 1.6rem 1.9rem}
.card-body .cat{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.card-body h3{font-size:1.5rem;margin:.35rem 0 .5rem}
.card-body p{font-size:.92rem;color:var(--muted)}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:1.2rem}
.card-foot .price{font-size:.92rem;color:var(--ink)}
.card-foot .arrow{color:var(--accent);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase}

/* ---- feature strip ---- */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2.5rem}
.feature .mark{font-family:var(--serif);font-size:2.6rem;color:var(--accent);line-height:1}
.feature h3{font-size:1.15rem;font-family:var(--sans);font-weight:500;margin:.9rem 0 .5rem;letter-spacing:0}
.feature p{font-size:.92rem;color:var(--muted)}

/* ---- split ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.split .visual{aspect-ratio:1;border-radius:var(--r)}
.split h2{font-size:clamp(1.9rem,3.5vw,2.8rem);margin-bottom:1.2rem}
.split p+p{margin-top:1rem}

/* ---- real photo in a split/founder slot ---- */
.photo{width:100%;aspect-ratio:1;object-fit:cover;object-position:center 25%;
  border-radius:var(--r);display:block;box-shadow:0 30px 60px -30px rgba(33,29,26,.4)}
.founder-name{margin-top:1.8rem;font-family:var(--serif);font-size:1.35rem;color:var(--ink)}
.founder-title{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:.2rem}

/* ---- tonal brand tile (stands in for photography, reads as intentional) ---- */
.swatch{background:linear-gradient(150deg,var(--h,#6a4a86),color-mix(in srgb,var(--h,#6a4a86) 55%,#000))}
.visual.swatch{display:flex;align-items:center;justify-content:center;overflow:hidden}
.visual.swatch .letter{font-family:var(--serif);font-size:clamp(4rem,10vw,7rem);color:rgba(255,255,255,.82)}
.brand-watermark{width:42%;max-width:160px;opacity:.55;mix-blend-mode:soft-light}

/* ---- product detail ---- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);
  align-items:start;padding-top:8rem}
.pd .visual{aspect-ratio:4/5;border-radius:var(--r);position:relative}
.pd h1{font-size:clamp(2.4rem,5vw,3.6rem);margin:.5rem 0 1rem}
.pd .desc{color:var(--muted);margin-bottom:2rem}
.pd .block{border-top:1px solid var(--line);padding:1.4rem 0}
.pd .block h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem}
.pd ul{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem}
.pd ul li{font-size:.85rem;background:var(--stone);border-radius:100px;padding:.4rem .9rem}
.sizes{display:flex;gap:.7rem;margin:1.6rem 0}
.size-opt{flex:1;border:1px solid var(--line);border-radius:12px;padding:1rem;text-align:center;
  cursor:pointer;background:var(--white);transition:border-color .25s,box-shadow .25s}
.size-opt.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.size-opt .s-label{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.size-opt .s-price{font-family:var(--serif);font-size:1.5rem;margin-top:.3rem}
.buy-note{font-size:.78rem;color:var(--muted);margin-top:.9rem}

/* ---- contact form ---- */
.form{display:grid;gap:1.1rem;margin-top:2.5rem}
.form input,.form textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);
  background:var(--white);border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem}
.form textarea{min-height:150px;resize:vertical}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--accent)}

/* ---- waist beads: color meanings + bead art ---- */
.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.color-item{display:flex;gap:.85rem;align-items:flex-start;background:var(--white);
  border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem}
.color-dot{width:20px;height:20px;border-radius:50%;flex:0 0 auto;margin-top:.2rem;
  box-shadow:inset 0 0 0 1px rgba(12,12,12,.15)}
.color-item h4{font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:0;margin-bottom:.15rem}
.color-item p{font-size:.83rem;color:var(--muted);line-height:1.5}
.bead-card .card-img{background:linear-gradient(160deg,#fbf9f4,#efe9de);aspect-ratio:1;padding:0}
.bead-card .card-img svg{width:88%;height:88%}

/* ---- footer ---- */
.footer{background:var(--ink);color:rgba(255,255,255,.7);padding:5rem 0 2.5rem}
.footer .top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:2.5rem;
  padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .brand{color:#fff}
.footer-links{display:flex;gap:2.5rem;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase}
.footer-links a:hover{color:var(--gold)}
.footer .tagline{font-family:var(--serif);font-size:1.1rem;letter-spacing:.3em;color:var(--gold);margin-top:.6rem}
.footer .bottom{margin-top:2rem;font-size:.78rem;color:rgba(255,255,255,.45)}

/* ---- animation ---- */
[data-animate]{opacity:0;transform:translateY(36px);
  transition:opacity .8s cubic-bezier(.25,.46,.45,.94),transform .8s cubic-bezier(.25,.46,.45,.94);
  transition-delay:var(--delay,0s)}
[data-animate].is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){[data-animate]{opacity:1;transform:none;transition:none}}

/* ---- responsive ---- */
@media (max-width:820px){
  .nav-links{display:none}
  .nav-toggle{display:block}
  .split,.pd{grid-template-columns:1fr}
  .pd .visual{max-width:420px}
}
