
:root{
  --bg:#F6F2EA;
  --surface:#EFE9DD;
  --surface-2:#E6DFCF;
  --ink:#1A1714;
  --ink-soft:#2A2622;
  --muted:#6B5F52;
  --accent:#8B6F47;
  --accent-deep:#6E5736;
  --line:#D9D1BE;
  --serif:"Fraunces",ui-serif,Georgia,serif;
  --sans:"Geist",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:"Geist Mono",ui-monospace,SFMono-Regular,monospace;
  --radius:14px;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --ease-quart:cubic-bezier(0.25,1,0.5,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv11";
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1000;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.06 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:0.55;mix-blend-mode:multiply;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color 220ms var(--ease)}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
.container{max-width:1280px;margin:0 auto;padding:0 clamp(20px,4vw,40px)}
.eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--muted);font-weight:500;
}

/* ---- NAV ---- */
header.nav{
  position:sticky;top:0;z-index:100;
  background:color-mix(in oklab,var(--bg) 88%,transparent);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid color-mix(in oklab,var(--line) 70%,transparent);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:20px;flex-wrap:nowrap}
.brand{font-family:var(--serif);font-weight:400;font-size:clamp(15px,1.3vw,18px);letter-spacing:-0.01em;white-space:nowrap;flex-shrink:0}
.brand em{font-style:italic;font-variation-settings:"opsz" 144}
.nav-links{display:none;gap:clamp(12px,1.4vw,22px);align-items:center;flex-wrap:nowrap;min-width:0}
@media(min-width:1000px){.nav-links{display:flex}}
.nav-links a{
  font-size:clamp(11px,0.9vw,13px);font-weight:500;color:var(--ink-soft);
  position:relative;padding:6px 0;white-space:nowrap;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--accent);transition:width 360ms var(--ease);
}
.nav-links a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:var(--bg);
  padding:10px 16px;border-radius:999px;
  font-size:clamp(11px,0.9vw,13px);font-weight:500;letter-spacing:0.01em;white-space:nowrap;
  transition:transform 220ms var(--ease),background 220ms var(--ease);
}
.nav-cta:hover{transform:translateY(-1px);background:var(--accent-deep)}
.nav-cta:active{transform:scale(0.98)}
.nav-cta::after{content:"→";font-size:14px}

/* ---- HERO ---- */
.hero{padding:clamp(60px,9vw,140px) 0 clamp(60px,8vw,110px);position:relative;overflow:hidden}
.hero-grid{
  display:grid;grid-template-columns:1fr;gap:48px;
  align-items:end;
}
@media(min-width:980px){.hero-grid{grid-template-columns:1.1fr 0.9fr;gap:64px}}
.hero-text .eyebrow{margin-bottom:28px;display:inline-block}
.hero h1{
  font-family:var(--serif);
  font-weight:330;
  font-variation-settings:"opsz" 144;
  font-size:clamp(48px,9vw,124px);
  line-height:0.92;
  letter-spacing:-0.035em;
  color:var(--ink);
  margin-bottom:32px;
}
.hero h1 em{
  font-style:italic;
  font-weight:300;
  color:var(--accent-deep);
  font-variation-settings:"opsz" 144;
}
.hero-sub{
  max-width:46ch;font-size:clamp(16px,1.6vw,19px);
  color:var(--ink-soft);line-height:1.55;margin-bottom:36px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn-primary{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--ink);color:var(--bg);
  padding:16px 28px;border-radius:999px;font-size:14px;font-weight:500;
  transition:transform 220ms var(--ease),background 220ms var(--ease);
  letter-spacing:0.01em;
}
.btn-primary:hover{transform:translateY(-2px);background:var(--accent-deep)}
.btn-primary:active{transform:scale(0.98)}
.btn-primary .arrow-circle{
  width:24px;height:24px;border-radius:50%;background:var(--bg);
  color:var(--ink);display:grid;place-items:center;font-size:12px;
  transition:transform 320ms var(--ease);
}
.btn-primary:hover .arrow-circle{transform:translateX(3px) rotate(-45deg)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 24px;border-radius:999px;
  border:1px solid var(--line);
  font-size:14px;font-weight:500;color:var(--ink-soft);
  transition:border-color 220ms var(--ease),background 220ms var(--ease);
}
.btn-ghost:hover{border-color:var(--ink);background:color-mix(in oklab,var(--surface) 70%,transparent)}

.hero-image{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:0 30px 60px -30px rgba(42,38,34,0.25);
}
.hero-image img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(0.95) contrast(1.02);
  transition:transform 1200ms var(--ease);
}
.hero-image:hover img{transform:scale(1.04)}
.hero-badge{
  position:absolute;top:24px;left:24px;
  background:color-mix(in oklab,var(--bg) 92%,transparent);
  backdrop-filter:blur(8px);
  padding:10px 16px;border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.18em;
  color:var(--ink-soft);text-transform:uppercase;
}

/* ---- METRICS BAR ---- */
.metrics{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:32px 0;
  background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%);
}
.metrics-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px 24px;
}
@media(min-width:760px){.metrics-grid{grid-template-columns:repeat(4,1fr)}}
.metric{display:flex;flex-direction:column;gap:6px}
.metric-num{
  font-family:var(--serif);font-size:clamp(34px,4.4vw,52px);
  font-weight:340;letter-spacing:-0.025em;line-height:1;
  font-variation-settings:"opsz" 144;
}
.metric-num em{color:var(--accent-deep);font-style:italic}
.metric-label{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted)}

/* ---- SECTION HEADERS ---- */
section{padding:clamp(72px,11vw,140px) 0;position:relative}
.section-head{
  display:grid;grid-template-columns:1fr;gap:24px;
  margin-bottom:clamp(48px,6vw,80px);align-items:end;
}
@media(min-width:880px){.section-head{grid-template-columns:auto 1fr;gap:80px}}
.section-head h2{
  font-family:var(--serif);
  font-weight:330;
  font-variation-settings:"opsz" 144;
  font-size:clamp(38px,5.6vw,76px);
  line-height:0.96;
  letter-spacing:-0.03em;
  max-width:14ch;
}
.section-head h2 em{font-style:italic;color:var(--accent-deep)}
.section-head p{max-width:48ch;color:var(--ink-soft);font-size:17px;line-height:1.55}

/* ---- LOCATIONS / SCHEDULE SYSTEM ---- */
.schedule{background:var(--surface);position:relative}
.schedule::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(60% 80% at 80% 10%,color-mix(in oklab,var(--accent) 8%,transparent),transparent 70%);
}
.schedule-shell{position:relative;z-index:1}
.location-tabs{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:8px;background:var(--bg);border:1px solid var(--line);
  border-radius:999px;margin-bottom:48px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.4);
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.location-tabs::-webkit-scrollbar{display:none}
.tab-btn{
  flex:0 0 auto;
  padding:11px 22px;border-radius:999px;
  font-size:13px;font-weight:500;letter-spacing:0.01em;
  color:var(--muted);
  transition:color 220ms var(--ease),background 280ms var(--ease),box-shadow 280ms var(--ease);
  white-space:nowrap;
}
.tab-btn:hover{color:var(--ink-soft)}
.tab-btn[aria-selected="true"]{
  background:var(--ink);color:var(--bg);
  box-shadow:0 2px 8px -2px rgba(26,23,20,0.3);
}
.tab-btn .pill-dot{
  display:inline-block;width:5px;height:5px;border-radius:50%;
  background:currentColor;opacity:0.4;margin-right:8px;vertical-align:middle;
}
.tab-btn[aria-selected="true"] .pill-dot{background:var(--accent);opacity:1}

.location-panel{display:none}
.location-panel[data-active="true"]{display:block;animation:fadeUp 600ms var(--ease) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

.panel-grid{
  display:grid;grid-template-columns:1fr;gap:32px;
}
@media(min-width:1000px){.panel-grid{grid-template-columns:1.05fr 0.95fr;gap:48px}}

/* Outer Bezel card */
.bezel{
  background:color-mix(in oklab,var(--bg) 60%,var(--surface) 40%);
  border:1px solid var(--line);
  border-radius:28px;
  padding:8px;
  box-shadow:0 1px 0 rgba(255,255,255,0.5) inset, 0 30px 60px -40px rgba(42,38,34,0.18);
}
.bezel-inner{
  background:var(--bg);
  border-radius:22px;
  padding:clamp(28px,3.4vw,40px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.6);
}

.location-info .city{
  font-family:var(--serif);font-weight:330;
  font-variation-settings:"opsz" 144;
  font-size:clamp(40px,5.4vw,68px);line-height:0.95;letter-spacing:-0.03em;
  margin-bottom:6px;
}
.location-info .city em{font-style:italic;color:var(--accent-deep)}
.location-info .neighbourhood{
  font-family:var(--mono);font-size:11px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--muted);margin-bottom:28px;
}
.location-row{
  display:grid;grid-template-columns:auto 1fr;gap:14px 16px;
  padding:18px 0;border-top:1px solid var(--line);
  align-items:start;
}
.location-row:first-of-type{border-top:none;padding-top:8px}
.location-row .icon{
  width:36px;height:36px;border-radius:10px;
  background:var(--surface);display:grid;place-items:center;
  color:var(--accent-deep);
}
.location-row .icon svg{width:16px;height:16px}
.location-row .label{
  font-family:var(--mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--muted);margin-bottom:4px;
}
.location-row .value{font-size:15px;color:var(--ink);line-height:1.5}
.location-row .value a:hover{color:var(--accent-deep)}

.hours-table{
  width:100%;margin-top:6px;border-collapse:collapse;
  font-size:14px;
}
.hours-table tr{border-top:1px dashed color-mix(in oklab,var(--line) 70%,transparent)}
.hours-table tr:first-child{border-top:none}
.hours-table td{padding:10px 0;color:var(--ink-soft)}
.hours-table .day{font-weight:500;width:40%}
.hours-table .time{text-align:right;font-family:var(--mono);font-size:13px;color:var(--ink)}
.hours-table tr.today{
  background:linear-gradient(90deg,color-mix(in oklab,var(--accent) 10%,transparent),transparent);
  border-radius:6px;
}
.hours-table tr.today td{color:var(--accent-deep);font-weight:600}
.hours-table .closed{color:var(--muted);font-style:italic}

.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  margin-bottom:24px;
}
.status-pill.open{background:color-mix(in oklab,#3a7d44 18%,var(--bg));color:#2c5e34}
.status-pill.closed{background:color-mix(in oklab,#9a3b2f 14%,var(--bg));color:#7a2d24}
.status-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 currentColor}50%{opacity:0.6;box-shadow:0 0 0 6px transparent}}

/* ---- BOOKING FORM ---- */
.booking{position:relative}
.booking h3{
  font-family:var(--serif);font-weight:340;font-size:28px;letter-spacing:-0.02em;
  margin-bottom:6px;
}
.booking h3 em{font-style:italic;color:var(--accent-deep)}
.booking-sub{font-size:13px;color:var(--muted);margin-bottom:24px}

.field-group{margin-bottom:18px}
.field-group label{
  display:block;font-family:var(--mono);font-size:10px;letter-spacing:0.2em;
  text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:500;
}
.field-group input,
.field-group select,
.field-group textarea{
  width:100%;padding:14px 16px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:12px;
  font-family:var(--sans);font-size:15px;color:var(--ink);
  transition:border-color 200ms var(--ease),background 200ms var(--ease),box-shadow 200ms var(--ease);
}
.field-group input:focus,
.field-group select:focus,
.field-group textarea:focus{
  outline:none;border-color:var(--accent);
  background:var(--bg);
  box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 18%,transparent);
}
.field-group textarea{min-height:90px;resize:vertical;font-family:var(--sans)}

.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:540px){.field-row{grid-template-columns:1fr}}

.service-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px;
  margin-top:4px;
}
.service-chip{
  position:relative;
  padding:14px 14px 14px 38px;
  border:1px solid var(--line);border-radius:12px;
  background:var(--surface);
  font-size:13px;font-weight:500;color:var(--ink-soft);
  cursor:pointer;text-align:left;
  transition:all 220ms var(--ease);
}
.service-chip::before{
  content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:14px;height:14px;border-radius:50%;border:1.5px solid var(--line);
  transition:all 200ms var(--ease);
}
.service-chip[aria-pressed="true"]{
  border-color:var(--ink);background:var(--bg);color:var(--ink);
}
.service-chip[aria-pressed="true"]::before{
  background:var(--ink);border-color:var(--ink);
  box-shadow:inset 0 0 0 3px var(--bg);
}

.time-slots{
  display:grid;grid-template-columns:repeat(4,1fr);gap:8px;
  margin-top:4px;
}
@media(max-width:540px){.time-slots{grid-template-columns:repeat(3,1fr)}}
.time-slot{
  padding:10px 4px;font-family:var(--mono);font-size:12px;
  border:1px solid var(--line);border-radius:10px;
  background:var(--surface);color:var(--ink-soft);
  transition:all 200ms var(--ease);
}
.time-slot:hover:not([disabled]){border-color:var(--ink);background:var(--bg)}
.time-slot[aria-pressed="true"]{
  background:var(--ink);color:var(--bg);border-color:var(--ink);
}
.time-slot[disabled]{opacity:0.3;cursor:not-allowed;text-decoration:line-through}

.btn-submit{
  width:100%;
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--ink);color:var(--bg);
  padding:18px 24px;border-radius:14px;
  font-size:15px;font-weight:500;letter-spacing:0.01em;
  transition:transform 200ms var(--ease),background 200ms var(--ease);
  margin-top:8px;
}
.btn-submit:hover{transform:translateY(-1px);background:var(--accent-deep)}
.btn-submit:active{transform:scale(0.99)}

.booking-meta{
  margin-top:18px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;
  font-size:12px;color:var(--muted);
}

.success-msg{
  display:none;padding:24px;background:color-mix(in oklab,var(--accent) 12%,var(--bg));
  border:1px solid color-mix(in oklab,var(--accent) 40%,var(--line));
  border-radius:14px;font-size:14px;color:var(--accent-deep);
}

/* ---- CRAFT (services) ---- */
.craft{background:var(--bg)}
.craft-grid{
  display:grid;grid-template-columns:1fr;gap:20px;
}
@media(min-width:780px){.craft-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.craft-grid{grid-template-columns:2.2fr 1fr 1fr}}
.craft-card{
  position:relative;overflow:hidden;
  border-radius:18px;background:var(--surface);
  min-height:300px;
  border:1px solid var(--line);
  transition:transform 500ms var(--ease);
}
.craft-card:hover{transform:translateY(-4px)}
.craft-card.feature{grid-row:span 2;min-height:520px}
.craft-card .img-wrap{position:absolute;inset:0;overflow:hidden}
.craft-card img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(0.92) contrast(1.04);
  transition:transform 1000ms var(--ease);
}
.craft-card:hover img{transform:scale(1.06)}
.craft-card .overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 0%,transparent 28%,rgba(20,17,14,0.55) 60%,rgba(20,17,14,0.94) 100%);
}
.craft-card .body{
  position:absolute;left:0;right:0;bottom:0;
  padding:clamp(20px,2.4vw,32px);color:var(--bg);
}
.craft-card .body .eyebrow{color:color-mix(in oklab,var(--bg) 75%,transparent)}
.craft-card h3{
  font-family:var(--serif);font-weight:340;font-variation-settings:"opsz" 144;
  font-size:clamp(26px,2.8vw,36px);letter-spacing:-0.02em;line-height:1.05;
  margin:8px 0 8px;
}
.craft-card h3 em{font-style:italic}
.craft-card p{font-size:14px;color:color-mix(in oklab,var(--bg) 80%,transparent);max-width:36ch}
.craft-card .price{
  position:absolute;top:24px;right:24px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.18em;
  background:color-mix(in oklab,var(--bg) 88%,transparent);
  color:var(--ink);padding:8px 14px;border-radius:999px;
  text-transform:uppercase;
}

/* ---- PROCESS ---- */
.process{background:var(--surface)}
.process-grid{
  display:grid;grid-template-columns:1fr;gap:0;
  border-top:1px solid var(--line);
}
@media(min-width:880px){.process-grid{grid-template-columns:repeat(4,1fr);border-top:none}}
.step{
  padding:clamp(28px,3.4vw,44px) clamp(24px,3vw,36px);
  border-bottom:1px solid var(--line);
  position:relative;
  transition:background 320ms var(--ease);
}
@media(min-width:880px){
  .step{border-bottom:none;border-right:1px solid var(--line)}
  .step:last-child{border-right:none}
}
.step:hover{background:color-mix(in oklab,var(--bg) 60%,var(--surface) 40%)}
.step-num{
  font-family:var(--mono);font-size:11px;letter-spacing:0.2em;
  color:var(--accent-deep);margin-bottom:24px;
}
.step h3{
  font-family:var(--serif);font-weight:340;font-size:28px;letter-spacing:-0.02em;
  margin-bottom:14px;line-height:1.1;
}
.step h3 em{font-style:italic}
.step p{font-size:14.5px;color:var(--ink-soft);line-height:1.6}

/* ---- TESTIMONIALS ---- */
.testimonials{background:var(--bg)}
.tm-grid{
  display:grid;grid-template-columns:1fr;gap:20px;
}
@media(min-width:780px){.tm-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1080px){.tm-grid{grid-template-columns:repeat(3,1fr)}}
.tm-card{
  padding:32px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:18px;
  position:relative;
  transition:transform 400ms var(--ease),box-shadow 400ms var(--ease);
}
.tm-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px -24px rgba(42,38,34,0.2)}
.tm-card .stars{color:var(--accent);font-size:14px;letter-spacing:0.15em;margin-bottom:16px}
.tm-card blockquote{
  font-family:var(--serif);font-size:19px;font-weight:340;line-height:1.45;
  letter-spacing:-0.01em;color:var(--ink);margin-bottom:24px;
}
.tm-card blockquote::before{content:"\201C";color:var(--accent);font-size:32px;line-height:0;vertical-align:-12px;margin-right:4px}
.tm-card .author{display:flex;align-items:center;gap:12px;padding-top:18px;border-top:1px solid var(--line)}
.tm-card .avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-deep));
  display:grid;place-items:center;
  font-family:var(--serif);color:var(--bg);font-size:18px;font-weight:340;
}
.tm-card .author-info{display:flex;flex-direction:column}
.tm-card .author-name{font-size:14px;font-weight:500}
.tm-card .author-meta{font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted)}

/* ---- ABOUT ---- */
.about{background:var(--bg)}
.about-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:980px){.about-grid{grid-template-columns:0.95fr 1.05fr;gap:80px}}
.about-img{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 30px 60px -30px rgba(42,38,34,0.25)}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-text h2{font-family:var(--serif);font-weight:330;font-variation-settings:"opsz" 144;font-size:clamp(38px,5.4vw,68px);line-height:0.96;letter-spacing:-0.03em;margin-bottom:28px;max-width:14ch}
.about-text h2 em{font-style:italic;color:var(--accent-deep)}
.about-text p{font-size:17px;line-height:1.65;color:var(--ink-soft);margin-bottom:18px;max-width:54ch}
.about-quote{
  margin-top:28px;padding:24px 28px;border-left:none;
  background:var(--surface);border-radius:14px;
  font-family:var(--serif);font-size:20px;font-style:italic;line-height:1.45;color:var(--ink);
}
.about-quote cite{display:block;font-style:normal;font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-top:14px}

/* ---- FABRICS ---- */
.fabrics{background:var(--surface);position:relative;overflow:hidden}
.fabric-house-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-bottom:64px}
@media(min-width:780px){.fabric-house-grid{grid-template-columns:repeat(2,1fr)}}
.house-card{
  background:var(--bg);border:1px solid var(--line);border-radius:18px;
  padding:32px;display:flex;flex-direction:column;gap:14px;
  transition:transform 400ms var(--ease),box-shadow 400ms var(--ease);
  position:relative;overflow:hidden;
}
.house-card:hover{transform:translateY(-3px);box-shadow:0 24px 50px -30px rgba(42,38,34,0.25)}
.house-card .badge{
  position:absolute;top:24px;right:24px;
  font-family:var(--mono);font-size:10px;letter-spacing:0.2em;color:var(--accent-deep);
  text-transform:uppercase;
}
.house-card h3{font-family:var(--serif);font-weight:340;font-variation-settings:"opsz" 144;font-size:clamp(28px,3vw,38px);letter-spacing:-0.02em;line-height:1.05}
.house-card h3 em{font-style:italic;color:var(--accent-deep)}
.house-card p{font-size:15px;line-height:1.6;color:var(--ink-soft);max-width:42ch}
.house-meta{display:flex;gap:20px;font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);margin-top:8px;border-top:1px solid var(--line);padding-top:14px}
.swatch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px}
.swatch{
  aspect-ratio:1;border-radius:12px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:14px;color:var(--bg);
  font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  position:relative;overflow:hidden;
  border:1px solid color-mix(in oklab,var(--ink) 8%,transparent);
  transition:transform 400ms var(--ease);
}
.swatch:hover{transform:scale(1.04)}
.swatch::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.18 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");mix-blend-mode:overlay;pointer-events:none}
.swatch span{position:relative;z-index:1}

/* ---- SHIRT CUSTOM ---- */
.shirts{background:var(--bg)}
.opt-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:680px){.opt-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1020px){.opt-grid{grid-template-columns:repeat(3,1fr)}}
.opt-card{
  background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:24px;display:flex;flex-direction:column;gap:18px;
  transition:transform 320ms var(--ease),background 320ms var(--ease);
}
.opt-card:hover{transform:translateY(-3px);background:color-mix(in oklab,var(--surface) 70%,var(--bg) 30%)}
.opt-card .opt-label{font-family:var(--mono);font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--accent-deep)}
.opt-card h3{font-family:var(--serif);font-weight:340;font-size:24px;letter-spacing:-0.015em;line-height:1.15}
.opt-card h3 em{font-style:italic}
.opt-card ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.opt-card li{
  font-size:14px;color:var(--ink-soft);padding-left:22px;position:relative;line-height:1.5;
}
.opt-card li::before{
  content:"";position:absolute;left:0;top:9px;width:10px;height:1px;background:var(--accent);
}

/* ---- WEDDING ---- */
.wedding{background:var(--ink);color:color-mix(in oklab,var(--bg) 92%,transparent);position:relative;overflow:hidden}
.wedding::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 20% 100%,color-mix(in oklab,var(--accent) 22%,transparent),transparent 70%);pointer-events:none}
.wedding .container{position:relative;z-index:1}
.wedding .section-head h2{color:var(--bg)}
.wedding .section-head h2 em{color:var(--accent)}
.wedding .section-head p{color:color-mix(in oklab,var(--bg) 75%,transparent)}
.wedding-split{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:980px){.wedding-split{grid-template-columns:1fr 1fr;gap:48px}}
.wedding-img{aspect-ratio:4/5;border-radius:18px;overflow:hidden}
.wedding-img img{width:100%;height:100%;object-fit:cover;filter:saturate(0.9) contrast(1.05)}
.wedding-list{display:flex;flex-direction:column;gap:20px}
.wedding-item{
  padding:24px 28px;border:1px solid color-mix(in oklab,var(--bg) 14%,transparent);border-radius:14px;
  background:color-mix(in oklab,var(--bg) 4%,transparent);
  transition:background 320ms var(--ease);
}
.wedding-item:hover{background:color-mix(in oklab,var(--bg) 8%,transparent)}
.wedding-item h3{font-family:var(--serif);font-weight:340;font-size:22px;letter-spacing:-0.01em;color:var(--bg);margin-bottom:8px}
.wedding-item h3 em{font-style:italic;color:var(--accent)}
.wedding-item p{font-size:14.5px;line-height:1.6;color:color-mix(in oklab,var(--bg) 75%,transparent)}

/* ---- ALTERATIONS ---- */
.alts{background:var(--surface)}
.alts-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:780px){.alts-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.alts-grid{grid-template-columns:repeat(4,1fr)}}
.alt-card{
  background:var(--bg);border:1px solid var(--line);border-radius:16px;
  padding:24px;display:flex;flex-direction:column;gap:10px;
  transition:transform 320ms var(--ease);
}
.alt-card:hover{transform:translateY(-3px)}
.alt-card .price{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;color:var(--accent-deep);text-transform:uppercase}
.alt-card h3{font-family:var(--serif);font-weight:340;font-size:22px;letter-spacing:-0.01em;line-height:1.15}
.alt-card p{font-size:14px;color:var(--ink-soft);line-height:1.55}

/* ---- PROMOTIONS ---- */
.promo{background:var(--bg)}
.promo-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:780px){.promo-grid{grid-template-columns:repeat(2,1fr);gap:24px}}
.promo-card{
  background:var(--surface);border:1px solid var(--line);border-radius:20px;
  padding:clamp(28px,3vw,40px);
  display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
}
.promo-card.feature{background:linear-gradient(135deg,var(--accent-deep) 0%,#3a2d1d 100%);color:var(--bg);border-color:transparent}
.promo-card.feature .promo-tag{background:color-mix(in oklab,var(--bg) 18%,transparent);color:var(--bg)}
.promo-card.feature h3{color:var(--bg)}
.promo-card.feature p{color:color-mix(in oklab,var(--bg) 80%,transparent)}
.promo-card.feature .promo-price{color:var(--bg)}
.promo-card.feature .promo-price small{color:color-mix(in oklab,var(--bg) 70%,transparent)}
.promo-card.feature .btn-ghost{border-color:color-mix(in oklab,var(--bg) 30%,transparent);color:var(--bg)}
.promo-card.feature .btn-ghost:hover{background:color-mix(in oklab,var(--bg) 12%,transparent);border-color:var(--bg)}
.promo-tag{
  align-self:flex-start;padding:6px 14px;border-radius:999px;
  background:var(--bg);color:var(--accent-deep);
  font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
}
.promo-card h3{font-family:var(--serif);font-weight:340;font-variation-settings:"opsz" 144;font-size:clamp(30px,3.6vw,46px);letter-spacing:-0.025em;line-height:1.05}
.promo-card h3 em{font-style:italic}
.promo-card p{font-size:15px;line-height:1.6;max-width:38ch}
.promo-price{font-family:var(--serif);font-size:48px;font-weight:340;letter-spacing:-0.025em;line-height:1;font-variation-settings:"opsz" 144}
.promo-price small{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-left:8px;font-weight:400}

/* ---- FAQ ---- */
.faq{background:var(--surface)}
.faq-list{max-width:880px;margin:0 auto}
.faq-item{
  border-top:1px solid var(--line);
  transition:background 280ms var(--ease);
}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;text-align:left;
  padding:26px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--serif);font-weight:340;font-size:clamp(18px,2vw,22px);letter-spacing:-0.01em;
  color:var(--ink);line-height:1.3;
  transition:color 220ms var(--ease);
}
.faq-q:hover{color:var(--accent-deep)}
.faq-q .ico{
  flex-shrink:0;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);
  display:grid;place-items:center;font-family:var(--mono);font-size:14px;color:var(--ink-soft);
  transition:transform 380ms var(--ease),background 380ms var(--ease);
}
.faq-item[open] .faq-q .ico{transform:rotate(45deg);background:var(--ink);color:var(--bg);border-color:var(--ink)}
.faq-a{padding:0 0 26px;color:var(--ink-soft);font-size:15.5px;line-height:1.7;max-width:64ch}

/* ---- JOURNAL ---- */
.journal{background:var(--bg)}
.journal-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:780px){.journal-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.journal-grid{grid-template-columns:repeat(3,1fr)}}
.journal-card{
  display:flex;flex-direction:column;gap:18px;
  background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;
  transition:transform 400ms var(--ease),box-shadow 400ms var(--ease);
}
.journal-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -28px rgba(42,38,34,0.22)}
.journal-card .pic{aspect-ratio:5/3;background:var(--surface-2);overflow:hidden}
.journal-card .pic img{width:100%;height:100%;object-fit:cover;transition:transform 900ms var(--ease)}
.journal-card:hover .pic img{transform:scale(1.06)}
.journal-card .body{padding:0 24px 26px;display:flex;flex-direction:column;gap:10px}
.journal-card .meta{font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted)}
.journal-card h3{font-family:var(--serif);font-weight:340;font-size:22px;letter-spacing:-0.015em;line-height:1.25}
.journal-card .read{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent-deep);margin-top:6px}

/* ---- FOOTER ---- */
footer{
  background:var(--ink);color:color-mix(in oklab,var(--bg) 85%,transparent);
  padding:80px 0 40px;
}
.foot-grid{
  display:grid;grid-template-columns:1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid color-mix(in oklab,var(--bg) 12%,transparent);
  margin-bottom:32px;
}
@media(min-width:780px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}}
.foot-brand h3{font-family:var(--serif);font-weight:330;font-size:36px;letter-spacing:-0.02em;color:var(--bg);margin-bottom:14px;font-variation-settings:"opsz" 144}
.foot-brand h3 em{font-style:italic;color:var(--accent)}
.foot-brand p{font-size:14px;max-width:34ch;line-height:1.6}
.foot-col h4{
  font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:color-mix(in oklab,var(--bg) 55%,transparent);margin-bottom:18px;font-weight:500;
}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-size:14px;transition:color 200ms var(--ease)}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{
  display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;
  font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:color-mix(in oklab,var(--bg) 50%,transparent);
}

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

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
  .reveal{opacity:1;transform:none}
}

/* ---- NAV DROPDOWN ---- */
.nav-links{gap:24px}
.nav-item{position:relative}
.nav-item > a{display:inline-flex;align-items:center;gap:4px}
.nav-item .caret{font-size:9px;opacity:0.55;transition:transform 220ms var(--ease)}
.nav-item.has-sub:hover .caret{transform:rotate(180deg);opacity:1}
.sub-menu{
  position:absolute;top:calc(100% + 14px);left:-16px;
  list-style:none;margin:0;padding:10px 0;
  min-width:230px;
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 22px 48px -28px rgba(40,32,20,0.32),0 1px 0 rgba(255,255,255,0.5) inset;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(-6px);
  transition:opacity 220ms var(--ease),transform 240ms var(--ease),visibility 0s linear 240ms;
  z-index:120;
}
.nav-item.has-sub:hover .sub-menu,
.nav-item.has-sub:focus-within .sub-menu{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);
  transition:opacity 240ms var(--ease),transform 320ms var(--ease),visibility 0s;
}
.sub-menu li{margin:0}
.sub-menu a{
  display:block;padding:9px 18px;font-size:13px;color:var(--ink-soft);
  border-left:2px solid transparent;
  transition:background 220ms var(--ease),color 220ms var(--ease),padding-left 220ms var(--ease);
}
.sub-menu a:hover{
  color:var(--accent-deep);
  background:color-mix(in oklab,var(--accent) 8%,transparent);
  padding-left:22px;
}
.sub-menu a::after{display:none}

/* ---- SUIT STYLE GALLERY ---- */
.style-gallery{padding:clamp(60px,8vw,100px) 0;border-top:1px solid var(--line)}
.style-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:clamp(16px,2vw,28px);margin-top:32px;
}
.style-card{
  position:relative;border-radius:14px;overflow:hidden;
  border:1px solid var(--line);background:var(--surface);
  aspect-ratio:3/4;
  transition:transform 360ms var(--ease),border-color 240ms var(--ease);
}
.style-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.style-card img{width:100%;height:100%;object-fit:cover;transition:transform 600ms var(--ease)}
.style-card:hover img{transform:scale(1.04)}
.style-card .style-label{
  position:absolute;left:12px;bottom:12px;right:12px;
  background:color-mix(in oklab,var(--bg) 92%,transparent);
  backdrop-filter:blur(8px);
  padding:8px 12px;border-radius:8px;
  font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink);
}

/* ---- CONTACT PAGE ---- */
.contact{padding:clamp(60px,9vw,120px) 0}
.contact-grid{display:grid;grid-template-columns:1fr;gap:48px}
@media(min-width:880px){.contact-grid{grid-template-columns:1fr 1.1fr}}
.contact-info{display:flex;flex-direction:column;gap:28px}
.contact-block{padding:24px;border:1px solid var(--line);border-radius:14px;background:var(--surface)}
.contact-block h3{font-family:var(--serif);font-weight:400;font-size:22px;margin-bottom:8px}
.contact-block a{color:var(--accent-deep);border-bottom:1px solid color-mix(in oklab,var(--accent) 40%,transparent)}
.policy-prose{max-width:760px;margin:48px auto;padding:0 clamp(20px,4vw,40px);line-height:1.75}
.policy-prose h2{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3vw,40px);margin:36px 0 14px}
.policy-prose h3{font-family:var(--serif);font-style:italic;font-size:20px;margin:28px 0 8px;color:var(--accent-deep)}
.policy-prose p{margin:12px 0;color:var(--ink-soft)}

/* ---- TIMECENTER CTA CARD ---- */
.tc-cta{display:flex;flex-direction:column;gap:22px}
.tc-cta-head h4{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(26px,2.4vw,34px);
  line-height:1.15;letter-spacing:-0.01em;margin:8px 0 12px;
}
.tc-cta-head h4 em{font-style:italic;color:var(--accent-deep);font-variation-settings:"opsz" 144}
.tc-cta-head p{color:var(--ink-soft);font-size:15px;line-height:1.65}
.tc-steps{list-style:none;display:flex;flex-direction:column;gap:10px;margin:0;padding:0}
.tc-steps li{
  display:flex;align-items:flex-start;gap:14px;
  font-size:14px;color:var(--ink-soft);line-height:1.5;
  padding:12px 14px;border:1px solid var(--line);border-radius:12px;
  background:color-mix(in oklab,var(--surface) 65%,transparent);
}
.tc-steps li span{
  flex:0 0 24px;height:24px;border-radius:50%;
  background:var(--ink);color:var(--bg);
  font-family:var(--mono);font-size:11px;font-weight:600;
  display:flex;align-items:center;justify-content:center;
  margin-top:1px;
}
.tc-launch{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--ink);color:var(--bg);
  padding:18px 28px;border-radius:999px;
  font-size:14px;font-weight:500;letter-spacing:0.01em;
  text-decoration:none;
  transition:transform 220ms var(--ease),background 220ms var(--ease);
}
.tc-launch:hover{transform:translateY(-1px);background:var(--accent-deep)}
.tc-launch:active{transform:scale(0.98)}

/* ---- INLINE BOOKING SCHEDULER ---- */
.bk-inline{display:block;width:100%}
.bk-inline-card{
  display:flex;flex-direction:column;background:transparent;
  border-radius:14px;overflow:hidden;
}
.bk-progress{display:flex;gap:6px;padding:0 0 16px}
.bk-progress span{
  flex:1;height:3px;background:var(--line);border-radius:2px;overflow:hidden;
}
.bk-progress span.done{background:var(--accent-deep)}
.bk-progress span.active{background:var(--accent-deep)}
.bk-body{padding:0 0 16px;flex:1}
.bk-step-label{
  font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:6px;
}
.bk-step-h{font-family:var(--serif);font-size:24px;font-weight:400;line-height:1.2;color:var(--ink);margin:0 0 18px}
.bk-step-h em{font-style:italic;color:var(--accent-deep)}
.bk-services{display:grid;grid-template-columns:1fr;gap:10px}
@media(min-width:520px){.bk-services{grid-template-columns:1fr 1fr}}
.bk-svc{
  text-align:left;padding:16px 18px;border:1px solid var(--line);background:var(--bg-warm);
  border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;
  transition:all 220ms var(--ease);font:inherit;color:inherit;
}
.bk-svc:hover{border-color:var(--accent);transform:translateY(-1px)}
.bk-svc.selected{border-color:var(--accent-deep);background:color-mix(in oklab,var(--accent) 10%,var(--bg))}
.bk-svc .nm{font-family:var(--serif);font-size:17px;color:var(--ink)}
.bk-svc .mn{font-family:var(--mono);font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-soft)}
.bk-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.bk-cal-title{font-family:var(--serif);font-size:18px;color:var(--ink)}
.bk-cal-nav{display:flex;gap:6px}
.bk-cal-nav button{
  width:32px;height:32px;border-radius:999px;border:1px solid var(--line);
  background:transparent;cursor:pointer;color:var(--ink-soft);
  display:grid;place-items:center;transition:all 200ms var(--ease);
}
.bk-cal-nav button:hover:not(:disabled){border-color:var(--ink);color:var(--ink)}
.bk-cal-nav button:disabled{opacity:0.3;cursor:not-allowed}
.bk-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.bk-cal .dh{
  font-family:var(--mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;
  color:var(--muted);text-align:center;padding:6px 0;
}
.bk-cal button{
  aspect-ratio:1;border:1px solid transparent;background:transparent;
  border-radius:8px;font-family:var(--mono);font-size:13px;color:var(--ink);
  cursor:pointer;transition:all 180ms var(--ease);
}
.bk-cal button:hover:not(:disabled){border-color:var(--accent);background:var(--bg-warm)}
.bk-cal button.selected{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.bk-cal button.today{font-weight:600;color:var(--accent-deep)}
.bk-cal button:disabled{color:var(--muted);cursor:not-allowed;opacity:0.4}
.bk-cal .empty{visibility:hidden}
.bk-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.bk-slot{
  padding:12px 8px;border:1px solid var(--line);border-radius:10px;
  background:var(--bg-warm);font-family:var(--mono);font-size:13px;color:var(--ink);
  cursor:pointer;transition:all 180ms var(--ease);
}
.bk-slot:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px)}
.bk-slot.selected{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.bk-slot:disabled{opacity:0.35;cursor:not-allowed;text-decoration:line-through}
.bk-no-slots{padding:24px;text-align:center;color:var(--ink-soft);font-style:italic;border:1px dashed var(--line);border-radius:10px}
.bk-fields{display:grid;gap:14px}
.bk-fields label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:6px}
.bk-fields .opt{color:var(--muted);text-transform:none;letter-spacing:0;font-style:italic;margin-left:6px}
.bk-fields input,.bk-fields textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  background:var(--bg-warm);font:inherit;font-size:15px;color:var(--ink);
  transition:border-color 200ms var(--ease);
}
.bk-fields input:focus,.bk-fields textarea:focus{outline:none;border-color:var(--accent-deep)}
.bk-fields textarea{min-height:80px;resize:vertical;font-family:var(--sans)}
.bk-foot{
  display:flex;gap:10px;justify-content:space-between;align-items:center;
  padding:14px 0 0;border-top:1px solid var(--line);
}
.bk-foot .spacer{flex:1}
.bk-btn{
  font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;
  padding:12px 20px;border-radius:999px;cursor:pointer;border:1px solid var(--line);
  background:transparent;color:var(--ink);transition:all 220ms var(--ease);
}
.bk-btn:hover{border-color:var(--ink)}
.bk-btn.primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.bk-btn.primary:hover{background:var(--accent-deep);border-color:var(--accent-deep)}
.bk-btn:disabled{opacity:0.4;cursor:not-allowed}
.bk-btn.primary:disabled:hover{background:var(--ink);border-color:var(--ink)}
.bk-summary{
  background:var(--bg-warm);border:1px solid var(--line);border-radius:14px;
  padding:18px 20px;margin-bottom:16px;display:grid;gap:10px;
}
.bk-summary .row{display:grid;grid-template-columns:90px 1fr;gap:10px;font-size:14px;align-items:baseline}
.bk-summary .row .k{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-soft)}
.bk-summary .row .v{color:var(--ink);font-family:var(--serif);font-size:16px}
.bk-confirm-icon{
  width:56px;height:56px;border-radius:999px;background:color-mix(in oklab,var(--accent) 18%,var(--bg));
  display:grid;place-items:center;margin:0 auto 14px;color:var(--accent-deep);
}
.bk-confirm-h{text-align:center;font-family:var(--serif);font-size:28px;font-weight:400;color:var(--ink);margin:0 0 6px}
.bk-confirm-sub{text-align:center;color:var(--ink-soft);margin:0 0 18px;font-size:15px}
.bk-ref{
  text-align:center;font-family:var(--mono);font-size:12px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--ink-soft);margin-bottom:18px;
}
.bk-ref strong{color:var(--accent-deep);font-weight:600;letter-spacing:0.1em}
.bk-final-actions{display:flex;flex-direction:column;gap:8px}
.bk-delivery{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  padding:12px 16px;border-radius:10px;margin-bottom:14px;border:1px solid var(--line);
  color:var(--ink-soft);background:var(--bg-warm);
}
.bk-delivery .bk-dot{
  width:8px;height:8px;border-radius:999px;background:var(--ink-soft);
  flex-shrink:0;
}
.bk-delivery.sending .bk-dot{background:#d4a13a;animation:bk-pulse 1.4s ease-in-out infinite}
.bk-delivery.sent{color:#1f6b3a;border-color:color-mix(in oklab,#1f6b3a 30%,var(--line));background:color-mix(in oklab,#1f6b3a 6%,var(--bg))}
.bk-delivery.sent .bk-dot{background:#1f6b3a}
.bk-delivery.failed{color:#a8392b;border-color:color-mix(in oklab,#a8392b 30%,var(--line));background:color-mix(in oklab,#a8392b 6%,var(--bg))}
.bk-delivery.failed .bk-dot{background:#a8392b}
.bk-delivery a{color:inherit;text-decoration:underline;margin-left:auto;letter-spacing:0.1em}
@keyframes bk-pulse{0%,100%{opacity:1}50%{opacity:0.35}}
.bk-stale{
  display:flex;align-items:center;gap:8px;margin-top:14px;
  font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--ink-soft);
}
.bk-stale-dot{
  width:7px;height:7px;border-radius:999px;background:#1f6b3a;
  box-shadow:0 0 0 0 rgba(31,107,58,0.45);animation:bk-live 2s ease-out infinite;
}
@keyframes bk-live{
  0%{box-shadow:0 0 0 0 rgba(31,107,58,0.45)}
  100%{box-shadow:0 0 0 8px rgba(31,107,58,0)}
}
.bk-loading{
  display:flex;align-items:center;gap:10px;padding:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--ink-soft);border:1px dashed var(--line);border-radius:10px;
}
.bk-loading .bk-stale-dot{background:#d4a13a;animation:bk-pulse 1.4s ease-in-out infinite}

/* ---- LANG SWITCH + NAV-RIGHT ---- */
.nav-right{display:flex;align-items:center;gap:14px}
.lang-switch{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--mono);font-size:11px;font-weight:500;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--ink-soft);
  border:1px solid var(--line);
  padding:8px 12px;border-radius:999px;
  transition:border-color 220ms var(--ease),color 220ms var(--ease),background 220ms var(--ease);
}
.lang-switch:hover{border-color:var(--accent);color:var(--accent-deep);background:color-mix(in oklab,var(--accent) 8%,transparent)}
.lang-switch .lang-on{color:var(--ink);font-weight:600}
.lang-switch .lang-off{color:var(--muted)}
.lang-switch .lang-sep{color:var(--line);margin:0 1px}
@media(max-width:640px){
  .lang-switch{padding:7px 10px;font-size:10px;letter-spacing:0.14em}
}

/* ---- MOBILE NAV ---- */
.nav-toggle{
  display:none;
  width:44px;height:44px;border-radius:999px;
  background:transparent;border:1px solid var(--line);
  flex-direction:column;align-items:center;justify-content:center;gap:4px;
  flex-shrink:0;cursor:pointer;
  transition:background 220ms var(--ease),border-color 220ms var(--ease);
}
.nav-toggle span{
  display:block;width:18px;height:1.5px;background:var(--ink);
  transition:transform 360ms var(--ease),opacity 200ms var(--ease);
  transform-origin:center;
}
.nav-toggle:hover{background:color-mix(in oklab,var(--accent) 8%,transparent)}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}

@media (max-width:999.98px){
  .nav-toggle{display:flex}
  .nav-links{
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    position:fixed;left:0;right:0;top:0;
    width:100vw;height:100vh;height:100dvh;
    padding:88px clamp(20px,5vw,32px) 32px;
    background:var(--bg);
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    transform:translateY(-100%);
    transition:transform 420ms cubic-bezier(0.22,1,0.36,1),visibility 0s linear 420ms;
    visibility:hidden;z-index:1100;
  }
  body.menu-open .nav-links{
    transform:translateY(0);visibility:visible;
    transition:transform 460ms cubic-bezier(0.22,1,0.36,1),visibility 0s;
  }
  body.menu-open{overflow:hidden}
  .nav-item{position:static;border-bottom:1px solid color-mix(in oklab,var(--line) 70%,transparent)}
  .nav-item > a{
    display:flex;align-items:center;justify-content:space-between;
    padding:18px 4px;font-size:18px;font-family:var(--serif);font-weight:400;
    letter-spacing:-0.01em;color:var(--ink);width:100%;
  }
  .nav-item .caret{
    font-size:14px;opacity:0.5;
    transition:transform 320ms var(--ease);
  }
  .nav-item.has-sub.is-open .caret{transform:rotate(180deg);opacity:1}
  .nav-item.has-sub.is-open > a{color:var(--accent-deep)}
  .sub-menu{
    position:static;background:transparent;border:none;box-shadow:none;
    padding:0 0 14px 4px;margin:0;min-width:0;
    opacity:0;visibility:hidden;pointer-events:none;
    max-height:0;overflow:hidden;
    transform:none;transition:opacity 240ms var(--ease),max-height 360ms var(--ease),visibility 0s linear 360ms;
  }
  .sub-menu::before{display:none}
  .nav-item.has-sub.is-open .sub-menu{
    opacity:1;visibility:visible;pointer-events:auto;max-height:600px;
    transition:opacity 280ms var(--ease),max-height 420ms var(--ease),visibility 0s;
  }
  .sub-menu a{
    padding:10px 0 10px 14px;font-size:15px;color:var(--ink-soft);
    border-left:none;
  }
  .sub-menu a:hover{padding-left:18px;background:transparent}
  /* Override the desktop hover styling */
  .nav-item.has-sub:hover .sub-menu{opacity:0;visibility:hidden;pointer-events:none;max-height:0}
  .nav-item.has-sub.is-open:hover .sub-menu{opacity:1;visibility:visible;pointer-events:auto;max-height:600px}
}
@media (max-width:520px){
  .nav-cta{display:none}
  .lang-switch{font-size:12px}
}
