:root{--font-serif:"Newsreader", Georgia, serif;--font-sans:"Plus Jakarta Sans", -apple-system, "Segoe UI", sans-serif;--font-body:var(--font-sans);--font-mono:"SF Mono", "Fira Code", "Roboto Mono", monospace;--background:#fcfcfd;--background-accent:#f4f5f7;--surface:#fff;--surface-strong:#fff;--border:#0f2b4e1a;--border-strong:#0f2b4e2e;--text:#0f172a;--text-secondary:#0f172a99;--muted:#4e617e;--accent:#0f2b4e;--accent-soft:#0f2b4e0f;--success:#059669;--warning:#d97706;--danger:#dc2626;--shadow-sm:0 1px 3px #0917170a;--shadow-md:0 4px 16px #0917170f;--radius-lg:14px;--radius-md:10px;--radius-sm:8px;--container:1120px;--transition:.15s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--background);min-height:100vh;color:var(--text);font-family:var(--font-body), sans-serif;margin:0;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.page-shell{height:100dvh;padding:.75rem;overflow:hidden}.auth-screen{background:var(--background);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-shell{width:min(100%,380px);padding:0 1.5rem}.auth-brand{justify-content:center;align-items:center;gap:.75rem;margin-bottom:2.5rem;display:flex}.auth-brand-logo{flex-shrink:0;width:40px;height:40px}.auth-brand-name{font-family:var(--font-serif);color:var(--accent);letter-spacing:-.01em;font-size:1.75rem;font-style:italic;font-weight:300}.auth-panel{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;display:flex}.auth-title{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--text);margin:0;font-size:1.5rem;font-weight:400;line-height:1.25}.auth-copy{color:var(--muted);margin:-.25rem 0 0;font-size:.8125rem;line-height:1.5}.auth-actions{flex-direction:column;align-items:stretch;gap:.75rem;display:flex}.auth-google-button{border-radius:var(--radius-sm);justify-content:center;width:100%;min-height:2.75rem;font-weight:500}.auth-note{color:var(--muted);text-align:center;margin:0;font-size:.75rem}.auth-error{border-radius:var(--radius-sm);color:var(--danger);background:#dc26260f;border:1px solid #dc26261f;padding:.75rem 1rem;font-size:.8125rem;line-height:1.5}.page-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.brand-mark{letter-spacing:.02em;color:var(--text);align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;display:inline-flex}.brand-mark:before{content:"";background:var(--accent);border-radius:2px;width:8px;height:8px;display:inline-block}.hero{grid-template-columns:minmax(0,1.35fr) minmax(300px,.9fr);gap:1rem;margin-bottom:1rem;display:grid}.hero-panel,.card{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.hero-panel{padding:1.5rem}.card{padding:1.25rem}.compact-card{padding:1rem}.hero-copy{max-width:44rem}.eyebrow{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0;font-size:.6875rem;font-weight:600}.hero-title{font-family:var(--font-serif);letter-spacing:-.02em;margin:0;font-size:clamp(2.25rem,5vw,3.5rem);font-weight:400;line-height:1}.hero-text,.muted,.setup-hint,.table-note{color:var(--muted)}.hero-text{margin:0;font-size:.9375rem;line-height:1.6}.stack{flex-direction:column;display:flex}.gap-3xs{gap:.125rem}.gap-2xs{gap:.25rem}.gap-xs{gap:.5rem}.gap-sm{gap:.75rem}.gap-md{gap:1.25rem}.gap-lg{gap:1.75rem}.cluster{flex-wrap:wrap;align-items:center;gap:.375rem;display:flex}.section-title,.card-title,.sidebar-title{margin:0}.section-title{font-family:var(--font-serif);letter-spacing:-.015em;font-size:1.25rem;font-weight:400}.card-title{font-size:.875rem;font-weight:600}.sidebar-title{font-family:var(--font-serif);letter-spacing:-.02em;color:var(--accent);font-size:1.375rem;font-weight:400}.page-kicker{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0;font-size:.6875rem;font-weight:700}.page-copy,.dashboard-card-summary,.scope-copy{color:var(--muted);margin:0}.text-link{color:var(--accent);font-size:.8125rem;font-weight:600}.text-link:hover,.dashboard-card-title:hover,.item-row-title:hover{text-decoration:underline}.button{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;min-height:2.5rem;transition:all var(--transition);justify-content:center;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:500;display:inline-flex}.button:hover{border-color:var(--border-strong)}.button:disabled{opacity:.45;cursor:not-allowed}.button-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.button-primary:hover{background:#0a1f3a;border-color:#0a1f3a}.button-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.button-secondary:hover{background:var(--background-accent)}.button-ghost{color:var(--text-secondary);border-color:var(--border);background:0 0}.button-ghost:hover{background:var(--background-accent);color:var(--text)}.badge{letter-spacing:.02em;text-transform:uppercase;border-radius:999px;align-items:center;min-height:1.375rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:500;display:inline-flex}.badge-neutral{background:var(--background-accent);color:var(--muted)}.badge-success{color:var(--success);background:#05966914}.badge-warning{color:var(--warning);background:#d977061a}.badge-danger{color:var(--danger);background:#dc262614}.stats-grid,.feature-grid{gap:.75rem;display:grid}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.feature-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:1rem}.stat-number{font-family:var(--font-sans);letter-spacing:-.02em;margin:0;font-size:1.5rem;font-weight:600}.workspace-shell{grid-template-columns:240px minmax(0,1fr);gap:.75rem;height:100%;display:grid}.workspace-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;justify-content:space-between;padding:1.25rem;display:flex;overflow-y:auto}.sidebar-top{flex:1;min-height:0;overflow-y:auto}.sidebar-bottom{flex-shrink:0}.sidebar-search{align-items:center;display:flex;position:relative}.sidebar-search-icon{color:var(--muted);pointer-events:none;position:absolute;left:.625rem}.sidebar-search-input{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--background-accent);width:100%;min-height:2rem;color:var(--text);transition:border-color var(--transition);padding:.375rem .625rem .375rem 2rem;font-size:.8125rem}.sidebar-search-input::placeholder{color:var(--muted)}.sidebar-search-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.sidebar-search-results{flex-direction:column;gap:.125rem;display:flex}.sidebar-search-empty{color:var(--muted);margin:0;padding:.5rem .75rem;font-size:.8125rem}.sidebar-nav-sections{flex:1;min-height:0;overflow-y:auto}.nav-section-toggle{cursor:pointer;border:none;align-items:center;width:100%;display:flex}.nav-chevron{width:16px;transition:transform var(--transition);color:var(--muted);flex-shrink:0;margin-left:-2px;margin-right:2px}.nav-chevron-open{transform:rotate(90deg)}.nav-sub-list{flex-direction:column;gap:.0625rem;margin-left:1rem;display:flex}.nav-sub-link{align-items:center;gap:.5rem;padding:.3125rem .75rem;font-size:.8125rem;display:flex}.nav-sub-dot{background:var(--border-strong);border-radius:999px;flex-shrink:0;width:5px;height:5px}.nav-sub-tag{color:var(--muted);margin-left:auto;font-size:.6875rem;font-weight:500}.sidebar-settings{margin-bottom:.5rem;position:relative}.sidebar-settings-btn{border-radius:var(--radius-sm);width:100%;color:var(--muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;align-items:center;gap:.375rem;padding:.5rem .75rem;font-size:.8125rem;font-weight:500;display:flex}.sidebar-settings-btn:hover{background:var(--accent-soft);color:var(--text)}.sidebar-settings-popover{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-md);z-index:20;flex-direction:column;gap:.125rem;margin-bottom:.25rem;padding:.375rem;display:flex;position:absolute;bottom:100%;left:0;right:0}.sidebar-settings-link{border-radius:calc(var(--radius-sm) - 2px);color:var(--text-secondary);transition:all var(--transition);align-items:center;gap:.5rem;padding:.5rem .625rem;font-size:.8125rem;font-weight:500;display:flex}.sidebar-settings-link:hover{background:var(--accent-soft);color:var(--text)}.workspace-main{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:.75rem;padding:1.5rem;display:flex;overflow-y:auto}.workspace-page{min-width:0}.workspace-page-header{margin-bottom:0}.workspace-section-heading,.workspace-inline-heading{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.workspace-topic-hero{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--background-accent);justify-content:space-between;gap:1rem;padding:1.25rem;display:flex}.workspace-topic-title,.dashboard-card-title{font-family:var(--font-serif);letter-spacing:-.025em;margin:0;font-size:1.875rem;font-weight:400}.dashboard-card-title{font-size:1.125rem}.topic-stats-grid,.topic-content-grid,.timeline-grid,.dashboard-grid{gap:.75rem;display:grid}.topic-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));width:min(100%,360px)}.topic-stat-value{color:var(--text);margin:.25rem 0 0;font-size:.875rem;font-weight:600}.topic-content-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.timeline-grid{grid-template-columns:1.4fr minmax(280px,.9fr)}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);padding:1.25rem}.dashboard-card-header{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.dashboard-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.dashboard-meta-grid dt{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 .25rem;font-size:.6875rem;font-weight:700}.dashboard-meta-grid dd{color:var(--text);margin:0}.sidebar-brand{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.sidebar-brand-logo{flex-shrink:0;width:24px;height:24px}.nav-link{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition);background:0 0;padding:.5rem .75rem;font-size:.875rem}.nav-link:hover{background:var(--accent-soft);color:var(--text)}.sidebar-user{border-radius:var(--radius-sm);background:var(--background-accent);flex-direction:column;gap:.75rem;padding:.75rem;display:flex}.sidebar-user-row{align-items:center;gap:.5rem;display:flex}.sidebar-user-avatar{background:var(--accent);color:#fff;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.6875rem;font-weight:600;display:flex}.sidebar-user-name{margin:0;font-size:.8125rem;font-weight:600}.sidebar-user-email{color:var(--muted);margin:0;font-size:.75rem}.sidebar-signout{width:100%;color:var(--muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;align-items:center;gap:.375rem;padding:.375rem 0;font-size:.75rem;font-weight:500;display:flex}.sidebar-signout:hover{color:var(--text)}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-md);overflow-x:auto}table{border-collapse:collapse;background:var(--surface);width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:.75rem 1rem}th{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:var(--background-accent);font-size:.6875rem;font-weight:600}tr:last-child td{border-bottom:none}.table-actions{flex-wrap:wrap;align-items:flex-end;gap:.5rem;display:flex}.item-list,.timeline-list{flex-direction:column;gap:.625rem;display:flex}.item-row,.timeline-row{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);justify-content:space-between;align-items:center;gap:.75rem;padding:.875rem 1rem;display:flex}.item-row-large,.timeline-row-stack{align-items:flex-start}.item-row-title{color:var(--text);font-weight:600}.timeline-row-meta{flex-direction:column;align-items:flex-end;gap:.375rem;display:flex}.field{flex-direction:column;gap:.25rem;display:flex}.field-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:600}.select{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);min-height:2.25rem;transition:border-color var(--transition);padding:.375rem .625rem;font-size:.8125rem}.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.setup-row{align-items:flex-start;gap:.75rem;display:flex}.setup-state{background:#d9770680;border-radius:999px;flex-shrink:0;width:8px;height:8px;margin-top:.375rem}.setup-state[data-ready=true]{background:var(--success)}.setup-label{margin:0;font-size:.875rem;font-weight:500}.setup-hint,.mono{font-family:var(--font-mono), monospace;font-size:.8125rem}.mono{word-break:break-all}.table-flat{overflow-x:auto}.table-flat table{background:0 0}.table-flat th{border-bottom:1px solid var(--border-strong);background:0 0}.table-flat tr:hover td{background:var(--accent-soft)}.section-divider{border-top:1px solid var(--border);padding-top:1.25rem}.meta-line{color:var(--muted);margin:0;font-size:.8125rem}.empty-state{border-radius:var(--radius-md);border:1px dashed var(--border-strong);background:var(--background-accent);color:var(--muted);padding:1rem;font-size:.875rem}.mobile-header{display:none}.mobile-menu-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:36px;height:36px;color:var(--text);cursor:pointer;transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.mobile-menu-btn:hover{background:var(--background-accent)}.sidebar-backdrop{display:none}@media (max-width:960px){.page-shell{height:auto;min-height:100dvh;overflow:visible}.workspace-shell{flex-direction:column;gap:0;height:100%;display:flex}.mobile-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-shrink:0;justify-content:flex-start;align-items:center;padding:.625rem 1rem;display:flex}.workspace-sidebar{z-index:100;width:280px;max-width:85vw;box-shadow:none;border-radius:0;transition:transform .25s cubic-bezier(.4,0,.2,1);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.workspace-sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 24px #0000001f}.sidebar-backdrop{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;display:block;position:fixed;inset:0}.workspace-main{border-radius:0 0 var(--radius-lg) var(--radius-lg);flex:1;min-height:0}.hero,.stats-grid,.feature-grid,.dashboard-grid,.timeline-grid,.topic-content-grid,.topic-stats-grid,.dashboard-meta-grid{grid-template-columns:1fr}.auth-shell{margin-top:8vh}.page-header,.workspace-topic-hero,.workspace-section-heading,.workspace-inline-heading,.dashboard-card-header,.item-row,.timeline-row{flex-direction:column;align-items:flex-start}.timeline-row-meta{align-items:flex-start}.table-flat{-webkit-overflow-scrolling:touch;margin-left:-.25rem;margin-right:-.25rem;padding-left:.25rem;padding-right:.25rem}.table-flat table{min-width:500px}.workspace-topic-title{font-size:1.5rem}.section-title{font-size:1.125rem}.button{min-height:2.75rem;padding:.625rem 1.125rem}.nav-link{align-items:center;min-height:2.5rem;display:flex}.nav-sub-link{min-height:2.25rem}.nav-section-toggle{min-height:2.5rem}.sidebar-settings-popover{box-shadow:none;border-color:var(--border);background:var(--background-accent);margin-top:.25rem;margin-bottom:0;position:relative;bottom:auto}}@media (max-width:640px){.page-shell{padding:0}.mobile-header{border-radius:0}.workspace-main{border-bottom:none;border-left:none;border-right:none;border-radius:0;padding:1rem}th,td{padding:.625rem .75rem;font-size:.8125rem}.workspace-topic-title{font-size:1.25rem}.hero-title{font-size:1.75rem}.meta-line{font-size:.75rem}.cluster{gap:.25rem}.badge{padding:.0625rem .375rem;font-size:.625rem}.table-actions{flex-direction:column;align-items:stretch}.table-actions .select,.table-actions .button{width:100%}}
