/* Angelic Hair — elegant brown / rose gold / hot pink */
:root{
  --espresso:#2c201b;
  --brown:#5a4038;
  --taupe:#8c7268;
  --rosegold:#b76e79;
  --rosegold-soft:#e6c9c2;
  --blush:#f6e8e2;
  --cream:#fbf5f1;
  --hotpink:#ff2e93;
  --hotpink-deep:#df1c7e;
  --white:#fffdfb;
  --shadow:0 18px 50px -20px rgba(90,64,56,.45);
  --r:18px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Jost",system-ui,sans-serif;
  color:var(--brown);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{font-family:"Playfair Display",Georgia,serif;font-weight:600;color:var(--espresso);line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1140px,92%);margin-inline:auto}
section{padding:clamp(64px,9vw,120px) 0}
.eyebrow{
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--rosegold);font-weight:600;margin-bottom:14px;
}
.center{text-align:center}

/* gradient rose-gold text accent */
.shine{
  background:linear-gradient(100deg,var(--rosegold),#d9a7a0,var(--rosegold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ── buttons ── */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  padding:15px 32px;border-radius:999px;font-weight:600;letter-spacing:.02em;
  font-size:.98rem;cursor:pointer;border:1.5px solid transparent;transition:.25s;
}
.btn-pink{background:var(--hotpink);color:#fff;box-shadow:0 12px 30px -10px rgba(255,46,147,.6)}
.btn-pink:hover{background:var(--hotpink-deep);transform:translateY(-2px)}
.btn-ghost{border-color:var(--rosegold);color:var(--brown)}
.btn-ghost:hover{background:var(--rosegold);color:#fff}

/* ── nav ── */
header.nav{position:sticky;top:0;z-index:50;background:rgba(251,245,241,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--rosegold-soft)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.brand{font-family:"Playfair Display",serif;font-size:1.5rem;color:var(--espresso);letter-spacing:.01em}
.brand b{color:var(--rosegold)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:.92rem;font-weight:500;color:var(--brown);transition:.2s}
.nav-links a:hover{color:var(--hotpink)}
.nav-links .btn{padding:11px 24px}
.nav-toggle{display:none;background:none;border:none;font-size:1.6rem;color:var(--brown);cursor:pointer}

/* ── hero ── */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1200px 600px at 80% -10%,var(--blush),transparent),
  linear-gradient(180deg,var(--cream),var(--white))}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;padding:clamp(50px,8vw,90px) 0}
.hero h1{font-size:clamp(2.7rem,6vw,4.6rem)}
.hero p.lead{font-size:1.18rem;color:var(--taupe);margin:22px 0 32px;max-width:46ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-photo{position:relative;aspect-ratio:4/5;border-radius:28px;overflow:hidden;box-shadow:var(--shadow);
  background:linear-gradient(135deg,var(--rosegold-soft),var(--blush))}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;color:var(--rosegold);text-align:center;padding:20px}
.hero-photo .ph span{font-family:"Playfair Display",serif;font-size:1.3rem}
.hero-badge{position:absolute;bottom:18px;left:18px;background:rgba(255,253,251,.92);padding:12px 18px;border-radius:14px;box-shadow:var(--shadow);font-size:.85rem;font-weight:600;color:var(--brown)}
.hero-badge b{color:var(--hotpink)}

/* ── trust strip ── */
.strip{background:var(--espresso);color:var(--blush)}
.strip .container{display:flex;flex-wrap:wrap;gap:34px;justify-content:center;align-items:center;padding:22px 0;text-align:center}
.strip span{font-size:.9rem;letter-spacing:.12em;text-transform:uppercase}
.strip b{color:var(--rosegold)}

/* ── services ── */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px}
.card{background:var(--white);border:1px solid var(--rosegold-soft);border-radius:var(--r);padding:34px 30px;transition:.3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--rosegold)}
.card .ico{font-size:1.8rem;margin-bottom:14px}
.card h3{font-size:1.4rem;margin-bottom:8px}
.card p{color:var(--taupe);font-size:.96rem}
.card ul{list-style:none;margin-top:14px;font-size:.92rem;color:var(--brown)}
.card li{padding:5px 0;border-bottom:1px dashed var(--rosegold-soft)}
.card li:last-child{border:none}

/* ── shop ── */
.shop{background:linear-gradient(180deg,var(--blush),var(--cream))}
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:48px}
.product{background:var(--white);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:.3s}
.product:hover{transform:translateY(-6px)}
.product .thumb{aspect-ratio:1;background:linear-gradient(135deg,var(--rosegold-soft),var(--blush));display:flex;align-items:center;justify-content:center;font-size:2.4rem;color:var(--rosegold)}
.product .thumb img{width:100%;height:100%;object-fit:cover}
.product .body{padding:22px}
.product h3{font-size:1.25rem}
.product .price{color:var(--hotpink);font-weight:700;margin:6px 0 14px}
.product .btn{width:100%;justify-content:center;padding:12px}

/* ── gallery ── */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:46px}
.gallery .cell{aspect-ratio:1;border-radius:14px;overflow:hidden;background:linear-gradient(135deg,var(--rosegold-soft),var(--blush));
  display:flex;align-items:center;justify-content:center;color:var(--rosegold);position:relative}
.gallery .cell img{width:100%;height:100%;object-fit:cover;transition:.5s}
.gallery .cell:hover img{transform:scale(1.07)}
.gallery .cell .ph{font-family:"Playfair Display",serif;font-size:.95rem;opacity:.8}

/* ── booking ── */
.book{background:var(--espresso);color:var(--blush);border-radius:0}
.book h2{color:var(--white)}
.book .eyebrow{color:var(--rosegold)}
.book p{color:var(--rosegold-soft);max-width:54ch;margin:18px auto 30px}
.book .btn-ghost{border-color:var(--rosegold);color:var(--blush)}
.book .btn-ghost:hover{background:var(--rosegold);color:#fff}

/* ── booking form ── */
.bookform{max-width:560px;margin:38px auto 0;display:flex;flex-direction:column;gap:14px}
.bookform .row{display:flex;gap:14px}
.bookform .row input{flex:1}
.bookform input,.bookform select,.bookform textarea{
  width:100%;padding:14px 16px;border-radius:12px;border:1.5px solid var(--rosegold);
  background:rgba(255,253,251,.95);color:var(--espresso);font-family:inherit;font-size:1rem;
}
.bookform textarea{resize:vertical}
.bookform input::placeholder,.bookform textarea::placeholder{color:var(--taupe)}
.bookform input:focus,.bookform select:focus,.bookform textarea:focus{outline:none;border-color:var(--hotpink);box-shadow:0 0 0 3px rgba(255,46,147,.18)}
.bookform .btn-pink{margin-top:4px;justify-content:center;padding:15px}
.formnote{font-size:.85rem;color:var(--rosegold-soft);margin-top:4px;text-align:center}
.booked{text-align:center;background:rgba(255,253,251,.96);border-radius:var(--r);padding:34px 28px}
.booked h3{color:var(--espresso);font-size:1.6rem;margin-bottom:10px}
.booked p{color:var(--brown);margin-bottom:16px}
.booked .btn{margin:6px auto}
@media(max-width:560px){.bookform .row{flex-direction:column}}

/* ── footer ── */
footer{background:var(--brown);color:var(--blush);padding:56px 0 28px;text-align:center}
footer .brand{color:#fff;display:block;margin-bottom:10px}
.socials{display:flex;gap:18px;justify-content:center;margin:22px 0}
.socials a{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08);transition:.25s;font-size:1.1rem}
.socials a:hover{background:var(--hotpink);transform:translateY(-3px)}
footer small{color:var(--rosegold-soft);opacity:.8}

/* ── responsive ── */
@media(max-width:860px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-cta{justify-content:center}
  .hero p.lead{margin-inline:auto}
  .cards,.products{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-toggle{display:block}
}
@media(max-width:560px){
  .cards,.products,.gallery{grid-template-columns:1fr 1fr}
  .gallery{gap:10px}
}
