:root{
  --dawn:#ffe7c7;
  --peach:#ffb88a;
  --sun:#ff7a59;
  --plum:#2b1d3a;
  --ink:#16101f;
  --mist:#fbf5ee;
  --line:rgba(43,29,58,.12);
  --shadow:0 10px 30px -12px rgba(43,29,58,.18);
  --rad:14px;
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,sans-serif;
  font-size:15px;line-height:1.55;color:var(--ink);
  background:var(--mist);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block;border-radius:var(--rad)}
a{color:var(--sun);text-decoration:none}
a:hover{color:var(--plum)}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;color:var(--plum);line-height:1.15;letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,4.6vw,3.1rem)}
h2{font-size:clamp(1.45rem,3vw,2.1rem)}
h3{font-size:1.1rem}
p{margin:.4rem 0}
.container{max-width:var(--maxw);margin:0 auto;padding:0 18px}
.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.65rem 1.1rem;border-radius:999px;border:1px solid var(--plum);
  background:var(--plum);color:var(--mist);font-weight:600;font-size:.85rem;
  cursor:pointer;transition:transform .2s,background .2s,color .2s;
}
.btn:hover{background:var(--sun);border-color:var(--sun);color:#fff;transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--plum)}
.btn.ghost:hover{background:var(--plum);color:var(--mist)}

.site-header{
  position:absolute;top:0;left:0;right:0;z-index:30;
  padding:18px 0;
  transition:transform .35s ease, background .25s ease, box-shadow .25s ease;
}
.site-header.scrolled{position:fixed;background:rgba(251,245,238,.92);backdrop-filter:blur(10px);box-shadow:var(--shadow);padding:10px 0}
.site-header.hide{transform:translateY(-110%)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.55rem;font-family:'Fraunces',serif;font-weight:600;color:var(--plum);font-size:1.05rem}
.brand .mark{
  width:34px;height:34px;border-radius:50%;
  background:radial-gradient(circle at 50% 70%,var(--sun) 0 38%,var(--peach) 39% 70%,var(--dawn) 71% 100%);
  box-shadow:inset 0 -2px 0 rgba(0,0,0,.06);
}
.menu-toggle{
  width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line);background:var(--mist);
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--plum);font-size:1.25rem;
  transition:background .2s,color .2s,transform .2s;
}
.menu-toggle:hover{background:var(--plum);color:var(--mist)}
.menu-toggle .ico-close{display:none}
.menu-toggle.is-open .ico-open{display:none}
.menu-toggle.is-open .ico-close{display:inline-block}

.nav-overlay{
  position:fixed;inset:0;z-index:40;
  background:linear-gradient(135deg,var(--plum) 0%, #4a2e5a 100%);
  color:var(--mist);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .3s ease;
}
.nav-overlay.is-open{opacity:1;pointer-events:auto}
.nav-overlay nav{text-align:center}
.nav-overlay ul{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.nav-overlay a{
  font-family:'Fraunces',serif;color:var(--mist);font-size:clamp(1.4rem,3.8vw,2.4rem);
  font-weight:500;padding:.2rem .6rem;border-radius:8px;
  transition:color .2s,letter-spacing .25s;
  display:inline-block;
}
.nav-overlay a:hover,.nav-overlay a.active{color:var(--peach);letter-spacing:.04em}
.nav-overlay .close-x{
  position:absolute;top:22px;right:22px;
  width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.25);
  background:transparent;color:var(--mist);font-size:1.3rem;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
}
.nav-overlay .close-x:hover{background:rgba(255,255,255,.1)}

.hero{
  position:relative;padding:130px 0 70px;
  background:
    radial-gradient(circle at 85% 15%, rgba(255,184,138,.55), transparent 55%),
    radial-gradient(circle at 10% 90%, rgba(255,122,89,.25), transparent 50%),
    var(--mist);
}
.hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:2rem;align-items:center}
.hero p.lead{font-size:1.05rem;color:#3a2d4d;max-width:46ch;margin:.9rem 0 1.4rem}
.eyebrow{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sun);font-weight:700;
  background:rgba(255,122,89,.1);padding:.35rem .7rem;border-radius:999px;
}
.hero-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.hero-art{position:relative}
.hero-art img{aspect-ratio:4/3;object-fit:cover;border-radius:24px;box-shadow:var(--shadow)}
.hero-art .badge{
  position:absolute;left:-14px;bottom:18px;
  background:var(--mist);border:1px solid var(--line);
  padding:.7rem .9rem;border-radius:14px;display:flex;align-items:center;gap:.55rem;
  box-shadow:var(--shadow);font-size:.85rem;
}
.hero-art .badge i{color:var(--sun);font-size:1.3rem}

section{padding:64px 0}
.section-head{text-align:center;max-width:620px;margin:0 auto 2.2rem}
.section-head p{color:#4a3c5e;margin-top:.4rem}

.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.pillar{
  background:#fff;border:1px solid var(--line);border-radius:var(--rad);
  padding:1.25rem;transition:transform .25s,border-color .25s;
}
.pillar:hover{transform:translateY(-3px);border-color:var(--peach)}
.pillar i{font-size:1.6rem;color:var(--sun);display:block;margin-bottom:.55rem}
.pillar h3{margin-bottom:.3rem}

.split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.split img{aspect-ratio:5/4;object-fit:cover;box-shadow:var(--shadow)}
.split ul{list-style:none;display:grid;gap:.55rem;margin-top:.8rem}
.split li{display:flex;gap:.55rem;align-items:flex-start}
.split li i{color:var(--sun);margin-top:3px}

.timeline{position:relative;display:grid;gap:1rem;max-width:760px;margin:0 auto}
.timeline-row{display:grid;grid-template-columns:60px 1fr;gap:1rem;background:#fff;border:1px solid var(--line);padding:1rem 1.1rem;border-radius:var(--rad)}
.timeline-row .when{font-family:'Fraunces',serif;color:var(--sun);font-weight:600}

.quote-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.quote{
  background:linear-gradient(180deg,#fff,#fdf6ed);
  border:1px solid var(--line);border-radius:var(--rad);
  padding:1.2rem;display:flex;flex-direction:column;gap:.6rem;
}
.quote .who{display:flex;align-items:center;gap:.55rem;margin-top:auto;font-size:.85rem;color:#4a3c5e}
.quote .who .avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--peach),var(--sun));color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-family:'Fraunces',serif;
}
.quote i.qmark{color:var(--peach);font-size:1.3rem}

.faq{max-width:760px;margin:0 auto;display:grid;gap:.6rem}
.faq details{
  background:#fff;border:1px solid var(--line);border-radius:var(--rad);
  padding:.85rem 1rem;
}
.faq summary{cursor:pointer;font-weight:600;color:var(--plum);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.3rem;color:var(--sun)}
.faq details[open] summary::after{content:"–"}
.faq p{margin-top:.5rem;color:#3a2d4d}

.cta-band{
  background:linear-gradient(135deg,var(--plum),#46295c);
  color:var(--mist);border-radius:24px;padding:2.2rem 1.6rem;text-align:center;
}
.cta-band h2{color:var(--mist)}
.cta-band p{opacity:.85;margin:.5rem auto 1.2rem;max-width:50ch}

.products{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.product{
  background:#fff;border:1px solid var(--line);border-radius:var(--rad);
  padding:1.3rem;display:flex;flex-direction:column;gap:.55rem;
  transition:transform .25s,box-shadow .25s;
}
.product:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.product .visual{
  aspect-ratio:4/3;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--dawn),var(--peach));
  color:var(--plum);font-size:2.6rem;
}
.product.v2 .visual{background:linear-gradient(135deg,#cfe7ff,#9fbdf6);color:#1d2c5a}
.product.v3 .visual{background:linear-gradient(135deg,#ffd8c2,#ff9a76);color:#5a1d20}
.product .price{font-family:'Fraunces',serif;font-size:1.4rem;color:var(--sun);font-weight:600}
.product ul{list-style:none;display:grid;gap:.3rem;margin:.4rem 0;font-size:.88rem}
.product li{display:flex;gap:.4rem;align-items:flex-start}
.product li i{color:var(--sun);margin-top:3px}
.product .btn{margin-top:auto}

.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.contact-card{
  background:linear-gradient(160deg,#fff,#fff8ee);
  border:1px solid var(--line);border-radius:20px;padding:1.6rem;
  display:flex;flex-direction:column;gap:1rem;
}
.contact-info{display:grid;gap:.7rem;margin-top:.4rem}
.contact-info a, .contact-info span{display:flex;gap:.6rem;align-items:flex-start;color:var(--ink);font-size:.95rem}
.contact-info i{color:var(--sun);font-size:1.15rem;margin-top:2px}
.contact-form{display:grid;gap:.7rem}
.contact-form label{font-size:.78rem;font-weight:600;color:var(--plum);text-transform:uppercase;letter-spacing:.06em}
.contact-form input,.contact-form textarea{
  width:100%;padding:.7rem .85rem;border:1px solid var(--line);
  border-radius:10px;font:inherit;background:#fff;color:var(--ink);
  transition:border-color .2s,box-shadow .2s;
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--sun);box-shadow:0 0 0 3px rgba(255,122,89,.15)}
.contact-form textarea{min-height:120px;resize:vertical}
.check{display:flex;gap:.55rem;align-items:flex-start;font-size:.82rem;color:#3a2d4d}
.check input{width:auto;margin-top:3px}
.map-frame{border-radius:20px;overflow:hidden;border:1px solid var(--line);min-height:300px;background:#eee}
.map-frame iframe{width:100%;height:100%;min-height:300px;border:0;display:block}

.policy{max-width:820px;margin:0 auto}
.policy h2{margin-top:1.6rem}
.policy h3{margin-top:1.1rem}
.policy p,.policy li{color:#34273f;font-size:.96rem;margin:.45rem 0}
.policy ul{padding-left:1.2rem;display:grid;gap:.25rem}
.policy .updated{color:#6a597a;font-size:.85rem}

.center-stage{
  min-height:calc(100vh - 64px - 60px);
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:90px 18px 40px;
  background:
    radial-gradient(circle at 50% 30%, rgba(255,184,138,.4), transparent 55%),
    var(--mist);
}
.center-stage .inner{max-width:520px}
.center-stage .big{
  font-size:clamp(3.5rem,12vw,6rem);font-family:'Fraunces',serif;
  background:linear-gradient(135deg,var(--sun),var(--plum));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;margin-bottom:.5rem;
}
.center-stage p{color:#3a2d4d;margin:.6rem 0 1.2rem}
.center-stage .actions{display:flex;gap:.55rem;justify-content:center;flex-wrap:wrap}

.site-footer{
  background:var(--plum);color:rgba(251,245,238,.88);
  padding:22px 0;font-size:.82rem;
}
.footer-inner{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:space-between;align-items:center}
.footer-inner nav{display:flex;flex-wrap:wrap;gap:.5rem 1rem}
.footer-inner a{color:rgba(251,245,238,.78)}
.footer-inner a:hover{color:var(--peach)}

.privacy-pop{
  position:fixed;left:14px;right:14px;bottom:14px;z-index:60;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:1rem 1.1rem;box-shadow:var(--shadow);
  display:none;flex-wrap:wrap;gap:.7rem;align-items:center;justify-content:space-between;
}
.privacy-pop.show{display:flex}
.privacy-pop p{font-size:.85rem;margin:0;max-width:60ch}
.privacy-pop .actions{display:flex;gap:.5rem}
.privacy-pop .btn{padding:.5rem .9rem;font-size:.78rem}

@media (max-width:860px){
  .hero{padding:120px 0 50px}
  .hero-grid,.split,.contact-wrap{grid-template-columns:1fr;gap:1.4rem}
  .pillars,.quote-row,.products{grid-template-columns:1fr}
  .hero-art .badge{left:10px}
  section{padding:48px 0}
}
@media (max-width:520px){
  body{font-size:14px}
  .btn{padding:.6rem .95rem}
  .timeline-row{grid-template-columns:50px 1fr}
  .footer-inner{justify-content:center;text-align:center}
  .footer-inner nav{justify-content:center}
}
