/*! tailwindcss v4.2.4 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--radius-sm:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{-webkit-tap-highlight-color:transparent;height:100%}body{color:#1c1c1e;background:#e5e5ea;justify-content:center;align-items:center;font-family:DM Sans,Noto Sans TC,sans-serif;display:flex;overflow:hidden}button{cursor:pointer;border:none;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{display:none}*{scrollbar-width:none}#root{justify-content:center;align-items:center;width:100%;height:100svh;display:flex}@media (width>=768px){body{background:#f2f2f7;align-items:stretch;overflow:auto}#root{justify-content:stretch;align-items:stretch;height:100svh}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}.st-root{--accent:#c8952a;--accent-dim:#c8952a1f;--accent-border:#c8952a4d;--glass:#fff;--glass-hover:#0000000a;--border:#00000014;--muted:#8e8e93;--success:#34c759;--danger:#ff3b30;--warning:#ff9500;--info:#007aff;--purple:#af52de;--radius:14px;--radius-sm:10px;--radius-lg:20px}@keyframes st-fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes st-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes st-slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes st-toastIn{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.st-root{color:#1c1c1e;background:#f2f2f7;flex-direction:column;width:100%;max-width:420px;height:100svh;font-family:-apple-system,BlinkMacSystemFont,Helvetica Neue,PingFang TC,sans-serif;display:flex;position:relative;overflow:hidden}.status-bar{color:#1c1c1e;z-index:10;background:#f2f2f7;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 22px 4px;font-size:14px;font-weight:700;display:flex;position:relative}.sb-right{align-items:center;gap:8px;display:flex}.signal{align-items:flex-end;gap:2px;display:flex}.signal span{background:#1c1c1e;border-radius:1px;width:3px}.batt{border:1.5px solid #00000059;border-radius:3px;align-items:center;width:24px;height:12px;padding:2px;display:flex;position:relative}.batt:after{content:"";background:#00000059;border-radius:0 1px 1px 0;width:2px;height:5px;position:absolute;top:50%;right:-4px;transform:translateY(-50%)}.batt-fill{background:#1c1c1e;border-radius:1px;flex:1;height:100%}.app-header{z-index:10;background:#f2f2f7;border-bottom:1px solid #00000014;flex-shrink:0;align-items:center;gap:10px;padding:4px 16px 12px;display:flex;position:relative}.logo{background:#c8952a1f;border:1px solid #c8952a40;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex;position:relative}.logo-badge{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:8px;display:flex;position:absolute;bottom:-3px;right:-3px}.app-name{color:#1c1c1e;letter-spacing:-.3px;flex:1;font-size:17px;font-weight:700}.header-actions{align-items:center;gap:6px;display:flex}.bell-btn{color:#1c1c1e;background:#0000000d;border:1px solid #0000001a;border-radius:9px;justify-content:center;align-items:center;padding:6px 8px;display:flex;position:relative}.bell-btn svg{stroke:#3c3c43;fill:none;stroke-width:2px;width:16px;height:16px}.bell-dot{background:var(--danger);border:1.5px solid #f2f2f7;border-radius:50%;width:8px;height:8px;position:absolute;top:3px;right:3px}.logout-btn{color:#3c3c43;background:#0000000d;border:1px solid #0000001a;border-radius:8px;padding:5px 10px;font-size:12px;font-weight:600}.logout-btn:hover{background:#0000001a}.switch-btn{color:var(--accent);cursor:pointer;white-space:nowrap;background:#c8952a1a;border:1px solid #c8952a4d;border-radius:8px;padding:5px 12px;font-size:13px;font-weight:600}.switch-btn:hover{background:#c8952a2e}.role-avatar{background:linear-gradient(135deg, var(--accent), #a07010);color:#fff;border:2px solid #c8952a4d;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.content{z-index:10;background:#f2f2f7;flex:1;padding:0 14px 10px;position:relative;overflow-y:auto}.tab-bar{z-index:50;padding:8px 4px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid #0000001a;flex-shrink:0;display:flex;position:relative;overflow-x:auto}.tab-btn{background:0 0;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:4px;min-width:60px;padding:4px 2px;transition:all .18s;display:flex;position:relative}.tab-btn .tab-icon{border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;transition:all .18s;display:flex}.tab-btn svg{stroke:#8e8e93;fill:none;stroke-width:1.8px;width:20px;height:20px;transition:all .18s;display:block}.tab-label{color:#8e8e93;letter-spacing:.2px;font-size:10px;font-weight:500;transition:all .18s}.tab-btn.active .tab-icon{background:#c8952a1a}.tab-btn.active svg{stroke:var(--accent);stroke-width:2.2px}.tab-btn.active .tab-label{color:var(--accent);font-weight:700}.tab-btn.active:after{content:"";background:var(--accent);border-radius:3px 3px 0 0;width:20px;height:3px;position:absolute;bottom:-2px;left:50%;transform:translate(-50%)}.page{padding-top:2px;display:none}.page.active{animation:.22s both st-fadeUp;display:block}.section-title{color:#1c1c1e;align-items:center;gap:6px;margin:14px 0 8px;font-size:16px;font-weight:700;display:flex}.section-title svg{stroke:#8e8e93;fill:none;stroke-width:2px;width:16px;height:16px}.card{border-radius:var(--radius);background:#fff;border:1px solid #00000012;margin-bottom:8px;padding:12px 14px;box-shadow:0 1px 3px #0000000f}.card-accent{background:#c8952a0d;border-color:#c8952a33}.badge{border-radius:20px;align-items:center;padding:3px 9px;font-size:10px;font-weight:700;display:inline-flex}.badge-pending{color:#ff9500;background:#ff950026}.badge-confirmed{color:#34c759;background:#34c75926}.badge-completed{color:#8e8e93;background:#00000012}.badge-cancelled{color:#ff3b30;background:#ff3b301f}.grid-2{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:8px;display:grid}.stat-card{border-radius:var(--radius);background:#fff;border:1px solid #00000012;padding:12px 14px;box-shadow:0 1px 3px #0000000f}.stat-label{color:#8e8e93;margin-bottom:4px;font-size:12px}.stat-value{font-size:22px;font-weight:700}.stat-value-sm{font-size:18px;font-weight:800}.c-green{color:var(--success)}.c-red{color:var(--danger)}.c-gold{color:var(--accent)}.c-blue{color:var(--info)}.c-orange{color:var(--warning)}.c-purple{color:var(--purple)}.res-row{align-items:flex-start;gap:10px;display:flex}.res-time-block{text-align:center;background:#c8952a1a;border-radius:10px;flex-shrink:0;min-width:52px;padding:8px 10px}.res-time{color:var(--accent);font-size:15px;font-weight:700}.res-sub{color:#c8952ab3;margin-top:1px;font-size:10px}.res-name{color:#1c1c1e;font-size:14px;font-weight:600}.res-detail{color:#8e8e93;margin-top:2px;font-size:12px}.tag-row{flex-wrap:wrap;gap:4px;margin-top:6px;display:flex}.tag{border-radius:6px;align-items:center;padding:2px 7px;font-size:10px;font-weight:700;line-height:1.4;display:inline-flex}.tag-birthday{color:#ec4899;background:#ec48991f}.tag-business{color:#007aff;background:#007aff1a}.tag-vegan{color:#34c759;background:#34c7591f}.tag-vip{color:var(--accent);background:#c8952a26}.tag-family{color:#ff9500;background:#ff95001f}.tag-allergy{color:#ff3b30;background:#ff3b301f}.tag-custom{color:#af52de;background:#af52de1f}.deposit-chip{color:#34c759;background:#34c7591a;border:1px solid #34c75940;border-radius:6px;align-items:center;gap:3px;padding:2px 7px;font-size:10px;font-weight:700;display:inline-flex}.cust-row{align-items:center;gap:10px;display:flex}.cust-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:flex}.cust-name{color:#1c1c1e;font-size:14px;font-weight:600}.cust-meta{color:#8e8e93;margin-top:2px;font-size:12px}.tx-row{align-items:center;gap:10px;display:flex}.tx-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.tx-icon svg{stroke:currentColor;fill:none;stroke-width:2.5px;width:16px;height:16px}.tx-icon.inc{color:var(--success);background:#34c7591f}.tx-icon.exp{color:var(--danger);background:#ff3b301a}.tx-desc{color:#1c1c1e;font-size:13px;font-weight:500}.tx-date{color:#8e8e93;font-size:11px}.tx-amount{flex-shrink:0;font-size:14px;font-weight:700}.ann-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.ann-dot{width:30px;height:30px;color:var(--accent);background:#c8952a1a;border:1px solid #c8952a40;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.ann-author{color:#1c1c1e;font-size:13px;font-weight:600}.ann-time{color:#8e8e93;font-size:11px}.ann-body{color:#3c3c43;white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.55}.ann-pinned{background:#c8952a0d;border-color:#c8952a4d}.ann-cat{text-transform:uppercase;letter-spacing:.5px;border-radius:5px;padding:2px 7px;font-size:9px;font-weight:800}.ann-cat-normal{color:#8e8e93;background:#00000012}.ann-cat-important{color:#ff3b30;background:#ff3b301f}.ann-cat-reminder{color:#007aff;background:#007aff1a}.ann-cat-event{color:#af52de;background:#af52de1f}.area-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.area-card{border-radius:var(--radius-sm);cursor:pointer;background:#fff;border:1px solid #00000012;padding:12px;transition:all .18s;box-shadow:0 1px 3px #0000000d}.area-card.sel,.area-card:hover{background:#c8952a12;border-color:#c8952a66}.area-name{color:#1c1c1e;font-size:13px;font-weight:700}.area-cap{color:#8e8e93;margin-top:2px;font-size:11px}.seat-dots{flex-wrap:wrap;gap:3px;margin-top:8px;display:flex}.dot{border-radius:50%;width:9px;height:9px}.dot-free{background:#0000001f}.dot-occ{background:var(--info)}.dot-res{background:var(--warning)}.pills{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.pill{border-radius:20px;align-items:center;gap:4px;padding:5px 12px;font-size:11px;font-weight:600;display:inline-flex}.pill-blue{color:#007aff;background:#007aff1a}.pill-orange{color:#ff9500;background:#ff95001f}.pill-dim{color:#8e8e93;background:#00000012}.pill-green{color:#34c759;background:#34c7591f}.pill-gold{color:var(--accent);background:#c8952a1f}.pill-red{color:#ff3b30;background:#ff3b301a}.add-btn{border-radius:var(--radius);width:100%;color:var(--accent);background:#c8952a12;border:1.5px dashed #c8952a66;justify-content:center;align-items:center;gap:7px;margin-top:4px;padding:13px;font-size:13px;font-weight:700;transition:all .18s;display:flex}.add-btn:hover{background:#c8952a24}.add-btn svg{stroke:currentColor;fill:none;stroke-width:2.8px;width:15px;height:15px}.bar-row{align-items:center;gap:8px;margin-bottom:7px;display:flex}.bar-lbl{color:#8e8e93;text-align:right;flex-shrink:0;width:34px;font-size:11px}.bar-track{background:#00000012;border-radius:4px;flex:1;height:20px;position:relative;overflow:hidden}.bar-fill{border-radius:4px;justify-content:flex-end;align-items:center;min-width:18px;height:100%;padding-right:7px;font-size:10px;font-weight:700;display:flex}.bar-inc{color:#fff;background:linear-gradient(90deg,#1a9e75,#34c759)}.bar-exp{color:#fff;background:linear-gradient(90deg,#cc1a1a,#ff3b30)}.bar-res{color:#fff;background:linear-gradient(90deg,#a07010,#c8952a)}.hour-row{align-items:center;gap:8px;margin-bottom:7px;display:flex}.hour-lbl{color:var(--accent);flex-shrink:0;width:42px;font-size:12px;font-weight:600}.hour-lbl.dim{color:#8e8e93}.hour-track{background:#00000012;border-radius:4px;flex:1;height:16px;overflow:hidden}.hour-cnt{color:#8e8e93;text-align:right;flex-shrink:0;width:36px;font-size:11px}.podium{gap:6px;display:flex}.podium-item{border-radius:var(--radius-sm);text-align:center;background:#c8952a0d;border:1px solid #c8952a26;flex:1;padding:10px 8px}.date-strip{-webkit-overflow-scrolling:touch;gap:6px;margin-bottom:4px;padding:2px 0 10px;display:flex;overflow-x:auto}.date-chip{cursor:pointer;background:#fff;border:1px solid #00000014;border-radius:14px;flex-direction:column;flex-shrink:0;align-items:center;min-width:52px;padding:10px 6px;transition:all .18s;display:flex;position:relative;box-shadow:0 1px 2px #0000000d}.date-chip:hover{background:#0000000a}.date-chip.active{background:#c8952a24;border-color:#c8952a80}.date-chip .dc-weekday{color:#8e8e93;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;font-size:10px;font-weight:600}.date-chip.active .dc-weekday{color:#c8952acc}.date-chip .dc-day{color:#3c3c43;font-size:18px;font-weight:800;line-height:1}.date-chip.active .dc-day{color:var(--accent)}.date-chip .dc-dot{background:0 0;border-radius:50%;width:5px;height:5px;margin-top:5px}.date-chip.has-res .dc-dot{background:#0003}.date-chip.active.has-res .dc-dot{background:var(--accent)}.date-chip .dc-month{color:#8e8e93;margin-top:2px;font-size:9px;font-weight:500}.date-chip.active .dc-month{color:#c8952ab3}.date-chip.today-chip .dc-day{color:#1c1c1e}.date-chip.today-chip:not(.active){border-color:#0003}.date-chip .dc-count{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:13px;height:13px;font-size:8px;font-weight:800;display:flex;position:absolute;top:3px;right:3px}.fc-item{border-bottom:1px solid #00000012;align-items:center;gap:10px;padding:10px 0;display:flex}.fc-item:last-child{border-bottom:none;padding-bottom:0}.fc-item:first-child{padding-top:0}.fc-tag{text-transform:uppercase;letter-spacing:.4px;border-radius:6px;flex-shrink:0;padding:3px 7px;font-size:9px;font-weight:700}.fc-tag-rent{color:#8b5cf6;background:#8b5cf61f}.fc-tag-salary{color:#007aff;background:#007aff1a}.fc-tag-util{color:#34c759;background:#34c7591f}.fc-tag-insure{color:#ff9500;background:#ff95001f}.fc-tag-other{color:#8e8e93;background:#00000012}.fc-name{color:#1c1c1e;flex:1;font-size:13px;font-weight:600}.fc-note{color:#8e8e93;margin-top:2px;font-size:11px}.fc-amount{color:var(--danger);flex-shrink:0;font-size:14px;font-weight:700}.fc-edit-btn{color:#8e8e93;background:0 0;border:1px solid #0000001f;border-radius:7px;flex-shrink:0;padding:4px 8px;font-size:11px;font-weight:600;transition:all .15s}.fc-edit-btn:hover{color:#1c1c1e;background:#0000000d}.fc-total-row{border-top:1px solid #00000014;justify-content:space-between;align-items:center;margin-top:4px;padding:10px 0 0;display:flex}.fc-total-label{color:#8e8e93;text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.fc-total-value{color:var(--danger);font-size:18px;font-weight:800}.cat-grid{grid-template-columns:1fr 1fr;gap:6px;margin-top:2px;display:grid}.cat-chip{text-align:center;cursor:pointer;color:#8e8e93;background:#0000000a;border:1px solid #00000014;border-radius:9px;padding:8px 10px;font-size:12px;font-weight:700;transition:all .15s}.cat-chip.sel-rent{color:#8b5cf6;background:#8b5cf626;border-color:#8b5cf666}.cat-chip.sel-salary{color:#007aff;background:#007aff1f;border-color:#007aff66}.cat-chip.sel-util{color:#34c759;background:#34c75926;border-color:#34c75966}.cat-chip.sel-insure{color:#ff9500;background:#ff950026;border-color:#ff950066}.cat-chip.sel-other,.cat-chip.sel-normal{color:#3c3c43;background:#00000017;border-color:#0003}.cat-chip.sel-important{color:#ff3b30;background:#ff3b301f;border-color:#ff3b3066}.cat-chip.sel-reminder{color:#007aff;background:#007aff1f;border-color:#007aff66}.cat-chip.sel-event{color:#af52de;background:#af52de1f;border-color:#af52de66}.divider{background:#00000014;height:1px;margin:10px 0}.form-group{min-width:0;margin-bottom:12px;overflow:hidden}.form-label{color:#8e8e93;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px;font-size:11px;font-weight:700;display:block}.form-input{box-sizing:border-box;border-radius:var(--radius-sm);color:#1c1c1e;appearance:none;background:#0000000a;border:1px solid #0000001a;outline:none;width:100%;min-width:0;max-width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s;display:block}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #c8952a26}.form-input::placeholder{color:#c7c7cc}select.form-input{text-overflow:ellipsis;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238E8E93' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}select.form-input option{color:#1c1c1e;background:#fff}.form-row{grid-template-columns:1fr;gap:8px;display:grid}.overlay{z-index:200;background:#0006;flex-direction:column;justify-content:flex-end;animation:.2s st-fadeIn;display:flex;position:absolute;inset:0}.drawer{padding:20px 18px;padding-bottom:calc(20px + env(safe-area-inset-bottom,0px));box-sizing:border-box;background:#fff;border-top:1px solid #0000001a;border-radius:20px 20px 0 0;width:100%;max-height:88vh;animation:.25s st-slideUp;overflow:hidden auto}.drawer-handle{background:#00000026;border-radius:2px;width:36px;height:4px;margin:0 auto 18px}.drawer-title{color:#1c1c1e;margin-bottom:16px;font-size:17px;font-weight:700}.btn-row{gap:8px;margin-top:14px;display:flex}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);flex:1;padding:12px;font-size:14px;font-weight:700;transition:opacity .18s}.btn-primary:hover{opacity:.9}.btn-secondary{color:#1c1c1e;border-radius:var(--radius-sm);background:#0000000f;border:1px solid #0000001f;flex:1;padding:12px;font-size:14px;font-weight:600;transition:background .18s}.btn-secondary:hover{background:#0000001a}.btn-danger{color:#ff3b30;background:#ff3b3014;border:1px solid #ff3b304d;border-radius:10px;padding:10px;font-size:13px;font-weight:700}.login-logo{margin-bottom:12px;font-size:52px}.login-title{color:#fff;letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:800}.login-sub{color:#ffffff8c;margin-bottom:40px;font-size:14px}.login-form{width:100%;max-width:340px}.login-input{color:#fff;background:#ffffff14;border:1px solid #ffffff2e;border-radius:14px;outline:none;width:100%;margin-bottom:12px;padding:14px 16px;font-size:15px}.login-input:focus{border-color:#c8952a}.login-input::placeholder{color:#ffffff4d}.login-btn{color:#fff;cursor:pointer;background:#c8952a;border-radius:14px;width:100%;margin-top:4px;padding:15px;font-size:16px;font-weight:800;transition:transform .18s;box-shadow:0 4px 20px #c8952a59}.login-btn:active{transform:scale(.98)}.login-roles{gap:8px;width:100%;max-width:340px;margin-top:24px;display:flex}.role-chip{text-align:center;cursor:pointer;background:#ffffff12;border:1px solid #ffffff2e;border-radius:10px;flex:1;padding:10px;transition:all .18s}.role-chip.sel{background:#c8952a26;border-color:#c8952a80}.role-chip-name{color:#fff;font-size:14px;font-weight:700}.role-chip-desc{color:#ffffff8c;margin-top:2px;font-size:11px}.login-hint{color:#ffffff73;text-align:center;margin-top:14px;font-size:12px}.dash-card{background:#fff;border:1px solid #c8952a33;border-radius:16px;margin-bottom:12px;padding:14px;position:relative;overflow:hidden;box-shadow:0 2px 8px #c8952a14}.dash-title{color:#1c1c1e;align-items:center;gap:6px;margin-bottom:10px;font-size:14px;font-weight:800;display:flex}.dash-title .d-date{color:#8e8e93;margin-left:auto;font-size:12px;font-weight:500}.dash-stats{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.dash-stat{text-align:center;background:#f2f2f7;border:1px solid #00000012;border-radius:10px;padding:8px 6px}.dash-stat-val{font-size:18px;font-weight:800;line-height:1.1}.dash-stat-lbl{color:#8e8e93;margin-top:2px;font-size:10px;font-weight:600}.dash-next{background:#0000000a;border-radius:10px;align-items:center;gap:8px;margin-top:10px;padding:9px 11px;font-size:12px;display:flex}.dash-next-time{color:var(--accent);font-size:14px;font-weight:800}.dash-next-label{color:#3c3c43;font-weight:600}.dash-next-dim{color:#8e8e93}.notif-item{border-bottom:1px solid #00000012;align-items:flex-start;gap:10px;padding:10px 0;display:flex}.notif-item:last-child{border-bottom:none}.notif-icon{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.notif-icon.warn{color:#ff9500;background:#ff95001f}.notif-icon.info{color:#007aff;background:#007aff1a}.notif-icon.alert{color:#ff3b30;background:#ff3b301a}.notif-icon.ok{color:#34c759;background:#34c7591f}.notif-body{flex:1;min-width:0}.notif-title{color:#1c1c1e;font-size:13px;font-weight:700}.notif-detail{color:#8e8e93;margin-top:2px;font-size:11px}.notif-action{color:var(--accent);background:#c8952a1a;border:1px solid #c8952a4d;border-radius:7px;margin-top:6px;padding:3px 8px;font-size:10px;font-weight:700}.settings-row{border-bottom:1px solid #00000012;align-items:center;gap:10px;padding:12px 0;display:flex}.settings-row:last-child{border-bottom:none}.settings-icon{width:36px;height:36px;color:var(--accent);background:#c8952a1a;border:1px solid #c8952a33;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;display:flex}.settings-title{color:#1c1c1e;font-size:13px;font-weight:700}.settings-sub{color:#8e8e93;margin-top:2px;font-size:11px}.settings-chevron{color:#c7c7cc;font-size:18px}.trend-legend{flex-wrap:wrap;gap:14px;margin-bottom:10px;display:flex}.trend-leg-item{color:#8e8e93;align-items:center;gap:5px;font-size:11px;display:flex}.trend-leg-dot{border-radius:2px;width:10px;height:4px}.donut-wrap{align-items:center;gap:14px;display:flex}.donut-svg{flex-shrink:0;width:110px;height:110px}.donut-legend{flex-direction:column;flex:1;gap:6px;display:flex}.donut-leg{align-items:center;gap:6px;font-size:11px;display:flex}.donut-leg-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.donut-leg-lbl{color:#3c3c43;flex:1;font-weight:600}.donut-leg-val{color:#8e8e93}.kpi-mini{background:#fff;border:1px solid #00000012;border-radius:12px;padding:12px;box-shadow:0 1px 3px #0000000d}.kpi-mini-lbl{color:#8e8e93;font-size:11px;font-weight:600}.kpi-mini-val{margin-top:4px;font-size:20px;font-weight:800}.kpi-mini-delta{margin-top:3px;font-size:10px;font-weight:700}.filter-row{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.filter-chip{color:#8e8e93;cursor:pointer;background:#fff;border:1px solid #0000001a;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:600;box-shadow:0 1px 2px #0000000d}.filter-chip.active{color:var(--accent);background:#c8952a1f;border-color:#c8952a66}.search-box{margin-bottom:10px;position:relative}.search-box input{color:#1c1c1e;background:#fff;border:1px solid #0000001a;border-radius:12px;outline:none;width:100%;padding:11px 12px 11px 36px;font-size:14px;box-shadow:0 1px 3px #0000000f}.search-box input:focus{border-color:var(--accent)}.search-box input::placeholder{color:#c7c7cc}.search-box:before{content:"🔍";opacity:.5;font-size:13px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.st-toast{color:#fff;z-index:500;pointer-events:none;white-space:nowrap;background:#1c1c1eeb;border:1px solid #ffffff1a;border-radius:10px;padding:10px 16px;font-size:13px;font-weight:600;animation:.25s st-toastIn;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0003}.conflict-warn{color:#ff3b30;background:#ff3b3014;border:1px solid #ff3b3040;border-radius:10px;margin-bottom:10px;padding:9px 12px;font-size:12px;font-weight:600}.capacity-warn{color:#ff9500;background:#ff950014;border:1px solid #ff950040;border-radius:10px;margin-bottom:10px;padding:9px 12px;font-size:12px;font-weight:600}.tag-picker{flex-wrap:wrap;gap:6px;display:flex}.tag-pick{cursor:pointer;color:#8e8e93;background:#0000000a;border:1px solid #0000001a;border-radius:16px;padding:5px 10px;font-size:11px;font-weight:700}.tag-pick.sel{color:var(--accent);background:#c8952a26;border-color:#c8952a73}.action-row{flex-wrap:wrap;gap:5px;margin-top:8px;display:flex}.action-btn{color:#8e8e93;background:#0000000d;border:1px solid #0000;border-radius:8px;flex:1;min-width:60px;padding:5px 8px;font-size:11px;font-weight:700}.action-btn.confirm{color:#34c759;background:#34c7591a;border-color:#34c7594d}.action-btn.complete{color:#8e8e93;background:#0000000d;border-color:#0000001a}.action-btn.edit{color:var(--accent);background:#c8952a14;border-color:#c8952a4d}.action-btn.delete{color:#ff3b30;background:#ff3b3012;border-color:#ff3b3040}.action-btn.copy{color:#007aff;background:#007aff14;border-color:#007aff4d}.action-btn.cancel{color:#ff3b30d9;background:#ff3b300f;border-color:#ff3b3033}.mini-sep{background:#00000012;height:1px;margin:6px 0}.status-bar-row{border-bottom:1px solid #00000012;align-items:center;gap:10px;padding:10px 0;display:flex}.status-bar-row:last-child{border-bottom:none}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.status-bar-label{color:#3c3c43;flex-shrink:0;width:52px;font-size:13px;font-weight:600}.status-bar-track{background:#00000012;border-radius:3px;flex:1;height:6px;overflow:hidden}.status-bar-fill{border-radius:3px;height:100%;transition:width .4s}.status-bar-count{color:#8e8e93;text-align:right;flex-shrink:0;width:70px;font-size:12px}.app-sidebar{display:none}.app-main{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}@media (width>=768px){.st-root{border-radius:0;max-width:100%}.status-bar{display:none}.app-header{padding:14px 24px}.app-name{font-size:18px}.content{padding:0 24px 16px}.tab-bar{padding:10px 16px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));gap:4px}.tab-btn{min-width:72px}.tab-btn svg{width:22px;height:22px}.tab-label{font-size:11px}.form-row{grid-template-columns:1fr 1fr}.section-title{font-size:17px}.dash-stat-val{font-size:22px}.date-chip{min-width:58px;padding:10px 8px}.date-chip .dc-day{font-size:20px}}@media (width>=1024px){.st-root{flex-direction:row;max-width:100%}.app-sidebar{background:#fff;border-right:1px solid #00000014;flex-direction:column;flex-shrink:0;width:220px;min-width:220px;height:100svh;padding:28px 14px 20px;display:flex;position:sticky;top:0}.sidebar-logo{border-bottom:1px solid #00000012;align-items:center;gap:10px;margin-bottom:14px;padding:0 6px 20px;display:flex}.sidebar-store-name{color:#1c1c1e;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:15px;font-weight:700;overflow:hidden}.sidebar-tabs{flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-tab-btn{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:10px;width:100%;padding:11px 12px;transition:background .15s;display:flex}.sidebar-tab-btn svg{stroke:#8e8e93;fill:none;stroke-width:1.8px;flex-shrink:0;width:20px;height:20px}.sidebar-tab-btn .sidebar-tab-label{color:#8e8e93;font-size:14px;font-weight:600}.sidebar-tab-btn:hover{background:#0000000a}.sidebar-tab-btn.active{background:#c8952a1a}.sidebar-tab-btn.active svg{stroke:#c8952a}.sidebar-tab-btn.active .sidebar-tab-label{color:#c8952a;font-weight:700}.sidebar-switch{color:#c8952a;cursor:pointer;background:#c8952a1a;border:1px solid #c8952a4d;border-radius:10px;width:100%;margin-top:10px;padding:10px 12px;font-size:13px;font-weight:600;transition:background .15s}.sidebar-switch:hover{background:#c8952a2e}.app-main>.tab-bar,.app-main>.status-bar{display:none}.app-main{background:#f2f2f7;flex-direction:column;flex:1;display:flex;overflow:hidden}.app-header{background:#fff;border-bottom:1px solid #00000014;padding:16px 32px}.app-header .switch-btn{display:none}.content{flex:1;padding:0 32px 20px;overflow-y:auto}.section-title{margin:18px 0 10px;font-size:18px}.dash-card{border-radius:18px}.card,.stat-card{border-radius:16px}}
