:root{--bg: #f6f4ef;--panel: #fffdf9;--ink: #1f2328;--muted: #66717e;--line: #d9d2c7;--accent: #0e8a6a;--accent-2: #ea6a2a;--accent-3: #2065d1;--warn: #d95d39;--shadow: 0 10px 32px rgba(24, 33, 43, .08)}*{box-sizing:border-box}body{margin:0;padding:28px 20px 40px;font-family:IBM Plex Sans,sans-serif;color:var(--ink);background:radial-gradient(circle at 0% 0%,#ffd7b8,#ffd7b800 44%),radial-gradient(circle at 100% 100%,#c6f0df,#c6f0df00 45%),var(--bg);min-height:100vh}h1,h2,h3{font-family:Space Grotesk,sans-serif;margin:0;letter-spacing:-.02em}.bg-orb{position:fixed;z-index:-1;border-radius:50%;filter:blur(70px);opacity:.36}.orb-a{width:240px;height:240px;background:#ffb86f;top:-70px;right:-50px}.orb-b{width:220px;height:220px;background:#5bc7a4;bottom:-60px;left:-60px}.app-header{max-width:1150px;margin:0 auto 16px;padding:6px 4px;display:flex;align-items:center}.brand{display:flex;align-items:center;gap:12px}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#0e8a6a,#0f6e56);box-shadow:var(--shadow)}.brand-mark svg{width:22px;height:22px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.brand-text{display:flex;flex-direction:column;line-height:1.1}.brand-name{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:22px;color:var(--ink, #1b2a38)}.eyebrow{text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:var(--accent-3);margin:0 0 8px;font-weight:600}h1{font-size:clamp(30px,4vw,44px);margin-bottom:8px}.subhead{margin:0;color:var(--muted);max-width:620px}.header-actions{display:flex;gap:10px;align-items:center}.tab-nav{max-width:1150px;margin:0 auto 16px;display:flex;gap:8px;flex-wrap:wrap}body.admin-open .tab-nav{display:none}.tab{border:1px solid var(--line);border-radius:999px;padding:10px 16px;background:#fff;cursor:pointer;font-weight:600;color:#32404f;display:inline-flex;align-items:center;gap:8px}.tab svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.plan-badge{margin:2px 0 0;font-size:12px;color:var(--muted)}.plan-badge strong{color:var(--accent);font-weight:600}.install-banner{max-width:1150px;margin:0 auto 16px;display:flex;align-items:center;gap:12px;padding:12px 14px;background:linear-gradient(135deg,#eef6ff,#f6fbff);border:1px solid #cfe0f5;border-radius:14px;box-shadow:var(--shadow)}.install-banner[hidden]{display:none}.install-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;flex:none;border-radius:10px;background:#d6e6fb}.install-icon svg{width:18px;height:18px;fill:none;stroke:#14479c;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.install-copy{flex:1;font-size:14px;color:#25405f}.install-btn{background:linear-gradient(120deg,#2065d1,#14479c);flex:none}.install-dismiss{flex:none;border:none;background:transparent;color:#5c7693;font-size:22px;line-height:1;cursor:pointer;padding:0 4px}.tab.active{background:#1f2f3f;color:#fff;border-color:#1f2f3f}main{max-width:1150px;margin:0 auto}.panel{display:none;animation:rise .35s ease}.panel.active{display:block}@keyframes rise{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.panel-top{display:flex;justify-content:space-between;gap:12px;align-items:end;margin-bottom:14px}.panel-title{display:flex;flex-direction:column;gap:2px}.panel-eyebrow{text-transform:uppercase;font-size:11px;letter-spacing:.14em;font-weight:700;color:var(--accent)}.date-field{background:#fff;border:1px solid var(--line);border-radius:12px;padding:6px 10px;gap:2px}.date-field span{font-size:11px;color:var(--muted)}.date-field input{border:none;padding:2px 0;background:transparent}.date-field input:focus{outline:none}.inline-fields{display:flex;gap:12px;flex-wrap:wrap}label{display:grid;gap:6px;font-size:13px;font-weight:600;color:#45515e}input,select{border:1px solid #cfd6de;border-radius:10px;padding:10px 12px;font-family:inherit;font-size:14px;color:var(--ink);background:#fff}input:focus,select:focus{outline:2px solid #8cb6ff;border-color:#8cb6ff}.grid.two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:14px}.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px;box-shadow:var(--shadow)}.card h3{margin-bottom:12px}.macro-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}.hero-card{background:linear-gradient(160deg,#fff,#f4fbf8);padding:22px 18px}.rings{display:flex;flex-direction:column;align-items:center;gap:22px}.ring{transform:rotate(-90deg);width:100%;height:100%}.ring-track{fill:none;stroke:#e9eef0;stroke-width:9}.ring-fill{fill:none;stroke-width:9;stroke-linecap:round;transition:stroke-dashoffset .5s ease}.ring-fill.over{stroke:var(--warn)!important}.p-stroke{stroke:#10a37f}.c-stroke{stroke:#2f6fed}.f-stroke{stroke:#f59e0b}.cal-stroke{stroke:#7c5cff;stroke-width:10}.ring-hero{position:relative;width:168px;height:168px}.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ring-value{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:38px;line-height:1;color:var(--ink)}.ring-value.small{font-size:18px}.ring-sub{margin-top:4px;font-size:13px;font-weight:600;color:var(--muted)}.macro-rings{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%}.macro-ring{display:flex;flex-direction:column;align-items:center;text-align:center}.ring-wrap{position:relative;width:78px;height:78px;display:flex;align-items:center;justify-content:center}.ring-wrap .ring-value{position:absolute}.macro-cap{margin:8px 0 0;font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:6px}.macro-sub{margin:1px 0 0;font-size:12px;color:var(--muted)}.dot{width:9px;height:9px;border-radius:50%;display:inline-block}.dot.p{background:#10a37f}.dot.c{background:#2f6fed}.dot.f{background:#f59e0b}.ring-remaining{display:block;margin-top:2px;font-size:11px;font-weight:700;color:var(--accent)}.ring-remaining.over{color:var(--warn)}.ring-remaining.met{color:var(--accent)}.ring-sub .ring-remaining{font-size:12px}.water-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.water-count{font-size:13px;font-weight:700;color:var(--accent-3)}.water-track{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0}.water-pip{flex:1 1 auto;min-width:14px;height:14px;border-radius:5px;background:var(--surface-2, #eef1f5);border:1px solid var(--line);transition:background .18s ease,transform .12s ease}.water-pip.filled{background:var(--accent-3);border-color:var(--accent-3)}.water-pip.extra.filled{background:var(--accent-2);border-color:var(--accent-2)}.water-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.water-ml{font-size:13px;font-weight:600;color:var(--muted)}.water-btn{width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:var(--panel);color:var(--ink);font-size:22px;font-weight:700;line-height:1;cursor:pointer;transition:background .15s ease,transform .1s ease}.water-btn:hover:not(:disabled){background:var(--surface-2, #eef1f5)}.water-btn:active:not(:disabled){transform:scale(.94)}.water-btn:disabled{opacity:.4;cursor:not-allowed}.trend-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.trend-head h3,.trend-seg{margin:0}.trend-stats{display:flex;gap:10px;margin:14px 0 6px}.trend-stat{flex:1 1 0;display:flex;flex-direction:column;align-items:center;text-align:center;padding:10px 4px;background:var(--surface-2, #eef1f5);border-radius:10px}.trend-stat-val{font-size:18px;font-weight:800;color:var(--ink)}.trend-stat-lbl{font-size:11px;font-weight:600;color:var(--muted);margin-top:2px}.trend-chart{position:relative;height:110px;margin:14px 0 8px}.trend-goalline{position:absolute;left:0;right:0;height:0;border-top:2px dashed var(--accent);opacity:.5;pointer-events:none;z-index:1}.trend-bars{display:flex;align-items:flex-end;gap:3px;height:100%}.trend-bar-wrap{flex:1 1 0;display:flex;flex-direction:column;align-items:center;height:100%;min-width:0}.trend-bar-col{flex:1 1 auto;width:100%;display:flex;align-items:flex-end;justify-content:center}.trend-bar{width:100%;max-width:22px;min-height:2px;border-radius:4px 4px 2px 2px;background:var(--muted);transition:height .3s ease}.trend-bar.met{background:var(--accent)}.trend-bar.close{background:var(--accent-2)}.trend-bar.under{background:var(--warn)}.trend-bar.over{background:var(--accent-3)}.trend-bar.empty{background:var(--line);opacity:.5}.trend-bar-lbl{font-size:10px;font-weight:600;color:var(--muted);margin-top:4px}.trend-legend{margin:0;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:6px}.history-seg{display:flex;width:100%;margin:0 0 16px}.history-seg .seg-btn{flex:1 1 0;text-align:center}.history-list{display:flex;flex-direction:column;gap:8px}.history-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:#fff;font:inherit;color:var(--ink);cursor:pointer;transition:background .15s ease,transform .1s ease}.history-row:hover{background:var(--surface-2, #eef1f5)}.history-row:active{transform:scale(.99)}.history-row.static{cursor:default}.history-row.static:hover{background:#fff}.history-row.static:active{transform:none}.history-row-label{font-size:14px;font-weight:600}.history-row-stats{display:flex;align-items:center;gap:8px;flex-shrink:0}.history-stat{font-size:13px;font-weight:600;color:var(--muted)}.history-stat.muted{opacity:.7;font-weight:500}.history-badge{font-size:11px;font-weight:700;color:var(--accent-3);background:var(--surface-2, #eef1f5);border-radius:999px;padding:2px 8px}.month-nav-btn:disabled{opacity:.35;cursor:not-allowed}.btn{border:none;background:linear-gradient(120deg,#0e8a6a,#0f6e56);color:#fff;border-radius:10px;padding:10px 14px;font-weight:600;cursor:pointer}.btn.ghost{background:#fff;color:#1b2a38;border:1px solid var(--line)}.file-btn{position:relative;overflow:hidden}.file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}.meal-form{display:grid;grid-template-columns:2fr repeat(3,1fr) auto;gap:8px;margin-bottom:12px}.list{display:grid;gap:8px}.entry{display:flex;justify-content:space-between;align-items:center;border:1px solid #dce4ea;border-radius:10px;padding:10px;background:#fff}.entry .meta{color:var(--muted);font-size:13px}.entry-tag{display:inline-block;margin-left:6px;padding:1px 7px;border-radius:999px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#0f6e56;background:#d9f3e8;vertical-align:middle}.entry.from-meal{border-color:#c7e6d8;background:#f5fbf8}.link-btn{border:none;background:transparent;color:var(--warn);cursor:pointer;font-weight:600}.checklist{display:grid;gap:10px;margin:10px 0 14px}.check-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;border:1px solid #dde3ea;border-radius:10px;padding:10px;background:#fff}.check-row input{width:18px;height:18px;margin:0}.check-text.done{text-decoration:line-through;color:#7b8794}.qty{color:#4f6071;font-size:12px}.inline-form{display:grid;grid-template-columns:2fr 1fr auto;gap:8px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:700px}th,td{border-bottom:1px solid #dde3ea;padding:10px 8px;text-align:left}th{font-family:Space Grotesk,sans-serif;font-size:13px}td input{width:110px}.hint{margin:0;color:#66717e;font-size:13px}.lock-note{margin:0 0 14px;padding:9px 13px;border-radius:10px;background:#fef3c7;border:1px solid #fcd34d;color:#92600a;font-size:13px;font-weight:600}.lock-note[hidden]{display:none}button:disabled,input:disabled,select:disabled,textarea:disabled{opacity:.5;cursor:not-allowed}.day-type-row{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin:0 0 14px}.day-swap-btn{border:1px solid var(--line);background:#fff;color:var(--accent-3);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.day-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.day-reset-btn{border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:600;text-decoration:underline;cursor:pointer;padding:6px 4px}.day-reset-btn[hidden]{display:none}.day-swap-btn:active{transform:scale(.97)}.day-type-badge{display:inline-block;margin:0;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:700;color:#0f6e56;background:#d9f3e8;border:1px solid #aedfcd}.day-type-badge.rest{color:#9a5b16;background:#fdeccc;border-color:#f0d49a}.card-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.card-head h3{margin:0}.inline-label{flex-direction:row;align-items:center;gap:8px}.inline-label select,.inline-label input{font-weight:500}.meal-list{display:grid;gap:10px;margin-top:4px}.meal-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:start;border:1px solid #dde3ea;border-radius:12px;padding:12px;background:#fff}.meal-row.done{background:#f3f8f5;border-color:#c7e6d8}.meal-check{width:20px;height:20px;margin:2px 0 0}.meal-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.meal-slot{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:15px;color:var(--ink)}.meal-time{font-size:12px;font-weight:600;color:var(--accent-3)}.meal-desc{margin:4px 0 0;font-size:13px;line-height:1.45;color:#45515e}.meal-row.done .meal-slot,.meal-row.done .meal-desc{text-decoration:line-through;color:#8b96a2}.meal-del{font-size:12px}.meal-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.pack-chip{border:1px solid var(--line);background:#fff;color:var(--accent-3);border-radius:999px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.pack-chip.is-packed{background:#eaf2ff;border-color:#b9d2fb;color:#2f6fed}.meal-row.packed{border-color:#b9d2fb}.meal-row.packed.done{border-color:#c7e6d8}tr.low td{background:#fdeef0}.stock-flag{font-size:12px;font-weight:700;white-space:nowrap}.stock-flag.low{color:#c0392b}.stock-flag.ok{color:#15915f}.stock-flag.none{color:#aab3bd}.restock-summary{margin-top:12px}.restock-title{margin:0 0 4px;font-weight:700;color:#c0392b}.restock-list{margin:0 0 10px;font-size:13px;color:#45515e}.restock-ok{margin:8px 0 0;font-size:13px;color:#15915f;font-weight:600}.restock-btn{font-size:13px}.sync-fields{display:grid;gap:12px;margin:12px 0}.switch-row{display:flex;flex-direction:row;align-items:center;gap:10px;margin:10px 0 14px;font-weight:600;color:#45515e}.switch-row input{width:20px;height:20px;margin:0}.sync-actions{display:flex;flex-wrap:wrap;gap:10px;margin:12px 0}.sync-status{margin:6px 0 0;font-size:13px;color:var(--muted);font-weight:600}.sync-status.error{color:var(--warn)}.sync-help{margin-top:12px;font-size:13px;color:#45515e}.sync-help summary{cursor:pointer;font-weight:600;color:var(--accent-3)}.sync-help ol{margin:8px 0;padding-left:20px}.sync-help li{margin-bottom:4px}@media(max-width:920px){.app-header{flex-direction:row;align-items:center;gap:12px;width:100%}.grid.two{grid-template-columns:1fr}.meal-form{grid-template-columns:1fr 1fr}.inline-form{grid-template-columns:1fr}}@media(max-width:620px){html{height:100%}body{height:100dvh;min-height:0;display:flex;flex-direction:column;padding:14px 12px 0;overflow:hidden}.app-header{order:0}.install-banner{order:1}main{order:2;flex:1 1 auto;min-height:0;min-width:0;width:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:16px}.panel,.card{min-width:0;max-width:100%}h2{font-size:22px}.panel-top{align-items:center;margin-bottom:16px}.card{padding:16px 14px;border-radius:18px}.hero-card{padding:20px 14px}.ring-hero{width:150px;height:150px}.ring-value{font-size:34px}.app-header{padding:4px 2px;margin-bottom:14px}.install-banner{flex-wrap:wrap}.install-copy{flex:1 1 100%;order:3}.header-actions .btn{flex:1 1 auto;text-align:center}.macro-grid{grid-template-columns:1fr 1fr}.meal-form{grid-template-columns:1fr}.sync-actions .btn,.sync-actions .file-btn{flex:1 1 140px;text-align:center}.tab-nav{order:3;position:sticky;bottom:0;left:0;right:0;z-index:50;margin:0 -12px;display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:#fffffff2;backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:6px 4px calc(6px + env(safe-area-inset-bottom));box-shadow:0 -6px 20px #18212b14}.tab{flex-direction:column;gap:3px;border:none;border-radius:12px;padding:8px 1px;background:transparent;color:var(--muted);font-size:10px;font-weight:600;min-width:0;overflow:hidden}.tab span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.tab svg{width:20px;height:20px}.tab.active{background:#eef6f2;color:var(--accent);border-color:transparent}}.month-nav{display:flex;align-items:center;gap:10px}.month-nav-btn{width:34px;height:34px;border:1px solid var(--line);background:#fff;border-radius:10px;font-size:18px;line-height:1;color:var(--accent-3, #32404f);cursor:pointer}.month-label{min-width:130px;text-align:center;font-weight:700;font-size:15px}.month-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}.stat-tile{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow)}.stat-value{font-size:22px;font-weight:700;color:var(--accent);line-height:1.1}.stat-label{font-size:12px;font-weight:600;color:#32404f}.stat-sub{font-size:11px;color:var(--muted)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:8px}.cal-weekdays span{text-align:center;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-cell{position:relative;aspect-ratio:1 / 1;border:1px solid var(--line);border-radius:10px;background:#fff;padding:5px 4px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;cursor:pointer;font:inherit;overflow:hidden}.cal-cell.empty{border:none;background:transparent;cursor:default}.cal-day{font-size:13px;font-weight:700;color:#32404f}.cal-dot{position:absolute;top:7px;right:7px;width:8px;height:8px;border-radius:50%}.cal-cell.train .cal-dot{background:var(--accent, #10a37f)}.cal-cell.rest .cal-dot{background:#c2ccd6}.cal-cell.train{background:#f1faf6;border-color:#cdeadd}.cal-macro{margin-top:auto;font-size:11px;font-weight:700;color:#2f6fed}.cal-cell.logged{box-shadow:inset 0 -3px #2f6fed}.cal-cell.today{outline:2px solid var(--accent, #10a37f);outline-offset:-2px}.cal-cell.swapped .cal-day:after{content:"•";color:#f59e0b;margin-left:2px}.cal-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}.legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.train{background:var(--accent, #10a37f)}.legend-dot.rest{background:#c2ccd6}.legend-dot.logged{background:#2f6fed}@media(max-width:620px){.month-summary{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:19px}.cal-grid,.cal-weekdays{gap:4px}.cal-cell{padding:4px 2px;border-radius:8px}.cal-day{font-size:12px}.cal-macro{font-size:9px}}.date-stepper{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap}.step-btn{width:38px;height:38px;border:1px solid var(--line);background:#fff;border-radius:12px;font-size:22px;line-height:1;color:var(--accent);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .08s ease,background .15s ease,box-shadow .15s ease;box-shadow:var(--shadow)}.step-btn:hover{background:#f1faf6}.step-btn:active{transform:scale(.92)}.date-stepper .date-field{display:inline-flex;align-items:center;padding:8px 10px}.today-btn{border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:999px;padding:7px 14px;font-size:12px;font-weight:700;cursor:pointer;transition:transform .08s ease,opacity .15s ease}.today-btn:active{transform:scale(.94)}.quick-add-head{display:flex;align-items:center;margin-bottom:8px}.quick-add-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.quick-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.quick-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid #cdeadd;background:#f1faf6;color:var(--ink);border-radius:999px;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:transform .08s ease,box-shadow .15s ease,background .15s ease;max-width:100%}.quick-chip:hover{background:#e6f5ee;box-shadow:var(--shadow)}.quick-chip:active{transform:scale(.95)}.quick-chip .quick-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.quick-chip .quick-macro{font-size:11px;font-weight:700;color:var(--accent);background:#fff;border-radius:999px;padding:2px 8px;flex:none}.quick-chip:before{content:"+";font-weight:700;color:var(--accent);font-size:15px;line-height:1}.ring-fill.close{filter:drop-shadow(0 0 3px rgba(16,163,127,.35))}.ring-fill.met{stroke:var(--accent)!important;filter:drop-shadow(0 0 6px rgba(14,138,106,.55))}.ring-fill.pop{animation:ringPop .6s ease}@keyframes ringPop{0%{transform:rotate(-90deg) scale(1)}40%{transform:rotate(-90deg) scale(1.06)}to{transform:rotate(-90deg) scale(1)}}.toast-host{position:fixed;left:0;right:0;bottom:calc(84px + env(safe-area-inset-bottom));display:flex;justify-content:center;pointer-events:none;z-index:200;padding:0 16px}.toast{pointer-events:auto;display:inline-flex;align-items:center;gap:14px;max-width:420px;background:#1f2328;color:#fff;border-radius:14px;padding:12px 16px;font-size:14px;font-weight:600;box-shadow:0 12px 34px #18212b52;opacity:0;transform:translateY(14px);transition:opacity .2s ease,transform .2s ease}.toast.show{opacity:1;transform:translateY(0)}.toast-msg{overflow:hidden;text-overflow:ellipsis}.toast-action{flex:none;border:none;background:transparent;color:#7fe0c0;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;padding:2px 4px}@media(min-width:621px){.toast-host{bottom:28px}}@media(prefers-reduced-motion:reduce){.ring-fill.pop{animation:none}.toast{transition:opacity .2s ease;transform:none}}.icon-btn{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;box-shadow:var(--shadow)}.icon-btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.icon-btn:hover{color:var(--accent);border-color:var(--accent)}#tab-admin .card{margin-bottom:14px}.admin-grid{display:grid;gap:12px;margin:10px 0 14px}.admin-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.admin-grid label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:#45515e}.admin-rows{display:grid;gap:8px;margin:10px 0 14px}.admin-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;border:1px solid #dde3ea;border-radius:10px;padding:8px;background:#fff}.admin-row input,.admin-row select{padding:8px 10px;font-size:13px;min-width:0}.admin-row .f-slot{flex:1 1 110px}.admin-row .f-group{flex:0 1 110px}.admin-row .f-time{flex:0 1 100px}.admin-row .f-num{flex:0 1 60px;width:60px}.admin-row .f-item{flex:2 1 100%}.admin-row .f-qty{flex:1 1 120px}.admin-del{margin-left:auto;border:none;background:#f5e1e1;color:#b3261e;width:30px;height:30px;border-radius:8px;font-size:18px;line-height:1;cursor:pointer;flex:0 0 auto}.admin-del:hover{background:#f0c9c9}.admin-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.seg{display:inline-flex;gap:4px;padding:4px;border:1px solid var(--line);border-radius:12px;background:#f4f1ec;margin:4px 0 12px}.seg-btn{border:none;background:transparent;padding:7px 14px;border-radius:9px;font-weight:600;font-size:13px;color:var(--muted);cursor:pointer}.seg-btn.active{background:#fff;color:var(--accent);box-shadow:var(--shadow)}.danger-card{border-color:#f0d2d2;background:#fdf6f6}.btn.danger{background:linear-gradient(120deg,#d6453b,#b3261e)}.admin-subnav{display:flex;gap:4px;padding:4px;margin:0 0 18px;background:var(--surface-2, #eef1f5);border:1px solid var(--line);border-radius:12px;position:sticky;top:0;z-index:20}.admin-subtab{flex:1 1 0;padding:9px 10px;border:none;border-radius:9px;background:transparent;color:var(--muted);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.admin-subtab:hover{color:var(--ink)}.admin-subtab.active{background:#fff;color:var(--accent);box-shadow:0 1px 3px #18212b1f}.admin-subpanel[hidden]{display:none}@media(max-width:620px){.admin-grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-row .f-slot,.admin-row .f-group,.admin-row .f-time{flex:1 1 calc(50% - 6px)}.admin-actions .btn{flex:1 1 140px;text-align:center}}.modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;background:#1418218c;backdrop-filter:blur(2px);animation:modalFade .18s ease}.modal-overlay[hidden]{display:none}.modal-card{width:100%;max-width:420px;background:#fff;border-radius:18px;padding:22px 22px 18px;box-shadow:0 18px 50px #14182147;animation:modalRise .2s ease}.modal-card h3{margin:0 0 10px;font-size:1.15rem}.modal-body{margin:0 0 18px;color:#4a5160;line-height:1.5;font-size:.95rem}.modal-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.modal-actions .btn{flex:0 1 auto}@keyframes modalFade{0%{opacity:0}}@keyframes modalRise{0%{opacity:0;transform:translateY(12px)}}@media(max-width:620px){.modal-actions .btn{flex:1 1 140px;text-align:center}}@media(prefers-reduced-motion:reduce){.modal-overlay,.modal-card{animation:none}}
