.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--color-primary);color:#fff;overflow-y:auto;overflow-x:hidden;z-index:25;transition:width var(--transition-slow)}.sidebar__brand{height:var(--header-height);display:flex;align-items:center;justify-content:center;padding:.5rem;background:#fff;border-bottom:1px solid rgba(255,255,255,.1);box-sizing:border-box;overflow:hidden}.sidebar__brand img{border-radius:var(--radius-sm)}.sidebar__nav,.sidebar__category{padding:var(--space-sm) 0}.sidebar__category-title{padding:var(--space-xs) var(--space-md);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#ffffff80;white-space:nowrap;overflow:hidden;transition:opacity var(--transition-base)}.sidebar__list{list-style:none}.sidebar__link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:#fffc;text-decoration:none;font-size:var(--font-sm);transition:background var(--transition-fast),color var(--transition-fast),padding var(--transition-slow);min-height:44px;white-space:nowrap;overflow:hidden;border-left:3px solid transparent}.sidebar__link-icon{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;opacity:.8}.sidebar__link-icon svg{width:18px;height:18px}.sidebar__link-text{overflow:hidden;text-overflow:ellipsis;transition:opacity var(--transition-base)}.sidebar__link:hover{background:#ffffff1a;color:#fff}.sidebar__link--active{background:#ffffff26;color:#fff;font-weight:600;border-left-color:var(--color-secondary)}@media (min-width: 768px) and (max-width: 1023px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar:hover{width:var(--sidebar-width);box-shadow:var(--shadow-xl)}.sidebar__brand{padding:.25rem}.sidebar__category-title{opacity:0;height:0;padding:0;overflow:hidden}.sidebar:hover .sidebar__category-title{opacity:1;height:auto;padding:var(--space-xs) var(--space-md)}.sidebar__link{justify-content:center;padding:var(--space-sm)}.sidebar:hover .sidebar__link{justify-content:flex-start;padding:var(--space-sm) var(--space-md)}.sidebar__link-text{opacity:0;width:0}.sidebar:hover .sidebar__link-text{opacity:1;width:auto}}@media (max-width: 767px){.sidebar{display:none}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);background:#ffffffeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:.5px solid var(--color-border);display:flex;justify-content:space-around;align-items:flex-start;padding-top:6px;z-index:20}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .bottom-nav{background:#1a2332eb;border-top-color:var(--color-border)}}:root[data-theme=dark] .bottom-nav{background:#1a2332eb;border-top-color:var(--color-border)}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:4px 12px;color:var(--color-text-muted);text-decoration:none;font-size:10px;transition:transform var(--transition-fast);-webkit-tap-highlight-color:transparent;position:relative}.bottom-nav__item:active{transform:scale(.9)}.bottom-nav__item--active{color:var(--color-secondary)}.bottom-nav__icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;margin-bottom:2px;transition:transform var(--transition-spring)}.bottom-nav__icon svg{width:22px;height:22px}.bottom-nav__item--active .bottom-nav__icon{transform:scale(1.05)}.bottom-nav__label{font-weight:500;letter-spacing:.01em}.bottom-nav__item--active .bottom-nav__label{font-weight:600}.header{position:fixed;top:var(--safe-area-top);left:0;right:0;height:var(--header-height);background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-md);z-index:30;transition:left var(--transition-slow)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .header{background:#1a2332d9}}:root[data-theme=dark] .header{background:#1a2332d9}.header__left{display:flex;align-items:center;gap:var(--space-sm)}.header__hamburger{display:none;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-md);transition:background var(--transition-fast)}.header__hamburger:active{background:var(--color-border-light)}.header__hamburger svg{width:22px;height:22px;color:var(--color-text)}.header__title{font-size:var(--font-md);font-weight:700;color:var(--color-primary)}.header__page-title{display:none;font-size:var(--font-sm);font-weight:600;color:var(--color-text-secondary)}.header__actions{display:flex;align-items:center;gap:var(--space-sm)}.header__user{font-size:var(--font-xs);color:var(--color-text-muted);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__spoof-container{position:relative}.header__spoof-trigger{display:flex;align-items:center;gap:4px;font-size:var(--font-xs);color:var(--color-text-muted);padding:4px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__spoof-trigger:hover{background:var(--color-bg);color:var(--color-text)}.header__spoof-chevron{flex-shrink:0;opacity:.6}.header__spoof-dropdown{position:absolute;top:100%;right:0;margin-top:4px;width:280px;max-height:360px;background:var(--color-surface, #fff);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001f;z-index:100;display:flex;flex-direction:column;overflow:hidden}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .header__spoof-dropdown{background:var(--color-surface, #1a2332)}}:root[data-theme=dark] .header__spoof-dropdown{background:var(--color-surface, #1a2332)}.header__spoof-search{padding:10px 12px;border:none;border-bottom:1px solid var(--color-border);font-size:var(--font-sm);outline:none;background:transparent;color:var(--color-text)}.header__spoof-search::placeholder{color:var(--color-text-muted)}.header__spoof-list{overflow-y:auto;max-height:300px}.header__spoof-loading,.header__spoof-empty{padding:16px 12px;text-align:center;font-size:var(--font-xs);color:var(--color-text-muted)}.header__spoof-option{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:8px 12px;text-align:left;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--color-border-light, rgba(0,0,0,.04))}.header__spoof-option:hover{background:var(--color-bg)}.header__spoof-option:disabled{opacity:.5;cursor:not-allowed}.header__spoof-option-name{font-size:var(--font-sm);font-weight:500;color:var(--color-text)}.header__spoof-option-email{font-size:var(--font-xs);color:var(--color-text-muted)}.header__spoof-badge{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#f59e0b1f;border:1px solid rgba(245,158,11,.4);border-radius:var(--radius-sm)}.header__spoof-badge-label{font-size:var(--font-xs);color:#b45309;font-weight:500}.header__spoof-badge-name{font-size:var(--font-xs);color:#92400e;font-weight:700;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .header__spoof-badge{background:#f59e0b26;border-color:#f59e0b80}:root:not([data-theme=light]) .header__spoof-badge-label{color:#fbbf24}:root:not([data-theme=light]) .header__spoof-badge-name{color:#fcd34d}}:root[data-theme=dark] .header__spoof-badge{background:#f59e0b26;border-color:#f59e0b80}:root[data-theme=dark] .header__spoof-badge-label{color:#fbbf24}:root[data-theme=dark] .header__spoof-badge-name{color:#fcd34d}.header__spoof-revert-btn{font-size:var(--font-xs);font-weight:600;color:#b45309;padding:2px 8px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.header__spoof-revert-btn:hover{background:#f59e0b33;color:#92400e}.header__spoof-revert-btn:disabled{opacity:.5;cursor:not-allowed}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .header__spoof-revert-btn{color:#fbbf24}:root:not([data-theme=light]) .header__spoof-revert-btn:hover{background:#f59e0b40;color:#fcd34d}}:root[data-theme=dark] .header__spoof-revert-btn{color:#fbbf24}:root[data-theme=dark] .header__spoof-revert-btn:hover{background:#f59e0b40;color:#fcd34d}.header__icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);transition:background var(--transition-fast),transform var(--transition-fast);color:var(--color-text-muted)}.header__icon-btn svg{width:18px;height:18px}.header__icon-btn:hover{background:var(--color-bg);color:var(--color-text)}.header__icon-btn:active{transform:scale(.9)}.header__icon-btn--quick{color:#7b2fbe}.header__icon-btn--quick:hover{color:#5a1f8e;background:#7b2fbe14}.header__icon-btn--reset{position:relative}.header__reset-toast{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;padding:2px 8px;font-size:var(--font-xs);font-weight:500;color:var(--color-success, #16a34a);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;animation:header-toast-fade 1.5s ease-out forwards;z-index:50}@keyframes header-toast-fade{0%{opacity:0;transform:translate(-50%) translateY(-2px)}15%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1}to{opacity:0}}@media (min-width: 1024px){.header{left:var(--sidebar-width)}}@media (min-width: 768px) and (max-width: 1023px){.header{left:var(--sidebar-collapsed-width)}}@media (max-width: 767px){.header{height:var(--header-height-mobile);padding:0 var(--space-sm);padding-left:calc(var(--space-sm) + var(--safe-area-left));padding-right:calc(var(--space-sm) + var(--safe-area-right))}.header__hamburger{display:flex}.header__page-title{display:block}.header__user,.header__spoof-container,.header__spoof-badge{display:none}.header__logout{font-size:var(--font-xs);padding:.25rem .5rem;min-height:32px}}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);z-index:40;opacity:0;visibility:hidden;transition:opacity var(--transition-slow),visibility var(--transition-slow)}.drawer-backdrop--visible{opacity:1;visibility:visible}.mobile-drawer{position:fixed;top:0;left:0;bottom:0;width:min(320px,85vw);background:var(--color-surface);z-index:50;transform:translate(-100%);transition:transform var(--transition-slow);overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:var(--safe-area-top);padding-bottom:var(--safe-area-bottom);box-shadow:var(--shadow-xl)}.mobile-drawer--open{transform:translate(0)}.mobile-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-surface);z-index:1}.mobile-drawer__brand{display:flex;align-items:center}.mobile-drawer__close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:background var(--transition-fast)}.mobile-drawer__close:active{background:var(--color-border-light)}.mobile-drawer__close svg{width:22px;height:22px;color:var(--color-text-muted)}.mobile-drawer__nav,.mobile-drawer__category{padding:var(--space-sm) 0}.mobile-drawer__category-title{padding:var(--space-xs) var(--space-lg);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.mobile-drawer__list{list-style:none}.mobile-drawer__link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);color:var(--color-text);text-decoration:none;font-size:var(--font-base);min-height:48px;transition:background var(--transition-fast);border-radius:0}.mobile-drawer__link:active{background:var(--color-border-light)}.mobile-drawer__link--active{color:var(--color-secondary);font-weight:600;background:#4a90d90f}.mobile-drawer__link-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mobile-drawer__link-icon svg{width:20px;height:20px}.filter-bar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-lg);overflow:hidden;transition:box-shadow var(--transition-base)}.filter-bar:hover{box-shadow:var(--shadow-xs)}.filter-bar__summary{display:none}.filter-bar__controls{display:flex;flex-wrap:wrap;gap:var(--space-md);align-items:flex-end;padding:.75rem 1rem}.filter-control{display:flex;flex-direction:column;gap:var(--space-xs)}.filter-control__label{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.filter-control__select,.filter-control__input{min-height:44px;min-width:44px;padding:.375rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-sm);background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.filter-control__select:focus,.filter-control__input:focus{outline:none;border-color:var(--color-secondary);box-shadow:0 0 0 3px #4a90d91a}.toggle-group{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.toggle-item{display:flex;align-items:center;gap:.375rem}.toggle-item__checkbox{width:20px;height:20px;cursor:pointer;accent-color:var(--color-secondary)}.toggle-item__label{font-size:var(--font-sm);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:44px;display:flex;align-items:center}@media (max-width: 767px){.filter-bar__summary{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-sm) var(--space-md);min-height:44px;background:none;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent}.filter-bar__summary-text{font-size:var(--font-sm);font-weight:500;color:var(--color-text-secondary)}.filter-bar__chevron{width:18px;height:18px;color:var(--color-text-muted);transition:transform var(--transition-base);flex-shrink:0}.filter-bar__chevron--up{transform:rotate(180deg)}.filter-bar__controls{display:none;flex-direction:column;align-items:stretch;gap:var(--space-sm);padding:0 var(--space-md) var(--space-md);animation:slideDown var(--transition-slow) ease-out}.filter-bar--expanded .filter-bar__controls{display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}}@media (min-width: 768px){.filter-bar__summary{display:none}.filter-bar__controls{display:flex}}.filter-control--states{min-width:0}.filter-chips{display:flex;flex-wrap:wrap;gap:.25rem}.filter-chip{display:inline-flex;align-items:center;padding:.2rem .5rem;font-size:var(--font-xs);font-weight:500;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-chip--active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.filter-chip--active:hover{background:var(--color-primary-dark, #4c51bf);border-color:var(--color-primary-dark, #4c51bf);color:#fff}.filter-control--analysis-period{grid-column:1 / -1;border-top:1px solid var(--color-border);padding-top:.75rem;margin-top:.5rem}.analysis-period{display:flex;flex-direction:column;gap:.5rem}.analysis-period__custom{display:flex;align-items:center;gap:.5rem;font-size:var(--font-sm)}.analysis-period__custom .filter-control__input{padding:.25rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-sm);min-height:32px}.analysis-period__arrow{color:var(--color-text-muted);font-weight:500}.analysis-period__end{color:var(--color-text-muted);font-size:var(--font-xs)}.filter-control__badge{margin-left:.5rem;padding:.1rem .4rem;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:500}@media (max-width: 767px){.filter-control--analysis-period{padding-top:.5rem;margin-top:.25rem}}.quick-chat-persistent{display:none;flex-direction:column;height:calc(100vh - var(--header-height) - 120px);min-height:400px;position:relative}.quick-chat-persistent--visible{display:flex}.quick-chat-persistent--hidden{display:flex;position:absolute;width:0;height:0;overflow:hidden;opacity:0;pointer-events:none}.quick-chat-frame{flex:1;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;min-height:0}@media (max-width: 767px){.quick-chat-persistent{height:calc(100vh - var(--header-height-mobile) - var(--bottom-nav-height) - var(--safe-area-bottom) - 80px);min-height:300px}.quick-chat-frame{border-radius:var(--radius-sm)}}.quick-chat-mobile{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl)}.quick-chat-mobile__button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-xl);background:#7b2fbe;color:#fff;border-radius:var(--radius-md);font-size:var(--font-base);font-weight:600;min-height:52px;min-width:200px;text-decoration:none;transition:background var(--transition-fast),transform var(--transition-fast)}.quick-chat-mobile__button:hover{background:#5a1f8e}.quick-chat-mobile__button:active{transform:scale(.97)}.quick-chat-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:#7b2fbe;border-radius:50%;animation:quick-chat-spin .8s linear infinite}@keyframes quick-chat-spin{to{transform:rotate(360deg)}}.app-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.app-shell--desktop{flex-direction:row;flex-wrap:wrap}.app-shell--desktop .app-shell__content{margin-left:var(--sidebar-width);margin-top:var(--header-height);padding:var(--space-lg);flex:1;min-width:0;transition:margin-left var(--transition-slow)}@media (min-width: 768px) and (max-width: 1023px){.app-shell--desktop .app-shell__content{margin-left:var(--sidebar-collapsed-width)}}.app-shell--mobile .app-shell__content{margin-top:var(--header-height-mobile);margin-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom));padding:var(--space-md);padding-left:calc(var(--space-md) + var(--safe-area-left));padding-right:calc(var(--space-md) + var(--safe-area-right));flex:1;min-width:0}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-muted);font-size:var(--font-sm);gap:var(--space-md)}.login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:var(--space-lg)}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);max-width:400px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}.login-card__logo{margin-bottom:var(--space-lg)}.login-card__logo img{max-height:48px;max-width:200px;background:#fff;padding:6px 12px;border-radius:var(--radius-sm)}.login-card__title{font-size:var(--font-2xl);font-weight:700;color:var(--color-primary);margin-bottom:var(--space-xs)}.login-card__subtitle{font-size:var(--font-sm);color:var(--color-text-muted);margin-bottom:var(--space-xl)}.login-card__message{font-size:var(--font-base);color:var(--color-text-secondary);margin-bottom:var(--space-xl);line-height:1.6}.login-card__button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-lg);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-base);font-weight:600;color:var(--color-text);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);min-height:52px}.login-card__button:hover{border-color:var(--color-secondary);box-shadow:var(--shadow-md)}.login-card__button:active{transform:scale(.98)}.login-card__google-icon{width:20px;height:20px;flex-shrink:0}.login-card__footer{margin-top:var(--space-lg);font-size:var(--font-xs);color:var(--color-text-muted)}@media (max-width: 767px){.login-card{padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-md)}}:root{--color-primary: #2B6B8C;--color-primary-light: #2a4a7f;--color-primary-dark: #0f2440;--color-secondary: #4a90d9;--color-secondary-light: #6ba8e8;--color-accent: #3182ce;--color-success: #38a169;--color-success-light: #c6f6d5;--color-danger: #e53e3e;--color-danger-light: #fed7d7;--color-warning: #d69e2e;--color-warning-light: #fefcbf;--color-bg: #f7fafc;--color-surface: #ffffff;--color-surface-elevated: #ffffff;--color-text: #1a202c;--color-text-secondary: #4a5568;--color-text-muted: #718096;--color-border: #e2e8f0;--color-border-light: #edf2f7;--color-overlay: rgba(0, 0, 0, .4);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px rgba(0, 0, 0, .05), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .06), 0 4px 6px rgba(0, 0, 0, .04);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .08), 0 10px 10px rgba(0, 0, 0, .04);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width: 240px;--sidebar-collapsed-width: 56px;--header-height: 56px;--header-height-mobile: 44px;--bottom-nav-height: 64px;--font-xs: .6875rem;--font-sm: .8125rem;--font-base: .9375rem;--font-md: 1rem;--font-lg: 1.125rem;--font-xl: 1.375rem;--font-2xl: 1.75rem;--font-3xl: 2.25rem;--safe-area-top: 0px;--safe-area-bottom: 0px;--safe-area-left: 0px;--safe-area-right: 0px}@supports (padding: env(safe-area-inset-top)){:root{--safe-area-top: env(safe-area-inset-top);--safe-area-bottom: env(safe-area-inset-bottom);--safe-area-left: env(safe-area-inset-left);--safe-area-right: env(safe-area-inset-right)}}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--color-bg: #0f1419;--color-surface: #1a2332;--color-surface-elevated: #1f2b3d;--color-text: #e8edf4;--color-text-secondary: #a0aec0;--color-text-muted: #718096;--color-border: #2d3748;--color-border-light: #1f2b3d;--color-primary-light: #4a90d9;--color-overlay: rgba(0, 0, 0, .6);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3), 0 2px 4px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .3), 0 4px 6px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .4), 0 10px 10px rgba(0, 0, 0, .2)}}:root[data-theme=dark]{--color-bg: #0f1419;--color-surface: #1a2332;--color-surface-elevated: #1f2b3d;--color-text: #e8edf4;--color-text-secondary: #a0aec0;--color-text-muted: #718096;--color-border: #2d3748;--color-border-light: #1f2b3d;--color-primary-light: #4a90d9;--color-overlay: rgba(0, 0, 0, .6);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3), 0 2px 4px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .3), 0 4px 6px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .4), 0 10px 10px rgba(0, 0, 0, .2)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;color:var(--color-text);background-color:var(--color-bg);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;padding-top:var(--safe-area-top)}button,a,input,select,textarea{min-height:44px;min-width:44px}button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}a{color:var(--color-secondary);text-decoration:none}:focus-visible{outline:2px solid var(--color-secondary);outline-offset:2px;border-radius:var(--radius-sm)}:focus:not(:focus-visible){outline:none}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:700;color:var(--color-text)}h1{font-size:var(--font-2xl)}h2{font-size:var(--font-xl)}h3{font-size:var(--font-lg)}@media (min-width: 768px){h1{font-size:var(--font-3xl)}h2{font-size:var(--font-2xl)}h3{font-size:var(--font-xl)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}#root{min-height:100vh;min-height:100dvh}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--color-border-light) 25%,var(--color-surface) 50%,var(--color-border-light) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton--text{height:1em;width:80%;margin-bottom:.5em}.skeleton--card{height:80px;border-radius:var(--radius-md)}.skeleton--chart{height:200px;border-radius:var(--radius-md)}@keyframes progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(400%)}}.progress-bar{position:fixed;top:0;left:0;right:0;height:3px;z-index:9999;overflow:hidden;background:transparent}.progress-bar:after{content:"";position:absolute;top:0;left:0;width:25%;height:100%;background:var(--color-secondary);border-radius:var(--radius-full);animation:progress-indeterminate 1.2s ease-in-out infinite}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:var(--space-md)}.loading-spinner:before{content:"";width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-secondary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
