/* Ink & Honey v2 — "Sit With Us": warm cream + amber + walnut, booking-forward, DM Serif Display */
:root{
  --cream:#f6ecd9; --cream2:#fbf5e9; --walnut:#3a2412; --ink:#2a1a0c; --mute:#8a6f4e;
  --line:#e3d3b6; --line2:#d8c39e; --honey:#d8932b; --honeyd:#b9741a; --gold:#e8b24c; --leaf:#5a6e3a;
  --serif:"DM Serif Display",Georgia,serif; --sans:"Inter",system-ui,sans-serif; --mono:"Space Mono",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--walnut);font-family:var(--sans);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
img{display:block;max-width:100%}
.wrap{max-width:1120px;margin:0 auto;padding:0 28px}
h1,h2,h3{font-family:var(--serif);font-weight:400;letter-spacing:.005em;margin:0;color:var(--ink)}
em{font-style:italic;color:var(--honeyd)}
.img-fail{background:repeating-linear-gradient(45deg,#efe2c8,#efe2c8 14px,#e6d2af 14px,#e6d2af 28px);min-height:200px}

/* NAV */
.nav{position:sticky;top:0;z-index:40;background:rgba(246,236,217,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-in{max-width:1120px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-size:21px;color:var(--ink);text-decoration:none}
.seal{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;color:var(--honey);font-size:18px}
.nav-links{margin-left:auto;display:flex;gap:24px}
.nav-links a{color:var(--mute);text-decoration:none;font-size:14px;letter-spacing:.02em;transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--honey);color:#fff;padding:9px 17px;border-radius:999px;font-size:13.5px;font-weight:600;text-decoration:none;white-space:nowrap;transition:transform .15s,background .15s}
.nav-cta:hover{transform:translateY(-1px);background:var(--honeyd)}
.burger{display:none;background:none;border:0;width:34px;height:34px;cursor:pointer;margin-left:auto;position:relative}
.burger span,.burger span::before,.burger span::after{content:"";position:absolute;left:6px;width:22px;height:2px;background:var(--ink);transition:.2s}
.burger span{top:16px}.burger span::before{top:-7px}.burger span::after{top:7px}
.drawer{display:none;flex-direction:column;background:var(--cream2);border-bottom:1px solid var(--line)}
.drawer a{padding:14px 28px;color:var(--ink);text-decoration:none;border-top:1px solid var(--line)}

/* HERO — split, booking card up front */
.hero{background:radial-gradient(120% 90% at 18% 8%,#fbf3e2,var(--cream) 60%);padding:64px 0 70px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;right:-60px;top:-60px;width:340px;height:340px;background:
  radial-gradient(circle at 50% 50%,transparent 60%,rgba(216,147,43,.14) 61%);
  -webkit-mask:repeating-conic-gradient(#000 0 0);opacity:.5;pointer-events:none}
.hero-grid{max-width:1120px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;position:relative}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--honeyd);display:flex;align-items:center;gap:10px;margin-bottom:18px}
.eyebrow .hx{color:var(--honey);font-size:14px}
.hero h1{font-size:clamp(40px,6.4vw,72px);line-height:1.04;letter-spacing:-.01em}
.hero-lede{max-width:48ch;color:#5a4326;font-size:17px;margin:22px 0 24px}.hero-lede b{color:var(--walnut)}
.hero-trust{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.hero-trust .t{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 16px;min-width:118px}
.hero-trust .t b{display:block;font-family:var(--serif);font-size:24px;color:var(--honeyd)}
.hero-trust .t span{font-size:12.5px;color:var(--mute)}
.hero-note{font-size:13px;color:var(--mute);max-width:48ch;margin:0}

/* BOOKING CARD */
.book-card{background:#fff;border:1px solid var(--line2);border-radius:18px;padding:30px;box-shadow:0 24px 60px -28px rgba(58,36,18,.4)}
.bc-eyebrow{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--honeyd)}
.bc-h{font-size:30px;margin:6px 0 18px}
.bc-form label{display:block;font-size:13px;font-weight:600;color:var(--walnut);margin-bottom:14px}
.bc-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bc-form input,.bc-form textarea,.bc-form select{width:100%;margin-top:6px;background:var(--cream2);border:1px solid var(--line2);border-radius:9px;padding:11px 13px;color:var(--walnut);font-family:var(--sans);font-size:14px;font-weight:400;resize:vertical}
.bc-form input::placeholder,.bc-form textarea::placeholder{color:#b09a76}
.bc-btn{width:100%;background:var(--honey);color:#fff;border:0;border-radius:999px;padding:14px;font-weight:700;font-size:15px;cursor:pointer;margin-top:4px;transition:background .15s,transform .15s}
.bc-btn:hover{background:var(--honeyd);transform:translateY(-1px)}
.bc-foot{font-size:12.5px;color:var(--mute);margin:14px 0 0}.bc-foot b{color:var(--walnut)}

/* shared sections */
section{padding:84px 0}
.tag{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--honeyd);display:flex;align-items:center;gap:10px;margin-bottom:26px}
.tag .hx{color:var(--honey);font-size:14px}
.tag.light{color:var(--leaf)}.tag.light .hx{color:var(--leaf)}
h2{font-size:clamp(30px,4.6vw,46px);line-height:1.08;max-width:20ch}
.lede{font-size:18px;color:#6a5234;max-width:60ch;margin:16px 0}
.btn{display:inline-block;background:var(--honey);color:#fff;padding:13px 24px;border-radius:999px;font-weight:600;font-size:15px;text-decoration:none;transition:transform .15s,background .15s;border:0}
.btn:hover{transform:translateY(-2px);background:var(--honeyd)}

/* HOW */
.how{background:var(--cream2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:34px}
.step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 22px}
.step .snum{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--honey)}
.step h3{font-size:22px;margin:10px 0 8px}
.step p{font-size:14.5px;color:#6a5234;margin:0}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;border-top:3px solid var(--honey)}
.svc h3{font-size:26px;margin:0 0 10px}
.svc p{font-size:15px;color:#6a5234;margin:0 0 14px}
.svc-meta{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--mute)}
.svc-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.svc-strip figure{margin:0}
.svc-strip img{width:100%;height:220px;object-fit:cover;border-radius:10px}
.svc-strip figcaption{font-family:var(--mono);font-size:11px;color:var(--mute);margin-top:8px}

/* PORTFOLIO */
.port-sec{background:var(--walnut);color:var(--cream)}
.port-sec h2,.port-sec .tag{color:var(--cream)}
.port-sec .tag .hx{color:var(--gold)}
.port-sec .lede{color:#d9c4a2}
.port-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:32px}
.port{margin:0}
.port-slot{aspect-ratio:3/4;border:1.5px dashed #6a4d2a;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;background:repeating-linear-gradient(45deg,rgba(232,178,76,.06),rgba(232,178,76,.06) 12px,transparent 12px,transparent 24px);color:var(--gold);padding:18px}
.port-slot .ph-mark{font-size:24px;color:var(--gold)}
.port-slot span:not(.ph-mark){font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.port-slot small{color:#c9b48f;font-size:12px;font-family:var(--sans);letter-spacing:.01em;text-transform:none}

/* PIERCING BANNER */
.pierce-banner{background:linear-gradient(180deg,#f3e6cd,var(--cream))}
.pb-in{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.pb-in figure{margin:0}
.pb-in img{width:100%;height:420px;object-fit:cover;border-radius:14px}
.pb-in figcaption{font-family:var(--mono);font-size:11px;color:var(--mute);margin-top:10px}

/* VISIT */
.visit{background:var(--cream2)}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.vrows{margin:22px 0 30px;display:grid;gap:0}
.vrow{display:grid;grid-template-columns:120px 1fr;gap:18px;padding:16px 0;border-top:1px solid var(--line)}
.vrow .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);padding-top:4px}
.vrow .val{font-family:var(--serif);font-size:20px;color:var(--ink)}
.vrow .sub{display:block;font-family:var(--sans);font-size:12.5px;color:var(--mute);margin-top:3px}
.visit-fig{margin:0}.visit-fig img{width:100%;height:420px;object-fit:cover;border-radius:14px}
.visit-fig figcaption{font-family:var(--mono);font-size:11px;color:var(--mute);margin-top:10px}

/* FOOTER */
.foot{background:var(--walnut);color:var(--cream);padding:46px 0}
.foot-in{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-mark{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:22px;color:var(--cream)}
.foot-mark .seal{color:var(--gold)}
.foot-line{color:#d9c4a2;font-size:14px;margin:8px 0 0}.foot-line b{color:var(--gold)}
.foot-credit{font-size:13px;color:#c9b48f;text-align:right}.foot-credit a{color:var(--gold);text-decoration:none}

/* REVEAL */
@media (prefers-reduced-motion:no-preference){
  html.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
  html.js .reveal.d1{transition-delay:.1s}html.js .reveal.d2{transition-delay:.2s}html.js .reveal.d3{transition-delay:.3s}
  html.js .reveal.in{opacity:1;transform:none}
}

/* MOBILE */
@media (max-width:900px){
  .hero-grid,.steps,.svc-grid,.svc-strip,.pb-in,.visit-grid{grid-template-columns:1fr}
  .steps{gap:14px}.svc-grid,.svc-strip{gap:16px}
  .port-grid{grid-template-columns:repeat(2,1fr)}
  .book-card{order:-1}
}
@media (max-width:640px){
  body{font-size:16px}
  .nav-links,.nav-cta{display:none}
  .burger{display:block}
  .drawer.open{display:flex}
  .wrap,.hero-grid{padding-left:18px;padding-right:18px}
  .nav-in{padding:12px 18px}
  section{padding:60px 0}
  .hero{padding:40px 0 52px}
  .hero h1{font-size:clamp(34px,10vw,48px)}
  .bc-row{grid-template-columns:1fr}
  .book-card{padding:22px}
  .svc-strip img{height:200px}
  .pb-in img,.visit-fig img{height:300px}
  .vrow{grid-template-columns:1fr;gap:3px}
}
