/* =====================================================================
   FATHERS BARBERS SALON — Design System
   Aesthetic: warm dark wood · rose gold · leather · engraved serif
   ===================================================================== */

:root{
  /* --- palette --- */
  --obsidian:   #14100D;
  --espresso:   #1C1612;
  --espresso-2: #241B15;
  --leather:    #2E2017;
  --leather-2:  #3A2A1E;
  --line:       rgba(206,148,104,.22);

  --rose:       #CE9468;   /* primary rose-gold */
  --rose-lite:  #E8C3A0;   /* highlight */
  --rose-deep:  #9E5C3C;   /* shadowed copper */
  --rose-glow:  rgba(206,148,104,.5);

  --cream:      #F2E8DA;
  --parch:      #E2D5C4;
  --muted:      #B0A08C;
  --muted-2:    #8A7C6C;

  --maxw: 1180px;
  --gutter: clamp(1.25rem, 4vw, 3rem);

  --serif:   "Cormorant Garamond", Georgia, serif;
  --display: "Cinzel", Georgia, serif;
  --ui:      "Jost", -apple-system, system-ui, sans-serif;

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

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms!important; transition-duration:.001ms!important; }
}

body{
  margin:0;
  background:var(--obsidian);
  color:var(--parch);
  font-family:var(--serif);
  font-size:clamp(1.06rem,.55vw + .95rem,1.22rem);
  line-height:1.7;
  font-weight:500;
  letter-spacing:.005em;
  overflow-x:hidden;
  position:relative;
}

/* film-grain overlay across whole page */
body::after{
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{ max-width:100%; height:auto; display:block; }
a{ color:var(--rose-lite); text-decoration:none; }

/* ---------- typography ---------- */
h1,h2,h3{ font-family:var(--display); font-weight:600; line-height:1.08;
  color:var(--cream); letter-spacing:.01em; margin:0 0 .5em; }
.h-xl{ font-size:clamp(2.7rem,7vw,5.4rem); }
.h-lg{ font-size:clamp(2.1rem,4.6vw,3.6rem); }
.h-md{ font-size:clamp(1.5rem,2.6vw,2.1rem); }
p{ margin:0 0 1.1em; }
.lead{ font-size:clamp(1.25rem,1.4vw,1.55rem); color:var(--cream); }
.muted{ color:var(--muted); }

.eyebrow{
  font-family:var(--ui); font-weight:500; text-transform:uppercase;
  letter-spacing:.42em; font-size:.72rem; color:var(--rose);
  display:inline-block; margin:0 0 1.1rem; padding-left:.42em;
}
.gold{
  background:linear-gradient(175deg,var(--rose-lite),var(--rose) 48%,var(--rose-deep));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.script{ font-style:italic; }

/* decorative rose-gold divider with center diamond */
.rule{ display:flex; align-items:center; gap:1rem; margin:1.6rem 0; }
.rule::before,.rule::after{ content:""; height:1px; flex:1;
  background:linear-gradient(90deg,transparent,var(--rose-deep),transparent); }
.rule i{ width:7px; height:7px; transform:rotate(45deg);
  border:1px solid var(--rose); background:var(--rose-glow); }
.rule.left::before{ display:none; }
.rule.left{ justify-content:flex-start; }
.rule.left::after{ max-width:120px; }

/* ---------- layout ---------- */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding:clamp(4rem,9vw,7.5rem) 0; position:relative; }
.section--tight{ padding:clamp(3rem,6vw,4.5rem) 0; }
.center{ text-align:center; }
.measure{ max-width:62ch; }
.measure.center{ margin-inline:auto; }

/* ---------- buttons ---------- */
.btn{ font-family:var(--ui); font-weight:500; letter-spacing:.16em;
  text-transform:uppercase; font-size:.8rem; cursor:pointer;
  display:inline-flex; align-items:center; gap:.6em; padding:1.05em 2.1em;
  border:1px solid transparent; border-radius:2px; transition:.4s var(--ease);
  position:relative; white-space:nowrap; }
.btn-gold{ color:#1a120c;
  background:linear-gradient(140deg,var(--rose-lite),var(--rose) 55%,var(--rose-deep));
  box-shadow:0 10px 30px -12px var(--rose-glow), inset 0 1px 0 rgba(255,255,255,.35); }
.btn-gold:hover{ transform:translateY(-2px);
  box-shadow:0 18px 40px -14px var(--rose-glow), inset 0 1px 0 rgba(255,255,255,.5); }
.btn-ghost{ color:var(--rose-lite); border-color:var(--line);
  background:rgba(255,255,255,.012); }
.btn-ghost:hover{ border-color:var(--rose); color:var(--cream);
  background:rgba(206,148,104,.07); }
.btn:focus-visible{ outline:2px solid var(--rose-lite); outline-offset:3px; }

/* ---------- header / nav ---------- */
.site-head{ position:sticky; top:0; z-index:100;
  background:rgba(20,16,13,.72); backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line); transition:.4s var(--ease); }
.site-head.scrolled{ background:rgba(16,12,10,.93); }
.nav{ display:flex; align-items:center; justify-content:space-between;
  gap:1.5rem; height:78px; }
.brand{ display:flex; align-items:center; gap:.72rem; }
.brand img{ width:42px; height:42px; filter:drop-shadow(0 2px 8px rgba(0,0,0,.6)); }
.brand b{ font-family:var(--display); font-weight:700; color:var(--cream);
  font-size:1.18rem; letter-spacing:.14em; line-height:1; }
.brand span{ display:block; font-family:var(--ui); font-size:.56rem;
  letter-spacing:.46em; color:var(--rose); text-transform:uppercase; margin-top:.32em; }

.nav-links{ display:flex; align-items:center; gap:2.1rem; list-style:none; margin:0; padding:0; }
.nav-links a{ font-family:var(--ui); font-size:.82rem; letter-spacing:.13em;
  text-transform:uppercase; color:var(--parch); font-weight:400;
  position:relative; padding:.4em 0; transition:color .3s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:0; height:1px;
  width:0; background:var(--rose); transition:width .35s var(--ease); }
.nav-links a:hover,.nav-links a[aria-current="page"]{ color:var(--cream); }
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{ width:100%; }
.nav-cta{ display:flex; align-items:center; gap:1.35rem; }
.nav-phone{ font-family:var(--ui); font-size:.82rem; letter-spacing:.08em; color:var(--parch);
  white-space:nowrap; padding:.4em 0; transition:color .3s; }
.nav-phone:hover{ color:var(--rose-lite); }

.nav-toggle{ display:none; background:none; border:0; cursor:pointer; padding:.5rem;
  flex-direction:column; gap:5px; }
.nav-toggle span{ width:26px; height:2px; background:var(--rose-lite);
  transition:.35s var(--ease); display:block; }

@media (max-width:940px){
  .nav-links,.nav-phone{ display:none; }
  .nav-toggle{ display:flex; }
  .mobile-menu{ position:fixed; inset:78px 0 0; z-index:99;
    background:linear-gradient(180deg,var(--espresso),var(--obsidian));
    border-top:1px solid var(--line);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:1.4rem; transform:translateY(-12px); opacity:0; visibility:hidden;
    transition:.4s var(--ease); padding:2rem; }
  .mobile-menu.open{ transform:none; opacity:1; visibility:visible; }
  .mobile-menu a{ font-family:var(--display); font-size:1.6rem; color:var(--cream);
    letter-spacing:.05em; }
  .mobile-menu a[aria-current="page"]{ color:var(--rose); }
  .mobile-menu .btn{ margin-top:1rem; }
  body.menu-open{ overflow:hidden; }
}
@media (min-width:941px){ .mobile-menu{ display:none; } }
@media (max-width:420px){ .brand b{ font-size:1.04rem; } .brand span span{ letter-spacing:.34em; font-size:.5rem; } .brand img{ width:36px; height:36px; } }

/* ---------- atmospheric backgrounds ---------- */
.bg-wood{
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(120,72,44,.30), transparent 60%),
    radial-gradient(90% 60% at 85% 110%, rgba(80,48,28,.28), transparent 65%),
    linear-gradient(180deg,var(--espresso),var(--obsidian));
}
.bg-leather{
  background:
    radial-gradient(80% 120% at 10% 0%, rgba(58,42,30,.6), transparent 55%),
    linear-gradient(180deg,var(--obsidian),var(--espresso-2));
}
/* faint barber-stripe texture band */
.stripe-band{ position:relative; }
.stripe-band::before{ content:""; position:absolute; inset:0; opacity:.04; pointer-events:none;
  background:repeating-linear-gradient(135deg,var(--rose) 0 14px,transparent 14px 38px); }

/* ---------- HERO ---------- */
.hero{ position:relative; overflow:hidden; isolation:isolate;
  min-height:min(92vh,840px); display:flex; align-items:center;
  padding-block:clamp(4rem,10vw,6rem); }
.hero::before{ content:""; position:absolute; inset:0; z-index:-2;
  background:
    radial-gradient(70% 90% at 50% 18%, rgba(150,92,56,.42), transparent 60%),
    radial-gradient(120% 80% at 50% 120%, rgba(40,24,14,.9), transparent 70%),
    linear-gradient(180deg,#1a130e,#100b08); }
.hero::after{ content:""; position:absolute; inset:0; z-index:-1; opacity:.05; pointer-events:none;
  background:repeating-linear-gradient(125deg,var(--rose-lite) 0 2px,transparent 2px 7px); }
.hero-inner{ display:grid; gap:2.5rem; justify-items:center; text-align:center; width:100%; }

/* medallion framing the crest */
.medallion{ position:relative; width:clamp(180px,26vw,250px); aspect-ratio:1;
  display:grid; place-items:center; }
.medallion::before{ content:""; position:absolute; inset:-10%;
  border-radius:50%; z-index:-1;
  background:radial-gradient(circle, rgba(206,148,104,.28), transparent 70%);
  filter:blur(6px); }
.medallion::after{ content:""; position:absolute; inset:-3%; border-radius:50%;
  border:1px solid var(--rose); opacity:.55;
  box-shadow:0 0 50px -8px var(--rose-glow), inset 0 0 30px -10px var(--rose-glow); }
.medallion img{ width:100%; height:100%; object-fit:contain;
  filter:drop-shadow(0 18px 34px rgba(0,0,0,.7)); }

.hero h1{ margin:0; }
.hero .sub{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.5em;
  font-size:clamp(.7rem,1.4vw,.92rem); color:var(--parch); margin-top:-.2rem; }
.hero .tagline{ font-style:italic; font-size:clamp(1.3rem,2.2vw,1.8rem);
  color:var(--cream); max-width:24ch; }
.hero-actions{ display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; }

/* scroll cue */
.scroll-cue{ position:absolute; bottom:1.6rem; left:50%; transform:translateX(-50%);
  font-family:var(--ui); font-size:.62rem; letter-spacing:.4em; text-transform:uppercase;
  color:var(--muted-2); display:flex; flex-direction:column; align-items:center; gap:.6rem; }
.scroll-cue i{ width:1px; height:38px; background:linear-gradient(var(--rose),transparent);
  animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%{transform:scaleY(0);transform-origin:top} 40%{transform:scaleY(1);transform-origin:top}
  60%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ---------- generic page banner ---------- */
.banner{ position:relative; padding:clamp(5.5rem,12vw,8rem) 0 clamp(3rem,6vw,4.5rem);
  text-align:center; overflow:hidden; isolation:isolate; }
.banner::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(80% 120% at 50% 0%, rgba(140,84,50,.36), transparent 60%),
    linear-gradient(180deg,#191210,var(--obsidian)); }
.banner h1{ margin-bottom:.2em; }
.banner p{ color:var(--muted); max-width:54ch; margin-inline:auto; }

/* ---------- highlight cards ---------- */
.grid{ display:grid; gap:1.4rem; }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
@media (max-width:820px){ .cols-3{ grid-template-columns:1fr; } .cols-2{ grid-template-columns:1fr; } }

.card{ border:1px solid var(--line); border-radius:4px; padding:2.2rem 1.9rem;
  background:linear-gradient(165deg,rgba(58,42,30,.34),rgba(20,16,13,.2));
  position:relative; overflow:hidden; transition:.45s var(--ease); }
.card::before{ content:""; position:absolute; left:0; top:0; height:2px; width:0;
  background:linear-gradient(90deg,var(--rose-lite),var(--rose-deep)); transition:width .5s var(--ease); }
.card:hover{ transform:translateY(-4px); border-color:rgba(206,148,104,.4);
  background:linear-gradient(165deg,rgba(58,42,30,.5),rgba(20,16,13,.25)); }
.card:hover::before{ width:100%; }
.card .ic{ color:var(--rose); margin-bottom:1rem; }
.card h3{ font-size:1.18rem; letter-spacing:.04em; }
.card p{ color:var(--muted); font-size:1rem; margin:0; }

/* ---------- split feature ---------- */
.split{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem);
  align-items:center; }
.split.rev{ direction:rtl; } .split.rev>*{ direction:ltr; }
@media (max-width:880px){ .split{ grid-template-columns:1fr; } .split.rev{ direction:ltr; } }
.figure{ position:relative; }
.figure .frame{ position:relative; border:1px solid var(--line); padding:.7rem; border-radius:3px;
  background:linear-gradient(160deg,rgba(206,148,104,.12),transparent); }
.figure .frame::after{ content:""; position:absolute; inset:.7rem;
  box-shadow:inset 0 0 0 1px rgba(206,148,104,.25); pointer-events:none; }
.figure .inner{ aspect-ratio:4/5; border-radius:2px; overflow:hidden; }

/* tile look used for figures & gallery placeholders */
.tile{ width:100%; height:100%; display:grid; place-items:center; position:relative;
  background:
    radial-gradient(120% 100% at 30% 10%, rgba(120,74,46,.4), transparent 55%),
    linear-gradient(150deg,var(--leather-2),var(--obsidian)); }
.tile::before{ content:""; position:absolute; inset:0; opacity:.5; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E"); }
.tile svg{ width:46%; max-width:120px; color:var(--rose); opacity:.5; z-index:1; }
.tile .cap{ position:absolute; bottom:1rem; font-family:var(--ui); font-size:.62rem;
  letter-spacing:.34em; text-transform:uppercase; color:var(--muted); z-index:1; }

/* ---------- services menu ---------- */
.menu{ display:grid; grid-template-columns:1fr 1fr; gap:.2rem 4rem; }
@media (max-width:820px){ .menu{ grid-template-columns:1fr; } }
.svc{ display:flex; align-items:baseline; gap:1rem; padding:1.15rem 0;
  border-bottom:1px solid var(--line); }
.svc .nm{ font-family:var(--display); font-size:1.12rem; color:var(--cream);
  letter-spacing:.02em; white-space:nowrap; }
.svc .dot{ flex:1; border-bottom:1px dotted rgba(206,148,104,.35); transform:translateY(-4px); }
.svc .pr{ font-family:var(--ui); font-size:1rem; color:var(--rose-lite); letter-spacing:.06em; }
.svc .ds{ flex-basis:100%; font-size:.97rem; color:var(--muted); margin-top:.15rem; line-height:1.45; }

/* ---------- gallery ---------- */
.gallery{ columns:3 260px; column-gap:1.1rem; }
.gallery .shot{ break-inside:avoid; margin-bottom:1.1rem; border:1px solid var(--line);
  border-radius:3px; overflow:hidden; position:relative; transition:.45s var(--ease); }
.gallery .shot:hover{ border-color:rgba(206,148,104,.5); transform:translateY(-3px); }
.gallery .shot .tile{ aspect-ratio:var(--ar,3/4); }
.gallery .shot img{ width:100%; display:block; transition:transform .6s var(--ease); }
.gallery .shot:hover img{ transform:scale(1.04); }
.gallery .shot .cap{ position:absolute; left:0; right:0; bottom:0; padding:1.6rem 1rem .85rem;
  font-family:var(--ui); font-size:.6rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--cream); z-index:2; opacity:0; transition:opacity .4s var(--ease);
  background:linear-gradient(transparent, rgba(10,7,4,.82)); pointer-events:none; }
.gallery .shot:hover .cap{ opacity:1; }
.figure .inner img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ---------- hours / location ---------- */
.hours{ list-style:none; margin:0; padding:0; }
.hours li{ display:flex; justify-content:space-between; gap:1.5rem; padding:.85rem 0;
  border-bottom:1px solid var(--line); font-family:var(--ui); font-size:.95rem;
  letter-spacing:.05em; }
.hours li span:first-child{ color:var(--parch); text-transform:uppercase; font-size:.82rem; letter-spacing:.18em; }
.hours li span:last-child{ color:var(--cream); }
.hours li.today{ }
.hours li.today span{ color:var(--rose-lite); }
.hours li.closed span:last-child{ color:var(--muted-2); }
.info-line{ display:flex; gap:.9rem; align-items:flex-start; margin:0 0 1.2rem; }
.info-line .ic{ color:var(--rose); flex:none; margin-top:.15rem; }
.info-line a{ color:var(--cream); }
.info-line a:hover{ color:var(--rose-lite); }
.map-frame{ border:1px solid var(--line); border-radius:4px; overflow:hidden;
  padding:.5rem; background:linear-gradient(160deg,rgba(206,148,104,.1),transparent); }
.map-frame iframe{ display:block; width:100%; height:420px; border:0; border-radius:2px; filter:grayscale(.3) contrast(1.05); }

/* ---------- forms ---------- */
.form{ display:grid; gap:1.3rem; }
.field{ display:grid; gap:.5rem; }
.field label{ font-family:var(--ui); font-size:.72rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--rose); }
.field input,.field textarea,.field select{ font-family:var(--serif); font-size:1.08rem;
  color:var(--cream); background:rgba(20,16,13,.6); border:1px solid var(--line);
  border-radius:3px; padding:.95rem 1.1rem; transition:.3s; width:100%; }
.field textarea{ resize:vertical; min-height:140px; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none;
  border-color:var(--rose); box-shadow:0 0 0 3px rgba(206,148,104,.15);
  background:rgba(46,32,23,.5); }
.field input::placeholder,.field textarea::placeholder{ color:var(--muted-2); }
.hp{ position:absolute; left:-9999px; }
.form-note{ font-size:.92rem; color:var(--muted); }

/* ---------- big CTA band ---------- */
.cta-band{ position:relative; text-align:center; overflow:hidden; isolation:isolate;
  padding:clamp(4rem,9vw,6.5rem) 0; }
.cta-band::before{ content:""; position:absolute; inset:0; z-index:-1;
  background:radial-gradient(70% 130% at 50% 0%, rgba(150,92,56,.4), transparent 60%),
    linear-gradient(180deg,var(--espresso-2),var(--obsidian)); }
.cta-band::after{ content:""; position:absolute; inset:0; z-index:-1; opacity:.05;
  background:repeating-linear-gradient(135deg,var(--rose) 0 14px,transparent 14px 40px); }

/* ---------- footer ---------- */
.site-foot{ background:linear-gradient(180deg,var(--obsidian),#0c0805);
  border-top:1px solid var(--line); padding-top:clamp(3.5rem,7vw,5rem); }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1.2fr; gap:2.5rem; padding-bottom:3rem; }
@media (max-width:820px){ .foot-grid{ grid-template-columns:1fr; gap:2.2rem; } }
.foot-grid h4{ font-family:var(--ui); font-size:.72rem; letter-spacing:.28em;
  text-transform:uppercase; color:var(--rose); margin:0 0 1.2rem; }
.foot-brand .brand{ margin-bottom:1.1rem; }
.foot-brand p{ color:var(--muted); font-size:1rem; max-width:34ch; }
.foot-links{ list-style:none; margin:0; padding:0; display:grid; gap:.7rem; }
.foot-links a{ color:var(--parch); font-family:var(--ui); font-size:.86rem; letter-spacing:.06em; }
.foot-links a:hover{ color:var(--rose-lite); }
.foot-contact p{ color:var(--parch); font-size:1rem; margin:0 0 .7rem; }
.foot-contact a{ color:var(--cream); }
.foot-book{ display:inline-block; font-family:var(--ui); font-size:.84rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--rose-lite)!important; transition:color .3s, gap .3s; }
.foot-book:hover{ color:var(--cream)!important; }
.foot-bar{ border-top:1px solid var(--line); padding:1.6rem 0; display:flex;
  justify-content:space-between; gap:1rem; flex-wrap:wrap; align-items:center;
  font-family:var(--ui); font-size:.74rem; letter-spacing:.1em; color:var(--muted-2); }
.foot-bar a{ color:var(--muted); } .foot-bar a:hover{ color:var(--rose-lite); }
.foot-bar nav{ display:flex; gap:1.4rem; flex-wrap:wrap; }

/* ---------- reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

/* hero load animation */
.hero .reveal{ transform:translateY(34px); }

/* ---------- misc ---------- */
.list-check{ list-style:none; margin:1.4rem 0; padding:0; display:grid; gap:.9rem; }
.list-check li{ display:flex; gap:.9rem; align-items:flex-start; color:var(--parch); }
.list-check svg{ color:var(--rose); flex:none; margin-top:.35rem; }
.pill{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--ui);
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--rose-lite);
  border:1px solid var(--line); border-radius:99px; padding:.5em 1.1em; }
.legal h2{ margin-top:2.4rem; }
.legal h3{ font-family:var(--serif); color:var(--rose-lite); font-size:1.3rem; margin-top:1.8rem; }
.legal p,.legal li{ color:var(--muted); }
.legal{ max-width:74ch; }
.note-box{ border:1px solid var(--line); border-left:3px solid var(--rose);
  background:rgba(206,148,104,.06); padding:1.3rem 1.5rem; border-radius:3px; margin:1.6rem 0; }
.note-box p{ margin:0; color:var(--parch); font-size:1rem; }

/* ---------- accessibility utilities ---------- */
.sr-only{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.skip-link{ position:absolute; left:10px; top:-64px; z-index:2000;
  background:var(--rose); color:#1a120c; font-family:var(--ui); font-size:.82rem;
  letter-spacing:.06em; padding:.7em 1.2em; border-radius:0 0 4px 4px; transition:top .2s var(--ease); }
.skip-link:focus{ top:0; outline:2px solid var(--cream); outline-offset:2px; }
