:root{--color-white: #ffffff;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-primary-50: #eef2ff;--color-primary-100: #e0e7ff;--color-primary-200: #c7d2fe;--color-primary-300: #a5b4fc;--color-primary-400: #818cf8;--color-primary-500: #6366f1;--color-primary-600: #4f46e5;--color-primary-700: #4338ca;--color-primary-800: #3730a3;--color-primary-900: #312e81;--color-success-50: #ecfdf5;--color-success-500: #10b981;--color-success-600: #059669;--color-warning-50: #fffbeb;--color-warning-500: #f59e0b;--color-warning-600: #d97706;--color-error-50: #fef2f2;--color-error-500: #ef4444;--color-error-600: #dc2626;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 256px;--sidebar-collapsed-width: 64px;--header-height: 64px}.select{width:100%;padding:var(--spacing-2) var(--spacing-3);font-family:var(--font-family);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-gray-900);background-color:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-lg);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right var(--spacing-2) center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:var(--spacing-10)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-gray-900);background-color:var(--color-gray-50);min-height:100vh}#app{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-gray-900)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm)}p{color:var(--color-gray-600)}a{color:var(--color-primary-600);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-700)}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-gray-100)}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-lg{font-size:var(--font-size-lg)}.text-muted{color:var(--color-gray-500)}.text-success{color:var(--color-success-600)}.text-warning{color:var(--color-warning-600)}.text-error{color:var(--color-error-600)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background-color:var(--color-white);border-right:1px solid var(--color-gray-200);display:flex;flex-direction:column;z-index:40;transition:width var(--transition-base)}.sidebar-header{height:var(--header-height);display:flex;align-items:center;padding:0 var(--spacing-6);border-bottom:1px solid var(--color-gray-200)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-3);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.sidebar-logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary-500),var(--color-primary-700));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-white)}.sidebar-nav{flex:1;padding:var(--spacing-4);overflow-y:auto}.sidebar-section{margin-bottom:var(--spacing-6)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-400);text-transform:uppercase;letter-spacing:.05em;padding:0 var(--spacing-3);margin-bottom:var(--spacing-2)}.sidebar-nav-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);border-radius:var(--radius-lg);color:var(--color-gray-600);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.sidebar-nav-item:hover{background-color:var(--color-gray-100);color:var(--color-gray-900)}.sidebar-nav-item.active{background-color:var(--color-primary-50);color:var(--color-primary-700)}.sidebar-nav-item-icon{width:20px;height:20px;flex-shrink:0}.sidebar-footer{padding:var(--spacing-4);border-top:1px solid var(--color-gray-200)}.main-wrapper{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.header{height:var(--header-height);background-color:var(--color-white);border-bottom:1px solid var(--color-gray-200);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-6);position:sticky;top:0;z-index:30}.header-left{display:flex;align-items:center;gap:var(--spacing-4)}.header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.header-right{display:flex;align-items:center;gap:var(--spacing-4)}.header-user{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--transition-fast)}.header-user:hover{background-color:var(--color-gray-100)}.header-user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background-color:var(--color-primary-100);color:var(--color-primary-700);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);overflow:hidden}.header-user-avatar img{width:100%;height:100%;object-fit:cover}.header-user-info{text-align:left}.header-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-900)}.header-user-role{font-size:var(--font-size-xs);color:var(--color-gray-500)}.main-content{flex:1;padding:var(--spacing-6)}.page{max-width:1400px;margin:0 auto}.page-header{margin-bottom:var(--spacing-6)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-2)}.page-description{font-size:var(--font-size-base);color:var(--color-gray-500)}.grid{display:grid;gap:var(--spacing-6)}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}@media (max-width: 1024px){.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-wrapper{margin-left:0}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(1,minmax(0,1fr))}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-gray-50)}.login-container{width:100%;max-width:400px;padding:var(--spacing-8);background-color:var(--color-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--spacing-8)}.login-logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.login-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--spacing-2)}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500)}.card{background-color:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200);overflow:hidden}.card-header{padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--color-gray-100);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:var(--spacing-1)}.card-body{padding:var(--spacing-6)}.card-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-gray-100);background-color:var(--color-gray-50)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1.5;border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary-600);color:var(--color-white)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-700)}.btn-secondary{background-color:var(--color-white);border-color:var(--color-gray-300);color:var(--color-gray-700)}.btn-secondary:hover:not(:disabled){background-color:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-ghost{background-color:transparent;color:var(--color-gray-600)}.btn-ghost:hover:not(:disabled){background-color:var(--color-gray-100);color:var(--color-gray-900)}.btn-sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base)}.input-group{margin-bottom:var(--spacing-4)}.input-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);margin-bottom:var(--spacing-2)}.input{width:100%;padding:var(--spacing-2) var(--spacing-3);font-family:var(--font-family);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-gray-900);background-color:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.input::placeholder{color:var(--color-gray-400)}.select{width:100%;padding:var(--spacing-2) var(--spacing-3);font-family:var(--font-family);font-size:var(--font-size-sm);line-height:1.5;color:var(--color-gray-900);background-color:var(--color-white);border:1px solid var(--color-gray-300);border-radius:var(--radius-lg);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E");background-position:right var(--spacing-2) center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:var(--spacing-10)}.select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full)}.badge-gray{background-color:var(--color-gray-100);color:var(--color-gray-700)}.badge-primary{background-color:var(--color-primary-100);color:var(--color-primary-700)}.badge-success{background-color:var(--color-success-50);color:var(--color-success-600)}.badge-warning{background-color:var(--color-warning-50);color:var(--color-warning-600)}.badge-error{background-color:var(--color-error-50);color:var(--color-error-600)}.stat-card{background-color:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200);padding:var(--spacing-6)}.stat-card-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-500);margin-bottom:var(--spacing-2)}.stat-card-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.stat-card-change{display:inline-flex;align-items:center;gap:var(--spacing-1);font-size:var(--font-size-sm);margin-top:var(--spacing-2)}.stat-card-change.positive{color:var(--color-success-600)}.stat-card-change.negative{color:var(--color-error-600)}.chart-card{background-color:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200)}.chart-card-header{padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--color-gray-100);display:flex;align-items:flex-start;justify-content:space-between}.chart-card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.chart-card-description{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-top:var(--spacing-1)}.chart-card-body{padding:var(--spacing-6);min-height:300px}.chart-card-footer{padding:var(--spacing-3) var(--spacing-6);border-top:1px solid var(--color-gray-100);background-color:var(--color-gray-50);font-size:var(--font-size-xs);color:var(--color-gray-500)}.spinner{width:24px;height:24px;border:2px solid var(--color-gray-200);border-top-color:var(--color-primary-600);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px}.spinner-lg{width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12);color:var(--color-gray-500)}.loading-state-text{margin-top:var(--spacing-4);font-size:var(--font-size-sm)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12);text-align:center}.empty-state-icon{width:48px;height:48px;color:var(--color-gray-400);margin-bottom:var(--spacing-4)}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin-bottom:var(--spacing-2)}.empty-state-description{font-size:var(--font-size-sm);color:var(--color-gray-500);max-width:320px}.progress{height:8px;background-color:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background-color:var(--color-primary-600);border-radius:var(--radius-full);transition:width var(--transition-slow)}.progress-bar.success{background-color:var(--color-success-500)}.progress-bar.warning{background-color:var(--color-warning-500)}.progress-bar.error{background-color:var(--color-error-500)}.alert{padding:var(--spacing-4);border-radius:var(--radius-lg);display:flex;gap:var(--spacing-3)}.alert-info{background-color:var(--color-primary-50);border:1px solid var(--color-primary-200);color:var(--color-primary-800)}.alert-success{background-color:var(--color-success-50);border:1px solid rgba(16,185,129,.2);color:var(--color-success-600)}.alert-warning{background-color:var(--color-warning-50);border:1px solid rgba(245,158,11,.2);color:var(--color-warning-600)}.alert-error{background-color:var(--color-error-50);border:1px solid rgba(239,68,68,.2);color:var(--color-error-600)}.alert-icon{flex-shrink:0;width:20px;height:20px}.alert-content{flex:1}.alert-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-1)}.alert-message{font-size:var(--font-size-sm)}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-gray-200)}.table th{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em;background-color:var(--color-gray-50)}.table td{font-size:var(--font-size-sm);color:var(--color-gray-900)}.table tbody tr:hover{background-color:var(--color-gray-50)}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;min-width:160px;background-color:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-1);z-index:50;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all var(--transition-fast)}.dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(4px)}.dropdown-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-gray-700);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.dropdown-item:hover{background-color:var(--color-gray-100)}.dropdown-divider{height:1px;background-color:var(--color-gray-200);margin:var(--spacing-1) 0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-6)}.page-header-content{flex:1}.page-header-actions{display:flex;gap:var(--spacing-3)}.environment-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.environment-item{padding:var(--spacing-2) 0}.environment-item-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-2)}.environment-item-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.environment-item-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.intent-split{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-6)}.intent-item{text-align:center;padding:var(--spacing-6);background-color:var(--color-gray-50);border-radius:var(--radius-lg)}.intent-item-label{font-size:var(--font-size-sm);color:var(--color-gray-600);margin-bottom:var(--spacing-2)}.intent-item-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.intent-item-count{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}.usage-display{text-align:center;padding:var(--spacing-4)}.usage-header{display:flex;align-items:baseline;justify-content:center;gap:var(--spacing-1)}.usage-current{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.usage-separator{font-size:var(--font-size-2xl);color:var(--color-gray-400)}.usage-limit{font-size:var(--font-size-2xl);font-weight:var(--font-weight-medium);color:var(--color-gray-500)}.usage-label{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-left:var(--spacing-2)}.usage-footer{display:flex;justify-content:center;margin-top:var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-gray-500)}@media (max-width: 768px){.page-header{flex-direction:column;gap:var(--spacing-4)}.page-header-actions{width:100%}.page-header-actions .select{flex:1}.intent-split{grid-template-columns:1fr;gap:var(--spacing-4)}}.chat-page{display:flex;gap:var(--spacing-6);height:calc(100vh - var(--header-height) - var(--spacing-12));max-height:800px}.chat-container{flex:1;display:flex;flex-direction:column;background-color:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200);overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-gray-200)}.chat-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0}.chat-subtitle{font-size:var(--font-size-sm);color:var(--color-gray-500);margin:0}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-6);display:flex;flex-direction:column;gap:var(--spacing-4)}.chat-message{display:flex;gap:var(--spacing-3);max-width:85%}.chat-message-user{align-self:flex-end;flex-direction:row-reverse}.chat-message-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-message-user .chat-message-avatar{background-color:var(--color-primary-100);color:var(--color-primary-700)}.chat-message-assistant .chat-message-avatar{background-color:var(--color-gray-100);color:var(--color-gray-600)}.chat-message-content{background-color:var(--color-gray-50);border-radius:var(--radius-lg);padding:var(--spacing-3) var(--spacing-4)}.chat-message-user .chat-message-content{background-color:var(--color-primary-600);color:var(--color-white)}.chat-message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-1)}.chat-message-author{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.chat-message-user .chat-message-author{color:var(--color-primary-100)}.chat-message-time{font-size:var(--font-size-xs);opacity:.7}.chat-message-text{font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.chat-message-text code{background-color:#0000001a;padding:0 var(--spacing-1);border-radius:var(--radius-sm);font-family:monospace}.chat-message-sources{margin-top:var(--spacing-2);display:flex;flex-wrap:wrap;gap:var(--spacing-1);align-items:center}.sources-label{font-size:var(--font-size-xs);color:var(--color-gray-500)}.chat-message-confidence{margin-top:var(--spacing-2)}.typing-indicator{display:flex;gap:4px;padding:var(--spacing-2)}.typing-indicator span{width:8px;height:8px;background-color:var(--color-gray-400);border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.chat-input-container{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-gray-200)}.chat-form{display:flex;flex-direction:column;gap:var(--spacing-2)}.chat-input-wrapper{display:flex;gap:var(--spacing-2);align-items:flex-end}.chat-input{flex:1;padding:var(--spacing-3);font-family:var(--font-family);font-size:var(--font-size-sm);border:1px solid var(--color-gray-300);border-radius:var(--radius-lg);resize:none;min-height:44px;max-height:120px}.chat-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px var(--color-primary-100)}.chat-send-btn{height:44px;width:44px;padding:0}.chat-disclaimer{font-size:var(--font-size-xs);color:var(--color-gray-400);text-align:center}.chat-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:var(--spacing-4)}.chat-sidebar-section{background-color:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-gray-200);padding:var(--spacing-4)}.chat-sidebar-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0 0 var(--spacing-3)}.suggestion-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.suggestion-btn{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs);text-align:left;background-color:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.suggestion-btn:hover{background-color:var(--color-primary-50);border-color:var(--color-primary-200)}.data-sources{display:flex;flex-direction:column;gap:var(--spacing-2)}.data-source-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-gray-600)}.data-source-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--color-gray-400)}.usage-meter{padding:var(--spacing-4)}.usage-meter-header{display:flex;align-items:baseline;justify-content:center;gap:var(--spacing-1)}.usage-meter-used{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.usage-meter-separator{font-size:var(--font-size-2xl);color:var(--color-gray-400)}.usage-meter-limit{font-size:var(--font-size-2xl);font-weight:var(--font-weight-medium);color:var(--color-gray-500)}.usage-meter-label{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-left:var(--spacing-2)}.usage-meter-footer{display:flex;justify-content:space-between;margin-top:var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-gray-500)}.plan-details{display:flex;flex-direction:column;gap:var(--spacing-3)}.plan-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) 0;border-bottom:1px solid var(--color-gray-100)}.plan-item:last-child{border-bottom:none}.plan-item-label{font-size:var(--font-size-sm);color:var(--color-gray-500)}.plan-item-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-900)}.quick-stats{display:flex;gap:var(--spacing-6);justify-content:center}.quick-stat-item{text-align:center}.quick-stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900)}.quick-stat-label{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}.action-list{display:flex;flex-direction:column}.switch-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.switch-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background-color:var(--color-gray-50);border-radius:var(--radius-lg)}.switch-from,.switch-to{flex:1}.switch-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.switch-arrow{color:var(--color-gray-400)}.switch-count{flex-shrink:0}.insight-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.insight-item{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);background-color:var(--color-gray-50);border-radius:var(--radius-lg)}.insight-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--color-primary-100);color:var(--color-primary-700);border-radius:var(--radius-lg);flex-shrink:0}.insight-content{flex:1}.insight-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin-bottom:var(--spacing-1)}.insight-value,.explanation-content{font-size:var(--font-size-sm);color:var(--color-gray-600);line-height:var(--line-height-relaxed)}.explanation-content ul{margin:var(--spacing-3) 0;padding-left:var(--spacing-6)}.explanation-content li{margin-bottom:var(--spacing-2)}.settings-section{margin-bottom:var(--spacing-6)}.settings-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin-bottom:var(--spacing-4)}.settings-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4);background-color:var(--color-gray-50);border-radius:var(--radius-lg)}.settings-row-info{flex:1}.settings-row-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-900)}.settings-row-description{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}.toggle{position:relative;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-gray-300);border-radius:var(--radius-full);transition:var(--transition-fast)}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:var(--transition-fast)}.toggle input:checked+.toggle-slider{background-color:var(--color-primary-600)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.report-unlock-card{text-align:center;padding:var(--spacing-8)}.unlock-progress{max-width:400px;margin:0 auto}.unlock-progress-header{display:flex;justify-content:space-between;margin-bottom:var(--spacing-2);font-size:var(--font-size-sm)}.unlock-progress-current{font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.unlock-progress-target{color:var(--color-gray-500)}.report-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.report-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4);background-color:var(--color-gray-50);border-radius:var(--radius-lg)}.report-item-info{flex:1}.report-item-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-900)}.report-item-meta{font-size:var(--font-size-xs);color:var(--color-gray-500);margin-top:var(--spacing-1)}@media (max-width: 1024px){.chat-page{flex-direction:column;height:auto;max-height:none}.chat-container{min-height:500px}.chat-sidebar{width:100%;flex-direction:row}.chat-sidebar-section{flex:1}}@media (max-width: 768px){.chat-sidebar{flex-direction:column}.quick-stats{flex-direction:column;gap:var(--spacing-4)}}.account-info{display:flex;align-items:center;gap:var(--spacing-4)}.account-avatar{width:64px;height:64px;border-radius:var(--radius-full);background-color:var(--color-primary-100);color:var(--color-primary-700);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);overflow:hidden}.account-avatar img{width:100%;height:100%;object-fit:cover}.account-details{flex:1}.account-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.account-email{font-size:var(--font-size-sm);color:var(--color-gray-500)}.account-org{font-size:var(--font-size-sm);color:var(--color-primary-600);margin-top:var(--spacing-1)}.api-key-display{padding:var(--spacing-4);background-color:var(--color-gray-50);border-radius:var(--radius-lg)}.api-key-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-2)}.api-key-value{display:flex;align-items:center;gap:var(--spacing-2)}.api-key-value code{flex:1;font-family:monospace;font-size:var(--font-size-sm);color:var(--color-gray-700)}.unlock-icon{color:var(--color-gray-400)}.report-item-actions{display:flex;align-items:center;flex-shrink:0}.extraction-row:hover{background-color:var(--color-bg-subtle, #f8fafc)}.extraction-row-expanded{background-color:var(--color-bg-subtle, #f0f7ff)}.extraction-detail-row td{padding:0;border-bottom:2px solid var(--color-border, #e2e8f0)}.extraction-detail-body{padding:var(--spacing-4) var(--spacing-6);background:var(--color-bg-subtle, #f8fafc)}.extraction-detail-meta{display:flex;gap:var(--spacing-6);font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-4);flex-wrap:wrap}.extraction-detail-section{margin-bottom:var(--spacing-4)}.extraction-detail-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.extraction-detail-pre{background:#fff;border:1px solid var(--color-border, #e2e8f0);border-radius:6px;padding:var(--spacing-3) var(--spacing-4);font-size:.75rem;line-height:1.5;overflow-x:auto;max-height:300px;white-space:pre-wrap;word-break:break-word}.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#22c55e;margin-right:6px;animation:live-pulse 1.5s infinite}@keyframes live-pulse{0%,to{opacity:1}50%{opacity:.3}}.json-highlight{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;white-space:pre;word-wrap:normal}.json-key{color:#6f42c1}.json-string{color:#22863a}.json-number{color:#005cc5}.json-boolean{color:#d73a49}.json-null{color:#6a737d}
