:root{
  --coffee:#5c3d2e;
  --latte:#8b5e3c;
  --foam:#f7efe6;
  --cream:#fff8f0;
  --ink:#2b221d;
  --accent:#c97b4b;
}

/* Base */
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", sans-serif;
  color:var(--ink); background:var(--foam); line-height:1.55;
}
.wrap{max-width:1000px;margin:0 auto;padding:20px 16px}

/* Header */
.header{position:sticky;top:0;z-index:10;background:linear-gradient(180deg,var(--coffee),var(--latte));color:#fff;border-bottom:4px solid var(--accent);display:flex;align-items:center;justify-content:space-between;padding:10px 14px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff}
.logo{width:44px;height:44px;display:block}
.brand-text{display:flex;flex-direction:column}
.title{font-weight:800;letter-spacing:.3px}
.tagline{font-size:12px;opacity:.85}
.nav{display:flex;gap:12px}
.link{background:none;border:0;color:#ffe6cf;cursor:pointer;font-weight:600}
.link:hover{opacity:.9}

/* Sections & cards */
.card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:18px;box-shadow:0 6px 18px rgba(0,0,0,.05);margin-bottom:16px}
.h1{margin:6px 0 8px}
.h2{margin:0 0 10px}
.h3{margin:0 0 8px}
.lead{font-size:1.05rem;opacity:.95}
.muted{opacity:.8}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.btn{padding:10px 14px;border-radius:12px;border:1px solid rgba(0,0,0,.08);cursor:pointer}
.btn.ghost{background:var(--cream)}
.btn.primary{background:var(--accent);color:#fff;border:0;box-shadow:0 8px 18px rgba(201,123,75,.35)}
.btn.primary:disabled{opacity:.6;cursor:not-allowed}

/* Cafe list */
.cafe-list{list-style:none;margin:0;padding:0}
.cafe{display:block;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:12px 14px;margin:10px 0;text-decoration:none;color:var(--ink);transition:transform .05s ease, box-shadow .2s ease}
.cafe:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.06)}

/* Menu page */
.grid-2{display:grid;gap:16px}
@media(min-width:840px){.grid-2{grid-template-columns:1fr 1fr}}
.row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(0,0,0,.08);border-radius:10px;margin:8px 0;background:#fff}
.total{margin-top:12px;font-weight:800}

/* Footer */
.footer{background:#fff;border-top:1px solid rgba(0,0,0,.06);padding:18px 0;margin-top:18px}
.foot-grid{max-width:1000px;margin:0 auto;padding:0 16px;display:grid;gap:10px}
@media(min-width:840px){.foot-grid{grid-template-columns:1fr 2fr 1fr;align-items:center}}
.foot-title{font-weight:800}
.foot-tag{font-size:12px;opacity:.8}
.foot-contact a{color:var(--accent);text-decoration:none}
.foot-links{display:flex;gap:10px;align-items:center;justify-content:flex-start}
.sep{opacity:.4}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;padding:16px}
.modal.show{display:flex}
.modal-card{background:#fff;max-width:760px;width:100%;max-height:85vh;border-radius:16px;box-shadow:0 20px 40px rgba(0,0,0,.25);display:flex;flex-direction:column}
.modal-close{position:absolute;margin:10px 12px;align-self:flex-end;border:0;background:#eee;border-radius:10px;padding:6px 10px;cursor:pointer}
.modal-body{padding:16px 18px 20px;overflow:auto;border-top:1px solid rgba(0,0,0,.06)}
.pre{white-space:pre-wrap;font-family:inherit}
