:root{
  --bg:#f6f3ee;
  --surface:#fffdf9;
  --ink:#1c1c1c;
  --graphite:#2b2b2b;
  --muted:#7a736b;
  --beige:#e7dccd;
  --beige-strong:#d2c2a8;
  --wood:#b89373;
  --line:rgba(28,28,28,0.1);
  --radius:22px;
  --radius-lg:32px;
  --container:1240px;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;line-height:1.55;font-weight:400}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--container);margin:0 auto;padding:0 28px}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:saturate(140%) blur(14px);
  background:rgba(246,243,238,0.72);
  border-bottom:1px solid transparent;transition:.3s}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(246,243,238,0.92)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{font-family:var(--serif);font-size:24px;font-weight:600;letter-spacing:.3px}
.nav-links{display:flex;gap:34px}
.nav-links a{font-size:14px;color:var(--graphite);transition:opacity .2s}
.nav-links a:hover{opacity:.6}
.nav-cta{font-size:14px;padding:11px 20px;border-radius:999px;
  background:var(--ink);color:var(--surface);transition:.2s}
.nav-cta:hover{background:var(--graphite);transform:translateY(-1px)}
@media(max-width:840px){.nav-links{display:none}}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;
  padding:140px 0 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(246,243,238,0.55) 0%,rgba(246,243,238,0.2) 40%,rgba(246,243,238,0.85) 100%),
  url('images/hero.jpg') center/cover no-repeat;z-index:0}
.hero-inner{position:relative;z-index:1;max-width:880px}
.eyebrow{font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);margin:0 0 22px;font-weight:500}
.hero-title{font-family:var(--serif);font-weight:500;
  font-size:clamp(44px,7vw,96px);line-height:1.02;letter-spacing:-.015em;
  margin:0 0 28px;color:var(--ink)}
.hero-title em{font-style:italic;color:var(--wood)}
.hero-sub{font-size:clamp(16px,1.4vw,20px);max-width:560px;
  color:var(--graphite);margin:0 0 40px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;
  padding:16px 30px;border-radius:999px;font-size:15px;font-weight:500;
  transition:transform .2s ease, background .2s ease, color .2s ease;
  cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--ink);color:var(--surface)}
.btn-primary:hover{background:var(--graphite);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--surface);transform:translateY(-2px)}

/* SECTIONS */
.section{padding:130px 0}
.section-head{margin-bottom:60px;max-width:680px}
.section-title{font-family:var(--serif);font-weight:500;
  font-size:clamp(32px,4.4vw,56px);line-height:1.08;letter-spacing:-.01em;
  margin:8px 0 0;color:var(--ink)}
.lead{font-size:17px;color:var(--graphite);max-width:560px;margin:0 0 18px}
.lead.muted{color:var(--muted)}
.muted{color:var(--muted)}
.small{font-size:13px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:end}
@media(max-width:820px){.two-col{grid-template-columns:1fr;gap:36px}}

/* ADVANTAGES */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:980px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards{grid-template-columns:1fr}}
.card{background:var(--surface);border-radius:var(--radius-lg);
  padding:38px 32px;border:1px solid var(--line);
  transition:transform .4s ease, box-shadow .4s ease}
.card:hover{transform:translateY(-4px);
  box-shadow:0 20px 50px -30px rgba(28,28,28,.25)}
.card-icon{font-family:var(--serif);font-size:28px;color:var(--wood);
  margin-bottom:30px;font-weight:500}
.card h3{font-family:var(--serif);font-weight:500;font-size:24px;
  margin:0 0 10px;letter-spacing:-.005em}
.card p{margin:0;color:var(--muted);font-size:15px;line-height:1.55}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:280px;gap:18px}
.g-item{position:relative;margin:0;border-radius:var(--radius-lg);
  overflow:hidden;background:var(--beige)}
.g-item img{width:100%;height:100%;object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.g-item:hover img{transform:scale(1.05)}
.g-item figcaption{position:absolute;bottom:22px;left:24px;
  background:rgba(255,253,249,0.92);backdrop-filter:blur(6px);
  padding:8px 16px;border-radius:999px;font-size:13px;
  font-weight:500;color:var(--ink)}
.g-large{grid-column:span 2;grid-row:span 2}
.g-wide{grid-column:span 2}
@media(max-width:900px){.gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:240px}
  .g-large{grid-column:span 2;grid-row:span 1}.g-wide{grid-column:span 2}}
@media(max-width:520px){.gallery{grid-template-columns:1fr;grid-auto-rows:260px}
  .g-large,.g-wide{grid-column:span 1}}

/* PROCESS */
.process{background:var(--beige);border-radius:var(--radius-lg);
  margin:0 28px;padding:120px 0}
.process .container{max-width:1180px}
.timeline{list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
  counter-reset:steps}
@media(max-width:900px){.timeline{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.timeline{grid-template-columns:1fr}}
.timeline li{padding:32px 26px;background:var(--surface);
  border-radius:var(--radius);position:relative}
.t-num{font-family:var(--serif);font-size:18px;color:var(--wood);
  display:block;margin-bottom:24px}
.timeline h3{font-family:var(--serif);font-weight:500;font-size:22px;
  margin:0 0 8px}
.timeline p{margin:0;color:var(--muted);font-size:14px}

/* CONTACT */
.contact{padding-top:80px}
.contact-card{background:var(--ink);color:var(--surface);
  border-radius:var(--radius-lg);padding:90px 70px;text-align:center}
.contact-card .section-title{color:var(--surface);margin-bottom:14px}
.contact-card .eyebrow{color:var(--beige-strong)}
.contact-card .lead{color:rgba(255,253,249,.7);margin:0 auto 44px;max-width:480px}
.contact-card .cta-row{justify-content:center;margin-top:44px}
.contact-card .btn-ghost{color:var(--surface);border-color:rgba(255,253,249,.3)}
.contact-card .btn-ghost:hover{background:var(--surface);color:var(--ink);border-color:var(--surface)}
.contact-card .btn-primary{background:var(--surface);color:var(--ink)}
.contact-card .btn-primary:hover{background:var(--beige)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:640px;margin:0 auto}
@media(max-width:600px){.contact-grid{grid-template-columns:1fr}
  .contact-card{padding:60px 28px}}
.contact-item{display:flex;flex-direction:column;gap:8px;
  padding:28px;border-radius:var(--radius);
  background:rgba(255,253,249,.06);border:1px solid rgba(255,253,249,.12);
  transition:.2s}
.contact-item:hover{background:rgba(255,253,249,.1);transform:translateY(-2px)}
.c-label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--beige-strong)}
.c-value{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--surface)}

/* FOOTER */
.footer{padding:60px 0 50px;border-top:1px solid var(--line)}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;align-items:start}
@media(max-width:700px){.footer-inner{grid-template-columns:1fr;gap:20px}}
.footer-col p{margin:4px 0}
.footer-col a:hover{color:var(--ink);text-decoration:underline}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);
  transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* Privacy page */
.legal{max-width:760px;margin:0 auto;padding:160px 28px 100px}
.legal h1{font-family:var(--serif);font-weight:500;font-size:clamp(36px,5vw,56px);
  margin:0 0 12px;letter-spacing:-.01em}
.legal h2{font-family:var(--serif);font-weight:500;font-size:26px;margin:42px 0 12px}
.legal p,.legal li{color:var(--graphite);font-size:16px;line-height:1.7}
.legal ul{padding-left:20px}
.legal .back{display:inline-block;margin-bottom:30px;color:var(--muted);font-size:14px}
.legal .back:hover{color:var(--ink)}
