*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f172a;--sidebar: #0f172a;--sidebar-w: 220px;--surface: #1e293b;--surface2: #263348;--border: #334155;--indigo: #6366f1;--indigo-d: #4f46e5;--text: #f1f5f9;--text-muted: #94a3b8;--green: #22c55e;--red: #ef4444;--amber: #f59e0b;--radius: 10px;--shadow: 0 4px 24px rgba(0,0,0,.35)}html,body,#root{height:100%}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--indigo);text-decoration:none}button{cursor:pointer;font-family:inherit}.layout{display:flex;min-height:100vh}.main-content{flex:1;min-width:0;padding:32px 36px;overflow-y:auto}.page-loading{display:flex;align-items:center;justify-content:center;height:100vh}.sidebar{width:var(--sidebar-w);background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 0;flex-shrink:0}.sidebar__brand{display:flex;align-items:center;gap:10px;padding:0 20px 20px;border-bottom:1px solid var(--border);margin-bottom:16px}.sidebar__logo{font-size:22px;color:var(--indigo)}.sidebar__name{font-weight:700;font-size:15px;color:var(--text);letter-spacing:-.01em}.sidebar__workspace{padding:8px 20px;font-size:12px;color:var(--text-muted);font-weight:500;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.sidebar__nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 10px}.sidebar__link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:7px;color:var(--text-muted);font-size:13.5px;font-weight:500;transition:all .15s}.sidebar__link:hover{background:var(--surface);color:var(--text)}.sidebar__link--active{background:#6366f126;color:var(--indigo)}.sidebar__icon{width:18px;text-align:center;font-size:15px}.sidebar__footer{padding:12px 10px 0;border-top:1px solid var(--border);margin-top:auto}.page-header{display:flex;align-items:baseline;gap:16px;margin-bottom:28px}.page-title{font-size:22px;font-weight:700;letter-spacing:-.02em}.page-sub{font-size:12px;color:var(--text-muted)}.section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:12px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;border:none;font-size:13.5px;font-weight:600;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--primary{background:var(--indigo);color:#fff}.btn--primary:hover:not(:disabled){background:var(--indigo-d)}.btn--ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn--ghost:hover:not(:disabled){background:var(--surface)}.btn--danger{background:#ef444426;color:var(--red);border:1px solid rgba(239,68,68,.3)}.btn--danger:hover:not(:disabled){background:#ef444440}.btn--sm{padding:5px 12px;font-size:12.5px}.btn--xs{padding:3px 8px;font-size:11.5px}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;border-left:3px solid var(--indigo)}.stat-card--green{border-left-color:var(--green)}.stat-card--red{border-left-color:var(--red)}.stat-card--amber{border-left-color:var(--amber)}.stat-card__label{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px}.stat-card__value{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.stat-card__sub{font-size:12px;color:var(--text-muted);margin-top:4px}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px}.chart-title{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--text)}.chart-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.chart-empty{color:var(--text-muted);font-size:13px;padding:24px 0;text-align:center}.field-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:4px 8px;font-size:12.5px;cursor:pointer}.ai-summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;margin-bottom:24px}.ai-summary-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.ai-summary-body{color:var(--text-muted);font-size:13.5px;line-height:1.75}.ai-summary-body h1,.ai-summary-body h2,.ai-summary-body h3{color:var(--text);margin:16px 0 6px;font-size:14px;font-weight:700}.ai-summary-body strong{color:var(--text)}.ai-summary-body ul{padding-left:18px}.ai-summary-body li{margin:4px 0}.ai-summary-body p{margin-bottom:8px}.ai-summary-placeholder{color:var(--text-muted);font-size:13px;font-style:italic}.sources-strip{margin-bottom:24px}.sources-list{display:flex;flex-direction:column;gap:8px}.source-chip{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 16px}.source-chip__info{display:flex;flex-direction:column;gap:2px}.source-chip__label{font-weight:600;font-size:13.5px}.source-chip__count,.source-chip__sync,.source-chip__hint{font-size:11.5px;color:var(--text-muted)}.source-chip__hint{font-style:italic}.growth-row{display:flex;gap:12px;margin-bottom:24px}.growth-chip{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 18px;display:flex;flex-direction:column;gap:2px}.growth-chip__label{font-size:11.5px;color:var(--text-muted)}.growth-chip__value{font-size:18px;font-weight:700;color:var(--green)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12.5px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.form-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:9px 12px;color:var(--text);font-size:13.5px;font-family:inherit;outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--indigo)}.form-input::placeholder{color:var(--text-muted)}.form-hint{font-size:11.5px;color:var(--text-muted);margin-top:5px;line-height:1.5}.source-form{max-width:480px;margin-top:16px}.card-title{font-size:16px;font-weight:700;margin-bottom:16px}.card-subtitle{font-size:14px;font-weight:600;margin:16px 0 8px}.home-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:60px 24px;background:var(--bg)}.home-header{text-align:center;margin-bottom:48px}.home-brand{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px}.home-logo{font-size:36px;color:var(--indigo)}.home-title{font-size:28px;font-weight:800;letter-spacing:-.03em}.home-sub{font-size:15px;color:var(--text-muted)}.home-body{width:100%;max-width:620px;display:flex;flex-direction:column;gap:32px}.create-workspace-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px}.create-form{display:flex;gap:10px}.create-form .form-input{flex:1}.workspace-list-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px}.workspace-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.workspace-item{display:flex;align-items:center;gap:12px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:14px 16px;cursor:pointer;text-align:left;transition:all .15s}.workspace-item:hover{border-color:var(--indigo);background:#6366f10f}.workspace-item__name{font-weight:600;flex:1;font-size:14px}.workspace-item__id{font-size:11.5px;color:var(--text-muted);font-family:monospace}.workspace-item__arrow{color:var(--indigo);font-size:16px}.empty-hint{color:var(--text-muted);font-style:italic;font-size:13px}.sync-limit-bar{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 16px;margin-bottom:16px}.sync-limit-bar--inline{background:none;border:none;padding:0;margin-bottom:0}.sync-limit-input{width:110px!important}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.source-list-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;overflow:hidden}.source-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);gap:16px}.source-row:last-child{border-bottom:none}.source-row__info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.source-row__actions{display:flex;gap:8px;flex-shrink:0}.source-row__type-badge{display:inline-block;background:#6366f126;color:var(--indigo);border-radius:4px;padding:1px 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;width:fit-content}.source-row__label{font-weight:600;font-size:13.5px}.source-row__synced{font-size:11.5px;color:var(--text-muted)}.source-row__webhook{display:flex;align-items:center;gap:8px;font-size:11.5px}.source-row__webhook code{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:2px 6px;color:var(--text-muted);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.add-source-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.source-type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.source-type-btn{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:18px 12px;font-size:13px;font-weight:600;color:var(--text);transition:all .15s}.source-type-btn:hover{border-color:var(--indigo);background:#6366f114;color:var(--indigo)}.source-type-icon{font-size:24px}.source-form-wrap{margin-top:16px}.webhook-url-row{display:flex;gap:8px;align-items:center}.webhook-url{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 32px;max-width:600px}.export-description{color:var(--text-muted);font-size:13.5px;margin-bottom:20px;line-height:1.6}.export-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.export-step{display:flex;align-items:center;gap:12px;font-size:13.5px;color:var(--text-muted)}.export-step__num{width:24px;height:24px;border-radius:50%;background:#6366f126;color:var(--indigo);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}.export-form{margin-bottom:20px}.export-success{margin-top:20px;display:flex;align-items:center;gap:16px;color:var(--green);font-weight:600}.csv-upload{padding:8px 0}.spinner-wrap{display:flex;justify-content:center;padding:24px}.spinner{border:3px solid var(--border);border-top-color:var(--indigo);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:7px;color:var(--red);padding:10px 14px;font-size:13px;margin-bottom:16px}.success-message{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:7px;color:var(--green);padding:10px 14px;font-size:13px;margin-bottom:16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;width:480px;max-width:95vw;box-shadow:var(--shadow)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-header h3{font-size:16px;font-weight:700}@media(max-width:900px){.stat-row{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}.source-type-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.sidebar{display:none}.main-content{padding:20px 16px}.stat-row{grid-template-columns:1fr 1fr}.create-form{flex-direction:column}}
