:root{
  --bg:#f5efe8;
  --bg-soft:#fffaf4;
  --surface:#fffdfa;
  --surface-2:#f7efe6;
  --card:rgba(255,255,255,0.86);
  --card-strong:rgba(255,255,255,0.96);
  --line:rgba(76,52,33,0.12);
  --text:#25180f;
  --muted:#625345;
  --soft:#7f6f60;
  --accent:#9d6237;
  --accent-2:#c9915f;
  --blue:#496a8b;
  --success:#5f8c66;
  --shadow:0 18px 40px rgba(58,34,14,0.12);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
  --radius-sm:12px;
  --container:min(1180px, calc(100vw - 28px));
  --font-title:"Playfair Display", Georgia, serif;
  --font-body:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --body-bg:
    radial-gradient(circle at top left, rgba(201,145,95,0.18), transparent 28%),
    radial-gradient(circle at top right, rgba(73,106,139,0.12), transparent 24%),
    linear-gradient(180deg, #fbf6ef 0%, #f4ece1 42%, #efe6dc 100%);
  --glass-bg:linear-gradient(180deg, rgba(255,255,255,0.82) 0%, rgba(249,240,231,0.96) 100%);
  --hero-overlay:
    linear-gradient(180deg, rgba(255,248,241,0.46) 0%, rgba(250,241,231,0.76) 56%, rgba(245,239,232,0.96) 100%),
    linear-gradient(120deg, rgba(201,145,95,0.14), transparent 42%),
    linear-gradient(220deg, rgba(73,106,139,0.12), transparent 36%);
  --sticky-bg:rgba(249,243,236,0.9);
  --input-bg:rgba(255,255,255,0.78);
  --chip-bg:rgba(255,255,255,0.72);
  --section-bg:linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(250,241,231,0.98) 100%);
  --menu-card-bg:linear-gradient(180deg, rgba(255,255,255,0.9) 0%, rgba(247,239,232,0.96) 100%);
  --placeholder-color:rgba(255,255,255,0.86);
}

body.dark{
  --bg:#07111d;
  --bg-soft:#0f2033;
  --surface:#132235;
  --surface-2:#18293c;
  --card:rgba(13,24,38,0.76);
  --card-strong:rgba(14,28,43,0.92);
  --line:rgba(255,255,255,0.08);
  --text:#f6efe7;
  --muted:#c6c0b8;
  --soft:#91a4b8;
  --accent:#c29152;
  --accent-2:#e0b274;
  --blue:#4f7da8;
  --success:#8eb98d;
  --shadow:0 18px 40px rgba(0,0,0,0.35);
  --body-bg:
    radial-gradient(circle at top left, rgba(194,145,82,0.22), transparent 25%),
    radial-gradient(circle at top right, rgba(79,125,168,0.18), transparent 28%),
    linear-gradient(180deg, #07111d 0%, #0a1624 30%, #0b1320 100%);
  --glass-bg:linear-gradient(180deg, rgba(21,35,53,0.78) 0%, rgba(10,18,30,0.88) 100%);
  --hero-overlay:
    linear-gradient(180deg, rgba(5,12,19,0.55) 0%, rgba(4,10,17,0.82) 58%, rgba(7,17,29,0.98) 100%),
    linear-gradient(120deg, rgba(194,145,82,0.18), transparent 42%),
    linear-gradient(220deg, rgba(79,125,168,0.18), transparent 36%);
  --sticky-bg:rgba(8,16,28,0.9);
  --input-bg:rgba(255,255,255,0.05);
  --chip-bg:rgba(255,255,255,0.04);
  --section-bg:linear-gradient(180deg, rgba(10,18,31,0.92) 0%, rgba(12,21,34,0.96) 100%);
  --menu-card-bg:linear-gradient(180deg, rgba(255,255,255,0.055) 0%, rgba(255,255,255,0.03) 100%);
  --placeholder-color:rgba(255,255,255,0.84);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:var(--body-bg);
  transition:background .28s ease,color .28s ease;
}
a{color:inherit}
img{max-width:100%;display:block}
button,input{font:inherit}
button{cursor:pointer}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.hide{display:none!important}
.container{width:var(--container);margin-inline:auto}
.page-shell{min-height:100vh}
.glass-card{
  background:var(--glass-bg);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  backdrop-filter:blur(14px);
}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2)}
.eyebrow::before{content:"";width:26px;height:1px;background:linear-gradient(90deg, transparent, var(--accent), transparent)}
.site-header{position:relative}
.hero{position:relative;min-height:440px;background:url("assets/images/cafe.jpg") center center / cover no-repeat;border-bottom:1px solid var(--line)}
.hero__overlay{position:absolute;inset:0;background:var(--hero-overlay)}
.hero__content{position:relative;z-index:1;display:grid;gap:28px;padding:34px 0 46px}
.brand{display:flex;align-items:center;gap:18px;text-decoration:none;max-width:max-content}
.brand__logo{width:110px;height:110px;object-fit:cover;border-radius:28px;border:1px solid var(--line);background:rgba(255,255,255,0.92);box-shadow:0 18px 28px rgba(0,0,0,0.18)}
.brand h1{margin:6px 0 8px;font-family:var(--font-title);font-size:clamp(2rem, 3vw, 3.6rem);line-height:1.02}
.brand__tagline{margin:0;font-size:1rem;color:var(--muted);max-width:780px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:46px;padding:0 18px;border-radius:999px;text-decoration:none;border:1px solid transparent;transition:transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#15120e;font-weight:800}
.btn--ghost{background:var(--chip-bg);color:var(--text);border-color:var(--line)}
.btn--full{width:100%}
.hero__panel{width:min(100%, 1080px);max-width:1080px;margin-inline:auto;border-radius:var(--radius-xl);padding:24px 30px}
.hero__description{margin:0 auto 18px;max-width:920px;line-height:1.7;color:var(--muted);text-align:center}
.hero__stats{display:grid;grid-template-columns:repeat(3, minmax(180px,1fr));gap:14px;max-width:920px;margin-inline:auto}
.hero__stats div{padding:14px 16px;border-radius:18px;background:var(--chip-bg);border:1px solid var(--line)}
.hero__stats strong{display:block;font-size:1.35rem;margin-bottom:4px}
.hero__stats span{font-size:.9rem;color:var(--soft)}
.sticky-tools{position:sticky;top:0;z-index:35;background:var(--sticky-bg);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.sticky-tools__inner{display:grid;gap:14px;padding:14px 0 16px}
.search-box{position:relative}
.search-box input{width:100%;min-height:56px;padding:0 52px 0 18px;border-radius:18px;border:1px solid var(--line);background:var(--input-bg);color:var(--text);outline:none}
.search-box input::placeholder{color:var(--soft)}
.search-box input:focus{border-color:rgba(194,145,82,0.45);box-shadow:0 0 0 3px rgba(194,145,82,0.12)}
.search-box__clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:36px;height:36px;border:0;border-radius:12px;color:var(--text);background:var(--chip-bg)}
.chips{display:flex;gap:10px;overflow:auto;padding-bottom:4px;scrollbar-width:thin}
.chip{flex:0 0 auto;min-height:42px;padding:0 16px;border-radius:999px;border:1px solid var(--line);background:var(--chip-bg);color:var(--text);font-weight:700}
.chip.is-active,.chip:hover{background:linear-gradient(135deg, rgba(194,145,82,0.92), rgba(224,178,116,0.96));color:#17110a;border-color:transparent}
.main-content{padding:26px 0 56px}
.search-summary{margin:0 0 18px;padding:14px 16px;border-radius:16px;background:rgba(73,106,139,0.1);border:1px solid rgba(73,106,139,0.16);color:var(--text)}
.menu-stack{display:grid;gap:22px}
.menu-section{border-radius:var(--radius-xl);padding:22px;background:var(--section-bg);border:1px solid var(--line);box-shadow:var(--shadow)}
.menu-section__top{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}
.menu-section h3{margin:8px 0 10px;font-family:var(--font-title);font-size:clamp(1.45rem, 2.5vw, 2rem)}
.menu-section__top p{margin:0;color:var(--muted);line-height:1.65;max-width:840px}
.section-badge{flex:0 0 auto;min-width:78px;padding:10px 14px;border-radius:16px;text-align:center;background:rgba(194,145,82,0.12);border:1px solid rgba(194,145,82,0.24)}
.section-badge strong{display:block;font-size:1.2rem}
.section-badge span{font-size:.8rem;color:var(--soft)}
.menu-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:16px}
.menu-card{display:flex;flex-direction:column;min-height:100%;border-radius:22px;overflow:hidden;background:var(--menu-card-bg);border:1px solid var(--line)}
.menu-card__media{position:relative;aspect-ratio:16/10;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:12px;background:linear-gradient(135deg, rgba(194,145,82,0.3), rgba(79,125,168,0.28))}
.menu-card__media img{display:block;width:auto;height:auto;max-width:100%;max-height:100%;margin:auto;object-fit:contain;object-position:center;image-rendering:auto;transform:translateZ(0)}
.menu-card__placeholder{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--font-title);font-size:1.8rem;letter-spacing:.08em;color:var(--placeholder-color);background:linear-gradient(135deg, rgba(194,145,82,0.36), rgba(79,125,168,0.32))}
.menu-card__body{display:flex;flex-direction:column;gap:10px;padding:16px;flex:1}
.menu-card__title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.menu-card__title h4{margin:0;font-size:1.02rem;line-height:1.35}
.price-tag{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;background:rgba(194,145,82,0.16);border:1px solid rgba(194,145,82,0.24);color:var(--accent);font-weight:800;font-size:.95rem}
body.dark .price-tag{color:#ffd49c}
.menu-card p{margin:0;line-height:1.55;color:var(--muted)}
.menu-card__meta{margin-top:auto;display:flex;justify-content:space-between;align-items:center;gap:10px;padding-top:4px}
.meta-dot{width:8px;height:8px;border-radius:999px;background:var(--accent-2);box-shadow:0 0 0 4px rgba(224,178,116,0.1)}
.meta-label{font-size:.84rem;color:var(--soft)}
.empty-state{padding:38px 20px;border-radius:22px;text-align:center;background:var(--chip-bg);border:1px dashed var(--line)}
.empty-state h3{margin:0 0 10px;font-family:var(--font-title)}
.empty-state p{margin:0;color:var(--muted)}
.contact-grid{margin-top:28px;display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:18px}
.contact-card{border-radius:24px;padding:22px}
.contact-card h3{margin:10px 0 12px;font-family:var(--font-title);font-size:1.5rem}
.contact-card p{margin:0 0 10px;color:var(--muted);line-height:1.65}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.social-links{display:grid;gap:12px}
.social-link{display:flex;align-items:center;justify-content:center;min-height:48px;border-radius:16px;text-decoration:none;font-weight:700;background:var(--chip-bg);border:1px solid var(--line)}
.clabe-box{margin-top:10px;display:grid;gap:4px;padding:16px;border-radius:18px;background:var(--chip-bg);border:1px solid var(--line)}
.clabe-box span{font-size:.86rem;color:var(--soft);text-transform:uppercase;letter-spacing:.14em}
.clabe-box strong{font-size:1.05rem;word-break:break-word}
.site-footer{padding:0 0 40px}
.site-footer__inner{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:10px;border-top:1px solid var(--line)}
.site-footer p{margin:0;color:var(--soft);font-size:.94rem}
.footer-admin-link{text-decoration:none;color:var(--accent);font-weight:700}
.fab-theme{position:fixed;z-index:80;right:calc(env(safe-area-inset-right) + 16px);bottom:calc(env(safe-area-inset-bottom) + 16px);width:62px;height:62px;border-radius:50%;display:grid;place-items:center;border:none;background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#fff;font-size:26px;box-shadow:0 14px 28px rgba(0,0,0,.22);transition:transform .18s ease, box-shadow .18s ease}
.fab-theme:hover{transform:scale(1.05)}
@media (max-width: 980px){.menu-grid{grid-template-columns:repeat(2, minmax(0,1fr))}.contact-grid{grid-template-columns:1fr}}
@media (max-width: 720px){.hero{min-height:430px}.hero__content{padding:24px 0 36px}.brand{align-items:flex-start}.brand__logo{width:88px;height:88px;border-radius:22px}.hero__panel{padding:20px}.hero__stats{grid-template-columns:1fr}.menu-grid{grid-template-columns:1fr}.menu-section__top{flex-direction:column}.site-footer__inner{flex-direction:column;align-items:flex-start}}
@media (max-width: 520px){.container{width:min(100vw - 20px, 1180px)}.brand{gap:14px}.hero__panel,.menu-section,.contact-card{padding:18px}.hero__description{font-size:.98rem}.search-box input{min-height:52px}.chip{min-height:40px;padding:0 14px}.fab-theme{width:58px;height:58px;font-size:24px}}
