:root {
  --cream: #f5f0e6;
  --paper: #fbf8f1;
  --ink: #1d2b24;
  --green: #243c30;
  --orange: #d86139;
  --line: #cfc8bb;
  --muted: #6d726b;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--cream); color: var(--ink); font-family: "DM Sans", sans-serif; }
a { color: inherit; text-decoration: none; }
button { font: inherit; }

.site-header {
  height: 82px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  padding: 0 5vw; border-bottom: 1px solid var(--line); background: var(--cream); position: relative; z-index: 10;
}
.brand { display: inline-flex; align-items: center; gap: 11px; font-family: "DM Serif Display", serif; font-size: 20px; width: max-content; }
.brand-mark { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; background: var(--orange); color: white; font-style: italic; }
.site-nav { display: flex; gap: 34px; font-size: 14px; }
.site-nav a, .text-link { position: relative; }
.site-nav a::after, .text-link::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -5px; height: 1px; background: currentColor; transition: right .25s; }
.site-nav a:hover::after, .text-link:hover::after { right: 0; }
.header-cta { justify-self: end; border: 1px solid var(--ink); padding: 11px 17px; font-size: 13px; font-weight: 600; }
.header-cta span { margin-left: 10px; }
.menu-toggle { display: none; }

.hero { min-height: 650px; display: grid; grid-template-columns: 1.05fr .95fr; border-bottom: 1px solid var(--line); }
.hero-copy { padding: 110px 6vw 80px 8vw; }
.eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: 11px; font-weight: 600; display: flex; align-items: center; gap: 10px; }
.eyebrow span { display: block; width: 26px; height: 1px; background: var(--orange); }
h1, h2 { font-family: "DM Serif Display", serif; font-weight: 400; margin: 0; line-height: .98; }
h1 { font-size: clamp(58px, 6vw, 92px); letter-spacing: -.035em; margin: 28px 0; }
h1 em, .story-copy em { color: var(--orange); font-weight: 400; }
.hero-intro { max-width: 500px; color: var(--muted); line-height: 1.75; font-size: 16px; }
.hero-actions { display: flex; align-items: center; gap: 34px; margin-top: 38px; }
.button { display: inline-block; padding: 15px 20px; font-size: 13px; font-weight: 600; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button-dark { color: white; background: var(--green); }
.text-link { font-size: 14px; font-weight: 600; }
.text-link span { color: var(--orange); margin-left: 8px; }

.hero-visual { position: relative; overflow: hidden; min-height: 570px; background: #cfc6b8; }
.hero-visual::before { content: ""; position: absolute; inset: 0; background: linear-gradient(145deg, rgba(255,255,255,.24), transparent 46%), linear-gradient(to top, rgba(44,35,25,.2), transparent 50%); }
.hero-visual::after { content: ""; position: absolute; left: -10%; right: -10%; bottom: 10%; height: 25%; background: #a79987; transform: rotate(-2deg); box-shadow: 0 -2px 18px rgba(52,39,27,.12); }
.sun-shape { position: absolute; width: 460px; height: 460px; border-radius: 50%; background: #e6daca; right: -100px; top: -60px; }
.cup { position: absolute; z-index: 3; width: 260px; height: 210px; left: 50%; top: 48%; transform: translate(-50%,-38%); border-radius: 18px 18px 95px 95px; background: #f6f0e3; box-shadow: inset -25px -18px 35px rgba(77,57,39,.12), 0 25px 30px rgba(50,40,30,.19); }
.coffee { position: absolute; left: 12px; right: 12px; top: -10px; height: 62px; border-radius: 50%; background: #eee8dc; box-shadow: 0 5px 8px rgba(46,35,25,.2); display: grid; place-items: center; }
.coffee::before { content: ""; width: 218px; height: 45px; border-radius: 50%; background: #6c3f26; box-shadow: inset 0 5px 12px #39251a; }
.coffee span { position: absolute; width: 64px; height: 23px; border-radius: 50%; background: #d3b48c; opacity: .7; }
.handle { position: absolute; right: -77px; top: 53px; width: 100px; height: 102px; border: 24px solid #eee7da; border-left-width: 17px; border-radius: 50%; z-index: -1; }
.saucer { position: absolute; z-index: 2; width: 390px; height: 85px; border-radius: 50%; background: #e4dbcc; left: 50%; top: 69%; transform: translateX(-50%); box-shadow: 0 22px 24px rgba(52,41,31,.2); }
.steam { position: absolute; z-index: 4; width: 45px; height: 120px; border-left: 3px solid rgba(255,255,255,.55); border-radius: 50%; top: 18%; left: 48%; transform: rotate(9deg); }
.steam-two { left: 56%; top: 16%; transform: rotate(-8deg); height: 100px; opacity: .7; }
.visual-note { position: absolute; z-index: 4; right: 30px; bottom: 26px; color: white; font-family: "DM Serif Display", serif; font-style: italic; font-size: 19px; transform: rotate(-5deg); }

.quick-info { min-height: 116px; display: grid; grid-template-columns: repeat(3, 1fr) 100px; align-items: center; padding: 20px 8vw; background: var(--paper); border-bottom: 1px solid var(--line); }
.quick-info > div:not(:last-child) { border-right: 1px solid var(--line); padding-right: 40px; margin-right: 40px; }
.info-label { text-transform: uppercase; letter-spacing: .15em; color: var(--muted); font-size: 10px; margin: 0 0 9px; }
.info-value { margin: 0; font-family: "DM Serif Display", serif; font-size: 20px; }
.bean-icon { font-size: 26px; text-align: right; color: var(--orange); }

.menu-section { padding: 110px 8vw 120px; background: var(--paper); }
.section-heading { display: grid; grid-template-columns: 1fr 360px; align-items: end; gap: 50px; }
.section-heading h2, .visit-section h2 { font-size: clamp(45px, 5vw, 70px); margin-top: 22px; }
.section-heading > p { color: var(--muted); line-height: 1.7; }
.menu-tabs { display: flex; gap: 8px; margin: 65px 0 25px; border-bottom: 1px solid var(--line); }
.menu-tabs button { border: 0; background: none; padding: 12px 22px; cursor: pointer; color: var(--muted); border-bottom: 2px solid transparent; }
.menu-tabs button.active { color: var(--ink); border-bottom-color: var(--orange); }
.menu-grid { display: none; grid-template-columns: 1fr 1fr; column-gap: 7vw; }
.menu-grid.active { display: grid; }
.menu-item { min-height: 116px; display: flex; justify-content: space-between; gap: 20px; padding: 28px 0; border-bottom: 1px solid var(--line); }
.menu-item h3 { margin: 0 0 8px; font-family: "DM Serif Display", serif; font-size: 21px; font-weight: 400; }
.menu-item p { margin: 0; color: var(--muted); font-size: 13px; }
.menu-item > span { font-family: "DM Serif Display", serif; font-size: 19px; }
.menu-item b { color: var(--orange); font-family: "DM Sans", sans-serif; font-size: 8px; text-transform: uppercase; letter-spacing: .1em; margin-left: 6px; }

.visit-section { display: grid; grid-template-columns: 1fr 1fr; }
.visit-card, .hours-card { padding: 100px 8vw; min-height: 500px; }
.visit-card { background: var(--green); color: white; }
.eyebrow.light span { background: #f0a17e; }
.address { color: #bec9c2; line-height: 1.7; margin: 32px 0; }
.button-light { background: var(--cream); color: var(--ink); }
.hours-card { background: #e0b17e; }
.hours-card .eyebrow span { background: var(--ink); }
.hours-row { display: flex; justify-content: space-between; gap: 20px; border-bottom: 1px solid rgba(29,43,36,.25); padding: 22px 0; }
.hours-row:first-of-type { margin-top: 38px; }
.hours-row strong { font-family: "DM Serif Display", serif; font-weight: 400; font-size: 19px; }
.hours-note { font-size: 12px; margin-top: 24px; opacity: .7; }

.story-section { text-align: center; padding: 120px 20px; background: var(--cream); }
.story-section .eyebrow { justify-content: center; }
.story-copy { font-family: "DM Serif Display", serif; font-size: clamp(45px, 6vw, 82px); line-height: 1.05; margin: 32px 0; }
.story-small { color: var(--muted); }
footer { display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 45px 5vw; background: var(--ink); color: white; font-size: 12px; }
.footer-brand { font-size: 18px; }
footer p { opacity: .65; }

@media (max-width: 800px) {
  .site-header { grid-template-columns: 1fr auto; padding: 0 22px; }
  .menu-toggle { display: block; border: 0; background: none; text-transform: uppercase; letter-spacing: .1em; font-size: 11px; }
  .site-nav { display: none; position: absolute; top: 82px; left: 0; right: 0; padding: 25px; background: var(--cream); border-bottom: 1px solid var(--line); flex-direction: column; gap: 22px; }
  .site-nav.open { display: flex; }
  .header-cta { display: none; }
  .hero { grid-template-columns: 1fr; }
  .hero-copy { padding: 75px 24px 65px; }
  .hero-visual { min-height: 480px; }
  .cup { transform: translate(-50%,-48%) scale(.78); }
  .saucer { transform: translateX(-50%) scale(.78); top: 65%; }
  .quick-info { grid-template-columns: 1fr; gap: 24px; padding: 36px 24px; }
  .quick-info > div:not(:last-child) { border-right: 0; border-bottom: 1px solid var(--line); padding: 0 0 20px; margin: 0; }
  .bean-icon { display: none; }
  .menu-section { padding: 80px 24px; }
  .section-heading { grid-template-columns: 1fr; }
  .menu-tabs { overflow-x: auto; margin-top: 45px; }
  .menu-tabs button { white-space: nowrap; padding-inline: 14px; }
  .menu-grid { grid-template-columns: 1fr; }
  .visit-section { grid-template-columns: 1fr; }
  .visit-card, .hours-card { padding: 75px 24px; min-height: auto; }
  .story-section { padding: 85px 20px; }
  footer { flex-direction: column; text-align: center; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; }
}
