:root{--bg: #FCFAF7;--bg-subtle: #F6F4F0;--bg-well: #EFEEEA;--card: #FFFFFF;--card-hover: rgba(255, 255, 255, .8);--text-1: #1C1C1A;--text-2: #4D4D4B;--text-3: #8C8C88;--accent: #2D5BFF;--accent-soft: rgba(45, 91, 255, .05);--up: #10B981;--up-soft: rgba(16, 185, 129, .05);--warn: #F59E0B;--warn-soft: rgba(245, 158, 11, .05);--down: #EF4444;--down-soft: rgba(239, 68, 68, .05);--border: rgba(0, 0, 0, .04);--border-active: rgba(0, 0, 0, .08);--border-luxury: rgba(0, 0, 0, .02);--shadow-luxury: 0 1px 2px rgba(0, 0, 0, .02), 0 4px 12px rgba(0, 0, 0, .03);--shadow-hover: 0 2px 4px rgba(0, 0, 0, .02), 0 12px 24px rgba(0, 0, 0, .04);--font-display: "Outfit", "Inter", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "IBM Plex Mono", "JetBrains Mono", monospace;--sidebar-width: 260px;--header-height: 72px;--radius-sm: 8px;--radius: 12px;--radius-lg: 18px;--radius-xl: 32px;--ease-premium: cubic-bezier(.2, 0, 0, 1);--duration: .25s}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:15px;-webkit-font-smoothing:antialiased;letter-spacing:-.011em}body{font-family:var(--font-body);background:var(--bg);color:var(--text-2);line-height:1.6;overflow:hidden;-webkit-user-select:none;user-select:none}#root{height:100vh;display:flex}*:focus{outline:none}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--text-1);color:#fff;padding:8px 16px;z-index:10000;font-weight:600;border-radius:0 0 var(--radius-sm) 0;transition:top .2s ease}.skip-link:focus{top:0}.app-layout{display:flex;width:100%;height:100vh}.sidebar{width:var(--sidebar-width);height:100vh;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;position:fixed;left:0;top:0;z-index:100}.sidebar-brand{padding:20px 20px 16px;border-bottom:1px solid var(--border)}.sidebar-brand h1{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.sidebar-brand span{font-family:var(--font-mono);font-size:.7rem;color:var(--text-3);display:block;margin-top:2px}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-2);text-decoration:none;font-size:.875rem;font-weight:500;transition:all var(--duration) var(--ease-premium);cursor:pointer;border:none;background:none;width:100%;text-align:left;min-height:44px}.sidebar-link:hover{background:var(--bg-subtle);color:var(--text-1)}.sidebar-link:focus-visible{background:var(--accent-soft);color:var(--accent)}.sidebar-link.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.sidebar-link svg{width:18px;height:18px;flex-shrink:0}.sidebar-account{padding:12px;border-top:1px solid var(--border);margin-top:auto}.account-switcher{width:100%;padding:8px 28px 8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-subtle);color:var(--text-1);font-family:var(--font-body);font-size:.8rem;font-weight:500;cursor:pointer;transition:border-color var(--duration) var(--ease-premium);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.account-switcher:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-color:var(--accent)}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{height:var(--header-height);background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.header-left{display:flex;align-items:center;gap:16px}.header-title{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--text-1)}.header-subtitle{font-size:.8rem;color:var(--text-3);font-family:var(--font-mono)}.header-right{display:flex;align-items:center;gap:12px}.page-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px}.page-content::-webkit-scrollbar{width:6px}.page-content::-webkit-scrollbar-track{background:transparent}.page-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.page-content::-webkit-scrollbar-thumb:hover{background:var(--border-active)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-luxury);transition:box-shadow var(--duration) var(--ease-premium)}.card:hover{box-shadow:var(--shadow-hover)}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--text-1)}.card-body{padding:20px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-luxury)}.kpi-label{font-size:.75rem;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.kpi-value{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--text-1);letter-spacing:-.02em;line-height:1.2}.kpi-trend{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;margin-top:6px;padding:2px 6px;border-radius:4px}.kpi-trend.up{color:var(--up);background:var(--up-soft)}.kpi-trend.down{color:var(--down);background:var(--down-soft)}.kpi-trend.neutral{color:var(--text-3);background:var(--bg-subtle)}.campaign-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;margin-bottom:24px}.campaign-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-luxury);cursor:pointer;transition:all var(--duration) var(--ease-premium)}.campaign-card:hover{box-shadow:var(--shadow-hover);border-color:var(--accent);transform:translateY(-1px)}.campaign-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.campaign-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-1);line-height:1.3}.campaign-objective{font-size:.7rem;color:var(--text-3);font-family:var(--font-mono);margin-top:2px}.campaign-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.campaign-metric{text-align:center}.campaign-metric-label{font-size:.65rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.campaign-metric-value{font-family:var(--font-mono);font-size:.9rem;font-weight:500;color:var(--text-1);margin-top:2px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.status-dot.active{background:var(--up);box-shadow:0 0 0 3px var(--up-soft)}.status-dot.paused{background:var(--warn);box-shadow:0 0 0 3px var(--warn-soft)}.status-dot.learning{background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-badge.active{background:var(--up-soft);color:var(--up)}.status-badge.paused{background:var(--warn-soft);color:var(--warn)}.status-badge.learning{background:var(--accent-soft);color:var(--accent)}.mode-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600}.mode-badge.exploring{background:#8b5cf61a;color:#14b8a6}.mode-badge.exploiting{background:var(--up-soft);color:var(--up)}.mode-badge.transition{background:var(--warn-soft);color:var(--warn)}.mode-badge.lost{background:var(--down-soft);color:var(--down)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.825rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all var(--duration) var(--ease-premium);min-height:44px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent);opacity:.9}.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--card);color:var(--text-1);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-subtle);border-color:var(--border-active)}.btn-secondary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-ghost{background:transparent;color:var(--text-2);border:none;padding:6px 10px}.btn-ghost:hover{background:var(--bg-subtle);color:var(--text-1)}.btn svg{width:16px;height:16px}.refresh-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);color:var(--text-2);font-family:var(--font-body);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--duration) var(--ease-premium);min-height:44px}.refresh-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.refresh-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-btn.loading svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.refresh-meta{font-family:var(--font-mono);font-size:.65rem;color:var(--text-3)}.rate-limit{font-family:var(--font-mono);font-size:.65rem;padding:2px 6px;border-radius:3px}.rate-limit.safe{background:var(--up-soft);color:var(--up)}.rate-limit.warning{background:var(--warn-soft);color:var(--warn)}.rate-limit.danger{background:var(--down-soft);color:var(--down)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto}.tab{padding:12px 18px;font-size:.825rem;font-weight:500;color:var(--text-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all var(--duration) var(--ease-premium);min-height:44px}.tab:hover{color:var(--text-2)}.tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.8rem}.data-table thead th{position:sticky;top:0;background:var(--bg-subtle);padding:12px 16px;text-align:left;font-weight:600;font-size:.7rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap}.data-table thead th:first-child{border-radius:var(--radius-sm) 0 0 0}.data-table thead th:last-child{border-radius:0 var(--radius-sm) 0 0}.data-table tbody td{padding:12px 16px;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:.78rem;color:var(--text-1)}.data-table tbody tr:hover{background:var(--bg-subtle)}.data-table tbody tr:last-child td{border-bottom:none}.data-table .col-date{font-weight:500;white-space:nowrap}.data-table .col-currency,.data-table .col-pct,.data-table .col-num{text-align:right}.font-data{font-family:var(--font-mono)!important;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.hover-row:hover{background:var(--bg-well)!important;cursor:crosshair}.shadow-luxury{box-shadow:var(--shadow-luxury)}.border-luxury{border:1px solid var(--border-luxury)}.inset-well{background:var(--bg-well);box-shadow:inset 0 1px 4px #00000005}.table-container{overflow-x:auto;overflow-y:auto;max-height:600px;border:1px solid var(--border);border-radius:var(--radius)}.table-container::-webkit-scrollbar{width:8px;height:8px}.table-container::-webkit-scrollbar-track{background:var(--bg-subtle);border-radius:4px}.table-container::-webkit-scrollbar-thumb{background:var(--text-3);border-radius:4px;opacity:.5}.table-container::-webkit-scrollbar-thumb:hover{background:var(--text-2)}.skeleton{background:linear-gradient(90deg,var(--bg-subtle) 25%,var(--border) 50%,var(--bg-subtle) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;width:100%;max-width:200px;margin-bottom:12px}.skeleton-text-short{height:16px;width:120px;margin-bottom:12px}.skeleton-text-long{height:16px;width:100%;margin-bottom:12px}.skeleton-kpi{height:36px;width:100%;border-radius:var(--radius)}.skeleton-card{height:180px;width:100%;border-radius:var(--radius)}.skeleton-card-small{height:120px;width:100%;border-radius:var(--radius)}.skeleton-card-large{height:240px;width:100%;border-radius:var(--radius)}.skeleton-circle{width:90px;height:90px;border-radius:50%}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-table-row{height:48px;width:100%;margin-bottom:4px}.text-up{color:var(--up)}.text-down{color:var(--down)}.text-warn{color:var(--warn)}.text-muted{color:var(--text-3)}.text-mono{font-family:var(--font-mono)}.text-display{font-family:var(--font-display)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:16px}.gap-lg{gap:24px}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mt-lg{margin-top:24px}.mb-md{margin-bottom:16px}.section-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-1);margin-bottom:16px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-3)}.empty-state svg{width:48px;height:48px;margin-bottom:16px;opacity:.3}.empty-state h3{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-2);margin-bottom:4px}.empty-state p{font-size:.825rem}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0a0f,#14141f 40%,#1a1a2e);padding:20px}.login-card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000080,0 0 80px #8b5cf60d;overflow:hidden}.login-brand{padding:32px 32px 24px;text-align:center;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(139,92,246,.04) 0%,transparent 100%)}.login-brand h1{font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--text-1);letter-spacing:-.02em;margin-bottom:4px}.login-brand span{font-size:.8rem;color:var(--text-3);font-family:var(--font-mono);letter-spacing:.05em}.login-form{padding:28px 32px 32px;display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.75rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}.login-field input{padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-subtle);color:var(--text-1);font-family:var(--font-body);font-size:.9rem;transition:all var(--duration) var(--ease-premium);outline:none;min-height:44px}.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.login-field input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.login-field input::placeholder{color:var(--text-3);opacity:.6}.login-error{padding:10px 14px;background:var(--down-soft);color:var(--down);border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;text-align:center}.login-btn{width:100%;padding:12px;font-size:.9rem;font-weight:600;margin-top:4px;border-radius:var(--radius-sm);letter-spacing:.01em;min-height:44px}.ai-markdown-output h1,.ai-markdown-output h2,.ai-markdown-output h3{font-weight:800;letter-spacing:-.02em;color:var(--text-1);margin:1.2em 0 .4em}.ai-markdown-output h2{font-size:1.15rem;border-bottom:1px solid var(--border-luxury);padding-bottom:.4em}.ai-markdown-output h3{font-size:1rem}.ai-markdown-output p{margin:.5em 0}.ai-markdown-output ul,.ai-markdown-output ol{margin:.5em 0;padding-left:1.5em}.ai-markdown-output li{margin:.3em 0}.ai-markdown-output strong{color:var(--text-1);font-weight:700}.ai-markdown-output table{border-collapse:collapse;width:100%;margin:.8em 0;font-size:.8rem}.ai-markdown-output th,.ai-markdown-output td{border:1px solid var(--border);padding:8px 12px;text-align:left}.ai-markdown-output th{background:var(--bg-subtle);font-weight:700;font-size:.75rem}.ai-markdown-output code{background:var(--bg-subtle);padding:2px 6px;border-radius:4px;font-size:.82em}.ai-markdown-output pre{background:var(--bg-well);padding:16px;border-radius:var(--radius);overflow-x:auto}.ai-markdown-output blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-2);margin:.8em 0}.alert-row:hover{background:#00000005}.alert-row:hover .copy-btn{opacity:1!important}.currency-display,.number-display{position:relative;cursor:help;border-bottom:1px dotted var(--text-3)}.copy-btn{transition:opacity .15s ease}@media(max-width:768px){.ai-chat-panel{left:24px!important;right:24px!important;width:auto!important;max-width:none!important}}@media(max-width:1024px){:root{--sidebar-width: 200px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.campaign-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media(max-width:768px){:root{--sidebar-width: 0}.sidebar{transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.kpi-grid,.campaign-grid{grid-template-columns:1fr}.header{padding:0 16px}.header-title{font-size:1rem}.page-content{padding:16px}.mobile-nav{position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--card);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;z-index:100;padding:0 16px}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;color:var(--text-3);text-decoration:none;font-size:.7rem;min-height:44px}.mobile-nav-item.active{color:var(--accent)}.mobile-nav-item svg{width:20px;height:20px}.page-content{padding-bottom:80px}.data-table-responsive{display:block}.data-table-responsive thead{display:none}.data-table-responsive tbody,.data-table-responsive tr{display:block}.data-table-responsive tr{margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);padding:12px}.data-table-responsive td{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border:none;border-bottom:1px solid var(--border-luxury)}.data-table-responsive td:last-child{border-bottom:none}.data-table-responsive td:before{content:attr(data-label);font-weight:600;color:var(--text-3);font-size:.7rem;text-transform:uppercase}}@media print{.sidebar,.header,.mobile-nav,[data-chat-toggle]{display:none!important}.main-content{margin-left:0}.page-content{overflow:visible}.card{break-inside:avoid;box-shadow:none;border:1px solid #ddd}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.skeleton{animation:none;background:var(--bg-subtle)}}@media(prefers-contrast:high){:root{--border: rgba(0, 0, 0, .2);--border-active: rgba(0, 0, 0, .4);--text-3: #666}.card{border-width:2px}*:focus-visible{outline-width:3px}}
