.range-toggle{position:relative}.range-toggle-trigger{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:180px;padding:8px 12px;background:var(--bg-panel);color:var(--text-main-dark);border:1px solid var(--border-dark);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--ease-fast),border-color var(--ease-fast),box-shadow var(--ease-fast),transform 80ms ease}.range-toggle-trigger:hover{background:#0b132a;border-color:#6366f180}.range-toggle-trigger:active{transform:translateY(1px)}.range-toggle-trigger:focus-visible{outline:none;box-shadow:0 0 0 2px #6366f166}.range-toggle-label{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.range-toggle-caret{width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--text-muted-dark);opacity:.8}.range-toggle-popover{position:absolute;top:calc(100% + 8px);right:0;z-index:30;min-width:240px;padding:8px;background:var(--bg-panel);border:1px solid var(--border-dark);border-radius:var(--radius-md);box-shadow:0 16px 36px #0009,inset 0 1px #ffffff0a}.range-toggle-option{padding:8px 10px;border-radius:8px;font-size:14px;font-weight:600;color:var(--text-muted-dark);cursor:pointer;transition:background var(--ease-fast),color var(--ease-fast),transform 80ms ease}.range-toggle-option:hover{background:#0b132a;color:var(--text-main-dark);transform:translate(2px)}.range-toggle-option.is-active{background:linear-gradient(135deg,#6366f12e,#8b5cf62e);color:#c7d2fe}.range-inline{position:relative;display:flex;align-items:center;gap:8px}.range-inline-field{min-width:120px;padding:8px 12px;background:var(--bg-panel);color:var(--text-main-dark);border:1px solid var(--border-dark);border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--ease-fast),border-color var(--ease-fast),box-shadow var(--ease-fast)}.range-inline-field:hover{border-color:#6366f180}.range-inline-field.is-active{border-color:#6366f1e6;box-shadow:0 0 0 2px #6366f159}.range-inline-sep{color:var(--text-muted-dark);font-weight:600}.range-inline-apply{padding:8px 14px;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent-start),var(--accent-end));color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:transform 80ms ease,box-shadow var(--ease-fast),opacity var(--ease-fast)}.range-inline-apply:hover{box-shadow:0 6px 16px #6366f173;opacity:.95}.range-inline-apply:active{transform:translateY(1px)}.range-inline-calendar{position:absolute;top:calc(100% + 8px);left:0;z-index:40}.calendar{background:#020617;border:1px solid var(--border-dark);border-radius:10px;padding:10px}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:13px;font-weight:600}.calendar-header button{background:transparent;border:none;color:var(--text-muted-dark);cursor:pointer;font-size:16px}.calendar-header button:hover{color:#c7d2fe}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-dow{text-align:center;font-size:11px;color:var(--text-muted-dark)}.calendar-day{height:28px;border:none;border-radius:6px;background:transparent;color:var(--text-main-dark);font-size:12px;cursor:pointer;transition:background var(--ease-fast),transform 80ms ease}.calendar-day:hover{background:#0b132a}.calendar-day.is-selected{background:linear-gradient(135deg,var(--accent-start),var(--accent-end));color:#fff}.calendar-day.is-disabled{opacity:.25;cursor:not-allowed}.layout.light .range-toggle-trigger{background:#fff;color:var(--text-main-light);border-color:var(--border-light)}.layout.light .range-toggle-trigger:hover{background:#f1f5f9;border-color:#6366f173}.layout.light .range-toggle-caret{border-top-color:var(--text-muted-light)}.layout.light .range-toggle-popover{background:#fff;border-color:var(--border-light);box-shadow:0 16px 36px #0f172a1f,inset 0 1px #fffc}.layout.light .range-toggle-option{color:var(--text-muted-light)}.layout.light .range-toggle-option:hover{background:#f1f5f9;color:var(--text-main-light)}.layout.light .range-toggle-option.is-active{background:linear-gradient(135deg,#6366f11f,#8b5cf61f);color:#1e3a8a}.layout.light .range-inline-field{background:#fff;color:var(--text-main-light);border-color:var(--border-light)}.layout.light .range-inline-field:hover{background:#f8fafc}.layout.light .calendar{background:#fff;border-color:var(--border-light)}.layout.light .calendar-header{color:var(--text-main-light)}.layout.light .calendar-header button{color:var(--text-muted-light)}.layout.light .calendar-header button:hover{color:#1e3a8a}.layout.light .calendar-dow{color:var(--text-muted-light)}.layout.light .calendar-day{color:var(--text-main-light)}.layout.light .calendar-day:hover{background:#f1f5f9}.layout.light .calendar-day.is-disabled{opacity:.35}:root{--bg-dark: #0b1220;--bg-panel: #020617;--bg-topbar: #0f172a;--bg-light: #ffffff;--border-dark: #1e293b;--border-light: #e5e7eb;--text-main-dark: #e5e7eb;--text-main-light: #0f172a;--text-muted-dark: #94a3b8;--text-muted-light: #475569;--accent-start: #6366f1;--accent-end: #8b5cf6;--positive: #22c55e;--negative: #ef4444;--radius-sm: 10px;--radius-md: 14px;--radius-full: 999px;--ease-fast: .16s ease;--ease-med: .22s ease}:root{--bg-app: var(--bg-dark);--bg-surface: var(--bg-panel);--bg-header: var(--bg-topbar);--card-depth-overlay: linear-gradient(180deg, rgba(15, 23, 42, .92), rgba(30, 41, 59, .88));--card-depth-overlay-soft: linear-gradient(180deg, rgba(30, 41, 59, .65), rgba(51, 65, 85, .45));--border-default: var(--border-dark);--text-main: var(--text-main-dark);--text-muted: var(--text-muted-dark)}.layout.light{--bg-app: #f5f7fb;--bg-surface: #ffffff;--bg-header: var(--bg-light);--card-depth-overlay: linear-gradient(180deg, rgba(255, 224, 224, .95), rgba(226, 232, 240, .9));--card-depth-overlay-soft: linear-gradient(180deg, rgba(199, 210, 254, .75), rgba(226, 232, 240, .65));--border-default: var(--border-light);--text-main: var(--text-main-light);--text-muted: var(--text-muted-light)}:root{--pie-1: #6366f1;--pie-2: #8b5cf6;--pie-3: #22d3ee;--pie-4: #22c55e;--pie-5: #f59e0b;--pie-6: #ec4899;--pie-7: #38bdf8;--pie-8: #a3e635;--pie-9: #f97316;--pie-10: #c084fc;--pie-muted: #475569}.layout.light{--pie-1: #4f46e5;--pie-2: #7c3aed;--pie-3: #0891b2;--pie-4: #16a34a;--pie-5: #d97706;--pie-6: #db2777;--pie-7: #0284c7;--pie-8: #65a30d;--pie-9: #ea580c;--pie-10: #9333ea;--pie-muted: #cbd5e1}:root{--heatmap-empty: #0b1220;--heatmap-low: #22d3ee;--heatmap-mid: #6366f1;--heatmap-high: #8b5cf6;--heatmap-hot: #ef4444;--heatmap-fill: var(--accent-start);--heatmap-stroke: #00ffd5}.layout.light{--heatmap-empty: #f1f5f9;--heatmap-low: #0891b2;--heatmap-mid: #4f46e5;--heatmap-high: #7c3aed;--heatmap-hot: #dc2626;--heatmap-fill: #b7b7c2;--heatmap-stroke: #cbd5e1}.sidebar-custom-icon{width:22px;height:22px;object-fit:contain;transition:filter var(--ease-fast);filter:brightness(0) invert(.6)}.sidebar-item.active .sidebar-custom-icon{filter:invert(42%) sepia(79%) saturate(2253%) hue-rotate(222deg) brightness(98%) contrast(92%)}body{margin:0;font-family:Inter,system-ui,sans-serif;background:var(--bg-app);color:var(--text-main);height:100vh;overflow:hidden}.layout{display:flex;height:100vh;background:var(--bg-app);color:var(--text-main);overflow:hidden}.main{flex:1;display:flex;flex-direction:column;height:100vh;overflow:hidden}.content{flex:1;overflow-y:auto;padding:32px 36px;display:flex;flex-direction:column;gap:32px}.topbar{height:70px;display:flex;align-items:center;padding:0 24px;background:var(--bg-header);border-bottom:2px solid var(--border-default);position:sticky;top:0;z-index:10}.topbar-left{display:flex;align-items:center;gap:14px}.topbar-title{font-size:19px;font-weight:600}.topbar-center{flex:1;display:flex;justify-content:center}.topbar-actions{display:flex;align-items:center;gap:20px}.topbar-actions .icon-btn,.topbar-actions .theme-toggle{color:var(--text-muted)}.icon-btn,.theme-toggle{display:flex;align-items:center;justify-content:center;padding:6px;background:transparent;border:none;cursor:pointer;color:inherit}.icon-btn:hover,.theme-toggle:hover{background:var(--bg-surface);border-radius:var(--radius-full)}.user-chip{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg-surface);border:2px solid var(--border-default);border-radius:var(--radius-full);font-size:16px;font-weight:600}.user-menu{position:relative}.user-chip{display:flex;align-items:center;gap:6px;cursor:pointer}.user-dropdown{position:absolute;right:0;top:110%;border-radius:6px;min-width:140px;z-index:1000}.layout.dark .user-dropdown{background:#222;border:1px solid #333;color:var(--text-main)}.layout.light .user-dropdown{background:#fff;border:1px solid var(--border-default);color:var(--text-main)}.dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 12px;width:100%;background:none;border:none;color:inherit;cursor:pointer}.dropdown-item:hover{background:#ffffff14}.layout.dark .user-chip{color:var(--text-main)}.layout.dark .user-chip svg{color:var(--text-main)}.layout.dark .user-chip:hover{background:var(--bg-surface)}.sidebar{width:264px;padding:18px 14px;background:var(--bg-surface);border-right:1px solid var(--border-default);display:flex;flex-direction:column;height:100vh;overflow-y:auto;transition:width var(--ease-med),padding var(--ease-med),background-color var(--ease-med)}.sidebar-header{display:flex;align-items:center;gap:12px;padding:12px 18px 24px;margin-bottom:6px}.sidebar-logo{width:42px;height:42px;object-fit:contain}.sidebar-brand{display:flex;flex-direction:column;line-height:1.1;transition:opacity var(--ease-fast),transform var(--ease-fast)}.sidebar-title-main{font-size:18px;font-weight:600}.sidebar-title-sub{font-size:13px;font-weight:600;color:var(--text-muted)}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar-item{position:relative;display:flex;align-items:center;gap:18px;padding:10px 14px;background:transparent;border:none;font-size:15px;font-weight:600;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;margin-bottom:8px;transition:background var(--ease-fast),color var(--ease-fast),transform var(--ease-fast)}.sidebar-item:hover{background:#6366f11a;color:#c7d2fe}.sidebar-item.active{background:linear-gradient(135deg,#6366f1f2,#4f46e5f2);color:#fff;box-shadow:0 6px 18px #6366f159}.sidebar-item.active:before{content:"";position:absolute;left:-6px;top:8px;bottom:8px;width:3px;border-radius:2px;background:#a5b4fc}.sidebar-item svg{flex-shrink:0;opacity:.9}.sidebar-divider{margin:14px 10px;height:1px;background:var(--border-default)}.sidebar.collapsed{width:72px;padding:14px 8px}.sidebar.collapsed .sidebar-header{justify-content:center;padding:12px 0 20px}.sidebar.collapsed .sidebar-brand{opacity:0;transform:translate(-6px);pointer-events:none}.sidebar.collapsed .sidebar-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-item span{display:none}.sidebar.collapsed .sidebar-item.active:before{left:-4px;top:12px;bottom:12px}.section{margin-bottom:32px}.section h3{font-size:12px;font-weight:600;margin-bottom:12px;color:var(--text-muted);text-transform:uppercase}.section-header{display:flex;justify-content:center;align-items:center;gap:12px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.grid>:only-child{max-width:320px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-app)}.login-card{width:360px;padding:32px;background:var(--bg-surface);border:2px solid var(--border-default);border-radius:16px;box-shadow:0 20px 40px #00000059;animation:loginFadeIn .42s ease-out}.login-logo-wrap{display:flex;justify-content:center;margin-bottom:18px}.login-logo{width:72px;height:72px;object-fit:contain;padding:10px;border-radius:14px}.login-title{margin:0 0 24px;font-size:22px;font-weight:700;text-align:center;color:var(--text-main)}.login-form{display:flex;flex-direction:column;gap:16px}.login-form label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:600;color:var(--text-muted)}.login-form input{padding:10px 12px;background:var(--bg-app);border:2px solid var(--border-default);border-radius:8px;color:var(--text-main);font-size:15px}.login-form input:focus{outline:none;border-color:#6366f1}.login-form button{margin-top:10px;padding:12px;font-size:15px;font-weight:700;border-radius:10px;border:none;cursor:pointer;color:#fff;background:linear-gradient(135deg,#6366f1f2,#4f46e5f2)}.login-form button:disabled{opacity:.7;cursor:default}.login-error{padding:10px 12px;border-radius:8px;background:#ef444426;color:#fca5a5;font-size:14px;font-weight:600}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}to{transform:translate(0)}}.login-card.shake{animation:shake .36s ease-in-out}.sources-split{display:grid;grid-template-columns:.95fr 1.05fr;gap:42px;align-items:start}.sources-left>h3,.sources-right>h3{margin-bottom:8px}.sources-left,.sources-right{display:flex;flex-direction:column}.card{position:relative;background:var(--bg-surface);color:var(--text-main);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:22px;cursor:pointer;transition:transform var(--ease-fast),box-shadow var(--ease-fast),border-color var(--ease-fast)}.card:hover{transform:translateY(-3px);box-shadow:0 12px 26px #00000073,0 0 0 1px #6366f14d;border-color:#6366f1d9}.card:before{content:"";position:absolute;inset:0;border-radius:var(--radius-md);opacity:0;pointer-events:none;background:radial-gradient(480px circle at top left,rgba(99,102,241,.1),transparent 45%);transition:opacity var(--ease-fast)}.card:hover:before{opacity:1}.sources-split.has-active .metric-card:not(.metric-card-active){opacity:.35;transform:none;box-shadow:none}.metric-card-active{opacity:1;transform:translateY(-2px);box-shadow:0 12px 26px #00000073,0 0 0 1px #6366f199;border-color:#6366f1d9}.metric-card-active:before{opacity:1}.card h4{margin:0 0 14px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);opacity:.75}.metric-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.metric-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);opacity:.75}.metric-delta{font-size:13px;font-weight:700}.metric-value{font-size:44px;font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--text-main)}.metric-card{overflow:hidden}.metric-main{transition:opacity .15s ease}.metric-hover{position:absolute;left:0;right:0;bottom:0;padding:14px 22px;background:linear-gradient(to top,var(--card-depth-overlay) 0%,var(--card-depth-overlay-soft) 55%,transparent 100%);opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity .85s ease,transform .15s ease}.card:hover .metric-hover{opacity:1;transform:translateY(0)}.card:hover .metric-main{opacity:.25}.metric-hover-row{display:flex;justify-content:space-between;font-size:14px;font-weight:900;margin-top:6px}.metric-hover-row .label{color:var(--text-muted)}.metric-hover-row .value{font-weight:600}.positive{color:var(--positive)}.negative{color:var(--negative)}.major-block.primary .card{padding:20px;border-color:#6366f18c;box-shadow:0 0 0 1px #6366f11f}.major-block.primary .metric-value{font-size:48px}.card.skeleton{height:128px;cursor:default;background:linear-gradient(90deg,var(--bg-surface) 25%,var(--border-default) 37%,var(--bg-surface) 63%);background-size:400% 100%;animation:skeleton-loading 1.4s ease infinite}@keyframes skeleton-loading{0%{background-position:100% 0}to{background-position:0 0}}.users-analytics-card{padding:0}.users-analytics-card:hover{transform:none;box-shadow:none}.analytics-card-header{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;padding:22px 26px 16px;border-bottom:1px solid var(--border-default)}.metric-summary{cursor:pointer;padding:12px 14px;border-radius:10px;transition:background .15s ease,transform .15s ease}.metric-summary:hover{background:#7c7cff0f}.metric-summary.active{background:#7c7cff24;box-shadow:inset 0 -2px #7c7cff}.metric-summary.primary .metric-summary-value{font-size:38px}.metric-summary.primary.active{background:linear-gradient(180deg,#7c7cff2e,#7c7cff1a)}.metric-summary-title{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.metric-summary-value{display:flex;align-items:center;gap:10px;font-size:32px;font-weight:700;line-height:1.1}.metric-summary-delta{font-size:12px;font-weight:600}.chart-tooltip{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:10px 12px;box-shadow:0 12px 24px #00000073,0 0 0 1px #6366f138}.chart-tooltip-date{font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:6px}.chart-tooltip-row{display:flex;align-items:center;gap:6px;font-size:13px}.chart-tooltip-label{color:var(--text-muted);white-space:nowrap}.chart-tooltip-sep{color:var(--text-muted)}.chart-tooltip-value{font-weight:600;color:var(--text-main)}.chart-legend{display:flex;gap:14px;margin-top:8px;padding-left:8px;font-size:13px;color:var(--text-muted)}.chart-legend-item{display:flex;align-items:center;gap:6px}.chart-legend-line{width:18px;height:0;border-top:3px solid;border-radius:2px}.chart-legend-line.dashed{border-top-style:dashed}.heatmap-card{width:100%;overflow:hidden}.distribution{display:flex;flex-direction:column;gap:14px}.distribution-row{display:grid;grid-template-columns:120px 1fr 40px;gap:10px;align-items:center;font-size:13px;color:var(--text-main);transition:transform .12s ease}.distribution-row:hover{transform:translate(4px)}.distribution-row .label{color:var(--text-muted)}.distribution-row .bar{height:8px;background:var(--bg-surface);border-radius:6px;overflow:hidden}.distribution-row .fill{height:100%;background:linear-gradient(135deg,var(--accent-start),var(--accent-end));transition:width .24s ease}.distribution-row .value{text-align:right;font-weight:600;color:var(--text-main)}.pie-split-card h4{margin-bottom:2px}.pie-split-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center}.pie-large{height:260px;width:100%}.pie-breakdown{display:flex;flex-direction:column;gap:12px}.pie-breakdown-row{display:grid;grid-template-columns:0px 1fr auto;gap:14px;align-items:center;font-size:14px;color:var(--text-main);transition:opacity .12s ease,transform .12s ease;cursor:default}.pie-breakdown-row:hover{transform:translate(4px)}.pie-breakdown-dot{width:9px;height:6px;border-radius:50%}.pie-breakdown-label{color:var(--text-muted);font-weight:800;font-size:14px}.pie-breakdown-value{font-weight:600;color:var(--text-main)}@media(max-width:900px){.pie-split-layout{grid-template-columns:1fr}.pie-large{height:220px}}
