
:root{
  --bg:#fbf5ea; --fg:#2a1d14; --muted:#6e5a48; --card:#fdf9f1;
  --border:#e4d8c4; --espresso:#3b2a1e; --ink:#1f160f;
  --cream:#fbf5ea; --copper:#b4742d; --secondary:#efe3cc;
  --radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--fg);line-height:1.55;font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-0.02em;color:var(--espresso);line-height:1.1}
::selection{background:var(--copper);color:var(--cream)}

.container{max-width:1140px;margin:0 auto;padding:0 20px}
.eyebrow{text-transform:uppercase;letter-spacing:0.22em;font-size:.72rem;font-weight:600;color:var(--copper)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.25rem;border-radius:999px;font-size:14px;font-weight:500;transition:all .25s ease;border:1px solid transparent;cursor:pointer}
.btn-dark{background:var(--espresso);color:var(--cream)}
.btn-dark:hover{background:var(--ink)}
.btn-light{background:var(--cream);color:var(--espresso)}
.btn-light:hover{background:var(--copper);color:var(--cream)}
.btn-outline{border-color:var(--border);background:var(--bg);color:var(--fg)}
.btn-outline:hover{background:var(--secondary)}
.btn-ghost-cream{border:1px solid rgba(251,245,234,.4);color:var(--cream)}
.btn-ghost-cream:hover{background:rgba(251,245,234,.1)}
.link-underline{position:relative;display:inline-block}
.link-underline::after{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.link-underline:hover::after{transform:scaleX(1);transform-origin:left}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,245,234,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-size:20px;color:var(--espresso);font-weight:500}
.brand-mark{width:34px;height:34px;border-radius:50%;background:var(--espresso);color:var(--cream);display:grid;place-items:center;font-size:14px;font-style:italic}
.nav-links{display:flex;gap:28px;align-items:center;list-style:none}
.nav-links a{font-size:14px;color:var(--fg);transition:color .2s}
.nav-links a:hover{color:var(--copper)}
.nav-cta{display:none}
@media(min-width:860px){.nav-cta{display:inline-flex}}
@media(max-width:760px){.nav-links{display:none}.nav-mobile{display:block}}
.menu-toggle{display:none;background:none;border:0;padding:6px;cursor:pointer}
@media(max-width:760px){.menu-toggle{display:block}}
.mobile-menu{display:none;border-top:1px solid var(--border);background:var(--bg)}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none;padding:14px 20px}
.mobile-menu li{padding:10px 0;border-bottom:1px dashed var(--border)}
.mobile-menu li:last-child{border:0}

/* Hero */
.hero{position:relative;height:78vh;min-height:560px;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(59,42,30,.45),rgba(59,42,30,.25) 60%,var(--bg))}
.hero-content{position:relative;z-index:2;max-width:1140px;margin:0 auto;padding:0 20px;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:80px;color:var(--cream)}
.hero h1{color:var(--cream);font-size:clamp(40px,7vw,72px);max-width:780px;margin-top:18px;line-height:1.02}
.hero h1 em{color:var(--copper);font-style:italic;font-weight:500}
.hero p.lead{margin-top:24px;max-width:540px;color:rgba(251,245,234,.85);font-size:15.5px;line-height:1.65}
.hero-cta{margin-top:32px;display:flex;flex-wrap:wrap;gap:12px}
.hero .eyebrow{color:rgba(251,245,234,.85)}

/* Sections */
section.pad{padding:80px 0}
@media(min-width:768px){section.pad{padding:110px 0}}
.section-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:48px}
.section-head h2{font-size:clamp(30px,4.4vw,48px);margin-top:8px}

.stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(239,227,204,.5)}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);max-width:1140px;margin:0 auto}
@media(min-width:768px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat{padding:20px 16px;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:0}
.stat p:last-child{font-family:'Fraunces',serif;font-size:20px;color:var(--espresso);margin-top:4px}

/* Marquee */
.marquee{overflow:hidden;border-bottom:1px solid var(--border);background:var(--bg);padding:16px 0}
.marquee-track{display:flex;gap:48px;white-space:nowrap;animation:marq 40s linear infinite;font-size:13px;text-transform:uppercase;letter-spacing:.28em;color:var(--muted)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Cards */
.cards{display:grid;gap:32px;grid-template-columns:1fr}
@media(min-width:700px){.cards.cols-3{grid-template-columns:repeat(3,1fr)}.cards.cols-2{grid-template-columns:1fr 1fr}.cards.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.cards.cols-4{grid-template-columns:repeat(4,1fr)}}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:transform .5s,box-shadow .5s}
.card:hover{transform:translateY(-4px);box-shadow:0 20px 50px -25px rgba(40,25,15,.35)}
.card .imgwrap{aspect-ratio:4/3;overflow:hidden;background:var(--secondary)}
.card .imgwrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.card:hover .imgwrap img{transform:scale(1.05)}
.card-body{padding:24px}
.card-body .meta{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.card-body h3{margin-top:8px;font-size:24px}
.card-body .notes{margin-top:8px;font-style:italic;color:var(--copper);font-size:14px}
.card-body p{margin-top:12px;color:rgba(42,29,20,.85);font-size:14px;line-height:1.65}

/* Two-col story */
.split{display:grid;gap:48px;grid-template-columns:1fr;align-items:center}
@media(min-width:820px){.split{grid-template-columns:1fr 1fr}}
.split img{border-radius:16px;box-shadow:0 30px 60px -30px rgba(32,20,12,.45)}
.split h2{font-size:clamp(28px,4vw,44px)}
.split p{margin-top:16px;line-height:1.7;color:rgba(42,29,20,.85)}
.bg-secondary{background:rgba(239,227,204,.5)}
.grain{background-image:radial-gradient(rgba(100,70,40,.06) 1px,transparent 1px),radial-gradient(rgba(100,70,40,.04) 1px,transparent 1px);background-size:3px 3px,7px 7px}

/* Process ordered list */
.process{display:grid;gap:24px;grid-template-columns:1fr;margin-top:48px}
@media(min-width:640px){.process{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.process{grid-template-columns:repeat(4,1fr)}}
.process-step{border:1px solid var(--border);background:var(--card);border-radius:16px;padding:24px}
.process-step .num{font-family:'Fraunces',serif;font-size:24px;color:var(--copper)}
.process-step h3{margin-top:8px;font-size:20px}
.process-step p{margin-top:8px;font-size:13.5px;line-height:1.65;color:var(--muted)}

/* Press */
.press{background:var(--espresso);color:var(--cream)}
.press h2,.press blockquote{color:var(--cream)}
.press-grid{display:grid;gap:40px;grid-template-columns:1fr}
@media(min-width:820px){.press-grid{grid-template-columns:3fr 2fr;align-items:center}}
.press blockquote{font-family:'Fraunces',serif;font-size:clamp(24px,3.2vw,36px);line-height:1.2;margin-top:16px}
.press cite{display:block;margin-top:20px;font-style:normal;font-size:13px;text-transform:uppercase;letter-spacing:.22em;color:rgba(251,245,234,.7)}
.press img{border-radius:16px}
.press .eyebrow{color:var(--copper)}

/* CTA */
.cta-center{text-align:center}
.cta-center h2{font-size:clamp(32px,5vw,60px);margin-top:12px}
.cta-center p{margin:18px auto 0;max-width:560px;color:rgba(42,29,20,.85);line-height:1.65}
.cta-buttons{margin-top:28px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}

/* Coffees grid */
.product{display:grid;gap:24px;grid-template-columns:1fr;align-items:flex-start}
@media(min-width:600px){.product{grid-template-columns:2fr 3fr}}
.product .imgwrap{aspect-ratio:1/1;border-radius:16px;overflow:hidden;background:var(--secondary)}
.product .imgwrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.product:hover .imgwrap img{transform:scale(1.04)}
.product .tag{font-size:11.5px;text-transform:uppercase;letter-spacing:.22em;color:var(--copper)}
.product h2{margin-top:8px;font-size:26px}
.product .origin{margin-top:4px;font-size:13.5px;color:var(--muted)}
.product .notes{margin-top:12px;font-style:italic;color:rgba(59,42,30,.85);font-size:14px}
.product .desc{margin-top:12px;font-size:14px;line-height:1.65;color:rgba(42,29,20,.85)}
.product dl{margin-top:16px;display:flex;flex-wrap:wrap;gap:4px 24px;font-size:12.5px;color:var(--muted)}
.product dl span{color:rgba(42,29,20,.85)}
.products-grid{display:grid;gap:48px;grid-template-columns:1fr}
@media(min-width:880px){.products-grid{grid-template-columns:1fr 1fr;gap:48px 56px}}

.boxed{margin-top:80px;border:1px solid var(--border);background:var(--card);border-radius:16px;padding:32px;text-align:center}
.boxed h3{font-size:28px;margin-top:8px}
.boxed p{margin:12px auto 0;max-width:540px;color:var(--muted);font-size:14.5px;line-height:1.65}

/* Visit */
.visit-hero{position:relative;height:55vh;min-height:420px;overflow:hidden}
.visit-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.visit-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(59,42,30,.2),rgba(59,42,30,.5),var(--bg))}
.visit-hero-content{position:relative;z-index:2;max-width:1140px;margin:0 auto;padding:0 20px;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:60px;color:var(--cream)}
.visit-hero h1{color:var(--cream);font-size:clamp(36px,5.5vw,60px);max-width:640px;margin-top:12px}
.hours{width:100%;border-collapse:collapse;margin-top:8px;font-size:15px}
.hours td{padding:12px 0;border-bottom:1px solid var(--border)}
.hours td:first-child{font-family:'Fraunces',serif;color:var(--espresso);width:130px}
.hours tr:last-child td{border-bottom:0}
.menu-list{margin-top:16px;list-style:none}
.menu-list li{display:flex;align-items:baseline;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}
.menu-list li:last-child{border:0}
.menu-name{font-family:'Fraunces',serif;font-size:17px;color:var(--espresso)}
.menu-dots{flex:1;border-bottom:1px dotted rgba(180,150,120,.5);transform:translateY(4px)}
.menu-desc{font-size:14px;font-style:italic;color:var(--muted);max-width:55%;text-align:right}
.menu-price{font-family:'Fraunces',serif;font-size:17px;color:var(--copper);width:56px;text-align:right}
@media(max-width:600px){.menu-desc{display:none}}

.visit-grid{display:grid;gap:48px;grid-template-columns:1fr}
@media(min-width:820px){.visit-grid{grid-template-columns:1fr 1fr}}
.visit-menu{display:grid;gap:48px;grid-template-columns:1fr}
@media(min-width:820px){.visit-menu{grid-template-columns:2fr 3fr}}

/* About */
.timeline{margin-top:48px;border-left:1px solid var(--border);padding-left:32px;list-style:none}
.timeline li{position:relative;margin-bottom:40px}
.timeline li::before{content:"";position:absolute;left:-37px;top:6px;width:12px;height:12px;border-radius:50%;background:var(--copper);box-shadow:0 0 0 4px var(--bg)}
.timeline .year{font-family:'Fraunces',serif;font-size:24px;color:var(--espresso)}
.timeline .body{margin-top:8px;font-size:14.5px;line-height:1.7;color:rgba(42,29,20,.85);max-width:640px}

.team{display:grid;gap:40px;grid-template-columns:1fr}
@media(min-width:820px){.team{grid-template-columns:repeat(3,1fr)}}
.team .role{font-size:11.5px;text-transform:uppercase;letter-spacing:.22em;color:var(--copper)}
.team h3{color:var(--cream);margin-top:8px;font-size:24px}
.team p{margin-top:8px;font-size:14px;line-height:1.7;color:rgba(251,245,234,.8)}

/* Contact */
.contact-grid{display:grid;gap:56px;grid-template-columns:1fr}
@media(min-width:880px){.contact-grid{grid-template-columns:2fr 3fr}}
.field-grid{display:grid;gap:20px;grid-template-columns:1fr}
@media(min-width:600px){.field-grid{grid-template-columns:1fr 1fr}}
.label{display:block;font-size:12.5px;font-weight:500;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}
.input,.textarea,.select{width:100%;margin-top:6px;border:1px solid var(--border);background:var(--bg);border-radius:8px;padding:11px 14px;font-size:14.5px;font-family:inherit;color:var(--fg);transition:border-color .2s,box-shadow .2s}
.input:focus,.textarea:focus,.select:focus{outline:0;border-color:var(--copper);box-shadow:0 0 0 3px rgba(180,116,45,.18)}
.form{border:1px solid var(--border);background:var(--card);border-radius:16px;padding:28px;display:flex;flex-direction:column;gap:20px}
.form h2{font-size:24px}

/* Article */
.article{max-width:720px;margin:0 auto;padding:80px 20px}
.article h1{font-size:clamp(32px,5vw,52px);margin-top:12px}
.article h2{font-size:26px;margin-top:32px}
.article p,.article li{margin-top:12px;font-size:15px;line-height:1.75;color:rgba(42,29,20,.88)}
.article ul,.article ol{margin-top:8px;padding-left:22px}
.article a{color:var(--copper)}
.article a:hover{text-decoration:underline}
.article table{margin-top:16px;width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:8px;overflow:hidden;font-size:14px}
.article th,.article td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}
.article th{background:var(--secondary);font-family:'Fraunces',serif;color:var(--espresso)}
.article address{font-style:normal;line-height:1.7}

/* Footer */
.site-footer{background:var(--ink);color:rgba(251,245,234,.78);padding:64px 0 32px;margin-top:60px}
.footer-grid{display:grid;gap:40px;grid-template-columns:1fr}
@media(min-width:760px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-grid h4{color:var(--cream);font-size:13px;text-transform:uppercase;letter-spacing:.22em;font-family:'Inter',sans-serif;letter-spacing:.22em;font-weight:600;margin-bottom:16px}
.footer-grid a{display:block;padding:5px 0;font-size:14px;color:rgba(251,245,234,.7)}
.footer-grid a:hover{color:var(--cream)}
.footer-brand p{margin-top:14px;font-size:14px;line-height:1.7;max-width:300px}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(251,245,234,.12);font-size:12.5px;color:rgba(251,245,234,.55);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}

/* Cookie banner */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:100;background:var(--espresso);color:var(--cream);border-radius:16px;padding:20px 24px;display:none;align-items:center;gap:16px;flex-wrap:wrap;box-shadow:0 20px 60px -20px rgba(0,0,0,.4);max-width:840px;margin-left:auto;margin-right:auto}
.cookie.show{display:flex}
.cookie p{font-size:13.5px;line-height:1.55;flex:1;min-width:240px}
.cookie a{color:var(--copper);text-decoration:underline}
.cookie .btn{padding:.55rem 1rem;font-size:13px}

@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
