/* ============================================================
   WHISKEY THIEF — bourbon bar & kitchen · Richland, MI
   "Oak & Ember" — charred oak · bourbon amber · aged brass
   Fonts: Fraunces (serif headings) · Oswald (labels/wordmark) · Inter (body)
   ============================================================ */

:root{
  --char:#160f08;        /* charred oak black */
  --char-2:#1d150c;
  --char-3:#271c10;
  --line:rgba(232,212,170,.12);
  --parch:#ecdfc6;       /* warm parchment text */
  --parch-dim:#a8967a;   /* muted tobacco */
  --amber:#cf8a2e;       /* bourbon amber (primary accent) */
  --amber-deep:#a8631b;  /* aged copper */
  --brass:#c9a35c;       /* aged brass (secondary highlight) */
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(135% 105% at 50% -18%, rgba(207,138,46,.13), transparent 52%),
    radial-gradient(110% 80% at 88% 6%, rgba(201,163,92,.06), transparent 46%),
    radial-gradient(150% 150% at 50% 58%, transparent 54%, rgba(0,0,0,.62)),
    var(--char);
  background-attachment:fixed;
  color:var(--parch);
  font-family:'Inter',sans-serif;
  font-weight:400;
  line-height:1.7;
  overflow-x:hidden;
}
::selection{background:var(--amber);color:#160f08}

h1,h2,h3,.serif{font-family:'Fraunces',serif;font-weight:600;line-height:1.18}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 6vw}

/* shared label / wordmark family */
.nav-logo,.foot-logo,.hero-title,.hero-sub,.nav-links,.hero-eyebrow,.sec-label,
.marquee span,.btn,.mi-badge,.mr-badge,.amenities span,.menu-cat-nav a,
.hero-stats span,.foot-col b,.foot-base,.ph-tag,.order-card span,.cform label,
.subhero .sec-label,.value .vtag{font-family:'Oswald',sans-serif}

/* ---------- reveal animations ---------- */
.rv{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.12s}.rv-d2{transition-delay:.24s}.rv-d3{transition-delay:.36s}.rv-d4{transition-delay:.48s}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* ---------- nav ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:1.4rem 6vw;display:flex;align-items:center;justify-content:space-between;
  transition:background .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent;
}
nav.scrolled{background:rgba(22,15,8,.9);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:.85rem 6vw;border-bottom-color:var(--line)}
.nav-logo{font-size:1.4rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase}
.nav-logo em{color:var(--amber);font-style:normal}
.nav-links{display:flex;gap:2.2rem;align-items:center;font-size:.82rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase}
.nav-links a{color:var(--parch-dim);transition:color .3s;position:relative}
.nav-links a:hover{color:var(--parch)}
.nav-links a.active{color:var(--parch)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--amber);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-links a.active::after{width:100%}
.nav-cta{
  border:1px solid var(--amber);color:var(--parch)!important;padding:.6rem 1.4rem;
  transition:background .3s,color .3s;
}
.nav-cta:hover{background:var(--amber);color:#160f08!important}
.nav-cta::after{display:none}
.nav-cta.active::after{display:none}
/* mobile menu toggle */
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;position:relative;z-index:60}
.nav-toggle span{position:absolute;left:0;width:100%;height:2px;background:var(--parch);transition:transform .35s,opacity .25s}
.nav-toggle span:nth-child(1){top:0}
.nav-toggle span:nth-child(2){top:10px}
.nav-toggle span:nth-child(3){top:20px}
.nav-toggle.open span:nth-child(1){transform:translateY(10px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-10px) rotate(-45deg)}
@media(max-width:820px){
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:2.4rem;
    background:rgba(22,15,8,.97);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    font-size:1.1rem;transform:translateX(100%);transition:transform .45s cubic-bezier(.2,.6,.2,1);
  }
  .nav-links.open{transform:none}
  .nav-links a::after{display:none}
}

/* ---------- generic page sub-hero (interior pages) ---------- */
.subhero{
  padding:11rem 6vw 5rem;position:relative;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.subhero .staves{height:100%;opacity:.5}
.subhero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}
.subhero .sec-label{justify-content:flex-start}
.subhero h1{font-size:clamp(2.8rem,7vw,5rem);font-weight:600;letter-spacing:.01em;margin:1rem 0 .8rem}
.subhero h1 em{font-style:normal;color:var(--amber)}
.subhero p{max-width:36rem;color:var(--parch-dim);font-size:1.08rem}
.subhero .vert-label{right:2vw;left:auto}

/* ---------- hero (home) ---------- */
header.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  position:relative;padding:9rem 6vw 4rem;
}
/* faint barrel-stave slats along the base */
.staves{
  position:absolute;left:0;right:0;bottom:0;height:34vh;opacity:.55;pointer-events:none;
  background-image:repeating-linear-gradient(90deg,rgba(232,212,170,.05) 0 1px,transparent 1px 15px);
  -webkit-mask-image:linear-gradient(to top,black,transparent);
  mask-image:linear-gradient(to top,black,transparent);
}
.hero-art{
  position:absolute;right:3vw;top:50%;transform:translateY(-50%);
  width:min(42vw,520px);aspect-ratio:1;pointer-events:none;
}
.hero-glow{
  position:absolute;inset:9%;border-radius:50%;
  background:radial-gradient(circle at 42% 36%,rgba(231,154,62,.6),rgba(168,99,27,.2) 54%,transparent 72%);
  filter:blur(4px);
  animation:emberpulse 7s ease-in-out infinite, sealrise 1.5s cubic-bezier(.2,.6,.2,1) both .25s;
}
@keyframes emberpulse{0%,100%{opacity:.85}50%{opacity:1;transform:scale(1.02)}}
@keyframes sealrise{from{opacity:0;transform:scale(.94)}to{opacity:.92;transform:none}}
.hero-art .seal{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.seal-ring{fill:none;stroke:var(--brass);stroke-width:1.5;opacity:.55}
.seal-ring2{fill:none;stroke:var(--amber);stroke-width:1;opacity:.4;stroke-dasharray:2 6;stroke-linecap:round}
.seal-rot{transform-box:view-box;transform-origin:200px 200px;animation:spin 48s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.seal-text{
  font-family:'Oswald',sans-serif;font-size:13px;font-weight:500;letter-spacing:.32em;
  fill:var(--parch);opacity:.62;text-transform:uppercase;
}
.seal-mono{
  font-family:'Fraunces',serif;font-weight:700;font-size:96px;text-anchor:middle;
  dominant-baseline:central;fill:var(--parch);
}
.seal-mono tspan{fill:var(--amber)}
@media(prefers-reduced-motion:reduce){.seal-rot{animation:none}.hero-glow{animation:sealrise 1.5s both}}
@media(max-width:900px){
  .hero-art{position:relative;right:auto;top:auto;transform:none;width:min(70vw,340px);margin:3rem auto 0;opacity:.9}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--brass);
}
.hero-eyebrow::before{content:"";width:34px;height:1px;background:var(--brass)}
.hero-title{
  font-size:clamp(3.6rem,11vw,9rem);font-weight:700;letter-spacing:.03em;text-transform:uppercase;
  line-height:.92;margin:1.2rem 0 .5rem;position:relative;z-index:2;
}
.hero-title em{font-style:normal;color:var(--amber)}
.hero-sub{
  font-size:clamp(1.1rem,3vw,1.8rem);font-weight:400;
  letter-spacing:.34em;text-transform:uppercase;color:var(--parch-dim);
  position:relative;z-index:2;
}
.hero-tag{max-width:35rem;margin:1.8rem 0 2.6rem;font-size:1.08rem;color:var(--parch-dim);position:relative;z-index:2}
.hero-tag strong{color:var(--parch);font-weight:600}
.hero-ctas{display:flex;gap:1.1rem;flex-wrap:wrap;position:relative;z-index:2}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:1.05rem 2.3rem;font-size:.82rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  transition:all .35s;border:1px solid transparent;cursor:pointer;
}
.btn-primary{background:var(--amber);color:#160f08}
.btn-primary:hover{background:var(--amber-deep);color:#fff;transform:translateY(-2px)}
.btn-ghost{border-color:var(--line);color:var(--parch)}
.btn-ghost:hover{border-color:var(--parch);transform:translateY(-2px)}
.hero-stats{
  display:flex;gap:0;margin-top:4rem;border-top:1px solid var(--line);
  position:relative;z-index:2;max-width:46rem;flex-wrap:wrap;
}
.hero-stats div{padding:1.4rem 2.4rem 0 0;margin-right:2.4rem}
.hero-stats b{display:block;font-family:'Fraunces',serif;font-size:1.7rem;font-weight:700;color:var(--parch)}
.hero-stats b .star{color:var(--brass)}
.hero-stats span{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--parch-dim)}
.vert-label{
  position:absolute;left:1.4vw;top:50%;transform:translateY(-50%);
  writing-mode:vertical-rl;font-family:'Oswald',sans-serif;
  font-size:.82rem;letter-spacing:.5em;text-transform:uppercase;color:var(--parch-dim);opacity:.4;
}
@media(max-width:900px){.vert-label{display:none}}

/* ---------- marquee ---------- */
.marquee{
  background:var(--amber);color:#160f08;overflow:hidden;white-space:nowrap;
  padding:.95rem 0;border-top:1px solid rgba(0,0,0,.18);border-bottom:1px solid rgba(0,0,0,.18);
}
.marquee-track{display:inline-block;animation:scroll 32s linear infinite}
.marquee span{
  font-size:.96rem;font-weight:600;letter-spacing:.26em;
  text-transform:uppercase;margin:0 1.6rem;
}
.marquee .dot{opacity:.5}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none}}

/* ---------- sections shared ---------- */
section{padding:8.5rem 0;position:relative}
.sec-label{
  display:flex;align-items:center;gap:1rem;font-size:.78rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--amber);margin-bottom:1.4rem;font-weight:500;
}
.sec-label::before{content:"";width:34px;height:1px;background:var(--amber)}
.sec-title{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:600;letter-spacing:.005em;margin-bottom:1.2rem}
.sec-title em{font-style:normal;color:var(--amber)}

/* ---------- story ---------- */
#story{background:var(--char-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.story-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:5rem;align-items:start}
@media(max-width:900px){.story-grid{grid-template-columns:1fr;gap:3rem}}
.story-text p{margin-bottom:1.4rem;color:var(--parch-dim);font-size:1.05rem}
.story-text p strong{color:var(--parch);font-weight:600}
.feature-card{
  background:var(--char-3);border:1px solid var(--line);padding:3rem 2.6rem;position:relative;
  margin-top:1rem;
}
.feature-card::before{
  content:"";position:absolute;top:-1px;left:-1px;width:56px;height:56px;
  border-top:2px solid var(--amber);border-left:2px solid var(--amber);
}
.feature-card::after{
  content:"";position:absolute;bottom:-1px;right:-1px;width:56px;height:56px;
  border-bottom:2px solid var(--amber);border-right:2px solid var(--amber);
}
.feature-icon{width:48px;height:48px;margin-bottom:1.5rem;color:var(--amber)}
.feature-card h3{font-size:1.7rem;margin-bottom:.9rem}
.feature-card p{color:var(--parch-dim);margin-bottom:1.3rem}
.feature-quote{
  border-left:2px solid var(--brass);padding-left:1.2rem;font-family:'Fraunces',serif;
  font-style:italic;color:var(--parch);font-size:1.02rem;line-height:1.6;
}
.feature-quote small{display:block;margin-top:.6rem;font-family:'Oswald',sans-serif;font-style:normal;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--parch-dim)}
.story-points{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:2.6rem;border:1px solid var(--line)}
@media(max-width:560px){.story-points{grid-template-columns:1fr}}
.story-points div{padding:1.6rem 1.7rem;border:1px solid var(--line);margin:-.5px}
.story-points b{display:block;font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;margin-bottom:.3rem}
.story-points span{font-size:.92rem;color:var(--parch-dim)}

/* ---------- menu (highlights grid, used on home) ---------- */
#menu .sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:3.4rem}
#menu .sec-head p{max-width:30rem;color:var(--parch-dim)}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line)}
@media(max-width:760px){.menu-grid{grid-template-columns:1fr}}
.menu-item{
  display:flex;justify-content:space-between;gap:2rem;align-items:baseline;
  padding:1.9rem 2.2rem;border:1px solid var(--line);margin:-.5px;
  transition:background .35s;position:relative;
}
.menu-item:hover{background:var(--char-2)}
.menu-item:hover .mi-name{color:var(--amber)}
.mi-name{font-family:'Fraunces',serif;font-size:1.18rem;font-weight:600;transition:color .3s}
.mi-badge{
  display:inline-block;margin-left:.7rem;
  font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass);
  border:1px solid rgba(201,163,92,.4);padding:.18rem .55rem;vertical-align:middle;white-space:nowrap;
}
.mi-desc{font-size:.9rem;color:var(--parch-dim);margin-top:.35rem;max-width:27rem}
.mi-price{font-family:'Fraunces',serif;font-size:1.1rem;color:var(--brass);white-space:nowrap}
.menu-note{margin-top:2.6rem;display:flex;align-items:center;justify-content:space-between;gap:1.6rem;flex-wrap:wrap}
.menu-note p{color:var(--parch-dim);font-size:.95rem}

/* ---------- full menu page ---------- */
.menu-cat-nav{
  position:sticky;top:0;z-index:40;background:rgba(22,15,8,.93);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.menu-cat-nav .inner{
  max-width:var(--maxw);margin:0 auto;padding:.9rem 6vw;
  display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;
}
.menu-cat-nav .inner::-webkit-scrollbar{display:none}
.menu-cat-nav a{
  white-space:nowrap;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--parch-dim);padding:.5rem .95rem;border:1px solid var(--line);
  transition:color .3s,border-color .3s,background .3s;
}
.menu-cat-nav a:hover,.menu-cat-nav a.active{color:var(--parch);border-color:var(--amber)}
.menu-section{padding:5rem 0 1rem;scroll-margin-top:70px}
.menu-section:first-of-type{padding-top:3rem}
.menu-cat-head{display:flex;align-items:baseline;gap:1.2rem;margin-bottom:2rem;flex-wrap:wrap}
.menu-cat-head h2{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:600}
.menu-cat-head .note{font-size:.85rem;color:var(--parch-dim);font-style:italic}
.menu-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line)}
@media(max-width:760px){.menu-list{grid-template-columns:1fr}}
.menu-row{
  display:flex;justify-content:space-between;gap:1.4rem;align-items:baseline;
  padding:1.25rem 1.6rem;border:1px solid var(--line);margin:-.5px;transition:background .3s;
}
.menu-row:hover{background:var(--char-2)}
.menu-row:hover .mr-name{color:var(--amber)}
.mr-name{font-family:'Fraunces',serif;font-size:1.04rem;font-weight:600;transition:color .3s}
.mr-desc{font-size:.84rem;color:var(--parch-dim);margin-top:.25rem;max-width:30rem;line-height:1.5}
.mr-price{font-family:'Fraunces',serif;font-size:1rem;color:var(--brass);white-space:nowrap}
.mr-badge{
  display:inline-block;margin-left:.6rem;font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brass);border:1px solid rgba(201,163,92,.4);padding:.14rem .5rem;vertical-align:middle;white-space:nowrap;
}

/* ---------- reviews ---------- */
#reviews{background:var(--char-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.rev-head{display:grid;grid-template-columns:auto 1fr;gap:4rem;align-items:center;margin-bottom:4rem}
@media(max-width:760px){.rev-head{grid-template-columns:1fr;gap:1.6rem}}
.rev-score{font-family:'Fraunces',serif;font-size:clamp(5rem,10vw,8rem);font-weight:700;line-height:1;color:var(--parch)}
.rev-score small{font-size:.35em;color:var(--parch-dim);font-weight:500}
.rev-stars{color:var(--brass);font-size:1.5rem;letter-spacing:.2em;margin:.4rem 0}
.rev-head p{color:var(--parch-dim);max-width:30rem;font-size:1.02rem}
.rev-head p b{color:var(--parch);font-weight:600}
.rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
@media(max-width:760px){.rev-grid{grid-template-columns:1fr}}
.rev-card{
  background:var(--char-3);border:1px solid var(--line);padding:2.4rem 2.3rem;
  display:flex;flex-direction:column;gap:1.3rem;transition:transform .35s,border-color .35s;
}
.rev-card:hover{transform:translateY(-4px);border-color:rgba(201,163,92,.4)}
.rev-card .q{font-family:'Fraunces',serif;font-size:1.08rem;line-height:1.65;color:var(--parch)}
.rev-card .q::before{content:"\201C";color:var(--amber);font-size:1.6em;line-height:0;vertical-align:-.25em;margin-right:.1em}
.rev-card .who{display:flex;align-items:center;gap:.8rem;margin-top:auto}
.rev-card .who .av{
  width:38px;height:38px;border-radius:50%;background:var(--amber-deep);
  display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;
  font-weight:700;color:#fff;font-size:.95rem;flex-shrink:0;
}
.rev-card .who b{display:block;font-weight:600;font-size:.92rem}
.rev-card .who span{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--parch-dim);font-family:'Oswald',sans-serif}
.rev-card .stars{color:var(--brass);font-size:.85rem;letter-spacing:.15em}

/* ---------- visit ---------- */
.visit-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:4.5rem;align-items:start}
@media(max-width:900px){.visit-grid{grid-template-columns:1fr;gap:3rem}}
.hours-table{width:100%;border-collapse:collapse;margin:2rem 0 2.4rem}
.hours-table td{padding:.85rem 0;border-bottom:1px solid var(--line);font-size:.98rem;color:var(--parch-dim)}
.hours-table td:last-child{text-align:right;color:var(--parch)}
.hours-table tr.today td{color:var(--brass)}
.hours-table tr.closed td:last-child{color:var(--amber);letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}
.visit-meta{display:flex;flex-direction:column;gap:1.1rem}
.visit-meta a{transition:color .3s}
.visit-meta a:hover{color:var(--amber)}
.visit-meta .row{display:flex;gap:1rem;align-items:flex-start;font-size:1rem;color:var(--parch-dim)}
.visit-meta .row svg{width:19px;height:19px;flex-shrink:0;margin-top:.25rem;color:var(--amber)}
.visit-meta .row b{color:var(--parch);font-weight:600}
.amenities{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.amenities span{
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--parch-dim);
  border:1px solid var(--line);padding:.45rem .9rem;
}
.map-frame{border:1px solid var(--line);position:relative;background:var(--char-2);aspect-ratio:4/3.4}
.map-frame::before{
  content:"";position:absolute;top:-1px;right:-1px;width:56px;height:56px;
  border-top:2px solid var(--brass);border-right:2px solid var(--brass);z-index:2;pointer-events:none;
}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(1) invert(.92) contrast(.88) sepia(.28) saturate(1.1)}
.map-fallback{
  position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.1rem;text-align:center;padding:2rem;background:var(--char-2);
  opacity:0;pointer-events:none;transition:opacity .5s;
}
.map-fallback.show{opacity:1;pointer-events:auto}
.map-fallback::before{
  content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background-image:repeating-linear-gradient(90deg,rgba(232,212,170,.05) 0 1px,transparent 1px 15px);
}
.map-fallback svg{width:44px;height:44px;color:var(--amber);position:relative}
.map-fallback b{font-family:'Fraunces',serif;font-size:1.25rem;font-weight:600;position:relative}
.map-fallback p{color:var(--parch-dim);font-size:.95rem;position:relative}

/* ---------- visit / call-ahead band (replaces delivery section) ---------- */
#order{background:var(--char-2);border-top:1px solid var(--line);text-align:center}
#order .sec-label{justify-content:center}
#order .sec-label::after{content:"";width:34px;height:1px;background:var(--amber)}
#order>.wrap>p{max-width:34rem;margin:0 auto 3.2rem;color:var(--parch-dim)}
.order-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;max-width:54rem;margin:0 auto}
@media(max-width:760px){.order-grid{grid-template-columns:1fr}}
.order-card{
  border:1px solid var(--line);padding:2.6rem 1.6rem;background:var(--char-3);
  display:flex;flex-direction:column;align-items:center;gap:.9rem;
  transition:transform .35s,border-color .35s;
}
.order-card:hover{transform:translateY(-5px);border-color:var(--amber)}
.order-card .glyph{color:var(--amber);line-height:1}
.order-card .glyph svg{width:32px;height:32px;display:block}
.order-card b{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:600}
.order-card span{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--parch-dim)}
.order-phone{margin-top:3rem;color:var(--parch-dim);font-size:.95rem}
.order-phone a{color:var(--brass);font-family:'Fraunces',serif;font-size:1.2rem;letter-spacing:.04em}
.order-phone a:hover{color:var(--amber)}

/* ---------- about page ---------- */
.about-lead{font-family:'Fraunces',serif;font-size:clamp(1.4rem,3vw,2rem);line-height:1.5;color:var(--parch);max-width:44rem;margin-bottom:2.2rem}
.about-lead em{font-style:normal;color:var(--amber)}
.about-body{max-width:44rem}
.about-body p{margin-bottom:1.5rem;color:var(--parch-dim);font-size:1.06rem}
.about-body p strong{color:var(--parch);font-weight:600}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);margin-top:1rem}
@media(max-width:760px){.values-grid{grid-template-columns:1fr}}
.value{padding:2.4rem 2rem;border:1px solid var(--line);margin:-.5px}
.value .vtag{color:var(--amber);font-size:1.5rem;font-weight:600;margin-bottom:1rem;display:block;letter-spacing:.08em}
.value h3{font-size:1.3rem;margin-bottom:.6rem}
.value p{color:var(--parch-dim);font-size:.96rem}
.pullquote{
  border-left:2px solid var(--brass);padding:.4rem 0 .4rem 1.8rem;margin:1rem 0;
  font-family:'Fraunces',serif;font-style:italic;font-size:1.2rem;color:var(--parch);line-height:1.6;
}
.pullquote small{display:block;margin-top:.7rem;font-family:'Oswald',sans-serif;font-style:normal;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--parch-dim)}

/* ---------- photo slots / gallery ---------- */
.photo-slot{
  position:relative;background:var(--char-3);border:1px solid var(--line);overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.photo-slot img{width:100%;height:100%;object-fit:cover;display:block}
.photo-slot::after{
  content:"";position:absolute;top:-1px;left:-1px;width:42px;height:42px;
  border-top:2px solid var(--amber);border-left:2px solid var(--amber);pointer-events:none;opacity:.5;
}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;grid-auto-rows:240px}
@media(max-width:760px){.gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}}
@media(max-width:480px){.gallery-grid{grid-template-columns:1fr;grid-auto-rows:220px}}
.gallery-grid .tall{grid-row:span 2}
.gallery-grid .wide{grid-column:span 2}
@media(max-width:480px){.gallery-grid .wide{grid-column:span 1}.gallery-grid .tall{grid-row:span 1}}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:4.5rem 0 2.5rem;position:relative;overflow:hidden}
.foot-grid{display:flex;justify-content:space-between;gap:3rem;flex-wrap:wrap;margin-bottom:3.5rem}
.foot-logo{font-family:'Oswald',sans-serif;font-size:1.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase}
.foot-logo em{color:var(--amber);font-style:normal}
.foot-col{font-size:.92rem;color:var(--parch-dim);line-height:2}
.foot-col b{display:block;color:var(--parch);font-weight:500;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;margin-bottom:.6rem}
.foot-col a:hover{color:var(--amber)}
.foot-motto{text-align:center;font-family:'Oswald',sans-serif;color:var(--parch-dim);letter-spacing:.42em;text-transform:uppercase;font-size:.8rem;margin-bottom:2rem;opacity:.6}
.foot-base{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:1.8rem;
  font-size:.74rem;letter-spacing:.1em;color:var(--parch-dim);text-transform:uppercase;
}
/* Gull Lake Digital credit — ALWAYS GLD brand blue, never re-themed to the client */
.foot-credit{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.28rem .85rem;border-radius:999px;
  background:rgba(63,181,173,.08);border:1px solid rgba(63,181,173,.3);
  font-family:'Oswald',sans-serif;font-size:.72rem;
  letter-spacing:.12em;color:#3fb5ad;text-transform:uppercase;
  text-decoration:none;transition:background .25s,border-color .25s;
}
.foot-credit:hover{background:rgba(63,181,173,.16);border-color:rgba(63,181,173,.6)}
.foot-credit svg{width:12px;height:12px;opacity:.8;flex-shrink:0}

/* ============================================================
   POLISH PASS — depth, focus, gallery tiles, FAQ, scroll cue
   ============================================================ */

a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--brass);outline-offset:3px;
}
summary:focus-visible{outline:2px solid var(--brass);outline-offset:3px}

.feature-card,.map-frame{box-shadow:0 30px 60px -42px rgba(0,0,0,.85)}

/* scroll cue (home hero) */
.scroll-cue{
  position:absolute;left:50%;bottom:2.2rem;transform:translateX(-50%);
  width:26px;height:42px;border:1px solid var(--line);border-radius:14px;
  display:flex;justify-content:center;padding-top:8px;z-index:3;transition:border-color .3s;
}
.scroll-cue:hover{border-color:var(--amber)}
.scroll-cue span{width:3px;height:8px;border-radius:2px;background:var(--brass);animation:scrollcue 1.9s ease-in-out infinite}
@keyframes scrollcue{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%{opacity:0;transform:translateY(13px)}100%{opacity:0}}
@media(max-width:900px){.scroll-cue{display:none}}
@media(prefers-reduced-motion:reduce){.scroll-cue span{animation:none;opacity:.7}}

/* ---- gallery photo-slot placeholder (no-photo state) ---- */
.photo-slot .ph{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.55rem;text-align:center;padding:1.4rem;overflow:hidden;
  background:linear-gradient(155deg,#2a1d10,#150d06);
}
.photo-slot .ph-mark{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:'Fraunces',serif;font-weight:900;font-size:4.6rem;line-height:1;letter-spacing:.04em;
  color:rgba(232,212,170,.06);pointer-events:none;transition:color .45s;user-select:none;white-space:nowrap;
}
.photo-slot .ph-name{position:relative;z-index:1;font-family:'Fraunces',serif;font-size:1.3rem;font-weight:600;color:var(--parch)}
.photo-slot .ph-tag{position:relative;z-index:1;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass)}
/* warm gradient variation per tile */
.gallery-grid .photo-slot:nth-child(7n+1) .ph{background:linear-gradient(155deg,#3a2410,#1a1107)}
.gallery-grid .photo-slot:nth-child(7n+2) .ph{background:linear-gradient(155deg,#2d2110,#171008)}
.gallery-grid .photo-slot:nth-child(7n+3) .ph{background:linear-gradient(155deg,#33260f,#161009)}
.gallery-grid .photo-slot:nth-child(7n+4) .ph{background:linear-gradient(155deg,#2a1d10,#150d06)}
.gallery-grid .photo-slot:nth-child(7n+5) .ph{background:linear-gradient(155deg,#3a2a14,#181008)}
.gallery-grid .photo-slot:nth-child(7n+6) .ph{background:linear-gradient(155deg,#291f12,#15100a)}
.gallery-grid .photo-slot:nth-child(7n) .ph{background:linear-gradient(155deg,#332310,#161009)}
.gallery-grid .photo-slot{transition:transform .45s,box-shadow .45s}
.gallery-grid .photo-slot:hover{transform:translateY(-5px);box-shadow:0 26px 50px -28px rgba(0,0,0,.75)}
.gallery-grid .photo-slot:hover .ph-mark{color:rgba(207,138,46,.16)}
.gallery-intro{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;flex-wrap:wrap;margin-bottom:2.2rem}
.gallery-intro p{color:var(--parch-dim);font-size:.98rem;max-width:36rem}
.gallery-intro a{color:var(--brass)}
.gallery-intro a:hover{color:var(--amber)}

/* ---- FAQ (contact) ---- */
.faq{max-width:48rem}
.faq details{border-bottom:1px solid var(--line)}
.faq details:first-of-type{border-top:1px solid var(--line)}
.faq summary{
  cursor:pointer;list-style:none;padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;gap:1.2rem;
  font-family:'Fraunces',serif;font-size:1.12rem;font-weight:500;color:var(--parch);transition:color .3s;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--amber);font-size:1.5rem;line-height:1;transition:transform .35s;flex-shrink:0}
.faq details[open] summary{color:var(--amber)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq-a{padding:0 0 1.6rem;color:var(--parch-dim);font-size:1rem;line-height:1.7;max-width:44rem}
.faq-a a{color:var(--brass)}
.faq-a a:hover{color:var(--amber)}

/* ---------- contact page form ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:3rem}}
.cform{display:flex;flex-direction:column;gap:1.3rem}
.cform label{display:block;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--parch-dim);margin-bottom:.5rem}
.cform input,.cform textarea,.cform select{
  width:100%;background:var(--char-3);border:1px solid var(--line);color:var(--parch);
  font-family:'Inter',sans-serif;font-size:1rem;padding:.95rem 1.1rem;
  transition:border-color .3s;
}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--amber)}
.cform textarea{resize:vertical;min-height:130px}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
@media(max-width:520px){.cform .row2{grid-template-columns:1fr}}
.cform .note{font-size:.82rem;color:var(--parch-dim)}
.cform .note a{color:var(--brass)}
