/* =========================================================
   Gold Brew Coffee Bar — Editorial / Warm Minimalist
   Kraft/cream + espresso-brown + warm gold
   ========================================================= */
:root{
  --cream:#f6efe3;
  --kraft:#ece0cc;
  --paper:#fbf7ef;
  --espresso:#3a2a1d;
  --espresso-2:#4d3826;
  --ink:#2c2118;
  --gold:#9b804a;        /* genuine brand gold from their site */
  --gold-deep:#7c6233;
  --muted:#7a6b58;
  --line:rgba(58,42,29,.14);
  --shadow:0 14px 40px -18px rgba(58,42,29,.32);
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --wrap:1120px;
  --r:14px;
}

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

body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* texture: subtle kraft grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background:
    radial-gradient(circle at 18% 12%, rgba(155,128,74,.08), transparent 38%),
    radial-gradient(circle at 82% 78%, rgba(58,42,29,.06), transparent 42%);
}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 22px}

img,svg{max-width:100%;height:auto;display:block}

a{color:inherit}
h1,h2,h3{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:1.06;margin:0}
em{font-style:italic;color:var(--gold-deep)}

.skip-link{
  position:absolute;left:-999px;top:0;background:var(--espresso);color:var(--cream);
  padding:12px 18px;border-radius:0 0 10px 0;z-index:200;font-weight:600;
}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  min-height:48px;padding:13px 24px;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:.96rem;text-decoration:none;
  background:var(--espresso);color:var(--cream);border:1.5px solid var(--espresso);
  transition:transform .25s ease, background .25s ease, color .25s ease;
  cursor:pointer;
}
.btn:hover{background:var(--espresso-2);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--espresso);border-color:var(--line)}
.btn-ghost:hover{background:rgba(58,42,29,.06);border-color:var(--espresso)}
.btn-sm{min-height:40px;padding:9px 18px;font-size:.88rem}
.btn-block{display:flex;width:100%}

.link{color:var(--gold-deep);text-decoration:underline;text-underline-offset:3px;font-weight:600}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(246,239,227,.82);backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;transition:border-color .3s ease, box-shadow .3s ease;
}
.site-header.scrolled{border-color:var(--line);box-shadow:0 8px 24px -22px rgba(58,42,29,.5)}
.header-inner{display:flex;align-items:center;gap:18px;min-height:66px;position:relative;z-index:1}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--espresso)}
.brand-mark{color:var(--gold-deep);display:flex}
.brand-text{font-family:var(--serif);font-size:1.18rem;line-height:1;display:flex;flex-direction:column;letter-spacing:-.01em}
.brand-text small{font-family:var(--sans);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:4px;font-weight:600}
.main-nav{display:none;gap:26px;margin-left:auto}
.main-nav a{text-decoration:none;color:var(--ink);font-weight:500;font-size:.94rem;opacity:.85;position:relative}
.main-nav a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--gold);transition:width .25s ease}
.main-nav a:hover{opacity:1}
.main-nav a:hover::after{width:100%}
.header-cta{margin-left:auto}
@media(min-width:860px){.main-nav{display:flex}.header-cta{margin-left:0}}

/* ---------- hero ---------- */
.hero{position:relative;z-index:1;padding:46px 0 30px}
.hero-grid{display:grid;gap:30px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;font-weight:600;color:var(--gold-deep);margin:0 0 16px}
.hero-copy h1{font-size:clamp(2.7rem,11vw,4.4rem);font-weight:300;color:var(--espresso)}
.hero-copy h1 em{display:inline-block}
.lede{font-size:1.08rem;color:var(--muted);max-width:30ch;margin:22px 0 28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px}

.hero-art{margin:8px 0 0;display:flex;flex-direction:column;align-items:center;color:var(--gold)}
.pour-svg{width:min(78%,300px)}
.hero-art-cap{font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--muted);margin-top:8px}

.hero-marquee-divider{height:1px;background:var(--line);margin-top:34px}

/* signature pour + steam motion */
.steam path{stroke-dasharray:80;stroke-dashoffset:80;animation:steam 4.5s ease-in-out infinite}
.steam .steam-2{animation-delay:.7s}
.steam .steam-3{animation-delay:1.3s}
@keyframes steam{
  0%{stroke-dashoffset:80;opacity:0;transform:translateY(6px)}
  35%{opacity:.6}
  100%{stroke-dashoffset:-80;opacity:0;transform:translateY(-10px)}
}
.stream{transform-origin:128px 60px;animation:pour 4.2s ease-in-out infinite}
@keyframes pour{
  0%,12%{transform:scaleY(0);opacity:0}
  20%{transform:scaleY(1);opacity:1}
  78%{transform:scaleY(1);opacity:1}
  88%,100%{transform:scaleY(0);opacity:0}
}
.crema{transform-origin:center;animation:fill 4.2s ease-in-out infinite}
@keyframes fill{0%,18%{transform:scaleX(.6);opacity:.5}30%{transform:scaleX(1);opacity:1}100%{transform:scaleX(1);opacity:1}}
.story-art .drip{animation:drip 2.6s ease-in infinite}
@keyframes drip{0%{transform:translateY(-6px);opacity:0}30%{opacity:1}70%{transform:translateY(10px);opacity:1}100%{transform:translateY(16px);opacity:0}}

/* ---------- sections ---------- */
.section{position:relative;z-index:1;padding:64px 0}
.section-head{max-width:40ch;margin-bottom:38px}
.section-head h2{font-size:clamp(2rem,7vw,3rem);color:var(--espresso);margin:10px 0 14px}
.section-sub{color:var(--muted);font-size:1.02rem}
.muted{color:var(--muted)}

/* ---------- menu ---------- */
.menu{background:var(--paper)}
.menu-cols{display:grid;gap:34px}
.menu-cat{font-size:1.35rem;color:var(--gold-deep);margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--line);font-style:italic}
.menu-list{list-style:none;margin:0;padding:0}
.menu-list li{display:flex;align-items:baseline;gap:8px;padding:9px 0;font-size:1.02rem}
.m-name{font-weight:500;color:var(--ink)}
.m-dot{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-3px)}
.m-price{font-family:var(--serif);font-size:1.05rem;color:var(--espresso)}
.m-price::before{content:"$";font-size:.78em;color:var(--gold-deep);margin-right:1px}
.menu-note{margin-top:30px;font-size:.85rem;color:var(--muted);font-style:italic}

/* ---------- story (asymmetric) ---------- */
.story{background:var(--espresso);color:var(--cream)}
.story .eyebrow{color:var(--gold)}
.story h2{color:var(--cream)}
.story-grid{display:grid;gap:34px}
.story-copy p{color:rgba(246,239,227,.82)}
.story-art{display:flex;justify-content:center;color:var(--gold)}
.story-art svg{width:min(60%,200px)}
.story-marks{list-style:none;display:grid;gap:18px;margin:30px 0 0;padding:0}
.story-marks li{display:flex;flex-direction:column;border-top:1px solid rgba(246,239,227,.18);padding-top:12px}
.story-marks strong{font-family:var(--serif);font-size:1.25rem;color:var(--gold);font-weight:400}
.story-marks span{font-size:.9rem;color:rgba(246,239,227,.7)}

/* ---------- about ---------- */
.about-grid{display:grid;gap:30px}
.about-copy p{color:var(--muted)}
.about-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.about-tags span{background:var(--kraft);color:var(--espresso);padding:7px 15px;border-radius:999px;font-size:.84rem;font-weight:600}
.about-card{background:var(--espresso);color:var(--cream);border-radius:var(--r);padding:28px;box-shadow:var(--shadow);align-self:start}
.about-card h3{font-size:1.4rem;color:var(--gold);margin-bottom:12px}
.about-addr{color:rgba(246,239,227,.85);margin:0 0 14px}
.about-card .link{color:var(--gold)}
.about-card .btn-ghost{color:var(--cream);border-color:rgba(246,239,227,.3);margin-top:14px}
.about-card .btn-ghost:hover{background:rgba(246,239,227,.1)}

/* ---------- reviews ---------- */
.reviews{background:var(--paper)}
.review-grid{display:grid;gap:20px}
.review-card{margin:0;background:var(--cream);border:1px solid var(--line);border-radius:var(--r);padding:26px}
.stars{color:var(--gold);letter-spacing:2px;font-size:1rem;display:block;margin-bottom:12px}
.review-card p{margin:0 0 14px;font-size:1.04rem;color:var(--ink)}
.review-card cite{font-style:normal;font-size:.84rem;color:var(--muted);font-weight:600}
.rating-line{text-align:center;margin-top:30px;color:var(--muted);font-size:1.05rem}
.rating-line strong{font-family:var(--serif);font-size:1.6rem;color:var(--gold-deep)}

/* ---------- visit ---------- */
.visit-grid{display:grid;gap:30px}
.hours{margin:22px 0;display:grid;gap:2px}
.hours div{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line)}
.hours dt{font-weight:600;color:var(--espresso)}
.hours dd{margin:0;color:var(--muted);font-family:var(--serif)}
.visit-addr{font-style:normal;font-family:var(--serif);font-size:1.15rem;color:var(--espresso);margin:6px 0 8px}
.hours-note{font-size:.82rem;color:var(--muted);font-style:italic;margin:0 0 20px}
.visit-actions{display:flex;flex-wrap:wrap;gap:12px}
.visit-map{margin:0;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);min-height:300px}
.visit-map iframe{width:100%;height:100%;min-height:340px;border:0;display:block;filter:sepia(.16) saturate(1.05)}

/* ---------- contact ---------- */
.contact{background:var(--espresso);color:var(--cream)}
.contact .eyebrow{color:var(--gold)}
.contact h2{color:var(--cream)}
.contact-grid{display:grid;gap:34px}
.contact-copy p{color:rgba(246,239,227,.82)}
.contact-list{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:14px}
.contact-list li{display:grid;gap:2px}
.contact-list .c-k{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.contact-list a{color:var(--cream);text-decoration:underline;text-underline-offset:3px}
.contact-form{background:var(--cream);color:var(--ink);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.04em;margin-bottom:6px;color:var(--espresso)}
.field input,.field textarea{
  width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:10px;
  font-family:var(--sans);font-size:1rem;background:var(--paper);color:var(--ink);resize:vertical;
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold)}
.form-status{margin:12px 0 0;font-size:.9rem;font-weight:600;color:var(--gold-deep)}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:var(--cream);padding:44px 0;position:relative;z-index:1}
.footer-inner{display:grid;gap:14px;text-align:center}
.brand-foot{justify-content:center;color:var(--cream)}
.brand-foot .brand-text small{color:var(--gold)}
.foot-meta{color:rgba(246,239,227,.8);font-size:.92rem;margin:0}
.foot-meta a{color:var(--gold)}
.foot-fine{color:rgba(246,239,227,.5);font-size:.8rem;margin:0}

/* ---------- sticky mobile CTA ---------- */
.sticky-cta{
  position:fixed;left:12px;right:12px;bottom:12px;z-index:120;
  display:flex;gap:8px;padding:8px;border-radius:999px;
  background:rgba(46,33,24,.92);backdrop-filter:blur(8px);
  box-shadow:0 14px 34px -12px rgba(0,0,0,.5);
  transform:translateY(140%);transition:transform .4s cubic-bezier(.2,.7,.3,1);
}
.sticky-cta.show{transform:translateY(0)}
.scta{
  flex:1;min-height:44px;display:flex;align-items:center;justify-content:center;
  text-decoration:none;color:var(--cream);font-weight:600;font-size:.88rem;border-radius:999px;
}
.scta-primary{background:var(--gold);color:var(--ink)}
@media(min-width:860px){.sticky-cta{display:none}}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .steam path,.stream,.crema,.story-art .drip{animation:none !important}
  .pour-svg .crema{transform:none}
}

/* ---------- responsive: tablet/desktop editorial grid ---------- */
@media(min-width:680px){
  .menu-cols{grid-template-columns:1fr 1fr;gap:30px 56px}
  .review-grid{grid-template-columns:repeat(3,1fr)}
  .about-tags span{font-size:.86rem}
}
@media(min-width:860px){
  .hero{padding:72px 0 40px}
  .hero-grid{grid-template-columns:1.05fr .95fr;align-items:center;gap:40px}
  .hero-art{margin:0}
  .section{padding:92px 0}
  .story-grid{grid-template-columns:.8fr 1.2fr;align-items:center;gap:56px}
  .about-grid{grid-template-columns:1.3fr .7fr;gap:48px;align-items:start}
  .visit-grid{grid-template-columns:.85fr 1.15fr;gap:46px;align-items:stretch}
  .contact-grid{grid-template-columns:1fr 1fr;gap:48px;align-items:center}
  .footer-inner{grid-template-columns:auto 1fr auto;text-align:left;align-items:center}
  .footer-inner .foot-meta{text-align:center}
  .footer-inner .foot-fine{text-align:right}
}
@media(min-width:1000px){
  .hero-copy h1{font-size:4.6rem}
}
