*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#818cf8;--primary-bg:#eef2ff;--bg:#f0f2f5;--card:#fff;--text:#0f172a;--text2:#64748b;--text3:#94a3b8;--border:#e2e8f0;--shadow:0 1px 3px #0000000a,0 1px 2px #00000008;--shadow-lg:0 4px 16px #0000000f;--radius:12px;--radius-sm:8px;--transition:.2s ease}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}#root{min-height:100vh}.login-page{background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#312e81 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fffffffa;border-radius:20px;width:100%;max-width:400px;padding:48px 40px;box-shadow:0 24px 80px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-logo{background:var(--primary);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:28px;display:flex}.login-header h1{margin-bottom:6px;font-size:24px}.login-header p{color:var(--text2);font-size:14px}.login-toggle{text-align:center;color:var(--primary);cursor:pointer;margin-top:20px;font-size:14px}.login-toggle:hover{text-decoration:underline}.form-group{margin-bottom:16px}.form-group label{margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;transition:var(--transition);color:var(--text);background:#fff;padding:10px 14px;font-size:14px}.form-group input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 4px #6366f11a}.msg{border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 14px;font-size:13px}.msg-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.msg-success{color:#16a34a;background:#f0fdf4}.dashboard{flex-direction:column;height:100vh;display:flex}.topbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;background:#ffffffeb;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:10px;display:flex}.logo-box{background:var(--primary);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.topbar-left h2{font-size:16px;font-weight:700}.badge{background:var(--primary-bg);color:var(--primary-dark);border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600}.topbar-center{background:#f1f5f9;border-radius:8px;gap:2px;padding:3px;display:flex}.nav-btn{color:var(--text2);cursor:pointer;transition:var(--transition);white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 16px;font-size:13px;font-weight:500;display:flex}.nav-btn.active{color:var(--primary);box-shadow:var(--shadow);background:#fff}.nav-btn:hover:not(.active){color:var(--text)}.topbar-right{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--primary-bg);width:30px;height:30px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.user-email{color:var(--text2);font-size:13px}.btn-outline-sm{border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:var(--transition);background:0 0;border-radius:6px;padding:5px 12px;font-size:12px}.btn-outline-sm:hover{border-color:var(--primary);color:var(--primary)}.btn-ghost{border:1px dashed var(--border);color:var(--text2);cursor:pointer;transition:var(--transition);background:0 0;border-radius:8px;padding:8px 18px;font-size:13px}.btn-ghost:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.btn-primary-sm{background:var(--primary);color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:8px;padding:8px 20px;font-size:13px;font-weight:500}.btn-primary-sm:hover{background:var(--primary-dark)}.btn-primary-sm:disabled{opacity:.5;cursor:not-allowed}.dashboard-body{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:20px;overflow-y:auto}.dashboard-view{flex-direction:column;gap:16px;display:flex}.holiday-banner{border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,#1e40af,#2563eb);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 16px;display:flex;box-shadow:0 2px 12px #2563eb40}.holiday-icon{font-size:16px}.holiday-label{white-space:nowrap;font-size:13px;font-weight:600}.holiday-tags{flex-wrap:wrap;gap:4px;display:flex}.holiday-tag{white-space:nowrap;background:#ffffff1f;border-radius:20px;align-items:center;gap:3px;padding:2px 10px;font-size:11px;display:inline-flex}.holiday-tag.imp{background:#fbbf244d;border:1px solid #fbbf2480}.holiday-date{background:#ffffff26;border-radius:4px;padding:0 4px;font-size:10px;font-weight:700}.holiday-region{opacity:.7;font-size:9px}.kpi-row{grid-template-columns:repeat(6,1fr);gap:10px;display:grid}@media (width<=1000px){.kpi-row{grid-template-columns:repeat(3,1fr)}}@media (width<=600px){.kpi-row{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);transition:var(--transition);border:1px solid #0000;align-items:center;gap:12px;padding:14px;display:flex}.kpi-card:hover{box-shadow:var(--shadow-lg);border-color:var(--border);transform:translateY(-1px)}.kpi-card.action{cursor:pointer}.kpi-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex}.kpi-num{color:var(--text);font-size:22px;font-weight:700;line-height:1.2}.kpi-label{color:var(--text3);margin-top:1px;font-size:12px}.tab-bar{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);gap:2px;padding:4px;display:flex}.tab-pill{color:var(--text2);cursor:pointer;transition:var(--transition);text-align:center;white-space:nowrap;background:0 0;border:none;border-radius:6px;flex:1;padding:9px 12px;font-size:13px;font-weight:500}.tab-pill.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #6366f14d}.tab-pill:hover:not(.active){background:#f1f5f9}.tab-content{flex-direction:column;gap:14px;display:flex}.chart-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=900px){.chart-row{grid-template-columns:1fr}}.chart-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:18px}.chart-card.wide{grid-column:span 2}@media (width<=900px){.chart-card.wide{grid-column:span 1}}.chart-title{align-items:center;gap:8px;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.chart-title:before{content:"";background:var(--primary);border-radius:2px;width:3px;height:16px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}@media (width<=600px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.stat-item{background:var(--card);border-radius:var(--radius-sm);box-shadow:var(--shadow);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.stat-l{color:var(--text2);font-size:13px}.stat-v{color:var(--text);font-size:16px;font-weight:700}.split-bar-container{padding:10px 0}.split-bar{border-radius:10px;height:44px;display:flex;overflow:hidden}.split-seg{color:#fff;justify-content:center;align-items:center;font-size:14px;font-weight:600;transition:flex .5s;display:flex}.urgent-seg{background:#f97316}.normal-seg{background:var(--primary)}.ai-card{border-radius:var(--radius);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;padding:20px}.ai-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.ai-title{align-items:center;gap:12px;display:flex}.ai-icon{font-size:28px}.ai-title h4{margin:0 0 2px;font-size:15px;font-weight:600}.ai-desc{color:#64748b;margin:0;font-size:12px}.btn-ai{background:var(--primary);color:#fff;cursor:pointer;transition:var(--transition);border:none;border-radius:8px;padding:8px 20px;font-size:13px;font-weight:500}.btn-ai:hover{background:var(--primary-dark)}.btn-ai:disabled{opacity:.5;cursor:not-allowed}.btn-ai.loading{background:var(--primary-dark)}.ai-report{border-radius:var(--radius-sm);background:#fff;border:1px solid #e2e8f0;margin-top:14px;padding:16px 20px}.ai-text{color:#1e293b;white-space:pre-wrap;margin:0;font-family:inherit;font-size:14px;line-height:1.9}.import-page{max-width:720px;margin:20px auto}.import-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:28px}.import-header{margin-bottom:20px}.import-header h3{margin-bottom:4px;font-size:20px;font-weight:700}.import-header p{color:var(--text2);font-size:13px}.dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;transition:var(--transition);background:#fafbfc;border-radius:14px;padding:50px 30px}.dropzone:hover,.dropzone-active{border-color:var(--primary);background:var(--primary-bg)}.dropzone-icon{margin-bottom:12px}.dropzone-text{color:var(--text);margin-bottom:6px;font-size:16px;font-weight:500}.dropzone-hint{color:var(--text3);margin-bottom:12px;font-size:12px}.preview-area{padding:0}.preview-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.preview-count{color:var(--text);font-size:14px}.preview-count strong{color:var(--primary)}.preview-actions{gap:8px;display:flex}.field-mapping-bar{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.mapping-chip{background:#f8fafc;border-radius:6px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;display:flex}.chip-field{color:var(--primary);font-weight:600}.mapping-note{color:var(--primary-dark);background:#ede9fe;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:500}.mabang-badge{color:#92400e;vertical-align:middle;background:#fef3c7;border-radius:20px;margin-left:6px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.preview-table-wrap{margin-bottom:12px;overflow-x:auto}.preview-table{border-collapse:collapse;width:100%;font-size:12px}.preview-table th{text-align:left;color:var(--text2);border-bottom:1px solid var(--border);white-space:nowrap;background:#f8fafc;padding:8px 10px;font-weight:500}.preview-table td{white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid #f1f5f9;max-width:150px;padding:8px 10px;overflow:hidden}.preview-more{text-align:center;color:var(--text3);padding:8px;font-size:12px}.error-msg{border-radius:var(--radius-sm);color:#dc2626;background:#fef2f2;border:1px solid #fecaca;padding:10px 14px;font-size:13px}.table-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.table-bar h4{font-size:15px;font-weight:600}.table-bar .count{color:var(--primary)}.table-filters{flex-wrap:wrap;gap:6px;display:flex}.filter-input,.filter-select{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:6px;min-width:110px;padding:6px 12px;font-size:13px}.filter-input:focus,.filter-select:focus{border-color:var(--primary);outline:none}.table-wrap{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow-x:auto}.order-table{border-collapse:collapse;width:100%;font-size:13px}.order-table th{text-align:left;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);white-space:nowrap;background:#f8fafc;padding:10px 14px;font-size:11px;font-weight:500}.order-table td{white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:10px 14px}.order-table tbody tr:hover{background:#f8fafc}.orderno{color:var(--primary);font-family:monospace;font-weight:500}.cat-tag{background:var(--primary-bg);color:var(--primary-dark);border-radius:20px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.status-tag{color:#fff;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:500;display:inline-block}.empty-state{text-align:center;color:var(--text3);padding:60px 20px;font-size:15px}.filter-bar{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);flex-wrap:wrap;align-items:flex-end;gap:12px;padding:12px 16px;display:flex}.filter-group{align-items:center;gap:6px;display:flex}.filter-group label{color:var(--text2);white-space:nowrap;font-size:12px;font-weight:600}.filter-sep{color:var(--text3);font-size:13px}.btn-clear{color:#dc2626;cursor:pointer;transition:var(--transition);white-space:nowrap;background:#fef2f2;border:1px solid #fee2e2;border-radius:6px;padding:6px 14px;font-size:12px}.btn-clear:hover{background:#fee2e2}.filter-count{color:var(--text2);white-space:nowrap;margin-left:auto;font-size:13px}.filter-count strong{color:var(--primary);font-size:15px}.trend-arrow{margin-left:4px;font-size:11px;font-weight:600}.trend-arrow.up{color:#16a34a}.trend-arrow.down{color:#dc2626}.trend-s{font-size:12px;font-weight:600}.trend-s.up{color:#16a34a}.trend-s.down{color:#dc2626}.chart-card.clickable{cursor:pointer;transition:var(--transition)}.chart-card.clickable:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.chart-hint{color:var(--text3);margin-left:6px;font-size:11px;font-weight:400}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--card);border-radius:16px;width:100%;max-width:480px;padding:28px;animation:.2s modalIn;position:relative;box-shadow:0 20px 60px #0003}.modal-wide{max-width:560px}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-close{cursor:pointer;color:var(--text3);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:18px;position:absolute;top:12px;right:14px}.modal-close:hover{color:var(--text);background:#f1f5f9}.modal-card h3{margin-bottom:4px;font-size:18px;font-weight:700}.modal-desc{color:var(--text2);margin-bottom:20px;font-size:13px}.share-url-box{gap:8px;margin-bottom:16px;display:flex}.share-input{border:1px solid var(--border);color:var(--text);cursor:text;background:#f8fafc;border-radius:8px;flex:1;padding:10px 14px;font-size:13px}.share-info{color:var(--text3);flex-direction:column;gap:4px;font-size:12px;display:flex}.rules-add{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.rules-list{flex-direction:column;gap:6px;max-height:300px;margin-bottom:12px;display:flex;overflow-y:auto}.rule-item{background:#f8fafc;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.rule-keyword{color:var(--primary);background:var(--primary-bg);border-radius:4px;padding:2px 8px;font-weight:600}.rule-arrow{color:var(--text3)}.rule-cat{color:var(--text);flex:1}.rule-del{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:12px}.rule-del:hover{color:#dc2626;background:#fee2e2}.rules-footer{justify-content:space-between;align-items:center;display:flex}.rules-count{color:var(--text3);font-size:12px}.tracker-header{margin-bottom:4px}.tracker-title{margin-bottom:2px;font-size:18px;font-weight:700}.tracker-desc{color:var(--text2);margin-bottom:12px;font-size:13px}.tracker-add{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tracker-list{flex-direction:column;gap:14px;display:flex}.tracker-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:18px}.tracker-top{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.tracker-info h4{margin-bottom:2px;font-size:15px;font-weight:600}.tracker-meta{color:var(--text3);font-size:12px}.tracker-warn{color:#f59e0b;font-weight:500}.tracker-del{color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:14px}.tracker-del:hover{color:#dc2626;background:#fef2f2}.tracker-stats{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px;display:grid}.ts-item{text-align:center;background:#f8fafc;border-radius:8px;padding:10px}.ts-num{color:var(--text);font-size:16px;font-weight:700;display:block}.ts-label{color:var(--text3);margin-top:2px;font-size:11px;display:block}.tracker-chart{background:#fafbfc;border:1px solid #f1f5f9;border-radius:8px;padding:8px}.heatmap-container{padding:12px 0}.heatmap-grid{flex-direction:column;gap:4px;display:flex}.heatmap-row{align-items:center;gap:4px;display:flex}.heatmap-label{width:36px;color:var(--text2);text-align:right;flex-shrink:0;font-size:11px}.heatmap-cell{width:40px;height:36px;transition:var(--transition);border-radius:4px;justify-content:center;align-items:center;font-size:11px;display:flex}.heatmap-cell:hover{z-index:1;transform:scale(1.15)}.heatmap-legend{color:var(--text3);align-items:center;gap:8px;margin-top:12px;font-size:10px;display:flex}.hm-legend-bar{border-radius:6px;flex:1;max-width:200px;height:12px;display:flex;overflow:hidden}.compare-panel{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid #f59e0b;margin-top:12px;padding:18px}.compare-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.compare-header h4{font-size:15px;font-weight:600}.compare-body{grid-template-columns:1fr auto 1fr;align-items:flex-start;gap:16px;display:grid}@media (width<=600px){.compare-body{text-align:center;grid-template-columns:1fr}}.compare-col label{color:var(--text2);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.compare-inputs{align-items:center;gap:4px;display:flex}.compare-stats{color:var(--text);flex-wrap:wrap;gap:12px;margin-top:8px;font-size:13px;display:flex}.compare-stats div{background:#f8fafc;border-radius:6px;padding:6px 12px;font-weight:500}.compare-vs{color:#f59e0b;justify-content:center;align-items:center;padding:20px 0;font-size:24px;font-weight:700;display:flex}.compare-result{text-align:center;background:#f8fafc;border-radius:8px;margin-top:12px;padding:10px;font-size:15px;font-weight:500}.empty-sm{text-align:center;color:var(--text3);padding:30px;font-size:14px}
