:root{--bg: #faf8f5;--surface: #ffffff;--surface-2: #f4f1ec;--ink: #1a1a1a;--ink-2: #4b5563;--muted: #8a8a8a;--border: #e9e5df;--primary: #d4541f;--primary-dark: #b34418;--primary-soft: #fdecdf;--accent: #1f3a4d;--success: #15803d;--error: #b91c1c;--radius-sm: 8px;--radius: 14px;--radius-lg: 22px;--shadow-sm: 0 1px 2px rgba(20, 20, 20, .04), 0 1px 3px rgba(20, 20, 20, .06);--shadow-md: 0 4px 12px rgba(20, 20, 20, .08), 0 2px 4px rgba(20, 20, 20, .05);--shadow-lg: 0 12px 32px rgba(20, 20, 20, .12);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--ink);line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit}.muted{color:var(--muted)}.muted.small{font-size:.85rem}.error{color:var(--error)}.success{color:var(--success)}.layout{min-height:100vh;display:flex;flex-direction:column}.customer-layout{background:var(--bg)}.topbar{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.25rem;background:var(--ink);color:#fff;position:sticky;top:0;z-index:10}.topbar a{color:#fff}.brand{font-weight:700;font-size:1.2rem;letter-spacing:-.01em}.topnav{display:flex;gap:1rem;flex:1}.topnav a{padding:.4rem .7rem;border-radius:8px;font-weight:500}.topnav a.active{background:#ffffff26}.user-area{display:flex;align-items:center;gap:.75rem;font-size:.9rem}.who em{color:#d1d5db;font-style:normal}.page{padding:1.25rem;max-width:1300px;width:100%;margin:0 auto}.page-pad{padding:2rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.card h2{margin-top:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem .95rem;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;color:var(--ink);transition:background .15s,transform .05s}.btn:hover{background:#f3f4f6}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn.primary:hover{background:var(--primary-dark)}.btn.ghost{background:transparent;border-color:transparent}.btn.ghost:hover{background:#0000000f}.btn.small{padding:.35rem .7rem;font-size:.85rem;border-radius:8px}input,select,textarea{font:inherit;padding:.55rem .65rem;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--ink)}input:focus,select:focus,textarea:focus{outline:2px solid var(--primary-soft);border-color:var(--primary)}textarea{width:100%;min-height:60px;resize:vertical}label{display:inline-flex;flex-direction:column;gap:.25rem}.row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}.row.between{justify-content:space-between}.actions{display:flex;gap:.4rem;flex-wrap:wrap}.cx{min-height:100vh;display:flex;flex-direction:column}.cx-hero{background:radial-gradient(1200px 400px at 80% -10%,rgba(212,84,31,.18),transparent 60%),linear-gradient(180deg,#fff,#fbf6ef);border-bottom:1px solid var(--border);padding:clamp(1.25rem,3vw,2rem) clamp(1rem,4vw,2.5rem)}.cx-hero-inner{max-width:1200px;margin:0 auto;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}.cx-brand{font-size:.85rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--primary)}.cx-welcome{margin:.35rem 0 .25rem;font-size:clamp(1.6rem,3.2vw,2.4rem);font-weight:800;letter-spacing:-.02em;line-height:1.1}.cx-sub{margin:0;color:var(--ink-2);max-width:60ch}.cx-quick{display:flex;flex-wrap:wrap;gap:.5rem}.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem .9rem;border:1px solid var(--border);background:var(--surface);border-radius:999px;cursor:pointer;font-size:.92rem;font-weight:500;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .12s,background .12s}.chip:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);background:#fff}.chip:active{transform:translateY(0)}.cx-guestbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;max-width:1200px;width:100%;margin:0 auto;padding:.6rem clamp(1rem,4vw,2.5rem);background:var(--surface);border-bottom:1px solid var(--border)}.cx-guestbar.editing{flex-direction:column;align-items:stretch;gap:.5rem;background:var(--primary-soft)}.cx-guestbar-label{font-size:.92rem;color:var(--ink-2);font-weight:500}.cx-guestbar.editing .cx-guestbar-label{color:var(--primary-dark);font-weight:600}.cx-guestbar-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.cx-guestbar-input{flex:1;min-width:0}.cx-tabs{position:sticky;top:0;z-index:5;padding:.6rem clamp(1rem,4vw,2.5rem);background:#faf8f5eb;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.cx-tabs-inner{max-width:1200px;margin:0 auto;display:flex;gap:.4rem;overflow-x:auto;scrollbar-width:none}.cx-tabs-inner::-webkit-scrollbar{display:none}.cx-tab{padding:.5rem .95rem;border:1px solid var(--border);background:var(--surface);border-radius:999px;cursor:pointer;white-space:nowrap;font-weight:500;color:var(--ink-2);transition:all .15s}.cx-tab:hover{color:var(--ink)}.cx-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}.cx-body{flex:1;padding:0 clamp(1rem,4vw,2.5rem)}.cx-menu{max-width:1200px;margin:0 auto}.cx-cat{padding:1.5rem 0 .5rem}.cx-cat-title{margin:0 0 1rem;font-size:clamp(1.2rem,2vw,1.5rem);font-weight:700;letter-spacing:-.01em}.cx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.cx-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s;cursor:pointer}.cx-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.cx-card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.cx-card-img-wrap{position:relative;width:100%;height:180px;background:var(--surface-2);overflow:hidden;flex-shrink:0}.cx-card-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.cx-card-img.placeholder{display:grid;place-items:center;font-size:3rem;color:var(--muted)}@media(min-width:768px){.cx-card-img-wrap{height:200px}}.cx-card-price{position:absolute;top:10px;right:10px;background:#000000c7;color:#fff;padding:.3rem .6rem;border-radius:999px;font-weight:600;font-size:.92rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.cx-card-body{padding:.85rem 1rem 1rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.cx-card-name{margin:0;font-size:1.05rem;font-weight:700}.cx-card-desc{margin:0;color:var(--ink-2);font-size:.92rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cx-card-actions{margin-top:auto}.cx-add{width:100%;padding:.65rem .8rem;background:var(--ink);color:#fff;border:none;border-radius:12px;cursor:pointer;font-weight:600;transition:background .15s}.cx-add:hover{background:#000}.cx-qty{display:inline-flex;align-items:center;gap:.5rem;background:var(--surface-2);padding:.25rem;border-radius:12px;width:100%;justify-content:space-between}.cx-qty.small{width:auto}.cx-qty-btn{width:36px;height:36px;border:none;border-radius:10px;background:var(--surface);color:var(--ink);cursor:pointer;font-size:1.1rem;font-weight:600;box-shadow:var(--shadow-sm)}.cx-qty-btn:hover{background:#fff}.cx-qty-val{min-width:28px;text-align:center;font-weight:600}.cx-cart-fab{position:fixed;left:50%;bottom:1.25rem;transform:translate(-50%);display:inline-flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;background:var(--primary);color:#fff;border:none;border-radius:999px;cursor:pointer;font-weight:600;box-shadow:var(--shadow-lg);z-index:20;transition:transform .15s,background .15s}.cx-cart-fab:hover{background:var(--primary-dark);transform:translate(-50%) translateY(-2px)}.cx-cart-fab-count{background:#ffffff38;padding:.1rem .55rem;border-radius:999px;font-size:.85rem}.cx-cart-fab-total{font-weight:700}.cx-backdrop{position:fixed;inset:0;background:#14141473;z-index:30;animation:fade-in .15s ease}.cx-sheet{position:fixed;right:0;top:0;bottom:0;width:min(420px,100%);background:var(--surface);z-index:31;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slide-in .2s ease}@media(max-width:600px){.cx-sheet{inset:auto 0 0;width:100%;max-height:92vh;border-radius:22px 22px 0 0;animation:slide-up .2s ease}}.cx-sheet-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.cx-sheet-head h2{margin:0}.cx-icon-btn{width:36px;height:36px;border:none;background:var(--surface-2);border-radius:50%;cursor:pointer;font-size:1rem}.cx-sheet-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}.cx-sheet-row{display:grid;grid-template-columns:56px 1fr auto;gap:.75rem;padding:.75rem 1.25rem;align-items:center;border-bottom:1px solid var(--border)}.cx-sheet-thumb{width:56px;height:56px;border-radius:10px;object-fit:cover}.cx-sheet-info{min-width:0}.cx-sheet-name{font-weight:600}.cx-sheet-price{color:var(--ink-2);font-size:.92rem}.cx-sheet-notes{margin:.75rem 1.25rem;width:calc(100% - 2.5rem)}.cx-sheet-row-wrap{border-bottom:1px solid var(--border)}.cx-sheet-row-wrap>.cx-sheet-row{border-bottom:none}.cx-item-note-toggle{margin-top:.25rem;padding:0;background:none;border:none;color:var(--primary);font-size:.85rem;cursor:pointer}.cx-item-note-toggle:hover{text-decoration:underline}.cx-item-note{display:block;margin:0 1.25rem .75rem;width:calc(100% - 2.5rem);padding:.5rem .75rem;border:1px solid var(--border);border-radius:10px;font:inherit;font-size:.9rem}.cx-sheet-foot{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border)}.cx-sheet-total{display:flex;justify-content:space-between;font-size:1.1rem;margin-bottom:.75rem}.cx-place{width:100%;padding:.95rem;background:var(--primary);color:#fff;border:none;border-radius:14px;cursor:pointer;font-weight:700;font-size:1rem;transition:background .15s}.cx-place:hover:not(:disabled){background:var(--primary-dark)}.cx-place:disabled{opacity:.6;cursor:not-allowed}.cx-tracker{padding:1.5rem 0 .5rem}.cx-tracker-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;margin-bottom:.75rem;box-shadow:var(--shadow-sm)}.cx-tracker-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.75rem;flex-wrap:wrap}.cx-progress{list-style:none;padding:0;margin:0 0 .75rem;display:grid;grid-template-columns:repeat(6,1fr);gap:.25rem;position:relative}.cx-progress-step{display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.72rem;color:var(--muted);text-align:center}.cx-progress-step .dot{width:14px;height:14px;border-radius:50%;background:var(--surface-2);border:2px solid var(--border);transition:all .25s}.cx-progress-step.done .dot{background:var(--success);border-color:var(--success)}.cx-progress-step.current .dot{background:var(--primary);border-color:var(--primary);box-shadow:0 0 0 5px var(--primary-soft);animation:pulse 1.4s ease-in-out infinite}.cx-progress-step.done .lbl,.cx-progress-step.current .lbl{color:var(--ink);font-weight:600}.cx-tracker-items{list-style:none;padding:0;margin:.5rem 0;font-size:.92rem;color:var(--ink-2)}.cx-tracker-items li{padding:.15rem 0}.cx-tracker-total{font-weight:600}.cx-status,.status{display:inline-block;padding:.25rem .7rem;border-radius:999px;font-size:.78rem;font-weight:600;background:var(--surface-2);color:var(--ink-2)}.status-pending{background:#fff1e6;color:#b34418}.status-accepted{background:#fef3c7;color:#92400e}.status-preparing{background:#fed7aa;color:#9a3412}.status-ready{background:#bbf7d0;color:#166534}.status-served{background:#dbeafe;color:#1e3a8a}.status-paid{background:#e5e7eb;color:#374151}.status-cancelled{background:#f3f4f6;color:#6b7280;text-decoration:line-through}.cx-empty{min-height:100vh;display:grid;place-items:center;padding:1.5rem;background:radial-gradient(800px 400px at 50% -20%,rgba(212,84,31,.15),transparent 60%),var(--bg)}.cx-empty-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 2rem;text-align:center;max-width:420px;box-shadow:var(--shadow-md)}.cx-empty-card{position:relative}.cx-empty-card h1{margin:.5rem 0;font-size:1.6rem}.cx-empty-card p{color:var(--ink-2);margin:.4rem 0}.cx-empty-icon{font-size:3.5rem}.cx-empty-corner{position:absolute;top:.75rem;inset-inline-end:.75rem}.cx-lang{display:inline-flex;border:1px solid var(--border);background:var(--surface);border-radius:999px;overflow:hidden;box-shadow:var(--shadow-sm)}.cx-lang-btn{border:0;background:transparent;padding:.45rem .75rem;font-size:.9rem;font-weight:600;color:var(--ink-2);cursor:pointer;min-width:2.5rem}.cx-lang-btn.active{background:var(--primary);color:#fff}.cx-lang-btn:not(.active):hover{background:var(--surface-2)}[dir=rtl] .cx-progress{direction:rtl}[dir=rtl] .cx-toast{left:auto;right:50%;transform:translate(50%)}.cx-empty-link{display:inline-block;margin-top:1.25rem;padding:.55rem 1rem;background:var(--surface-2);color:var(--ink);border-radius:10px;font-weight:500}.cx-empty-link:hover{background:var(--border);text-decoration:none}.cx-toast{position:fixed;left:50%;bottom:5.5rem;transform:translate(-50%);background:var(--ink);color:#fff;padding:.75rem 1.1rem;border-radius:999px;font-weight:500;z-index:40;box-shadow:var(--shadow-lg);animation:pop .25s cubic-bezier(.4,1.4,.5,1);max-width:92vw}.cx-toast.success{background:#166534}.cx-toast.error{background:var(--error)}.cx-sheet.bill{width:min(480px,100%)}.cx-bill-head-text{display:flex;flex-direction:column;gap:.15rem;min-width:0}.cx-bill-head-text h2,.cx-bill-summary{margin:0}.cx-bill-body{flex:1;overflow-y:auto;padding:.85rem 1.25rem 1rem}.cx-bill-empty{display:grid;place-items:center;gap:.6rem;padding:3rem 1rem 2rem;text-align:center}.cx-bill-empty-icon{font-size:3rem;opacity:.85}.cx-bill-empty p{margin:0}.cx-bill-groups{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem}.cx-bill-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem .65rem;box-shadow:var(--shadow-sm);transition:border-color .15s,background .15s,box-shadow .15s}.cx-bill-group.mine{background:var(--primary-soft);border-color:var(--primary)}.cx-bill-group-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.55rem}.cx-bill-group-who{display:flex;align-items:center;gap:.6rem;min-width:0}.cx-bill-avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--surface-2);border:1px solid var(--border);font-weight:700;color:var(--ink-2);font-size:.95rem;flex:0 0 auto}.cx-bill-group.mine .cx-bill-avatar{background:var(--primary);color:#fff;border-color:var(--primary)}.cx-bill-group-name{display:flex;align-items:center;gap:.45rem;min-width:0;flex-wrap:wrap}.cx-bill-group-name strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:16ch}.cx-bill-mine-pill{background:var(--primary);color:#fff;font-size:.68rem;font-weight:700;padding:.12rem .55rem;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.cx-bill-group-subtotal{font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap}.cx-bill-items{list-style:none;margin:0;padding:0}.cx-bill-item{display:grid;grid-template-columns:2.25rem 1fr auto auto;gap:.5rem .65rem;align-items:center;padding:.45rem 0;border-top:1px dashed var(--border)}.cx-bill-item:first-child{border-top:0;padding-top:.15rem}.cx-bill-item-qty{font-weight:700;color:var(--ink-2);font-variant-numeric:tabular-nums;text-align:center}.cx-bill-item-main{display:flex;flex-direction:column;gap:.1rem;min-width:0}.cx-bill-item-name{font-weight:500;color:var(--ink);overflow-wrap:anywhere;line-height:1.25}.cx-bill-item-note{font-size:.78rem;color:var(--muted);font-style:italic}.cx-bill-item-status{font-size:.68rem;padding:.15rem .5rem}.cx-bill-item-total{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap;text-align:end}.cx-bill-foot{display:flex;flex-direction:column;gap:.65rem;background:var(--surface)}.cx-bill-total{display:flex;justify-content:space-between;align-items:baseline;font-size:1rem;color:var(--ink-2)}.cx-bill-total strong{font-size:1.4rem;color:var(--primary);font-variant-numeric:tabular-nums}.cx-bill-actions{display:grid;grid-template-columns:1fr 1.5fr;gap:.6rem}.cx-bill-actions .btn{width:100%;padding:.8rem 1rem;border-radius:12px;font-weight:600;font-size:.95rem}@media(max-width:480px){.cx-bill-item{grid-template-columns:2rem 1fr auto;grid-template-areas:"qty main total" "qty status total";row-gap:.2rem}.cx-bill-item-qty{grid-area:qty;align-self:start;padding-top:.1rem}.cx-bill-item-main{grid-area:main}.cx-bill-item-status{grid-area:status;justify-self:start}.cx-bill-item-total{grid-area:total;align-self:start}}.cx-details{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(520px,calc(100% - 2rem));max-height:calc(100vh - 2rem);background:var(--surface);z-index:31;display:flex;flex-direction:column;border-radius:22px;overflow:hidden;box-shadow:var(--shadow-lg);animation:fade-in .15s ease}@media(max-width:600px){.cx-details{inset:auto 0 0;transform:none;width:100%;max-height:92vh;border-radius:22px 22px 0 0;animation:slide-up .2s ease}}.cx-details-img-wrap{position:relative;width:100%;height:240px;background:var(--surface-2);flex-shrink:0}@media(min-width:601px){.cx-details-img-wrap{height:280px}}.cx-details-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.cx-details-img.placeholder{display:grid;place-items:center;font-size:4rem;color:var(--muted)}.cx-details-close{position:absolute;top:12px;right:12px;background:#ffffffeb;box-shadow:var(--shadow-sm)}[dir=rtl] .cx-details-close{right:auto;left:12px}.cx-details-body{padding:1rem 1.25rem;overflow-y:auto;flex:1}.cx-details-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.cx-details-name{margin:0;font-size:1.35rem;font-weight:700;letter-spacing:-.01em}.cx-details-price{flex-shrink:0;font-weight:700;font-size:1.1rem;color:var(--ink)}.cx-details-desc{margin:.25rem 0 0;color:var(--ink-2);line-height:1.5;white-space:pre-wrap}.cx-details-foot{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border)}.cx-details-foot .cx-qty{width:100%;padding:.4rem;font-size:1.05rem}.cx-details-sections{margin-top:1rem;display:flex;flex-direction:column;gap:1rem}.cx-details-section{display:flex;flex-direction:column;gap:.5rem;padding-top:1rem;border-top:1px solid var(--border)}.cx-details-section-title{margin:0;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--ink-2)}.cx-details-ingredients{list-style:disc;padding-inline-start:1.25rem;margin:0;display:grid;grid-template-columns:1fr;gap:.2rem 1rem;color:var(--ink)}@media(min-width:480px){.cx-details-ingredients{grid-template-columns:repeat(2,1fr)}}.cx-details-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.65rem 1rem}.cx-meta-item{display:flex;flex-direction:column;gap:.2rem;min-width:0}.cx-meta-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-2);font-weight:600}.cx-meta-value{font-weight:600;color:var(--ink)}.cx-spicy{color:#b3411a}.cx-chips{display:flex;flex-wrap:wrap;gap:.35rem}.cx-chip{display:inline-flex;align-items:center;padding:.25rem .55rem;background:var(--surface-2);border-radius:999px;font-size:.82rem;font-weight:500;color:var(--ink);border:1px solid var(--border)}.cx-chip.warn{background:#fff4ec;color:#9a3a0a;border-color:#f3c69d}.cx-chip.ok{background:#ecf8ee;color:#1f6b34;border-color:#b9dec1}.cx-card-badges{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:-.15rem}.cx-badge{display:inline-flex;align-items:center;height:22px;padding:0 .5rem;font-size:.7rem;font-weight:700;letter-spacing:.02em;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);color:var(--ink)}.cx-badge.ok{background:#ecf8ee;color:#1f6b34;border-color:#b9dec1}.cx-badge.warn{background:#fff4ec;color:#9a3a0a;border-color:#f3c69d}.cx-sheet.item-editor{width:min(640px,100%)}.item-editor-body{flex:1;overflow-y:auto;padding:1rem 1.25rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem 1rem}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.form-field{display:flex;flex-direction:column;gap:.3rem;min-width:0}.form-field.full{grid-column:1 / -1}.form-field>span{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;color:var(--ink-2)}.form-field input[type=text],.form-field input[type=number],.form-field select,.form-field textarea{padding:.55rem .7rem;border:1px solid var(--border);border-radius:8px;font:inherit;background:var(--surface);color:var(--ink)}.form-field textarea{resize:vertical;min-height:96px;font-family:inherit}.form-field small{font-size:.78rem}.switch-row{display:inline-flex;align-items:center;gap:.4rem;font-size:.92rem;color:var(--ink);font-weight:400;text-transform:none;letter-spacing:0}.board{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem}@media(max-width:1100px){.board{grid-template-columns:repeat(2,1fr)}}.board-col h3{margin:0 0 .5rem;font-size:.95rem;text-transform:uppercase;color:var(--muted);letter-spacing:.05em}.order-card{padding:.85rem}.order-head{display:flex;justify-content:space-between;margin-bottom:.4rem;font-size:.95rem}.order-items{list-style:none;padding:0;margin:0 0 .5rem;font-size:.9rem}.order-items li{padding:2px 0}.order-actions{display:flex;flex-wrap:wrap;gap:.3rem}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{text-align:left;padding:.55rem .65rem;border-bottom:1px solid var(--border)}.data-table th{background:var(--surface-2);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-2)}.table-bills{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.85rem}.table-bill{padding:.85rem 1rem;display:flex;flex-direction:column;gap:.7rem}.table-bill-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.table-bill-head h3{margin:0;font-size:1.05rem}.table-bill-total{text-align:right;display:flex;flex-direction:column}.table-bill-total strong{font-size:1.15rem}.table-bill-orders{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}.table-bill-orders>li{border:1px solid var(--border);border-radius:8px;padding:.55rem .65rem;background:var(--surface-2)}.table-bill-order-head{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.9rem}.table-bill-order-total{margin-left:auto;font-weight:600}.table-bill-items{list-style:none;padding:0;margin:.4rem 0 0;font-size:.85rem}.table-bill-items li{padding:1px 0}.table-bill-foot{display:flex;justify-content:flex-end;align-items:center;gap:.6rem;border-top:1px dashed var(--border);padding-top:.6rem;flex-wrap:wrap}.table-bill-foot .small{flex:1;min-width:0}.req-list{list-style:none;padding:0;margin:0}.req-list li{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--border)}.badge{display:inline-block;min-width:22px;padding:0 8px;border-radius:999px;background:var(--primary);color:#fff;font-size:.75rem;font-weight:600;text-align:center;vertical-align:middle;margin-left:.4rem}.login-wrap{display:flex;justify-content:center;padding:2rem}.login-card{width:100%;max-width:380px;display:flex;flex-direction:column;gap:.75rem}.login-card label,.login-card input{width:100%}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in{0%{transform:translate(20px);opacity:0}to{transform:none;opacity:1}}@keyframes slide-up{0%{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}@keyframes pop{0%{transform:translate(-50%,6px);opacity:0}to{transform:translate(-50%);opacity:1}}@keyframes pulse{0%,to{box-shadow:0 0 0 5px var(--primary-soft)}50%{box-shadow:0 0 0 9px #d4541f2e}}.brand{display:inline-flex;align-items:center;gap:.55rem}.brand-logo{height:28px;width:auto;max-width:100px;object-fit:contain;border-radius:6px;background:#fff;padding:2px}.cx-hero-brand{display:flex;align-items:center;gap:.9rem;min-width:0}.cx-hero-logo{height:clamp(48px,8vw,72px);width:auto;max-width:clamp(72px,14vw,140px);object-fit:contain;border-radius:12px;background:var(--surface);padding:6px;box-shadow:var(--shadow-sm);flex-shrink:0}.branding-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:.75rem}.branding-field{display:flex;flex-direction:column;gap:.4rem}.branding-field input[type=text],.branding-field input[type=color]{align-self:flex-start}.branding-field input[type=text]{width:100%}.branding-logo{margin-top:1.25rem}.branding-logo-preview{width:96px;height:96px;border:1px dashed var(--border);border-radius:12px;display:grid;place-items:center;background:var(--surface-2);flex-shrink:0;overflow:hidden}.branding-logo-preview img{max-width:100%;max-height:100%;object-fit:contain}.branding-preview{margin-top:1.25rem;display:flex;flex-direction:column;gap:.5rem}.branding-preview-card{border-radius:var(--radius-lg);padding:1.25rem;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow-md);max-width:480px}.branding-preview-header{display:flex;align-items:center;gap:.85rem}.branding-preview-logo{width:56px;height:56px;border-radius:12px;object-fit:contain;background:#ffffffeb;padding:4px}.branding-preview-mark{width:56px;height:56px;border-radius:12px;background:#ffffff2e;color:#fff;display:grid;place-items:center;font-size:1.6rem;font-weight:700}.branding-preview-cta{align-self:flex-start;padding:.6rem 1.1rem;border-radius:12px;border:none;font-weight:600;cursor:default}
