:root{
  --cream:#F8F0E8; --blush:#F1DED2; --sand:#EAD9C6;
  --gold:#BE9A5E; --gold-lt:#E5CDA0; --gold-deep:#A2793F;
  --mocha:#7A5A45; --espresso:#43301F; --espresso-2:#352617;
  --muted:#8A7160; --line:rgba(67,48,31,.12);
  --shadow:0 30px 64px -34px rgba(67,48,31,.45);
  --display:"Bodoni Moda",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
  --script:"Pinyon Script",cursive;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--cream);color:var(--espresso);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}
.wrap{width:min(1180px,92vw);margin-inline:auto}
.eyebrow{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;font-weight:600;color:var(--gold-deep);display:inline-block}
.display{font-family:var(--display);font-weight:500;line-height:1.04;letter-spacing:-.01em}
.script{font-family:var(--script);font-weight:400}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--gold-deep);outline-offset:3px;border-radius:2px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:18px 0;transition:padding .35s,background .35s,box-shadow .35s}
.nav.scrolled{padding:9px 0;background:rgba(248,240,232,.88);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.nav-inner{width:min(1180px,92vw);margin-inline:auto;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:44px;height:44px;border-radius:50%}
.brand .txt{line-height:1}
.brand .txt b{font-family:var(--display);font-weight:600;font-size:1.12rem;letter-spacing:.06em;display:block}
.brand .txt i{font-family:var(--script);font-size:1.15rem;color:var(--gold-deep);font-style:normal;display:block;margin-top:-2px}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:.92rem;font-weight:500;opacity:.78;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.btn{font-family:var(--body);font-size:.9rem;font-weight:600;cursor:pointer;border:none;padding:13px 24px;border-radius:999px;transition:transform .2s,box-shadow .2s,background .2s,color .2s;display:inline-flex;align-items:center;gap:9px}
.btn-primary{background:var(--espresso);color:var(--cream)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(67,48,31,.7)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{transform:translateY(-2px);background:var(--gold-deep);box-shadow:0 14px 30px -14px rgba(162,121,63,.7)}
.btn-ghost{background:transparent;color:var(--espresso);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--espresso);color:var(--cream)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px}
.nav-toggle span{width:24px;height:2px;background:var(--espresso);display:block}

/* HERO */
.hero{position:relative;padding:160px 0 84px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.9rem,6.4vw,5rem);margin:16px 0 22px}
.hero h1 em{font-style:italic;color:var(--gold-deep)}
.hero p.lead{font-size:1.12rem;color:var(--mocha);max-width:31em;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.pillars{display:flex;gap:14px;margin-top:42px;flex-wrap:wrap}
.pillars div{display:flex;align-items:center;gap:9px;font-size:.9rem;font-weight:500;color:var(--mocha)}
.pillars .d{width:7px;height:7px;border-radius:50%;background:var(--gold);flex:none}
.hero-visual{position:relative;aspect-ratio:4/5;border-radius:220px 220px 28px 28px;overflow:hidden;background:linear-gradient(160deg,var(--blush),var(--sand));box-shadow:var(--shadow);display:grid;place-items:center}
.hero-visual::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 30% 16%,rgba(229,205,160,.9),transparent 55%),radial-gradient(90% 80% at 80% 92%,rgba(190,154,94,.4),transparent 60%);mix-blend-mode:screen;animation:drift 13s ease-in-out infinite alternate}
.hero-logo{width:62%;position:relative;z-index:1;filter:drop-shadow(0 18px 30px rgba(67,48,31,.25))}
.hero-visual .tag{position:absolute;left:18px;bottom:18px;background:rgba(248,240,232,.92);backdrop-filter:blur(6px);padding:10px 16px;border-radius:14px;font-size:.82rem;font-weight:600;display:flex;align-items:center;gap:8px;z-index:2}
.hero-visual .tag .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(190,154,94,.25)}
.glow-orb{position:absolute;border-radius:50%;filter:blur(64px);z-index:-1}
.glow-1{width:440px;height:440px;background:var(--gold-lt);opacity:.6;top:-90px;right:-120px;animation:drift 17s ease-in-out infinite alternate}
.glow-2{width:380px;height:380px;background:#EAD2C2;opacity:.7;bottom:-150px;left:-110px;animation:drift 21s ease-in-out infinite alternate-reverse}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(24px,-18px) scale(1.08)}}

/* MARQUEE */
.marquee{border-block:1px solid var(--line);padding:16px 0;overflow:hidden;white-space:nowrap;background:var(--blush)}
.marquee-track{display:inline-flex;gap:50px;animation:scroll 30s linear infinite;font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--mocha)}
.marquee-track span{opacity:.75}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
.section{padding:94px 0}
.section-head{max-width:38em;margin-bottom:52px}
.section-head h2{font-size:clamp(2rem,4.2vw,3.1rem);margin:14px 0 16px}
.section-head h2 em{font-style:italic;color:var(--gold-deep)}
.section-head p{color:var(--mocha);font-size:1.05rem}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px 28px;transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.svc::after{content:"";position:absolute;inset:auto -40px -40px auto;width:150px;height:150px;border-radius:50%;background:radial-gradient(circle,var(--gold-lt),transparent 70%);opacity:0;transition:opacity .35s}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.svc:hover::after{opacity:.85}
.svc .ic{width:50px;height:50px;border-radius:14px;background:var(--blush);display:grid;place-items:center;margin-bottom:18px;position:relative;z-index:1}
.svc .ic svg{width:25px;height:25px;stroke:var(--gold-deep);fill:none;stroke-width:1.6}
.svc h3{font-family:var(--display);font-size:1.32rem;font-weight:500;margin-bottom:8px;position:relative;z-index:1}
.svc p{font-size:.95rem;color:var(--mocha);position:relative;z-index:1}

.about{background:var(--espresso);color:var(--cream);position:relative;overflow:hidden}
.about .glow-orb{opacity:.32}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.about .eyebrow{color:var(--gold-lt)}
.about h2{font-family:var(--display);font-size:clamp(2rem,4vw,3rem);font-weight:500;margin:14px 0 22px;line-height:1.08}
.about h2 em{font-style:italic;color:var(--gold-lt)}
.about p{color:rgba(248,240,232,.8);margin-bottom:18px;max-width:34em}
.about .sign{font-family:var(--script);font-size:2.2rem;color:var(--gold-lt);margin-top:6px;line-height:1}
.about-photo{aspect-ratio:3/4;border-radius:24px;background:linear-gradient(150deg,var(--mocha),var(--gold-deep));position:relative;overflow:hidden;box-shadow:var(--shadow);display:grid;place-items:center}
.about-photo::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 70% 18%,rgba(229,205,160,.6),transparent 60%);mix-blend-mode:screen}
.about-logo{width:62%;position:relative;z-index:1;filter:drop-shadow(0 16px 26px rgba(0,0,0,.3))}
.about-badge{position:absolute;left:18px;right:18px;bottom:18px;background:rgba(53,38,23,.6);backdrop-filter:blur(8px);border:1px solid rgba(229,205,160,.28);border-radius:16px;padding:13px 18px;z-index:2}
.about-badge b{font-family:var(--display);font-size:1.05rem}
.about-badge small{display:block;font-size:.76rem;color:var(--gold-lt);letter-spacing:.04em}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.step{position:relative;padding-top:28px;border-top:2px solid var(--espresso)}
.step .num{font-family:var(--display);font-size:.95rem;font-weight:600;color:var(--gold-deep);letter-spacing:.1em}
.step h3{font-family:var(--display);font-size:1.4rem;font-weight:500;margin:14px 0 10px}
.step p{color:var(--mocha);font-size:.96rem}

.testi{background:var(--blush)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.quote{background:var(--cream);border-radius:20px;padding:30px 28px;border:1px solid var(--line)}
.quote .stars{color:var(--gold);font-size:1rem;letter-spacing:2px;margin-bottom:14px}
.quote p{font-family:var(--display);font-size:1.1rem;line-height:1.45;font-style:italic;margin-bottom:18px}
.quote .who{display:flex;align-items:center;gap:12px}
.quote .who .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--mocha));display:grid;place-items:center;color:#fff;font-weight:700;font-family:var(--display)}
.quote .who b{font-size:.95rem;display:block}
.quote .who small{color:var(--muted);font-size:.82rem}

/* BOOKING / CONTACT */
.contact{background:var(--espresso-2);color:var(--cream);position:relative;overflow:hidden}
.contact .glow-orb{opacity:.4}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact .eyebrow{color:var(--gold-lt)}
.contact h2{font-family:var(--display);font-size:clamp(2.1rem,4.4vw,3.3rem);font-weight:500;margin:14px 0 18px;line-height:1.06}
.contact h2 em{font-style:italic;color:var(--gold-lt)}
.contact .lead{color:rgba(248,240,232,.8);margin-bottom:30px;max-width:30em}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:14px}
.contact-list li{display:flex;align-items:center;gap:14px;font-size:1rem}
.contact-list .ic{width:42px;height:42px;border-radius:12px;background:rgba(229,205,160,.14);display:grid;place-items:center;flex:none}
.contact-list .ic svg{width:20px;height:20px;stroke:var(--gold-lt);fill:none;stroke-width:1.7}
.contact-list a:hover{color:var(--gold-lt)}

.form{background:rgba(248,240,232,.06);border:1px solid rgba(229,205,160,.22);border-radius:24px;padding:32px}
.form label{display:block;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:7px;color:var(--gold-lt)}
.field{margin-bottom:18px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form input,.form textarea,.form select{width:100%;background:rgba(248,240,232,.09);border:1px solid rgba(229,205,160,.28);color:var(--cream);padding:13px 15px;border-radius:12px;font-family:var(--body);font-size:.96rem}
.form input::placeholder,.form textarea::placeholder{color:rgba(248,240,232,.42)}
.form textarea{resize:vertical;min-height:90px}
.form select option{color:#222}
.form .btn-gold{background:var(--gold-lt);color:var(--espresso);width:100%;justify-content:center;margin-top:6px}
.form .btn-gold:hover{background:#fff}
.form .mini{font-size:.78rem;color:rgba(248,240,232,.55);margin-top:12px;text-align:center}
.vmsg{color:#FFD2C2;font-size:.82rem;display:block;margin-top:5px}
.alert{padding:14px 18px;border-radius:14px;margin-bottom:18px;font-size:.92rem}
.alert-error{background:rgba(255,120,90,.16);border:1px solid rgba(255,150,120,.5);color:#FFD9CC}

.success{background:rgba(229,205,160,.12);border:1px solid rgba(229,205,160,.4);border-radius:24px;padding:40px 34px;text-align:center}
.success .check{width:64px;height:64px;border-radius:50%;background:var(--gold-lt);display:grid;place-items:center;margin:0 auto 18px}
.success .check svg{width:32px;height:32px;stroke:var(--espresso);fill:none;stroke-width:2.4}
.success h3{font-family:var(--display);font-size:1.7rem;font-weight:500;margin-bottom:10px}
.success p{color:rgba(248,240,232,.82);margin-bottom:8px}
.success .ref{font-family:var(--display);color:var(--gold-lt);font-size:1.1rem;margin-top:10px}

.footer{background:var(--espresso);color:rgba(248,240,232,.62);padding:46px 0;text-align:center}
.footer .brand{justify-content:center;color:var(--cream);margin-bottom:6px}
.footer .socials{display:flex;gap:16px;justify-content:center;margin:18px 0}
.footer .socials a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(229,205,160,.32);display:grid;place-items:center;transition:background .2s,color .2s}
.footer .socials a:hover{background:var(--gold-lt);color:var(--espresso)}
.footer .socials svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7}
.footer small{font-size:.82rem}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

.fab{position:fixed;right:20px;bottom:20px;z-index:60;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#FEDA77,#DD2A7B,#8134AF);display:grid;place-items:center;box-shadow:0 12px 28px -8px rgba(129,52,175,.7);transition:transform .2s}
.fab:hover{transform:scale(1.08)}
.fab svg{width:28px;height:28px;stroke:#fff;fill:none;stroke-width:1.9}

@media (max-width:920px){
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
  .hero-visual{order:-1;max-width:420px;margin-inline:auto}
  .svc-grid,.testi-grid,.steps{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .nav-links{position:fixed;inset:0 0 auto 0;top:0;background:var(--cream);flex-direction:column;padding:90px 8vw 30px;gap:22px;transform:translateY(-110%);transition:transform .35s;box-shadow:var(--shadow)}
  .nav-links.open{transform:none}
  .nav-toggle{display:flex}
  .nav .nav-cta{display:none}
  .svc-grid,.testi-grid,.steps,.row2{grid-template-columns:1fr}
  .hero{padding-top:120px}
  .section{padding:64px 0}
}
