*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:#f5f5f5;color:#111;font-size:14px;line-height:1.6}.app{min-height:100vh}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.login-card{background:#fff;border-radius:12px;border:1px solid #e5e5e5;padding:40px;width:380px}.login-title{font-size:20px;font-weight:600;margin-bottom:6px}.login-sub{font-size:13px;color:#888;margin-bottom:28px}.form-group{margin-bottom:16px}.form-label{font-size:12px;font-weight:500;color:#555;margin-bottom:6px;display:block}.form-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;outline:none;transition:border-color .15s}.form-input:focus{border-color:#111}.login-btn{width:100%;padding:11px;background:#111;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;margin-top:8px;transition:background .15s}.login-btn:hover{background:#333}.login-btn:disabled{background:#aaa;cursor:not-allowed}.login-error{color:#dc2626;font-size:12px;margin-top:10px;text-align:center}.dash-header{background:#fff;border-bottom:1px solid #e5e5e5;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.dash-logo{font-size:15px;font-weight:600}.dash-logo span{color:#888;font-weight:400}.header-right{display:flex;align-items:center;gap:16px}.refresh-info{font-size:12px;color:#888}.refresh-btn{padding:6px 14px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:12px;cursor:pointer;font-weight:500}.refresh-btn:hover{background:#f5f5f5}.logout-btn{padding:6px 14px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:12px;cursor:pointer;color:#888}.dash-body{padding:24px;max-width:1400px;margin:0 auto}.tab-bar{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid #e5e5e5}.tab-btn{padding:10px 20px;border:none;background:none;font-size:13px;font-weight:500;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}.tab-btn.active{color:#111;border-bottom-color:#111}.tab-btn:hover:not(.active){color:#555}.offer-toggle{display:flex;gap:6px;margin-bottom:20px}.offer-btn{padding:6px 16px;border-radius:20px;border:1px solid #ddd;background:#fff;font-size:12px;font-weight:500;cursor:pointer;color:#555;transition:all .15s}.offer-btn.active{background:#111;color:#fff;border-color:#111}.date-bar{display:flex;gap:8px;margin-bottom:24px;align-items:center;flex-wrap:wrap}.date-btn{padding:6px 14px;border:1px solid #ddd;border-radius:6px;background:#fff;font-size:12px;cursor:pointer;color:#555}.date-btn.active{background:#111;color:#fff;border-color:#111}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}.kpi-card{background:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:16px}.kpi-label{font-size:11px;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.kpi-value{font-size:24px;font-weight:600;color:#111}.kpi-sub{font-size:11px;color:#aaa;margin-top:4px}.kpi-up{color:#16a34a;font-size:11px;margin-top:4px}.kpi-down{color:#dc2626;font-size:11px;margin-top:4px}.card{background:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:20px;margin-bottom:16px}.card-title{font-size:13px;font-weight:600;color:#111;margin-bottom:16px}.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;padding:8px 12px;font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid #e5e5e5;white-space:nowrap}td{padding:10px 12px;border-bottom:1px solid #f0f0f0;color:#111}tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500}.badge-green{background:#dcfce7;color:#16a34a}.badge-amber{background:#fef9c3;color:#ca8a04}.badge-red{background:#fee2e2;color:#dc2626}.badge-blue{background:#dbeafe;color:#2563eb}.badge-gray{background:#f3f4f6;color:#6b7280}.alert{padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:16px}.alert-warning{background:#fffbeb;border:1px solid #fcd34d;color:#92400e}.alert-info{background:#eff6ff;border:1px solid #93c5fd;color:#1e40af}.alert-success{background:#f0fdf4;border:1px solid #86efac;color:#166534}.coming-soon{text-align:center;padding:48px 24px;color:#888}.coming-soon h3{font-size:16px;font-weight:600;color:#111;margin-bottom:8px}.coming-soon p{font-size:13px}.day-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}.day-label{font-size:12px;font-weight:500;width:90px;flex-shrink:0;color:#555}.day-track{flex:1;height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}.day-fill{height:100%;border-radius:4px;transition:width .3s}.day-val{font-size:12px;width:70px;text-align:right;color:#555;flex-shrink:0}.loading{text-align:center;padding:48px;color:#888;font-size:13px}.spinner{width:24px;height:24px;border:2px solid #e5e5e5;border-top-color:#111;border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.card-grid{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}.dash-body{padding:16px}}
