
:root{
  --bg:#06110f;
  --panel:rgba(7,20,18,.78);
  --panel-strong:rgba(8,16,15,.92);
  --line:rgba(213,170,83,.28);
  --gold:#a59369;
  --gold-soft:#a59369;
  --text:#f4ead6;
  --muted:#c7b99b;
  --shadow:0 18px 60px rgba(0,0,0,.35);
  --radius:22px;
  --modal-text:#f6efdf;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Georgia, "Times New Roman", serif;
  background: radial-gradient(circle at top, rgba(26,62,56,.65), rgba(3,7,7,1) 40%), #020808;
  color:var(--text);
  min-height:100vh;
}
body::before{
  content:"";
  position:fixed; inset:0;
  background: linear-gradient(rgba(0,0,0,.45),rgba(0,0,0,.6)), url("assets/background.jpg") center/cover no-repeat;
  opacity:.62;
  pointer-events:none;
}
a{color:inherit; text-decoration:none}
.page-shell,.admin-shell{position:relative; z-index:1}
.hero{
  min-height:34vh; display:grid; place-items:center; position:relative;
  padding:30px 20px 10px;
}
.hero-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.2), rgba(0,0,0,.5));
}
.hero-content{
  position:relative; text-align:center; max-width:880px;
  padding:18px 28px;
}
.hero-logo-only{display:flex; flex-direction:column; align-items:center; gap:12px}
.jade-wordmark{
  margin:0;
  font-size:clamp(2.1rem, 5vw, 3.4rem);
  letter-spacing:.28em;
  color:var(--gold-soft);
}
.brand-logo{
  width:min(92vw, 620px);
  height:auto;
  display:block;
}
.eyebrow{
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--gold-soft);
  font-size:.75rem;
  margin:0 0 10px;
}
h1{margin:0}
.content{max-width:1280px; margin:0 auto; padding:0 18px 38px}
.menu-only-layout{padding-top:6px}
.glass{
  background: var(--panel);
  border:1px solid var(--line);
  backdrop-filter: blur(15px);
  box-shadow: var(--shadow);
}
.price-pill,.primary-btn,.secondary-btn{
  border:1px solid var(--line);
  background: rgba(10,23,21,.76);
  color:var(--text);
  border-radius:999px;
  padding:10px 16px;
  backdrop-filter: blur(8px);
}
.category-strip{
  margin-top:8px; border-radius:999px; padding:10px; overflow:auto; display:flex; gap:8px;
}
.category-chip{
  white-space:nowrap; cursor:pointer; border:none; font:inherit; color:var(--text);
  background:transparent; border-radius:999px; padding:12px 16px;
}
.category-chip.active{background:rgba(210,164,86,.22); border:1px solid var(--line)}
.category-header{
  display:flex; justify-content:space-between; gap:16px; align-items:end; padding:26px 8px 12px;
}
.category-header h2{font-size:2rem; margin:0}
.results-summary{color:var(--muted)}
.menu-grid{
  display:grid; grid-template-columns:1fr; gap:18px;
}
.card{
  overflow:hidden; border-radius:24px; border:1px solid var(--line); background:var(--panel-strong); box-shadow:var(--shadow);
  display:grid; grid-template-columns:280px 1fr;
}
.card-image-wrap{position:relative; overflow:hidden; background:rgba(255,255,255,.03); min-height:100%}
.card img{width:100%; height:100%; object-fit:cover; display:block}
.card-body{padding:18px; display:flex; flex-direction:column; gap:10px}
.card-top{display:flex; justify-content:space-between; gap:12px; align-items:start}
.card h3{margin:0; font-size:1.18rem}
.code{color:var(--gold-soft); font-size:.8rem; letter-spacing:.14em; text-transform:uppercase}
.subtitle-cn{color:var(--muted); line-height:1.5; min-height:2.2em}
.desc{line-height:1.65; color:#e7dbc4; flex:1}
.card-actions{display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap}
.view-btn{
  background:transparent; color:var(--gold-soft); border:1px solid var(--line); border-radius:999px; padding:9px 14px; cursor:pointer;
}
.allergen-badges{display:flex; gap:8px; flex-wrap:wrap}
.allergen-badge{
  display:inline-flex; align-items:center; justify-content:center; min-width:34px; height:34px;
  padding:0 10px; border-radius:999px; border:1px solid var(--line); background:rgba(210,164,86,.08);
  color:var(--gold-soft); font-size:.88rem;
}
.card-allergens-note{color:var(--muted); font-size:.94rem; line-height:1.55}
.allergens-section{
  margin:28px 0 10px; padding:22px; display:grid; grid-template-columns:minmax(240px, 340px) 1fr; gap:20px; align-items:center;
  border-radius:var(--radius);
}
.allergens-section h3{margin:0 0 10px; font-size:1.4rem}
.allergens-copy p:last-child{margin-bottom:0; color:var(--muted); line-height:1.6}
.allergens-image-wrap{
  overflow:auto; border-radius:16px; border:1px solid var(--line); background:rgba(255,255,255,.02); padding:10px;
}
.allergens-image-wrap img{width:100%; min-width:780px; display:block}
.dish-modal{
  border:none; padding:0; background:transparent; width:min(980px, calc(100vw - 24px));
}
.dish-modal::backdrop{background:rgba(0,0,0,.75)}
.modal-grid{
  display:grid; grid-template-columns:1.05fr .95fr; background:#0d2b25; border:1px solid var(--line); border-radius:26px; overflow:hidden;
}
.modal-image-wrap{min-height:360px; background:#050b0a}
.modal-image-wrap img{width:100%; height:100%; object-fit:cover}
.modal-content{padding:26px; color:var(--modal-text)}
.modal-content h3{font-size:2rem; margin:0 0 12px; color:var(--gold-soft)}
.modal-subtitle{color:#f3e7cc; line-height:1.6}
.modal-allergens{color:#fff4d6; line-height:1.7}
#modalDescription{color:#fff8eb; line-height:1.7}
.modal-close{
  position:absolute; right:14px; top:14px; z-index:2; border:none; background:rgba(0,0,0,.55);
  color:#fff; width:44px; height:44px; border-radius:50%; font-size:1.8rem; cursor:pointer;
}
.admin-body .admin-shell{max-width:1380px; margin:0 auto; padding:24px 18px 40px}
.admin-login{max-width:460px; margin:12vh auto 0; padding:28px}
.login-form,.create-grid{display:grid; gap:14px}
.hidden{display:none !important}
.error-text{color:#ffb0a8; min-height:1.4em}
.muted{color:var(--muted)}
.back-link{display:inline-block; margin-top:14px; color:var(--gold-soft)}
.admin-top{padding:20px; display:flex; justify-content:space-between; gap:18px; align-items:flex-start}
.admin-create,.admin-list,.admin-login{padding:20px; border-radius:var(--radius)}
.create-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.create-grid textarea{grid-column:1/-1; resize:vertical}
.create-grid button{justify-self:start}
.admin-toolbar{display:flex; gap:12px; margin-bottom:16px}
.admin-toolbar > *{flex:1}
.admin-items{display:grid; gap:14px}
.admin-item{
  border:1px solid var(--line); border-radius:18px; padding:16px; background:rgba(255,255,255,.03);
}
.admin-item-head{display:flex; justify-content:space-between; gap:12px; align-items:center; margin-bottom:12px}
.admin-item-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px}
.admin-item-grid textarea{grid-column:1/-1}
.row-actions{display:flex; gap:10px; margin-top:12px}
.danger-soft{border-color:rgba(255,120,120,.35)}
.admin-toolbar input, .create-grid input, .create-grid textarea, .create-grid select, .login-form input{
  width:100%; border-radius:14px; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  color:var(--text); padding:14px 16px; font:inherit;
}
@media (max-width: 860px){
  .category-header,.admin-top,.admin-toolbar{flex-direction:column; align-items:stretch}
  .modal-grid,.card,.create-grid,.admin-item-grid,.allergens-section{grid-template-columns:1fr}
  .card-image-wrap{min-height:220px}
  .allergens-image-wrap img{min-width:640px}
}


/* Custom updates for Jade final layout */
.hero-logo-only{
  gap: 10px;
}
.jade-wordmark{
  color:#a59369;
  letter-spacing:.24em;
  line-height:1;
  text-align:center;
}
.brand-logo{
  width:min(88vw, 520px);
  margin:0 auto;
}
.hero{
  min-height:26vh;
  padding:24px 20px 6px;
}
.card-top h3{
  color:var(--gold-soft);
}
.allergens-section{
  grid-template-columns:1fr;
  align-items:start;
}
.allergens-legend{
  border:1px solid var(--line);
  border-radius:18px;
  padding:18px 20px;
  background:rgba(255,255,255,.02);
}
.allergen-legend-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(180px, 1fr));
  gap:12px 18px;
  color:var(--text);
  line-height:1.6;
}
.allergen-legend-grid strong{
  color:var(--gold-soft);
  display:inline-block;
  min-width:24px;
}
.modal-content .eyebrow,
#modalName,
#modalDescription,
.modal-subtitle,
.modal-allergens{
  color:#f7eddc;
}
#modalName{
  color:#a59369;
}
.code{
  display:none;
}
@media (max-width: 900px){
  .allergen-legend-grid{
    grid-template-columns:repeat(2, minmax(160px, 1fr));
  }
}
@media (max-width: 640px){
  .allergen-legend-grid{
    grid-template-columns:1fr;
  }
}


/* ===== Phone optimization & premium polish ===== */
.hero{
  min-height:22vh;
  padding:20px 16px 8px;
}
.hero-content{
  width:100%;
  display:flex;
  justify-content:center;
}
.brand-lockup{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  text-align:center;
}
.brand-logo{
  width:min(88vw, 440px);
  max-width:440px;
  margin:0 auto;
  display:block;
}
.jade-wordmark{
  color:#a59369;
  margin:0;
  text-align:center;
  letter-spacing:.22em;
  font-weight:600;
  line-height:1;
}
.mobile-hint{
  margin:10px 10px 0;
  text-align:center;
  color:var(--muted);
  font-size:.82rem;
  letter-spacing:.04em;
}
.category-strip{
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.category-strip::-webkit-scrollbar{display:none;}
.category-header{
  padding:18px 6px 10px;
}
.category-header h2{
  font-size:clamp(1.5rem, 5vw, 2rem);
}
.results-summary{
  font-size:.95rem;
}
.menu-grid{
  gap:14px;
}
.card{
  grid-template-columns:1fr;
  border-radius:20px;
}
.card-image-wrap{
  min-height:220px;
}
.card-body{
  padding:16px;
  gap:8px;
}
.card h3{
  font-size:1.15rem;
  line-height:1.25;
  color:var(--gold-soft);
}
.subtitle-cn{
  color:#e2d4b7;
  min-height:auto;
  margin-top:2px;
}
.subtitle-cn .grammage{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:.94rem;
}
.desc{
  font-size:.98rem;
  line-height:1.6;
}
.price-pill{
  padding:8px 14px;
  font-size:.96rem;
  white-space:nowrap;
}
.card-allergens-note{
  font-size:.92rem;
}
.allergen-legend-grid{
  grid-template-columns:repeat(2, minmax(140px, 1fr));
  gap:10px 14px;
}
.dish-modal{
  width:min(960px, calc(100vw - 14px));
}
.modal-grid{
  grid-template-columns:1fr;
}
.modal-image-wrap{
  min-height:240px;
}
.modal-content{
  padding:18px;
}
.modal-content h3{
  font-size:1.6rem;
  line-height:1.2;
}
.modal-subtitle{
  color:#eadcbf;
  line-height:1.5;
}
#modalDescription{
  color:#fff8eb;
  line-height:1.65;
}
.modal-allergens{
  color:#f3e8cd;
}
@media (max-width: 900px){
  .content{
    padding:0 14px 28px;
  }
  .category-strip{
    gap:6px;
    padding:8px;
    margin-top:4px;
  }
  .category-chip{
    padding:11px 14px;
    font-size:.95rem;
  }
  .card-image-wrap{
    min-height:200px;
  }
}
@media (max-width: 640px){
  .hero{
    min-height:18vh;
    padding-top:16px;
  }
  .brand-logo{
    width:min(92vw, 360px);
  }
  .jade-wordmark{
    font-size:clamp(1.8rem, 8vw, 2.5rem);
    letter-spacing:.18em;
  }
  .mobile-hint{
    display:block;
  }
  .category-header{
    display:block;
  }
  .results-summary{
    margin-top:8px;
  }
  .card{
    border-radius:18px;
  }
  .card-image-wrap{
    min-height:180px;
  }
  .card-body{
    padding:14px;
  }
  .card-top{
    display:grid;
    grid-template-columns:1fr auto;
    align-items:start;
  }
  .subtitle-cn{
    font-size:.95rem;
  }
  .desc{
    font-size:.95rem;
  }
  .card-actions{
    flex-direction:column;
    align-items:flex-start;
  }
  .allergen-legend-grid{
    grid-template-columns:1fr;
  }
  .modal-close{
    right:10px;
    top:10px;
    width:40px;
    height:40px;
  }
}
@media (min-width: 641px){
  .mobile-hint{
    display:none;
  }
}


/* ===== Final premium polish ===== */
body{
  letter-spacing:.01em;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 20% 12%, rgba(165,147,105,.10), transparent 24%),
    radial-gradient(circle at 82% 16%, rgba(165,147,105,.08), transparent 20%),
    radial-gradient(circle at 50% 88%, rgba(165,147,105,.05), transparent 26%);
  z-index:0;
}

.hero{
  min-height:20vh;
}
.hero-content{
  padding:8px 12px 2px;
}
.brand-lockup{
  position:relative;
}
.brand-lockup::after{
  content:"";
  width:min(220px, 46vw);
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(165,147,105,.75), transparent);
  display:block;
  margin:10px auto 0;
}
.brand-logo{
  filter: drop-shadow(0 8px 28px rgba(0,0,0,.28));
}
.jade-wordmark{
  text-shadow:0 2px 12px rgba(0,0,0,.22);
}

.content{
  max-width:1100px;
}
.menu-intro{
  text-align:center;
  max-width:760px;
  margin:0 auto 18px;
  padding:4px 12px 10px;
}
.menu-intro-kicker{
  margin:0 0 8px;
  color:var(--gold-soft);
  text-transform:uppercase;
  letter-spacing:.24em;
  font-size:.76rem;
}
.menu-intro-title{
  margin:0;
  font-size:clamp(1.8rem, 4.6vw, 2.8rem);
  color:#f1e6d0;
  font-weight:500;
}
.menu-intro-copy{
  margin:12px auto 0;
  max-width:640px;
  color:var(--muted);
  line-height:1.7;
  font-size:.98rem;
}

.category-strip{
  border-radius:20px;
  padding:10px;
  background:linear-gradient(180deg, rgba(11,25,23,.86), rgba(7,18,16,.74));
}
.category-chip{
  transition:all .22s ease;
}
.category-chip:hover{
  background:rgba(165,147,105,.12);
}
.category-chip.active{
  box-shadow:inset 0 0 0 1px rgba(165,147,105,.28), 0 10px 20px rgba(0,0,0,.18);
}

.category-header{
  align-items:center;
  border-bottom:1px solid rgba(165,147,105,.14);
  margin-bottom:14px;
}
.category-header h2{
  color:#f0e3cb;
  letter-spacing:.02em;
}

.menu-grid{
  gap:18px;
}
.card{
  position:relative;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  background:
    linear-gradient(180deg, rgba(11,23,21,.97), rgba(8,18,16,.97));
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 52px rgba(0,0,0,.28);
  border-color:rgba(165,147,105,.34);
}
.card-image-wrap{
  position:relative;
}
.card-image-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.18) 100%);
  pointer-events:none;
}
.card-body{
  position:relative;
}
.card h3{
  margin:0;
  color:#f0dfbf;
  font-size:1.18rem;
}
.subtitle-cn{
  font-size:.98rem;
  color:#dfcfb0;
}
.subtitle-cn .grammage{
  color:#aa9b79;
  letter-spacing:.02em;
}
.desc{
  color:#efe4cf;
}
.price-pill{
  background:linear-gradient(180deg, rgba(21,35,31,.92), rgba(11,22,20,.92));
  box-shadow:inset 0 0 0 1px rgba(165,147,105,.12);
}
.card-actions{
  padding-top:4px;
  border-top:1px solid rgba(165,147,105,.10);
}
.card-allergens-note{
  color:#cabd9f;
}
.view-btn{
  transition:all .2s ease;
}
.view-btn:hover{
  background:rgba(165,147,105,.10);
  transform:translateY(-1px);
}

.allergens-section{
  margin-top:28px;
  background:linear-gradient(180deg, rgba(10,22,20,.93), rgba(8,17,15,.88));
}
.allergens-section h3{
  color:#f0dfbf;
}
.allergens-copy p:last-child{
  color:#cbbd9d;
}
.allergens-legend{
  box-shadow:inset 0 0 0 1px rgba(165,147,105,.06);
}
.allergen-legend-grid div{
  padding:8px 10px;
  border-radius:12px;
  background:rgba(255,255,255,.015);
}

.menu-footer-note{
  text-align:center;
  max-width:760px;
  margin:16px auto 8px;
  padding:0 12px 24px;
}
.menu-footer-note p{
  margin:0;
  color:#bbaa87;
  font-size:.92rem;
  line-height:1.65;
}

.dish-modal::backdrop{
  backdrop-filter:blur(3px);
}
.modal-grid{
  background:
    linear-gradient(180deg, rgba(11,31,27,.98), rgba(8,24,21,.98));
  box-shadow:0 24px 70px rgba(0,0,0,.45);
}
.modal-content{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.modal-content h3{
  color:#f0dfbf;
}
.modal-subtitle{
  color:#deceae;
}
#modalDescription{
  color:#f6eddc;
}
.modal-allergens{
  padding-top:6px;
  border-top:1px solid rgba(165,147,105,.12);
}
.modal-close{
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
.modal-close:hover{
  background:rgba(0,0,0,.7);
}

@media (max-width: 640px){
  .menu-intro{
    margin-bottom:14px;
    padding-bottom:8px;
  }
  .menu-intro-copy{
    font-size:.94rem;
    line-height:1.65;
  }
  .category-strip{
    border-radius:16px;
  }
  .card{
    box-shadow:0 14px 34px rgba(0,0,0,.20);
  }
  .card h3{
    font-size:1.08rem;
  }
  .subtitle-cn{
    font-size:.94rem;
  }
  .card-allergens-note{
    font-size:.9rem;
    line-height:1.5;
  }
  .view-btn{
    width:100%;
    text-align:center;
    padding:11px 14px;
  }
}


/* Final requested tweaks */
.menu-intro{
  margin:0 auto 10px;
  padding:2px 12px 8px;
}
.menu-intro-title-simple{
  font-size:clamp(1.55rem, 4.2vw, 2.15rem);
  letter-spacing:.08em;
  color:#f0e3cb;
  text-transform:uppercase;
}

.price-pill,
.card-allergens-note,
.modal-allergens,
.allergen-legend-grid,
.subtitle-cn .grammage,
#modalPrice,
.view-btn,
.category-chip{
  font-variant-numeric: lining-nums tabular-nums;
  font-feature-settings: "lnum" 1, "tnum" 1;
}

.subtitle-cn .grammage{
  display:block;
  margin-top:4px;
  line-height:1.35;
}

.modal-subtitle .grammage{
  display:block;
  margin-top:6px;
  color:#bbaa87;
  font-size:.95rem;
  line-height:1.35;
}

@media (max-width: 640px){
  .menu-intro{
    margin-bottom:8px;
    padding-bottom:4px;
  }
  .menu-intro-title-simple{
    font-size:clamp(1.4rem, 7vw, 1.9rem);
  }
}


.menu-intro-title-simple{
  color: var(--gold-soft) !important;
  letter-spacing: .24em;
}


/* Final mobile number consistency fix */
@media (max-width: 640px){
  .price-pill,
  .card-allergens-note,
  .modal-allergens,
  .allergen-legend-grid,
  .subtitle-cn .grammage,
  #modalPrice,
  .view-btn,
  .category-chip{
    font-variant-numeric: tabular-nums lining-nums;
    font-feature-settings: "tnum" 1, "lnum" 1;
    font-kerning: none;
  }
}


/* Final hard fix for equal number size on phones */
@media (max-width: 640px){
  .price-pill,
  .card-allergens-note,
  .modal-allergens,
  .allergen-legend-grid,
  .subtitle-cn .grammage,
  #modalPrice,
  .view-btn,
  .category-chip,
  .results-summary,
  .menu-footer-note,
  .modal-price-label,
  input,
  textarea,
  button,
  select,
  strong,
  .eyebrow{
    font-variant-numeric: tabular-nums lining-nums !important;
    font-feature-settings: "tnum" 1, "lnum" 1 !important;
    -webkit-font-feature-settings: "tnum" 1, "lnum" 1 !important;
    font-kerning: none !important;
  }

  .price-pill,
  #modalPrice,
  .card-allergens-note,
  .modal-allergens,
  .allergen-legend-grid,
  .subtitle-cn .grammage{
    letter-spacing: 0 !important;
    text-rendering: geometricPrecision;
    -webkit-text-size-adjust: 100%;
  }
}

.brand-lockup{
 display:flex;
 justify-content:center;
 align-items:center;
}

.jade-logo-img{
 max-width:340px;
 width:100%;
 margin:10px auto;
 display:block;
}

@media (max-width:640px){
 .jade-logo-img{
  max-width:260px;
 }
}

/* merged flow */
.screen-block.hidden{display:none!important}
.welcome-card{max-width:560px;margin:20px auto 0;padding:28px 24px;text-align:center;border-radius:24px}
.creative-welcome-card{position:relative;min-height:62vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden;background:radial-gradient(circle at top left,rgba(165,147,105,.18),transparent 28%),radial-gradient(circle at bottom right,rgba(165,147,105,.10),transparent 26%),linear-gradient(180deg,rgba(12,24,22,.96),rgba(8,18,16,.94));box-shadow:0 24px 70px rgba(0,0,0,.28)}
.welcome-ornament{position:absolute;width:150px;height:150px;border:1px solid rgba(165,147,105,.16);border-radius:50%;pointer-events:none;animation:floatSlow 6s ease-in-out infinite}
.welcome-ornament-left{top:-55px;left:-45px}.welcome-ornament-right{bottom:-55px;right:-35px;animation-delay:1.5s}
.welcome-title{margin:0;color:#f0dfbf;font-size:clamp(2rem,5vw,3rem);font-weight:500;line-height:1.08}
.welcome-copy{margin:12px auto 0;max-width:460px;color:var(--muted);line-height:1.7}
.welcome-actions{margin-top:auto;padding-top:30px}.welcome-btn-large{min-width:230px;padding:14px 26px;font-size:1.05rem}
.menu-intro-categories{margin:0 auto 10px!important;padding:4px 0 2px!important;text-align:center}
.category-selection-card-compact{padding:12px;border-radius:24px}.creative-category-card{max-width:1180px;margin:0 auto;width:100%;background:radial-gradient(circle at top left,rgba(200,174,114,.09),transparent 24%),linear-gradient(180deg,rgba(12,24,22,.97),rgba(8,18,16,.95))!important;box-shadow:0 20px 56px rgba(0,0,0,.24)}
.category-grid{width:100%;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}
.food-card{position:relative;overflow:hidden;min-height:145px;border-radius:20px;padding:14px;justify-content:flex-end;align-items:flex-start;text-align:left;background:rgba(10,18,16,.78);animation:categoryFadeUp .5s ease both}
.category-card-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.02);z-index:0;transition:transform .55s ease}.category-card-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.12) 0%,rgba(0,0,0,.28) 38%,rgba(0,0,0,.72) 100%);z-index:1}
.food-card .category-card-label{position:relative;z-index:2;color:#fff4dd;text-shadow:0 2px 10px rgba(0,0,0,.45);font-size:1rem;line-height:1.18;font-weight:600;max-width:95%}
.food-card::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(200,174,114,.22);pointer-events:none;z-index:2}.food-card:hover .category-card-bg{transform:scale(1.06)}
@keyframes categoryFadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes floatSlow{0%,100%{transform:translateY(0)}50%{transform:translateY(10px)}}
.category-strip{scrollbar-width:none;-ms-overflow-style:none}.category-strip::-webkit-scrollbar{display:none}
@media(max-width:900px){.category-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.food-card{min-height:130px}}
@media(max-width:640px){.creative-welcome-card{min-height:66vh;padding:24px 18px}.welcome-btn-large{width:100%;min-width:0;padding:16px 18px;font-size:1.08rem}.category-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px}.category-selection-card-compact{padding:8px;border-radius:18px}.food-card{min-height:92px;border-radius:15px;padding:9px}.food-card .category-card-label{font-size:.82rem;line-height:1.1}}


/* Admin allergen field + dish image disclaimer */
.image-disclaimer{
  margin:2px 0 0;
  color:#b8aa8c;
  font-size:.78rem;
  line-height:1.45;
  font-style:italic;
}
.modal-image-disclaimer{
  color:#c9bb9e;
  margin-top:-2px;
}
.admin-item-grid input[data-field="allergens"]{
  border-color:rgba(165,147,105,.34);
}


/* Admin image browse/upload */
.image-upload-control{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.image-upload-control .upload-btn{
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.image-file-name{
  color:var(--muted);
  font-size:.9rem;
  line-height:1.4;
}
.admin-row-upload{
  min-width:220px;
}
@media (max-width:640px){
  .image-upload-control{
    align-items:stretch;
    flex-direction:column;
  }
  .image-upload-control .upload-btn{
    width:100%;
  }
}
