@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:400;font-display:swap;src:url(../media/53e45098eac42afb-s.p.0l2qk94b1u89y.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:400;font-display:swap;src:url(../media/85ea1b3aadcead52-s.01rdcbu-77uoy.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:400;font-display:swap;src:url(../media/3c285486269019b7-s.p.0sn2213rkw2e_.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:500;font-display:swap;src:url(../media/625a092f804baad3-s.p.0mrp_qm_8jqq_.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:500;font-display:swap;src:url(../media/6afabefbb32d7517-s.05-22z7vt.jl1.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:500;font-display:swap;src:url(../media/a4f4f75ad654963f-s.p.0h6jagi-ln9qy.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:600;font-display:swap;src:url(../media/a3bcb02a0e9e5d11-s.p.0p40-daftjh_g.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:600;font-display:swap;src:url(../media/b35fd19aef91b293-s.07en.a1_ufzzv.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:600;font-display:swap;src:url(../media/8f46d218c8f79e34-s.p.0xhl7b6zs4.~j.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:700;font-display:swap;src:url(../media/8ffc259da9d23054-s.p.0b_.2~bprftx..woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:700;font-display:swap;src:url(../media/9e486ba39c38fb8a-s.0qxf2_hlpbci0.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:700;font-display:swap;src:url(../media/6f42e0a3b0519c4d-s.p.0czffigx~77c..woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:800;font-display:swap;src:url(../media/fcf129058e6e31f2-s.p.0k.rt6-fab6y0.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:800;font-display:swap;src:url(../media/7b74840ea7c05e95-s.08-6qa~ryw15i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Be Vietnam Pro;font-style:normal;font-weight:800;font-display:swap;src:url(../media/3eca85881bcfa204-s.p.09gf3ff1ir7gl.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Be Vietnam Pro Fallback;src:local(Arial);ascent-override:90.61%;descent-override:24.01%;line-gap-override:0.0%;size-adjust:110.36%}.be_vietnam_pro_73367072-module__B8bsvG__className{font-family:Be Vietnam Pro,Be Vietnam Pro Fallback;font-style:normal}.be_vietnam_pro_73367072-module__B8bsvG__variable{--font-be-vietnam:"Be Vietnam Pro", "Be Vietnam Pro Fallback"}
@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-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:var(--font-geist-sans);--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-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{.surface-card{border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);ring:1px solid #e2e8f0cc;background:#ffffffeb;border:1px solid #fffc}.btn-primary{border-radius:var(--radius-md);background:var(--accent);color:#fff;box-shadow:var(--shadow-sm);cursor:pointer;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;transition:background .15s,box-shadow .15s,transform .15s;display:inline-flex}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);color:#475569;cursor:pointer;justify-content:center;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:500;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-secondary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary:hover:not(:disabled){border-color:var(--border-strong);background:var(--surface-muted);color:#0f172a}.input-field{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);width:100%;min-width:0;max-width:100%;color:var(--foreground);box-shadow:var(--shadow-sm);padding:.625rem .875rem .625rem 2.5rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.input-plain{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);width:100%;min-width:0;max-width:100%;color:var(--foreground);box-shadow:var(--shadow-sm);padding:.625rem .875rem;font-size:.875rem;transition:border-color .15s,box-shadow .15s}.input-plain::placeholder,.textarea-plain::placeholder{color:#94a3b8}.input-plain:focus,.textarea-plain:focus{border-color:var(--accent-muted);outline:none;box-shadow:0 0 0 3px #4f46e51f}.textarea-plain{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);width:100%;min-width:0;max-width:100%;color:var(--foreground);box-shadow:var(--shadow-sm);resize:vertical;overflow-wrap:break-word;word-break:break-word;padding:.625rem .875rem;font-size:.875rem;line-height:1.5;transition:border-color .15s,box-shadow .15s}.chip{cursor:pointer;border-radius:999px;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.75rem;font-weight:600;transition:background .15s,color .15s,box-shadow .15s;display:inline-flex}.chip-active{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm)}.chip-idle{color:#475569;ring:1px solid var(--border);background:#fff}.chip-idle:hover{background:var(--surface-muted);color:#0f172a}.btn-call{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:#059669;justify-content:center;align-items:center;gap:.375rem;min-width:0;max-width:100%;padding:.5rem .875rem;font-size:.8125rem;font-weight:600;transition:background .15s,transform .15s;display:inline-flex}.btn-call:hover{background:#047857}.btn-call:active{transform:scale(.98)}.btn-toggle-contact{border-radius:var(--radius-md);cursor:pointer;justify-content:center;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-toggle-contact:disabled,.btn-toggle-ordered:disabled{opacity:.55;cursor:not-allowed}.btn-toggle-contact-pending{color:#b45309;background:#fffbeb;border:1px solid #fcd34d}.btn-toggle-contact-pending:hover:not(:disabled){background:#fef3c7}.btn-toggle-contact-done{color:#047857;background:#ecfdf5;border:1px solid #6ee7b7}.btn-toggle-contact-done:hover:not(:disabled){background:#d1fae5}.btn-toggle-ordered{border-radius:var(--radius-md);cursor:pointer;justify-content:center;align-items:center;gap:.375rem;padding:.5rem .875rem;font-size:.8125rem;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.btn-toggle-ordered-pending{color:#4338ca;background:#eef2ff;border:1px solid #c7d2fe}.btn-toggle-ordered-pending:hover:not(:disabled){background:#e0e7ff}.btn-toggle-ordered-done{color:#1d4ed8;background:#eff6ff;border:1px solid #93c5fd}.btn-toggle-ordered-done:hover:not(:disabled){background:#dbeafe}.order-row{border-radius:var(--radius-lg);border:1px solid var(--border);cursor:pointer;background:#fff;gap:.875rem;min-width:0;padding:.875rem 1rem;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex;overflow:hidden}.order-row:hover{border-color:var(--accent-muted);box-shadow:var(--shadow-md)}.order-row-pending{border-left:4px solid #f59e0b}.order-row-done{opacity:.92;border-left:4px solid #10b981}.order-row-ordered{opacity:.95;border-left:4px solid #3b82f6}.drawer-overlay{z-index:40;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);cursor:pointer;background:#0f172a73;position:fixed;inset:0}.drawer-panel{z-index:50;min-width:0;box-shadow:var(--shadow-lg);background:#fff;flex-direction:column;display:flex;position:fixed;overflow-x:hidden}@media (max-width:767px){.drawer-panel{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:92vh;inset:auto 0 0}}@media (min-width:768px){.drawer-panel{border-left:1px solid var(--border);width:min(100%,28rem);top:0;bottom:0;right:0}}.input-field::placeholder{color:#94a3b8}.input-field:focus{border-color:var(--accent-muted);outline:none;box-shadow:0 0 0 3px #4f46e51f}.skeleton{border-radius:var(--radius-lg);background:linear-gradient(90deg,#f1f5f9 0%,#e2e8f0 50%,#f1f5f9 100%) 0 0/200% 100%;animation:1.4s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@keyframes toast-in{0%{opacity:0;transform:translateY(.5rem)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.toast-enter{animation:.22s ease-out toast-in}}@layer utilities{.visible{visibility:visible}.flex{display:flex}.hidden{display:none}.h-full{height:100%}.min-h-full{min-height:100%}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.break-all{word-break:break-all}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--background:#f4f6f9;--foreground:#0f172a;--surface:#fff;--surface-muted:#f8fafc;--border:#e2e8f0;--border-strong:#cbd5e1;--accent:#4f46e5;--accent-hover:#4338ca;--accent-soft:#eef2ff;--accent-muted:#c7d2fe;--success:#059669;--warning:#d97706;--danger:#dc2626;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.25rem;--shadow-sm:0 1px 2px #0f172a0a, 0 1px 3px #0f172a0f;--shadow-md:0 4px 6px -1px #0f172a0d, 0 2px 4px -2px #0f172a0d;--shadow-lg:0 10px 15px -3px #0f172a0f, 0 4px 6px -4px #0f172a0a}html{overflow-x:clip}body{background:var(--background);color:var(--foreground);font-family:var(--font-sans), system-ui, sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip}::selection{background:var(--accent-muted);color:#312e81}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f6f7fb;--surface:#fff;--surface-2:#fafbff;--border:#ebedf3;--border-strong:#dfe3ec;--text:#161a2e;--text-muted:#6b7286;--text-faint:#9aa1b2;--primary:#6d28d9;--primary-2:#8b5cf6;--primary-soft:#f1ebfe;--primary-grad:linear-gradient(135deg, #7c3aed 0%, #6366f1 100%);--green:#059669;--green-bg:#e7f7f0;--orange:#d97706;--orange-bg:#fdf3e3;--red:#e11d48;--red-bg:#fdeaef;--blue:#2563eb;--blue-bg:#e8f0fe;--purple:#7c3aed;--purple-bg:#f1ebfe;--shadow-sm:0 1px 2px #1419320a;--shadow:0 4px 16px #1419320f;--shadow-lg:0 18px 50px #14193229;--radius:16px;--radius-sm:10px;--sidebar-w:248px}html{-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility}body{font-family:var(--font-be-vietnam), "Be Vietnam Pro", system-ui, -apple-system, sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}button{font-family:inherit}.app{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:28px;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;padding:4px 8px;display:flex}.brand-logo{background:var(--primary-grad);color:#fff;border-radius:12px;place-items:center;width:42px;height:42px;font-size:20px;display:grid;box-shadow:0 6px 16px #7c3aed59}.brand-text strong{letter-spacing:-.01em;font-size:15px;font-weight:700;display:block}.brand-text span{color:var(--text-faint);font-size:12px}.nav{flex-direction:column;gap:4px;display:flex}.nav-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);padding:0 10px 6px;font-size:11px;font-weight:600}.nav-item{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:12px;width:100%;padding:11px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.nav-item svg{flex-shrink:0;width:19px;height:19px}.sidebar-foot{background:var(--primary-grad);color:#fff;border-radius:14px;margin-top:auto;padding:16px}.sidebar-foot strong{font-size:13px;display:block}.sidebar-foot p{opacity:.85;margin-top:4px;font-size:12px}.content{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:22px 32px 0;display:flex}.topbar h1{letter-spacing:-.02em;font-size:22px;font-weight:700}.topbar p{color:var(--text-muted);margin-top:2px;font-size:13.5px}.main{flex:1;padding:22px 32px 40px}.summary{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:22px;display:grid}.sum-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:center;gap:14px;padding:18px;transition:transform .15s,box-shadow .15s;display:flex}.sum-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.sum-icon{border-radius:12px;flex-shrink:0;place-items:center;width:46px;height:46px;display:grid}.sum-icon svg{width:22px;height:22px}.sum-icon{font-size:22px}.sum-icon.i-total{background:var(--primary-soft);color:var(--primary)}.sum-icon.i-expiring{background:var(--orange-bg);color:var(--orange)}.sum-icon.i-expired{background:var(--red-bg);color:var(--red)}.sum-icon.i-new{background:var(--blue-bg);color:var(--blue)}.sum-icon.i-returning{background:var(--purple-bg);color:var(--purple)}.sum-icon.i-active{background:var(--green-bg);color:var(--green)}.sum-value{letter-spacing:-.02em;font-size:24px;font-weight:800;line-height:1.1}.sum-label{color:var(--text-muted);margin-top:2px;font-size:12.5px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding:16px 18px;display:flex}.filters{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--border-strong);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:999px;align-items:center;gap:7px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.chip:hover{border-color:var(--primary-2);color:var(--primary)}.chip-active{background:var(--primary-grad);color:#fff;border-color:#0000;box-shadow:0 4px 12px #7c3aed4d}.chip-active:hover{color:#fff}.chip-count{background:#0000000f;border-radius:999px;padding:1px 7px;font-size:11px;font-weight:700}.chip-active .chip-count{background:#ffffff40}.toolbar-right{align-items:center;gap:10px;display:flex}.search{align-items:center;display:flex;position:relative}.search svg{width:16px;height:16px;color:var(--text-faint);pointer-events:none;position:absolute;left:12px}.search input{border:1px solid var(--border-strong);background:var(--surface-2);border-radius:10px;width:230px;padding:9px 14px 9px 36px;font-family:inherit;font-size:14px;transition:all .15s}.search input:focus{border-color:var(--primary-2);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-items:center;gap:7px;padding:9px 16px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn svg{width:16px;height:16px}.btn-primary{background:var(--primary-grad);color:#fff;box-shadow:0 4px 12px #7c3aed4d}.btn-primary:hover{filter:brightness(1.06);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border-strong)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--primary-2);color:var(--primary)}.btn-ghost:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid #0000}.btn-danger:hover{background:var(--red);color:#fff}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.btn-sm{border-radius:9px;gap:5px;padding:6px 11px;font-size:12.5px}.btn-sm svg{width:14px;height:14px}.row-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.row-actions--compact{flex-wrap:nowrap;gap:4px}.row-clickable{cursor:pointer}.registrations-table .col-check{width:36px}.registrations-table .col-time,.registrations-table .col-price,.registrations-table .col-status,.registrations-table .col-actions{white-space:nowrap}.registrations-table .col-price{font-weight:700}.registrations-table .col-package{min-width:120px}.cell-status-badges{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.registrations-table .col-actions{position:relative}.row-menu{display:inline-flex;position:relative}.row-menu-trigger svg{width:14px;height:14px}.row-menu-dropdown{border:1px solid var(--border-strong);background:var(--surface);border-radius:12px;min-width:168px;padding:6px;box-shadow:0 12px 32px #0f172a1f}.row-menu-dropdown--portal{z-index:1000;position:fixed}.row-menu-item{width:100%;color:var(--text);font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:9px 10px;font-size:13px;text-decoration:none;transition:background .12s;display:flex}.row-menu-item svg{width:15px;height:15px;color:var(--text-muted);flex-shrink:0}.row-menu-item:hover:not(:disabled){background:var(--surface-2)}.row-menu-item:disabled{opacity:.5;cursor:not-allowed}.row-menu-item--primary{color:var(--primary);font-weight:600}.row-menu-item--danger,.row-menu-item--danger svg{color:var(--red)}.cell-inline-badge{margin-top:6px;margin-right:6px;display:inline-flex}.cell-note{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;font-size:12px;display:-webkit-box;overflow:hidden}.pagination-bar{border-top:1px solid var(--border);background:var(--surface-2);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px 16px;padding:14px 16px;display:flex}.pagination-info{color:var(--text-muted);font-size:13px}.pagination-size{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pagination-size-label{color:var(--text-faint);margin-right:2px;font-size:12px}.pagination-nav{align-items:center;gap:8px;display:flex}.pagination-page{color:var(--text-muted);text-align:center;min-width:88px;font-size:13px}.modal-sub{color:var(--text-muted);margin-top:2px;font-size:12.5px}.chot-modal{max-width:520px;position:relative;overflow:hidden}.chot-head{background:var(--primary-grad);color:#fff;justify-content:space-between;align-items:center;gap:12px;padding:20px 24px;display:flex;position:relative;overflow:hidden}.chot-head:after{content:"";background:#ffffff1f;border-radius:50%;width:140px;height:140px;position:absolute;top:-40px;right:-30px}.chot-head-main{z-index:1;align-items:center;gap:14px;display:flex}.chot-head-icon{background:#fff3;border-radius:13px;flex-shrink:0;place-items:center;width:44px;height:44px;display:grid}.chot-head-icon svg{width:22px;height:22px}.chot-head h2{letter-spacing:-.01em;font-size:19px;font-weight:800}.chot-head p{opacity:.9;margin-top:2px;font-size:12.5px}.chot-close{color:#fff;z-index:1}.chot-close:hover{color:#fff;background:#ffffff2e;border-color:#0000}.cz-section{flex-direction:column;gap:8px;display:flex}.cz-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-faint);align-items:center;gap:7px;font-size:12px;font-weight:700;display:flex}.cz-label svg{width:15px;height:15px;color:var(--primary)}.cz-required{text-transform:none;letter-spacing:0;color:var(--orange);margin-left:auto;font-size:11px;font-weight:600}.cz-input{border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);border-radius:10px;width:100%;padding:10px 13px;font-family:inherit;font-size:14px;transition:all .15s}.cz-input:focus{border-color:var(--primary-2);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.qty-row{justify-content:space-between;align-items:center;gap:10px;margin-top:8px;display:flex}.qty-pill{text-align:center;min-width:40px;color:var(--primary-2);background:var(--primary-soft);border-radius:999px;padding:4px 14px;font-size:15px;font-weight:800}.prod-cell{align-items:center;gap:10px;display:flex}.prod-thumb{object-fit:cover;border:1px solid var(--border);background:var(--surface-2);border-radius:8px;flex-shrink:0;width:36px;height:36px}.prod-thumb-empty{background:linear-gradient(135deg, var(--surface-2), var(--border))}.bulk-bar{background:var(--primary-soft);border:1px solid var(--primary-2);color:var(--text);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;padding:12px 16px;font-size:14px;display:flex}.bulk-bar-actions{gap:8px;display:flex}.bulk-result{color:#065f46;cursor:pointer;background:#ecfdf5;border:1px solid #6ee7b7;border-radius:12px;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:14px;padding:11px 16px;font-size:13px;display:flex;position:relative}.bulk-result-close{opacity:.6;margin-left:auto;font-size:18px;line-height:1}.pkg-picker{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;display:grid}.pkg-option{text-align:left;border:1.5px solid var(--border-strong);background:var(--surface);cursor:pointer;border-radius:12px;flex-direction:column;gap:2px;padding:11px 12px;transition:all .15s;display:flex;position:relative}.pkg-option:hover{border-color:var(--primary-2);transform:translateY(-1px)}.pkg-option.active{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 4px 12px #7c3aed2e}.pkg-check{background:var(--primary-grad);border-radius:50%;place-items:center;width:18px;height:18px;animation:.25s cubic-bezier(.16,1,.3,1) pop-in;display:grid;position:absolute;top:8px;right:8px}.pkg-check svg{color:#fff;width:11px;height:11px}.pkg-option strong{white-space:nowrap;text-overflow:ellipsis;padding-right:18px;font-size:13.5px;overflow:hidden}.pkg-option span{color:var(--text-muted);font-size:11.5px}.pkg-option.active span{color:var(--primary)}.field-hint{color:var(--text-muted);font-size:12px}.deal-value{background:linear-gradient(135deg,#f1ebfe,#e8f0fe);border:1px solid #d9d4f7;border-radius:14px;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.dv-label{color:var(--text-muted);font-size:12px;font-weight:600}.dv-amount{letter-spacing:-.02em;color:var(--primary);margin-top:2px;font-size:24px;font-weight:800}.dv-pkg{color:var(--primary);white-space:nowrap;text-overflow:ellipsis;background:#7c3aed1f;border-radius:999px;max-width:180px;padding:6px 12px;font-size:12.5px;font-weight:700;overflow:hidden}.btn-chot{color:#fff;background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 6px 16px #05966952}.btn-chot:hover:not(:disabled){filter:brightness(1.05);transform:translateY(-1px)}.btn-chot:disabled{opacity:.55;cursor:not-allowed}.celebrate{z-index:5;background:#fffffff7;flex-direction:column;justify-content:center;align-items:center;gap:8px;animation:.2s fade;display:flex;position:absolute;inset:0;overflow:hidden}.celebrate-check{background:linear-gradient(135deg,#059669,#10b981);border-radius:50%;place-items:center;width:84px;height:84px;animation:.4s cubic-bezier(.16,1,.3,1) pop-in;display:grid;box-shadow:0 12px 30px #05966966}.celebrate-check svg{color:#fff;stroke-width:3px;width:42px;height:42px}.celebrate-text{color:var(--green);margin-top:6px;font-size:20px;font-weight:800;animation:.4s cubic-bezier(.16,1,.3,1) 80ms both pop-in}.celebrate-sub{color:var(--text);font-size:15px;font-weight:700;animation:.4s cubic-bezier(.16,1,.3,1) .16s both pop-in}.confetti{pointer-events:none;position:absolute;inset:0}.confetti-piece{opacity:0;border-radius:2px;width:9px;height:14px;animation:1.4s ease-in forwards confetti-fall;position:absolute;top:-10px}@keyframes pop-in{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-10px)rotate(0)}to{opacity:0;transform:translateY(360px)rotate(540deg)}}.detail-list{flex-direction:column;gap:2px;display:flex}.detail-list>div{border-bottom:1px solid var(--border);grid-template-columns:130px 1fr;gap:14px;padding:10px 0;display:grid}.detail-list>div:last-child{border-bottom:none}.detail-list dt{color:var(--text-faint);font-size:12.5px;font-weight:600}.detail-list dd{color:var(--text);font-size:13.5px}@media (max-width:520px){.detail-list>div{grid-template-columns:1fr;gap:2px}}.detail-modal-body{flex-direction:column;gap:16px;padding:20px 24px 24px;display:flex}.detail-badges{flex-wrap:wrap;gap:8px;display:flex}.detail-actions{border-top:1px solid var(--border);justify-content:flex-start;padding-top:4px}.detail-meta-btns{flex-wrap:wrap;gap:8px;display:flex}.detail-meta-btn{align-self:flex-start}.copy-options-table th:last-child,.copy-options-table td.copy-options-action{white-space:nowrap;text-align:right;width:1%}.copy-options-label{white-space:nowrap;width:1%;color:var(--text-muted);font-weight:600}.copy-options-value{word-break:break-word;max-width:280px;color:var(--text)}.connect-zalo-badge{color:#fff;background:#0068ff;border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;font-weight:700;display:inline-flex}.modal-overlay--stack{z-index:60}.btn-icon{cursor:pointer;width:32px;height:32px;color:var(--text-muted);background:0 0;border:1px solid #0000;border-radius:9px;place-items:center;transition:all .15s;display:grid}.btn-icon svg{width:16px;height:16px}.btn-icon:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--text)}.btn-icon.danger:hover{background:var(--red-bg);border-color:var(--red-bg);color:var(--red)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;padding:13px 16px;font-size:11.5px;font-weight:600}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:13px 16px}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .12s}tbody tr:hover{background:var(--surface-2)}.cust-cell{align-items:center;gap:12px;display:flex}.avatar{color:#fff;border-radius:11px;flex-shrink:0;place-items:center;width:38px;height:38px;font-size:14px;font-weight:700;display:grid}.cell-name{color:var(--text);font-weight:600}.cell-sub{color:var(--text-faint);font-size:12.5px}.pancake-report{margin-top:5px}.pancake-report-row{align-items:center;gap:6px;max-width:200px;display:flex}.pancake-report--detail{border:1px solid var(--border,#e2e8f0);background:var(--surface-2,#f8fafc);border-radius:12px;margin-top:0;padding:14px 16px}.pancake-report--detail .pancake-report-row{max-width:none}.pancake-report--detail .pancake-bar-track{height:8px}.pancake-report--detail .pancake-bar-rate{min-width:36px;font-size:12px}.pancake-detail-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.pancake-detail-head strong{color:var(--text-faint);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:700}.pancake-detail-rate{font-size:12px;font-weight:700}.pancake-detail-rate.is-ok{color:var(--green,#16a34a)}.pancake-detail-rate.is-warn{color:var(--orange,#d97706)}.pancake-detail-rate.is-danger{color:var(--red,#e11d48)}.pancake-detail-stats{color:var(--text-muted);flex-wrap:wrap;gap:10px 16px;margin-top:10px;font-size:12.5px;display:flex}.pancake-detail-stats em{color:var(--text);font-style:normal;font-weight:700}.pancake-detail-warn-count{color:var(--orange,#d97706);align-items:center;gap:4px;font-weight:600;display:inline-flex}.pancake-detail-warn-count svg{width:13px;height:13px}.pancake-detail-warn-btn{border:1px solid var(--orange-bg,#ffedd5);background:var(--orange-bg,#ffedd5);color:var(--orange,#d97706);font:inherit;cursor:pointer;border-radius:999px;align-items:center;gap:5px;padding:4px 10px;font-size:12.5px;font-weight:600;transition:opacity .15s,transform .15s;display:inline-flex}.pancake-detail-warn-btn:hover{opacity:.9}.pancake-detail-warn-btn svg{width:13px;height:13px}.pancake-detail-hint{color:var(--text-faint);margin:10px 0 0;font-size:12.5px}.pancake-report--detail .pancake-warn-panel{margin-top:12px}.pancake-bar{flex:1;align-items:center;gap:6px;min-width:0;display:flex;position:relative}.pancake-bar-track{background:var(--border,#e2e8f0);border-radius:999px;flex:1;min-width:56px;height:6px;display:flex;overflow:hidden}.pancake-bar-track.is-empty{opacity:.45}.pancake-bar-ok{background:var(--green,#16a34a);height:100%}.pancake-bar-fail{background:var(--red,#e11d48);height:100%}.pancake-bar-rate{min-width:30px;color:var(--text-faint);font-size:11px;font-weight:700;line-height:1}.pancake-bar-rate.is-ok{color:var(--green,#16a34a)}.pancake-bar-rate.is-warn{color:var(--orange,#d97706)}.pancake-bar-rate.is-danger{color:var(--red,#e11d48)}.pancake-warn-badge{background:var(--orange-bg,#fdf3e3);color:var(--orange,#d97706);cursor:pointer;border:none;border-radius:999px;flex-shrink:0;align-items:center;gap:2px;padding:2px 6px;font-size:11px;font-weight:700;line-height:1;display:inline-flex;position:relative}.pancake-warn-badge:hover{filter:brightness(.97)}.pancake-warn-badge svg{width:12px;height:12px}.pancake-warn-popover{z-index:40;color:#f8fafc;text-align:left;cursor:default;background:#1e293b;border-radius:8px;min-width:220px;max-width:280px;padding:10px 12px;font-size:12px;line-height:1.45;display:none;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 8px 20px #0f172a38}.pancake-warn-badge.is-open .pancake-warn-popover{display:block}.pancake-warn-popover strong{letter-spacing:.02em;text-transform:uppercase;color:#fdba74;margin-bottom:6px;font-size:11px;display:block}.pancake-warn-popover:after{content:"";border:5px solid #0000;border-top-color:#1e293b;position:absolute;top:100%;left:50%;transform:translate(-50%)}.pancake-warn-list{margin:0;padding:0;list-style:none}.pancake-warn-list li+li{border-top:1px solid #ffffff14;margin-top:8px;padding-top:8px}.pancake-warn-list li span{display:block}.pancake-warn-list li small{color:#94a3b8;margin-top:2px;font-size:11px;display:block}.pancake-warn-empty{color:#cbd5e1;margin:0;font-size:11px}.pancake-warn-panel{border:1px solid var(--orange-bg,#fde68a);background:var(--orange-bg,#fdf3e3);border-radius:10px;margin-top:8px;padding:10px 12px}.pancake-warn-panel-head{width:100%;color:var(--orange,#d97706);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:13px;display:flex}.pancake-warn-panel.is-open .pancake-warn-panel-head{margin-bottom:8px}.pancake-warn-panel-head svg{width:14px;height:14px}.pancake-warn-panel-list{margin:0;padding:0;list-style:none}.pancake-warn-panel-list li{color:var(--text);padding:8px 0;font-size:13px}.pancake-warn-panel-list li+li{border-top:1px solid #d9770626}.pancake-warn-panel-list li small{color:var(--text-faint);margin-top:3px;font-size:11px;display:block}.pancake-bar-loading{background:linear-gradient(90deg, var(--border,#e2e8f0) 25%, #eef2f7 50%, var(--border,#e2e8f0) 75%);background-size:200% 100%;border-radius:999px;flex:1;height:6px;animation:1.1s linear infinite pancake-bar-shimmer}@keyframes pancake-bar-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.pancake-bar-tip{z-index:30;color:#f8fafc;pointer-events:none;background:#1e293b;border-radius:8px;min-width:190px;max-width:260px;padding:8px 10px;font-size:12px;line-height:1.45;display:none;position:absolute;bottom:calc(100% + 8px);left:0;box-shadow:0 8px 20px #0f172a38}.pancake-bar-tip strong{letter-spacing:.02em;text-transform:uppercase;color:#94a3b8;margin-bottom:4px;font-size:11px;display:block}.pancake-bar-tip:after{content:"";border:5px solid #0000;border-top-color:#1e293b;position:absolute;top:100%;left:14px}.pancake-bar:hover .pancake-bar-tip,.pancake-bar:focus-within .pancake-bar-tip{display:block}.cell-address{max-width:220px;color:var(--text-muted);font-size:13px}.cell-actions{white-space:nowrap;text-align:right}.cell-actions .btn-icon{display:inline-grid}.badge{white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.badge-active{background:var(--green-bg);color:var(--green)}.badge-expiring{background:var(--orange-bg);color:var(--orange)}.badge-expired{background:var(--red-bg);color:var(--red)}.badge-new{background:var(--blue-bg);color:var(--blue)}.badge-returning{background:var(--purple-bg);color:var(--purple)}.badge-package{background:var(--surface-2);color:var(--text);border:1px solid var(--border-strong)}.count-pill{background:var(--surface-2);border:1px solid var(--border-strong);min-width:30px;color:var(--text-muted);border-radius:8px;place-items:center;padding:3px 8px;font-size:12.5px;font-weight:700;display:inline-grid}.count-pill.hot{background:var(--purple-bg);color:var(--purple);border-color:#0000}.sync-modes{grid-template-columns:1fr 1fr;gap:12px;display:grid}.sync-mode{border:1.5px solid var(--border-strong);background:var(--surface);text-align:left;cursor:pointer;border-radius:12px;flex-direction:column;gap:3px;padding:14px;transition:all .15s;display:flex}.sync-mode strong{font-size:14px}.sync-mode span{color:var(--text-muted);font-size:12px}.sync-mode:hover{border-color:var(--primary-2)}.sync-mode.active{border-color:var(--primary);background:var(--primary-soft)}.sync-mode:disabled{opacity:.6;cursor:not-allowed}.sync-result{grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:10px;display:grid}.sync-stat{background:var(--surface-2);border:1px solid var(--border);text-align:center;border-radius:10px;padding:12px 8px}.sync-stat b{letter-spacing:-.02em;font-size:20px;font-weight:800;display:block}.sync-stat span{color:var(--text-muted);font-size:11.5px}.sync-stat.ins b{color:var(--green)}.sync-stat.upd b{color:var(--purple)}.sync-stat.skip b{color:var(--text-muted)}.sync-stat.err b{color:var(--red)}.empty-state{text-align:center;color:var(--text-muted);padding:70px 20px}.empty-state .empty-icon{background:var(--primary-soft);width:56px;height:56px;color:var(--primary);border-radius:16px;place-items:center;margin:0 auto 14px;display:grid}.empty-state .empty-icon svg{width:28px;height:28px}.spinner{border:3px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;width:34px;height:34px;margin:0 auto 14px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.import-result{color:var(--text);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#eef2ff,#f5f0ff);border:1px solid #d9d4f7;margin-bottom:18px;padding:16px 44px 16px 18px;font-size:13.5px;position:relative}.import-result .ir-head{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.ir-tag{border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:12.5px;font-weight:600;display:inline-flex}.ir-tag.ins{background:var(--green-bg);color:var(--green)}.ir-tag.upd{background:var(--blue-bg);color:var(--blue)}.ir-tag.skip{color:var(--text-muted);background:#eceef3}.ir-tag.err{background:var(--red-bg);color:var(--red)}.import-result .btn-icon{position:absolute;top:10px;right:10px}.import-errors{color:var(--red);max-height:140px;margin-top:10px;padding-left:18px;font-size:12.5px;overflow-y:auto}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#161a2e73;justify-content:center;align-items:center;padding:20px;animation:.15s fade;display:flex;position:fixed;inset:0}@keyframes fade{0%{opacity:0}}.modal{background:var(--surface);width:100%;max-width:560px;max-height:92vh;box-shadow:var(--shadow-lg);border-radius:20px;animation:.18s cubic-bezier(.16,1,.3,1) pop;overflow-y:auto}@keyframes pop{0%{opacity:0;transform:translateY(12px)scale(.98)}}.modal-header{border-bottom:1px solid var(--border);background:var(--surface);z-index:1;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.modal-header h2{font-size:18px;font-weight:700}.form{flex-direction:column;gap:18px;padding:24px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.field{flex-direction:column;gap:7px;display:flex}.field span{color:var(--text);font-size:13px;font-weight:600}.field input,.field select{border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);border-radius:10px;padding:10px 13px;font-family:inherit;font-size:14px;transition:all .15s}.field input:focus,.field select:focus{border-color:var(--primary-2);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.hint{color:var(--text-muted);background:var(--primary-soft);border-radius:10px;gap:8px;padding:11px 13px;font-size:12.5px;display:flex}.hint svg{width:16px;height:16px;color:var(--primary);flex-shrink:0;margin-top:1px}.form-error{color:var(--red);background:var(--red-bg);border-radius:10px;margin-bottom:18px;padding:11px 13px;font-size:13px}.form .form-error{margin-bottom:0}.form-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.stats{flex-direction:column;gap:18px;display:flex}.highlight-row{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.highlight{border-radius:var(--radius);color:#fff;box-shadow:var(--shadow);padding:22px;position:relative;overflow:hidden}.highlight .hl-label{opacity:.9;font-size:13px;font-weight:500}.highlight .hl-value{letter-spacing:-.02em;margin-top:6px;font-size:28px;font-weight:800}.highlight .hl-sub{opacity:.9;margin-top:4px;font-size:13px}.highlight .hl-emoji{opacity:.22;font-size:54px;position:absolute;bottom:10px;right:16px}.hl-total{background:var(--primary-grad)}.hl-best{background:linear-gradient(135deg,#059669,#10b981)}.hl-worst{background:linear-gradient(135deg,#e11d48,#fb7185)}.chart-grid{grid-template-columns:1.6fr 1fr;gap:16px;display:grid}@media (max-width:820px){.chart-grid{grid-template-columns:1fr}}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:24px}.chart-card h3{margin-bottom:18px;font-size:15px;font-weight:700}.chart{flex-direction:column;gap:13px;display:flex}.chart-row{grid-template-columns:120px 1fr;align-items:center;gap:14px;display:grid}.chart-label{color:var(--text-muted);text-align:right;font-size:13px;font-weight:600}.chart-bar-track{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;height:30px;overflow:hidden}.chart-bar{background:var(--primary-grad);border-radius:7px;justify-content:flex-end;align-items:center;min-width:34px;height:100%;padding:0 10px;transition:width .6s cubic-bezier(.16,1,.3,1);display:flex}.chart-bar-best{background:linear-gradient(135deg,#059669,#10b981)}.chart-bar-worst{background:linear-gradient(135deg,#e11d48,#fb7185)}.chart-count{color:#fff;font-size:12px;font-weight:700}.mini-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;display:grid}.donut-wrap{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.donut{border-radius:50%;flex-shrink:0;place-items:center;width:150px;height:150px;display:grid;position:relative}.donut-hole{background:var(--surface);text-align:center;border-radius:50%;place-items:center;width:96px;height:96px;display:grid}.donut-total{letter-spacing:-.02em;font-size:26px;font-weight:800;line-height:1;display:block}.donut-cap{color:var(--text-muted);font-size:12px}.legend{flex-direction:column;flex:1;gap:12px;min-width:150px;list-style:none;display:flex}.legend li{align-items:center;gap:10px;font-size:13.5px;display:flex}.legend-dot{border-radius:4px;flex-shrink:0;width:12px;height:12px}.legend-label{color:var(--text-muted);font-weight:500}.legend-value{margin-left:auto;font-weight:700}.legend-pct{color:var(--text-faint);font-weight:500}.date-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;display:flex}.date-range{align-items:center;gap:8px;display:flex}.date-range input{border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:10px;padding:8px 12px;font-family:inherit;font-size:13.5px}.date-range input:focus{border-color:var(--primary-2);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.date-range span{color:var(--text-faint)}.login-screen{background:linear-gradient(#f1ebfe 0%,#f6f7fb 45%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);width:100%;max-width:380px;box-shadow:var(--shadow-lg);border-radius:22px;padding:32px 28px}.login-logo{background:var(--primary-grad);color:#fff;border-radius:15px;place-items:center;width:52px;height:52px;margin-bottom:18px;display:grid;box-shadow:0 8px 20px #7c3aed59}.login-logo svg{width:24px;height:24px}.login-card h1{letter-spacing:-.02em;font-size:20px;font-weight:700}.login-sub{color:var(--text-muted);margin-top:4px;margin-bottom:4px;font-size:13.5px}.password-wrap{align-items:center;display:flex;position:relative}.password-wrap input{width:100%;padding-right:56px}.password-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 8px;font-size:12.5px;font-weight:600;position:absolute;right:8px}.password-toggle:hover{background:var(--surface-2);color:var(--primary)}.menu-toggle{display:none}@media (max-width:900px){.sidebar{z-index:60;box-shadow:var(--shadow-lg);transition:transform .2s;position:fixed;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-backdrop{z-index:55;background:#161a2e66;position:fixed;inset:0}.menu-toggle{display:grid}}@media (max-width:640px){.form-row{grid-template-columns:1fr}.topbar,.main{padding-left:16px;padding-right:16px}.toolbar{flex-direction:column;align-items:stretch}.toolbar-right{flex-wrap:wrap}.search,.search input{width:100%}}.pwa-banner{border-radius:var(--radius-md);background:linear-gradient(135deg,#4f46e514,#6366f10a);border:1px solid #4f46e533;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;display:flex}.pwa-banner-text{min-width:200px;color:var(--text);flex:1;font-size:13.5px;line-height:1.5}.pwa-banner-actions{flex-wrap:wrap;gap:8px;display:flex}.care-hint{color:var(--text-muted);background:var(--blue-bg);border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:14px 18px;font-size:13px;display:flex}.care-hint svg{width:18px;height:18px;color:var(--blue);flex-shrink:0;margin-top:1px}.care-sub-bar{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;padding:0 18px 14px;display:flex}.care-table .care-note-cell{min-width:180px;max-width:260px}.care-row-done{opacity:.82}.cell-phone{color:var(--primary);font-size:12.5px;font-weight:600;text-decoration:none}.cell-phone:hover{text-decoration:underline}.care-note-input{border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);resize:vertical;border-radius:10px;width:100%;min-height:120px;padding:10px 13px;font-family:inherit;font-size:14px;transition:all .15s}.care-note-input:focus{border-color:var(--primary-2);background:var(--surface);box-shadow:0 0 0 3px var(--primary-soft);outline:none}
