@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/prompt-thai-300-normal-qs9oCq2b.woff2) format("woff2"),url(/assets/prompt-thai-300-normal-CDWjDcdW.woff) format("woff");unicode-range:U+02D7,U+0303,U+0331,U+0E01-0E5B,U+200C-200D,U+25CC}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/prompt-vietnamese-300-normal-CzHbdZ_C.woff2) format("woff2"),url(/assets/prompt-vietnamese-300-normal-D5eS_LbO.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/prompt-latin-ext-300-normal-BveSF7za.woff2) format("woff2"),url(/assets/prompt-latin-ext-300-normal-5PsZRnuW.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,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:Prompt;font-style:normal;font-display:swap;font-weight:300;src:url(/assets/prompt-latin-300-normal-CW7rmI5T.woff2) format("woff2"),url(/assets/prompt-latin-300-normal-CCBwf7Ta.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/prompt-thai-400-normal-BrkKv8cO.woff2) format("woff2"),url(/assets/prompt-thai-400-normal-DJypnfr3.woff) format("woff");unicode-range:U+02D7,U+0303,U+0331,U+0E01-0E5B,U+200C-200D,U+25CC}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/prompt-vietnamese-400-normal-BCPzsgPT.woff2) format("woff2"),url(/assets/prompt-vietnamese-400-normal-D4pLyeNK.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/prompt-latin-ext-400-normal-DdSafGZ9.woff2) format("woff2"),url(/assets/prompt-latin-ext-400-normal-1pHbN9uy.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,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:Prompt;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/prompt-latin-400-normal-BQ9zjSN8.woff2) format("woff2"),url(/assets/prompt-latin-400-normal-CxU4ec_r.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/prompt-thai-500-normal-C18pDUoL.woff2) format("woff2"),url(/assets/prompt-thai-500-normal-D7YNqUJD.woff) format("woff");unicode-range:U+02D7,U+0303,U+0331,U+0E01-0E5B,U+200C-200D,U+25CC}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/prompt-vietnamese-500-normal-DmzxmPwa.woff2) format("woff2"),url(/assets/prompt-vietnamese-500-normal-w_sS_j2F.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/prompt-latin-ext-500-normal--EZ1um7s.woff2) format("woff2"),url(/assets/prompt-latin-ext-500-normal-D-lI1EVT.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,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:Prompt;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/prompt-latin-500-normal-CxzxEHZc.woff2) format("woff2"),url(/assets/prompt-latin-500-normal-B1edBDQ9.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/prompt-thai-600-normal-MrdfU7zR.woff2) format("woff2"),url(/assets/prompt-thai-600-normal-CYPViXds.woff) format("woff");unicode-range:U+02D7,U+0303,U+0331,U+0E01-0E5B,U+200C-200D,U+25CC}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/prompt-vietnamese-600-normal-7QWjJBsF.woff2) format("woff2"),url(/assets/prompt-vietnamese-600-normal-1dyohtNh.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Prompt;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/prompt-latin-ext-600-normal-Cg9L7iJU.woff2) format("woff2"),url(/assets/prompt-latin-ext-600-normal-C8b50x67.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,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:Prompt;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/prompt-latin-600-normal-hKZWXsc1.woff2) format("woff2"),url(/assets/prompt-latin-600-normal-CSDDLorv.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--color-bg: #EFE3CA;--color-primary: #35858E;--color-primary-deep: #1F5C64;--color-primary-bright: #4FA5AF;--color-primary-light: rgba(53, 133, 142, .09);--color-gold: #C99857;--color-weekend: #E8927C;--color-card: #ffffff;--color-border: rgba(53, 133, 142, .13);--color-muted: rgba(31, 92, 100, .6)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Prompt,Noto Sans Thai,system-ui,sans-serif;font-weight:400;background:var(--color-bg);color:var(--color-primary);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input{font-family:inherit}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-card{width:100%;max-width:380px;background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:32px 28px;box-shadow:0 8px 30px #124c430f}.login-title{margin:0 0 4px;font-size:20px;font-weight:600}.login-sub{margin:0 0 24px;font-size:12.5px;color:var(--color-muted)}.field{margin-bottom:14px}.field label{display:block;font-size:11px;color:var(--color-muted);margin-bottom:6px}.field input{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:10px;font-size:14px;background:#fff;color:var(--color-primary);outline:none;transition:border-color .15s}.field input:focus{border-color:var(--color-primary)}.btn-primary{width:100%;background:var(--color-primary);color:#fff;border:0;border-radius:10px;padding:11px;font-size:14px;font-weight:500;margin-top:6px}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-msg{background:#b8504614;color:var(--color-weekend);font-size:12.5px;padding:9px 12px;border-radius:8px;margin-bottom:12px}.shell{padding:28px}@media (max-width: 768px){.shell{padding:16px}}.shell-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.shell-header h1{font-size:20px;font-weight:600;margin:0}.logout-btn{background:transparent;border:1px solid var(--color-border);border-radius:10px;padding:8px 14px;min-height:36px;color:var(--color-primary);font-size:12.5px;font-family:inherit;font-weight:500;cursor:pointer;white-space:nowrap;text-align:center}@media (max-width: 768px){.logout-btn{flex:1;min-height:44px;font-size:13px;border-radius:10px}}.admin-shell{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.admin-sidebar{background:var(--color-primary);color:#fff;padding:24px 18px;display:flex;flex-direction:column;gap:6px}.admin-sidebar h2{font-size:16px;font-weight:600;margin:0 0 18px;color:#fff}.admin-nav-link{display:block;padding:9px 12px;font-size:13px;color:#ffffffc7;text-decoration:none;border-radius:8px;transition:background .15s,color .15s}.admin-nav-link:hover{background:#ffffff14;color:#fff}.admin-nav-link.active{background:#ffffff24;color:#fff}.admin-sidebar-spacer{flex:1}.admin-sidebar-footer{font-size:11px;color:#ffffff8c;padding:10px 12px;border-top:1px solid rgba(255,255,255,.1)}.admin-content{padding:28px;background:var(--color-bg)}@media (max-width: 768px){.admin-content{padding:16px}}.admin-content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.admin-content-header h1{margin:0;font-size:20px;font-weight:600}.admin-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:20px;margin-bottom:18px}.admin-card h3{margin:0 0 14px;font-size:14px;font-weight:500}.admin-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr)) auto;gap:10px;align-items:end}.admin-form .field{margin-bottom:0}.admin-form select{width:100%;padding:10px 12px;border:1px solid var(--color-border);border-radius:10px;font-size:14px;background:#fff;color:var(--color-primary);font-family:inherit}.admin-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.admin-table th,.admin-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-border)}.admin-table th{font-weight:500;color:var(--color-muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.4px}.admin-table tr:last-child td{border-bottom:0}.btn-sm{background:transparent;border:1px solid var(--color-border);border-radius:8px;padding:5px 10px;font-size:11.5px;color:var(--color-primary);margin-right:6px}.btn-sm.danger{color:var(--color-weekend);border-color:#b850464d}.btn-sm:hover{background:var(--color-primary-light)}.role-pill{display:inline-block;padding:2px 9px;border-radius:999px;font-size:10.5px;font-weight:500}.role-pill.admin{background:var(--color-primary);color:#fff}.role-pill.viewer{background:var(--color-primary-light);color:var(--color-primary)}.empty-text{color:var(--color-muted);font-size:12.5px;text-align:center;padding:24px}@media (max-width: 768px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{flex-direction:row;padding:14px;overflow-x:auto}.admin-sidebar h2,.admin-sidebar-spacer,.admin-sidebar-footer{display:none}.admin-nav-link{white-space:nowrap}}.upload-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}@media (max-width: 768px){.upload-grid{grid-template-columns:1fr}}.upload-slot{background:var(--color-card);border:2px dashed var(--color-border);border-radius:16px;padding:18px;transition:border-color .15s,background .15s}.upload-slot.has-file{border-style:solid;background:var(--color-primary-light);border-color:var(--color-primary)}.upload-slot.uploading{border-style:solid;border-color:var(--color-gold)}.upload-slot.success{border-style:solid;border-color:#2a8772;background:#2a87720f}.upload-slot.error{border-style:solid;border-color:var(--color-weekend);background:#b850460f}.upload-slot-label{font-size:11px;color:var(--color-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.upload-slot-title{font-size:14px;font-weight:500;margin-bottom:12px}.upload-slot input[type=file]{display:block;font-size:12px;width:100%}.upload-slot-meta{font-size:11.5px;color:var(--color-muted);margin-top:8px;word-break:break-all}.upload-progress{margin-top:10px;font-size:12px;color:var(--color-primary)}.upload-result{margin-top:10px;font-size:12.5px}.upload-result.success{color:#2a8772}.upload-result.error{color:var(--color-weekend)}.banner{padding:10px 14px;border-radius:10px;font-size:12.5px;margin-bottom:14px}.banner.warn{background:#c899681f;color:#8c6a3a;border:1px solid rgba(200,153,104,.3)}.banner.info{background:var(--color-primary-light);color:var(--color-primary)}.dash-shell{min-height:100vh;padding:24px 28px 28px;background:var(--color-bg);max-width:1400px;margin:0 auto}@media (max-width: 768px){.dash-shell{padding:14px 16px 20px}}@media (max-width: 480px){.dash-shell{padding:10px 12px 16px}}.dash-billboard{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:0;background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:14px 20px;box-shadow:0 2px 12px #124c430d;flex-wrap:wrap}@media (max-width: 768px){.dash-billboard{flex-direction:column;align-items:flex-start;gap:12px;padding:14px 16px}}.dash-sticky-sentinel{width:100%;height:1px}.dash-context-bar{position:sticky;top:0;z-index:30;margin-left:-28px;margin-right:-28px;padding:8px 28px 10px;margin-bottom:18px;background:transparent;transition:background-color .22s ease,box-shadow .22s ease}@media print{.dash-context-bar{position:static}}.dash-context-bar.is-stuck{background:#f7f3ece6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 2px 16px #124c4314;border-bottom:1px solid rgba(18,76,67,.06)}@media (max-width: 768px){.dash-context-bar{margin-left:-16px;margin-right:-16px;padding-left:16px;padding-right:16px}}@media (max-width: 480px){.dash-context-bar{margin-left:-12px;margin-right:-12px;padding-left:12px;padding-right:12px}}.dash-context-bar-inner{display:flex;align-items:center;gap:12px;justify-content:space-between}@media (max-width: 768px){.dash-context-bar-inner{flex-direction:column;align-items:stretch;gap:8px}}.dash-context-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--color-border);border-radius:999px;padding:5px 14px 5px 5px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;color:var(--color-primary);box-shadow:0 1px 4px #124c430f;white-space:nowrap;flex-shrink:0;opacity:0;visibility:hidden;transform:translateY(-5px);pointer-events:none;transition:opacity .18s ease,transform .18s ease,box-shadow .15s ease,visibility 0s linear .18s}.dash-context-bar.is-stuck .dash-context-pill{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;transition:opacity .18s ease,transform .18s ease,box-shadow .15s ease,visibility 0s linear 0s}.dash-context-pill:hover{box-shadow:0 2px 8px #124c431f}.ctx-pill-logo{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-deep) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;flex-shrink:0;overflow:hidden}.ctx-pill-logo img{width:100%;height:100%;object-fit:cover;border-radius:50%}.ctx-pill-text{display:flex;align-items:center;gap:4px;min-width:0;overflow:hidden}.ctx-pill-brand{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.ctx-pill-sep{color:var(--color-muted);font-weight:400;flex-shrink:0;padding:0 1px}.ctx-pill-dim{color:var(--color-muted);font-weight:500;white-space:nowrap;flex-shrink:0}@media (max-width: 768px){.dash-context-pill{width:100%;justify-content:center;flex-shrink:0}.ctx-pill-brand{max-width:140px}}@media (prefers-reduced-motion: reduce){.dash-context-pill{transition:opacity .18s ease,visibility 0s linear .18s;transform:none!important}.dash-context-bar.is-stuck .dash-context-pill{transition:opacity .18s ease,visibility 0s linear 0s}}.dash-brand{display:flex;align-items:center;gap:14px;min-width:0}.dash-brand-text{min-width:0}.dash-logo{width:68px;height:68px;border-radius:18px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-deep) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:26px;flex-shrink:0;letter-spacing:-.02em;box-shadow:0 6px 18px #1f5c6447}.dash-logo-img{width:68px;height:68px;object-fit:cover;border-radius:18px;background:#fff;border:1px solid var(--color-border);padding:3px;box-shadow:0 6px 18px #1f5c642e;flex-shrink:0}.dash-brand-name{font-size:26px;font-weight:700;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.015em;line-height:1.15}.dash-brand-sub{font-size:11.5px;font-weight:600;color:var(--color-gold);letter-spacing:.18em;text-transform:uppercase;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-brand-meta{display:flex;align-items:center;gap:6px;margin-top:5px;flex-wrap:wrap}.dash-branch-pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:11.5px;font-weight:500;background:var(--color-primary-light);color:var(--color-primary);border:1px solid rgba(18,76,67,.12);white-space:nowrap}.dash-period-pill{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:11.5px;font-weight:600;background:var(--color-primary);color:#fff;white-space:nowrap}@media (max-width: 480px){.dash-brand-name{font-size:24px}.dash-brand-sub{font-size:13.5px;letter-spacing:.16em}.dash-logo,.dash-logo-img{width:64px;height:64px;border-radius:14px;font-size:24px}}.dash-user{font-size:11.5px;color:var(--color-muted);font-weight:500;padding:4px 2px}.dash-header-divider{width:1px;height:22px;background:var(--color-border);flex-shrink:0}.dash-action-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}@media (max-width: 768px){.dash-action-row{width:100%;display:flex;flex-wrap:wrap;gap:6px}.dash-header-divider,.dash-user{display:none}}.filter-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}@media (max-width: 768px){.filter-bar{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.filter-chip--brand,.filter-chip--branch{grid-column:1 / -1}}.filter-chip--brand{background:linear-gradient(135deg,#fffaf2,#fff);border-color:#c8996859}.filter-chip--brand svg{color:var(--color-gold)}.filter-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--color-border);border-radius:10px;padding:9px 14px;min-height:44px;font-size:12.5px;font-family:inherit;color:var(--color-primary);font-weight:500;cursor:pointer;position:relative;min-width:0}@media (max-width: 768px){.filter-chip{width:100%;min-height:48px}}.filter-chip-label{color:var(--color-muted);font-weight:400;white-space:nowrap;flex-shrink:0}.filter-chip select{background:transparent;border:0;font-family:inherit;font-size:12.5px;font-weight:500;color:var(--color-primary);cursor:pointer;outline:none;padding-right:4px;min-width:0;max-width:160px}@media (max-width: 768px){.filter-chip select{flex:1;min-width:0;max-width:none;width:100%;font-size:13px}}.filter-chip.primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.filter-chip.primary .filter-chip-label{color:#ffffffb3}.filter-chip.primary select{color:#fff}.filter-chip.primary select option{color:var(--color-primary)}.filter-chip svg{color:var(--color-gold);flex-shrink:0}.kpi-strip{display:grid;grid-template-columns:1.4fr repeat(6,1fr);gap:12px;margin-bottom:18px}.kpi-card{background:radial-gradient(circle at 95% 5%,rgba(201,152,87,.2) 0%,transparent 55%),linear-gradient(140deg,var(--color-primary) 0%,var(--color-primary-deep) 100%);border:0;border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;justify-content:space-between;min-height:124px;position:relative;overflow:visible;transition:transform .18s ease,box-shadow .18s ease;box-shadow:0 6px 20px #1f5c642e;color:#fff}.kpi-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px #1f5c6442}.kpi-card.has-tip:hover,.kpi-card.tip-open{z-index:40}.kpi-card.primary{background:radial-gradient(circle at 95% 5%,rgba(201,152,87,.22) 0%,transparent 55%),linear-gradient(140deg,var(--color-primary) 0%,var(--color-primary-deep) 100%);box-shadow:0 8px 28px #1f5c643d}.kpi-card.primary:hover{box-shadow:0 14px 36px #1f5c644d}.kpi-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.kpi-label{font-size:14px;color:#ffffffa6;font-weight:500;letter-spacing:.3px;text-transform:uppercase;line-height:1.3}@media (max-width: 768px){.kpi-label{font-size:13px}}@media (max-width: 480px){.kpi-label{font-size:16px}}.kpi-icon{width:44px;height:44px;border-radius:12px;background:#ffffff24;color:var(--color-gold);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .18s ease}.kpi-icon svg{width:24px;height:24px}.kpi-card:hover .kpi-icon{transform:scale(1.08)}.kpi-card.tone-revenue .kpi-icon{color:#f1c088}.kpi-card.tone-count .kpi-icon{color:#a8e8d0}.kpi-card.tone-ratio .kpi-icon{color:#b8dde0}.kpi-card.primary .kpi-icon{color:var(--color-gold)}.kpi-value{font-size:40px;font-weight:600;line-height:1.1;margin-top:12px;letter-spacing:-.02em;color:#fff;font-variant-numeric:tabular-nums}.kpi-card.primary .kpi-value{font-size:48px;font-weight:600;color:#fff}.yoy-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:10px;font-size:13px;line-height:1.3}.yoy-label{color:#fff9;font-weight:500;letter-spacing:.01em}.yoy-prev{color:#ffffffd9;font-weight:600;letter-spacing:-.01em}.yoy-delta{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:999px;font-weight:700;font-size:12.5px;letter-spacing:.01em;margin-left:2px}.yoy-delta.up{background:#ffffff2e;color:#a8e8d0}.yoy-delta.down{background:#e8927c47;color:#ffd0c5}.yoy-delta.flat{background:#ffffff1f;color:#fff9}.yoy-arrow{font-size:14px;line-height:1;font-weight:700;margin-right:1px}.yoy-empty{display:inline-block;margin-top:10px;font-size:11px;color:#ffffff73;font-style:italic}.kpi-card.primary .yoy-row{font-size:13.5px;margin-top:12px}.kpi-card.primary .yoy-delta{font-size:13px;padding:3px 10px}.kpi-card.primary .yoy-arrow{font-size:15px}@media (max-width: 768px){.kpi-value{font-size:38px}.kpi-card.primary .kpi-value{font-size:44px}}@media (max-width: 480px){.kpi-value{font-size:44px}.kpi-card.primary .kpi-value{font-size:52px}.yoy-row{font-size:16px;gap:5px}.yoy-delta{font-size:15px;padding:3px 9px}.kpi-card.primary .yoy-row{font-size:16px}.kpi-card.primary .yoy-delta{font-size:15px}}.kpi-card.has-tip{cursor:pointer}.kpi-card .kpi-tooltip{position:absolute;left:50%;bottom:calc(100% + 10px);transform:translate(-50%) translateY(6px);background:#fff;color:var(--color-primary-deep);font-size:13px;padding:8px 14px;border-radius:10px;white-space:nowrap;box-shadow:0 6px 24px #1f5c6438,0 1px 4px #00000014;border:1px solid rgba(53,133,142,.15);opacity:0;pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:100;max-width:calc(100vw - 32px)}.kpi-card .kpi-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#fff;filter:drop-shadow(0 1px 1px rgba(53,133,142,.12))}.kpi-tip-current{font-size:14px;font-weight:600;color:var(--color-primary);line-height:1.4}.kpi-tip-prev{font-size:12.5px;font-weight:400;color:var(--color-muted);margin-top:3px;line-height:1.4}.kpi-card.tip-open .kpi-tooltip,.kpi-card.has-tip:hover .kpi-tooltip{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}@media (max-width: 480px){.kpi-card .kpi-tooltip{font-size:15px;padding:10px 14px;white-space:normal;min-width:180px;max-width:240px;text-align:center}.kpi-tip-current{font-size:16px}.kpi-tip-prev{font-size:14px}}@media (max-width: 1180px){.kpi-strip{grid-template-columns:repeat(2,1fr)}.kpi-card.primary{grid-column:span 2;min-height:auto}}@media (max-width: 480px){.kpi-strip{grid-template-columns:1fr}.kpi-card.primary{grid-column:auto}}.dash-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:18px;margin-bottom:18px}.dash-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:10px}.dash-card-title{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:600}.dash-card-title .dot{width:6px;height:6px;border-radius:50%;background:var(--color-gold)}.dash-card-sub{font-size:13px;color:var(--color-muted);margin-top:2px}.secondary-row{display:grid;grid-template-columns:1fr 1.4fr;gap:14px;margin-bottom:18px}@media (max-width: 1024px){.secondary-row{grid-template-columns:1fr}}.chart-pair-row{display:grid;grid-template-columns:1fr 1.8fr;gap:14px;margin-bottom:18px}.chart-pair-row>.dash-card{margin-bottom:0}@media (max-width: 1024px){.chart-pair-row{grid-template-columns:1fr}}.cat-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:4px 28px}@media (max-width: 768px){.cat-grid-2col{grid-template-columns:1fr;gap:0}}.bar-value-label{font-size:11px;fill:var(--color-primary)}.bar-value-label.weekend{fill:var(--color-weekend)}.cat-row{display:grid;grid-template-columns:36px 1fr 70px 60px;align-items:center;gap:10px;padding:6px 0}.cat-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cat-icon-emoji{font-size:18px;line-height:1}.cat-icon-letter{font-size:14px;font-weight:600;line-height:1}@media (max-width: 480px){.cat-row{grid-template-columns:32px 1fr 64px 50px;gap:8px}.cat-icon{width:32px;height:32px;border-radius:8px}.cat-icon-emoji{font-size:16px}.cat-icon-letter{font-size:13px}.cat-name,.cat-value{font-size:15px}.cat-pct{font-size:14px}}.cat-name{font-size:14px;font-weight:500}.cat-bar-track{background:#124c430f;border-radius:4px;height:7px;overflow:hidden}.cat-bar-fill{height:100%;border-radius:4px}.cat-value{font-size:13px;font-weight:500;text-align:right}.cat-pct{font-size:12.5px;color:var(--color-muted);text-align:right}.top-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media (max-width: 1024px){.top-menu-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.top-menu-grid{grid-template-columns:1fr}}.mcat-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:14px;overflow:hidden;position:relative;transition:box-shadow .18s ease,transform .18s ease}.mcat-card:hover{box-shadow:0 8px 24px #124c4317;transform:translateY(-2px)}.mcat-accent{height:4px;width:100%}.mcat-header{display:flex;align-items:center;gap:10px;padding:12px 14px 10px;border-bottom:1px solid var(--color-border)}.mcat-icon-wrap{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mcat-icon{font-size:18px;line-height:1}.mcat-title-wrap{min-width:0}.mcat-title{font-size:15px;font-weight:700;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mcat-sub{font-size:12px;color:var(--color-muted);margin-top:1px}.mcat-list{padding:6px 14px 12px;display:flex;flex-direction:column;gap:9px}.mcat-item{display:grid;grid-template-columns:22px 1fr auto;align-items:center;gap:8px}.mcat-rank{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.mcat-name-wrap{min-width:0;display:flex;flex-direction:column;gap:3px}.mcat-name{font-size:13px;font-weight:500;color:var(--color-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.mcat-bar-track{height:4px;background:#124c4312;border-radius:999px;overflow:hidden}.mcat-bar-fill{height:100%;border-radius:999px;opacity:.6;transition:width .4s ease}.mcat-value{font-size:13px;font-weight:700;white-space:nowrap;text-align:right}.toggle-pill{display:inline-flex;background:#124c430f;border-radius:999px;padding:3px}.toggle-pill button{background:transparent;border:0;padding:6px 14px;min-height:32px;font-size:13px;border-radius:999px;color:var(--color-muted);font-family:inherit}.toggle-pill button.active{background:var(--color-primary);color:#fff}.toggle-pill button:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 480px){.toggle-pill button{font-size:15px;padding:8px 16px;min-height:44px}.mcat-rank{width:26px;height:26px;font-size:15px;border-radius:7px}.mcat-name{font-size:16px}.mcat-sub{font-size:14px}.mcat-value{font-size:15px}.mcat-title{font-size:16px}}.hourly-chart-wrap{width:100%}.hourly-chart-controls{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:12px}.hourly-legend{display:inline-flex;align-items:center;gap:14px;font-size:12.5px;color:var(--color-muted)}.hourly-legend-item{display:inline-flex;align-items:center;gap:6px;font-weight:500}.legend-swatch{width:10px;height:10px;border-radius:3px;display:inline-block}.hourly-empty-note{font-size:12.5px;color:var(--color-muted);font-style:italic;margin:-4px 0 10px;text-align:center}.hourly-tip{background:#fff;border:1px solid rgba(18,76,67,.12);border-radius:10px;padding:10px 12px;font-size:12.5px;box-shadow:0 8px 24px #124c431f;min-width:180px}.hourly-tip-time{color:var(--color-muted);font-size:12px;font-weight:600;margin-bottom:6px;letter-spacing:.02em;text-transform:uppercase}.hourly-tip-row{display:flex;align-items:center;gap:8px;padding:3px 0}.hourly-tip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.hourly-tip-label{color:var(--color-muted);font-size:12.5px;flex:1}.hourly-tip-value{color:var(--color-primary);font-weight:600;font-size:12.5px;letter-spacing:-.01em}.hourly-tip-delta{margin-top:6px;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;display:inline-block}.hourly-tip-delta.up{background:#2a877224;color:#2a8772}.hourly-tip-delta.down{background:#b8504624;color:var(--color-weekend)}.hourly-tip-delta.flat{background:#124c4314;color:var(--color-muted)}.hourly-tip-meta{font-size:12px;color:var(--color-muted);margin-top:6px;border-top:1px solid rgba(18,76,67,.06);padding-top:6px}@media (max-width: 480px){.hourly-chart-controls{flex-direction:column;align-items:flex-start}.hourly-legend{font-size:13px;gap:10px}.hourly-tip{font-size:14px;padding:12px 14px;min-width:200px}.hourly-tip-time,.hourly-tip-label{font-size:15px}.hourly-tip-value{font-size:16px}.hourly-tip-meta,.hourly-tip-delta{font-size:13px}}.shift-chart-wrap{width:100%}.shift-legend{display:flex;flex-wrap:wrap;align-items:center;gap:4px 16px;margin-bottom:14px;font-size:12.5px;color:var(--color-muted)}.shift-legend-item{display:inline-flex;align-items:center;gap:6px;font-weight:500}@media (max-width: 480px){.shift-legend{gap:4px 12px;font-size:13.5px}}.brand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px}.brand-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;padding:20px 16px 16px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;transition:box-shadow .18s ease,transform .18s ease}.brand-card:hover{box-shadow:0 8px 24px #124c4317;transform:translateY(-2px)}.brand-logo-zone{position:relative;cursor:pointer;border-radius:16px;overflow:hidden;border:2px dashed var(--color-border);transition:border-color .18s ease;flex-shrink:0}.brand-logo-zone:hover,.brand-logo-zone.dragging{border-color:var(--color-primary);border-style:solid}.brand-logo-zone.uploading{opacity:.7;cursor:wait}.brand-logo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#124c43b8;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .18s ease;border-radius:14px}.brand-logo-zone:hover .brand-logo-overlay,.brand-logo-zone.dragging .brand-logo-overlay,.brand-logo-zone.uploading .brand-logo-overlay{opacity:1}.brand-logo-hint{color:#fff;font-size:11.5px;font-weight:600;text-align:center;padding:4px 8px}.brand-logo-img{object-fit:contain;display:block;border-radius:14px;background:var(--color-bg)}.brand-logo-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;font-weight:600;border-radius:14px;letter-spacing:.03em}.brand-card-body{width:100%}.brand-card-name{font-size:14px;font-weight:600;color:var(--color-primary);margin-bottom:6px;word-break:break-word}.brand-card-meta{display:flex;justify-content:center;gap:6px}.brand-branch-pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:500;background:var(--color-primary-light);color:var(--color-primary)}.brand-edit-form{display:flex;flex-direction:column}.brand-edit-input{width:100%;padding:8px 10px;border:1px solid var(--color-primary);border-radius:8px;font-size:13px;font-family:inherit;outline:none;color:var(--color-primary)}.brand-card-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;width:100%;padding-top:4px;border-top:1px solid var(--color-border)}.hist-section{background:var(--color-card);border:1px solid var(--color-border);border-radius:16px;overflow:hidden;margin-bottom:18px}.hist-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--color-border);flex-wrap:wrap}.hist-title{font-size:14px;font-weight:600;color:var(--color-primary)}.hist-sub{font-size:11.5px;color:var(--color-muted);margin-top:2px}.hist-filters{display:flex;gap:8px;flex-wrap:wrap}.hist-select{padding:6px 10px;border:1px solid var(--color-border);border-radius:8px;font-size:12.5px;font-family:inherit;color:var(--color-primary);background:var(--color-bg);cursor:pointer;outline:none;min-height:34px}.hist-select:focus{border-color:var(--color-primary)}.hist-loading{padding:16px 20px}.hist-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.hist-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12.5px;min-width:680px}.hist-table th{padding:9px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--color-muted);text-transform:uppercase;letter-spacing:.4px;background:var(--color-bg);border-bottom:1px solid var(--color-border);white-space:nowrap}.hist-table td{padding:10px 14px;border-bottom:1px solid var(--color-border);vertical-align:middle}.hist-row:last-child td{border-bottom:0}.hist-row:hover td{background:var(--color-primary-light)}.hist-branch-name{display:block;font-weight:500;font-size:12.5px}.hist-branch-code{display:inline-block;margin-top:2px;font-size:10.5px;color:var(--color-muted);background:var(--color-primary-light);padding:1px 6px;border-radius:4px}.hist-yearmonth{font-weight:600;font-size:13px;color:var(--color-primary);white-space:nowrap}.hist-filename{font-size:11.5px;color:var(--color-muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hist-rows{text-align:right;font-variant-numeric:tabular-nums;font-weight:500;white-space:nowrap}.hist-user{font-size:12px;color:var(--color-muted)}.hist-time{font-size:11.5px;color:var(--color-muted);white-space:nowrap;cursor:default}.hist-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-top:1px solid var(--color-border);gap:12px;flex-wrap:wrap}.hist-pagesize{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--color-muted)}.hist-pagination{display:flex;align-items:center;gap:4px}.hist-page-btn{min-width:32px;height:32px;padding:0 6px;border:1px solid var(--color-border);border-radius:8px;background:#fff;font-size:12.5px;font-family:inherit;color:var(--color-primary);cursor:pointer;transition:background .15s,border-color .15s;display:flex;align-items:center;justify-content:center}.hist-page-btn:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary)}.hist-page-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:600}.hist-page-btn:disabled{opacity:.35;cursor:not-allowed}.hist-page-ellipsis{width:28px;text-align:center;font-size:12px;color:var(--color-muted)}@media (max-width: 640px){.hist-header{flex-direction:column}.hist-filters{width:100%}.hist-select{flex:1}.hist-footer{flex-direction:column;align-items:flex-start}.hist-pagesize{font-size:12px}}@keyframes shimmer{0%{opacity:.35}50%{opacity:.8}to{opacity:.35}}.skeleton{animation:shimmer 1.5s ease-in-out infinite;background:#124c431a;border-radius:6px}.empty-state{text-align:center;padding:60px 20px;background:var(--color-card);border-radius:16px;border:1px solid var(--color-border)}.empty-state-icon{font-size:40px;margin-bottom:12px;opacity:.5}.empty-state h3{font-size:15px;font-weight:500;margin:0 0 6px}.empty-state p{font-size:13px;color:var(--color-muted);margin:0}
