.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}.login-container{width:100%;max-width:420px;background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:48px 40px}.login-header{text-align:center;margin-bottom:40px}.login-header h1{font-size:32px;font-weight:600;color:var(--text);margin:0 0 8px;letter-spacing:.5px}.login-header p{font-size:14px;color:var(--muted);margin:0}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:500;color:var(--text)}.form-group input{width:100%;padding:12px 16px;font-size:14px;color:var(--text);background:var(--bg);border:1px solid rgba(255,255,255,.08);border-radius:6px;outline:none;transition:all .2s;font-family:inherit}.form-group input::placeholder{color:var(--muted)}.form-group input:focus{border-color:var(--primary);background:var(--card)}.form-group input:disabled{opacity:.5;cursor:not-allowed}.error-message{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:13px;line-height:1.5}.login-button{width:100%;padding:14px 24px;font-size:14px;font-weight:500;color:#fff;background:var(--primary);border:none;border-radius:6px;cursor:pointer;transition:all .2s;margin-top:8px}.login-button:hover:not(:disabled){background:#06f;transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.sticky{position:sticky;top:0;z-index:50;background:#f6f8fbe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(226,232,240,.95)}.sticky-inner{width:var(--container);margin:0 auto;padding:14px 20px 10px}.top-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:10px}.title{font-size:22px;font-weight:680;letter-spacing:.2px}.tabs{display:flex;gap:8px;align-items:center}.tab{padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--muted);font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:.15s ease;box-shadow:0 1px #0f172a05}.tab:hover{transform:translateY(-1px)}.tab.active{color:var(--text);border-color:#2563eb40;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 8px 22px #2563eb1a}.tab.disabled{opacity:.6;cursor:not-allowed}.tab.disabled:hover{transform:none}.period-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.period{display:flex;gap:6px;padding:6px;background:#ffffffc7;border:1px solid var(--line);border-radius:999px;box-shadow:0 1px #0f172a05}.pill{padding:8px 12px;border-radius:999px;font-size:13px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;transition:.15s ease;border:1px solid transparent;white-space:nowrap}.pill:hover{background:#2563eb0f}.pill.active{color:var(--text);background:var(--primary-weak);border-color:#2563eb33}.period-meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:10px}.badge{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#ffffffe0}.logout-btn{padding:8px 16px;font-size:13px;font-weight:500;color:var(--muted);background:var(--card);border:1px solid var(--line);border-radius:999px;cursor:pointer;transition:all .15s ease;box-shadow:0 1px #0f172a05}.logout-btn:hover{color:var(--text);background:#fffffff2;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.custom-date-picker{position:absolute;top:100%;right:20px;margin-top:8px;z-index:100;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #0000001f;min-width:400px}.date-picker-content{padding:20px}.date-picker-header{margin-bottom:16px}.date-picker-header h3{font-size:16px;font-weight:600;color:var(--text);margin:0}.date-picker-inputs{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.date-input-group{display:flex;flex-direction:column;gap:6px}.date-input-group label{font-size:13px;font-weight:500;color:var(--text)}.date-input-group input[type=date]{padding:10px 12px;font-size:14px;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--text);font-family:inherit;transition:all .15s ease}.date-input-group input[type=date]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.date-picker-actions{display:flex;gap:8px;justify-content:flex-end}.date-picker-actions button{padding:8px 16px;font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s ease;border:1px solid var(--line)}.btn-cancel{background:var(--card);color:var(--muted)}.btn-cancel:hover{background:var(--bg);color:var(--text)}.btn-apply{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-apply:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.btn-apply:disabled{opacity:.5;cursor:not-allowed}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.shimmer{animation:shimmer 2s infinite linear;background:linear-gradient(to right,#ffffff0d,#ffffff26,#ffffff0d);background-size:1000px 100%}.skeleton-box{background:#ffffff0d;border-radius:6px;overflow:hidden}.skeleton-line{height:12px;background:#ffffff14;border-radius:4px;margin-bottom:8px}.skeleton-line:last-child{margin-bottom:0}.hero-skeleton{padding:24px}.hero-skeleton .skeleton-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.hero-skeleton .skeleton-title{flex:1}.hero-skeleton .skeleton-meta{display:flex;gap:8px;flex-wrap:wrap}.hero-skeleton .skeleton-chip{width:80px;height:28px;background:#ffffff0d;border-radius:999px}.hero-skeleton .skeleton-chart{width:100%;height:240px;background:#ffffff08;border-radius:8px;position:relative;overflow:hidden}.kpi-skeleton{padding:20px}.kpi-skeleton .skeleton-title{width:60%;height:16px;margin-bottom:16px}.kpi-skeleton .skeleton-value{width:50%;height:32px;margin-bottom:8px}.kpi-skeleton .skeleton-subtitle{width:70%;height:12px;margin-bottom:16px}.kpi-skeleton .skeleton-chips{display:flex;gap:8px;margin-bottom:16px}.kpi-skeleton .skeleton-chip{width:100px;height:24px;background:#ffffff0d;border-radius:999px}.kpi-skeleton .skeleton-sparkline{width:100%;height:80px;background:#ffffff08;border-radius:6px;margin-top:12px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.tooltip{position:fixed;z-index:100;pointer-events:none;background:#0f172aeb;color:#fff;font-size:12px;padding:8px 10px;border-radius:10px;box-shadow:0 10px 25px #0000002e;opacity:0;transform:translateY(6px);transition:opacity .12s ease,transform .12s ease;max-width:340px;line-height:1.25}.tooltip.show{opacity:1;transform:translateY(0)}.tooltip .t-muted{color:#ffffffbf;margin-top:4px;font-size:11px}#root{width:100%;min-height:100vh}:root{--bg: #f6f8fb;--card: #ffffff;--text: #0f172a;--muted: #64748b;--line: #e2e8f0;--primary: #2563eb;--primary-weak: #dbeafe;--good: #16a34a;--bad: #dc2626;--shadow: 0 6px 20px rgba(15, 23, 42, .06);--radius: 16px;--container: 1440px;--font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji"}*{box-sizing:border-box}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg)}.wrap{width:var(--container);margin:0 auto;padding:18px 20px 56px}.section{margin-top:18px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;position:relative;overflow:hidden}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.card-title{font-size:13px;color:var(--muted);font-weight:650;letter-spacing:.2px}.big{font-size:30px;font-weight:760;letter-spacing:.2px;line-height:1.05}.sub{margin-top:6px;font-size:12px;color:var(--muted)}.delta{font-size:12px;font-weight:700;padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#f8fafce6;white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none}.delta.good{color:var(--good);border-color:#16a34a33;background:#16a34a0f}.delta.bad{color:var(--bad);border-color:#dc262633;background:#dc26260f}.delta.neutral{color:var(--muted)}.chart-card{min-height:320px}.chart-card.hero{min-height:360px}.chart-title{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.chart-title h3{margin:0;font-size:15px;font-weight:760;letter-spacing:.2px}.chart-title small{color:var(--muted);font-size:12px;display:block;margin-top:2px}.chart-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.chip{font-size:12px;color:var(--muted);padding:6px 10px;border-radius:999px;border:1px solid var(--line);background:#f8fafcd9;cursor:default;-webkit-user-select:none;user-select:none}.chip.btn{cursor:pointer;transition:.12s ease}.chip.btn:hover{transform:translateY(-1px)}.chip.btn.active{background:#2563eb1a;border-color:#2563eb40;color:var(--text)}.kpi-inline{display:flex;align-items:baseline;gap:8px}.kpi-inline .value{font-size:18px;font-weight:800}.kpi-inline .unit{font-size:12px;color:var(--muted);font-weight:650}.chart-area{margin-top:8px;border-top:1px dashed rgba(226,232,240,.9);padding-top:10px}.mini{min-height:220px}.mini .big{font-size:26px}.mini .spark{margin-top:10px;border-top:1px dashed rgba(226,232,240,.9);padding-top:10px}.hint{font-size:11px;color:var(--muted)}svg{display:block}.axis text{font-size:11px;fill:var(--muted);font-weight:650}.grid line{stroke:#e2e8f0e6;stroke-width:1}.line{fill:none;stroke:#2563ebe6;stroke-width:2.4}.area{fill:#2563eb1a}.dot{fill:#fff;stroke:#2563ebe6;stroke-width:2;cursor:pointer}
