@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Syne:wght@600;700&display=swap";:root{color-scheme:light;font-family:Space Grotesk,system-ui,sans-serif;background-color:#0f172a;color:#0f172a}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top,#f8fafc,#e2e8f0 40%,#cbd5f5);min-height:100vh;color:#0f172a}[data-theme=dark]{color-scheme:dark}[data-theme=dark] body{background:radial-gradient(circle at top,#1f2937,#111827 45%,#020617);color:#e2e8f0}.page{max-width:1200px;margin:0 auto;padding:48px 24px 64px;display:flex;flex-direction:column;gap:32px}.warning-banner{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:12px 16px;border-radius:14px;font-weight:600}.hero{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:32px;border-radius:28px;background:linear-gradient(135deg,#111827,#1e293b 55%,#0f172a);color:#f8fafc;box-shadow:0 25px 50px #0f172a59}.eyebrow{font-size:.85rem;text-transform:uppercase;letter-spacing:.2em;color:#94a3b8;margin:0 0 8px}.hero h1{font-family:Syne,sans-serif;font-size:clamp(2.4rem,3vw,3.4rem);margin:0 0 8px}.subtitle{margin:0;color:#cbd5f5;max-width:260px}.status-list{display:flex;flex-wrap:nowrap;gap:12px;align-items:stretch;min-width:0}.status{padding:16px 20px;border-radius:16px;background:#0f172a66;border:1px solid rgba(148,163,184,.4);min-width:0;flex:1 1 0}.status-role{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:nowrap}.status-role>div:first-child{flex:1;min-width:0;margin-right:22px}.status-role .status-value{white-space:nowrap}.status-label{margin:0;font-size:.8rem;color:#94a3b8}.status-value{margin:8px 0 0;font-weight:600;color:#e2e8f0;word-break:normal;overflow-wrap:anywhere}.status button{margin-top:12px}.status-role button{margin-top:0;white-space:nowrap}.status-inline-btn{margin-top:0;padding:5px 12px;min-height:30px;font-size:.86rem;line-height:1;align-self:center}.status-error{margin:8px 0 0;color:#fecaca;font-size:.8rem;width:100%}.status-auth{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:nowrap}.status-auth .status-value{margin-bottom:0;white-space:nowrap}.status-auth .logout{margin-top:0;white-space:nowrap}.status-settings,.status-toggles{width:72px;min-width:72px;height:72px;padding:8px;display:flex;justify-content:center;align-items:center}.icon-controls{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%}.dual-toggle-btn{width:100%;min-width:0;height:24px;padding:15px 32px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;gap:4px;font-size:.78rem;border:1px solid rgba(148,163,184,.45)!important;background:transparent!important;box-shadow:none!important;color:#e2e8f0}.status-settings .dual-toggle-btn{margin-top:0;border:1px solid rgba(148,163,184,.45)!important;background:transparent!important;box-shadow:none!important;outline:none}.hero .status-settings .dual-toggle-btn,.hero button.dual-toggle-btn,.hero button.dual-toggle-btn.ghost{background:transparent!important;border:1px solid rgba(148,163,184,.45)!important;color:#e2e8f0;box-shadow:none!important}.dual-toggle-btn .separator{font-size:.8rem;opacity:.7}.dual-toggle-btn .active{filter:saturate(1.2);transform:scale(1.08)}.dual-toggle-btn:hover{transform:none;box-shadow:none;background:transparent!important;border-color:#e2e8f09e!important}.hero .status-settings .dual-toggle-btn:hover,.hero .status-settings .dual-toggle-btn:focus,.hero .status-settings .dual-toggle-btn:active{background:transparent!important;border-color:#e2e8f09e!important;box-shadow:none!important}.hero .status-inline-btn,.hero .status-inline-btn.ghost{padding:5px 12px;min-height:30px;font-size:.86rem;margin-top:0}.status-role,.status-auth{min-width:280px;flex:1 1 300px}.header-actions{display:flex;align-items:center;justify-content:center;gap:12px}.menu{position:relative}.menu-trigger{width:72px;height:72px;border-radius:16px;border:1px solid rgba(226,232,240,.2);background:transparent;display:grid;gap:5px;padding:16px;cursor:pointer;margin:0}.menu-trigger span{display:block;width:100%;height:3px;border-radius:999px;background:#e2e8f0}.menu-popover{position:absolute;right:0;top:56px;background:#0f172a;border-radius:14px;padding:8px;min-width:180px;box-shadow:0 20px 40px #0f172a66;display:flex;flex-direction:column;gap:6px;z-index:10}.menu-item{background:transparent;color:#e2e8f0;border:none;padding:10px 12px;text-align:left;border-radius:10px;font-weight:600;box-shadow:none;transform:none}.menu-item:hover{transform:none;box-shadow:none}.menu-trigger:hover{transform:none;box-shadow:none;background:transparent}.menu-item:hover,.menu-item.active{background:#94a3b833}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.card{background:#fff;border-radius:20px;padding:20px;display:flex;flex-direction:column;gap:12px;box-shadow:0 16px 30px #0f172a1f}.card h2{margin:0;font-size:1.2rem}.card h3{margin:0;font-size:1.1rem}.card p{margin:0;color:#334155}.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;cursor:pointer}.card-main{display:flex;align-items:flex-start;gap:10px}.icon-toggle{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;color:#0f172a;font-weight:700;line-height:1}.card-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.role-select{display:flex;flex-direction:column;align-items:flex-start;gap:4px;font-size:.8rem}.role-select select{min-width:180px;padding:8px 12px;border-radius:10px}.role-label{color:#475569;font-weight:600;letter-spacing:.02em}.user-card{padding:18px 20px}.user-card-header{align-items:center;gap:20px}.user-meta h3{margin-bottom:2px}.user-meta p{margin:0}.user-actions{align-items:center;gap:10px}.row-action{padding:8px 14px;border-radius:12px;font-size:.9rem;min-height:40px}.user-actions .danger{border-color:#b91c1c}@media(max-width:980px){.user-card-header{flex-direction:column;align-items:flex-start}.user-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}}label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:#0f172a}input,select{padding:10px 12px;border-radius:12px;border:1px solid #cbd5f5;font-size:.95rem;font-family:inherit;background:#fff}button{border:none;border-radius:999px;background:#0f172a;color:#f8fafc;padding:10px 16px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}button:hover{transform:translateY(-1px);box-shadow:0 8px 18px #0f172a33}button.ghost{background:#0f172a14;color:#0f172a;border:1px solid rgba(15,23,42,.2)}button.danger{background:#b91c1c;color:#fef2f2}.hero button.ghost,.hero .menu-item{color:#e2e8f0}.hero button.ghost{background:#94a3b833;border-color:#e2e8f066}.response{background:#0f172a;color:#e2e8f0;border-radius:14px;padding:12px;font-size:.8rem;white-space:pre-wrap}.footer{text-align:center;color:#334155;font-size:.9rem}.footer .muted{color:#475569}.home{display:flex;flex-direction:column;gap:20px}.home-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.datasource-list{display:flex;flex-direction:column;gap:12px}.datasource-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px;border-radius:16px;background:#f8fafc;border:1px solid #e2e8f0}.datasource-title{font-weight:700;margin:0}.datasource-actions{display:flex;gap:8px}.datasource-subrow{margin-top:14px;padding-top:14px;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:10px}.user-subrow{margin-top:14px;padding-top:14px;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:12px}.datasource-lines{display:flex;flex-direction:column;gap:8px}.datasource-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.datasource-line:hover{background:#eef2ff;border-color:#c7d2fe}.datasource-line-content{display:flex;align-items:center;gap:10px;flex:1}.datasource-line-type{font-weight:700;color:#0f172a}.datasource-line-meta{display:flex;flex-direction:column;gap:2px}.runs-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.run-row{cursor:pointer}.run-row-main,.run-row-meta{min-width:0}.product-row-head{justify-content:space-between}.product-expand-btn{min-width:120px}.product-layers{margin-top:10px;padding:12px;border-radius:10px;border:1px solid #cbd5e1;background:#f8fafc;display:grid;gap:10px}.product-layers h4{margin:0 0 6px}.product-panels{display:grid;gap:10px}.product-panel{border:1px solid #cbd5e1;border-radius:10px;background:#fff}.product-panel-summary{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;cursor:pointer;font-weight:700}.product-panel-body{border-top:1px solid #e2e8f0;padding:10px 12px}.product-page-meta{margin:0 0 8px}.product-layer-list{margin:0;padding-left:18px;display:grid;gap:4px}.product-suggestion-item{padding:8px;border:1px solid #cbd5e1;border-radius:8px;background:#fff}.product-suggestion-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.suggestion-badge{border-radius:999px;padding:2px 8px;font-size:.75rem;font-weight:600}.suggestion-pending{background:#e2e8f0;color:#0f172a}.suggestion-accepted,.suggestion-applied{background:#dcfce7;color:#166534}.suggestion-rejected{background:#fee2e2;color:#991b1b}.product-suggestion-form{margin-top:12px;display:grid;gap:8px}.product-suggestion-filters{display:flex;gap:8px;align-items:center;margin-bottom:8px}.product-suggestion-form-inline{display:grid;grid-template-columns:120px 160px auto;gap:8px}.product-weekly-series{margin-bottom:8px}.weekly-trend-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:8px 0 10px}.weekly-trend-card{border:1px solid #cbd5e1;border-radius:10px;background:#fff;padding:8px 10px}.weekly-trend-head{display:flex;align-items:center;justify-content:space-between;font-weight:700;margin-bottom:6px}.weekly-trend-delta{font-size:.8rem;font-weight:700}.weekly-trend-delta.up{color:#15803d}.weekly-trend-delta.down{color:#b91c1c}.weekly-trend-delta.flat{color:#64748b}.trend-line,.trend-bars{width:100%;height:64px;display:block;border-radius:6px;background:linear-gradient(180deg,#f8fafc,#eef2ff)}.weekly-trend-foot{margin:6px 0 0;font-size:.78rem}.product-suggestion-tasks{margin-top:8px}.product-task-list,.product-timeline-list{margin:6px 0 0;padding-left:18px;display:grid;gap:4px}.product-task-item label{display:inline-flex;align-items:center;gap:8px}.product-suggestion-timeline{margin-top:8px}.product-suggestion-timeline summary{cursor:pointer}.product-suggestion-create{margin-top:10px}.product-suggestion-create summary{cursor:pointer;font-weight:700}.run-failed{border-color:#fecaca;background:#fff1f2}.run-group{display:flex;flex-direction:column;gap:8px;padding:8px;border-radius:12px;border:1px solid #fecaca;background:#fff7f7}.run-group-header{background:#fff1f2;border-color:#fecaca}.run-group-toggle{white-space:nowrap}.run-group-actions{display:flex;align-items:center;gap:8px}.run-group-rows{display:flex;flex-direction:column;gap:8px;padding-left:12px}.runs-paging{flex-direction:row;align-items:center;justify-content:space-between}.error-inline{color:#b91c1c;font-size:.8rem;min-width:0;overflow:hidden;white-space:pre-wrap;overflow-wrap:anywhere;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:20}.error-inline-row{display:flex;flex-direction:column;align-items:flex-start;gap:4px;min-width:0;max-width:100%}.copy-error-wrap{position:relative;display:inline-flex;align-items:center}.copy-error-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex:0 0 auto;margin-left:0;color:#64748b;opacity:.9;cursor:pointer;transition:color .15s ease,opacity .15s ease,transform .15s ease}.copy-feedback{position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);font-size:.72rem;white-space:nowrap;padding:2px 8px;border-radius:999px;background:#0f172a;color:#f8fafc;border:1px solid #334155}.context-preview{margin:8px 0 0;padding:10px;border:1px solid #cbd5e1;border-radius:10px;background:#f8fafc;max-height:360px;overflow:auto;white-space:pre-wrap;overflow-wrap:anywhere;font-size:.82rem;line-height:1.45}.copy-error-icon:hover,.copy-error-icon:focus-visible{color:#0f172a;opacity:1;transform:translateY(-1px);outline:none}.datasource-edit-icon{width:18px;height:18px;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#334155;border:1px solid #cbd5e1;background:#f8fafc;opacity:0;transform:translate(-4px);transition:opacity .15s ease,transform .15s ease}.datasource-line:hover .datasource-edit-icon{opacity:1;transform:translate(0)}.modal-backdrop{position:fixed;inset:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;padding:24px;z-index:20}.modal{background:#fff;border-radius:24px;padding:24px;width:min(520px,100%);box-shadow:0 24px 50px #0f172a59;display:flex;flex-direction:column;gap:16px}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.chat-modal{width:min(760px,100%)}.improvement-modal{width:min(920px,100%);max-height:80vh;overflow:auto}.improvement-plan{display:grid;gap:10px}.improvement-products{margin:0;padding-left:20px;display:grid;gap:10px}.improvement-product{border:1px solid #cbd5e1;border-radius:10px;background:#f8fafc;padding:10px}.improvement-product-head{display:flex;flex-direction:column;gap:2px;margin-bottom:4px}.improvement-actions{margin:8px 0 0;padding-left:18px;display:grid;gap:6px}.chat-thread{max-height:360px;overflow:auto;display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:14px;border:1px solid #e2e8f0;background:#f8fafc}.chat-message{max-width:88%;padding:10px 12px;border-radius:12px;border:1px solid #cbd5e1;background:#fff}.chat-message p{margin:0}.chat-message .chat-role{font-size:.75rem;font-weight:700;margin-bottom:4px;color:#475569}.chat-user{align-self:flex-end;background:#e0f2fe;border-color:#7dd3fc}.chat-assistant{align-self:flex-start;background:#fff}.login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(280px,1.1fr) minmax(280px,.9fr);gap:32px;align-items:center;padding:48px 24px;max-width:1200px;margin:0 auto}.login-hero{background:linear-gradient(135deg,#0f172a,#1e293b,#111827);color:#f8fafc;border-radius:28px;padding:36px;box-shadow:0 25px 50px #0f172a59}.login-hero h1{font-family:Syne,sans-serif;font-size:clamp(2.2rem,3vw,3.2rem);margin:0 0 12px}.login-blurb{margin-top:24px;padding:16px;border-radius:16px;background:#0f172a59;color:#cbd5f5}.login-top-controls{display:flex;justify-content:flex-end;margin-bottom:20px}.login-control{color:#e2e8f0;font-size:.75rem;gap:4px}.login-control select{min-width:130px}.login-column{display:flex;flex-direction:column;gap:20px}.login-card{background:#fff;border-radius:24px;padding:32px;display:flex;flex-direction:column;gap:16px;box-shadow:0 18px 35px #0f172a2e}.login-card h2{margin:0}.login-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.login-header .ghost{color:#0f172a;border-color:#0f172a33;background:#0f172a0f}.login-actions{display:flex;flex-direction:column;gap:10px}.login-actions .muted{color:#475569;font-size:.85rem}.stack{display:flex;flex-direction:column;gap:12px}.row-actions{display:flex;justify-content:flex-end}.error{color:#b91c1c;background:#fee2e2;padding:8px 10px;border-radius:10px;font-size:.85rem}.success{color:#15803d;background:#dcfce7;padding:8px 10px;border-radius:10px;font-size:.85rem}[data-theme=dark] .card,[data-theme=dark] .modal,[data-theme=dark] .login-card{background:#111827;box-shadow:0 16px 30px #0206178c}[data-theme=dark] .card p,[data-theme=dark] .footer,[data-theme=dark] .footer .muted,[data-theme=dark] .muted,[data-theme=dark] label{color:#cbd5e1}[data-theme=dark] .card h2,[data-theme=dark] .card h3,[data-theme=dark] .modal h3,[data-theme=dark] .modal h4,[data-theme=dark] .datasource-line-type,[data-theme=dark] .icon-toggle{color:#e2e8f0}[data-theme=dark] input,[data-theme=dark] select{background:#1f2937;border-color:#334155;color:#f8fafc}[data-theme=dark] button{background:#e2e8f0;color:#0f172a}[data-theme=dark] button.ghost{background:#e2e8f01f;border-color:#e2e8f052;color:#e2e8f0}[data-theme=dark] .menu-trigger{background:transparent;border-color:#94a3b861}[data-theme=dark] .menu-popover{background:#1f2937;border:1px solid #334155}[data-theme=dark] .menu-popover .menu-item{background:transparent;color:#e2e8f0}[data-theme=dark] .menu-item:hover,[data-theme=dark] .menu-item.active{background:#94a3b840}[data-theme=dark] .datasource-item,[data-theme=dark] .datasource-line{background:#0f172a;border-color:#334155}[data-theme=dark] .datasource-line:hover{background:#1e293b;border-color:#475569}[data-theme=dark] .datasource-edit-icon{background:#1f2937;border-color:#475569;color:#cbd5e1}[data-theme=dark] .datasource-subrow,[data-theme=dark] .user-subrow{border-top-color:#334155}[data-theme=dark] .product-panel{background:#0f172a;border-color:#334155}[data-theme=dark] .product-panel-body{border-top-color:#334155}[data-theme=dark] .weekly-trend-card{background:#111827;border-color:#334155}[data-theme=dark] .trend-line,[data-theme=dark] .trend-bars{background:linear-gradient(180deg,#1f2937,#0f172a)}[data-theme=dark] .chat-thread,[data-theme=dark] .improvement-product{background:#0f172a;border-color:#334155}[data-theme=dark] .chat-message{background:#111827;border-color:#334155}[data-theme=dark] .chat-message .chat-role{color:#94a3b8}[data-theme=dark] .chat-user{background:#0c4a6e;border-color:#0369a1}[data-theme=dark] .error{color:#fecaca;background:#b91c1c38}[data-theme=dark] .error-inline{color:#fecaca}[data-theme=dark] .copy-error-icon{color:#cbd5e1}[data-theme=dark] .copy-error-icon:hover,[data-theme=dark] .copy-error-icon:focus-visible{color:#f8fafc}[data-theme=dark] .copy-feedback{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}[data-theme=dark] .context-preview{background:#0f172a;border-color:#334155;color:#e2e8f0}[data-theme=dark] .run-failed{border-color:#7f1d1d;background:#7f1d1d40}[data-theme=dark] .run-group{border-color:#7f1d1d;background:#7f1d1d29}[data-theme=dark] .run-group-header{border-color:#7f1d1d;background:#7f1d1d3d}[data-theme=dark] .success{color:#bbf7d0;background:#15803d40}@media(max-width:900px){.login-shell{grid-template-columns:1fr}}@media(max-width:720px){.hero{flex-direction:column;align-items:flex-start}.status-list{flex-wrap:wrap}.status{width:100%;flex:1 1 100%}.status-settings{width:100%;min-width:0;height:auto;align-items:flex-start}.status-settings .icon-controls{width:auto;flex-direction:row}.status-settings .dual-toggle-btn{width:auto;min-width:84px;height:34px;padding:0 10px;font-size:.95rem}}
