/* =========================================================
   LYCEN — Barbershop, Downtown Knoxville
   Palette: warm vulcanite black / cordovan / bone / tobacco
   Type: Big Shoulders Display (sign), Hanken Grotesk (body),
         Spline Sans Mono (ledger/labels)
   Shape: sharp corners, hairline rules, comb-tick motif
   ========================================================= */

:root{
  --ink:#161210;        /* warm near-black (vulcanite) */
  --ink-2:#211a16;      /* raised dark surface */
  --espresso:#2a1f19;   /* secondary dark */
  --cordovan:#7a2d28;   /* strop leather — primary accent */
  --cordovan-lt:#a4453c;/* lighter cordovan (on dark) */
  --tobacco:#b07a45;    /* warm wood/leather mid */
  --tobacco-lt:#caa477; /* soft tan (secondary accent) */
  --bone:#ece3d4;       /* towel / light ground */
  --bone-2:#e1d5c2;     /* deeper bone */
  --bone-3:#d3c4ac;     /* bone edge / rules on light */
  --muted-d:#b8a892;    /* muted text on dark (AA on ink) */
  --muted-l:#5a4d3b;    /* muted text on bone (AA on bone & bone-2) */
  --err-d:#e0917f;      /* error text on dark form */

  --maxw:1180px;
  --gutter:clamp(20px,5vw,64px);
  --r:0px;              /* sharp shape language */

  --f-disp:'Big Shoulders Display',-apple-system,system-ui,sans-serif;
  --f-body:'Hanken Grotesk',-apple-system,system-ui,sans-serif;
  --f-mono:'Spline Sans Mono',ui-monospace,'SFMono-Regular',monospace;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--bone);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3,h4{margin:0;line-height:1.02}
p{margin:0}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
ul{margin:0;padding:0;list-style:none}

.shell{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}

.skip-link{position:absolute;left:-999px;top:0;background:var(--cordovan);color:var(--bone);
  padding:10px 16px;z-index:200;font-family:var(--f-mono);font-size:.8rem}
.skip-link:focus{left:8px;top:8px}

/* ---------- eyebrow / shared section heads ---------- */
.eyebrow{
  font-family:var(--f-mono);
  font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--tobacco-lt);margin:0 0 18px;font-weight:500;
  display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--cordovan-lt)}
.eyebrow-dark{color:var(--cordovan)}
.eyebrow-dark::before{background:var(--cordovan)}

.sec-head{max-width:640px;margin-bottom:clamp(40px,6vw,68px)}
.sec-title{
  font-family:var(--f-disp);font-weight:700;
  font-size:clamp(2.5rem,6vw,4.6rem);
  letter-spacing:-.01em;text-transform:uppercase;line-height:.94;
}
.sec-lead{margin-top:22px;font-size:1.08rem;color:var(--muted-l);max-width:52ch}
.sec-head-light .sec-lead{color:var(--muted-d)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--f-mono);font-weight:500;font-size:.82rem;
  letter-spacing:.08em;text-transform:uppercase;
  padding:13px 22px;border:1px solid transparent;border-radius:var(--r);
  cursor:pointer;transition:background .22s var(--ease),color .22s var(--ease),border-color .22s var(--ease);
  white-space:nowrap;
}
.btn-solid{background:var(--cordovan);color:var(--bone);border-color:var(--cordovan)}
.btn-solid:hover{background:var(--ink);border-color:var(--ink);color:var(--bone)}
.btn-ghost{background:transparent;color:var(--bone);border-color:rgba(236,227,212,.4)}
.btn-ghost:hover{border-color:var(--bone);background:rgba(236,227,212,.08)}
.btn-lg{padding:16px 28px;font-size:.86rem}
.btn-block{width:100%}
.btn-text{
  font-family:var(--f-mono);font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);padding:13px 4px;position:relative;
}
.btn-text span{transition:transform .25s var(--ease);display:inline-block}
.btn-text::after{content:"";position:absolute;left:4px;right:4px;bottom:8px;height:1px;
  background:var(--cordovan);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.btn-text:hover::after{transform:scaleX(1)}
.btn-text:hover span{transform:translateX(4px)}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s var(--ease),box-shadow .3s var(--ease);}
.site-header::before{content:"";position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(22,18,16,.55),rgba(22,18,16,0));
  pointer-events:none;transition:opacity .3s var(--ease);}
.header-inner{display:flex;align-items:center;gap:24px;height:74px;position:relative}
.brand{display:flex;align-items:center;gap:11px;color:var(--bone);margin-right:auto;transition:color .3s var(--ease)}
.brand-mark{color:var(--cordovan-lt);display:flex;transition:color .3s var(--ease)}
.brand-word{font-family:var(--f-disp);font-weight:700;font-size:1.7rem;letter-spacing:.02em;text-transform:uppercase}
.nav-links{display:flex;gap:30px}
.nav-links a{font-family:var(--f-mono);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--bone);opacity:.82;position:relative;padding:6px 0;transition:opacity .2s,color .3s}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--cordovan-lt);
  transform:scaleX(0);transform-origin:left;transition:transform .26s var(--ease)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{transform:scaleX(1)}
.header-cta{display:flex;gap:10px}

/* scrolled state */
.site-header.scrolled{background:var(--bone);box-shadow:0 1px 0 var(--bone-3)}
.site-header.scrolled::before{opacity:0}
.site-header.scrolled .brand{color:var(--ink)}
.site-header.scrolled .brand-mark{color:var(--cordovan)}
.site-header.scrolled .nav-links a{color:var(--ink);opacity:.78}
.site-header.scrolled .nav-links a:hover{opacity:1;color:var(--cordovan)}
.site-header.scrolled .btn-ghost{color:var(--ink);border-color:rgba(22,18,16,.28)}
.site-header.scrolled .btn-ghost:hover{border-color:var(--ink);background:rgba(22,18,16,.05)}

/* hamburger */
.hamburger{display:none;width:42px;height:42px;background:transparent;border:1px solid rgba(236,227,212,.4);
  border-radius:var(--r);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hamburger span{width:18px;height:1.6px;background:var(--bone);transition:transform .26s var(--ease),opacity .2s}
.site-header.scrolled .hamburger{border-color:rgba(22,18,16,.28)}
.site-header.scrolled .hamburger span{background:var(--ink)}
.hamburger.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{position:fixed;inset:74px 0 auto 0;z-index:99;background:var(--ink);
  border-bottom:1px solid var(--espresso);transform-origin:top;}
.mobile-menu nav{display:flex;flex-direction:column;padding:18px var(--gutter) 30px}
.mobile-menu a{font-family:var(--f-mono);text-transform:uppercase;letter-spacing:.08em;font-size:.92rem;
  color:var(--bone);padding:15px 0;border-bottom:1px solid rgba(236,227,212,.1)}
.mobile-menu .mm-call{color:var(--tobacco-lt)}
.mobile-menu .mm-book{margin-top:20px;border:none}
.mobile-menu .mm-book{justify-content:center}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;background:var(--ink);color:var(--bone);
  padding:clamp(120px,17vh,180px) 0 0;overflow:hidden}
.hero::before{content:"";position:absolute;top:0;right:0;width:46%;height:100%;
  background:radial-gradient(120% 80% at 100% 0%,rgba(122,45,40,.26),transparent 60%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:48px;align-items:center;
  padding-bottom:clamp(70px,11vh,120px);position:relative}
.hero-copy{max-width:660px}
.hero-title{
  font-family:var(--f-disp);font-weight:800;text-transform:uppercase;
  font-size:clamp(3.4rem,11vw,8.2rem);line-height:.86;letter-spacing:-.015em;margin:6px 0 0;
}
.hero-title span{display:block}
.hero-accent{color:transparent;background:linear-gradient(95deg,var(--cordovan-lt) 0%,var(--tobacco) 60%,var(--tobacco-lt) 100%);
  -webkit-background-clip:text;background-clip:text}
@supports not ((-webkit-background-clip:text) or (background-clip:text)){
  .hero-accent{color:var(--tobacco-lt);background:none}
}
.hero-sub{margin-top:30px;font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--muted-d);max-width:46ch;line-height:1.55}
.hero-actions{display:flex;align-items:center;gap:18px;margin-top:38px;flex-wrap:wrap}
.hero-actions .btn-text{color:var(--bone)}
.hero-actions .btn-text::after{background:var(--tobacco-lt)}
.hero-meta{display:flex;gap:26px;margin-top:46px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-d)}
.hero-meta li{position:relative;padding-left:18px}
.hero-meta li::before{content:"";position:absolute;left:0;top:50%;width:7px;height:1px;background:var(--cordovan-lt)}

/* THE FADE signature */
.hero-fade{position:relative;align-self:stretch;min-height:340px;display:flex}
.fade-panel{position:relative;flex:1;border:1px solid rgba(236,227,212,.16);overflow:hidden;
  background:
    repeating-linear-gradient(to bottom,transparent 0,transparent 6px,rgba(236,227,212,.05) 6px,rgba(236,227,212,.05) 7px),
    linear-gradient(to bottom,var(--bone) 0%,var(--tobacco) 26%,var(--cordovan) 58%,var(--ink-2) 100%);
}
/* clipper-guard fade lines that tighten toward the dark end */
.fade-panel::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:
    repeating-linear-gradient(to bottom,rgba(22,18,16,.32) 0,rgba(22,18,16,.32) 1px,transparent 1px,transparent 3px);
  -webkit-mask-image:linear-gradient(to bottom,transparent 38%,#000 100%);
  mask-image:linear-gradient(to bottom,transparent 38%,#000 100%);}
.razor-draw{position:absolute;inset:0;margin:auto;width:62%;height:auto;z-index:2}
.razor-line{fill:none;stroke:var(--bone);stroke-width:3.4;stroke-linecap:square;stroke-linejoin:round;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}
.fade-tag{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);z-index:3;
  font-family:var(--f-mono);font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--bone);opacity:.85}

/* JS draw-on animation */
.js-ready .razor-line{stroke-dasharray:var(--len,520);stroke-dashoffset:var(--len,520)}
.js-ready .hero-fade.is-in .razor-line{animation:drawRazor 1.5s var(--ease) forwards}
.js-ready .hero-fade.is-in .razor-line:nth-child(2){animation-delay:.5s}
@keyframes drawRazor{to{stroke-dashoffset:0}}

/* comb-tick rule */
.tick-rule{height:14px;position:relative;
  background:repeating-linear-gradient(to right,var(--cordovan) 0,var(--cordovan) 1.5px,transparent 1.5px,transparent 9px);
  opacity:.9}

/* =========================================================
   TICKER
   ========================================================= */
.ticker{background:var(--cordovan);color:var(--bone);overflow:hidden;padding:18px 16px;
  border-bottom:1px solid rgba(0,0,0,.15)}
.ticker-track{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:2px 4px;
  font-family:var(--f-disp);font-weight:600;font-size:clamp(1rem,2vw,1.25rem);letter-spacing:.05em;text-transform:uppercase}
.ticker-track span{padding:2px 20px}
.ticker-track .dot{color:var(--tobacco-lt);padding:2px 2px}

/* =========================================================
   SERVICES
   ========================================================= */
.services{background:var(--bone);padding:clamp(72px,11vw,128px) 0}
.svc-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,84px)}
.svc-cat{font-family:var(--f-disp);font-weight:700;text-transform:uppercase;font-size:1.7rem;letter-spacing:.01em;
  display:flex;align-items:baseline;gap:14px;padding-bottom:18px;border-bottom:2px solid var(--ink);margin-bottom:6px}
.svc-num{font-family:var(--f-mono);font-size:.72rem;font-weight:500;color:var(--cordovan);letter-spacing:.1em}
.svc-row{display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  padding:17px 8px 17px 14px;position:relative;border-bottom:1px solid var(--bone-3);transition:padding .25s var(--ease)}
.svc-row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--cordovan);
  transform:scaleY(0);transform-origin:center;transition:transform .25s var(--ease)}
.svc-row:hover{padding-left:22px;background:linear-gradient(to right,rgba(122,45,40,.05),transparent 60%)}
.svc-row:hover::before{transform:scaleY(1)}
.svc-name{font-weight:600;font-size:1.04rem;color:var(--ink)}
.svc-name em{display:block;font-style:normal;font-family:var(--f-mono);font-size:.72rem;letter-spacing:.04em;
  text-transform:uppercase;color:var(--muted-l);margin-top:3px;font-weight:400}
.svc-price{font-family:var(--f-mono);font-weight:500;font-size:1.04rem;color:var(--cordovan);
  font-variant-numeric:tabular-nums}
.svc-row:hover .svc-price{color:var(--ink)}
.svc-foot{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-top:clamp(40px,6vw,64px);padding-top:34px;border-top:1px solid var(--bone-3)}
.svc-foot p{font-size:1.06rem;color:var(--muted-l);max-width:46ch}

/* =========================================================
   THE CRAFT
   ========================================================= */
.craft{background:var(--ink);color:var(--bone);padding:clamp(72px,11vw,128px) 0;position:relative}
.craft::before{content:"";position:absolute;top:0;left:0;right:0;height:14px;
  background:repeating-linear-gradient(to right,var(--espresso) 0,var(--espresso) 1.5px,transparent 1.5px,transparent 9px)}
.craft-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.craft-card{padding:34px 30px 38px;border-left:1px solid rgba(236,227,212,.13);position:relative;
  transition:background .3s var(--ease)}
.craft-card:first-child{border-left:none}
.craft-card::after{content:"";position:absolute;left:-1px;top:0;width:1px;height:0;background:var(--cordovan-lt);transition:height .35s var(--ease)}
.craft-card:hover{background:rgba(236,227,212,.03)}
.craft-card:hover::after{height:100%}
.craft-icon{color:var(--tobacco-lt);display:block;width:48px;height:48px;margin-bottom:26px;transition:color .3s var(--ease)}
.craft-icon svg{width:48px;height:48px}
.craft-card:hover .craft-icon{color:var(--cordovan-lt)}
.craft-card h3{font-family:var(--f-disp);font-weight:700;text-transform:uppercase;font-size:1.5rem;
  letter-spacing:.01em;margin-bottom:12px}
.craft-card p{font-size:.96rem;color:var(--muted-d);line-height:1.6}

/* =========================================================
   VISIT
   ========================================================= */
.visit{background:var(--bone-2);padding:clamp(72px,11vw,128px) 0}
.visit-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:stretch}
.visit-rows{margin-top:42px;display:flex;flex-direction:column;gap:30px}
.visit-block{padding-left:18px;border-left:2px solid var(--cordovan)}
.vb-label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted-l);font-weight:500;margin-bottom:9px}
.vb-body{font-size:1.12rem;color:var(--ink);line-height:1.5}
.hours{border-collapse:collapse;width:100%;max-width:320px}
.hours th,.hours td{text-align:left;padding:8px 0;font-size:1rem;border-bottom:1px solid var(--bone-3)}
.hours th{font-weight:600;color:var(--ink);font-family:var(--f-body)}
.hours td{font-family:var(--f-mono);font-size:.9rem;color:var(--muted-l);text-align:right;font-variant-numeric:tabular-nums}
.hours tr{transition:background .2s var(--ease)}
.hours tr:hover{background:rgba(122,45,40,.06)}
.inline-link{color:var(--cordovan);font-weight:600;border-bottom:1px solid rgba(122,45,40,.35);transition:border-color .2s,color .2s}
.inline-link:hover{color:var(--ink);border-color:var(--ink)}

/* map panel */
.map-panel{position:relative;background:var(--ink);overflow:hidden;min-height:420px;border:1px solid var(--espresso)}
.map-grid{position:absolute;inset:0;
  background-image:linear-gradient(rgba(236,227,212,.06) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(236,227,212,.06) 1px,transparent 1px);
  background-size:34px 34px}
.map-river{position:absolute;left:-10%;right:-10%;bottom:8%;height:62px;transform:rotate(-7deg);
  background:linear-gradient(90deg,transparent,rgba(176,122,69,.22),transparent);
  border-top:1px solid rgba(176,122,69,.3);border-bottom:1px solid rgba(176,122,69,.18)}
.map-roads{position:absolute;inset:0;width:100%;height:100%}
.map-roads line{stroke:rgba(236,227,212,.16);stroke-width:1.4}
.map-pin{position:absolute;left:46%;top:42%;display:flex;align-items:center;gap:12px}
.pin-dot{width:16px;height:16px;background:var(--cordovan);border:3px solid var(--bone);border-radius:50%;
  position:relative;flex:none;box-shadow:0 0 0 6px rgba(122,45,40,.25)}
.pin-label{font-family:var(--f-disp);font-weight:700;text-transform:uppercase;color:var(--bone);font-size:1.15rem;line-height:1}
.pin-label em{display:block;font-family:var(--f-mono);font-style:normal;font-size:.62rem;letter-spacing:.14em;
  color:var(--tobacco-lt);margin-top:5px;font-weight:400}
.map-tag{position:absolute;left:18px;bottom:16px;font-family:var(--f-mono);font-size:.68rem;
  letter-spacing:.2em;text-transform:uppercase;color:var(--muted-d)}

/* =========================================================
   BOOK
   ========================================================= */
.book{background:var(--ink);color:var(--bone);padding:clamp(72px,11vw,128px) 0}
.book-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,80px);align-items:start}
.book-intro .sec-lead{color:var(--muted-d)}
.book-intro .inline-link{color:var(--tobacco-lt);border-color:rgba(202,164,119,.4)}
.book-intro .inline-link:hover{color:var(--bone);border-color:var(--bone)}
.book-points{margin-top:34px;display:flex;flex-direction:column;gap:16px}
.book-points li{position:relative;padding-left:30px;font-family:var(--f-mono);font-size:.84rem;
  letter-spacing:.04em;color:var(--muted-d);text-transform:uppercase}
.book-points li::before{content:"";position:absolute;left:0;top:.5em;width:16px;height:1px;background:var(--cordovan-lt)}

/* form */
.book-form{background:var(--ink-2);border:1px solid var(--espresso);padding:clamp(26px,3.5vw,42px);position:relative}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.field{margin-bottom:20px;display:flex;flex-direction:column}
.field label{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted-d);margin-bottom:9px}
.field label .opt{color:var(--muted-l);letter-spacing:.08em}
.field input,.field select,.field textarea{
  font-family:var(--f-body);font-size:1rem;color:var(--bone);background:var(--ink);
  border:1px solid #3a2c24;border-radius:var(--r);padding:13px 14px;width:100%;transition:border-color .2s var(--ease)}
.field textarea{resize:vertical;min-height:84px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'%3E%3Cpath d='M3 5l4 4 4-4' stroke='%23caa477' stroke-width='1.6' fill='none' stroke-linecap='square'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;cursor:pointer}
.field input::placeholder,.field textarea::placeholder{color:#6f5e4e}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--tobacco)}
.field.invalid input,.field.invalid select{border-color:var(--cordovan-lt)}
.field-err{font-family:var(--f-mono);font-size:.7rem;letter-spacing:.04em;color:var(--err-d);
  margin-top:7px;height:0;opacity:0;overflow:hidden;transition:opacity .2s}
.field.invalid .field-err{height:auto;opacity:1}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-fineprint{font-family:var(--f-mono);font-size:.68rem;letter-spacing:.04em;color:var(--muted-d);
  text-align:center;margin-top:16px;text-transform:uppercase}
.form-success{text-align:center;padding:24px 8px 8px}
.success-mark{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;
  border:1px solid var(--tobacco);color:var(--tobacco-lt);margin-bottom:18px}
.success-mark svg{width:30px;height:30px}
.form-success h3{font-family:var(--f-disp);font-weight:700;text-transform:uppercase;font-size:1.8rem;margin-bottom:10px}
.form-success p{color:var(--muted-d);max-width:34ch;margin:0 auto}

/* =========================================================
   FAQ
   ========================================================= */
.faq{background:var(--bone);padding:clamp(72px,11vw,128px) 0}
.faq-list{border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--bone-3)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:20px;cursor:pointer;
  padding:26px 6px;list-style:none;font-family:var(--f-disp);font-weight:600;text-transform:uppercase;
  font-size:clamp(1.2rem,2.4vw,1.7rem);letter-spacing:.01em;color:var(--ink);transition:color .2s var(--ease)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--cordovan)}
.faq-plus{position:relative;width:18px;height:18px;flex:none}
.faq-plus::before,.faq-plus::after{content:"";position:absolute;background:var(--cordovan);transition:transform .3s var(--ease)}
.faq-plus::before{left:0;top:8px;width:18px;height:2px}
.faq-plus::after{left:8px;top:0;width:2px;height:18px}
.faq-item[open] .faq-plus::after{transform:scaleY(0)}
.faq-body{padding:0 6px 28px;max-width:64ch;overflow:hidden}
.faq-item:not([open]) .faq-body{display:none}
.faq-body p{color:var(--muted-l);font-size:1.04rem}
.faq-item[open] .faq-body{display:block;animation:faqIn .28s var(--ease)}
@keyframes faqIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.faq-item[open] .faq-body{animation:none}}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--ink);color:var(--bone);padding:clamp(60px,9vw,96px) 0 38px}
.footer-top{display:grid;grid-template-columns:1.2fr 2fr;gap:48px}
.footer-word{font-family:var(--f-disp);font-weight:800;text-transform:uppercase;
  font-size:clamp(3.4rem,9vw,6rem);line-height:.8;letter-spacing:.01em;display:block;color:var(--bone)}
.footer-tag{font-family:var(--f-mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--tobacco-lt);margin-top:18px}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.footer-col h4{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted-d);margin-bottom:14px;font-weight:500}
.footer-col p{color:var(--bone-2);font-size:.98rem;line-height:1.7}
.footer-col .inline-link{color:var(--tobacco-lt);border-color:rgba(202,164,119,.35)}
.footer-col .inline-link:hover{color:var(--bone);border-color:var(--bone)}
.footer-rule{height:10px;margin:clamp(40px,6vw,60px) 0 26px;
  background:repeating-linear-gradient(to right,var(--espresso) 0,var(--espresso) 1.5px,transparent 1.5px,transparent 9px)}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-d)}

/* =========================================================
   REVEAL (gated behind js-ready)
   ========================================================= */
.js-ready .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js-ready .reveal.is-in{opacity:1;transform:none}
.js-ready .hero .reveal[data-rev="1"]{transition-delay:.05s}
.js-ready .hero .reveal[data-rev="2"]{transition-delay:.15s}
.js-ready .hero .reveal[data-rev="3"]{transition-delay:.27s}
.js-ready .hero .reveal[data-rev="4"]{transition-delay:.4s}
.js-ready .hero .reveal[data-rev="5"]{transition-delay:.52s}
.js-ready .hero .reveal[data-rev="6"]{transition-delay:.62s}
@media (prefers-reduced-motion:reduce){
  .js-ready .reveal{opacity:1;transform:none;transition:none}
  .js-ready .razor-line{stroke-dashoffset:0;animation:none}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .nav-links{display:none}
  .header-cta{display:none}
  .hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:0}
  .hero-fade{display:none}
  .craft-grid{grid-template-columns:1fr 1fr}
  .craft-card{border-top:1px solid rgba(236,227,212,.13)}
  .craft-card:nth-child(-n+2){border-top:none}
  .craft-card:nth-child(odd){border-left:none}
  .book-grid{grid-template-columns:1fr;gap:40px}
}
@media (max-width:720px){
  body{font-size:16px}
  .svc-cols{grid-template-columns:1fr;gap:48px}
  .visit-grid{grid-template-columns:1fr}
  .map-panel{min-height:320px;order:-1}
  .footer-top{grid-template-columns:1fr;gap:36px}
  .footer-cols{grid-template-columns:1fr 1fr}
  .field-row{grid-template-columns:1fr;gap:0}
  .hero{padding-top:104px}
  .hero-title{font-size:clamp(3rem,15vw,5rem)}
  .svc-foot{flex-direction:column;align-items:flex-start;gap:18px}
}
@media (max-width:430px){
  .craft-grid{grid-template-columns:1fr}
  .craft-card{border-left:none;border-top:1px solid rgba(236,227,212,.13)}
  .craft-card:first-child{border-top:none}
  .footer-cols{grid-template-columns:1fr}
  .hero-meta{gap:14px 22px}
}
