:root{
  --white:#ffffff;
  --paper:#fbfbfa;
  --line:rgba(20,20,20,.07);
  --line-soft:rgba(20,20,20,.04);
  --ink:#161616;
  --ink-soft:#5b5b5b;
  --ink-faint:#9a9a9a;
  --accent:#1a1a1a;
  --radius:20px;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Spline Sans',sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:400;letter-spacing:-.01em;line-height:1.08}
em{font-style:italic;color:var(--ink-soft)}

.eyebrow{
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:400;margin-bottom:1.1rem;
}

/* NAV */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1.2rem,5vw,3.5rem);
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line-soft);
}
.brand{display:flex;align-items:center;gap:.6rem;font-family:'Fraunces',serif;font-size:1.15rem}
.nav-links{display:flex;gap:2rem}
.nav-links a{font-size:.9rem;color:var(--ink-soft);transition:color .3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  font-size:.86rem;padding:.55rem 1.2rem;border:1px solid var(--line);
  border-radius:100px;transition:all .35s var(--ease);
}
.nav-cta:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* HERO */
.hero{
  max-width:var(--maxw);margin:0 auto;
  padding:clamp(4rem,10vw,8rem) clamp(1.2rem,5vw,3.5rem) 4rem;
  text-align:center;
}
.hero h1{
  font-size:clamp(2.8rem,8vw,6rem);font-weight:300;margin:.4rem 0 1.6rem;
}
.hero-sub{
  max-width:600px;margin:0 auto 2.4rem;font-size:1.12rem;color:var(--ink-soft);
}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:clamp(3rem,7vw,5rem)}
.hero-image{
  border-radius:var(--radius);overflow:hidden;
  box-shadow:0 30px 90px -50px rgba(0,0,0,.35);
}
.hero-image img{width:100%;aspect-ratio:16/9;object-fit:cover}

/* BUTTONS */
.btn-primary,.btn-ghost,.btn-outline{
  display:inline-block;font-size:.92rem;font-weight:400;
  padding:.85rem 1.7rem;border-radius:100px;cursor:pointer;
  transition:all .35s var(--ease);border:1px solid transparent;font-family:inherit;
}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(0,0,0,.5)}
.btn-ghost{color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--paper)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-primary.full{width:100%;text-align:center}
.sm{padding:.55rem 1.1rem;font-size:.82rem}

/* STATS */
.stats{
  max-width:var(--maxw);margin:0 auto;
  padding:0 clamp(1.2rem,5vw,3.5rem);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;
}
.stats div{background:var(--white);padding:2rem 1.4rem;text-align:center}
.stats strong{display:block;font-family:'Fraunces',serif;font-size:2.1rem;font-weight:400}
.stats span{font-size:.82rem;color:var(--ink-faint)}

/* SECTION HEAD */
section{padding:clamp(4rem,9vw,7rem) clamp(1.2rem,5vw,3.5rem)}
.section-head{max-width:640px;margin:0 auto clamp(2.5rem,5vw,4rem);text-align:center}
.section-head h2{font-size:clamp(1.9rem,4.5vw,3rem);margin-bottom:1rem}
.lede{color:var(--ink-soft);font-size:1.05rem}

/* SERVICES */
.service-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.4rem,3vw,2.4rem);
}
.service-card{
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  background:var(--white);transition:all .4s var(--ease);
}
.service-card:hover{box-shadow:0 30px 70px -45px rgba(0,0,0,.3);transform:translateY(-4px)}
.service-card img{width:100%;aspect-ratio:3/2;object-fit:cover}
.service-card h3{font-size:1.4rem;padding:1.6rem 1.6rem .5rem}
.service-card p{padding:0 1.6rem;color:var(--ink-soft);font-size:.98rem}
.card-link{display:inline-block;padding:1.1rem 1.6rem 1.7rem;font-size:.9rem;color:var(--ink);transition:opacity .3s}
.card-link:hover{opacity:.55}

/* METHOD */
.steps{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
}
.step{background:var(--white);padding:clamp(2rem,4vw,3rem)}
.step-num{font-family:'Fraunces',serif;font-size:1.1rem;color:var(--ink-faint)}
.step h3{font-size:1.35rem;margin:1rem 0 .7rem}
.step p{color:var(--ink-soft);font-size:.96rem}

/* PRICES */
.price-grid{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,1.8rem);
  align-items:stretch;
}
.price-card{
  border:1px solid var(--line);border-radius:var(--radius);
  padding:2.2rem 1.9rem;background:var(--white);display:flex;flex-direction:column;
  transition:all .4s var(--ease);
}
.price-card:hover{box-shadow:0 30px 70px -50px rgba(0,0,0,.3)}
.price-card.featured{border-color:var(--ink);box-shadow:0 30px 80px -50px rgba(0,0,0,.35)}
.price-card .tag{
  align-self:flex-start;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  background:var(--ink);color:#fff;padding:.3rem .7rem;border-radius:100px;margin-bottom:1rem;
}
.price-card h3{font-size:1.5rem;margin-bottom:.5rem}
.price{font-family:'Fraunces',serif;font-size:2.7rem;font-weight:400;line-height:1;margin:.3rem 0 .2rem}
.price span{font-size:1.4rem;vertical-align:super;color:var(--ink-soft)}
.price small{display:block;font-size:.8rem;font-family:'Spline Sans';color:var(--ink-faint);margin-top:.4rem;font-weight:300}
.price-desc{color:var(--ink-soft);font-size:.95rem;margin:.6rem 0 1.4rem}
.price-card ul{list-style:none;margin-bottom:1.8rem;flex:1}
.price-card li{position:relative;padding:.5rem 0 .5rem 1.5rem;font-size:.94rem;color:var(--ink-soft);border-bottom:1px solid var(--line-soft)}
.price-card li::before{content:"";position:absolute;left:0;top:1.05rem;width:7px;height:7px;border:1px solid var(--ink);transform:rotate(45deg)}
.price-note{max-width:var(--maxw);margin:2.5rem auto 0;text-align:center;color:var(--ink-faint);font-size:.92rem}
.price-note a{color:var(--ink);text-decoration:underline;text-underline-offset:3px}

/* QUOTE */
.quote{max-width:820px;margin:0 auto;text-align:center}
.quote blockquote{font-family:'Fraunces',serif;font-size:clamp(1.4rem,3.2vw,2.1rem);font-weight:300;line-height:1.4}
.quote cite{display:block;margin-top:1.5rem;font-family:'Spline Sans';font-size:.92rem;font-style:normal;color:var(--ink-faint)}

/* CONTACT */
.contact{background:var(--paper)}
.contact-inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:start;
}
.contact-info h2{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:1rem}
.contact-list{list-style:none;margin-top:2rem}
.contact-list li{display:flex;flex-direction:column;padding:1rem 0;border-bottom:1px solid var(--line)}
.contact-list strong{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:400;margin-bottom:.3rem}
.contact-list a,.contact-list span{font-size:1.05rem;color:var(--ink)}
.contact-list a:hover{opacity:.6}
.contact-form{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.4rem)}
.field{margin-bottom:1.2rem}
.field label{display:block;font-size:.84rem;color:var(--ink-soft);margin-bottom:.45rem}
.field .opt{color:var(--ink-faint)}
.field input,.field textarea{
  width:100%;border:1px solid var(--line);border-radius:12px;
  padding:.8rem .9rem;font-family:inherit;font-size:.96rem;color:var(--ink);
  background:var(--paper);transition:border .3s var(--ease);resize:vertical;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink);background:#fff}
.consent{display:flex;gap:.65rem;align-items:flex-start;font-size:.86rem;color:var(--ink-soft);margin-bottom:1.4rem}
.consent input{margin-top:.25rem;accent-color:var(--ink)}
.consent a{text-decoration:underline;text-underline-offset:2px}
.form-status{margin-top:1rem;font-size:.9rem;min-height:1.2em}
.form-status.ok{color:#1c7a4a}
.form-status.err{color:#b4392f}

/* FOOTER */
.footer{padding:clamp(3rem,6vw,5rem) clamp(1.2rem,5vw,3.5rem) 2rem;border-top:1px solid var(--line)}
.footer-top{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.2fr 1.4fr;gap:2.5rem}
.footer-brand{display:flex;flex-direction:column;gap:.4rem}
.footer-brand span{font-family:'Fraunces',serif;font-size:1.15rem;display:inline-flex;align-items:center}
.footer-brand svg{vertical-align:middle}
.footer-brand p{color:var(--ink-faint);font-size:.92rem;margin-top:.4rem;max-width:280px}
.footer-cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.footer-cols h4{font-family:'Spline Sans';font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:500;margin-bottom:1rem}
.footer-cols a{display:block;font-size:.92rem;color:var(--ink-soft);padding:.3rem 0;transition:color .3s}
.footer-cols a:hover{color:var(--ink)}
.footer-bottom{max-width:var(--maxw);margin:3rem auto 0;padding-top:1.6rem;border-top:1px solid var(--line-soft);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.8rem;color:var(--ink-faint)}
.cookie-reopen{background:none;border:none;font-family:inherit;font-size:.8rem;color:var(--ink-soft);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.cookie-reopen:hover{color:var(--ink)}

/* COOKIE BANNER */
.cookie-banner{
  position:fixed;left:50%;bottom:1.4rem;transform:translateX(-50%) translateY(160%);
  width:min(680px,calc(100% - 2rem));z-index:80;
  background:rgba(255,255,255,.86);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:0 30px 80px -40px rgba(0,0,0,.4);
  padding:1.4rem 1.6rem;display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;
  transition:transform .55s var(--ease);
}
.cookie-banner.show{transform:translateX(-50%) translateY(0)}
.cookie-text{flex:1;min-width:240px}
.cookie-text strong{font-family:'Fraunces',serif;font-weight:400;font-size:1.05rem}
.cookie-text p{font-size:.86rem;color:var(--ink-soft);margin-top:.3rem}
.cookie-text a{text-decoration:underline;text-underline-offset:2px}
.cookie-actions{display:flex;gap:.7rem}

/* LEGAL PAGES */
.legal{max-width:760px;margin:0 auto;padding:clamp(3rem,7vw,6rem) clamp(1.2rem,5vw,2rem)}
.legal h1{font-size:clamp(2rem,5vw,3rem);margin-bottom:.6rem}
.legal .updated{color:var(--ink-faint);font-size:.86rem;margin-bottom:2.5rem}
.legal h2{font-size:1.4rem;margin:2.4rem 0 .8rem}
.legal p,.legal li{color:var(--ink-soft);font-size:1rem;margin-bottom:.8rem}
.legal ul{padding-left:1.3rem;margin-bottom:1rem}
.legal a{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
.back-link{display:inline-flex;align-items:center;gap:.4rem;margin-top:3rem;font-size:.92rem;color:var(--ink)}
.back-link:hover{opacity:.6}

/* REVEAL */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:860px){
  .nav-links{display:none}
  .service-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr}
  .contact-inner{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
}
@media(max-width:480px){
  .stats{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr}
  .cookie-banner{flex-direction:column;align-items:stretch}
  .cookie-actions{justify-content:stretch}
  .cookie-actions button{flex:1}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
