
:root{
  --ink:#32180f;
  --brown:#5c2e19;
  --brown-soft:#7b563a;
  --gold:#c58d35;
  --gold-2:#e4bc68;
  --gold-3:#9b641d;
  --cream:#fffaf2;
  --cream-2:#f7eddd;
  --white:#ffffff;
  --line:rgba(185,132,53,.22);
  --shadow:0 22px 70px rgba(61,31,17,.10);
  --shadow-soft:0 14px 40px rgba(61,31,17,.08);
  --radius:28px;
  --him-blue:#9db9c9;
  --him-blue-2:#d7e5ec;
  --him-blue-ink:#2c5368;
  --her-pink:#d7a3b2;
  --her-pink-2:#f4d6de;
  --her-pink-ink:#774051;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Noto Sans Thai","Noto Sans",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 8% 6%,rgba(228,188,104,.18),transparent 32rem),
    radial-gradient(circle at 90% 18%,rgba(197,141,53,.10),transparent 30rem),
    linear-gradient(180deg,#fff 0%,#fffaf1 48%,#fff 100%);
  line-height:1.65;
}
body.nav-open{overflow:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}
button{cursor:pointer}
.container{width:min(1180px,calc(100% - 32px));margin-inline:auto}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:#fff;padding:.7rem 1rem;border-radius:999px;z-index:999}

[data-lang="en"] .th,[data-lang="th"] .en{display:none!important}
.display{
  font-family:"Noto Serif Thai","Cormorant Garamond",Georgia,serif;
  font-weight:500;
  line-height:1.18;
  letter-spacing:-.025em;
}
.eyebrow{
  color:var(--gold);
  font-family:"Cormorant Garamond","Noto Serif Thai",Georgia,serif;
  letter-spacing:.08em;
  font-size:1.06rem;
}
.gold-text{color:var(--gold)}
.muted{color:rgba(50,24,15,.66)}
.small{font-size:.92rem}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  min-height:46px;
  padding:.74rem 1.18rem;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.82);
  color:var(--ink);
  box-shadow:0 8px 24px rgba(61,31,17,.06);
  transition:transform .24s ease,box-shadow .24s ease,background .24s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}
.btn-gold{border:0;color:#fff;background:linear-gradient(135deg,var(--gold-2),#bd7e27 64%,#8e541d)}
.btn-soft{background:linear-gradient(180deg,#fff,#fff8ec)}
.btn-him{
  border-color:rgba(112,154,177,.34);
  color:var(--him-blue-ink);
  background:linear-gradient(135deg,var(--him-blue-2),#c0d5df 48%,var(--him-blue));
  box-shadow:0 12px 30px rgba(73,112,134,.18);
  font-weight:800;
}
.btn-her{
  border-color:rgba(196,125,145,.34);
  color:var(--her-pink-ink);
  background:linear-gradient(135deg,#fff0f3,var(--her-pink-2) 46%,var(--her-pink));
  box-shadow:0 12px 30px rgba(157,83,105,.16);
  font-weight:800;
}
.btn-him:hover{box-shadow:0 18px 42px rgba(73,112,134,.24);}
.btn-her:hover{box-shadow:0 18px 42px rgba(157,83,105,.22);}
.btn svg{width:1.05rem;height:1.05rem}
.icon{
  width:42px;height:42px;border-radius:999px;
  display:grid;place-items:center;
  color:var(--gold);
  border:1px solid var(--line);
  background:rgba(255,255,255,.78);
}
.icon svg{width:22px;height:22px;stroke-width:1.65}
.brand-mark{display:block;object-fit:contain}
.logo-lockup{display:flex;align-items:center;gap:.75rem}
.logo-lockup .brand-mark{width:44px;height:44px;flex:0 0 auto}
.logo-lockup strong{display:block;font-size:.93rem;letter-spacing:.095em;line-height:1;color:var(--ink)}
.logo-lockup span{display:block;margin-top:.25rem;color:var(--gold);font-size:.58rem;letter-spacing:.22em;font-weight:700}

/* Header */
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(255,253,248,.88);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(185,132,53,.14);
}
.navbar{
  min-height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
}
.nav-links{
  position:fixed;
  inset:74px 16px auto 16px;
  display:grid;
  gap:.15rem;
  padding:1rem;
  border:1px solid var(--line);
  border-radius:24px;
  background:rgba(255,253,248,.98);
  box-shadow:var(--shadow);
  opacity:0;
  pointer-events:none;
  transform:translateY(-10px);
  transition:.24s ease;
}
body.nav-open .nav-links{opacity:1;pointer-events:auto;transform:translateY(0)}
.nav-links a{
  display:flex;
  justify-content:space-between;
  padding:.86rem 1rem;
  border-radius:16px;
  color:rgba(50,24,15,.78);
}
.nav-links a:hover,.nav-links a.is-current{background:#fff4df;color:var(--ink)}
.nav-service{display:grid;gap:.15rem;position:relative}
.nav-service-trigger{width:100%}
.nav-dropdown{display:grid;gap:.12rem;margin:.05rem 0 .2rem .85rem;padding-left:.85rem;border-left:1px solid rgba(185,132,53,.22)}
.nav-dropdown a{font-size:.92rem;color:rgba(50,24,15,.66);background:rgba(255,244,223,.42)}
.nav-dropdown a:hover,.nav-dropdown a.is-current{background:#fff4df;color:var(--ink)}

.nav-actions{display:flex;align-items:center;gap:.5rem}
.lang-toggle{
  display:inline-grid;
  grid-template-columns:1fr 1fr;
  padding:3px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
}
.lang-toggle button{border:0;background:transparent;border-radius:999px;padding:.43rem .55rem;font-size:.75rem;color:rgba(50,24,15,.58)}
.lang-toggle button.is-active{background:var(--ink);color:#fff}
.menu-btn{
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  width:44px;height:44px;
  display:grid;place-items:center;
  color:var(--brown);
}
.header-cta{display:none}

/* Mobile-first sections */
main{position:relative;overflow:hidden}
.decor-bg{
  position:absolute;inset:0;pointer-events:none;opacity:.30;
  background:
    radial-gradient(circle at 12% 14%,rgba(197,141,53,.11) 0 2px,transparent 3px),
    radial-gradient(circle at 88% 16%,rgba(197,141,53,.10) 0 2px,transparent 3px);
  background-size:58px 58px,72px 72px;
  mask-image:linear-gradient(180deg,#000 0,transparent 78%);
}
.hero{
  position:relative;
  padding:1.2rem 0 4rem;
}
.hero-inner{display:grid;gap:1.35rem;position:relative;z-index:2}
.hero-visual{
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(185,132,53,.20);
  box-shadow:var(--shadow);
  background:#fff;
}
.hero-visual img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  object-position:62% center;
}
.hero-copy{
  padding:.3rem .15rem 0;
}
.hero-copy .hero-logo{
  width:76px;height:76px;margin-bottom:1rem;object-fit:contain;
}
.hero h1{
  font-size:clamp(2.35rem,12vw,5.7rem);
  margin:0 0 .9rem;
}
.hero-sub{
  font-size:1.15rem;
  line-height:1.75;
  color:#9a641f;
  margin:0 0 1.2rem;
}
.hero-tags{
  display:grid;
  grid-template-columns:1fr;
  gap:.58rem;
  width:100%;
  max-width:760px;
  margin:0 0 1.25rem;
  padding:0;
  list-style:none;
}
.hero-tags li{
  min-width:0;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:.5rem;
  padding:.62rem .88rem;
  border:1px solid var(--line);
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.90),rgba(255,248,237,.76));
  color:rgba(50,24,15,.78);
  font-size:.92rem;
  font-weight:650;
  line-height:1.2;
  box-shadow:0 10px 26px rgba(61,31,17,.055);
}
.hero-tags svg{
  width:1.08rem;
  height:1.08rem;
  flex:0 0 1.08rem;
  color:var(--gold-3);
  stroke-width:1.85;
}
.hero-tags span{min-width:0;}
.hero-actions,.actions{display:flex;gap:.7rem;flex-wrap:wrap}

/* General */
.section{padding:4rem 0}
.section-tight{padding:2.7rem 0}
.section-head{margin-bottom:1.45rem}
.section-head.center{text-align:center}
.section-title{font-size:clamp(2rem,8vw,4.2rem);margin:0}
.section-kicker{display:block;color:var(--gold);font-family:"Cormorant Garamond","Noto Serif Thai",Georgia,serif;font-size:1.1rem;margin-top:.15rem}
.section-lead{color:rgba(50,24,15,.66);line-height:1.9;max-width:680px;margin:.9rem 0 0}
.section-head.center .section-lead{margin-inline:auto}
.card{
  border:1px solid var(--line);
  background:rgba(255,255,255,.78);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
}
.services-grid{display:grid;gap:1rem}
.service-card{
  padding:.75rem;
  display:grid;
  grid-template-columns:108px 1fr;
  gap:.9rem;
  align-items:center;
}
.service-card img{
  width:108px;height:120px;object-fit:cover;border-radius:18px;
}
.service-card h3{font-family:"Cormorant Garamond","Noto Serif Thai",Georgia,serif;font-size:1.42rem;line-height:1.1;margin:0 0 .4rem}
.service-card p{margin:0 0 .8rem;color:rgba(50,24,15,.64);font-size:.92rem;line-height:1.65}
.text-link{display:inline-flex;color:var(--gold-3);font-weight:700;font-size:.92rem}
.center-action{text-align:center;margin-top:1.5rem}

/* Why */
.reason-grid{display:grid;gap:.85rem}
.reason-card{
  display:grid;
  grid-template-columns:44px 1fr;
  gap:.9rem;
  padding:1.1rem;
}
.reason-card h3{margin:0 0 .25rem;font-size:1.05rem}
.reason-card p{margin:0;color:rgba(50,24,15,.62);font-size:.9rem;line-height:1.65}

/* About */
.about-panel{padding:.85rem;display:grid;gap:1rem}
.about-copy{padding:1.2rem}
.about-copy h2{font-size:clamp(2rem,8vw,3.4rem);margin:.2rem 0 .9rem}
.about-copy p{color:rgba(50,24,15,.67);line-height:1.9;margin:0 0 1.25rem}
.about-gallery{display:grid;gap:.75rem}
.about-gallery img{width:100%;min-height:220px;object-fit:cover;border-radius:22px}

/* Highlights */
.highlights-panel{padding:.85rem}
.highlight-grid{display:grid;gap:1rem}
.highlight-card{
  overflow:hidden;
  display:grid;
  background:#fff;
}
.highlight-card img{width:100%;height:220px;object-fit:cover}
.highlight-copy{padding:1.35rem}
.highlight-card h3{font-size:clamp(1.8rem,7vw,3.2rem);margin:0 0 .4rem}
.highlight-card p{margin:0 0 1rem;color:rgba(50,24,15,.66)}
.check-list{list-style:none;margin:0 0 1.15rem;padding:0;display:grid;gap:.55rem}
.check-list li{display:flex;gap:.6rem;color:rgba(50,24,15,.74);line-height:1.55}
.check-list li::before{content:"◎";color:var(--gold);font-size:.8rem;margin-top:.1rem}
.price{font-family:"Cormorant Garamond",Georgia,serif;font-size:2.8rem;line-height:1;color:var(--gold);margin:.2rem 0 1rem}

/* Interior strip */
.split-grid{display:grid;gap:1rem}
.image-panel{overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-soft);border:1px solid var(--line)}
.image-panel img{width:100%;height:100%;min-height:260px;object-fit:cover}
.soft-panel{padding:1.4rem}
.soft-panel h2{font-size:clamp(2rem,8vw,3.4rem);margin:0 0 1rem}
.soft-panel p{color:rgba(50,24,15,.66);line-height:1.9;margin:0 0 1.2rem}

/* Detail pages */
.page-hero{padding:3rem 0 2rem;position:relative}
.page-hero-grid{display:grid;gap:1.3rem;align-items:center}
.page-hero h1{font-size:clamp(2.4rem,11vw,5.3rem);margin:0 0 .8rem}
.page-hero p{color:rgba(50,24,15,.68);line-height:1.9;margin:0}
.page-hero-media{border-radius:30px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.page-hero-media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.program-layout{display:grid;gap:1rem}
.program-main{display:grid;gap:1rem}
.program-card{padding:1.25rem}
.program-card h2,.program-card h3{margin-top:0}
.program-card h2{font-size:clamp(1.8rem,7vw,3rem)}
.program-card p{color:rgba(50,24,15,.66);line-height:1.85}
.fact-grid{display:grid;gap:.75rem}
.fact{padding:1rem;border-radius:20px;background:#fff;border:1px solid var(--line)}
.fact strong{display:block;color:var(--brown);margin-bottom:.2rem}
.package-table{display:grid;gap:.65rem}
.package-row{display:grid;grid-template-columns:1fr auto;gap:.8rem;align-items:center;padding:.95rem 1rem;border:1px solid var(--line);border-radius:18px;background:#fff}
.package-row strong{font-family:"Cormorant Garamond",Georgia,serif;font-size:1.5rem}
.package-row span:last-child{color:var(--gold);font-weight:700}
.sidebar{display:grid;gap:1rem}
.sticky-card{padding:1.2rem}
.sticky-card img{border-radius:20px;margin-bottom:1rem}
.sticky-card h3{margin:.2rem 0 .6rem}
.sticky-card p{color:rgba(50,24,15,.65);line-height:1.75}
.gallery-grid{display:grid;gap:1rem}
.gallery-grid img{width:100%;height:240px;object-fit:cover;border-radius:24px;box-shadow:var(--shadow-soft);border:1px solid var(--line)}

/* FAQ */
.faq-list{display:grid;gap:.75rem}
.faq-item{border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.82);overflow:hidden}
.faq-question{width:100%;border:0;background:transparent;text-align:left;display:flex;justify-content:space-between;gap:1rem;padding:1.05rem 1.2rem;color:var(--ink);font-weight:700}
.faq-question::after{content:"+";color:var(--gold);font-size:1.35rem;line-height:1}
.faq-item.is-open .faq-question::after{content:"−"}
.faq-answer{display:none;padding:0 1.2rem 1.15rem;color:rgba(50,24,15,.66);line-height:1.8}
.faq-item.is-open .faq-answer{display:block}

/* Contact */
.contact-grid{display:grid;gap:1rem}
.contact-card{padding:1.25rem}
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:.85rem}
.contact-list li{display:grid;grid-template-columns:36px 1fr;gap:.75rem;align-items:start}
.map-wrap{overflow:hidden;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow-soft);background:#fff}
.map-wrap iframe{width:100%;height:320px;border:0;display:block;filter:saturate(.86) sepia(.06)}
.form-grid{display:grid;gap:.85rem}
.input{width:100%;border:1px solid var(--line);border-radius:18px;background:#fff;padding:.95rem 1rem;color:var(--ink)}
textarea.input{min-height:140px;resize:vertical}

/* Footer */
.prefooter{
  padding:3rem 0;
  background:linear-gradient(100deg,rgba(255,255,255,.92),rgba(255,248,237,.82));
  border-top:1px solid var(--line);
}
.prefooter-grid{display:grid;gap:1rem;align-items:center}
.prefooter h2{font-size:clamp(2rem,8vw,4rem);margin:0 0 .6rem}
.prefooter p{margin:0 0 1.1rem;color:rgba(50,24,15,.66)}
.prefooter img{border-radius:28px;box-shadow:var(--shadow);border:1px solid var(--line);max-height:330px;width:100%;object-fit:cover;object-position:center top}
.footer{
  background:#fff7eb;
  border-top:1px solid var(--line);
  padding:2.4rem 0 6rem;
}
.footer-grid{display:grid;gap:1.6rem}
.footer h3{margin:0 0 .75rem}
.footer p,.footer li{color:rgba(50,24,15,.62);line-height:1.75}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.5rem}
.socials{display:flex;gap:.6rem;margin-top:1rem}
.socials a{width:36px;height:36px;border:1px solid var(--line);border-radius:999px;display:grid;place-items:center;background:#fff;color:var(--brown)}
.footer-map{overflow:hidden;border:1px solid var(--line);border-radius:22px;background:#fff}
.footer-map iframe{width:100%;height:150px;border:0;display:block}
.copyright{border-top:1px solid rgba(185,132,53,.18);margin-top:1.6rem;padding-top:1rem;color:rgba(50,24,15,.48);font-size:.85rem;display:grid;gap:.5rem;text-align:center;}

/* Sticky mobile CTA */
.mobile-cta{
  position:fixed;left:12px;right:12px;bottom:12px;z-index:90;
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:.45rem;
  padding:.45rem;border:1px solid var(--line);
  border-radius:999px;background:rgba(255,253,248,.92);
  backdrop-filter:blur(16px);
  box-shadow:0 16px 46px rgba(61,31,17,.18);
}
.mobile-cta a{display:flex;align-items:center;justify-content:center;border-radius:999px;background:#fff;min-height:42px;font-size:.82rem;border:1px solid rgba(185,132,53,.16)}
.mobile-cta a:last-child{background:linear-gradient(135deg,var(--gold-2),#bd7e27);color:#fff;border:0}

/* Utility */
.mt-0{margin-top:0}
.mt-1{margin-top:1rem}
.mt-2{margin-top:2rem}
.mb-0{margin-bottom:0}
.desktop-only{display:none}
.full-bleed-promo{border-radius:28px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.full-bleed-promo img{width:100%;object-fit:cover}
.note-box{padding:1rem;border-radius:20px;border:1px solid var(--line);background:#fffaf2;color:rgba(50,24,15,.66);line-height:1.75}

/* Tablet */
@media (min-width:720px){
  .container{width:min(1180px,calc(100% - 48px))}
  .header-cta{display:inline-flex}
  .hero{padding:2.2rem 0 5rem}
  .hero-inner{grid-template-columns:1fr;gap:1.7rem}
  .hero-copy{text-align:center;max-width:900px;margin-inline:auto}
  .hero-copy .hero-logo{margin-inline:auto}
  .hero-tags{grid-template-columns:repeat(3,minmax(0,1fr));margin-inline:auto}
  .hero-tags li{justify-content:center;text-align:center}
  .hero-tags,.hero-actions{justify-content:center}
  .hero-visual img{aspect-ratio:16/8.2}
  .section{padding:5.5rem 0}
  .section-head{display:flex;align-items:end;justify-content:space-between;gap:2rem}
  .section-head.center{display:block}
  .section-lead{margin-top:0}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .service-card{display:block;padding:.9rem}
  .service-card img{width:100%;height:auto;aspect-ratio:1/.85;margin-bottom:1rem}
  .service-card h3,.service-card p{text-align:center;margin-left:auto;margin-right:auto}
  .reason-grid{grid-template-columns:repeat(2,1fr)}
  .about-panel{grid-template-columns:.75fr 1.25fr;align-items:stretch}
  .about-gallery{grid-template-columns:repeat(3,1fr)}
  .about-gallery img{min-height:100%;height:100%;aspect-ratio:1/1.08}
  .highlight-grid{grid-template-columns:repeat(2,1fr)}
  .highlight-card img{height:260px}
  .split-grid{grid-template-columns:1fr 1fr;align-items:center}
  .page-hero-grid{grid-template-columns:1fr .85fr}
  .program-layout{grid-template-columns:1fr .38fr;align-items:start}
  .sidebar{position:sticky;top:96px}
  .fact-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:.75fr 1.25fr}
  .form-grid.two{grid-template-columns:repeat(2,1fr)}
  .prefooter-grid{grid-template-columns:1fr .55fr}
  .footer-grid{grid-template-columns:1.1fr .9fr 1fr 1fr}
  .copyright{display:flex;justify-content:space-between}
}

/* Desktop */
@media (min-width:1040px){
  .navbar{min-height:82px}
  .menu-btn{display:none}
  .nav-links{
    position:static;display:flex;align-items:center;gap:1.15rem;
    padding:0;border:0;background:transparent;box-shadow:none;
    opacity:1;pointer-events:auto;transform:none;
  }
  .nav-links a{padding:.65rem .3rem;border-radius:0;font-size:.94rem;position:relative}
  .nav-links a::after{content:"";position:absolute;left:.3rem;right:.3rem;bottom:.35rem;height:1px;background:var(--gold);transform:scaleX(0);transition:.24s ease}
  .nav-links a:hover,.nav-links a.is-current{background:transparent}
  .nav-links a:hover::after,.nav-links a.is-current::after{transform:scaleX(1)}
  .nav-service{display:block}
  .nav-service-trigger{width:auto}
  .nav-dropdown{
    position:absolute;top:calc(100% + .68rem);left:50%;z-index:90;
    min-width:245px;margin:0;padding:.55rem;border:1px solid var(--line);
    border-radius:18px;background:rgba(255,253,248,.98);box-shadow:var(--shadow);
    opacity:0;pointer-events:none;transform:translateX(-50%) translateY(8px);
    transition:.22s ease;
  }
  .nav-service:hover .nav-dropdown,.nav-service:focus-within .nav-dropdown{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
  .nav-dropdown::before{content:"";position:absolute;left:0;right:0;top:-.8rem;height:.8rem}
  .nav-dropdown a{display:block;padding:.78rem .9rem;border-radius:12px;font-size:.88rem;background:transparent;white-space:nowrap}
  .nav-dropdown a::after{display:none}
  .nav-dropdown a:hover,.nav-dropdown a.is-current{background:#fff4df;color:var(--ink)}

  .hero{min-height:760px;padding:3rem 0 7rem}
  .hero-inner{grid-template-columns:.9fr .95fr;align-items:center;gap:2.2rem}
  .hero-copy{text-align:left;max-width:none}
  .hero-copy .hero-logo{margin-left:0}
  .hero-tags{display:flex;flex-wrap:nowrap;margin-left:0;margin-right:0;max-width:100%;width:100%}
  .hero-tags li{flex:1 1 0;white-space:nowrap;justify-content:center;padding-inline:.7rem}
  .hero-tags,.hero-actions{justify-content:flex-start}
  .hero-visual{border-radius:44px}
  .hero-visual img{height:620px;aspect-ratio:auto}
  .services-grid{grid-template-columns:repeat(5,1fr)}
  .reason-grid{grid-template-columns:repeat(5,1fr)}
  .reason-card{text-align:center;display:block;padding:1.4rem 1rem;background:transparent;box-shadow:none}
  .reason-card .icon{margin:0 auto 1rem}
  .highlight-card{grid-template-columns:.95fr 1fr;min-height:390px}
  .highlight-card img{height:100%;min-height:390px}
  .desktop-only{display:block}
  .mobile-cta{display:none}
}


@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{scroll-behavior:auto!important;transition:none!important}
}

/* Premium polish pass: motion, depth, corrected footer layout */
:root{
  --ease-lux:cubic-bezier(.19,1,.22,1);
  --shadow-lux:0 28px 90px rgba(61,31,17,.14);
  --ring-gold:0 0 0 1px rgba(228,188,104,.22),0 18px 60px rgba(197,141,53,.14);
}

body{
  background:
    radial-gradient(circle at 8% 6%,rgba(228,188,104,.18),transparent 32rem),
    radial-gradient(circle at 86% 12%,rgba(197,141,53,.13),transparent 28rem),
    radial-gradient(circle at 78% 78%,rgba(255,236,197,.32),transparent 32rem),
    linear-gradient(180deg,#fff 0%,#fffaf1 46%,#fff 100%);
}

.site-header{
  transition:background .35s var(--ease-lux),box-shadow .35s var(--ease-lux),border-color .35s var(--ease-lux),transform .35s var(--ease-lux);
}
.site-header::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(228,188,104,.72),transparent);
  opacity:.7;
}
.site-header.is-scrolled{
  background:rgba(255,253,248,.95);
  box-shadow:0 14px 42px rgba(61,31,17,.08);
}
.scroll-progress{
  position:fixed;
  top:0;left:0;
  width:100%;height:3px;
  transform:scaleX(var(--scroll-progress,0));
  transform-origin:left center;
  background:linear-gradient(90deg,#e4bc68,#c58d35,#8e541d);
  z-index:999;
  pointer-events:none;
}

.logo-lockup{min-width:0;}
.logo-lockup > span{
  min-width:0;
  margin-top:0;
  color:inherit;
  font-size:inherit;
  letter-spacing:normal;
  font-weight:400;
}
.logo-lockup > span > span{
  display:block;
  margin-top:.25rem;
  color:var(--gold);
  font-size:.58rem;
  letter-spacing:.22em;
  font-weight:700;
}
.logo-lockup .brand-mark{height:auto;}

.btn,.card,.image-panel,.page-hero-media,.full-bleed-promo,.footer-map,.about-gallery img,.gallery-grid img,.prefooter img{
  transition:transform .55s var(--ease-lux),box-shadow .55s var(--ease-lux),border-color .55s var(--ease-lux),filter .55s var(--ease-lux);
}
.btn{position:relative;overflow:hidden;isolation:isolate;}
.btn::after{
  content:"";
  position:absolute;
  inset:-40% auto -40% -65%;
  width:55%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.46),transparent);
  transform:skewX(-18deg) translateX(-120%);
  transition:transform .9s var(--ease-lux);
  z-index:0;
  pointer-events:none;
}
.btn:hover::after{transform:skewX(-18deg) translateX(420%);}
.btn:hover{transform:translateY(-3px);}

.card{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,250,242,.74));
  backdrop-filter:blur(10px);
}
.card::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at var(--mx,50%) var(--my,0%),rgba(228,188,104,.18),transparent 38%);
  opacity:0;
  transition:opacity .35s ease;
  pointer-events:none;
}
.card:hover::before{opacity:1;}
.card:hover,.image-panel:hover,.page-hero-media:hover,.full-bleed-promo:hover,.gallery-grid img:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lux);
  border-color:rgba(197,141,53,.36);
}
.service-card img,.highlight-card img,.image-panel img,.page-hero-media img,.gallery-grid img,.prefooter img{
  transition:transform .8s var(--ease-lux),filter .8s var(--ease-lux);
}
.service-card:hover img,.highlight-card:hover img,.image-panel:hover img,.page-hero-media:hover img,.gallery-grid img:hover,.prefooter img:hover{
  transform:scale(1.035);
  filter:saturate(1.05) contrast(1.02);
}
.hero-visual{position:relative;isolation:isolate;}
.hero-visual::before{
  content:"";
  position:absolute;
  inset:1px;
  z-index:1;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(145deg,rgba(255,255,255,.28),transparent 32%,rgba(197,141,53,.10));
}
.hero-visual img{transform:scale(1.025) translate3d(0,var(--parallax-y,0px),0);will-change:transform;}

.section-title,.hero h1,.page-hero h1{
  text-wrap:balance;
}
.section-head{position:relative;}
.section-head::before{
  content:"";
  position:absolute;
  left:0;top:-.8rem;
  width:52px;height:2px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--gold-2),transparent);
}
.section-head.center::before{left:50%;transform:translateX(-50%);}

body.effects-ready .reveal-item{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .8s var(--ease-lux),transform .8s var(--ease-lux);
  transition-delay:var(--reveal-delay,0ms);
}
body.effects-ready .reveal-item.is-visible{
  opacity:1;
  transform:translateY(0);
}

/* Footer correction and premium treatment */
.footer{
  position:relative;
  overflow:hidden;
  padding:2.2rem 0 max(6.4rem,calc(5.2rem + env(safe-area-inset-bottom)));
  background:
    radial-gradient(circle at 10% 0%,rgba(228,188,104,.22),transparent 24rem),
    radial-gradient(circle at 92% 88%,rgba(197,141,53,.14),transparent 28rem),
    linear-gradient(180deg,#fff8ed 0%,#fff4e4 100%);
}
.footer::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(115deg,transparent 0 56%,rgba(255,255,255,.38) 56.15%,transparent 56.9%),
    radial-gradient(circle at 22% 42%,rgba(255,255,255,.36),transparent 15rem);
  pointer-events:none;
}
.footer .container,.footer-grid,.copyright{position:relative;z-index:1;}
.footer-grid{
  align-items:start;
  gap:1.35rem;
}
.footer-grid > div{min-width:0;}
.footer .logo-lockup{
  width:max-content;
  max-width:100%;
  gap:.7rem;
  padding:.48rem .72rem .48rem .48rem;
  border:1px solid rgba(185,132,53,.22);
  border-radius:999px;
  background:rgba(255,255,255,.54);
  box-shadow:0 12px 34px rgba(61,31,17,.06);
}
.footer .logo-lockup .brand-mark{
  width:38px;
  height:38px;
  flex:0 0 38px;
}
.footer .logo-lockup strong{
  font-size:.82rem;
  letter-spacing:.09em;
  white-space:nowrap;
}
.footer .logo-lockup > span > span{
  font-size:.52rem;
  letter-spacing:.18em;
  white-space:nowrap;
}
.footer p{max-width:34rem;}
.footer h3{
  color:var(--brown);
  font-size:1rem;
  letter-spacing:.04em;
}
.footer-map{
  min-height:180px;
  box-shadow:var(--ring-gold);
}
.footer-map iframe{
  height:190px;
  filter:saturate(.88) sepia(.08) contrast(.98);
}
.socials a{
  transition:transform .35s var(--ease-lux),background .35s var(--ease-lux),color .35s var(--ease-lux),box-shadow .35s var(--ease-lux);
}
.socials a:hover{
  transform:translateY(-3px);
  background:linear-gradient(135deg,var(--gold-2),#bd7e27);
  color:#fff;
  box-shadow:0 12px 28px rgba(197,141,53,.25);
}

@media (max-width:520px){
  .container{width:min(100% - 28px,1180px);}
  .logo-lockup{gap:.58rem;}
  .logo-lockup .brand-mark{width:38px;height:38px;}
  .logo-lockup strong{font-size:.78rem;letter-spacing:.07em;}
  .logo-lockup > span > span{font-size:.49rem;letter-spacing:.16em;}
  .footer .logo-lockup{
    padding:.42rem .62rem .42rem .42rem;
    gap:.55rem;
  }
  .footer .logo-lockup .brand-mark{
    width:32px;
    height:32px;
    flex-basis:32px;
  }
  .footer .logo-lockup strong{font-size:.72rem;}
  .footer .logo-lockup > span > span{font-size:.46rem;letter-spacing:.13em;}
  .footer p,.footer li{font-size:.93rem;}
  .footer-map iframe{height:170px;}
  .btn{width:100%;}
  .hero-actions .btn,.actions .btn{width:auto;flex:1 1 auto;}
}

@media (min-width:720px){
  .footer{padding-bottom:2.6rem;}
  .footer-grid{
    grid-template-columns:1.18fr .82fr 1fr;
    grid-template-areas:
      "brand contact location"
      "map map map";
  }
  .footer-grid > div:nth-child(1){grid-area:brand;}
  .footer-grid > div:nth-child(2){grid-area:contact;}
  .footer-grid > div:nth-child(3){grid-area:location;}
  .footer-map{grid-area:map;}
  .footer-map iframe{height:220px;}
}

@media (min-width:1040px){
  .footer-grid{
    grid-template-columns:minmax(260px,1.15fr) minmax(170px,.78fr) minmax(250px,1fr) minmax(300px,1.08fr);
    grid-template-areas:"brand contact location map";
    gap:2rem;
  }
  .footer-map{height:100%;min-height:230px;}
  .footer-map iframe{height:100%;min-height:230px;}
}


/* Grouped image lightbox */
[data-lightbox-group] img:not(.brand-mark):not(.hero-logo){
  cursor:zoom-in;
}
.js-lightbox-img{
  transition:transform .45s var(--ease-lux), filter .45s var(--ease-lux), box-shadow .45s var(--ease-lux);
}
.js-lightbox-img:hover{
  filter:saturate(1.04) contrast(1.02);
}
.lightbox{
  position:fixed;
  inset:0;
  z-index:999;
  display:grid;
  place-items:center;
  padding:clamp(1rem,3vw,2.2rem);
  background:rgba(13,10,8,.86);
  backdrop-filter:blur(10px);
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease;
}
.lightbox.is-open{
  opacity:1;
  pointer-events:auto;
}
.lightbox__dialog{
  position:relative;
  width:min(1180px,100%);
  max-height:92vh;
  display:grid;
  gap:.75rem;
  transform:translateY(10px) scale(.99);
  transition:transform .35s var(--ease-lux);
}
.lightbox.is-open .lightbox__dialog{transform:translateY(0) scale(1);}
.lightbox__stage{
  position:relative;
  display:grid;
  place-items:center;
  overflow:visible;
  min-height:220px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
}
.lightbox__stage::before{display:none;}
.lightbox__image{
  max-width:100%;
  max-height:min(82vh,840px);
  width:auto;
  height:auto;
  object-fit:contain;
  border-radius:18px;
  box-shadow:0 22px 70px rgba(0,0,0,.34);
}
.lightbox__caption{
  justify-self:center;
  max-width:min(780px,100%);
  margin:0;
  padding:.48rem .85rem;
  border:0;
  border-radius:999px;
  background:rgba(255,250,242,.13);
  color:rgba(255,250,242,.88);
  font-size:.9rem;
  text-align:center;
  backdrop-filter:blur(8px);
}
.lightbox__btn{
  position:absolute;
  z-index:2;
  display:grid;
  place-items:center;
  width:46px;
  height:46px;
  border:0;
  border-radius:999px;
  background:rgba(255,250,242,.18);
  color:#fffaf2;
  box-shadow:0 14px 34px rgba(0,0,0,.22);
  backdrop-filter:blur(12px);
  transition:transform .24s ease, background .24s ease;
}
.lightbox__btn:hover{
  transform:translateY(-2px);
  background:rgba(255,250,242,.28);
}
.lightbox__btn svg{width:22px;height:22px;stroke-width:1.8;}
.lightbox__close{top:.4rem;right:.4rem;}
.lightbox__prev,.lightbox__next{top:50%;transform:translateY(-50%);}
.lightbox__prev:hover,.lightbox__next:hover{transform:translateY(calc(-50% - 2px));}
.lightbox__prev{left:.4rem;}
.lightbox__next{right:.4rem;}
body.lightbox-open{overflow:hidden;}
@media (max-width:720px){
  .lightbox{padding:.75rem;}
  .lightbox__image{border-radius:14px;max-height:76vh;}
  .lightbox__btn{width:42px;height:42px;}
  .lightbox__close{top:.45rem;right:.45rem;}
  .lightbox__prev{left:.45rem;}
  .lightbox__next{right:.45rem;}
  .lightbox__caption{border-radius:18px;font-size:.82rem;line-height:1.45;}
}

@media (prefers-reduced-motion: reduce){
  .scroll-progress{display:none;}
  body.effects-ready .reveal-item{opacity:1!important;transform:none!important;transition:none!important;}
  .hero-visual img{transform:none!important;}
}

/* Final premium carousel, footer and language polish */
html, body{overflow-x:hidden;}

.premium-carousel{
  position:relative;
  margin-top:1.45rem;
  isolation:isolate;
}
.carousel-viewport{
  overflow:hidden;
  border-radius:calc(var(--radius) + 2px);
}
.carousel-track{
  display:flex!important;
  gap:1rem;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  overscroll-behavior-inline:contain;
  padding:.25rem .15rem 1.15rem;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.carousel-track::-webkit-scrollbar{display:none;}
.carousel-track > *{
  flex:0 0 min(86%, 340px);
  scroll-snap-align:start;
  scroll-snap-stop:always;
}
.service-carousel .carousel-track > *{flex-basis:min(82%, 330px);}
.gallery-carousel .carousel-track > *{flex:0 0 100%;}
.highlight-carousel .carousel-track > *{flex-basis:min(92%, 780px);}
.testimonial-carousel .carousel-track > *{flex-basis:min(86%, 360px);}

.carousel-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:9;
  width:44px;
  height:44px;
  border:1px solid rgba(197,141,53,.28);
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.9);
  color:var(--brown);
  box-shadow:0 16px 36px rgba(61,31,17,.12);
  font-size:2rem;
  line-height:1;
  transition:transform .3s var(--ease-lux), background .3s var(--ease-lux), color .3s var(--ease-lux), opacity .3s ease;
}
.carousel-btn:hover{background:linear-gradient(135deg,var(--gold-2),#bd7e27);color:#fff;transform:translateY(-50%) scale(1.04);}
.carousel-prev{left:-.65rem;}
.carousel-next{right:-.65rem;}
.premium-carousel.is-single .carousel-btn{opacity:.28;pointer-events:none;}
.carousel-dots{display:flex;justify-content:center;gap:.45rem;margin-top:.6rem;position:relative;z-index:7;pointer-events:none;}
.carousel-dots button{pointer-events:auto;}
.carousel-dots button{
  width:8px;height:8px;padding:0;border:0;border-radius:999px;
  background:rgba(92,46,25,.32);
  box-shadow:0 0 0 1px rgba(255,255,255,.85);
  transition:width .28s var(--ease-lux), background .28s ease;
}
.carousel-dots button.is-active{width:26px;background:linear-gradient(90deg,var(--gold-2),var(--gold));}

.service-carousel .service-card{height:auto;}
.gallery-carousel{margin-top:0;align-self:stretch;padding-bottom:2.75rem;}
.gallery-carousel .carousel-viewport,.gallery-carousel .carousel-track,.gallery-carousel .about-gallery{height:100%;}
.gallery-carousel .carousel-dots{
  position:absolute;
  left:50%;
  bottom:.65rem;
  transform:translateX(-50%);
  margin-top:0;
  min-height:auto;
  padding:.38rem .58rem;
  border:1px solid rgba(197,141,53,.18);
  border-radius:999px;
  background:rgba(255,253,248,.88);
  box-shadow:0 12px 34px rgba(61,31,17,.10);
  backdrop-filter:blur(12px);
}
.gallery-carousel .about-gallery img{
  width:100%;
  min-height:340px;
  height:100%;
  object-fit:cover;
  border-radius:22px;
}
.highlight-carousel .highlight-card{height:auto;}
.testimonial-section{
  background:linear-gradient(180deg,rgba(255,255,255,.2),rgba(255,248,237,.68));
}
.testimonial-card{
  padding:1.45rem;
  min-height:260px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.testimonial-card p{
  margin:.85rem 0 1.2rem;
  color:rgba(50,24,15,.74);
  line-height:1.85;
  font-size:1rem;
}
.stars{
  color:var(--gold);
  letter-spacing:.18em;
  font-size:1.05rem;
}

.footer .logo-lockup{
  width:min(100%, 286px);
  max-width:100%;
}
.footer .logo-lockup > span{overflow:hidden;}
.footer .logo-lockup strong,.footer .logo-lockup > span > span{
  overflow:hidden;
  text-overflow:ellipsis;
}

@media (max-width:520px){
  .footer{overflow:hidden;}
  .footer .logo-lockup{
    width:min(100%, 238px);
    max-width:calc(100vw - 52px);
    padding:.38rem .52rem .38rem .38rem;
    gap:.46rem;
  }
  .footer .logo-lockup .brand-mark{width:28px;height:28px;flex:0 0 28px;}
  .footer .logo-lockup strong{font-size:.62rem;letter-spacing:.045em;white-space:nowrap;}
  .footer .logo-lockup > span > span{font-size:.39rem;letter-spacing:.08em;white-space:nowrap;}
  .footer-grid{gap:1.15rem;}
  .footer p{max-width:100%;}
  .hero-tags{max-width:none;}
  .hero-tags li{border-radius:20px;justify-content:flex-start;padding:.72rem .9rem;}
  .carousel-viewport{border-radius:24px;overflow:visible;}
  .carousel-track{padding-inline:0;}
  .carousel-btn{width:38px;height:38px;font-size:1.55rem;top:auto;bottom:-.25rem;transform:none;}
  .carousel-btn:hover{transform:scale(1.04);}
  .carousel-prev{left:.2rem;}
  .carousel-next{right:.2rem;}
  .carousel-dots{padding:0 3.2rem;min-height:38px;align-items:center;}
  .gallery-carousel{padding-bottom:3rem;}
  .gallery-carousel .carousel-dots{padding:.38rem .58rem;min-height:auto;bottom:.58rem;}
  .gallery-carousel .about-gallery img{min-height:280px;}
  .testimonial-card{min-height:300px;}
  .service-carousel .carousel-track > *, .testimonial-carousel .carousel-track > *{flex-basis:86%;}
}

@media (min-width:720px){
  .service-carousel .carousel-track > *{flex-basis:calc((100% - 1rem)/2);}
  .testimonial-carousel .carousel-track > *{flex-basis:calc((100% - 1rem)/2);}
  .gallery-carousel .carousel-track > *{flex-basis:100%;}
}

@media (min-width:1040px){
  .service-carousel .carousel-track > *{flex-basis:calc((100% - 3rem)/4);}
  .testimonial-carousel .carousel-track > *{flex-basis:calc((100% - 3rem)/4);}
  .highlight-carousel .carousel-track > *{flex-basis:min(70%, 820px);}
  .gallery-carousel .carousel-track > *{flex-basis:100%;}
}

/* Client Feedback refinement: one testimonial visible at a time */
.testimonial-section .section-head{
  align-items:end;
}
.testimonial-carousel{
  margin:1.65rem auto 0;
}
.testimonial-carousel .carousel-viewport{
  overflow:hidden!important;
  border-radius:30px;
}
.testimonial-carousel .carousel-track{
  gap:0!important;
  padding:.25rem 0 1.05rem;
}
.testimonial-carousel .carousel-track > *{
  flex:0 0 100%!important;
  max-width:100%;
  scroll-snap-align:start;
}
.testimonial-carousel .carousel-prev{left:-1.35rem;}
.testimonial-carousel .carousel-next{right:-1.35rem;}
.testimonial-card{
  min-height:245px;
  padding:2rem clamp(1.35rem, 4vw, 3rem);
  text-align:center;
  align-items:center;
  justify-content:center;
  gap:.9rem;
  background:
    radial-gradient(circle at 50% -20%, rgba(197,141,53,.16), transparent 46%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,250,241,.88));
}
.testimonial-card::before{
  content:'“';
  display:block;
  height:2.2rem;
  font-family:Georgia, serif;
  font-size:4.6rem;
  line-height:.75;
  color:rgba(197,141,53,.42);
}
.testimonial-card p{
  max-width:620px;
  margin:0;
  font-size:clamp(1rem, 1.65vw, 1.17rem);
  line-height:1.9;
}
.testimonial-carousel .stars{
  order:-1;
}
.testimonial-carousel .carousel-dots{
  margin-top:.2rem;
}
@media (max-width:720px){
  .testimonial-section .section-head{align-items:flex-start;}
  .testimonial-carousel{max-width:100%;}
  .testimonial-carousel .carousel-prev{left:.25rem;}
  .testimonial-carousel .carousel-next{right:.25rem;}
  .testimonial-card{
    min-height:310px;
    padding:1.65rem 1.2rem 2rem;
  }
  .testimonial-card::before{font-size:4rem;height:1.8rem;}
}

/* Melissa Prime Age promotions */
.promotion-strip{
  position:relative;
  padding-top:3.5rem;
  padding-bottom:3.5rem;
  background:
    radial-gradient(circle at 12% 8%,rgba(228,188,104,.20),transparent 26rem),
    linear-gradient(180deg,rgba(255,250,242,.78),rgba(255,255,255,.92));
  border-block:1px solid rgba(185,132,53,.16);
}
.promotion-teaser-grid{display:grid;gap:1rem;}
.promo-teaser-card{
  padding:1.35rem;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  min-height:100%;
}
.promo-teaser-card.featured,
.prime-offer.featured{
  background:
    radial-gradient(circle at 90% 0%,rgba(228,188,104,.26),transparent 18rem),
    linear-gradient(180deg,rgba(255,255,255,.95),rgba(255,247,232,.88));
}
.promo-tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:.35rem .82rem;
  margin-bottom:.8rem;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(135deg,var(--gold-2),#bd7e27 65%,#8e541d);
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.02em;
}
.promo-tag-him{
  color:var(--him-blue-ink);
  background:linear-gradient(135deg,var(--him-blue-2),#c0d5df 52%,var(--him-blue));
  box-shadow:0 10px 24px rgba(73,112,134,.14);
}
.promo-tag-her{
  color:var(--her-pink-ink);
  background:linear-gradient(135deg,#fff0f3,var(--her-pink-2) 52%,var(--her-pink));
  box-shadow:0 10px 24px rgba(157,83,105,.13);
}
.promo-teaser-card h3{font-size:clamp(2rem,8vw,3.35rem);margin:0 0 .65rem;}
.promo-teaser-card p{color:rgba(50,24,15,.66);line-height:1.85;margin:0 0 1rem;}
.promo-price-line{
  width:100%;
  display:grid;
  gap:.2rem;
  padding:1rem;
  margin:auto 0 1rem;
  border:1px solid rgba(185,132,53,.24);
  border-radius:22px;
  background:rgba(255,255,255,.76);
}
.old-price{color:rgba(50,24,15,.46);text-decoration:line-through;font-weight:600;}
.promo-price-line strong{font-size:1.62rem;color:var(--gold-3);line-height:1.1;}
.promo-validity{
  text-align:center;
  margin:1.15rem 0 0;
  color:rgba(50,24,15,.62);
  font-weight:700;
}
.promo-hero .page-hero-media img{object-position:center;}
.promo-hero-actions{margin-top:1.1rem;}
.promo-page-grid{display:grid;gap:1.2rem;}
.prime-offer{
  padding:clamp(1.15rem,3vw,2rem);
  scroll-margin-top:96px;
}
.offer-head{display:grid;gap:1rem;margin-bottom:1.25rem;}
.offer-head h2{font-size:clamp(2.35rem,10vw,4.65rem);margin:0 0 .55rem;}
.offer-head p{color:rgba(50,24,15,.68);line-height:1.9;margin:0;}
.offer-price-card{
  display:grid;
  align-content:center;
  gap:.28rem;
  padding:1.15rem;
  border-radius:24px;
  border:1px solid rgba(185,132,53,.30);
  background:
    linear-gradient(180deg,rgba(255,255,255,.88),rgba(255,248,237,.88));
  box-shadow:0 14px 42px rgba(197,141,53,.11);
}
.offer-price-card > span{color:var(--gold-3);font-weight:800;font-size:.92rem;letter-spacing:.02em;}
.offer-price-card del{color:rgba(50,24,15,.45);font-weight:700;}
.offer-price-card strong{font-size:clamp(1.8rem,7vw,2.65rem);line-height:1.05;color:var(--brown);}
.prime-offer > h3{margin:0 0 1rem;color:var(--brown);font-size:1.1rem;}
.benefit-list{display:grid;gap:.72rem;}
.benefit-item{
  display:grid;
  grid-template-columns:42px 1fr;
  gap:.85rem;
  padding:.95rem;
  border:1px solid rgba(185,132,53,.20);
  border-radius:22px;
  background:rgba(255,255,255,.70);
}
.benefit-item > span{
  width:42px;height:42px;
  border-radius:999px;
  display:grid;place-items:center;
  color:#fff;
  background:linear-gradient(135deg,var(--gold-2),#bd7e27 65%,#8e541d);
  font-family:"Cormorant Garamond",Georgia,serif;
  font-size:1.38rem;
  font-weight:700;
}
.benefit-item h4{margin:.1rem 0 .28rem;color:var(--ink);font-size:1rem;line-height:1.35;}
.benefit-item p{margin:0;color:rgba(50,24,15,.66);line-height:1.78;}
.offer-closing{
  margin:1.15rem 0 0;
  padding:1rem;
  border-radius:22px;
  border:1px solid rgba(185,132,53,.20);
  background:#fffaf2;
  color:var(--brown);
  font-weight:700;
  line-height:1.75;
}
.promo-bottom-card{
  margin-top:1.2rem;
  padding:1.15rem;
  display:grid;
  gap:1rem;
  align-items:center;
}
.promo-bottom-card strong{display:block;color:var(--brown);font-size:1.08rem;margin-bottom:.25rem;}
.promo-bottom-card p{margin:0;color:rgba(50,24,15,.66);line-height:1.75;}

@media (min-width:720px){
  .promotion-teaser-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .promo-teaser-card{padding:1.65rem;}
  .offer-head{grid-template-columns:1fr minmax(230px,.36fr);align-items:stretch;}
  .promo-bottom-card{grid-template-columns:1fr auto;padding:1.35rem 1.55rem;}
}

@media (min-width:1040px){
  .promotion-strip{padding-top:4.6rem;padding-bottom:4.6rem;}
  .promo-page-grid{gap:1.45rem;}
  .benefit-list{grid-template-columns:repeat(2,minmax(0,1fr));}
  .benefit-item{padding:1rem 1.05rem;}
}

@media (max-width:520px){
  .benefit-item{grid-template-columns:34px 1fr;gap:.7rem;padding:.82rem;}
  .benefit-item > span{width:34px;height:34px;font-size:1.15rem;}
  .promo-bottom-card .btn{width:100%;}
}


@media (min-width:1040px) and (max-width:1120px){
  .nav-links{gap:.82rem;}
  .header-cta{display:none;}
}


/* Longevity testing additions */
.longevity-summary .reason-card{align-items:flex-start;}
.longevity-summary .reason-card h3{letter-spacing:.06em;}
@media (min-width: 980px){
  .longevity-summary{grid-template-columns:repeat(3,1fr);}
}

@media (min-width:1040px) and (max-width:1260px){
  .nav-links{gap:.55rem;}
  .nav-links a{font-size:.84rem;}
  .header-cta{display:none;}
}
@media (min-width:1261px){
  .nav-links{gap:1rem;}
}


/* Melissa Clinic requested small fixes: recognizable social icons, field symbols, and clearer contact CTAs */
.sr-only{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}
.socials .social-link{
  width:40px;
  height:40px;
  border:0;
  color:#fff;
  box-shadow:0 10px 24px rgba(61,31,17,.12);
}
.socials .social-link svg{width:21px;height:21px;display:block;}
.socials .social-facebook,
.socials .social-facebook:hover{background:#1877f2;color:#fff;}
.socials .social-line,
.socials .social-line:hover{background:#06c755;color:#fff;}
.socials .social-instagram,
.socials .social-instagram:hover{
  background:radial-gradient(circle at 30% 105%,#feda75 0 22%,#fa7e1e 36%,#d62976 58%,#962fbf 76%,#4f5bd5 100%);
  color:#fff;
}
.socials .social-link:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 14px 30px rgba(61,31,17,.2);}
.socials .social-facebook .facebook-f-icon{
  width:22px;
  height:22px;
  transform:translateX(.55px);
}

.icon-field{position:relative;display:block;}
.icon-field .input{padding-left:3.1rem;}
.icon-field .field-icon{
  position:absolute;
  left:1rem;
  top:50%;
  transform:translateY(-50%);
  width:22px;
  height:22px;
  display:grid;
  place-items:center;
  color:var(--gold);
  opacity:.85;
  pointer-events:none;
  z-index:2;
}
.icon-field-textarea .field-icon{top:1.18rem;transform:none;}
.icon-field .field-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;}
.mobile-cta a{gap:.36rem;font-weight:700;}
.mobile-cta a svg{width:18px;height:18px;flex:0 0 18px;}
.mobile-cta .mobile-cta-call{color:var(--brown);}
.mobile-cta .mobile-cta-line{color:#06c755;border-color:rgba(6,199,85,.22);}
.mobile-cta .mobile-cta-map{color:#fff;}
.mobile-cta .mobile-cta-line svg{width:20px;height:20px;}
@media (max-width:390px){
  .mobile-cta a{font-size:.76rem;gap:.25rem;}
  .mobile-cta a svg{width:16px;height:16px;}
  .mobile-cta .mobile-cta-line svg{width:18px;height:18px;}
}


/* Peptide directory and legal pages */
.compliance-box{background:linear-gradient(180deg,#fff8ed,#fff);border-color:rgba(197,141,53,.34)}
.compliance-box strong{display:block;color:var(--brown);font-size:1.05rem;margin-bottom:.35rem}
.compliance-box p{margin:.35rem 0 0;color:rgba(50,24,15,.68)}
.peptide-tools{padding:1rem;display:grid;gap:1rem}
.peptide-search{display:grid;gap:.45rem;font-weight:700;color:var(--brown)}
.peptide-filter-row{display:flex;flex-wrap:wrap;gap:.55rem}
.peptide-chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:.62rem .9rem;color:rgba(50,24,15,.72);font-weight:700;box-shadow:0 8px 22px rgba(61,31,17,.045);transition:transform .22s ease,background .22s ease,color .22s ease}
.peptide-chip:hover{transform:translateY(-1px)}
.peptide-chip.is-active{border-color:transparent;color:#fff;background:linear-gradient(135deg,var(--gold-2),#bd7e27 64%,#8e541d)}
.peptide-grid{display:grid;gap:1rem}
.compound-card{padding:1.15rem;display:grid;gap:.75rem;align-content:start}
.compound-card h3{margin:0;font-family:"Noto Serif Thai","Cormorant Garamond",Georgia,serif;font-size:1.35rem;line-height:1.25;color:var(--brown)}
.compound-card p{margin:0;color:rgba(50,24,15,.66);line-height:1.75;font-size:.94rem}
.compound-list{list-style:none;margin:.2rem 0 0;padding:0;display:flex;flex-wrap:wrap;gap:.45rem}
.compound-list li{padding:.42rem .66rem;border:1px solid rgba(185,132,53,.18);border-radius:999px;background:#fffaf2;color:rgba(50,24,15,.78);font-size:.86rem;font-weight:700}
.no-results[hidden]{display:none!important}
.legal-content{padding:1.25rem;max-width:930px}
.legal-content h2{margin:1.4rem 0 .45rem;font-family:"Noto Serif Thai","Cormorant Garamond",Georgia,serif;font-size:1.55rem;color:var(--brown)}
.legal-content h2:first-of-type{margin-top:.5rem}
.legal-content p{color:rgba(50,24,15,.68);line-height:1.9}
.footer-legal-links a{color:var(--gold-3);font-weight:700}
@media (min-width:720px){
  .peptide-tools{padding:1.2rem 1.35rem}
  .peptide-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .legal-content{padding:2rem}
}
@media (min-width:1040px){
  .nav-links{gap:.72rem}
  .nav-links a{font-size:.86rem;padding-inline:.2rem}
  .peptide-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}


.compound-card-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.1rem;padding-top:1rem;border-top:1px solid rgba(135,107,65,.16)}
.btn-small{padding:.7rem 1rem;font-size:.88rem;min-height:auto}
.peptide-reset{justify-self:start;margin-top:.25rem}

.compound-card[hidden]{display:none!important}
.peptide-count{margin:0;color:rgba(50,24,15,.62);font-size:.9rem;font-weight:700}
