@import "https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--orange:#ff4a1c;--orange-deep:#c8330a;--orange-soft:#ffb89a;--cream:#f6efe6;--paper:#fbfaf8;--ink:#181410;--ink-2:#3a332c;--muted:#8a847f;--line:#e8e2da;--green:#1a7a4a;--green-soft:#e6f4ed;--red:#c8330a;--red-soft:#fdecea;--amber:#d4820a;--amber-soft:#fef3e2;--pad:16px;--radius:16px}html,body,#root{background:var(--paper);height:100%;color:var(--ink-2);-webkit-font-smoothing:antialiased;font-family:Hanken Grotesk,sans-serif;font-size:15px;line-height:1.5}.app{flex-direction:column;height:100%;display:flex}.main-content{padding:0 var(--pad) calc(80px + env(safe-area-inset-bottom));flex:1;overflow-y:auto}.appbar{padding:calc(env(safe-area-inset-top) + 12px) var(--pad) 12px;background:var(--paper);border-bottom:1px solid var(--line);z-index:10;align-items:center;gap:12px;display:flex;position:sticky;top:0}.appbar .logo{align-items:center;gap:6px;text-decoration:none;display:flex}.appbar .logo svg{width:28px;height:28px;color:var(--orange)}.appbar .logo .wordmark{color:var(--orange);letter-spacing:-.03em;font-family:Bricolage Grotesque,sans-serif;font-size:20px;font-style:italic;font-weight:800}.appbar .logo .badge{background:var(--ink);color:var(--paper);letter-spacing:.04em;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:700}.appbar-title{color:var(--ink);flex:1;font-size:17px;font-weight:700}.appbar-right{align-items:center;gap:8px;margin-left:auto;display:flex}.bottomnav{background:var(--paper);border-top:1px solid var(--line);padding-bottom:env(safe-area-inset-bottom);z-index:20;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{cursor:pointer;color:var(--muted);letter-spacing:.02em;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 4px 8px;font-family:Hanken Grotesk,sans-serif;font-size:10px;font-weight:600;transition:color .15s;display:flex}.nav-item svg{width:22px;height:22px}.nav-item.active{color:var(--orange)}.page-head{justify-content:space-between;align-items:flex-end;padding:20px 0 16px;display:flex}.page-title{color:var(--ink);letter-spacing:-.02em;font-family:Bricolage Grotesque,sans-serif;font-size:28px;font-style:italic;font-weight:800;line-height:1}.page-sub{color:var(--muted);margin-top:3px;font-size:13px;font-weight:500}.dot{color:var(--orange)}.table-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding-bottom:12px;display:grid}@media (width>=600px){.table-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=900px){.table-grid{grid-template-columns:repeat(4,1fr)}}.table-card{border:2px solid var(--line);border-radius:var(--radius);cursor:pointer;background:#fff;flex-direction:column;gap:8px;min-height:130px;padding:16px;transition:border-color .15s,transform .15s,box-shadow .15s;display:flex;position:relative}.table-card:active{transform:scale(.97)}.table-card.occupied{border-color:var(--orange)}.table-card.paid{border-color:var(--green)}.table-card-name{color:var(--ink);font-size:15px;font-weight:700}.table-card-status{letter-spacing:.04em;text-transform:uppercase;border-radius:20px;width:fit-content;padding:3px 8px;font-size:11px;font-weight:700}.table-card-status.empty{background:var(--cream);color:var(--muted)}.table-card-status.occupied{background:var(--orange-soft);color:var(--orange-deep)}.table-card-status.paid{background:var(--green-soft);color:var(--green)}.table-card-total{color:var(--ink);margin-top:auto;font-size:18px;font-weight:700}.table-card-meta{color:var(--muted);font-size:12px;font-weight:500}.add-table-card{border:2px dashed var(--line);border-radius:var(--radius);cursor:pointer;min-height:130px;color:var(--muted);background:0 0;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px;font-family:Hanken Grotesk,sans-serif;font-size:13px;font-weight:600;transition:border-color .15s,color .15s;display:flex}.add-table-card:hover{border-color:var(--orange);color:var(--orange)}.add-table-card svg{width:24px;height:24px}.btn{cursor:pointer;border:none;border-radius:50px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 20px;font-family:Hanken Grotesk,sans-serif;font-size:15px;font-weight:700;transition:background .15s,transform .1s,opacity .15s;display:flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:default}.btn-primary{background:var(--orange);color:#fff}.btn-primary:hover:not(:disabled){background:var(--orange-deep)}.btn-ghost{background:var(--cream);color:var(--ink-2)}.btn-ghost:hover:not(:disabled){background:var(--line)}.btn-danger{background:var(--red-soft);color:var(--red)}.btn-sm{width:auto;padding:9px 16px;font-size:13px}.btn-icon{border-radius:50%;flex-shrink:0;width:40px;height:40px;padding:0}.btn-icon svg{width:18px;height:18px}.pill{cursor:pointer;border:none;border-radius:50px;align-items:center;gap:6px;padding:8px 14px;font-family:Hanken Grotesk,sans-serif;font-size:13px;font-weight:700;transition:background .15s;display:inline-flex}.pill.solid{background:var(--orange);color:#fff}.pill.solid:hover{background:var(--orange-deep)}.pill.ghost{background:var(--cream);color:var(--ink-2)}.pill.ghost:hover{background:var(--line)}.pill svg{width:16px;height:16px}.overlay{z-index:30;background:#18141080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.sheet{background:var(--paper);padding:24px var(--pad) calc(24px + env(safe-area-inset-bottom));border-radius:20px 20px 0 0;flex-direction:column;gap:16px;width:100%;max-width:520px;max-height:90vh;display:flex;overflow-y:auto}.sheet-handle{background:var(--line);border-radius:2px;width:36px;height:4px;margin:0 auto -8px}.sheet-title{color:var(--ink);font-family:Bricolage Grotesque,sans-serif;font-size:22px;font-style:italic;font-weight:800}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--ink-2);font-size:13px;font-weight:700}.field input,.field textarea,.field select{border:1.5px solid var(--line);color:var(--ink);background:#fff;border-radius:12px;outline:none;width:100%;padding:12px 14px;font-family:Hanken Grotesk,sans-serif;font-size:15px;transition:border-color .15s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--orange)}.field textarea{resize:vertical;min-height:80px}.list{flex-direction:column;gap:2px;display:flex}.lrow{cursor:pointer;background:#fff;border-radius:12px;align-items:center;gap:12px;padding:13px 14px;transition:background .1s;display:flex}.lrow:hover{background:var(--cream)}.lrow .meta{flex:1;min-width:0}.lrow .meta b{color:var(--ink);font-size:15px;font-weight:700;display:block}.lrow .meta span{color:var(--muted);font-size:13px;font-weight:500}.lrow .right{text-align:right;flex-shrink:0}.sec-head{justify-content:space-between;align-items:center;margin:20px 0 10px;display:flex}.sec-head h3{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:13px;font-weight:700}.chip{letter-spacing:.03em;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-block}.chip.open{background:var(--orange-soft);color:var(--orange-deep)}.chip.closed{background:var(--cream);color:var(--muted)}.chip.paid{background:var(--green-soft);color:var(--green)}.chip.pending{background:var(--amber-soft);color:var(--amber)}.auth-wrap{min-height:100vh;padding:24px var(--pad);background:var(--paper);flex-direction:column;justify-content:center;align-items:center;gap:24px;display:flex}.auth-logo{align-items:center;gap:8px;display:flex}.auth-logo svg{width:36px;height:36px;color:var(--orange)}.auth-logo .wordmark{color:var(--orange);letter-spacing:-.03em;font-family:Bricolage Grotesque,sans-serif;font-size:28px;font-style:italic;font-weight:800}.auth-logo .badge{background:var(--ink);color:var(--paper);letter-spacing:.04em;border-radius:5px;padding:2px 7px;font-size:11px;font-weight:700}.auth-card{border:1.5px solid var(--line);background:#fff;border-radius:20px;flex-direction:column;gap:16px;width:100%;max-width:400px;padding:28px 24px;display:flex}.auth-card h2{color:var(--ink);font-family:Bricolage Grotesque,sans-serif;font-size:22px;font-style:italic;font-weight:800}.auth-card p{color:var(--muted);font-size:14px}.err-msg{color:var(--red);text-align:center;font-size:13px;font-weight:600}.empty{text-align:center;color:var(--muted);flex-direction:column;align-items:center;gap:10px;padding:48px 24px;display:flex}.empty svg{opacity:.4;width:48px;height:48px}.empty b{color:var(--ink-2);font-size:16px;font-weight:700}.empty p{font-size:14px}.page-loading{justify-content:center;align-items:center;height:100%;min-height:200px;display:flex}.spinner{border:3px solid var(--line);border-top-color:var(--orange);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.qr-wrap{flex-direction:column;align-items:center;gap:16px;padding:8px 0;display:flex}.qr-wrap canvas{border-radius:12px}.qr-label{color:var(--ink);text-align:center;font-size:18px;font-weight:700}.qr-url{color:var(--muted);word-break:break-all;text-align:center;font-size:12px}.item-row{background:#fff;border-radius:10px;align-items:center;gap:10px;padding:11px 14px;display:flex}.item-row .item-name{color:var(--ink);flex:1;font-size:14px;font-weight:600}.item-row .item-qty{color:var(--muted);font-size:13px;font-weight:600}.item-row .item-price{color:var(--ink-2);font-size:14px;font-weight:700}.alert{background:var(--amber-soft);color:var(--amber);border-radius:12px;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;padding:12px 14px;font-size:14px;font-weight:600;display:flex}.alert.success{background:var(--green-soft);color:var(--green)}.alert.error{background:var(--red-soft);color:var(--red)}
