/* =========================================================
   AD SMILE ARCH — salon.css  ·  "The Smile Studio"
   Innovative beauty palette: porcelain · berry-plum ·
   terracotta-rose · sage-mint · brass + iridescent accent.
   Loaded on <body class="salon">. NO medical framing.
   ========================================================= */

.salon{
  --bg:#faf6f2; --bg-2:#f3eae4; --warm:#efe2d8;
  --ink:#2a1722;            /* deep aubergine ink — crisp on porcelain */
  --ink-soft:#6c5560;       /* readable secondary */
  --line:#e7dad2;
  --plum:#5e2a3b; --plum-deep:#431e2b;
  --rose:#c97b6b; --rose-deep:#a85a4e;
  --mint:#8fb8a6; --mint-deep:#5e8c77;
  --gold:#c9a227; --gold-soft:#e6c878;
  --irid:linear-gradient(120deg,#f6d8c9 0%,#eccfe2 50%,#d2e6dc 100%);
  --irid-soft:linear-gradient(120deg,rgba(246,216,201,.5),rgba(236,207,226,.5),rgba(210,230,220,.5));
  background:var(--bg);color:var(--ink);font-weight:400;
}
.salon::before{opacity:.025}
.salon ::selection{background:var(--rose);color:#fff}
.salon ::-webkit-scrollbar-track{background:var(--bg)}
.salon ::-webkit-scrollbar-thumb{background:linear-gradient(var(--rose),var(--plum));border:3px solid var(--bg)}

/* fonts: Fraunces display + Jost body */
.salon h1,.salon h2,.salon h3,.salon h4,.salon h5{font-family:'Fraunces',serif;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.salon .script{font-family:'Pinyon Script',cursive}
.salon .eyebrow{color:var(--rose-deep);font-weight:600;font-size:.72rem}
.salon .eyebrow::before{background:linear-gradient(90deg,transparent,var(--rose))}
.salon .eyebrow.center::before{background:linear-gradient(90deg,transparent,var(--rose))}
.salon .eyebrow.center::after{background:linear-gradient(90deg,var(--rose),transparent)}
.salon .sec-title{color:var(--ink)}
.salon .sec-title em{color:var(--rose-deep)}
.salon .sec-sub{color:var(--ink-soft);font-size:1.08rem}

/* glitter palette on light bg — visible rose+gold */
.salon .glitter .g{--g-color:#e6c878;--g-glow:rgba(201,123,107,.55)}
.salon .glitter .g.spark{--g-color:#c97b6b;--g-glow:rgba(94,42,59,.4)}

/* buttons */
.salon .btn-solid{background:var(--plum);color:#fff5ef;border-radius:44px;padding:16px 34px;
  display:inline-flex;align-items:center;gap:10px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
  transition:.45s var(--ease);box-shadow:0 16px 34px -18px rgba(94,42,59,.7)}
.salon .btn-solid:hover{background:var(--rose-deep);transform:translateY(-3px);box-shadow:0 22px 44px -16px rgba(168,90,78,.7)}
.salon .btn-line{border:1.5px solid var(--plum);color:var(--plum);border-radius:44px;padding:15px 32px;
  display:inline-flex;align-items:center;gap:10px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;transition:.45s var(--ease)}
.salon .btn-line:hover{background:var(--plum);color:#fff5ef;transform:translateY(-3px)}

/* ===== NAV ===== */
.salon header.scrolled{background:rgba(250,246,242,.9);box-shadow:0 1px 0 var(--line),0 16px 40px -30px rgba(94,42,59,.3)}
.salon .logo .lt b{background:linear-gradient(135deg,var(--rose-deep),var(--plum));-webkit-background-clip:text;background-clip:text;color:transparent}
.salon .logo .lt span{color:var(--ink-soft)}
.salon .navlinks a{color:#4a3640;font-weight:500}
.salon .navlinks a::after{background:var(--rose)}
.salon .navlinks a:hover{color:var(--rose-deep)}
.salon .nav-cta{border-color:var(--plum);color:var(--plum);font-weight:500}
.salon .nav-cta:hover{background:var(--plum);color:#fff5ef;box-shadow:0 8px 22px -8px rgba(94,42,59,.5)}
.salon .burger span{background:var(--plum)}
.salon .navlinks.mobile{background:rgba(250,246,242,.98);border-left:1px solid var(--line)}
.salon .navlinks.mobile a{border-bottom:1px solid var(--line)}

/* ===== HERO ===== */
.s-hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:130px 0 70px;overflow:hidden}
.s-hero-bg{position:absolute;inset:0;z-index:0;background:
   radial-gradient(70% 60% at 88% 16%,rgba(236,207,226,.55),transparent 60%),
   radial-gradient(60% 60% at 6% 92%,rgba(210,230,220,.55),transparent 60%),
   radial-gradient(50% 50% at 50% 50%,rgba(246,216,201,.35),transparent 70%),
   linear-gradient(160deg,#faf6f2,#f3eae4)}
.s-hero-bg::after{content:"";position:absolute;width:62vmax;height:62vmax;right:-16vmax;top:-12vmax;
  background:var(--irid);opacity:.55;border-radius:46% 54% 60% 40%/52% 44% 56% 48%;
  filter:blur(8px);animation:morph 18s ease-in-out infinite}
@keyframes morph{0%,100%{border-radius:46% 54% 60% 40%/52% 44% 56% 48%;transform:rotate(0)}50%{border-radius:60% 40% 44% 56%/46% 58% 42% 54%;transform:rotate(12deg)}}
.s-hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.s-hero .eyebrow{margin-bottom:22px}
.s-name{font-family:'Fraunces',serif;font-size:clamp(2.9rem,6.6vw,5.1rem);line-height:1;color:var(--ink);font-weight:600}
.s-name em{font-style:italic;font-weight:500;background:linear-gradient(120deg,var(--rose-deep),var(--plum) 60%,var(--rose));-webkit-background-clip:text;background-clip:text;color:transparent}
.s-lead{font-size:1.12rem;color:#4a3b42;max-width:46ch;margin:22px 0 18px;line-height:1.7}
.s-tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:32px}
.s-tag{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;padding:9px 18px;border-radius:30px;font-weight:500;
  background:rgba(255,255,255,.7);backdrop-filter:blur(6px);border:1px solid var(--line);color:var(--plum)}
.s-btns{display:flex;gap:14px;flex-wrap:wrap}
.s-right{position:relative;display:flex;justify-content:center}
.s-photo{position:relative;width:min(100%,440px);aspect-ratio:680/900;border-radius:300px 300px 34px 34px;overflow:hidden;
  box-shadow:0 50px 100px -42px rgba(94,42,59,.5);border:9px solid #fff}
.s-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.s-leaf{position:absolute;z-index:-1;opacity:.6}
.s-leaf svg{width:150px;height:150px;stroke:var(--mint-deep);fill:none;stroke-width:1}
.s-leaf.l1{top:-34px;left:-34px}
.s-leaf.l2{bottom:-22px;right:-34px;transform:rotate(160deg)}
.s-chip{position:absolute;z-index:3;background:rgba(255,255,255,.82);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.7);
  border-radius:20px;padding:15px 19px;box-shadow:0 24px 50px -24px rgba(94,42,59,.45);display:flex;align-items:center;gap:13px}
.s-chip .em{font-family:'Fraunces';font-weight:600;font-size:1.8rem;line-height:1;
  background:linear-gradient(120deg,var(--rose-deep),var(--plum));-webkit-background-clip:text;background-clip:text;color:transparent}
.s-chip .lbl{font-size:.66rem;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);max-width:12ch;font-weight:500}
.s-chip.c1{top:8%;left:-6%}
.s-chip.c2{bottom:11%;right:-7%}

/* ===== marquee strip (plum) ===== */
.s-strip{background:var(--plum);overflow:hidden;padding:20px 0}
.s-strip-track{display:flex;gap:54px;width:max-content;animation:slide 30s linear infinite}
.s-strip:hover .s-strip-track{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.s-strip .it{font-family:'Fraunces';font-style:italic;font-size:1.4rem;color:#f3d9c9;white-space:nowrap;display:inline-flex;align-items:center;gap:16px}
.s-strip .it::after{content:"✦";color:var(--gold-soft);font-style:normal;font-size:.8rem}

/* ===== section bg helpers ===== */
.salon .bg-warm{background:linear-gradient(180deg,#f3eae4,#efe2d8)}
.salon .bg-plain{background:var(--bg)}
.salon .bg-ink{background:linear-gradient(160deg,#3a1f2e,#2a1722)}
.salon .bg-ink .sec-title,.salon .bg-ink h2,.salon .bg-ink h3,.salon .bg-ink h4{color:#fbeef0}
.salon .bg-ink .sec-title em{color:var(--gold-soft)}
.salon .bg-ink .sec-sub,.salon .bg-ink p{color:#e3cdd2}
.salon .bg-ink .eyebrow{color:var(--gold-soft)}
.salon .bg-ink .eyebrow::before,.salon .bg-ink .eyebrow.center::after,.salon .bg-ink .eyebrow.center::before{background:linear-gradient(90deg,transparent,var(--gold-soft))}

/* iridescent hairline divider */
.irid-div{height:3px;width:120px;margin:0 auto;border-radius:3px;background:var(--irid)}

/* ===== ritual ===== */
.s-ritual{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.r-step{position:relative;text-align:center;padding:38px 22px;background:#fff;border-radius:26px;border:1px solid var(--line);
  transition:.5s var(--ease);overflow:hidden}
.r-step::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--irid);transform:scaleX(0);transform-origin:left;transition:.5s var(--ease)}
.r-step:hover{transform:translateY(-10px);box-shadow:0 34px 64px -34px rgba(94,42,59,.4);border-color:transparent}
.r-step:hover::before{transform:scaleX(1)}
.r-step .ring{width:80px;height:80px;margin:0 auto 22px;border-radius:50%;display:grid;place-items:center;
  background:var(--irid);box-shadow:inset 0 0 0 6px #fff}
.r-step .ring svg{width:34px;height:34px;stroke:var(--plum);fill:none;stroke-width:1.4}
.r-step .no{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose-deep);margin-bottom:6px;font-weight:600}
.r-step h3{font-size:1.5rem;margin-bottom:8px}
.r-step p{color:var(--ink-soft);font-size:.92rem}

/* ===== experts ===== */
.experts-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.experts-photo{position:relative;border-radius:30px;overflow:hidden;border:9px solid #fff;box-shadow:0 46px 90px -42px rgba(94,42,59,.5)}
.experts-photo img{width:100%;display:block}
.experts-photo .float{position:absolute;bottom:22px;left:22px;right:22px;background:rgba(255,255,255,.86);
  backdrop-filter:blur(10px);border-radius:20px;padding:18px 22px;display:flex;gap:18px;align-items:center}
.experts-photo .float .big{font-family:'Fraunces';font-weight:600;font-size:2.5rem;line-height:1;
  background:linear-gradient(120deg,var(--rose-deep),var(--plum));-webkit-background-clip:text;background-clip:text;color:transparent}
.experts-photo .float .t{font-size:.85rem;color:var(--ink-soft)}
.experts-text h2{font-size:clamp(2rem,4vw,3rem);margin:16px 0 14px}
.experts-text h2 em{font-style:italic;color:var(--rose-deep)}
.experts-text p{color:#4a3b42;margin-bottom:16px;line-height:1.7}
.elist{display:flex;flex-direction:column;gap:12px;margin-top:22px}
.elist li{display:flex;gap:14px;align-items:flex-start}
.elist .ic{flex:0 0 42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--irid)}
.elist .ic svg{width:20px;height:20px;stroke:var(--plum);fill:none;stroke-width:1.6}
.elist b{font-family:'Fraunces';font-weight:600;color:var(--ink);display:block;font-size:1.06rem}
.elist span{font-size:.9rem;color:var(--ink-soft)}

/* ===== signature kit (dark aubergine) ===== */
.kit-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.kit-photo{position:relative;border-radius:30px;overflow:hidden;border:8px solid rgba(255,255,255,.08);box-shadow:0 46px 90px -42px rgba(0,0,0,.6)}
.kit-photo img{width:100%;display:block}
.kit-photo .stamp{position:absolute;top:20px;right:20px;background:rgba(255,255,255,.9);border-radius:30px;padding:8px 18px;
  font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--plum);font-weight:600}
.kit-list{display:flex;flex-direction:column;gap:14px;margin-top:26px}
.kit-list li{display:flex;gap:16px;align-items:flex-start}
.kit-list .ic{flex:0 0 46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(230,200,120,.16);border:1px solid rgba(230,200,120,.4)}
.kit-list .ic svg{width:22px;height:22px;stroke:var(--gold-soft);fill:none;stroke-width:1.5}
.kit-list b{font-family:'Fraunces';font-weight:600;font-size:1.12rem;display:block;color:#fbeef0}
.kit-list span{font-size:.9rem;color:#e3cdd2}
.kit-value{display:inline-flex;align-items:center;gap:10px;margin-top:28px;padding:15px 26px;border-radius:14px;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#2a1722;font-weight:600;letter-spacing:.03em}
.kit-value b{font-family:'Fraunces';font-size:1.4rem}

/* ===== services menu ===== */
.menu{max-width:900px;margin:0 auto}
.menu-row{display:flex;align-items:baseline;gap:18px;padding:24px 0;border-bottom:1px dashed var(--line);transition:.3s}
.menu-row:hover{padding-left:8px}
.menu-row:hover .mr-name{color:var(--rose-deep)}
.mr-name{font-family:'Fraunces';font-weight:600;font-size:1.45rem;color:var(--ink);transition:.3s;white-space:nowrap}
.mr-dots{flex:1;border-bottom:1px dotted #d3c2b8;transform:translateY(-4px)}
.mr-desc{flex:0 0 auto;max-width:40%;font-size:.88rem;color:var(--ink-soft);text-align:right}
.mr-meta{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);white-space:nowrap;font-weight:600}

/* ===== love grid ===== */
.love-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.love{position:relative;padding:36px 28px;background:#fff;border-radius:26px;border:1px solid var(--line);transition:.5s var(--ease);overflow:hidden}
.love::after{content:"";position:absolute;inset:0;border-radius:26px;padding:1.5px;background:var(--irid);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.5s}
.love:hover{transform:translateY(-10px);box-shadow:0 34px 64px -34px rgba(94,42,59,.4)}
.love:hover::after{opacity:1}
.love .ic{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;margin-bottom:18px;background:var(--irid)}
.love .ic svg{width:28px;height:28px;stroke:var(--plum);fill:none;stroke-width:1.4}
.love h4{font-size:1.4rem;margin-bottom:8px}
.love p{color:var(--ink-soft);font-size:.92rem}

/* ===== gallery ===== */
.s-gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.s-gal a{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:3/4;border:6px solid #fff;box-shadow:0 26px 54px -36px rgba(94,42,59,.45)}
.s-gal img{width:100%;height:100%;object-fit:cover;transition:.7s var(--ease)}
.s-gal a:hover img{transform:scale(1.07)}
.s-gal a::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(94,42,59,.45),transparent 55%);opacity:.55;transition:.4s}
.s-gal a:hover::after{opacity:.2}

/* ===== book band (photo-capable) ===== */
.book-band{position:relative;border-radius:32px;overflow:hidden;padding:64px;text-align:center;background:linear-gradient(160deg,#3a1f2e,#2a1722)}
.book-band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:.5}
.book-band .ov{position:absolute;inset:0;z-index:1;background:linear-gradient(160deg,rgba(58,31,46,.86),rgba(42,23,34,.92))}
.book-band>*{position:relative;z-index:2}
.book-band .script{color:var(--gold-soft);font-size:2.1rem}
.book-band h2{font-size:clamp(2rem,4.5vw,3.2rem);color:#fbeef0;margin:6px 0 16px}
.book-band p{color:#e3cdd2;max-width:48ch;margin:0 auto 30px}

/* ===== contact ===== */
.s-ct{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:stretch}
.s-ct-info h2{font-size:clamp(2rem,4vw,3rem);margin:14px 0 16px}
.s-ct-info h2 em{font-style:italic;color:var(--rose-deep)}
.s-ct-info p{color:#4a3b42;max-width:42ch;margin-bottom:28px}
.s-ct-list{display:flex;flex-direction:column;gap:6px;margin-bottom:28px}
.s-ct-row{display:flex;gap:16px;align-items:center;padding:16px;border-radius:16px;transition:.4s;border:1px solid transparent}
.s-ct-row:hover{background:#fff;border-color:var(--line);box-shadow:0 18px 40px -30px rgba(94,42,59,.4)}
.s-ct-row .ic{flex:0 0 46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--irid)}
.s-ct-row .ic svg{width:20px;height:20px;stroke:var(--plum);fill:none;stroke-width:1.6}
.s-ct-row .tx span{display:block;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#9a8190}
.s-ct-row .tx b{font-weight:600;color:var(--ink);font-size:1.04rem;font-family:'Fraunces'}
.s-socials{display:flex;gap:12px}
.s-socials a{width:48px;height:48px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line);background:#fff;transition:.4s}
.s-socials a:hover{background:var(--plum);transform:translateY(-4px)}
.s-socials a svg{width:20px;height:20px;fill:var(--plum);transition:.4s}
.s-socials a:hover svg{fill:#fff5ef}
.s-form{background:#fff;border:1px solid var(--line);border-radius:26px;padding:42px;box-shadow:0 34px 80px -44px rgba(94,42,59,.4);position:relative;overflow:hidden}
.s-form::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--irid)}
.s-form h3{font-size:1.8rem;margin-bottom:6px}
.s-form .sm{font-size:.88rem;color:var(--ink-soft);margin-bottom:24px}
.s-form .fg label{display:block;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:#9a8190;margin-bottom:8px;font-weight:500}
.s-form .fg{margin-bottom:18px}
.s-form input,.s-form select,.s-form textarea{width:100%;padding:14px 16px;border-radius:12px;background:var(--bg);
  border:1px solid var(--line);color:var(--ink);font-family:'Jost';font-size:.95rem;transition:.3s}
.s-form input:focus,.s-form select:focus,.s-form textarea:focus{outline:none;border-color:var(--rose);box-shadow:0 0 0 3px rgba(201,123,107,.18)}
.s-form textarea{resize:vertical;min-height:90px}
.s-form .btn-solid{width:100%;justify-content:center;margin-top:6px}

/* ===== footer ===== */
.salon footer{background:linear-gradient(160deg,#3a1f2e,#2a1722);border-top:1px solid rgba(230,200,120,.22)}
.salon .foot-grid p{color:#cdb4bc}
.salon .foot-grid h5{color:var(--gold-soft)}
.salon .foot-grid a{color:#cdb4bc}
.salon .foot-grid a:hover{color:var(--gold-soft)}
.salon .foot-bot{border-top:1px solid rgba(230,200,120,.14);color:#a98c98}
.salon .foot-bot .gold-txt{background:linear-gradient(135deg,var(--gold-soft),var(--rose));-webkit-background-clip:text;background-clip:text;color:transparent}
.salon .logo .lt span{color:#cdb4bc}

/* responsive */
@media(max-width:1000px){
  .s-hero .wrap,.experts-grid,.kit-grid,.s-ct{grid-template-columns:1fr}
  .s-right{order:-1;margin-bottom:14px}
  .s-ritual{grid-template-columns:1fr 1fr}
  .love-grid,.s-gal{grid-template-columns:1fr 1fr}
  .s-chip.c1{left:0}.s-chip.c2{right:0}
  .mr-desc{display:none}
}
@media(max-width:600px){
  .s-ritual,.love-grid,.s-gal{grid-template-columns:1fr}
  .book-band,.s-form{padding:30px}
  .menu-row{flex-wrap:wrap;gap:8px}
  .mr-dots{display:none}
}

/* =========================================================
   ADD-ON: gradient button + illustrated transformation
   ========================================================= */
.salon .btn-grad{display:inline-flex;align-items:center;gap:10px;padding:16px 34px;border-radius:44px;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:#fff5ef;
  background:linear-gradient(120deg,var(--rose) 0%,var(--plum) 70%);background-size:160% 160%;
  box-shadow:0 18px 38px -16px rgba(94,42,59,.65);transition:.45s var(--ease)}
.salon .btn-grad:hover{transform:translateY(-3px);background-position:100% 0;box-shadow:0 24px 48px -16px rgba(168,90,78,.7)}

/* illustrated before/after */
.ill-band{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.ill-stage{position:relative;background:#fff;border-radius:28px;padding:30px;border:1px solid var(--line);
  box-shadow:0 40px 80px -44px rgba(94,42,59,.4)}
.ill-stage::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;border-radius:28px 28px 0 0;background:var(--irid)}
.ill-stage svg{width:100%;height:auto;display:block}
.ill-cap{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding:0 8px}
.ill-cap span{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.ill-cap b{font-family:'Fraunces';font-weight:600;color:var(--rose-deep);font-size:1.05rem}
.ill-text h2{font-size:clamp(2rem,4vw,3rem);margin:16px 0 0}
.ill-text h2 em{font-style:italic;color:var(--rose-deep)}
.ill-points{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.ill-points li{display:flex;gap:14px;align-items:flex-start}
.ill-points .pn{flex:0 0 34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--irid)}
.ill-points .pn svg{width:18px;height:18px;stroke:var(--plum);fill:none;stroke-width:2}
.ill-points b{font-family:'Fraunces';font-weight:600;color:var(--ink);display:block;font-size:1.04rem}
.ill-points span{font-size:.9rem;color:var(--ink-soft)}
@media(max-width:1000px){.ill-band{grid-template-columns:1fr;gap:36px}}
