:root{--wisteria-50:#faf7fd;--wisteria-100:#f2ebf9;--wisteria-200:#e4d6f2;--wisteria-300:#cfb6e7;--wisteria-400:#b994d7;--wisteria-500:#9b73c4;--wisteria-600:#8b6fb8;--wisteria-700:#6f4f9b;--wisteria-800:#523775;--wisteria-900:#331f4d;--ink-900:#1b1324;--ink-700:#3d2e4d;--ink-500:#6b5a7a;--ink-300:#a697b2;--ink-100:#e6dfeb;--paper:#fff;--paper-cream:#fdfbff;--success:#2e7d53;--danger:#c03d3d;--warning:#d98f2c;--radius-sm:8px;--radius:14px;--radius-lg:22px;--radius-xl:32px;--shadow-sm:0 1px 2px #5237750f, 0 1px 3px #5237750a;--shadow:0 4px 14px #52377514, 0 1px 3px #5237750a;--shadow-lg:0 20px 40px -10px #5237752e, 0 8px 20px -8px #5237751a;--sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--serif:"Fraunces", "Times New Roman", Georgia, serif}*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--sans);color:var(--ink-900);background:var(--paper-cream);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none;margin:0}button{cursor:pointer;color:inherit;background:0 0;border:none;padding:0;font-family:inherit}input,textarea,select{color:var(--ink-900);font-family:inherit;font-size:1rem}a{color:var(--wisteria-700);text-decoration:none}.app{background:var(--paper-cream);flex-direction:column;min-height:100dvh;display:flex}.topbar{z-index:30;-webkit-backdrop-filter:saturate(180%)blur(14px);border-bottom:1px solid var(--ink-100);background:#ffffffd9;justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:sticky;top:0}.brand{font-family:var(--serif);letter-spacing:-.01em;color:var(--wisteria-800);align-items:center;gap:10px;font-size:20px;font-weight:700;display:flex}.brand-mark{background:linear-gradient(135deg, var(--wisteria-300), var(--wisteria-600));color:#fff;width:32px;height:32px;box-shadow:var(--shadow-sm);border-radius:10px;place-items:center;font-size:18px;display:grid}.brand em{color:var(--wisteria-600);font-style:italic;font-weight:600}.role-switch{background:var(--wisteria-100);border-radius:999px;gap:2px;padding:3px;display:flex}.role-switch button{color:var(--wisteria-700);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;transition:all .2s}.role-switch button.active{background:var(--paper);color:var(--wisteria-800);box-shadow:var(--shadow-sm)}.main{flex:1}.hero{background:linear-gradient(180deg, var(--wisteria-100) 0%, var(--paper-cream) 100%);padding:34px 20px 24px}.hero-inner{max-width:980px;margin:0 auto}.hero h1{font-family:var(--serif);letter-spacing:-.02em;color:var(--wisteria-900);margin:0 0 8px;font-size:clamp(34px,6vw,52px);font-weight:900;line-height:1.05}.hero h1 em{color:var(--wisteria-600);font-style:italic;font-weight:600}.hero p{color:var(--ink-500);max-width:540px;margin:0 0 18px;font-size:16px}.hero-meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.pill{background:var(--paper);border:1px solid var(--ink-100);color:var(--ink-700);box-shadow:var(--shadow-sm);border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;display:inline-flex}.pill.accent{background:var(--wisteria-600);color:#fff;border-color:var(--wisteria-600)}.pill .dot{background:var(--success);border-radius:50%;width:6px;height:6px;display:inline-block}.category-rail{z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--ink-100);scrollbar-width:none;background:#fdfbffeb;gap:8px;padding:10px 20px;display:flex;position:sticky;top:64px;overflow-x:auto}.category-rail::-webkit-scrollbar{display:none}.category-rail button{color:var(--ink-500);white-space:nowrap;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .2s}.category-rail button.active{background:var(--wisteria-900);color:#fff}.menu{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;max-width:980px;margin:0 auto;padding:24px 20px 120px;display:grid}.menu-category{font-family:var(--serif);color:var(--wisteria-900);grid-column:1/-1;margin:16px 0 4px;font-size:22px;font-weight:700}.menu-category:first-child{margin-top:0}.menu-card{background:var(--paper);border:1px solid var(--ink-100);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;transition:transform .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.menu-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.menu-card.unavailable{opacity:.5;cursor:not-allowed}.menu-card-img{aspect-ratio:16/10;background:linear-gradient(135deg, var(--wisteria-100), var(--wisteria-200));place-items:center;font-size:72px;display:grid}.menu-card-body{flex-direction:column;gap:6px;padding:14px 16px 16px;display:flex}.menu-card-title{color:var(--ink-900);font-size:16px;font-weight:700}.menu-card-desc{color:var(--ink-500);min-height:36px;font-size:13px;line-height:1.4}.menu-card-row{justify-content:space-between;align-items:center;margin-top:6px;display:flex}.menu-card-price{color:var(--wisteria-800);font-size:16px;font-weight:700}.menu-card-time{color:var(--ink-500);align-items:center;gap:4px;font-size:12px;display:flex}.menu-card-add{background:var(--paper);width:36px;height:36px;color:var(--wisteria-800);box-shadow:var(--shadow);border-radius:50%;place-items:center;font-size:20px;font-weight:700;transition:transform .15s;display:grid;position:absolute;top:12px;right:12px}.menu-card-add:hover{background:var(--wisteria-600);color:#fff;transform:scale(1.08)}.cart-fab{background:var(--wisteria-900);color:#fff;z-index:40;border-radius:999px;align-items:center;gap:12px;padding:14px 22px;font-size:15px;font-weight:600;transition:transform .2s;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 32px #331f4d59}.cart-fab:hover{transform:translate(-50%)translateY(-2px)}.cart-fab .count{background:var(--wisteria-400);color:var(--wisteria-900);border-radius:999px;padding:2px 10px;font-size:13px;font-weight:700}.overlay{z-index:50;opacity:0;pointer-events:none;background:#1b132473;transition:opacity .2s;position:fixed;inset:0}.overlay.open{opacity:1;pointer-events:auto}.drawer{background:var(--paper);z-index:60;width:min(460px,100vw);box-shadow:var(--shadow-lg);flex-direction:column;transition:transform .25s cubic-bezier(.2,.8,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}.drawer.open{transform:translate(0)}.drawer-head{border-bottom:1px solid var(--ink-100);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.drawer-head h2{font-family:var(--serif);color:var(--wisteria-900);margin:0;font-size:22px;font-weight:700}.drawer-body{flex:1;padding:8px 22px 22px;overflow-y:auto}.drawer-foot{border-top:1px solid var(--ink-100);background:var(--paper-cream);padding:18px 22px 22px}.close-btn{background:var(--wisteria-100);width:36px;height:36px;color:var(--wisteria-800);border-radius:50%;place-items:center;font-size:18px;font-weight:700;transition:background .15s;display:grid}.close-btn:hover{background:var(--wisteria-200)}.cart-item{border-bottom:1px solid var(--ink-100);grid-template-columns:56px 1fr auto;align-items:center;gap:14px;padding:14px 0;display:grid}.cart-item:last-child{border-bottom:none}.cart-item-img{background:var(--wisteria-100);border-radius:12px;place-items:center;width:56px;height:56px;font-size:28px;display:grid}.cart-item-info{min-width:0}.cart-item-name{font-size:15px;font-weight:600}.cart-item-price{color:var(--ink-500);margin-top:2px;font-size:13px}.qty-stepper{background:var(--wisteria-100);border-radius:999px;align-items:center;gap:6px;padding:4px;display:flex}.qty-stepper button{background:var(--paper);width:26px;height:26px;color:var(--wisteria-800);box-shadow:var(--shadow-sm);border-radius:50%;place-items:center;font-size:14px;font-weight:700;display:grid}.qty-stepper button:hover{background:var(--wisteria-600);color:#fff}.qty-stepper span{text-align:center;min-width:18px;font-size:14px;font-weight:600}.totals{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.totals-row{color:var(--ink-500);justify-content:space-between;font-size:14px;display:flex}.totals-row.total{color:var(--ink-900);border-top:1px dashed var(--ink-100);margin-top:8px;padding-top:10px;font-size:18px;font-weight:700}.tip-row{gap:6px;margin:10px 0 4px;display:flex}.tip-row button{background:var(--wisteria-100);color:var(--wisteria-800);border-radius:10px;flex:1;padding:8px;font-size:13px;font-weight:600}.tip-row button.active{background:var(--wisteria-800);color:#fff}.field{flex-direction:column;gap:6px;margin:12px 0;display:flex}.field label{color:var(--ink-500);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.field input,.field textarea,.field select{background:var(--paper);border:1px solid var(--ink-100);border-radius:10px;outline:none;padding:11px 14px;transition:border-color .15s,box-shadow .15s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--wisteria-400);box-shadow:0 0 0 3px var(--wisteria-100)}.field textarea{resize:vertical;min-height:72px;font-family:inherit}.btn-primary{background:var(--wisteria-900);color:#fff;border-radius:14px;justify-content:center;align-items:center;gap:8px;width:100%;padding:15px;font-size:15px;font-weight:700;transition:background .15s,transform .1s;display:flex}.btn-primary:hover{background:var(--wisteria-800)}.btn-primary:active{transform:scale(.99)}.btn-primary:disabled{background:var(--ink-300);cursor:not-allowed}.btn-ghost{color:var(--wisteria-700);background:var(--wisteria-100);border-radius:10px;padding:10px 14px;font-size:14px;font-weight:600}.btn-ghost:hover{background:var(--wisteria-200)}.btn-danger{color:var(--danger);background:0 0;border-radius:8px;padding:6px 10px;font-size:13px;font-weight:500}.btn-danger:hover{background:#fdeaea}.empty-state{text-align:center;color:var(--ink-500);padding:60px 20px}.empty-state .emoji{margin-bottom:12px;font-size:48px}.empty-state h3{font-family:var(--serif);color:var(--wisteria-800);margin:0 0 6px}.empty-state p{margin:0;font-size:14px}.track-wrap{max-width:560px;margin:0 auto;padding:24px 20px 100px}.track-card{background:var(--paper);border-radius:var(--radius-xl);box-shadow:var(--shadow);border:1px solid var(--ink-100);padding:28px}.track-head{text-align:center;margin-bottom:22px}.track-head .status-label{color:var(--wisteria-600);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;font-size:13px;font-weight:700}.track-head h2{font-family:var(--serif);color:var(--wisteria-900);margin:0 0 4px;font-size:28px;font-weight:700}.track-head p{color:var(--ink-500);margin:0;font-size:14px}.progress-track{background:var(--wisteria-100);border-radius:999px;height:8px;margin:18px 0 10px;position:relative;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--wisteria-500), var(--wisteria-700));border-radius:999px;transition:width .6s cubic-bezier(.2,.8,.2,1);position:absolute;inset:0;box-shadow:0 0 20px #8b6fb880}.progress-fill.done{background:linear-gradient(90deg, var(--success), #4ba974);box-shadow:0 0 20px #2e7d5380}.steps{justify-content:space-between;margin-top:6px;padding:0 2px;display:flex}.step{color:var(--ink-300);text-align:center;flex-direction:column;flex:1;align-items:center;gap:6px;font-size:11px;display:flex}.step .bullet{background:var(--wisteria-100);width:20px;height:20px;color:var(--wisteria-400);border-radius:50%;place-items:center;font-size:10px;transition:all .3s;display:grid}.step.active .bullet,.step.done .bullet{background:var(--wisteria-700);color:#fff;box-shadow:0 0 0 4px var(--wisteria-100)}.step.active{color:var(--wisteria-800);font-weight:600}.step.done{color:var(--ink-500)}.step.done .bullet{background:var(--success)}.order-summary{border-top:1px dashed var(--ink-100);margin-top:22px;padding-top:22px}.order-summary h4{font-family:var(--serif);color:var(--wisteria-900);margin:0 0 10px;font-size:16px}.summary-line{color:var(--ink-700);justify-content:space-between;padding:6px 0;font-size:14px;display:flex}.chef{grid-template-columns:1fr;gap:16px;max-width:1240px;margin:0 auto;padding:20px;display:grid}@media (width>=860px){.chef{grid-template-columns:380px 1fr}}.chef-section{background:var(--paper);border-radius:var(--radius-lg);border:1px solid var(--ink-100);overflow:hidden}.chef-section-head{border-bottom:1px solid var(--ink-100);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.chef-section-head h3{font-family:var(--serif);color:var(--wisteria-900);margin:0;font-size:18px}.chef-section-body{padding:8px 20px 20px}.order-card{background:var(--paper-cream);border-radius:var(--radius);border:1px solid var(--ink-100);cursor:pointer;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;margin-bottom:10px;padding:16px;transition:all .15s;display:grid}.order-card:hover{border-color:var(--wisteria-300);box-shadow:var(--shadow-sm)}.order-card.new{background:var(--wisteria-100);border-color:var(--wisteria-300);animation:2s ease-out 3 pulse-new}@keyframes pulse-new{0%,to{box-shadow:0 0 #9b73c466}50%{box-shadow:0 0 0 8px #9b73c400}}.order-badge{background:var(--wisteria-600);color:#fff;width:42px;height:42px;font-size:14px;font-weight:700;font-family:var(--serif);border-radius:12px;place-items:center;display:grid}.order-card.accepted .order-badge{background:var(--wisteria-800)}.order-card.cooking .order-badge{background:var(--warning)}.order-card.ready .order-badge{background:var(--success)}.order-info{min-width:0}.order-title{font-size:14px;font-weight:600}.order-meta{color:var(--ink-500);margin-top:2px;font-size:12px}.order-total{color:var(--wisteria-800);font-weight:700}.status-tag{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.status-tag.placed{background:var(--wisteria-100);color:var(--wisteria-700)}.status-tag.accepted{color:var(--wisteria-900);background:#e0d4f0}.status-tag.cooking{color:var(--warning);background:#fef1dd}.status-tag.ready{color:var(--success);background:#d7f0e0}.status-tag.delivered{background:var(--ink-100);color:var(--ink-500)}.order-detail{flex-direction:column;gap:20px;padding:22px;display:flex}.order-detail h2{font-family:var(--serif);color:var(--wisteria-900);margin:0}.detail-item{background:var(--wisteria-50);border-left:3px solid var(--wisteria-400);border-radius:12px;padding:14px}.detail-item-title{justify-content:space-between;font-size:15px;font-weight:700;display:flex}.detail-item-section{margin-top:10px;font-size:13px}.detail-item-section h5{color:var(--wisteria-700);text-transform:uppercase;letter-spacing:.05em;margin:0 0 4px;font-size:11px;font-weight:700}.detail-item-section pre{white-space:pre-wrap;word-wrap:break-word;color:var(--ink-700);margin:0;font-family:inherit;line-height:1.5}.action-row{gap:10px;display:flex}.action-row button{flex:1}.menu-editor-card{background:var(--paper-cream);border:1px solid var(--ink-100);border-radius:var(--radius);grid-template-columns:auto 1fr auto;align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;display:grid}.menu-editor-card.unavailable{opacity:.6}.menu-editor-emoji{background:var(--wisteria-100);border-radius:10px;place-items:center;width:42px;height:42px;font-size:24px;display:grid}.menu-editor-info{min-width:0}.menu-editor-name{font-size:14px;font-weight:600}.menu-editor-price{color:var(--wisteria-800);margin-top:2px;font-size:12px;font-weight:600}.menu-editor-actions{gap:4px;display:flex}.icon-btn{width:32px;height:32px;color:var(--ink-500);border-radius:8px;place-items:center;transition:all .15s;display:grid}.icon-btn:hover{background:var(--wisteria-100);color:var(--wisteria-800)}.two-col{grid-template-columns:1fr 1fr;gap:10px;display:grid}.toast-wrap{z-index:100;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;top:80px;right:20px}.toast{background:var(--wisteria-900);color:#fff;box-shadow:var(--shadow-lg);pointer-events:auto;border-radius:12px;align-items:center;gap:10px;max-width:340px;padding:12px 18px;font-size:14px;font-weight:500;animation:.25s ease-out toast-in;display:flex}.toast.success{background:var(--success)}.toast.warn{background:var(--warning)}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.modal{z-index:70;background:#1b132480;place-items:center;padding:20px;animation:.18s fade-in;display:grid;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--paper);border-radius:var(--radius-xl);width:min(560px,100%);max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-head{border-bottom:1px solid var(--ink-100);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-head h3{font-family:var(--serif);color:var(--wisteria-900);margin:0;font-size:22px}.modal-body{padding:20px 24px}.skeleton{background:linear-gradient(90deg, var(--wisteria-100), var(--wisteria-50), var(--wisteria-100));background-size:200% 100%;border-radius:12px;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.emoji-picker{background:var(--wisteria-50);border-radius:10px;grid-template-columns:repeat(8,1fr);gap:4px;margin-top:6px;padding:8px;display:grid}.emoji-picker button{aspect-ratio:1;border-radius:6px;font-size:22px;transition:background .12s}.emoji-picker button:hover,.emoji-picker button.selected{background:var(--wisteria-200)}.banner{background:var(--wisteria-100);border-left:3px solid var(--wisteria-500);color:var(--wisteria-900);border-radius:8px;align-items:center;gap:10px;margin:10px 20px;padding:12px 18px;font-size:13px;display:flex}.banner button{color:var(--wisteria-700);font-weight:700;text-decoration:underline}.level-card{background:linear-gradient(135deg, var(--wisteria-800), var(--wisteria-500));color:#fff;border-radius:var(--radius-lg);grid-template-columns:auto 1fr auto;align-items:center;gap:18px;margin-bottom:14px;padding:22px 26px;display:grid;box-shadow:0 12px 32px -8px #52377559}.level-icon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff38;border-radius:18px;place-items:center;width:64px;height:64px;font-size:34px;display:grid}.level-info{min-width:0}.level-label{text-transform:uppercase;letter-spacing:.1em;opacity:.8;font-size:11px;font-weight:700}.level-title{font-family:var(--serif);margin:2px 0 8px;font-size:28px;font-weight:700;line-height:1.1}.level-xp-bar{background:#fff3;border-radius:999px;height:10px;overflow:hidden}.level-xp-fill{background:linear-gradient(90deg,#fff6c2,#ffe272);border-radius:999px;height:100%;transition:width .6s cubic-bezier(.2,.8,.2,1);box-shadow:0 0 14px #ffe27299}.level-xp-text{opacity:.9;margin-top:4px;font-size:12px}.level-side{text-align:center;border-left:1px solid #ffffff40;padding-left:18px}.level-side .number{font-family:var(--serif);font-size:32px;font-weight:800;line-height:1}.level-side .caption{opacity:.85;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-size:10px}.streak-chip{background:#fff3;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;display:inline-flex}.streak-chip .flame{filter:drop-shadow(0 0 6px #ffb43ccc);font-size:18px;animation:1.4s ease-in-out infinite flame-flicker}@keyframes flame-flicker{0%,to{transform:scale(1)rotate(-2deg)}50%{transform:scale(1.12)rotate(3deg)}}.feed{flex-direction:column;gap:8px;max-height:420px;display:flex;overflow-y:auto}.feed-item{background:var(--paper-cream);border:1px solid var(--ink-100);border-left:3px solid var(--wisteria-500);border-radius:10px;padding:12px 14px}.feed-item.five{background:#fffbf0;border-left-color:#e8a93b}.feed-stars{letter-spacing:2px;color:#e8a93b;font-size:13px}.feed-note{color:var(--ink-900);margin-top:4px;font-size:14px;font-style:italic;line-height:1.4}.feed-meta{color:var(--ink-500);margin-top:4px;font-size:11px}.stars-input{justify-content:center;gap:8px;margin:10px 0;display:flex}.stars-input button{color:var(--ink-300);padding:4px;font-size:36px;transition:transform .12s,color .12s}.stars-input button.active{color:#e8a93b;text-shadow:0 0 12px #e8a93b80}.stars-input button:hover{transform:scale(1.18)}.special-ribbon{color:#fff;letter-spacing:.06em;text-transform:uppercase;z-index:2;background:linear-gradient(135deg,#e8a93b,#c08413);border-radius:0 4px 4px 0;padding:4px 12px 4px 10px;font-size:11px;font-weight:800;position:absolute;top:14px;left:-6px;box-shadow:0 4px 10px #c0841366}.special-ribbon:before{content:"";border-top:6px solid #7a5310;border-left:6px solid #0000;position:absolute;bottom:-6px;left:0}.special-hero{border-radius:var(--radius-xl);cursor:pointer;background:linear-gradient(135deg,#fffbf0,#fff3d6);border:1px solid #f4d48c;grid-column:1/-1;grid-template-columns:auto 1fr auto;align-items:center;gap:20px;margin-bottom:8px;padding:22px 26px;transition:transform .15s;display:grid;position:relative;overflow:hidden}.special-hero:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.special-hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 20% 20%,#ffd78c66,#0000 60%);position:absolute;inset:0}.special-hero-img{z-index:1;background:#ffffffb3;border-radius:20px;place-items:center;width:80px;height:80px;font-size:54px;display:grid;position:relative}.special-hero-body{z-index:1;min-width:0;position:relative}.special-label{text-transform:uppercase;letter-spacing:.1em;color:#b37b0d;font-size:11px;font-weight:800}.special-title{font-family:var(--serif);color:var(--wisteria-900);margin:2px 0 4px;font-size:26px;font-weight:700}.special-desc{color:var(--ink-700);font-size:14px;line-height:1.4}.special-cta{z-index:1;background:var(--wisteria-900);color:#fff;white-space:nowrap;border-radius:999px;padding:10px 18px;font-size:14px;font-weight:700;position:relative}.tab-card{background:linear-gradient(135deg, var(--paper), var(--wisteria-50));border:1px solid var(--wisteria-200);border-radius:var(--radius-lg);gap:14px;padding:22px;display:grid}.tab-amount{font-family:var(--serif);color:var(--wisteria-900);font-size:42px;font-weight:800;line-height:1}.tab-sub{color:var(--ink-500);font-size:13px}.tip-jar{border-radius:var(--radius);background:linear-gradient(135deg,#ffe8f5,#f9d9ff);border:1px solid #e9b8e1;gap:2px;padding:14px 18px;display:grid}.tip-jar-amount{font-family:var(--serif);color:#8a3c7d;font-size:24px;font-weight:800}.tip-jar-label{color:#8a3c7d;text-transform:uppercase;letter-spacing:.08em;opacity:.85;font-size:11px;font-weight:700}.invoice-page{max-width:520px;margin:0 auto;padding:24px 20px 100px}.invoice-card{background:var(--paper);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--ink-100);padding:32px 28px}.invoice-card h2{font-family:var(--serif);color:var(--wisteria-900);margin:0 0 4px}.invoice-total{font-family:var(--serif);color:var(--wisteria-900);text-align:center;margin:14px 0 6px;font-size:52px;font-weight:800}.zelle-box{background:var(--wisteria-50);border:1px dashed var(--wisteria-400);border-radius:var(--radius);text-align:center;margin:16px 0;padding:16px}.zelle-box .label{text-transform:uppercase;letter-spacing:.08em;color:var(--wisteria-700);font-size:11px;font-weight:700}.zelle-box .handle{font-family:var(--serif);color:var(--wisteria-900);-webkit-user-select:all;user-select:all;margin-top:4px;font-size:22px;font-weight:700}.piggy-wrap{transform-origin:50% 85%;width:100%;max-width:320px;margin:6px auto 4px;transition:transform .2s;display:block;position:relative}.piggy-wrap:hover{transform:rotate(-1deg)}.piggy-wrap.jiggling{animation:.85s cubic-bezier(.3,1.3,.4,1) piggy-jiggle}@keyframes piggy-jiggle{0%{transform:rotate(0)translateY(0)scale(1)}10%{transform:rotate(-5deg)translateY(-6px)scale(1.03)}22%{transform:rotate(4deg)translateY(-2px)scale(1.01)}34%{transform:rotate(-3deg)translateY(-4px)scale(1.02)}48%{transform:rotate(2deg)translateY(0)scale(1)}62%{transform:rotate(-1deg)translateY(-1px)}80%{transform:rotate(.5deg)translateY(0)}to{transform:rotate(0)}}.piggy-img{-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:auto;display:block}.piggy-balance{letter-spacing:-.02em;color:#fff;text-shadow:0 2px 4px #8b2b5573,0 0 1px #8b2b5599;pointer-events:none;white-space:nowrap;font-family:Fraunces,serif;font-weight:900;position:absolute;transform:translate(-50%,-50%)}.piggy-slot-glow{opacity:0;pointer-events:none;filter:blur(2px);background:radial-gradient(circle,#e8a93be6,#e8a93b00 70%);border-radius:4px;width:60px;height:14px;position:absolute;transform:translate(-50%,-50%)}.piggy-wrap.jiggling .piggy-slot-glow{animation:.5s ease-out slot-flash}@keyframes slot-flash{0%{opacity:0;transform:translate(-50%,-50%)scale(.6)}30%{opacity:1;transform:translate(-50%,-50%)scale(1.4)}to{opacity:0;transform:translate(-50%,-50%)scale(1)}}.coin-layer{pointer-events:none;z-index:180;position:fixed;inset:0}.coin{will-change:transform, opacity;filter:drop-shadow(0 4px 8px #c9931659);animation-name:coin-arc;animation-timing-function:cubic-bezier(.3,.05,.6,1);animation-fill-mode:forwards;display:inline-block;position:fixed}@keyframes coin-arc{0%{opacity:0;transform:translate(0)rotate(0)scale(.6)}12%{opacity:1;transform:translate(calc(var(--dx) * .12), calc(var(--peak) * .4)) rotate(calc(var(--rot) * .15)) scale(1)}55%{transform:translate(calc(var(--dx) * .55), var(--peak)) rotate(calc(var(--rot) * .6)) scale(1);opacity:1}to{transform:translate(var(--dx), var(--dy)) rotate(var(--rot)) scale(.5);opacity:0}}@keyframes tab-bump{0%,to{transform:scale(1)}30%{text-shadow:0 0 20px #c9931680;transform:scale(1.08)}60%{transform:scale(.97)}}.tab-amount.bump{animation:.6s ease-out tab-bump}.confetti-layer{pointer-events:none;z-index:200;position:fixed;inset:0;overflow:hidden}.confetti-piece{animation-name:confetti-fall;animation-timing-function:cubic-bezier(.2,.4,.6,1);animation-fill-mode:forwards;position:absolute;top:-40px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}to{transform:translateY(105vh) rotate(var(--rot,360deg));opacity:0}}.takeover{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:150;background:#1b1324bf;place-items:center;animation:.25s fade-in;display:grid;position:fixed;inset:0}.takeover-card{background:linear-gradient(135deg, var(--wisteria-500), var(--wisteria-800));color:#fff;text-align:center;border-radius:28px;max-width:420px;padding:40px 50px;animation:.5s cubic-bezier(.2,1.2,.4,1) takeover-pop;box-shadow:0 30px 60px #0000004d}@keyframes takeover-pop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.takeover-icon{margin-bottom:12px;font-size:80px}.takeover-title{font-family:var(--serif);font-size:34px;font-weight:800;line-height:1.1}.takeover-subtitle{opacity:.9;margin-top:8px;font-size:16px}@media (width<=600px){.topbar{padding:12px 16px}.hero{padding:24px 16px 20px}.menu{gap:12px;padding:20px 16px 120px}.chef{padding:14px}}
