
:root{--brand:#f97316;--brand2:#fb923c;--ink:#111827;--muted:#6b7280;--line:#e5e7eb;--bg:#fffaf5;--card:#fff;--shadow:0 20px 50px rgba(17,24,39,.08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:radial-gradient(circle at top left,#fff7ed,#fff 28%,#f8fafc)}a{text-decoration:none;color:inherit}button,input,textarea,select{font:inherit}.shop-header{min-height:86px;padding:18px clamp(18px,4vw,64px);display:flex;align-items:center;justify-content:space-between;gap:22px;position:sticky;top:0;z-index:30;background:rgba(255,255,255,.86);backdrop-filter:blur(18px);border-bottom:1px solid rgba(229,231,235,.7)}.shop-header.compact{position:relative}.brand-lockup{display:flex;align-items:center;gap:12px;min-width:210px}.brand-lockup img,.logo-mark{width:52px;height:52px;border-radius:18px;object-fit:cover;background:linear-gradient(135deg,var(--brand),#ffedd5);display:grid;place-items:center;font-size:25px;box-shadow:0 10px 30px rgba(249,115,22,.25)}.brand-lockup strong{display:block;font-size:24px;letter-spacing:-.04em}.brand-lockup span{display:block;color:var(--muted);font-size:13px;margin-top:2px}.mode-switch{display:flex;align-items:center;gap:10px;padding:8px;background:white;border:1px solid var(--line);border-radius:24px;box-shadow:0 12px 34px rgba(17,24,39,.06)}.mode-btn{border:0;background:#f9fafb;border-radius:16px;padding:13px 20px;font-weight:800;color:var(--ink);cursor:pointer;transition:.2s}.mode-btn.active,.mode-btn:hover{background:linear-gradient(135deg,var(--brand),#ea580c);color:white;box-shadow:0 8px 20px rgba(249,115,22,.28)}.mode-btn.link{display:inline-flex}.shop-nav{display:flex;align-items:center;gap:14px;color:#374151;font-weight:700}.shop-nav a{padding:10px 12px;border-radius:12px}.shop-nav a:hover{background:#fff7ed;color:var(--brand)}.toast{max-width:1180px;margin:18px auto;border-radius:18px;padding:14px 18px;font-weight:800}.toast.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.premium-hero{max-width:1240px;margin:28px auto 30px;border-radius:36px;min-height:380px;background:linear-gradient(135deg,#111827,#292524);background-size:cover;background-position:center;display:grid;grid-template-columns:1fr 330px;align-items:end;padding:50px;color:white;box-shadow:0 30px 70px rgba(17,24,39,.18);overflow:hidden;position:relative}.premium-hero:after{content:"";position:absolute;inset:auto -12% -25% auto;width:420px;height:420px;border-radius:50%;background:rgba(249,115,22,.25);filter:blur(4px)}.hero-copy{position:relative;z-index:1}.hero-badge{display:inline-flex;padding:9px 14px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);font-weight:800;color:#fed7aa}.hero-copy h1{font-size:clamp(42px,6vw,76px);line-height:.95;margin:22px 0 18px;max-width:770px;letter-spacing:-.06em}.hero-copy p{font-size:20px;color:#e5e7eb;max-width:690px;line-height:1.6}.hero-actions{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}.primary-cta,.secondary-cta{border-radius:16px;padding:14px 20px;font-weight:900}.primary-cta{background:linear-gradient(135deg,var(--brand),#ea580c);color:white}.secondary-cta{background:white;color:#111827}.hero-card{position:relative;z-index:1;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(12px);border-radius:28px;padding:24px;box-shadow:0 20px 50px rgba(0,0,0,.15)}.hero-card span{color:#fed7aa;font-weight:800}.hero-card strong{display:block;font-size:28px;margin:8px 0}.hero-card small{color:#e5e7eb}.shop-shell{max-width:1240px;margin:0 auto 80px;display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:30px;align-items:start}.menu-toolbar{display:flex;align-items:end;justify-content:space-between;gap:16px;margin:8px 0 18px}.menu-toolbar h2{font-size:36px;margin:0;letter-spacing:-.05em}.menu-toolbar p{margin:6px 0 0;color:var(--muted)}.search-box{background:white;border:1px solid var(--line);border-radius:18px;display:flex;align-items:center;gap:8px;padding:0 14px;min-width:260px;box-shadow:0 12px 30px rgba(17,24,39,.04)}.search-box input{height:48px;border:0;outline:0;width:100%;background:transparent}.category-strip{display:flex;gap:10px;overflow:auto;padding:4px 2px 18px;margin-bottom:6px;position:sticky;top:86px;background:rgba(255,255,255,.82);z-index:20;backdrop-filter:blur(14px)}.cat-chip{border:1px solid var(--line);background:white;border-radius:999px;padding:13px 18px;font-weight:900;white-space:nowrap;cursor:pointer;transition:.2s;box-shadow:0 8px 20px rgba(17,24,39,.04)}.cat-chip.active,.cat-chip:hover{border-color:#fed7aa;background:#fff7ed;color:var(--brand);transform:translateY(-1px)}.menu-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.premium-food-card{background:white;border:1px solid rgba(229,231,235,.8);border-radius:26px;padding:12px;display:grid;grid-template-columns:150px 1fr;gap:16px;box-shadow:0 18px 44px rgba(17,24,39,.06);transition:.22s}.premium-food-card:hover{transform:translateY(-3px);box-shadow:0 26px 64px rgba(17,24,39,.1)}.food-media{position:relative;height:150px;border-radius:20px;overflow:hidden;background:#f3f4f6}.food-media img{width:100%;height:100%;object-fit:cover}.food-placeholder{width:100%;height:100%;display:grid;place-items:center;font-size:40px;background:linear-gradient(135deg,#f3f4f6,#fff7ed)}.featured-badge{position:absolute;top:10px;left:10px;background:linear-gradient(135deg,var(--brand),#ea580c);color:white;font-size:12px;font-weight:900;padding:6px 9px;border-radius:999px}.food-info{display:flex;flex-direction:column;min-width:0}.food-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.food-title-row h3{font-size:20px;margin:6px 0 6px;letter-spacing:-.03em}.heart{border:0;background:#f9fafb;color:#9ca3af;border-radius:50%;width:36px;height:36px;font-size:20px;cursor:pointer}.food-info p{margin:0;color:var(--muted);line-height:1.45;min-height:42px}.mini-options{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.mini-options span{font-size:12px;background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;padding:5px 8px;border-radius:999px;font-weight:800}.food-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:14px}.food-footer strong{font-size:22px;color:var(--brand);letter-spacing:-.04em}.add-btn{border:0;border-radius:14px;background:linear-gradient(135deg,var(--brand),#ea580c);color:white;font-weight:900;padding:11px 18px;cursor:pointer;box-shadow:0 10px 22px rgba(249,115,22,.28)}.order-panel{position:sticky;top:108px;background:white;border:1px solid rgba(229,231,235,.8);border-radius:32px;padding:22px;box-shadow:0 28px 70px rgba(17,24,39,.1)}.order-head{display:flex;justify-content:space-between;align-items:start;gap:12px}.order-head h2{font-size:28px;margin:0;letter-spacing:-.04em}.order-head span{color:var(--muted);font-weight:800}.clear-cart{border:0;background:#fff7ed;color:#c2410c;border-radius:12px;padding:8px 10px;font-weight:900;cursor:pointer}.context-pill{margin:16px 0;background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:12px;font-weight:900;color:#334155}.cart-list{display:flex;flex-direction:column;gap:10px;max-height:310px;overflow:auto;padding-right:4px}.cart-empty{text-align:center;color:#9ca3af;border:1px dashed #d1d5db;border-radius:18px;padding:24px}.cart-empty span{font-size:34px}.cart-empty p{margin:8px 0 0}.cart-row{display:grid;grid-template-columns:58px 1fr auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:18px;padding:10px}.cart-thumb{width:58px;height:58px;border-radius:14px;background:#f3f4f6;object-fit:cover;display:grid;place-items:center}.cart-main strong{display:block}.cart-main small{display:block;color:var(--muted);line-height:1.35}.cart-actions{text-align:right}.cart-actions button{border:0;background:#fee2e2;color:#991b1b;border-radius:10px;padding:5px 8px;font-weight:900;margin-top:5px}.checkout-summary{border-top:1px solid var(--line);margin-top:18px;padding-top:16px}.checkout-summary>div:not(.tip-area){display:flex;justify-content:space-between;margin:8px 0}.summary-muted{display:flex;justify-content:space-between;color:var(--muted);margin-top:8px}.tip-area{background:#fff7ed;border:1px solid #fed7aa;border-radius:18px;padding:14px;margin:14px 0}.tip-area label{font-weight:900}.tip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:10px 0}.tip-grid button{border:1px solid #fed7aa;background:white;border-radius:12px;padding:9px 6px;font-weight:900;cursor:pointer}.tip-area input{width:100%;border:1px solid #fed7aa;border-radius:12px;padding:11px;background:white}.grand-total{font-size:20px;font-weight:900;border-top:1px solid var(--line);padding-top:14px}.grand-total strong{font-size:30px;color:var(--brand)}.checkout-form{display:flex;flex-direction:column;gap:10px;margin-top:18px}.checkout-form label,.pretty-form label,.admin-form label{font-size:13px;font-weight:900;color:#374151}.checkout-form input,.checkout-form textarea,.pretty-form input,.pretty-form textarea,.admin-form input,.admin-form textarea,.admin-form select,.admin-table-row select,.ticket-actions select{width:100%;border:1px solid var(--line);border-radius:14px;padding:13px 14px;margin-top:6px;background:white;outline:none}.checkout-form input:focus,.checkout-form textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px #ffedd5}.checkout-form textarea{min-height:74px;resize:vertical}.place-order{border:0;border-radius:16px;background:linear-gradient(135deg,var(--brand),#ea580c);color:white;font-weight:950;padding:16px;cursor:pointer;font-size:16px;box-shadow:0 16px 34px rgba(249,115,22,.3)}.order-message{font-weight:900;color:#166534}.empty-state{background:white;border:1px dashed #d1d5db;border-radius:28px;padding:40px;text-align:center}.empty-state span{font-size:48px}.empty-state a{display:inline-block;margin-top:12px;background:var(--brand);color:white;border-radius:14px;padding:12px 18px;font-weight:900}.premium-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px}.premium-modal.hidden{display:none}.modal-scrim{position:absolute;inset:0;background:rgba(15,23,42,.58);backdrop-filter:blur(6px)}.premium-modal-card{position:relative;background:white;border-radius:30px;width:min(620px,100%);padding:22px;box-shadow:0 40px 90px rgba(0,0,0,.28);max-height:92vh;overflow:auto}.modal-x{position:absolute;right:18px;top:16px;border:0;background:#f3f4f6;border-radius:50%;width:38px;height:38px;font-size:24px;cursor:pointer;z-index:2}.modal-hero{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:16px}.modal-image{height:140px;border-radius:22px;background:#f3f4f6;background-size:cover;background-position:center;display:grid;place-items:center;font-size:36px}.modal-hero h2{font-size:30px;margin:0 40px 6px 0;letter-spacing:-.04em}.modal-hero p{color:var(--muted);margin:0;line-height:1.5}.option-group{border:1px solid var(--line);border-radius:20px;padding:16px;margin:14px 0}.option-group strong{display:block;font-size:18px;margin-bottom:4px}.option-group p{margin:0 0 8px;color:var(--muted)}.option-group label{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;cursor:pointer}.option-group label:hover{background:#fff7ed}.option-group input{accent-color:var(--brand)}.modal-bottom{display:grid;grid-template-columns:130px 1fr 150px;gap:10px;border-top:1px solid var(--line);padding-top:16px;align-items:center}.qty-stepper{display:grid;grid-template-columns:40px 1fr 40px;border:1px solid var(--line);border-radius:14px;overflow:hidden}.qty-stepper button{border:0;background:#fff7ed;color:#c2410c;font-weight:950;font-size:20px}.qty-stepper input{text-align:center;border:0;outline:0}.item-note{border:1px solid var(--line);border-radius:14px;padding:13px}.modal-add{border:0;border-radius:14px;background:linear-gradient(135deg,var(--brand),#ea580c);color:white;font-weight:950;padding:14px;cursor:pointer}.simple-page{background:linear-gradient(135deg,#fff7ed,#fff,#f8fafc);min-height:100vh}.center-shell{max-width:820px;margin:42px auto;padding:0 18px}.reservation-card{background:white;border:1px solid var(--line);border-radius:34px;padding:34px;box-shadow:var(--shadow)}.reservation-copy span{display:inline-flex;color:var(--brand);font-weight:950;text-transform:uppercase;letter-spacing:.12em;font-size:12px}.reservation-copy h1{font-size:52px;letter-spacing:-.06em;margin:10px 0}.reservation-copy p{color:var(--muted);font-size:18px}.pretty-form{display:flex;flex-direction:column;gap:14px;margin-top:24px}.pretty-form button,.admin-form button,.admin-primary,.admin-table-row button,.assign-row button,.ticket-actions button{border:0;border-radius:14px;background:linear-gradient(135deg,var(--brand),#ea580c);color:white;font-weight:950;padding:13px 16px;cursor:pointer}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.table-link-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:24px}.table-link-grid a{background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:5px}.admin-app{background:#f8fafc;display:grid;grid-template-columns:260px 1fr;min-height:100vh}.admin-sidebar{background:#111827;color:white;padding:28px;position:sticky;top:0;height:100vh}.admin-brand{font-size:20px;margin-bottom:28px}.admin-sidebar a{display:block;padding:13px 14px;border-radius:14px;color:#d1d5db;margin-bottom:6px;font-weight:800}.admin-sidebar a.active,.admin-sidebar a:hover{background:#1f2937;color:white}.admin-main{padding:34px;max-width:1420px;width:100%}.admin-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}.admin-top h1{font-size:42px;margin:0;letter-spacing:-.05em}.admin-top p{color:var(--muted);margin:6px 0 0}.admin-primary{display:inline-flex}.admin-alert{border-radius:16px;padding:14px 16px;font-weight:900;margin-bottom:18px}.admin-alert.error{background:#fef2f2;color:#991b1b}.admin-alert.success{background:#f0fdf4;color:#166534}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.stat-grid article{background:white;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 10px 28px rgba(17,24,39,.05)}.stat-grid span{display:block;color:var(--muted);font-weight:800}.stat-grid strong{display:block;font-size:32px;margin-top:8px}.admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.admin-card{background:white;border:1px solid var(--line);border-radius:26px;padding:22px;box-shadow:0 12px 34px rgba(17,24,39,.05);margin-bottom:18px}.admin-card.wide{margin-top:18px}.admin-card h2{margin:0 0 16px;font-size:24px;letter-spacing:-.03em}.admin-form{display:flex;flex-direction:column;gap:10px}.admin-form.compact{margin-bottom:18px}.admin-form .inline{display:flex;align-items:center;gap:8px}.admin-form .inline input{width:auto;margin:0}.admin-list{display:flex;flex-direction:column;gap:8px}.admin-list>div{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:10px 12px}.small-danger{border:0;background:#fee2e2;color:#991b1b;border-radius:10px;padding:7px 10px;font-weight:900}.assign-row{display:grid;grid-template-columns:220px 1fr auto;gap:14px;align-items:center;border-top:1px solid var(--line);padding:14px 0}.assign-row div{display:flex;flex-wrap:wrap;gap:12px}.assign-row label{background:#f8fafc;border:1px solid var(--line);border-radius:999px;padding:8px 12px}.admin-table-row{display:grid;grid-template-columns:1fr 1.4fr .7fr 300px;gap:12px;align-items:center;border-top:1px solid var(--line);padding:12px 0}.admin-table-row form{display:flex;gap:8px}.kds{background:#030712;color:white;min-height:100vh}.kds-header{display:flex;justify-content:space-between;align-items:center;padding:28px 34px;border-bottom:1px solid #1f2937;background:#020617;position:sticky;top:0;z-index:20}.kds-header h1{font-size:42px;margin:0}.kds-header p{color:#9ca3af;margin:6px 0 0}.kds-header nav{display:flex;gap:12px}.kds-header a{background:#111827;border:1px solid #374151;border-radius:14px;padding:12px 16px;font-weight:900}.ticket-board{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:28px}.kds-ticket{background:#111827;border:1px solid #374151;border-radius:28px;padding:22px;box-shadow:0 20px 50px rgba(0,0,0,.22)}.kds-ticket.new{border-color:#f97316}.kds-ticket.ready{border-color:#22c55e}.ticket-top{display:flex;justify-content:space-between;align-items:start;gap:14px}.ticket-top strong{font-size:22px;text-transform:capitalize}.ticket-top span{display:block;color:#9ca3af;margin-top:4px}.ticket-top em{font-style:normal;background:#f97316;color:white;border-radius:999px;padding:8px 12px;font-weight:950}.ticket-money{display:flex;gap:10px;margin:16px 0}.ticket-money span{background:#1f2937;border:1px solid #374151;border-radius:12px;padding:8px 10px;color:#e5e7eb}.ticket-note{background:#1f2937;border-radius:14px;padding:12px;color:#e5e7eb}.ticket-items{display:flex;flex-direction:column;gap:10px;margin:16px 0}.ticket-items>div{background:#020617;border:1px solid #374151;border-radius:16px;padding:14px}.ticket-items ul{color:#fbbf24;margin:8px 0 0}.ticket-items small{display:block;color:#9ca3af;margin-top:8px}.ticket-actions{display:grid;grid-template-columns:1fr 120px;gap:10px}.empty-kds{grid-column:1/-1;text-align:center;border:1px dashed #374151;border-radius:28px;padding:60px;color:#9ca3af}.empty-kds span{font-size:54px}.empty-kds h2{color:white}
@media(max-width:1100px){.shop-shell{grid-template-columns:1fr}.order-panel{position:relative;top:auto}.premium-hero{grid-template-columns:1fr}.hero-card{display:none}.admin-app{display:block}.admin-sidebar{height:auto;position:relative}.admin-grid,.stat-grid,.ticket-board{grid-template-columns:1fr 1fr}.admin-table-row{grid-template-columns:1fr}.admin-table-row form{justify-content:flex-start}.shop-header{flex-wrap:wrap}.mode-switch{order:3;width:100%;overflow:auto}.category-strip{top:142px}}@media(max-width:720px){.shop-header{align-items:flex-start}.shop-nav{flex-wrap:wrap;font-size:14px}.brand-lockup strong{font-size:19px}.premium-hero{margin:14px;border-radius:24px;padding:30px;min-height:320px}.hero-copy h1{font-size:42px}.shop-shell{margin:0 14px 50px}.menu-toolbar{display:block}.search-box{min-width:0;margin-top:14px}.menu-grid{grid-template-columns:1fr}.premium-food-card{grid-template-columns:110px 1fr}.food-media{height:120px}.order-panel{border-radius:24px}.modal-hero,.modal-bottom{grid-template-columns:1fr}.modal-image{height:180px}.tip-grid{grid-template-columns:repeat(2,1fr)}.two-col,.table-link-grid,.stat-grid,.admin-grid,.ticket-board{grid-template-columns:1fr}.admin-main{padding:18px}.admin-top{display:block}.assign-row{grid-template-columns:1fr}.reservation-copy h1{font-size:40px}}

.delivery-address-box{background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px;margin:4px 0 8px}.delivery-address-box h3{margin:0 0 10px;font-size:16px;letter-spacing:-.02em}.delivery-address-box .two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:720px){.delivery-address-box .two-col{grid-template-columns:1fr}}


/* ===============================
   v8 MOBILE RESPONSIVE UX FIX
   =============================== */

.mobile-cart-button,
.mobile-cart-backdrop,
.mobile-cart-close {
  display: none;
}

@media (max-width: 920px) {
  body.cart-open {
    overflow: hidden;
  }

  .shop-page {
    padding-bottom: 96px;
  }

  .shop-header {
    min-height: auto;
    padding: 12px 14px;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
  }

  .brand-lockup {
    min-width: 0;
    gap: 10px;
  }

  .brand-lockup img,
  .logo-mark {
    width: 44px;
    height: 44px;
    border-radius: 15px;
    font-size: 22px;
  }

  .brand-lockup strong {
    font-size: 18px;
    line-height: 1.1;
  }

  .brand-lockup span {
    font-size: 12px;
    white-space: nowrap;
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .shop-nav {
    grid-column: 1 / -1;
    width: 100%;
    overflow-x: auto;
    white-space: nowrap;
    gap: 8px;
    padding-bottom: 2px;
    scrollbar-width: none;
  }

  .shop-nav::-webkit-scrollbar {
    display: none;
  }

  .shop-nav a {
    flex: 0 0 auto;
    padding: 9px 12px;
    background: #f8fafc;
    border-radius: 999px;
    font-size: 13px;
  }

  .mode-switch {
    grid-column: 1 / -1;
    order: 3;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    padding: 6px;
    gap: 6px;
    border-radius: 18px;
    overflow: visible;
  }

  .mode-btn {
    padding: 12px 8px;
    font-size: 14px;
    border-radius: 14px;
    text-align: center;
    justify-content: center;
  }

  .premium-hero {
    margin: 12px;
    min-height: 260px;
    border-radius: 24px;
    padding: 28px 22px;
  }

  .hero-copy h1 {
    font-size: 34px;
    line-height: 1;
    margin: 16px 0 12px;
  }

  .hero-copy p {
    font-size: 15px;
    line-height: 1.5;
  }

  .hero-actions {
    gap: 10px;
    margin-top: 20px;
  }

  .primary-cta,
  .secondary-cta {
    width: 100%;
    text-align: center;
    padding: 13px 16px;
  }

  .shop-shell {
    display: block;
    margin: 0 12px 40px;
  }

  .menu-toolbar {
    margin-top: 20px;
  }

  .menu-toolbar h2 {
    font-size: 30px;
  }

  .menu-toolbar p {
    font-size: 14px;
  }

  .search-box {
    width: 100%;
    min-width: 0;
  }

  .category-strip {
    position: sticky;
    top: 140px;
    z-index: 24;
    margin-left: -12px;
    margin-right: -12px;
    padding: 10px 12px;
    background: rgba(255,255,255,.92);
    border-top: 1px solid rgba(229,231,235,.75);
    border-bottom: 1px solid rgba(229,231,235,.75);
  }

  .cat-chip {
    padding: 11px 15px;
    font-size: 14px;
  }

  .menu-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .premium-food-card {
    grid-template-columns: 104px 1fr;
    gap: 12px;
    padding: 10px;
    border-radius: 22px;
  }

  .food-media {
    height: 112px;
    border-radius: 18px;
  }

  .food-title-row h3 {
    font-size: 17px;
    margin: 4px 0;
  }

  .food-info p {
    font-size: 13px;
    min-height: auto;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .mini-options {
    margin-top: 7px;
  }

  .mini-options span {
    font-size: 11px;
    padding: 4px 7px;
  }

  .food-footer {
    padding-top: 10px;
  }

  .food-footer strong {
    font-size: 18px;
  }

  .add-btn {
    padding: 9px 14px;
    border-radius: 12px;
    min-width: 64px;
  }

  /* Convert desktop sidebar into mobile bottom sheet */
  .order-panel {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    top: auto;
    z-index: 90;
    max-height: 88vh;
    overflow: auto;
    border-radius: 28px 28px 0 0;
    padding: 22px 18px 28px;
    transform: translateY(110%);
    transition: transform .28s ease;
    box-shadow: 0 -24px 70px rgba(17,24,39,.28);
  }

  .order-panel.mobile-open {
    transform: translateY(0);
  }

  .mobile-cart-close {
    display: grid;
    place-items: center;
    position: absolute;
    right: 16px;
    top: 14px;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: #f3f4f6;
    font-size: 24px;
    line-height: 1;
    color: #111827;
  }

  .mobile-cart-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 80;
    background: rgba(15,23,42,.42);
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    filter: none;
  }

  .mobile-cart-backdrop.visible {
    display: block;
  }

  .mobile-cart-button {
    position: fixed;
    left: 14px;
    right: 14px;
    bottom: 16px;
    z-index: 70;
    height: 60px;
    border: 0;
    border-radius: 20px;
    background: linear-gradient(135deg,var(--brand),#ea580c);
    color: white;
    font-weight: 950;
    align-items: center;
    justify-content: space-between;
    padding: 0 18px;
    box-shadow: 0 18px 44px rgba(249,115,22,.38);
  }

  .mobile-cart-button span,
  .mobile-cart-button strong {
    font-size: 16px;
  }

  .cart-list {
    max-height: 260px;
  }

  .cart-row {
    grid-template-columns: 50px 1fr;
    position: relative;
  }

  .cart-thumb {
    width: 50px;
    height: 50px;
  }

  .cart-actions {
    grid-column: 2;
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .checkout-summary {
    margin-top: 14px;
    padding-top: 14px;
  }

  .tip-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .checkout-form {
    gap: 9px;
  }

  .checkout-form input,
  .checkout-form textarea,
  .pretty-form input,
  .pretty-form textarea,
  .admin-form input,
  .admin-form textarea,
  .admin-form select {
    font-size: 16px; /* prevents iOS zoom */
    padding: 13px;
    border-radius: 14px;
  }

  .delivery-address-box {
    padding: 12px;
    border-radius: 18px;
  }

  .delivery-address-box .two-col,
  .two-col {
    grid-template-columns: 1fr;
  }

  .place-order {
    position: sticky;
    bottom: 0;
    min-height: 56px;
  }

  /* Modal full-width mobile sheet */
  .premium-modal {
    align-items: end;
    padding: 0;
  }

  .premium-modal-card {
    width: 100%;
    max-height: 92vh;
    border-radius: 28px 28px 0 0;
    padding: 18px;
  }

  .modal-hero {
    grid-template-columns: 96px 1fr;
    gap: 12px;
  }

  .modal-image {
    height: 96px;
    border-radius: 18px;
  }

  .modal-hero h2 {
    font-size: 23px;
    margin-right: 42px;
  }

  .modal-hero p {
    font-size: 13px;
  }

  .option-group {
    padding: 13px;
    border-radius: 18px;
  }

  .option-group label {
    min-height: 44px;
  }

  .modal-bottom {
    grid-template-columns: 1fr;
    position: sticky;
    bottom: 0;
    background: white;
    padding-top: 12px;
  }

  .qty-stepper {
    min-height: 50px;
  }

  .modal-add {
    min-height: 54px;
  }

  /* Simple pages mobile */
  .center-shell {
    margin: 20px auto;
    padding: 0 12px;
  }

  .reservation-card {
    border-radius: 26px;
    padding: 22px;
  }

  .reservation-copy h1 {
    font-size: 34px;
  }

  .reservation-copy p {
    font-size: 15px;
  }

  .table-link-grid {
    grid-template-columns: 1fr;
  }

  /* Admin mobile */
  .admin-app {
    display: block;
  }

  .admin-sidebar {
    position: relative;
    height: auto;
    padding: 16px;
  }

  .admin-sidebar a {
    display: inline-flex;
    margin: 4px;
    padding: 10px 12px;
  }

  .admin-main {
    padding: 14px;
  }

  .admin-top {
    display: block;
  }

  .admin-top h1 {
    font-size: 32px;
  }

  .stat-grid,
  .admin-grid,
  .ticket-board {
    grid-template-columns: 1fr;
  }

  .admin-card {
    border-radius: 22px;
    padding: 18px;
  }

  .assign-row,
  .admin-table-row {
    display: block;
  }

  .assign-row > *,
  .admin-table-row > * {
    margin-bottom: 10px;
  }

  .admin-table-row form {
    display: grid;
    grid-template-columns: 1fr auto;
  }

  /* KDS mobile/tablet */
  .kds-header {
    display: block;
    padding: 18px;
  }

  .kds-header h1 {
    font-size: 32px;
  }

  .kds-header nav {
    margin-top: 12px;
    overflow-x: auto;
  }

  .ticket-board {
    padding: 14px;
  }

  .kds-ticket {
    border-radius: 22px;
    padding: 18px;
  }
}

@media (max-width: 420px) {
  .premium-food-card {
    grid-template-columns: 92px 1fr;
  }

  .food-media {
    height: 102px;
  }

  .food-title-row h3 {
    font-size: 16px;
  }

  .food-footer strong {
    font-size: 17px;
  }

  .add-btn {
    padding: 8px 12px;
  }

  .mode-btn {
    font-size: 13px;
    padding: 11px 6px;
  }

  .category-strip {
    top: 146px;
  }
}


/* v9 access + order-flow fixes */
.fulfillment-required {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: linear-gradient(135deg,#fff7ed,#ffffff);
  border: 1px solid #fed7aa;
  border-radius: 24px;
  padding: 18px;
  margin: 0 0 18px;
  box-shadow: 0 12px 34px rgba(249,115,22,.08);
}

.fulfillment-required strong {
  display: block;
  font-size: 20px;
  letter-spacing: -.03em;
}

.fulfillment-required span {
  display: block;
  color: var(--muted);
  margin-top: 4px;
  font-weight: 700;
}

.fulfillment-required div:last-child {
  display: flex;
  gap: 10px;
}

.fulfillment-required button {
  border: 0;
  border-radius: 14px;
  background: linear-gradient(135deg,var(--brand),#ea580c);
  color: white;
  font-weight: 950;
  padding: 12px 18px;
  cursor: pointer;
}

.fulfillment-required.selected {
  display: none;
}

.fulfillment-required.attention {
  animation: attentionPulse .45s ease-in-out 0s 2;
}

@keyframes attentionPulse {
  0%,100% { transform: scale(1); box-shadow: 0 12px 34px rgba(249,115,22,.08); }
  50% { transform: scale(1.015); box-shadow: 0 18px 50px rgba(249,115,22,.22); }
}

@media (max-width: 920px) {
  .mode-switch {
    grid-template-columns: repeat(2, 1fr);
  }

  .fulfillment-required {
    display: block;
    border-radius: 22px;
  }

  .fulfillment-required div:last-child {
    margin-top: 14px;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}


/* v10 staff session + customization preset admin UI */
.admin-help {
  color: var(--muted);
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
  line-height: 1.45;
  margin: 0 0 14px;
}

.preset-box {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 16px;
  padding: 12px;
  margin: 12px 0;
}

.preset-box strong {
  display: block;
  margin-bottom: 8px;
}

.preset-box div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.preset-box button {
  border: 1px solid #fed7aa;
  background: #fff;
  color: #c2410c;
  border-radius: 999px;
  padding: 8px 11px;
  font-weight: 900;
  cursor: pointer;
}

.custom-group-preview {
  display: block !important;
}

.custom-group-preview span,
.custom-group-preview em {
  display: block;
}

.custom-group-preview em {
  color: var(--muted);
  margin-top: 4px;
  font-style: normal;
  font-size: 13px;
}


/* ===============================
   v11 MOBILE HOTFIX
   Fixes v10 mobile regression
   =============================== */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

.shop-page {
  width: 100%;
  max-width: 100%;
}

.mobile-cart-button {
  display: none;
}

.mobile-cart-backdrop {
  display: none;
}

.mobile-cart-close {
  display: none;
}

.fulfillment-required button {
  appearance: none !important;
  -webkit-appearance: none !important;
  border: 0 !important;
  border-radius: 14px !important;
  background: linear-gradient(135deg,var(--brand),#ea580c) !important;
  color: #fff !important;
  font-weight: 950 !important;
  padding: 12px 18px !important;
  cursor: pointer !important;
  box-shadow: 0 10px 22px rgba(249,115,22,.22) !important;
}

@media (max-width: 920px) {
  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden !important;
  }

  body.cart-open {
    overflow: hidden !important;
  }

  .shop-page {
    padding-bottom: 88px;
  }

  .shop-header {
    width: 100%;
    max-width: 100%;
    min-height: auto;
    padding: 12px 14px;
    display: grid !important;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
  }

  .brand-lockup {
    min-width: 0 !important;
    max-width: 100%;
    overflow: hidden;
  }

  .shop-nav {
    justify-content: flex-end;
  }

  .mode-switch {
    grid-column: 1 / -1;
    width: 100%;
    max-width: 100%;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    padding: 6px;
    gap: 6px;
    margin: 0;
    overflow: hidden;
  }

  .mode-btn,
  .mode-btn.link {
    width: 100%;
    min-width: 0;
    justify-content: center;
    text-align: center;
    white-space: nowrap;
  }

  .premium-hero,
  .shop-shell,
  .menu-column,
  .menu-grid,
  .premium-food-card,
  .order-panel {
    max-width: 100%;
  }

  .premium-hero {
    width: calc(100% - 24px);
    margin: 12px;
    box-sizing: border-box;
  }

  .shop-shell {
    width: calc(100% - 24px);
    margin: 0 12px 40px !important;
    display: block !important;
    grid-template-columns: none !important;
  }

  .menu-column {
    width: 100%;
  }

  .fulfillment-required {
    width: 100%;
    display: block !important;
    border-radius: 22px;
    margin-bottom: 18px;
  }

  .fulfillment-required.selected {
    display: none !important;
  }

  .fulfillment-required div:last-child {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 14px;
  }

  .fulfillment-required button {
    width: 100% !important;
    min-height: 46px;
    font-size: 15px;
  }

  .category-strip {
    max-width: calc(100vw - 0px);
    overflow-x: auto;
    overscroll-behavior-x: contain;
  }

  .menu-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    width: 100%;
  }

  .premium-food-card {
    width: 100%;
    min-width: 0;
    display: grid !important;
    grid-template-columns: 104px minmax(0, 1fr) !important;
  }

  .food-info,
  .food-title-row,
  .food-info p {
    min-width: 0;
  }

  /* Critical fix:
     On mobile, the cart is a drawer and must not appear in document flow. */
  .order-panel {
    display: block !important;
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: 88vh;
    overflow-y: auto;
    z-index: 900;
    border-radius: 28px 28px 0 0 !important;
    padding: 22px 18px 28px !important;
    transform: translate3d(0, 115%, 0) !important;
    opacity: 0;
    pointer-events: none;
    transition: transform .28s ease, opacity .2s ease;
    box-shadow: 0 -24px 70px rgba(17,24,39,.28);
  }

  .order-panel.mobile-open {
    transform: translate3d(0, 0, 0) !important;
    opacity: 1;
    pointer-events: auto;
  }

  .mobile-cart-close {
    display: grid !important;
    place-items: center;
    position: absolute;
    right: 16px;
    top: 14px;
    width: 38px;
    height: 38px;
    border: 0;
    border-radius: 50%;
    background: #f3f4f6;
    font-size: 24px;
    line-height: 1;
    color: #111827;
    z-index: 2;
  }

  .mobile-cart-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 850;
    background: rgba(15,23,42,.42);
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    filter: none;
  }

  .mobile-cart-backdrop.visible {
    display: block !important;
  }

  .mobile-cart-button {
    position: fixed;
    left: 14px;
    right: 14px;
    bottom: 16px;
    z-index: 800;
    height: 60px;
    border: 0;
    border-radius: 20px;
    background: linear-gradient(135deg,var(--brand),#ea580c);
    color: white;
    font-weight: 950;
    align-items: center;
    justify-content: space-between;
    padding: 0 18px;
    box-shadow: 0 18px 44px rgba(249,115,22,.38);
  }

  .mobile-cart-button[style*="flex"] {
    display: flex !important;
  }

  .checkout-form input,
  .checkout-form textarea,
  .pretty-form input,
  .pretty-form textarea,
  .admin-form input,
  .admin-form textarea,
  .admin-form select {
    max-width: 100%;
  }
}

@media (min-width: 921px) {
  .mobile-cart-button,
  .mobile-cart-backdrop,
  .mobile-cart-close {
    display: none !important;
  }

  .order-panel {
    opacity: 1;
    pointer-events: auto;
  }
}

@media (max-width: 420px) {
  .shop-header {
    grid-template-columns: 1fr;
  }

  .shop-nav {
    width: 100%;
    justify-content: flex-start;
  }

  .mode-switch {
    grid-template-columns: 1fr 1fr !important;
  }

  .premium-food-card {
    grid-template-columns: 92px minmax(0, 1fr) !important;
  }
}


/* v12 staff authentication + roles */
.staff-login-hint {
  margin-top: 18px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
}

.admin-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.staff-badge {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  background: white;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  color: #374151;
  box-shadow: 0 10px 24px rgba(17,24,39,.04);
}

.staff-form-grid {
  display: grid !important;
  grid-template-columns: 1fr 1.2fr 1.2fr .8fr auto;
  gap: 10px;
  align-items: end;
}

.staff-form-grid input,
.staff-form-grid select {
  margin: 0 !important;
}

.staff-role-help {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 10px;
  margin: 14px 0;
}

.staff-role-help span {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 11px;
  color: var(--muted);
  font-size: 13px;
}

.staff-role-help strong {
  color: var(--ink);
}

.staff-list small {
  display: block;
  color: var(--muted);
  margin-top: 3px;
}

@media (max-width: 920px) {
  .admin-actions {
    display: block;
  }

  .staff-badge {
    margin-bottom: 10px;
  }

  .staff-form-grid {
    grid-template-columns: 1fr !important;
  }

  .staff-role-help {
    grid-template-columns: 1fr;
  }
}


/* v14 full menu editor */
.menu-editor-list {
  display: grid;
  gap: 14px;
}

.menu-edit-card {
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fff;
  overflow: hidden;
}

.menu-edit-card summary {
  list-style: none;
  cursor: pointer;
  padding: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.menu-edit-card summary::-webkit-details-marker {
  display: none;
}

.menu-edit-summary {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.menu-edit-summary img,
.menu-edit-placeholder {
  width: 72px;
  height: 72px;
  border-radius: 16px;
  object-fit: cover;
  background: #f3f4f6;
  display: grid;
  place-items: center;
  font-size: 28px;
  flex: 0 0 auto;
}

.menu-edit-summary strong,
.menu-edit-summary span {
  display: block;
}

.menu-edit-summary strong {
  font-size: 18px;
  letter-spacing: -.03em;
}

.menu-edit-summary span {
  color: var(--muted);
  margin-top: 4px;
}

.menu-edit-card summary em {
  font-style: normal;
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 950;
}

.menu-edit-form {
  padding: 0 14px 14px;
  border-top: 1px solid var(--line);
}

.menu-edit-actions {
  display: flex;
  justify-content: flex-start;
}

.menu-delete-form {
  padding: 0 14px 14px;
}

.menu-delete-form button {
  border: 0;
}

@media (max-width: 920px) {
  .menu-edit-card summary {
    align-items: flex-start;
  }

  .menu-edit-summary img,
  .menu-edit-placeholder {
    width: 58px;
    height: 58px;
    border-radius: 14px;
  }

  .menu-edit-summary strong {
    font-size: 16px;
  }

  .menu-edit-card summary em {
    padding: 7px 10px;
  }

  .menu-edit-form .two-col {
    grid-template-columns: 1fr !important;
  }
}


/* v15 Kitchen Dashboard */
.kds-alert {
  margin: 18px 28px 0;
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 900;
}

.kds-alert.error {
  background: #7f1d1d;
  color: #fecaca;
}

.kds-alert.success {
  background: #064e3b;
  color: #bbf7d0;
}

.kds-stats {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 14px;
  padding: 18px 28px 0;
}

.kds-stats article {
  background: #111827;
  border: 1px solid #374151;
  border-radius: 20px;
  padding: 16px;
}

.kds-stats span {
  color: #9ca3af;
  font-weight: 800;
}

.kds-stats strong {
  display: block;
  font-size: 32px;
  margin-top: 6px;
}

.kds-tools {
  padding: 18px 28px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.kds-filter-tabs {
  display: flex;
  gap: 10px;
  overflow-x: auto;
}

.kds-filter-tabs a,
.sound-toggle {
  background: #111827;
  color: white;
  border: 1px solid #374151;
  border-radius: 999px;
  padding: 11px 15px;
  font-weight: 900;
}

.kds-filter-tabs a.active {
  background: #f97316;
  border-color: #f97316;
}

.sound-toggle {
  cursor: pointer;
}

.kitchen-board-v15 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.kds-ticket.priority-rush {
  border-color: #ef4444;
  box-shadow: 0 0 0 2px rgba(239,68,68,.18), 0 20px 50px rgba(0,0,0,.22);
}

.kds-ticket.priority-hold {
  border-color: #eab308;
}

.kds-ticket.warning-time {
  border-color: #f59e0b;
}

.kds-ticket.late {
  border-color: #dc2626;
  animation: pulseLate 1.4s infinite;
}

@keyframes pulseLate {
  0%,100% { box-shadow: 0 20px 50px rgba(0,0,0,.22); }
  50% { box-shadow: 0 0 0 3px rgba(220,38,38,.28), 0 20px 50px rgba(0,0,0,.22); }
}

.ticket-timer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #020617;
  border: 1px solid #374151;
  border-radius: 14px;
  padding: 12px;
  margin: 14px 0 0;
}

.ticket-timer span {
  color: #9ca3af;
  font-weight: 800;
}

.ticket-timer strong {
  color: #fbbf24;
  font-size: 24px;
}

.priority-pill {
  background: #ef4444 !important;
  color: white !important;
  text-transform: uppercase;
}

.ticket-note.warning {
  border: 1px solid #f59e0b;
  color: #fde68a;
}

.ticket-workflow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 9px;
  margin-top: 16px;
}

.workflow-btn {
  width: 100%;
  min-height: 52px;
  border: 0;
  border-radius: 16px;
  color: white;
  font-weight: 950;
  cursor: pointer;
  font-size: 16px;
}

.workflow-btn.accept {
  background: #2563eb;
}

.workflow-btn.prepare {
  background: #f97316;
}

.workflow-btn.ready {
  background: #16a34a;
}

.workflow-btn.done {
  background: #22c55e;
}

.ticket-secondary {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  margin-top: 12px;
}

.ticket-secondary select {
  width: 100%;
  background: #020617;
  color: white;
  border: 1px solid #374151;
  border-radius: 14px;
  padding: 12px;
}

.cancel-btn {
  border: 0;
  background: #7f1d1d;
  color: #fecaca;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 950;
  cursor: pointer;
}

@media (max-width: 1100px) {
  .kds-stats {
    grid-template-columns: repeat(3, 1fr);
  }

  .kitchen-board-v15 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 920px) {
  .kds-stats {
    grid-template-columns: repeat(2, 1fr);
    padding: 14px;
  }

  .kds-tools {
    display: block;
    padding: 14px;
  }

  .kds-filter-tabs {
    margin-bottom: 12px;
  }

  .sound-toggle {
    width: 100%;
  }

  .kitchen-board-v15 {
    grid-template-columns: 1fr !important;
  }

  .ticket-secondary {
    grid-template-columns: 1fr;
  }

  .workflow-btn {
    min-height: 56px;
  }
}


/* v16 Premium Kitchen Display */
.kds-premium {
  background:
    radial-gradient(circle at top left, rgba(249,115,22,.12), transparent 34%),
    #070b16;
  color: #f8fafc;
  min-height: 100vh;
}

.kds-premium-header {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  padding: 20px 28px;
  background: rgba(7,11,22,.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(148,163,184,.16);
}

.kds-title {
  display: flex;
  align-items: center;
  gap: 14px;
}

.kds-logo {
  width: 58px;
  height: 58px;
  border-radius: 20px;
  background: linear-gradient(135deg,#f97316,#ea580c);
  display: grid;
  place-items: center;
  font-size: 28px;
  box-shadow: 0 18px 40px rgba(249,115,22,.22);
}

.kds-title h1 {
  margin: 0;
  font-size: 38px;
  letter-spacing: -.055em;
  line-height: 1;
}

.kds-title p {
  margin: 7px 0 0;
  color: #94a3b8;
  font-weight: 700;
}

.kds-header-actions {
  display: flex;
  gap: 9px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.kds-action {
  border: 1px solid rgba(249,115,22,.55);
  background: linear-gradient(135deg,#f97316,#ea580c);
  color: #fff;
  border-radius: 14px;
  padding: 11px 14px;
  font-weight: 950;
  cursor: pointer;
}

.kds-action.ghost {
  background: rgba(15,23,42,.9);
  border-color: rgba(148,163,184,.22);
  color: #e5e7eb;
}

.kds-action.danger {
  background: rgba(127,29,29,.85);
  border-color: rgba(248,113,113,.25);
}

.kds-toast {
  margin: 16px 28px 0;
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 900;
}

.kds-toast.error {
  background: rgba(127,29,29,.85);
  color: #fecaca;
}

.kds-toast.success {
  background: rgba(6,78,59,.85);
  color: #bbf7d0;
}

.kds-premium-stats {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
  padding: 18px 28px 0;
}

.kds-premium-stats article {
  background: rgba(15,23,42,.78);
  border: 1px solid rgba(148,163,184,.16);
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 18px 44px rgba(0,0,0,.18);
}

.kds-premium-stats span {
  display: block;
  color: #94a3b8;
  font-weight: 900;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.kds-premium-stats strong {
  display: block;
  margin-top: 6px;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -.04em;
}

.kds-status-tabs {
  display: flex;
  gap: 10px;
  padding: 18px 28px 0;
  overflow-x: auto;
}

.kds-status-tabs a {
  flex: 0 0 auto;
  border: 1px solid rgba(148,163,184,.18);
  background: rgba(15,23,42,.75);
  color: #cbd5e1;
  border-radius: 999px;
  padding: 12px 16px;
  font-weight: 950;
}

.kds-status-tabs a.active {
  background: #f97316;
  color: #fff;
  border-color: #f97316;
}

.kds-kanban {
  display: grid;
  grid-template-columns: repeat(3, minmax(340px, 1fr));
  gap: 18px;
  padding: 22px 28px 34px;
  align-items: start;
}

.kds-column {
  background: rgba(15,23,42,.52);
  border: 1px solid rgba(148,163,184,.14);
  border-radius: 28px;
  min-height: 420px;
  overflow: hidden;
}

.kds-column-head {
  position: sticky;
  top: 99px;
  z-index: 5;
  background: rgba(15,23,42,.94);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(148,163,184,.14);
  padding: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.kds-column-head h2 {
  margin: 0;
  font-size: 24px;
  letter-spacing: -.04em;
}

.kds-column-head p {
  margin: 4px 0 0;
  color: #94a3b8;
  font-weight: 700;
}

.kds-column-head strong {
  width: 42px;
  height: 42px;
  border-radius: 16px;
  background: #020617;
  border: 1px solid rgba(148,163,184,.18);
  display: grid;
  place-items: center;
  font-size: 20px;
}

.column-new .kds-column-head strong {
  color: #fbbf24;
}

.column-preparing .kds-column-head strong {
  color: #fb923c;
}

.column-ready .kds-column-head strong {
  color: #4ade80;
}

.kds-column-list {
  display: grid;
  gap: 14px;
  padding: 14px;
}

.kds-premium-ticket {
  background: #101827;
  border: 1px solid rgba(148,163,184,.18);
  border-radius: 24px;
  padding: 16px;
  box-shadow: 0 20px 44px rgba(0,0,0,.22);
}

.kds-premium-ticket.status-new {
  border-color: rgba(249,115,22,.75);
}

.kds-premium-ticket.status-ready {
  border-color: rgba(34,197,94,.75);
}

.kds-premium-ticket.priority-rush {
  border-color: #ef4444;
  box-shadow: 0 0 0 2px rgba(239,68,68,.16), 0 20px 44px rgba(0,0,0,.22);
}

.kds-premium-ticket.priority-hold {
  border-color: #eab308;
}

.kds-premium-ticket.warning-time {
  border-color: #f59e0b;
}

.kds-premium-ticket.late {
  border-color: #dc2626;
  animation: premiumLate 1.3s infinite;
}

@keyframes premiumLate {
  50% { box-shadow: 0 0 0 3px rgba(220,38,38,.32), 0 20px 44px rgba(0,0,0,.22); }
}

.ticket-main-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}

.ticket-type {
  display: flex;
  gap: 12px;
  align-items: center;
  min-width: 0;
}

.ticket-type > span {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: #020617;
  border: 1px solid rgba(148,163,184,.18);
  font-size: 22px;
  flex: 0 0 auto;
}

.ticket-type strong {
  display: block;
  text-transform: capitalize;
  font-size: 21px;
  letter-spacing: -.03em;
}

.ticket-type small {
  display: block;
  margin-top: 3px;
  color: #94a3b8;
  font-weight: 700;
}

.ticket-status {
  text-align: right;
}

.ticket-status em {
  display: inline-flex;
  background: #f97316;
  color: #fff;
  border-radius: 999px;
  padding: 7px 10px;
  font-style: normal;
  font-weight: 950;
  text-transform: uppercase;
  font-size: 12px;
}

.ticket-status strong {
  display: block;
  color: #fbbf24;
  font-size: 22px;
  margin-top: 8px;
}

.ticket-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}

.ticket-meta-row span {
  background: #020617;
  border: 1px solid rgba(148,163,184,.18);
  color: #e5e7eb;
  border-radius: 999px;
  padding: 8px 10px;
  font-weight: 850;
  font-size: 13px;
}

.priority-chip {
  background: #ef4444 !important;
  color: white !important;
  text-transform: uppercase;
}

.ticket-address,
.ticket-warning {
  border-radius: 16px;
  padding: 12px;
  margin: 12px 0;
}

.ticket-address {
  background: rgba(30,41,59,.82);
}

.ticket-warning {
  background: rgba(120,53,15,.62);
  border: 1px solid rgba(245,158,11,.45);
}

.ticket-address span,
.ticket-warning span {
  display: block;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 4px;
}

.ticket-address p,
.ticket-warning p {
  margin: 0;
  line-height: 1.45;
}

.kds-items {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.kds-item {
  background: #060b16;
  border: 1px solid rgba(148,163,184,.18);
  border-radius: 18px;
  padding: 13px;
}

.kds-item-title {
  display: flex;
  gap: 10px;
  align-items: start;
}

.kds-item-title strong {
  color: #fbbf24;
  font-size: 18px;
}

.kds-item-title span {
  font-size: 18px;
  font-weight: 950;
}

.kds-item ul {
  margin: 9px 0 0 27px;
  padding: 0;
  color: #fde68a;
}

.kds-item p {
  margin: 9px 0 0;
  color: #cbd5e1;
  background: rgba(148,163,184,.08);
  border-radius: 12px;
  padding: 8px;
}

.kds-ticket-actions {
  display: grid;
  gap: 9px;
  margin-top: 14px;
}

.kds-ticket-actions form {
  margin: 0;
}

.kds-btn {
  width: 100%;
  min-height: 54px;
  border: 0;
  border-radius: 16px;
  color: white;
  font-weight: 950;
  cursor: pointer;
  font-size: 16px;
}

.kds-btn.accept {
  background: #2563eb;
}

.kds-btn.preparing {
  background: #f97316;
}

.kds-btn.ready {
  background: #16a34a;
}

.kds-btn.complete {
  background: #22c55e;
}

.kds-ticket-secondary {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 9px;
  margin-top: 10px;
}

.kds-ticket-secondary select {
  width: 100%;
  min-height: 46px;
  background: #020617;
  color: #e5e7eb;
  border: 1px solid rgba(148,163,184,.22);
  border-radius: 14px;
  padding: 0 12px;
  font-weight: 900;
}

.kds-cancel {
  min-height: 46px;
  border: 0;
  background: rgba(127,29,29,.85);
  color: #fecaca;
  border-radius: 14px;
  padding: 0 14px;
  font-weight: 950;
  cursor: pointer;
}

.kds-empty {
  grid-column: 1 / -1;
  text-align: center;
  background: rgba(15,23,42,.52);
  border: 1px dashed rgba(148,163,184,.3);
  border-radius: 28px;
  padding: 70px 30px;
  color: #94a3b8;
}

.kds-empty span {
  font-size: 54px;
}

.kds-empty h2 {
  color: #fff;
  font-size: 30px;
  margin-bottom: 6px;
}

@media (max-width: 1250px) {
  .kds-kanban {
    grid-template-columns: repeat(2, minmax(320px, 1fr));
  }

  .kds-premium-stats {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 920px) {
  .kds-premium-header {
    display: block;
    padding: 16px;
  }

  .kds-title h1 {
    font-size: 32px;
  }

  .kds-logo {
    width: 50px;
    height: 50px;
    border-radius: 17px;
  }

  .kds-header-actions {
    margin-top: 14px;
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 2px;
  }

  .kds-action {
    flex: 0 0 auto;
  }

  .kds-premium-stats {
    grid-template-columns: repeat(2, 1fr);
    padding: 14px;
    gap: 10px;
  }

  .kds-premium-stats article {
    padding: 14px;
    border-radius: 18px;
  }

  .kds-premium-stats strong {
    font-size: 28px;
  }

  .kds-status-tabs {
    padding: 0 14px 14px;
  }

  .kds-kanban {
    grid-template-columns: 1fr;
    padding: 0 14px 24px;
  }

  .kds-column {
    min-height: auto;
    border-radius: 22px;
  }

  .kds-column-head {
    top: 0;
    padding: 14px;
  }

  .kds-column-list {
    padding: 12px;
  }

  .kds-premium-ticket {
    border-radius: 22px;
    padding: 14px;
  }

  .ticket-main-head {
    align-items: flex-start;
  }

  .ticket-type > span {
    width: 42px;
    height: 42px;
  }

  .ticket-type strong {
    font-size: 19px;
  }

  .kds-ticket-secondary {
    grid-template-columns: 1fr;
  }

  .kds-cancel,
  .kds-ticket-secondary select,
  .kds-btn {
    min-height: 54px;
  }
}


/* v17 Reservation + Table Manager */
.reservation-manager {
  min-height: 100vh;
  background: linear-gradient(135deg,#fff7ed,#fff,#f8fafc);
  color: var(--ink);
}

.res-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
  padding: 18px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
}

.res-title {
  display: flex;
  align-items: center;
  gap: 14px;
}

.res-logo {
  width: 56px;
  height: 56px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg,var(--brand),#ea580c);
  color: white;
  font-size: 27px;
  box-shadow: 0 18px 40px rgba(249,115,22,.22);
}

.res-title h1 {
  margin: 0;
  font-size: 38px;
  letter-spacing: -.055em;
}

.res-title p {
  margin: 5px 0 0;
  color: var(--muted);
  font-weight: 700;
}

.res-nav {
  display: flex;
  align-items: center;
  gap: 10px;
}

.res-nav a,
.res-filter button,
.res-filter a,
.table-add-form button,
.reservation-update-form button,
.table-edit-form button {
  border: 0;
  border-radius: 14px;
  padding: 12px 15px;
  background: linear-gradient(135deg,var(--brand),#ea580c);
  color: white;
  font-weight: 950;
  cursor: pointer;
}

.res-nav a {
  background: white;
  color: var(--ink);
  border: 1px solid var(--line);
}

.res-toast {
  max-width: 1280px;
  margin: 16px auto 0;
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 900;
}

.res-toast.error {
  background: #fef2f2;
  color: #991b1b;
}

.res-toast.success {
  background: #f0fdf4;
  color: #166534;
}

.res-stats {
  max-width: 1280px;
  margin: 18px auto 0;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
  padding: 0 18px;
}

.res-stats article {
  background: white;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 12px 34px rgba(17,24,39,.05);
}

.res-stats span {
  display: block;
  color: var(--muted);
  font-weight: 900;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.res-stats strong {
  display: block;
  font-size: 32px;
  margin-top: 6px;
}

.res-toolbar {
  max-width: 1280px;
  margin: 18px auto 0;
  padding: 0 18px;
}

.res-filter {
  background: white;
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 14px;
  display: flex;
  align-items: end;
  gap: 12px;
  box-shadow: 0 12px 34px rgba(17,24,39,.05);
}

.res-filter label {
  font-size: 13px;
  font-weight: 950;
  color: #374151;
}

.res-filter input,
.res-filter select,
.table-add-form input,
.reservation-update-form input,
.reservation-update-form select,
.reservation-update-form textarea,
.table-edit-form input,
.table-edit-form textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
  margin-top: 6px;
  background: white;
}

.res-filter a {
  background: #f8fafc;
  color: var(--ink);
  border: 1px solid var(--line);
}

.res-layout {
  max-width: 1280px;
  margin: 18px auto 60px;
  padding: 0 18px;
  display: grid;
  grid-template-columns: 1fr 390px;
  gap: 18px;
  align-items: start;
}

.res-panel {
  background: white;
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 20px;
  box-shadow: 0 16px 44px rgba(17,24,39,.06);
}

.res-panel-head h2 {
  margin: 0;
  font-size: 28px;
  letter-spacing: -.04em;
}

.res-panel-head p {
  margin: 6px 0 0;
  color: var(--muted);
}

.reservation-list {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.reservation-card-staff {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 16px;
  background: #fff;
}

.reservation-card-staff.status-pending {
  border-color: #f59e0b;
}

.reservation-card-staff.status-confirmed {
  border-color: #2563eb;
}

.reservation-card-staff.status-seated {
  border-color: #16a34a;
}

.reservation-main {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.reservation-main strong {
  display: block;
  font-size: 22px;
  letter-spacing: -.03em;
}

.reservation-main span {
  display: block;
  color: var(--muted);
  margin-top: 4px;
  font-weight: 700;
}

.reservation-main em {
  font-style: normal;
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 950;
  text-transform: uppercase;
  font-size: 12px;
}

.reservation-contact {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0;
}

.reservation-contact span {
  background: #f8fafc;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 10px;
  font-weight: 800;
  color: #374151;
}

.guest-note {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 14px;
  padding: 12px;
  color: #7c2d12;
}

.reservation-update-form {
  display: grid;
  grid-template-columns: 1fr 1.2fr .8fr auto;
  gap: 10px;
  align-items: end;
  margin-top: 12px;
}

.reservation-update-form label,
.table-edit-form label {
  font-size: 13px;
  font-weight: 950;
  color: #374151;
}

.reservation-update-form .wide {
  grid-column: 1 / -2;
}

.res-empty {
  text-align: center;
  border: 1px dashed #d1d5db;
  border-radius: 22px;
  padding: 50px 20px;
  color: var(--muted);
}

.res-empty span {
  font-size: 44px;
}

.table-add-form {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.table-card-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.staff-table-card {
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fff;
  overflow: hidden;
}

.staff-table-card summary {
  list-style: none;
  cursor: pointer;
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.staff-table-card summary::-webkit-details-marker {
  display: none;
}

.staff-table-card strong {
  display: block;
  font-size: 18px;
}

.staff-table-card span {
  display: block;
  color: var(--muted);
  margin-top: 4px;
  font-weight: 700;
}

.staff-table-card em {
  font-style: normal;
  color: #c2410c;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 950;
}

.table-edit-form {
  display: grid;
  gap: 10px;
  padding: 0 14px 14px;
  border-top: 1px solid var(--line);
}

.table-edit-form .inline {
  display: flex;
  align-items: center;
  gap: 8px;
}

.table-edit-form .inline input {
  width: auto;
}

.qr-link-box {
  margin: 0 14px 14px;
  border-radius: 16px;
  background: #f8fafc;
  border: 1px solid var(--line);
  padding: 12px;
}

.qr-link-box span,
.qr-link-box code,
.qr-link-box a {
  display: block;
}

.qr-link-box span {
  color: var(--muted);
  font-weight: 900;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.qr-link-box code {
  margin: 8px 0;
  background: white;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px;
}

.qr-link-box a {
  color: var(--brand);
  font-weight: 950;
}

@media (max-width: 1100px) {
  .res-stats {
    grid-template-columns: repeat(3, 1fr);
  }

  .res-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 920px) {
  .res-header {
    display: block;
    padding: 14px;
  }

  .res-title h1 {
    font-size: 32px;
  }

  .res-nav {
    margin-top: 14px;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .res-nav a {
    flex: 0 0 auto;
  }

  .res-stats {
    grid-template-columns: repeat(2, 1fr);
    padding: 0 12px;
  }

  .res-toolbar,
  .res-layout {
    padding: 0 12px;
  }

  .res-filter {
    display: grid;
    grid-template-columns: 1fr;
  }

  .reservation-update-form {
    grid-template-columns: 1fr;
  }

  .reservation-update-form .wide {
    grid-column: auto;
  }

  .res-panel {
    border-radius: 22px;
    padding: 16px;
  }
}


/* v18 Reservation UI Fix */
.res-app-v18 {
  min-height: 100vh;
  background: #f8fafc;
  color: #111827;
  display: grid;
  grid-template-columns: 260px 1fr;
}

.res-sidebar-v18 {
  min-height: 100vh;
  background: #111827;
  color: white;
  padding: 24px;
  position: sticky;
  top: 0;
}

.res-side-brand {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 26px;
}

.res-side-brand > div {
  width: 48px;
  height: 48px;
  border-radius: 17px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg,#f97316,#ea580c);
  box-shadow: 0 16px 36px rgba(249,115,22,.25);
}

.res-side-brand strong,
.res-side-brand small {
  display: block;
}

.res-side-brand strong {
  font-size: 18px;
}

.res-side-brand small {
  color: #9ca3af;
  margin-top: 3px;
}

.res-sidebar-v18 nav {
  display: grid;
  gap: 8px;
}

.res-sidebar-v18 nav a {
  color: #d1d5db;
  padding: 13px 14px;
  border-radius: 14px;
  font-weight: 900;
}

.res-sidebar-v18 nav a.active,
.res-sidebar-v18 nav a:hover {
  background: #1f2937;
  color: white;
}

.res-main-v18 {
  padding: 30px;
  min-width: 0;
}

.res-top-v18 {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 20px;
}

.res-eyebrow {
  color: #f97316;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .13em;
}

.res-top-v18 h1 {
  margin: 8px 0 8px;
  font-size: 46px;
  letter-spacing: -.06em;
  line-height: 1;
}

.res-top-v18 p {
  margin: 0;
  color: #6b7280;
  font-weight: 700;
}

.res-top-action {
  background: linear-gradient(135deg,#f97316,#ea580c);
  color: white;
  border-radius: 16px;
  padding: 13px 16px;
  font-weight: 950;
  flex: 0 0 auto;
}

.res-toast-v18 {
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 900;
  margin-bottom: 18px;
}

.res-toast-v18.error {
  background: #fef2f2;
  color: #991b1b;
}

.res-toast-v18.success {
  background: #f0fdf4;
  color: #166534;
}

.res-stats-v18 {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.res-stats-v18 article {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 22px;
  padding: 18px;
  box-shadow: 0 12px 34px rgba(17,24,39,.05);
}

.res-stats-v18 span {
  display: block;
  color: #6b7280;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.res-stats-v18 strong {
  display: block;
  font-size: 32px;
  margin-top: 6px;
}

.res-filter-card-v18,
.res-card-v18 {
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 28px;
  box-shadow: 0 16px 44px rgba(17,24,39,.06);
}

.res-filter-card-v18 {
  padding: 16px;
  margin-bottom: 18px;
}

.res-filter-v18 {
  display: flex;
  align-items: end;
  gap: 12px;
}

.res-filter-v18 label,
.reservation-form-v18 label,
.table-form-v18 label {
  color: #374151;
  font-size: 13px;
  font-weight: 950;
}

.res-filter-v18 input,
.res-filter-v18 select,
.reservation-form-v18 input,
.reservation-form-v18 select,
.reservation-form-v18 textarea,
.table-add-v18 input,
.table-form-v18 input,
.table-form-v18 textarea {
  width: 100%;
  border: 1px solid #d1d5db;
  border-radius: 14px;
  padding: 12px;
  margin-top: 6px;
  background: white;
  outline: none;
}

.res-filter-v18 button,
.reservation-form-v18 button,
.table-add-v18 button,
.table-form-v18 button {
  border: 0;
  border-radius: 14px;
  background: linear-gradient(135deg,#f97316,#ea580c);
  color: white;
  font-weight: 950;
  padding: 13px 16px;
  cursor: pointer;
}

.res-filter-v18 a {
  border-radius: 14px;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  color: #111827;
  font-weight: 950;
  padding: 12px 14px;
}

.res-grid-v18 {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 18px;
  align-items: start;
}

.res-card-v18 {
  padding: 20px;
}

.res-card-head-v18 h2 {
  margin: 0;
  font-size: 28px;
  letter-spacing: -.04em;
}

.res-card-head-v18 p {
  margin: 6px 0 0;
  color: #6b7280;
  font-weight: 700;
}

.reservation-list-v18 {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}

.reservation-ticket-v18 {
  border: 1px solid #e5e7eb;
  border-radius: 22px;
  padding: 16px;
  background: #fff;
}

.reservation-ticket-v18.status-pending {
  border-color: #f59e0b;
}

.reservation-ticket-v18.status-confirmed {
  border-color: #2563eb;
}

.reservation-ticket-v18.status-seated {
  border-color: #16a34a;
}

.reservation-ticket-top-v18 {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.reservation-ticket-top-v18 strong {
  display: block;
  font-size: 22px;
  letter-spacing: -.03em;
}

.reservation-ticket-top-v18 span {
  display: block;
  color: #6b7280;
  margin-top: 4px;
  font-weight: 750;
}

.reservation-ticket-top-v18 em {
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: 7px 10px;
  font-style: normal;
  font-weight: 950;
  text-transform: uppercase;
  font-size: 12px;
}

.reservation-tags-v18 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 12px 0;
}

.reservation-tags-v18 span {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: 8px 10px;
  color: #374151;
  font-weight: 850;
}

.reservation-note-v18 {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 16px;
  padding: 12px;
  margin: 12px 0;
}

.reservation-note-v18 span {
  color: #9a3412;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.reservation-note-v18 p {
  margin: 5px 0 0;
  color: #7c2d12;
}

.reservation-form-v18 {
  display: grid;
  grid-template-columns: 1fr 1.2fr .8fr auto;
  gap: 10px;
  align-items: end;
  margin-top: 12px;
}

.reservation-form-v18 .wide {
  grid-column: 1 / -2;
}

.res-empty-v18,
.res-empty-small-v18 {
  text-align: center;
  border: 1px dashed #d1d5db;
  border-radius: 22px;
  padding: 44px 18px;
  color: #6b7280;
}

.res-empty-v18 span,
.res-empty-small-v18 span {
  font-size: 42px;
}

.table-add-v18 {
  display: grid;
  gap: 10px;
  margin: 18px 0;
}

.table-list-v18 {
  display: grid;
  gap: 12px;
}

.table-ticket-v18 {
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  background: white;
  overflow: hidden;
}

.table-ticket-v18.inactive {
  opacity: .62;
}

.table-ticket-v18 summary {
  list-style: none;
  cursor: pointer;
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.table-ticket-v18 summary::-webkit-details-marker {
  display: none;
}

.table-ticket-v18 strong {
  display: block;
  font-size: 18px;
}

.table-ticket-v18 span {
  display: block;
  color: #6b7280;
  margin-top: 4px;
  font-weight: 700;
}

.table-ticket-v18 em {
  background: #fff7ed;
  color: #c2410c;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  padding: 7px 10px;
  font-style: normal;
  font-weight: 950;
}

.table-form-v18 {
  display: grid;
  gap: 10px;
  padding: 0 14px 14px;
  border-top: 1px solid #e5e7eb;
}

.table-form-v18 .inline {
  display: flex;
  gap: 8px;
  align-items: center;
}

.table-form-v18 .inline input {
  width: auto;
}

.table-qr-v18 {
  margin: 0 14px 14px;
  padding: 12px;
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
}

.table-qr-v18 span,
.table-qr-v18 code,
.table-qr-v18 a {
  display: block;
}

.table-qr-v18 span {
  color: #6b7280;
  font-weight: 950;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.table-qr-v18 code {
  margin: 8px 0;
  background: white;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 8px;
}

.table-qr-v18 a {
  color: #f97316;
  font-weight: 950;
}

@media (max-width: 1180px) {
  .res-app-v18 {
    grid-template-columns: 1fr;
  }

  .res-sidebar-v18 {
    min-height: auto;
    position: relative;
  }

  .res-sidebar-v18 nav {
    display: flex;
    flex-wrap: wrap;
  }

  .res-grid-v18 {
    grid-template-columns: 1fr;
  }

  .res-stats-v18 {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 920px) {
  .res-main-v18 {
    padding: 14px;
  }

  .res-top-v18 {
    display: block;
  }

  .res-top-v18 h1 {
    font-size: 34px;
  }

  .res-top-action {
    display: inline-flex;
    margin-top: 14px;
  }

  .res-stats-v18 {
    grid-template-columns: repeat(2, 1fr);
  }

  .res-filter-v18 {
    display: grid;
    grid-template-columns: 1fr;
  }

  .reservation-form-v18 {
    grid-template-columns: 1fr;
  }

  .reservation-form-v18 .wide {
    grid-column: auto;
  }
}

.table-session-open-v364{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:rgba(255,255,255,.92);color:#111827;text-decoration:none;font-weight:950;padding:7px 10px;margin-left:8px}
@media(max-width:620px){.table-session-open-v364{margin-left:0;margin-top:6px;width:100%}}
