:root{--bg: #f6f4ef;--paper: #fffdfa;--ink: #191714;--muted: #5f5a52;--line: #e4ddd2;--accent: #1e5c5a;--accent-light: #e8f2f1;--ok: #16803c;--danger: #c43b2f;--amber: #9a6700;--warn-bg: #fff8e8;--code-bg: #f0ebe3;--sidebar: #ede8df;--sans: "Libre Franklin", ui-sans-serif, system-ui, sans-serif;--serif: "Libre Baskerville", Georgia, serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-9: 36px;--touch-min: 44px;--page-pad-bottom: 72px;--text-caption: .82rem;--text-ui: .92rem;--text-body: 1rem;--text-title-sm: 1.05rem;--text-title: 1.28rem;--text-page: 1.5rem;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--shadow-card: 0 12px 40px rgba(0, 0, 0, .06)}@media(prefers-color-scheme:dark){:root{--bg: #0c0e12;--paper: #14171d;--ink: #e8e6e1;--muted: #a8a39a;--line: #2a2f38;--accent: #3d9a96;--accent-light: #1a2e2d;--ok: #22c55e;--danger: #ff5a4d;--amber: #f59e0b;--warn-bg: #1a1710;--code-bg: #1c2028;--sidebar: #1a1e26}}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--serif);line-height:1.6;font-size:16px}h1,h2,h3,h4,button,label,.meta,.badge,nav,table{font-family:var(--sans)}h1{margin:0 0 var(--space-2);font-size:var(--text-page);font-weight:700;letter-spacing:-.02em;line-height:1.15}h2{margin:0 0 var(--space-3);font-size:var(--text-title);font-weight:700;letter-spacing:-.01em}h2.section-after{margin-top:var(--space-9)}h3{margin:var(--space-6) 0 var(--space-2);font-size:1rem;font-weight:600}p{margin:0 0 var(--space-3)}a{color:var(--accent)}.app-chrome{position:sticky;top:0;z-index:200;background:var(--paper);border-bottom:1px solid var(--line);box-shadow:0 1px color-mix(in srgb,var(--line) 80%,transparent)}.app-chrome-inner{max-width:980px;margin:0 auto;padding:0 var(--space-6);display:flex;align-items:center;gap:var(--space-4);min-height:52px}.app-brand{font-family:var(--sans);font-size:.92rem;font-weight:700;color:var(--accent);letter-spacing:-.01em;flex-shrink:0}.app-nav{display:flex;align-items:center;gap:var(--space-1);flex:1;min-width:0;margin-left:calc(var(--space-4) * 2)}.app-nav-link{display:inline-flex;align-items:center;min-height:36px;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);color:var(--muted);font-family:var(--sans);font-size:.88rem;font-weight:600;text-decoration:none;white-space:nowrap}.app-nav-link:hover,.app-nav-link.active{color:var(--accent);background:var(--accent-light)}.app-chrome-help{flex-shrink:0;min-height:36px;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);color:var(--muted);font-family:var(--sans);font-size:.88rem;font-weight:600;text-decoration:none}.app-chrome-help:hover{color:var(--accent);background:var(--accent-light)}.app-chrome-session{margin:0 0 0 auto;display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;min-width:0}.app-chrome-email{color:var(--muted);font-family:var(--sans);font-size:.86rem;font-weight:500;max-width:14rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-chrome-sign-out{flex-shrink:0;min-height:32px;padding:var(--space-1) var(--space-2);font-size:.82rem}.shell{max-width:720px;margin:0 auto;padding:var(--space-6) var(--space-6) var(--page-pad-bottom)}.shell.wide{max-width:980px}.shell-auth{max-width:420px}.auth-card-result{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-4)}.auth-card-action{display:inline-block;text-align:center;text-decoration:none}.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--space-7) var(--space-8);box-shadow:var(--shadow-card)}.page-header{margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--line)}.page-nav{margin:0 0 var(--space-3);font-family:var(--sans);font-size:.88rem}.page-breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1);margin:0 0 var(--space-3);font-family:var(--sans);font-size:.88rem}.page-breadcrumb-sep{color:var(--muted)}.page-header-row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:var(--space-3) var(--space-5)}.page-header-titles h1{margin:0}.page-header-actions{flex-shrink:0}.page-header-btn{display:inline-flex;align-items:center;min-height:36px;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);background:var(--accent-light);color:var(--accent);font-family:var(--sans);font-size:.88rem;font-weight:600;text-decoration:none}.page-header-btn:hover{background:color-mix(in srgb,var(--accent) 12%,var(--accent-light));text-decoration:none}.page-subtitle{margin:var(--space-2) 0 0;font-family:var(--sans);font-size:var(--text-ui);color:var(--muted);font-weight:500}.page-context-nav{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3);font-family:var(--sans)}.page-context-link{display:inline-flex;align-items:center;min-height:32px;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);border:none;color:var(--accent);font-size:.86rem;font-weight:600;text-decoration:underline;text-underline-offset:2px}.page-context-link:hover{background:var(--accent-light);text-decoration:none}.section-title{margin:0 0 var(--space-3);font-size:var(--text-title)}.section-lead{margin:0 0 var(--space-4)}.content-section+.content-section{margin-top:var(--space-9);padding-top:var(--space-9);border-top:1px solid var(--line)}.meta{color:var(--muted);font-size:.86rem}.meta strong{color:var(--ink)}.field-label{display:block;font-weight:600;font-size:var(--text-caption);text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0}.field-group+.field-group{margin-top:var(--space-6)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-stack,.form-col{display:flex;flex-direction:column;gap:var(--space-6);max-width:420px}input[type=email],input[type=text],input:not([type]),select,textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--line);border-radius:8px;font:inherit;background:var(--paper);color:var(--ink)}.form-row{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-3);align-items:center}.form-row input,.form-row select{width:auto;flex:1;min-width:140px}.msg-after-form{margin-top:var(--space-4)}.upload-row{display:block;margin:var(--space-3) 0;font-family:var(--sans)}button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);min-height:32px;background:transparent;color:var(--accent);border:none;border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);font-family:var(--sans);font-size:var(--text-ui);font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px}button:hover:not(:disabled),.btn:hover:not(:disabled){background:var(--accent-light);text-decoration:none}button:disabled,.btn:disabled{opacity:.45;cursor:not-allowed}button.secondary,.btn.secondary{color:var(--accent)}button.secondary.active,.btn.secondary.active,button.active,.btn.active{background:var(--accent-light);text-decoration:none}button.btn-primary,.btn.btn-primary{min-height:var(--touch-min);padding:var(--space-2) var(--space-5);background:var(--accent);color:var(--paper);border:1px solid var(--accent);border-radius:var(--radius-sm);font-weight:600;text-decoration:none}button.btn-primary:hover:not(:disabled),.btn.btn-primary:hover:not(:disabled){background:color-mix(in srgb,var(--accent) 88%,var(--ink));border-color:color-mix(in srgb,var(--accent) 88%,var(--ink))}button.compact,.btn.compact{min-height:28px;padding:var(--space-1) var(--space-2);font-size:.86rem}.error{color:var(--danger);margin-top:var(--space-3)}.badge{display:inline-block;background:var(--accent-light);color:var(--accent);padding:var(--space-1) var(--space-3);border-radius:999px;font-size:.82rem;font-weight:600}.badge.badge-warn{background:var(--warn-bg);color:var(--amber)}.dev-link{margin-top:var(--space-4);padding:var(--space-3);background:var(--warn-bg);border-radius:8px;font-size:.88rem;word-break:break-all}.filter-chip{display:inline-flex;align-items:center;min-height:32px;padding:var(--space-1) var(--space-2);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-family:var(--sans);font-size:.86rem;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.filter-chip:hover,.filter-chip.active{background:var(--accent-light);text-decoration:none}.save-status{font-family:var(--sans);font-size:.82rem;font-weight:500;color:var(--muted);display:inline-grid;vertical-align:middle}.save-status-text,.save-status-reserve{grid-area:1 / 1;white-space:nowrap}.save-status-reserve{visibility:hidden;font-weight:500}.save-status-saving{color:var(--accent)}.save-status-error{color:var(--danger);font-weight:600}.editor-context-link{font-family:var(--sans);font-size:.82rem;font-weight:600;text-decoration:none;color:var(--accent);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);flex-shrink:0}.editor-context-link:hover{background:var(--accent-light)}.action-bar{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-4) 0}.piece-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin:0 0 var(--space-4);font-family:var(--sans)}.data-table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:var(--text-ui);margin:var(--space-3) 0}.data-table th,.data-table td{text-align:left;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--line);vertical-align:top}.data-table th{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;background:color-mix(in srgb,var(--sidebar) 70%,transparent)}.data-table tr:last-child td{border-bottom:none}.data-table.sortable th:not(.table-actions-head){cursor:pointer;-webkit-user-select:none;user-select:none;padding-right:1.25rem;position:relative}.data-table.sortable th:not(.table-actions-head):hover{color:var(--accent)}.data-table.sortable th:not(.table-actions-head):after{content:"⇅";position:absolute;right:.35rem;opacity:.35;font-size:.7rem}.data-table.sortable th.sorted-asc:after{content:"↑";opacity:.9}.data-table.sortable th.sorted-desc:after{content:"↓";opacity:.9}.table-wrap{overflow-x:auto;margin:var(--space-3) 0;border:1px solid var(--line);border-radius:10px}.table-wrap .data-table{margin:0}.pieces-table{table-layout:auto}.pieces-table col.col-title{width:100%}.pieces-table col.col-materials,.pieces-table col.col-updated{width:0}.pieces-table col.col-actions{width:1%}.pieces-table .col-title{width:auto;min-width:10rem}.pieces-table .col-materials,.pieces-table .col-updated{width:0;white-space:nowrap;padding-right:calc(var(--space-3) * 1.1)}.pieces-table .col-actions,.pieces-table .table-actions-head.col-actions{width:1%;min-width:5.5rem;white-space:nowrap;padding-right:calc(var(--space-3) * 1.1);text-align:right;vertical-align:top}.pieces-table .table-actions{display:flex;align-items:flex-start;justify-content:flex-end;vertical-align:top}.pieces-table .table-actions-group{align-items:flex-start}.table-actions-head{width:1%;white-space:nowrap}.table-actions{display:inline-flex;flex-wrap:nowrap;gap:var(--space-1);align-items:center;justify-content:flex-end;max-width:100%}.table-role-field{display:block;margin:0}.table-role-select{width:auto;min-width:7.5rem;min-height:32px;padding:var(--space-1) var(--space-2);font-family:var(--sans);font-size:.86rem;font-weight:600}.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}.table-text-btn{flex-shrink:0;white-space:nowrap}a.table-text-btn{text-decoration:underline;text-underline-offset:2px;color:var(--accent)}a.table-text-btn:hover{background:var(--accent-light);text-decoration:none}.piece-created-title{margin:0;font-family:var(--sans);font-size:1.75rem;font-weight:700;line-height:1.25;color:var(--ink)}.piece-title-cell{display:flex;align-items:flex-start;gap:var(--space-2);min-width:0}.piece-rename-btn{flex-shrink:0;opacity:.55}.piece-title-cell:hover .piece-rename-btn,.piece-rename-btn:focus-visible{opacity:1}.piece-rename-form{display:flex;align-items:center;gap:var(--space-2);min-width:0}.piece-rename-input{flex:1;min-width:0;min-height:var(--touch-min);padding:var(--space-2) var(--space-3);border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--sans);font-size:var(--text-ui);background:var(--paper);color:var(--ink)}.piece-title-link{color:var(--ink);font-weight:600;text-decoration:none}.piece-title-link:hover{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.materials-cell{display:inline-flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.materials-indicator{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--sans);font-size:.82rem;white-space:nowrap}.materials-dots{display:inline-flex;gap:4px}.materials-dot{width:8px;height:8px;border-radius:50%;background:var(--line)}.materials-dot.on{background:var(--ok)}.materials-dot.optional{box-sizing:border-box;border:1px dashed var(--muted);background:transparent}.materials-dot.optional.on{background:color-mix(in srgb,var(--ok) 45%,transparent);border-color:var(--ok)}.materials-indicator.ready .materials-label{color:var(--ok);font-weight:600}.materials-indicator.incomplete .materials-label{color:var(--amber);font-weight:600}.section-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.table-empty{margin:var(--space-4) 0}.filter-row{display:flex;gap:var(--space-3);align-items:center;margin:var(--space-4) 0;font-family:var(--sans);flex-wrap:wrap}.filter-row label{display:flex;gap:var(--space-2);align-items:center;font-weight:600}.filter-row select{width:auto;padding:var(--space-2) var(--space-3)}.filter-row .filter-chip{margin-left:var(--space-1)}.ok{color:var(--accent);margin-top:var(--space-3)}.warn{color:var(--amber);font-family:var(--sans);font-size:.88rem}.warn button{margin-left:var(--space-2)}.editor-layout{min-height:100vh;height:100vh;display:flex;flex-direction:column}.editor-back{font-family:var(--sans);font-size:.88rem;font-weight:600;text-decoration:none;color:var(--accent);flex-shrink:0;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm)}.editor-back:hover{background:var(--accent-light)}.editor-bar{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,max-content);grid-template-areas:"identity tools actions";gap:var(--space-3) var(--space-4);align-items:center;padding:var(--space-3) var(--space-5);background:var(--paper);border-bottom:1px solid var(--line);font-family:var(--sans)}.editor-bar-identity{grid-area:identity;display:flex;align-items:center;gap:var(--space-2);min-width:0}.editor-bar h1{margin:0;font-size:1.1rem;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-bar-tools{grid-area:tools;display:flex;gap:var(--space-5);align-items:center;flex-shrink:0;justify-self:center}.editor-bar-cluster{display:inline-flex;align-items:center;gap:var(--space-1)}.editor-bar-cluster-zoom{gap:var(--space-2)}.editor-bar .zoom-control{font-size:.78rem;gap:var(--space-1)}.editor-bar .zoom-control input[type=range]{width:4.25rem}.editor-bar-actions{grid-area:actions;display:flex;gap:var(--space-4);align-items:center;flex-wrap:nowrap;justify-self:end;max-width:100%;overflow-x:auto}.editor-bar-zone{display:flex;gap:var(--space-1);align-items:center;flex-wrap:wrap}.editor-bar-zone-status{gap:var(--space-2)}.editor-bar-zone-status .save-status{margin-left:var(--space-1)}.editor-bar-zone-status .warn{margin-left:var(--space-2)}.editor-bar-zone+.editor-bar-zone{border-left:1px solid var(--line);padding-left:var(--space-4);margin-left:var(--space-1)}.editor-bar-zone-workflow,.editor-bar-zone-history{gap:var(--space-2)}.table-actions-group{display:inline-flex;flex-wrap:nowrap;gap:var(--space-1);align-items:center}.table-actions-group+.table-actions-group{border-left:1px solid var(--line);padding-left:var(--space-2);margin-left:var(--space-1)}.context-hint{margin:var(--space-4) 0;padding:var(--space-3) var(--space-4);background:color-mix(in srgb,var(--accent) 6%,var(--paper));border-radius:var(--radius-md);border:1px solid var(--line)}.icon-btn{min-height:32px;min-width:32px;padding:var(--space-1);color:var(--accent);font-size:var(--text-ui);line-height:1;text-decoration:none}.icon-btn:hover:not(:disabled){background:var(--accent-light)}.icon-btn--danger{color:var(--danger)}.icon-btn--danger:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 12%,var(--paper))}.editor-main{flex:1;padding:0;min-width:0}.changes-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000038;opacity:0;pointer-events:none;transition:opacity .28s ease;z-index:90}.changes-backdrop.open{opacity:1;pointer-events:auto}.changes-drawer{position:fixed;top:0;right:0;width:min(360px,100vw);height:100vh;background:var(--paper);border-left:1px solid var(--line);padding:var(--space-5);overflow:auto;z-index:100;transform:translate(100%);transition:transform .28s ease;box-shadow:-8px 0 32px #00000014}.changes-drawer.open{transform:translate(0)}.changes-drawer-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.changes-drawer-head h2{margin:0;font-size:1.1rem}.changes-close{flex-shrink:0;font-size:1.1rem}.history-list{list-style:none;padding:0;margin:var(--space-4) 0}.history-list li.history-row{padding:0;border-bottom:1px solid var(--line)}.history-list li.history-row.session-autosave .history-row-delta{color:var(--muted)}.history-list.nested{margin:0}.history-list.nested>li:last-child{border-bottom:none}.history-group{list-style:none;padding:0;border-bottom:1px solid var(--line)}.session-expand{display:block;width:100%;margin:var(--space-2) 0;padding:var(--space-2) var(--space-3);background:transparent;color:var(--muted);border:none;border-radius:8px;font-family:var(--sans);font-size:.82rem;font-weight:500;cursor:pointer;min-height:var(--touch-min);text-align:left;text-decoration:none}.session-expand:hover{color:var(--accent);background:var(--accent-light)}.history-row-main{display:flex;align-items:stretch;gap:var(--space-1)}.history-row-hit{flex:1;display:block;width:100%;margin:0;padding:var(--space-3) var(--space-2) var(--space-3) 0;border:none;background:transparent;text-align:left;cursor:pointer;font-family:var(--sans);color:inherit;border-radius:8px;text-decoration:none;min-height:auto}.history-row-hit:hover{background:color-mix(in srgb,var(--accent) 6%,transparent)}.history-row.selected .history-row-hit{background:var(--accent-light)}.history-row.current:not(.selected) .history-row-hit{box-shadow:inset 3px 0 0 var(--accent);padding-left:var(--space-2)}.history-row-primary{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);font-size:.92rem;font-weight:400;line-height:1.35}.history-row-when{color:var(--ink)}.history-row.current:not(.selected) .history-row-when{font-weight:600}.history-row-author{font-weight:400;color:var(--muted)}.history-row-delta{margin-top:var(--space-1);font-size:.85rem;font-weight:400;color:var(--muted);line-height:1.4}.history-row-delta.is-substantive{font-weight:500;color:var(--ink)}.history-list li.history-row.session-autosave .history-row-delta.is-substantive{color:var(--muted)}.badge.milestone,.badge.current-badge{font-size:.78rem;font-weight:600}.history-row-menu-wrap{position:relative;flex-shrink:0;align-self:flex-start;padding-top:var(--space-2)}.history-menu-trigger{font-size:.92rem;letter-spacing:.02em}.history-row-menu{position:absolute;top:calc(100% - var(--space-1));right:0;z-index:20;min-width:168px;background:var(--paper);border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px #0000001a;padding:var(--space-1);display:flex;flex-direction:column}.history-row-menu button{display:block;width:100%;margin:0;padding:var(--space-2) var(--space-3);border:none;border-radius:6px;background:transparent;text-align:left;font-family:var(--sans);font-size:.88rem;font-weight:500;color:var(--ink);cursor:pointer;min-height:36px;text-decoration:none}.history-row-menu button:hover:not(:disabled){background:var(--accent-light);color:var(--accent)}.history-row-menu button:disabled{opacity:.45;cursor:not-allowed}.preview-banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--warn-bg);border-bottom:1px solid var(--line);font-family:var(--sans);font-size:.9rem}.preview-banner-text{color:var(--amber)}.preview-banner-actions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.label-form{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-2);align-items:center}.label-form input{flex:1;min-width:140px;padding:var(--space-2) var(--space-3)}.btn-row{display:flex;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;align-items:center}.btn-row--lead{margin-top:var(--space-3)}.link-btn{display:inline-flex;align-items:center;min-height:32px;padding:var(--space-1) var(--space-2);border:none;border-radius:var(--radius-sm);font-family:var(--sans);font-weight:600;text-decoration:underline;text-underline-offset:2px;color:var(--accent)}.link-btn:hover{background:var(--accent-light);text-decoration:none}.link-btn.compact{min-height:28px;font-size:.86rem}.invite-form{align-items:end;gap:var(--space-3)}.invite-form label{display:flex;flex-direction:column;gap:var(--space-2);font-weight:600;margin:0}.invite-email{flex:2;min-width:200px}.invite-email input{width:100%}.invite-role{flex:0 0 140px}.invite-role select{width:100%}.invite-form input,.invite-form select{min-height:var(--touch-min);height:var(--touch-min);box-sizing:border-box;padding:0 var(--space-3);line-height:calc(var(--touch-min) - 2px);font-family:var(--sans);font-size:var(--text-ui)}.invite-form select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:var(--space-8)}.invite-submit{flex-shrink:0;align-self:end;min-height:var(--touch-min)}.team-invite-section.content-section{margin-top:0;padding-top:0;border-top:none}.invite-table-row td{padding-top:var(--space-4);border-top:2px solid var(--line);background:color-mix(in srgb,var(--accent-light) 35%,var(--paper))}.invite-table-form{display:flex;gap:var(--space-3);align-items:end;flex-wrap:wrap}.invite-table-field .field-label{font-size:.72rem}.invite-table-field{display:flex;flex-direction:column;gap:var(--space-2);margin:0;font-family:var(--sans)}.invite-table-field.invite-email{flex:2;min-width:200px}.invite-table-field.invite-role{flex:1;min-width:120px}.invite-table-form input,.invite-table-form select{min-height:var(--touch-min);height:var(--touch-min);box-sizing:border-box;padding:0 var(--space-3);line-height:calc(var(--touch-min) - 2px);font-family:var(--sans);font-size:var(--text-ui);width:100%}.invite-table-form select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:var(--space-8)}.invite-table-submit{flex-shrink:0}.table-empty-cell{padding:var(--space-4) var(--space-3)}.feedback-banner{margin-top:var(--space-5);padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);border:1px solid var(--line);font-family:var(--sans)}.feedback-banner--inline{margin-top:0;margin-bottom:var(--space-4)}.feedback-banner--success{background:color-mix(in srgb,var(--ok) 8%,var(--paper));border-color:color-mix(in srgb,var(--ok) 35%,var(--line))}.feedback-banner--warn{background:var(--warn-bg);border-color:color-mix(in srgb,var(--amber) 35%,var(--line))}.feedback-banner-title{margin:0 0 var(--space-2);font-size:var(--text-title-sm);font-weight:700;color:var(--ink)}.feedback-banner--success .feedback-banner-title{color:var(--ok)}.feedback-banner--warn .feedback-banner-title{color:var(--amber)}.feedback-banner-detail{margin:0;font-size:var(--text-ui);color:var(--muted)}.feedback-banner-actions{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:stretch}.feedback-banner-link{flex:1;min-width:12rem;min-height:var(--touch-min);padding:0 var(--space-3);border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:.82rem}.feedback-banner-copy{flex-shrink:0;min-height:var(--touch-min);padding:0 var(--space-4);background:var(--accent-light);text-decoration:none}.materials-panel{font-family:var(--sans)}.materials-panel>.feedback-banner--inline{margin-bottom:var(--space-4)}.materials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:var(--space-3)}.material-tile{position:relative;aspect-ratio:5 / 6;display:flex;flex-direction:column;align-items:stretch;gap:var(--space-2);padding:var(--space-4);border:1px solid var(--line);border-radius:var(--radius-md);background:color-mix(in srgb,var(--bg) 35%,var(--paper));min-width:0}.material-tile-head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);min-height:1.2em}.material-tile--ready{border-color:color-mix(in srgb,var(--ok) 40%,var(--line));background:color-mix(in srgb,var(--ok) 5%,var(--paper))}.material-tile--busy{opacity:.75}.material-tile-label{font-size:var(--text-ui);font-weight:700;line-height:1.2}.material-tile-badge{align-self:flex-start;font-size:.432rem;font-weight:400;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);background:var(--accent-light);padding:2px var(--space-2);border-radius:999px}.material-tile-badge--optional{color:var(--muted);background:color-mix(in srgb,var(--muted) 12%,var(--paper))}.material-tile-status{flex:1;display:flex;flex-direction:column;justify-content:center;gap:var(--space-1);font-size:.78rem;color:var(--muted);line-height:1.35;min-height:0}.material-tile-check{flex-shrink:0;color:var(--ok);font-weight:700;font-size:1rem;line-height:1.2}.material-tile-filename{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.material-tile-actions{display:flex;flex-direction:column;gap:var(--space-1);margin-top:auto}.material-tile-action{width:100%;min-height:32px;background:var(--accent-light);text-decoration:none;font-size:.84rem}.material-tile-remove{width:100%;min-height:28px;background:transparent;color:var(--danger);font-size:.78rem;text-decoration:underline;text-underline-offset:2px}.material-tile-remove:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 8%,var(--paper));text-decoration:none}.material-tile-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.materials-editor-cta-wrap{display:flex;justify-content:center;margin-top:var(--space-6)}.materials-editor-cta{min-height:52px;min-width:11rem;padding:var(--space-3) var(--space-8);font-size:var(--text-title-sm);text-decoration:none}.notes-preview{background:var(--code-bg);padding:var(--space-3);border-radius:8px;font-size:.82rem;max-height:200px;overflow:auto}.canvas-main{padding:0;display:flex;flex-direction:column;flex:1;min-height:0}.onset-editor{display:flex;flex-direction:column;flex:1;min-height:0}.timeline-canvas-stage{position:relative;flex:1;display:flex;flex-direction:column;min-height:0}.timeline-canvas-stage .timeline-scroll{flex:1}.editor-materials-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;align-items:center;justify-content:center;padding:var(--space-8);background:color-mix(in srgb,var(--paper) 78%,transparent);pointer-events:none}.editor-materials-overlay-text{margin:0;max-width:32rem;text-align:center;font-family:var(--sans);font-size:var(--text-title);font-weight:600;line-height:1.45;color:var(--ink);pointer-events:auto}.editor-materials-overlay-text a{font-weight:700}.zoom-control{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--muted)}.zoom-control-label{display:inline-flex;align-items:center;gap:.2em;white-space:nowrap;min-width:2.35rem}.zoom-control-value{font-weight:600;color:var(--accent)}.zoom-control input[type=range]{width:6.5rem}.editor-metrics{margin-left:auto;color:var(--muted);font-size:.78rem}.timeline-wrap{flex:1;display:flex;flex-direction:column;min-height:280px}.timeline-scroll{flex:1;overflow:hidden;background:var(--paper);border-bottom:1px solid var(--line)}.timeline-inner{display:inline-block;vertical-align:top;width:max-content;min-width:100%}.pane{border-bottom:1px solid var(--line);background:var(--paper)}.pane-head{padding:var(--space-2) var(--space-4);font-family:var(--sans);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);background:color-mix(in srgb,var(--bg) 60%,var(--paper));border-bottom:1px solid var(--line)}#timeline-canvas{display:block;cursor:crosshair;min-height:200px;max-width:none}#timeline-canvas.dragging,#timeline-canvas.scrubbing{cursor:ew-resize}.timeline-stage{position:relative}.timeline-playhead{position:absolute;top:0;width:2px;margin-left:-1px;background:#c45c26;pointer-events:none;z-index:2;display:none}.minimap-bar{background:var(--paper);border-bottom:1px solid var(--line);flex-shrink:0}#minimap-canvas{display:block;width:100%;height:48px;cursor:grab}#minimap-canvas:active{cursor:grabbing}.editor-status{display:flex;gap:var(--space-3);align-items:center;padding:var(--space-2) var(--space-4);font-family:var(--sans);font-size:.82rem;background:color-mix(in srgb,var(--bg) 60%,var(--paper));border-top:1px solid var(--line)}.editor-status.err{color:var(--danger)}.help-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:grid;place-items:center;padding:var(--space-5);background:#08090c8c}.help-modal-card{position:relative;width:min(420px,100%);max-height:min(85vh,640px);overflow-y:auto;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:var(--space-6);font-family:var(--sans);box-shadow:0 20px 50px #0000002e}.help-modal-close{position:absolute;top:var(--space-2);right:var(--space-3);width:var(--touch-min);height:var(--touch-min);min-height:var(--touch-min);border:0;background:transparent;font-size:1.35rem;cursor:pointer;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;text-decoration:none}.help-modal-card h2{margin:0 var(--space-8) var(--space-2) 0;font-size:1.05rem;font-weight:700;color:var(--ink)}.help-modal-intro{margin:0 0 var(--space-3);font-size:.88rem;color:var(--muted);line-height:1.45}.help-modal-body{margin:var(--space-3) 0 0;font-size:.85rem;color:var(--muted);line-height:1.5;font-family:var(--serif)}.help-modal-card--wide{width:min(480px,100%)}.help-modal-section{margin-top:var(--space-4)}.help-modal-section-title{margin:0 0 var(--space-2);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.help-modal-list{margin:0;padding-left:1.15rem;font-size:.88rem;line-height:1.5;color:var(--ink)}.help-modal-list li+li{margin-top:var(--space-2)}.help-modal-footer{margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--line)}.bug-report-form textarea{min-height:7rem;resize:vertical}.bug-report-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.shortcut-list{margin:var(--space-3) 0 0}.shortcut-row{display:grid;grid-template-columns:4rem 1fr;gap:var(--space-2);margin-bottom:var(--space-2);padding:var(--space-2) 0;border-bottom:1px solid var(--line)}.shortcut-row:last-child{border-bottom:none}.shortcut-row dt{font-weight:700;margin:0}.shortcut-row dd{margin:0;color:var(--muted)}@media(max-width:640px){.shell{padding:var(--space-6) var(--space-3) var(--page-pad-bottom)}.card{padding:var(--space-6) var(--space-5)}.page-header-row{flex-direction:column;align-items:flex-start}.invite-form,.invite-table-form{flex-direction:column;align-items:stretch}.invite-role,.invite-email,.invite-table-field{flex:1;width:100%}.invite-table-submit,.invite-submit{width:100%}.editor-bar{grid-template-columns:1fr;grid-template-areas:"identity" "tools" "actions";padding:var(--space-2) var(--space-3);gap:var(--space-2)}.editor-bar-tools{justify-self:start;flex-wrap:wrap}.editor-bar-actions{justify-self:stretch;flex-wrap:wrap;overflow-x:visible}.changes-drawer{padding:var(--space-4)}}
