*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:Geist,ui-sans-serif,system-ui,-apple-system,sans-serif;font-feature-settings:"ss01","cv11";background:var(--bg);color:var(--fg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}input,textarea,select{font:inherit;color:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-radius:4px}::selection{background:color-mix(in oklch,var(--accent) 30%,transparent)}:root{--bg: oklch(99% .003 270);--bg-sub: oklch(97.5% .004 270);--surface: #ffffff;--surface-2: oklch(98% .003 270);--border: oklch(92% .006 270);--border-strong: oklch(86% .008 270);--fg: oklch(20% .012 270);--fg-muted: oklch(45% .012 270);--fg-faint: oklch(62% .01 270);--accent: oklch(55% .16 265);--accent-fg:#fff;--accent-soft: color-mix(in oklch, var(--accent) 12%, var(--surface));--assignment: oklch(58% .16 145);--product: oklch(68% .14 75);--knowledge: oklch(60% .14 235);--side: oklch(60% .14 305);--shadow-sm: 0 1px 0 oklch(0% 0 0 / .04), 0 1px 2px oklch(0% 0 0 / .04);--shadow-md: 0 1px 0 oklch(0% 0 0 / .04), 0 4px 12px -2px oklch(0% 0 0 / .08), 0 2px 4px -1px oklch(0% 0 0 / .04);--shadow-lg: 0 8px 32px -8px oklch(0% 0 0 / .14), 0 4px 12px -4px oklch(0% 0 0 / .08);--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--sidebar-w: 248px}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;height:100vh}.sidebar{background:var(--bg-sub);border-right:1px solid var(--border);display:flex;flex-direction:column;min-width:0}.brand{display:flex;align-items:center;gap:10px;padding:18px 16px 14px}.brand-mark{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,var(--accent) 0%,color-mix(in oklch,var(--accent) 65%,white) 100%);position:relative;display:grid;place-items:center}.brand-mark:after{content:"";width:8px;height:8px;border-radius:2px;background:#ffffffd9}.brand-name{font-weight:600;letter-spacing:-.01em;font-size:14px}.brand-sub{font-size:11px;color:var(--fg-faint);margin-top:1px}.workspace-switch{margin:4px 8px 14px;padding:8px 10px;display:flex;align-items:center;gap:8px;border-radius:var(--radius-sm);cursor:pointer}.workspace-switch:hover{background:var(--surface)}.ws-avatar{width:22px;height:22px;border-radius:5px;background:#daa24f;color:#fff;font-size:11px;font-weight:600;display:grid;place-items:center}.ws-meta{flex:1;min-width:0}.ws-name{font-size:13px;font-weight:500;line-height:1.2}.ws-role{font-size:11px;color:var(--fg-faint);line-height:1.2;margin-top:2px}.chev{color:var(--fg-faint);font-size:11px}.nav{padding:0 8px;display:flex;flex-direction:column;gap:1px}.nav-section{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-faint);padding:14px 10px 6px;font-weight:500}.nav-item{display:flex;align-items:center;gap:9px;padding:6px 10px;border-radius:var(--radius-sm);color:var(--fg-muted);font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;white-space:nowrap;min-width:0}.nav-item>span:not(.nav-count){min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis}.nav-count{flex-shrink:0}.nav-item:hover{background:var(--surface);color:var(--fg)}.nav-item.active{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-sm)}.nav-item .icon{width:15px;height:15px;flex-shrink:0;color:var(--fg-faint)}.nav-item.active .icon{color:var(--accent)}.nav-count{margin-left:auto;font-size:11px;color:var(--fg-faint);font-variant-numeric:tabular-nums}.sidebar-footer{margin-top:auto;padding:10px 8px;border-top:1px solid var(--border)}.main{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--bg)}.topbar{height:48px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px;background:var(--bg);flex-shrink:0}.crumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--fg-muted);min-width:0;overflow:hidden}.crumb{padding:3px 6px;border-radius:4px;cursor:pointer;white-space:nowrap}.crumb:hover{background:var(--surface-2);color:var(--fg)}.crumb.current{color:var(--fg);font-weight:500}.crumb-sep{color:var(--fg-faint);font-size:11px}.topbar .spacer{flex:1}.btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--fg);background:var(--surface);border:1px solid var(--border);cursor:pointer;transition:background .12s,border-color .12s}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn-primary{background:var(--accent);color:#fff;border-color:transparent}.btn-primary:hover{background:color-mix(in oklch,var(--accent) 88%,black);border-color:transparent}.btn-ghost{background:transparent;border-color:transparent;color:var(--fg-muted)}.btn-ghost:hover{background:var(--surface-2);color:var(--fg)}.btn-sm{padding:3px 7px;font-size:11.5px}.btn .icon{width:13px;height:13px}.kbd{font-family:Geist Mono,ui-monospace,monospace;font-size:10.5px;padding:1px 5px;border-radius:3px;background:var(--surface-2);border:1px solid var(--border);color:var(--fg-faint);margin-left:2px}.seg{display:inline-flex;padding:2px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);gap:2px}.seg button{padding:3px 9px;border-radius:4px;font-size:12px;color:var(--fg-muted);display:inline-flex;align-items:center;gap:5px}.seg button:hover{color:var(--fg)}.seg button.on{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-sm)}.seg .icon{width:12px;height:12px}.content{flex:1;min-height:0;display:flex;flex-direction:column;position:relative;overflow:hidden}.dash{padding:48px 56px;max-width:1080px;width:100%;margin:0 auto;overflow:auto}.dash h1{font-size:24px;font-weight:600;letter-spacing:-.01em;margin:0 0 4px}.dash .greet{font-size:13px;color:var(--fg-muted);margin-bottom:32px}.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:32px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.stat-label{font-size:11.5px;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.04em;font-weight:500}.stat-value{font-size:22px;font-weight:600;margin-top:4px;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.stat-delta{font-size:11px;color:var(--fg-muted);margin-top:2px}.stat-delta.up{color:#1c882d}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:28px 0 12px}.section-head h2{margin:0;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-muted)}.roadmap-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:border-color .12s,box-shadow .12s,transform .12s}.roadmap-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.rm-icon{width:36px;height:36px;border-radius:8px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex-shrink:0}.rm-icon svg{width:18px;height:18px}.rm-body{flex:1;min-width:0}.rm-title{font-size:14px;font-weight:500;letter-spacing:-.005em}.rm-meta{font-size:12px;color:var(--fg-muted);margin-top:2px}.rm-stats{display:flex;gap:18px;font-size:11.5px;color:var(--fg-muted)}.rm-stat{display:flex;align-items:center;gap:5px}.rm-stat .dot{width:7px;height:7px;border-radius:2px}.rm-stats .dot.a{background:var(--assignment)}.rm-stats .dot.p{background:var(--product)}.rm-stats .dot.k{background:var(--knowledge)}.rm-progress{width:100px;height:6px;background:var(--surface-2);border-radius:99px;overflow:hidden}.rm-progress>div{height:100%;background:var(--accent);border-radius:99px}.cards-grid{display:flex;flex-direction:column;gap:8px}.workspace{flex:1;display:grid;grid-template-columns:1fr 0;position:relative;min-height:0;overflow:hidden}.workspace.has-panel{grid-template-columns:1fr 380px}.workspace>.stage{position:relative;overflow:hidden;min-width:0}.canvas-wrap{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,var(--bg) 0,var(--bg) 70%,var(--bg-sub) 100%)}.canvas-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 1px 1px,oklch(85% .005 270) 1px,transparent 1px);background-size:24px 24px;opacity:.5;pointer-events:none}.canvas-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.canvas-nodes{position:absolute;top:0;right:0;bottom:0;left:0}.node{position:absolute;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none}.node-inner{display:flex;align-items:center;gap:7px;padding:7px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;white-space:nowrap;box-shadow:var(--shadow-sm);cursor:grab;transition:box-shadow .15s,border-color .15s,transform .1s}.node-inner:active{cursor:grabbing}.node.selected .node-inner{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 18%,transparent),var(--shadow-md)}.node:hover .node-inner{box-shadow:var(--shadow-md)}.node-edit-btn{display:none;margin-left:4px;padding:0 3px;background:none;border:none;cursor:pointer;font-size:11px;color:var(--fg-muted);line-height:1;border-radius:3px}.node-edit-btn:hover{background:var(--bg-hover);color:var(--fg)}.node:hover .node-edit-btn{display:inline-flex;align-items:center}.node-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.node-dot.a{background:var(--assignment)}.node-dot.p{background:var(--product)}.node-dot.k{background:var(--knowledge)}.node-dot.s{background:var(--side)}.node[data-kind=assignment] .node-inner{background:color-mix(in oklch,var(--assignment) 8%,var(--surface));border-color:color-mix(in oklch,var(--assignment) 35%,var(--border));font-weight:600}.node[data-kind=product] .node-inner{background:color-mix(in oklch,var(--product) 12%,var(--surface));border-color:color-mix(in oklch,var(--product) 40%,var(--border))}.node[data-kind=knowledge] .node-inner{background:var(--surface);border-color:color-mix(in oklch,var(--knowledge) 30%,var(--border));font-size:11.5px;padding:5px 9px}.node[data-kind=side] .node-inner{background:color-mix(in oklch,var(--side) 10%,var(--surface));border-color:color-mix(in oklch,var(--side) 30%,var(--border))}.node[data-kind=semester]{pointer-events:none;z-index:0}.node[data-kind=semester] .node-inner{background:transparent;border:0;box-shadow:none;padding:0;display:flex;flex-direction:column;align-items:center;gap:2px;font-weight:600;font-size:42px;line-height:1;letter-spacing:-.02em;text-transform:none;color:color-mix(in oklch,var(--fg) 14%,transparent);cursor:default}.node[data-kind=semester] .semester-period{font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:color-mix(in oklch,var(--fg) 22%,transparent)}.canvas-toolbar{position:absolute;left:50%;bottom:18px;transform:translate(-50%);display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:99px;padding:5px;box-shadow:var(--shadow-md);z-index:5}.canvas-toolbar button{width:30px;height:30px;border-radius:99px;display:grid;place-items:center;color:var(--fg-muted)}.canvas-toolbar button:hover{background:var(--surface-2);color:var(--fg)}.canvas-toolbar .divider{width:1px;height:18px;background:var(--border);margin:0 4px}.canvas-toolbar .icon{width:14px;height:14px}.canvas-toolbar .zoom-val{font-size:11px;color:var(--fg-muted);font-variant-numeric:tabular-nums;min-width:36px;text-align:center;font-family:Geist Mono,ui-monospace,monospace}.canvas-legend{position:absolute;left:16px;bottom:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;display:flex;gap:14px;box-shadow:var(--shadow-sm);z-index:5;font-size:11.5px;color:var(--fg-muted)}.legend-item{display:flex;align-items:center;gap:6px}.legend-item .dot{width:8px;height:8px;border-radius:2px}.canvas-controls{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:6px;z-index:5}.canvas-controls .btn{box-shadow:var(--shadow-sm)}.canvas-hint{font-size:11px;color:var(--fg-muted);background:var(--surface);border:1px solid var(--border);border-radius:99px;padding:5px 10px;box-shadow:var(--shadow-sm)}.canvas-hint b{color:var(--accent);font-weight:600}.alignment-bar{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;align-items:stretch;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md);padding:6px;gap:0;z-index:6;animation:alignBarIn .18s ease-out}@keyframes alignBarIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.align-group{display:flex;align-items:center;gap:2px;padding:0 6px}.align-label{font-size:10px;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.05em;margin-right:6px;font-weight:500}.align-divider{width:1px;background:var(--border);margin:4px 0}.align-btn{width:28px;height:28px;border-radius:6px;display:grid;place-items:center;color:var(--fg-muted);background:transparent;transition:background .12s,color .12s}.align-btn:hover{background:var(--surface-2);color:var(--fg)}.align-btn:disabled{opacity:.35;cursor:not-allowed}.align-btn:disabled:hover{background:transparent;color:var(--fg-muted)}.table-wrap{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;background:var(--bg)}.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;background:var(--surface)}.tbl thead th{position:sticky;top:0;z-index:2;background:var(--bg-sub);text-align:left;font-weight:500;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-muted);padding:9px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.tbl tbody td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:top}.tbl tbody tr{cursor:pointer}.tbl tbody tr:hover{background:var(--surface-2)}.tbl tbody tr.selected{background:var(--accent-soft)}.tbl .col-title{font-weight:500}.tbl .pill-stack{display:flex;flex-wrap:wrap;gap:4px}.tbl .grouped{background:var(--bg-sub);font-weight:500;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-muted)}.tbl .grouped td{padding:7px 12px}.tbl .indented{padding-left:28px}.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 7px;border-radius:99px;font-size:11px;font-weight:500;background:var(--surface-2);border:1px solid var(--border);color:var(--fg-muted);white-space:nowrap}.pill .dot{width:6px;height:6px;border-radius:2px}.pill.assignment .dot{background:var(--assignment)}.pill.assignment{background:color-mix(in oklch,var(--assignment) 8%,transparent);border-color:color-mix(in oklch,var(--assignment) 25%,var(--border));color:color-mix(in oklch,var(--assignment) 60%,var(--fg))}.pill.product .dot{background:var(--product)}.pill.product{background:color-mix(in oklch,var(--product) 12%,transparent);border-color:color-mix(in oklch,var(--product) 30%,var(--border));color:color-mix(in oklch,var(--product) 55%,var(--fg))}.pill.knowledge .dot{background:var(--knowledge)}.pill.knowledge{background:color-mix(in oklch,var(--knowledge) 8%,transparent);border-color:color-mix(in oklch,var(--knowledge) 25%,var(--border));color:color-mix(in oklch,var(--knowledge) 60%,var(--fg))}.pill.side .dot{background:var(--side)}.pill.outcome{background:var(--surface-2);color:var(--fg-muted);font-family:Geist Mono,ui-monospace,monospace;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em}.panel{border-left:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.panel-head{padding:14px 16px 10px;display:flex;align-items:flex-start;gap:10px;border-bottom:1px solid var(--border)}.panel-kind{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.panel-kind .dot{width:7px;height:7px;border-radius:2px}.panel-title{font-size:16px;font-weight:600;letter-spacing:-.01em;line-height:1.25;outline:none;border-radius:4px;padding:1px 0;word-break:break-word}.panel-title:focus{background:var(--accent-soft)}.panel-close{margin-left:auto;width:24px;height:24px;border-radius:5px;display:grid;place-items:center;color:var(--fg-faint)}.panel-close:hover{background:var(--surface-2);color:var(--fg)}.panel-body{flex:1;overflow:auto;padding:8px 0 24px}.field{padding:10px 16px}.field-label{font-size:11px;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.04em;font-weight:500;margin-bottom:6px;display:flex;align-items:center;gap:6px}.field-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.field-text{font-size:13px;color:var(--fg);line-height:1.55}.field-text.muted{color:var(--fg-muted)}.field-input{width:100%;padding:6px 8px;border-radius:5px;background:var(--surface-2);border:1px solid var(--border);font-size:13px}.field-input:focus{background:var(--surface);border-color:var(--accent)}.field-textarea{width:100%;min-height:80px;padding:8px;border-radius:5px;background:var(--surface-2);border:1px solid var(--border);font-size:13px;line-height:1.5;resize:vertical;font-family:inherit}.field-textarea:focus{background:var(--surface);border-color:var(--accent)}.linked-list{display:flex;flex-direction:column;gap:1px}.linked-row{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:5px;cursor:pointer;transition:background .12s}.linked-row:hover{background:var(--surface-2)}.linked-row .dot{width:7px;height:7px;border-radius:2px;flex-shrink:0}.linked-row .lr-title{font-size:13px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.linked-row .lr-meta{font-size:11px;color:var(--fg-faint);flex-shrink:0}.add-link{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:5px;font-size:12px;color:var(--fg-faint);cursor:pointer;border:1px dashed var(--border-strong);margin-top:4px}.add-link:hover{color:var(--accent);border-color:var(--accent)}.ai-card{margin:8px 16px 0;padding:12px 14px;border-radius:var(--radius-sm);background:linear-gradient(135deg,color-mix(in oklch,var(--accent) 8%,var(--surface)) 0%,var(--surface) 100%);border:1px solid color-mix(in oklch,var(--accent) 25%,var(--border))}.ai-card-head{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:500;color:color-mix(in oklch,var(--accent) 60%,var(--fg));margin-bottom:6px}.ai-card-head .icon{width:14px;height:14px}.ai-card-body{font-size:12.5px;color:var(--fg-muted);line-height:1.5}.ai-actions{display:flex;gap:6px;margin-top:10px}.kb-page{display:grid;grid-template-columns:240px 1fr;height:100%;min-height:0}.kb-side{border-right:1px solid var(--border);background:var(--bg-sub);padding:14px 8px;overflow:auto}.kb-side h3{margin:8px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-faint);font-weight:500}.kb-tag{display:flex;align-items:center;gap:8px;padding:5px 10px;border-radius:5px;font-size:12.5px;color:var(--fg-muted);cursor:pointer}.kb-tag:hover,.kb-tag.active{background:var(--surface);color:var(--fg)}.kb-tag .dot{width:7px;height:7px;border-radius:2px;background:var(--knowledge)}.kb-tag .count{margin-left:auto;font-size:11px;color:var(--fg-faint);font-variant-numeric:tabular-nums}.kb-main{display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.kb-header{padding:18px 24px 12px;display:flex;align-items:center;gap:10px}.kb-header h1{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em}.kb-header .sub{color:var(--fg-muted);font-size:13px;margin-left:4px}.kb-search{position:relative;flex:1;max-width:340px;margin-left:auto}.kb-search input{width:100%;padding:6px 10px 6px 30px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:13px}.kb-search .icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:var(--fg-faint)}.kb-list{flex:1;overflow:auto;padding:0 24px 24px}.kb-row{display:grid;grid-template-columns:1fr 200px 90px 90px;align-items:center;gap:12px;padding:12px 4px;border-bottom:1px solid var(--border);cursor:pointer}.kb-row:hover{background:var(--surface-2)}.kb-row .t{display:flex;flex-direction:column;gap:2px;min-width:0}.kb-row .name{font-weight:500;font-size:13.5px}.kb-row .desc{font-size:12px;color:var(--fg-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kb-row .col-meta{font-size:12px;color:var(--fg-muted)}.kb-row .status{display:inline-flex;align-items:center;gap:5px;font-size:11.5px}.kb-row .status .dot{width:6px;height:6px;border-radius:99px}.status.synced .dot{background:#31983d}.status.draft .dot{background:#cb9317}.status.unlinked .dot{background:var(--fg-faint)}.prompts{padding:32px 56px;max-width:980px;margin:0 auto;width:100%;overflow:auto}.prompts h1{margin:0;font-size:22px;font-weight:600;letter-spacing:-.01em}.prompts>.lead{color:var(--fg-muted);font-size:13.5px;margin:6px 0 28px;max-width:560px}.prompt-tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:18px}.prompt-tab{padding:9px 14px;font-size:13px;font-weight:500;color:var(--fg-muted);border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:7px}.prompt-tab .dot{width:8px;height:8px;border-radius:2px}.prompt-tab.active{color:var(--fg);border-bottom-color:var(--accent)}.prompt-tab:hover{color:var(--fg)}.prompt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.prompt-card .label{font-size:11px;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.04em;font-weight:500;margin-bottom:8px;display:flex;align-items:center;gap:6px}.prompt-editor{width:100%;min-height:220px;padding:14px;font-family:Geist Mono,ui-monospace,monospace;font-size:12.5px;line-height:1.65;border-radius:6px;background:var(--bg-sub);border:1px solid var(--border);resize:vertical}.prompt-vars{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.var-pill{font-family:Geist Mono,ui-monospace,monospace;font-size:10.5px;padding:2px 6px;border-radius:99px;background:var(--surface-2);border:1px solid var(--border);color:var(--fg-muted);cursor:pointer}.var-pill:hover{background:var(--accent-soft);color:var(--accent)}.prompt-meta-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}.prompt-actions{display:flex;gap:8px;margin-top:18px;align-items:center}.prompt-status{margin-left:auto;font-size:11.5px;color:var(--fg-muted);display:flex;align-items:center;gap:6px}.prompt-status .dot{width:6px;height:6px;border-radius:99px;background:#31983d}.preview{flex:1;background:linear-gradient(180deg,#f0f2f5,#eaebef);overflow:auto;padding:24px 0}.preview-frame{max-width:1100px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden}.preview-bar{height:34px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;padding:0 14px;background:var(--bg-sub);font-size:11px;color:var(--fg-faint)}.preview-dots{display:flex;gap:5px}.preview-dots i{width:9px;height:9px;border-radius:99px;background:var(--border-strong);display:block}.preview-url{margin:0 auto;font-family:Geist Mono,ui-monospace,monospace;font-size:11px;color:var(--fg-muted);padding:2px 12px;background:var(--surface);border:1px solid var(--border);border-radius:99px}.preview-body{padding:48px 64px 64px;min-height:520px}.preview-body h1{font-size:30px;margin:0;letter-spacing:-.02em;font-weight:600}.preview-body .lede{color:var(--fg-muted);font-size:14px;margin:6px 0 36px}.semester-chip{display:inline-flex;align-items:center;padding:6px 14px;border-radius:99px;background:var(--bg-sub);border:1px solid var(--border);font-size:12px;font-weight:500;color:var(--fg-muted)}.preview-roadmap{display:grid;grid-template-columns:160px 1fr;gap:24px;margin-top:24px;align-items:start}.preview-period{padding:8px 0;font-size:13px;font-weight:600;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.04em}.preview-assignments{display:flex;flex-direction:column;gap:14px}.preview-assignment{border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;background:var(--surface);cursor:pointer;transition:border-color .12s,box-shadow .12s}.preview-assignment:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.pa-head{display:flex;align-items:center;gap:8px;margin-bottom:4px}.pa-head .badge{background:var(--assignment);color:#fff;font-size:10.5px;padding:2px 7px;border-radius:99px;font-weight:600;letter-spacing:.02em}.pa-title{font-size:16px;font-weight:600;letter-spacing:-.005em}.pa-desc{font-size:13px;color:var(--fg-muted);line-height:1.55;margin:4px 0 12px}.pa-products{display:flex;flex-wrap:wrap;gap:8px}.pa-product{display:flex;align-items:center;gap:7px;padding:6px 10px;border-radius:6px;border:1px solid var(--border);font-size:12.5px;background:var(--surface-2)}.pa-product .dot{width:7px;height:7px;border-radius:2px;background:var(--product)}.pa-product .count{font-size:10.5px;color:var(--fg-faint);font-family:Geist Mono,ui-monospace,monospace}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--fg-faint);gap:8px}.empty .icon{width:34px;height:34px;opacity:.4}.empty h3{margin:6px 0 0;font-size:14px;color:var(--fg-muted);font-weight:500}.empty p{margin:0;font-size:12.5px;max-width:300px;text-align:center}[class*=TweaksPanel]{font-family:inherit!important}
