*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}:root{--background: #f8fafc;--surface: #ffffff;--surface-low: #f1f5f9;--surface-mid: #e2e8f0;--surface-high: #cbd5e1;--surface-highest: #94a3b8;--on-surface: #0f172a;--on-surface-variant: #475569;--outline: #94a3b8;--outline-variant: #cbd5e1;--primary: #2563eb;--primary-container: #dbeafe;--on-primary-container: #1e3a8a;--secondary: #0d9488;--secondary-container: #ccfbf1;--on-secondary-container: #115e59;--tertiary: #db2777;--tertiary-container: #fce7f3;--on-tertiary-container: #831843;--error: #dc2626;--error-container: #fee2e2;--on-error-container: #991b1b;--gap: clamp(10px, 1.25vw, 24px);--panel-pad: clamp(10px, 1vw, 16px);font-family:"Noto Serif",Noto Sans SC,serif}html,body,#app{width:100%;height:100%;overflow:hidden}body{background:var(--background);color:var(--on-surface)}button,textarea{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}textarea{border:0;outline:0}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.case-app{--login-bg: #f8fafc;--login-bg-strong: rgba(255, 255, 255, .92);--login-bg-card: #ffffff;--login-bg-soft: #e2e8f0;--login-text: #0f172a;--login-text-muted: #475569;--login-text-subtle: #64748b;--login-line: #cbd5e1;--login-line-strong: #94a3b8;--login-button-bg: #0f172a;--login-button-text: #fff;--login-button-hover: #1e293b;--login-flow: rgba(15, 23, 42, .12);display:flex;flex-direction:column;width:100vw;height:100dvh;overflow:hidden;background:var(--background);color:var(--on-surface);font-family:"Noto Serif",serif}.case-app.dark{--background: #0e0e0e;--surface: #121212;--surface-low: #171717;--surface-mid: #252525;--surface-high: #333333;--surface-highest: #525252;--on-surface: #f8fafc;--on-surface-variant: #cbd5e1;--outline: #525252;--outline-variant: #262626;--primary: #f8fafc;--primary-container: #262626;--on-primary-container: #f8fafc;--secondary: #94a3b8;--secondary-container: #243038;--on-secondary-container: #e2e8f0;--tertiary: #e2e8f0;--tertiary-container: #2c2630;--on-tertiary-container: #f8fafc;--error: #fca5a5;--error-container: #3f1d1d;--on-error-container: #fecaca;--login-bg: #0e0e0e;--login-bg-strong: #0a0a0a;--login-bg-card: #121212;--login-bg-soft: #353434;--login-text: #fff;--login-text-muted: #c4c7c8;--login-text-subtle: #737373;--login-line: #262626;--login-line-strong: #404040;--login-button-bg: #fff;--login-button-text: #2f3131;--login-button-hover: #e2e2e2;--login-flow: rgba(245, 247, 249, .9);--wb-accent-text: #0f172a;--wb-accent-hover: #e2e8f0}.case-app.dark .primary-action,.case-app.dark .analyze-button,.case-app.dark .portrait-info button{color:var(--wb-accent-text)}.case-app.dark .primary-action:hover,.case-app.dark .analyze-button:hover:not(:disabled),.case-app.dark .portrait-info button:hover{background:var(--wb-accent-hover)}.case-app.dark .loading-mask>div{background:var(--surface);color:var(--on-surface)}.case-app.dark .loading-mask h3{color:var(--on-surface)}.case-app.dark .ok-suggest{background:#2430388c;border-color:#94a3b840}.case-app.dark .conflict-suggest{background:#2c26308c;border-color:#e2e8f01f}.case-app.dark .product-title b{color:var(--on-primary-container)}.case-app :not(.material-symbols-outlined){font-family:inherit}.case-app .material-symbols-outlined{font-family:Material Symbols Outlined}.workbench-body{display:flex;min-height:0;flex:1;overflow:hidden}.sidebar{width:clamp(184px,14vw,256px);height:100%;min-height:0;display:flex;flex-direction:column;gap:12px;flex-shrink:0;overflow:hidden;padding:clamp(16px,2vw,32px) 16px;background:var(--surface);border-right:1px solid var(--outline-variant);box-shadow:0 8px 24px #0f172a0f;z-index:2;transition:width .28s cubic-bezier(.22,1,.36,1),padding .28s ease}.workflow-sidebar.is-collapsed{width:72px;padding-left:10px;padding-right:10px}.sidebar-collapse-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:100%;min-height:36px;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-low);color:var(--on-surface-variant);transition:background .2s ease,color .2s ease,transform .12s ease}.sidebar-collapse-btn:hover{color:var(--on-surface);background:var(--surface-mid)}.sidebar-collapse-btn:active{transform:scale(.96)}.sidebar-collapse-btn .material-symbols-outlined{font-size:22px}.workflow-sidebar.is-collapsed .side-nav a{justify-content:center;padding:0}.workflow-sidebar.is-collapsed .side-nav a span:last-child,.workflow-sidebar.is-collapsed .sketch-history-title,.workflow-sidebar.is-collapsed .sketch-history-count,.workflow-sidebar.is-collapsed .sketch-history-list,.workflow-sidebar.is-collapsed .sketch-history-empty{display:none}.workflow-sidebar.is-collapsed .sketch-history-head{justify-content:center;padding:0}.workflow-sidebar.is-collapsed .sketch-history{flex:0;padding-top:8px}.station-title{padding:0 8px;margin-bottom:clamp(8px,2vh,32px);cursor:pointer;transition:opacity .2s ease}.station-title:hover{opacity:.78}.station-title h2{font-size:clamp(18px,1.35vw,22px);font-weight:800}.station-title p,.product-title b,.card-meta span{font-family:inherit;letter-spacing:.05em}.station-title p{margin-top:2px;color:var(--on-surface-variant);font-size:10px}.side-nav{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;overflow:hidden}.side-nav a{display:flex;align-items:center;gap:12px;min-height:clamp(38px,5vh,48px);padding:0 12px;color:var(--on-surface-variant);text-decoration:none;border-radius:8px;transition:color .2s ease,background .2s ease,transform .12s ease,box-shadow .2s ease}.side-nav a:hover{color:var(--on-surface);background:var(--surface-mid)}.side-nav a:active,.sketch-history-item:active,.primary-action:active,.analyze-button:active,.redraw-button:active,.portrait-info button:active{transform:scale(.95)}.side-nav a.active{color:var(--on-primary-container);background:var(--primary-container);font-weight:800;box-shadow:0 4px 12px #2563eb1f}.side-nav span:last-child{font-size:clamp(13px,.9vw,14px)}.primary-action{width:100%;min-height:40px;margin-top:4px;border-radius:8px;background:var(--primary);color:#fff;font-weight:800;box-shadow:0 10px 18px #2563eb2e;transition:background .2s ease,box-shadow .2s ease,transform .12s ease}.primary-action:hover{background:#1d4ed8;box-shadow:0 14px 24px #2563eb3d}.sketch-history{display:flex;flex-direction:column;flex:1;gap:8px;min-height:0;margin-top:2px;padding-top:10px;border-top:1px solid var(--outline-variant)}.sketch-history-head{display:flex;flex-shrink:0;align-items:center;gap:10px;width:100%;min-height:36px;padding:0 12px;color:var(--on-surface-variant)}.sketch-history-title{flex:1;text-align:left;font-size:clamp(13px,.9vw,14px);font-weight:700}.sketch-history-count{min-width:20px;padding:2px 6px;border-radius:999px;background:var(--primary-container);color:var(--on-primary-container);font-size:11px;font-weight:800;line-height:1.2}.sketch-history-list{display:flex;flex:1;flex-direction:column;gap:6px;min-height:0;overflow-x:hidden;overflow-y:auto;padding:0 2px 4px 4px;scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:var(--surface-highest) transparent}.sketch-history-list::-webkit-scrollbar{width:6px}.sketch-history-list::-webkit-scrollbar-track{background:transparent}.sketch-history-list::-webkit-scrollbar-thumb{border-radius:999px;background:var(--surface-highest)}.sketch-history-list::-webkit-scrollbar-thumb:hover{background:var(--outline)}.sketch-history-empty{padding:10px 8px;color:var(--on-surface-variant);font-size:12px;line-height:1.5}.sketch-history-item{display:block;width:100%;padding:8px 10px;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-low);text-align:left;transition:border-color .2s ease,background .2s ease,transform .12s ease}.sketch-history-item:hover{border-color:#2563eb59;background:var(--surface-mid)}.sketch-history-item.active{border-color:var(--primary);background:var(--primary-container)}.sketch-history-item:active{transform:scale(.98)}.sketch-history-item-top{display:flex;gap:8px;align-items:flex-start}.sketch-history-thumb{width:36px;height:44px;flex-shrink:0;object-fit:cover;border-radius:4px;border:1px solid var(--outline-variant);background:var(--surface)}.sketch-history-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.sketch-history-meta b{color:var(--on-surface);font-size:12px;font-weight:800;line-height:1.3}.sketch-history-meta span{color:var(--on-surface-variant);font-size:10px;line-height:1.35}.sketch-history-item p{margin-top:6px;color:var(--on-surface-variant);font-size:11px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.main-shell{flex:1;min-width:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.topbar{height:clamp(52px,7vh,64px);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 clamp(18px,2.7vw,40px);background:var(--surface);border-bottom:1px solid var(--outline-variant);box-shadow:0 4px 14px #0f172a0a}.product-title{display:flex;align-items:center;gap:16px;min-width:0;cursor:pointer;transition:opacity .2s ease}.product-title:hover{opacity:.78}.product-title span{font-size:clamp(18px,1.45vw,22px);font-weight:800;white-space:nowrap}.product-title i{width:1px;height:16px;background:var(--outline-variant)}.product-title b{padding:2px 8px;border-radius:4px;background:var(--primary-container);color:var(--primary);font-size:11px;white-space:nowrap}.top-actions{display:flex;align-items:center;gap:clamp(10px,1.2vw,24px)}.top-actions>button{width:38px;height:38px;border-radius:50%;background:transparent;color:var(--on-surface-variant);transition:background .2s ease,color .2s ease}.top-actions>button:hover{color:var(--primary);background:var(--surface-mid)}.operator{display:flex;align-items:center;gap:12px;padding-left:clamp(8px,1.2vw,16px);border-left:1px solid var(--outline-variant);cursor:pointer;transition:opacity .2s ease}.operator:hover{opacity:.8}.avatar{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#2563eb,#0d9488);color:#fff;font-weight:800;box-shadow:0 4px 10px #0f172a29}.operator span{font-size:14px;font-weight:700}.workspace{flex:1;min-height:0;display:grid;grid-template-columns:minmax(230px,3fr) minmax(360px,5fr) minmax(310px,4fr);gap:var(--gap);padding:var(--gap);overflow:hidden}.witness-column,.analysis-column,.preview-column{min-height:0;display:flex;flex-direction:column;gap:10px;overflow:hidden}.section-head{height:clamp(34px,4.3vh,44px);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:10px}.section-head h3{display:flex;align-items:center;gap:8px;min-width:0;color:var(--on-surface);font-size:clamp(17px,1.3vw,20px);font-weight:800;white-space:nowrap}.section-head h3 .material-symbols-outlined{color:var(--primary)}.section-head h3 .secondary{color:var(--secondary)}.section-head>button,.redraw-button{flex-shrink:0;border-radius:8px;transition:background .2s ease,box-shadow .2s ease,transform .12s ease}.section-head>button{padding:6px 8px;background:transparent;color:var(--primary);font-family:inherit;font-size:12px}.section-head>button:hover{background:var(--primary-container)}.witness-list,.analysis-list{flex:1;min-height:0;display:grid;gap:clamp(8px,1vh,16px);overflow:hidden}.witness-card,.analysis-card,.portrait-card{background:var(--surface);border:1px solid var(--surface-mid);border-radius:12px;transition:box-shadow .2s ease,border-color .2s ease,transform .12s ease}.witness-card{min-height:0;display:flex;flex-direction:column;padding:var(--panel-pad);cursor:pointer}.witness-card:hover,.analysis-card:hover{border-color:#2563eb66;box-shadow:0 10px 26px #0f172a14}.witness-card:active,.analysis-card:active{transform:scale(.99)}.card-meta{height:24px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;pointer-events:none}.card-meta>span{color:var(--secondary);font-size:12px;font-weight:800}.card-meta button{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:transparent;color:var(--on-surface-variant);opacity:0;pointer-events:auto;transition:opacity .2s ease,color .2s ease,background .2s ease}.witness-card:hover .card-meta button{opacity:1}.card-meta button:hover{color:var(--error);background:var(--error-container)}.card-meta .material-symbols-outlined{font-size:18px}.witness-card textarea{flex:1;min-height:0;width:100%;padding:clamp(8px,.8vw,12px);resize:none;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-low);color:var(--on-surface);font-size:clamp(12px,.83vw,14px);line-height:1.5;cursor:text}.witness-card textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px #2563eb2e}.analyze-button{height:clamp(46px,6.1vh,64px);flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;background:var(--primary);color:#fff;font-weight:800;box-shadow:0 12px 22px #2563eb33;transition:background .2s ease,box-shadow .2s ease,transform .12s ease}.analyze-button:hover:not(:disabled){background:#1d4ed8;box-shadow:0 16px 28px #2563eb47}.count-tags{display:flex;gap:8px}.count-tags span{padding:4px 8px;border-radius:5px;font-family:inherit;font-size:10px;font-weight:800;white-space:nowrap}.count-tags .ok{color:var(--on-secondary-container);background:var(--secondary-container)}.count-tags .bad{color:var(--on-error-container);background:var(--error-container)}.analysis-list{grid-auto-rows:minmax(0,max-content);align-content:start}.analysis-card{padding:clamp(10px,1vw,16px);cursor:pointer}.analysis-title{display:flex;align-items:center;gap:8px;margin-bottom:clamp(8px,1vh,14px);pointer-events:none}.analysis-title span{width:8px;height:8px;border-radius:50%;background:var(--secondary)}.analysis-card.conflict .analysis-title span{background:var(--tertiary)}.analysis-title b{color:var(--on-surface);font-size:clamp(13px,1vw,16px)}.analysis-card.summary p{color:var(--on-primary-container);font-size:clamp(12px,.9vw,14px);line-height:1.55}.analysis-card.summary{background:var(--primary-container);border-color:#2563eb2e}.evidence-row{display:flex;align-items:center;gap:12px;margin-bottom:10px}.evidence-row em{width:92px;color:var(--on-surface-variant);font-family:inherit;font-size:11px;font-style:normal;font-weight:800}.evidence-row strong{padding:5px 10px;border-radius:7px;border:1px solid var(--outline-variant);background:var(--surface-low);color:var(--on-surface);font-size:clamp(12px,.9vw,14px)}.evidence-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;pointer-events:none}.evidence-grid div{min-width:0;padding:8px;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-low);text-align:center}.evidence-grid p{color:var(--on-surface-variant);font-family:inherit;font-size:10px;font-weight:800}.evidence-grid span{display:block;margin-top:4px;color:var(--on-surface);font-size:clamp(11px,.8vw,13px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.suggestion{margin-top:clamp(8px,1vh,14px);padding:clamp(8px,.85vw,12px);border-radius:8px;pointer-events:none}.suggestion p{font-size:clamp(12px,.85vw,14px);line-height:1.5}.ok-suggest{color:var(--on-secondary-container);background:#ccfbf180;border:1px solid rgba(13,148,136,.2)}.conflict-suggest{color:var(--on-tertiary-container);background:#fce7f37a;border:1px solid rgba(219,39,119,.18)}.redraw-button{display:flex;align-items:center;gap:6px;min-height:32px;padding:0 10px;border:1px solid var(--outline-variant);background:var(--surface);color:var(--on-surface)}.redraw-button .material-symbols-outlined{font-size:18px}.redraw-button:hover:not(:disabled){background:var(--surface-mid);box-shadow:0 5px 14px #0f172a14}.portrait-card{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;border-radius:16px;cursor:pointer}.portrait-card:hover{border-color:#2563eb4d;box-shadow:0 18px 38px #0f172a24}.portrait-stage{position:relative;flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:clamp(10px,1.2vw,16px);overflow:hidden;background:#0f172a}.portrait-stage img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 22px 42px #00000059;transition:transform .5s ease;z-index:1}.portrait-card:hover .portrait-stage img{transform:scale(1.02)}.portrait-badges{position:absolute;top:clamp(12px,1.5vw,24px);right:clamp(12px,1.5vw,24px);display:flex;flex-direction:column;align-items:flex-end;gap:8px;z-index:2;pointer-events:none}.portrait-badges span{padding:4px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#0000009e;color:#fff;font-family:inherit;font-size:10px}.portrait-badges span:last-child{border-color:#3b82f64d;background:#3b82f633;color:#93c5fd}.dot-grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.2;pointer-events:none;background-image:radial-gradient(circle,#64748b 1px,transparent 1px);background-size:40px 40px}.portrait-info{min-height:clamp(82px,11vh,116px);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:var(--panel-pad);border-top:1px solid var(--outline-variant);background:var(--surface)}.portrait-info h4{color:var(--on-surface);font-size:clamp(16px,1.15vw,18px);font-weight:800}.portrait-info p{margin-top:4px;color:var(--on-surface-variant);font-family:inherit;font-size:10px}.portrait-info button{flex-shrink:0;padding:9px 14px;border-radius:8px;background:var(--primary);color:#fff;font-weight:800;transition:background .2s ease,transform .12s ease;pointer-events:auto}.portrait-info button:hover{background:#1d4ed8}.report-panel{flex-shrink:0;display:grid;gap:6px;padding:0 var(--panel-pad) var(--panel-pad);background:var(--surface)}.report-row{display:flex;justify-content:space-between;gap:12px;padding:7px 10px;border-radius:8px;background:var(--surface-low);border:1px solid var(--outline-variant);font-size:clamp(11px,.85vw,13px)}.report-row span{color:var(--on-surface-variant)}.report-row b{color:var(--on-surface)}.loading-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;background:#0f172a6b;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.loading-mask>div{width:min(420px,90vw);padding:28px;border:1px solid var(--outline-variant);border-radius:16px;background:#fff;text-align:center;box-shadow:0 24px 60px #0f172a38}.loading-mask .material-symbols-outlined{color:var(--primary);font-size:48px;animation:pulse 1.2s ease-in-out infinite}.loading-mask h3{margin-top:10px;font-size:20px}.loading-mask p{margin-top:8px;color:var(--on-surface-variant)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.96)}}.login-page{--login-bg: #0e0e0e;--login-bg-strong: #0a0a0a;--login-bg-card: #121212;--login-bg-soft: #353434;--login-text: #fff;--login-text-muted: #c4c7c8;--login-text-subtle: #737373;--login-line: #262626;--login-line-strong: #404040;--login-button-bg: #fff;--login-button-text: #2f3131;--login-button-hover: #e2e2e2;--login-hero-overlay: rgba(14, 14, 14, .6);--login-hero-gradient: linear-gradient(to top, #0e0e0e, transparent, transparent);--login-flow: rgba(245, 247, 249, .9);min-height:100dvh;max-height:100dvh;overflow-y:auto;background:var(--login-bg);color:var(--login-text-muted);font-family:Manrope,Noto Sans SC,sans-serif;font-size:1rem;line-height:1.6;-webkit-font-smoothing:antialiased;transition:background .45s ease,color .45s ease}.login-page.light{--login-bg: #f5f3ee;--login-bg-strong: rgba(252, 250, 246, .92);--login-bg-card: rgba(255, 255, 255, .78);--login-bg-soft: #e8e3d8;--login-text: #1d2328;--login-text-muted: #4f5a62;--login-text-subtle: #7c858c;--login-line: rgba(28, 35, 40, .14);--login-line-strong: rgba(28, 35, 40, .28);--login-button-bg: #1d2328;--login-button-text: #fff;--login-button-hover: #313b44;--login-hero-overlay: rgba(255, 255, 255, .42);--login-hero-gradient: linear-gradient(to top, #f5f3ee, rgba(245, 243, 238, .46), transparent);--login-flow: rgba(15, 17, 18, .16);color:var(--login-text-muted)}.theme-flow{position:fixed;top:0;left:0;z-index:70;width:100%;height:100%;pointer-events:none;background:linear-gradient(to bottom,var(--login-flow) 0%,rgba(255,255,255,.18) 36%,transparent 72%);opacity:0;transform:translateY(-105%)}.login-page.theme-flowing .theme-flow,.case-app.theme-flowing .theme-flow{animation:themeFlowDown .78s cubic-bezier(.22,1,.36,1)}@keyframes themeFlowDown{0%{opacity:0;transform:translateY(-105%)}18%{opacity:.78}to{opacity:0;transform:translateY(105%)}}.login-nav{position:sticky;top:0;z-index:80;width:100%;background:var(--login-bg-strong);border-bottom:1px solid var(--login-line);color:var(--login-text);font-family:"Noto Serif",serif;font-size:14px;letter-spacing:-.01em;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:background .45s ease,border-color .45s ease,color .45s ease}.login-nav-inner{position:relative;max-width:1280px;margin:0 auto;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;gap:32px}.login-nav-left,.login-nav-right,.login-links{display:flex;align-items:center}.login-nav-left{gap:32px}.login-brand{color:var(--login-text);text-decoration:none;font-family:"Noto Serif",serif;font-size:20px;font-weight:700;white-space:nowrap}.login-links{position:relative;gap:24px}.login-links a{position:relative;color:var(--login-text-subtle);text-decoration:none;padding-bottom:6px;transition:color .28s ease,text-shadow .28s ease,transform .18s ease}.login-links a:hover{color:var(--login-text)}.login-links a.active{color:var(--login-text);text-shadow:0 0 18px color-mix(in srgb,var(--login-text) 40%,transparent);transform:scale(.95)}.nav-indicator{position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--login-text);opacity:.92;transition:transform .38s cubic-bezier(.22,1,.36,1),width .38s cubic-bezier(.22,1,.36,1),background .3s ease}.login-nav-right{gap:24px}.login-nav-right button,.hero-actions button:first-child{border-radius:4px;background:var(--login-button-bg);color:var(--login-button-text);font-family:Manrope,sans-serif;font-size:12px;font-weight:600;line-height:1.4;letter-spacing:.08em;transition:background .2s ease,color .2s ease,border-color .2s ease}.hero-actions button:first-child{background:#fff;color:#1d2328}.login-nav-right button{padding:8px 16px}.login-nav-right button:hover,.hero-actions button:first-child:hover{background:var(--login-button-hover)}.hero-actions button:first-child:hover{background:#e8e8e8}.login-nav-right .theme-toggle{padding:7px 12px;display:inline-flex;align-items:center;gap:6px;border:0;background:transparent;color:var(--login-text)}.theme-toggle .material-symbols-outlined{font-size:18px}.theme-toggle b{display:inline-block;min-width:2em;text-align:center;font:inherit}.login-nav-right .theme-toggle:hover{background:#8080801f}.workbench-nav{flex-shrink:0}.workbench-nav .login-nav-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center}.workbench-nav .login-nav-left{justify-self:start}.workbench-nav .login-nav-right{justify-self:end}.workbench-nav-title{position:static;justify-self:center;grid-column:2;color:var(--login-text);font-family:"Noto Serif",serif;font-size:20px;font-weight:400;letter-spacing:-.01em;white-space:nowrap;pointer-events:none}.case-app .login-nav-right button,.case-app .login-nav-right .theme-toggle{font-family:inherit;letter-spacing:.02em}.login-hero{position:relative;width:100%;height:80vh;min-height:560px;display:flex;align-items:center;justify-content:center;overflow:hidden}.login-hero-bg,.login-hero-bg img,.hero-multiply,.hero-gradient{position:absolute;top:0;right:0;bottom:0;left:0}.login-hero-bg{z-index:0}.login-hero-bg img{width:100%;height:100%;object-fit:cover}.hero-multiply{background:var(--login-hero-overlay);mix-blend-mode:multiply;transition:background .45s ease}.hero-gradient{background:var(--login-hero-gradient);transition:background .45s ease}.login-hero-content{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 32px;text-align:center}.login-hero-content h1{margin-bottom:24px;color:var(--login-text);font-family:"Noto Serif",serif;font-size:clamp(3.1rem,6vw,4.5rem);font-weight:400;line-height:1.1;letter-spacing:-.02em;text-shadow:0 10px 24px rgba(0,0,0,.28);transition:color .45s ease,text-shadow .45s ease}.login-hero-content p{max-width:672px;margin:0 auto 40px;color:var(--login-text-muted);font-size:1.125rem;line-height:1.6;letter-spacing:.01em;text-shadow:0 8px 18px rgba(0,0,0,.35)}.hero-actions{display:flex;align-items:center;justify-content:center;gap:16px}.hero-actions button{width:auto;padding:12px 32px;text-transform:uppercase}.hero-actions button:last-child{border:1px solid var(--login-line);border-radius:4px;background:transparent;color:var(--login-text);font-family:Manrope,sans-serif;font-size:12px;font-weight:600;line-height:1.4;letter-spacing:.08em;transition:border-color .2s ease}.hero-actions button:last-child:hover{border-color:var(--login-line-strong)}.login-curriculum{max-width:1200px;margin:0 auto;padding:120px 32px;scroll-margin-top:96px}.login-section-title{margin-bottom:64px}.login-section-title h2{margin-bottom:16px;color:var(--login-text);font-family:"Noto Serif",serif;font-size:2.5rem;font-weight:400;line-height:1.2;letter-spacing:-.01em}.login-section-title p{max-width:760px;margin:0 0 32px;color:var(--login-text-muted);font-family:"Noto Serif",Noto Sans SC,serif;font-size:1.18rem;font-weight:400;line-height:1.8}.login-section-title div{width:96px;height:2px;background:var(--login-bg-soft)}.feature-list{display:flex;flex-direction:column;gap:0}.feature-row{position:relative;width:100%;min-height:132px;padding:28px 0;display:grid;grid-template-columns:88px minmax(260px,.9fr) minmax(320px,1.2fr);align-items:center;gap:32px;border-top:1px solid var(--login-line);background:transparent;transition:transform .28s ease,border-color .28s ease}.feature-row:last-of-type{border-bottom:1px solid var(--login-line)}.feature-row:hover{border-color:var(--login-line-strong);transform:translate(10px)}.feature-row span{color:var(--login-text-subtle);font-family:"Noto Serif",serif;font-size:1.05rem;font-weight:400;line-height:1}.feature-row h3{margin:0;color:var(--login-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:clamp(1.65rem,2.4vw,2.35rem);font-weight:400;line-height:1.22;letter-spacing:-.01em}.feature-row p{margin:0;color:var(--login-text-muted);font-family:"Noto Serif",Noto Sans SC,serif;font-size:1.06rem;font-weight:400;line-height:1.75}.feature-note{max-width:840px;margin:72px 0 0 auto;padding-left:32px;border-left:2px solid var(--login-text)}.resource-quote{margin-top:72px}.feature-note p{margin:0 0 16px;color:var(--login-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:clamp(1.8rem,3vw,2.65rem);font-style:italic;font-weight:400;line-height:1.25}.feature-note span{color:var(--login-text-subtle);font-family:"Noto Serif",Noto Sans SC,serif;font-size:1rem;letter-spacing:.02em}.resource-library{max-width:1200px;margin:0 auto;padding:0 32px 128px;scroll-margin-top:96px}.resource-title{margin-bottom:56px}.resource-demo{display:grid;grid-template-columns:minmax(320px,.92fr) minmax(420px,1.08fr);gap:48px;align-items:stretch}.rag-proof-panel,.vision-demo-panel{min-height:560px;padding:32px;border-radius:6px;background:color-mix(in srgb,var(--login-bg-card) 72%,transparent);box-shadow:0 28px 80px #0000001f}.login-page.light .rag-proof-panel,.login-page.light .vision-demo-panel{box-shadow:0 28px 70px #1f293714}.demo-panel-head{margin-bottom:26px;display:flex;align-items:center;justify-content:space-between;gap:18px}.demo-panel-head span{color:var(--login-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:1.55rem;font-weight:400;line-height:1.25}.demo-panel-head button{min-width:96px;padding:9px 16px;border:1px solid var(--login-line);border-radius:4px;background:var(--login-button-bg);color:var(--login-button-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:.95rem;transition:background .2s ease,border-color .2s ease,transform .12s ease}.demo-panel-head button:hover:not(:disabled){border-color:var(--login-line-strong);background:var(--login-button-hover);transform:translateY(-1px)}.demo-panel-head button:disabled{cursor:wait;opacity:.68}.rag-proof-intro{margin:0 0 28px;color:var(--login-text-muted);font-family:"Noto Serif",Noto Sans SC,serif;font-size:1.08rem;line-height:1.75}.rag-proof-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--login-line)}.rag-proof-list article{padding:24px 0;border-bottom:1px solid var(--login-line)}.rag-proof-list b{display:block;margin-bottom:10px;color:var(--login-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:clamp(1.35rem,2vw,1.85rem);font-weight:400;line-height:1.25}.rag-proof-list p,.vision-info-list p,.vision-intro{margin:0;color:var(--login-text-muted);font-family:"Noto Serif",Noto Sans SC,serif;font-size:1rem;line-height:1.7}.vision-intro{margin-bottom:28px;font-size:1.08rem}.vision-info-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--login-line)}.vision-info-list article{padding:24px 0;border-bottom:1px solid var(--login-line)}.vision-info-list b{display:block;margin-bottom:10px;color:var(--login-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:clamp(1.25rem,1.8vw,1.65rem);font-weight:400;line-height:1.25}.workflow-block{margin-top:64px}.workflow-block h3{margin:0 0 18px;color:var(--login-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:clamp(1.55rem,2.2vw,2.1rem);font-weight:400;line-height:1.25}.workflow-strip{padding:24px 0;display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid var(--login-line);border-bottom:1px solid var(--login-line)}.workflow-strip span{color:var(--login-text);font-family:"Noto Serif",Noto Sans SC,serif;font-size:1.08rem;white-space:nowrap}.workflow-strip i{flex:1;height:1px;min-width:24px;background:var(--login-line)}.login-footer{width:100%;border-top:1px solid var(--login-line);background:var(--login-bg-strong);color:var(--login-text);font-family:"Noto Serif",serif;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.login-footer>div{max-width:1280px;margin:0 auto;padding:48px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}.login-footer span{display:block;margin-bottom:8px;color:var(--login-text);font-size:18px;font-weight:700;opacity:.8}.login-footer small{color:var(--login-text-subtle);text-transform:none}.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:24px 32px}.footer-links a{color:var(--login-text-subtle);text-decoration:none;opacity:.8;transition:color .2s ease,opacity .2s ease}.footer-links a:hover{color:var(--login-text);opacity:1}@media(max-width:1180px){.workspace{grid-template-columns:minmax(210px,3fr) minmax(330px,5fr) minmax(270px,4fr)}}@media(max-height:760px){:root{--gap: 10px;--panel-pad: 10px}.side-nav{gap:4px}.sketch-history{padding-top:8px}.witness-card textarea{font-size:12px;line-height:1.42}.analysis-card:nth-child(n+5){display:none}.suggestion p,.analysis-card.summary p{line-height:1.38}}@media(max-width:920px){.operator span,.product-title i,.product-title b,.top-actions>button{display:none}.workspace{grid-template-columns:minmax(200px,.9fr) minmax(300px,1.2fr) minmax(250px,1fr);gap:8px;padding:8px}.section-head h3{font-size:15px}.count-tags{display:none}}@media(max-width:900px){.login-links{display:none}.login-nav-inner{padding:16px 20px}.login-hero-content{padding:0 20px}.hero-actions{flex-direction:column}.hero-actions button{width:100%;max-width:320px}.login-curriculum{padding:80px 20px}.feature-row{min-height:auto;padding:26px 0;grid-template-columns:44px 1fr;gap:12px 20px}.feature-row p{grid-column:2}.feature-row:hover{transform:none}.feature-note{margin-top:56px;padding-left:22px}.resource-library{padding:0 20px 96px}.resource-demo{grid-template-columns:1fr;gap:28px}.rag-proof-panel,.vision-demo-panel{min-height:auto;padding:24px}.demo-panel-head,.workflow-strip{align-items:flex-start;flex-direction:column}.workflow-strip i{width:1px;height:20px;min-width:0;margin-left:8px}.login-footer>div{flex-direction:column;text-align:center}}.workflow-workspace{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;padding:var(--gap);overflow:hidden}.workflow-step-frame{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.workflow-step-frame>.step-panel,.workflow-step-frame>section.step-panel{flex:1;min-height:0;width:100%}.step-panel{display:flex;flex-direction:column;width:100%;min-height:0;padding:clamp(14px,2vw,28px);padding-bottom:clamp(12px,1.5vw,20px);overflow:hidden;border-radius:8px;background:var(--surface);box-shadow:0 20px 60px #0f172a14}.step-panel-main{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;padding-right:4px;scrollbar-width:thin;scrollbar-color:var(--surface-highest) transparent}.step-panel-main::-webkit-scrollbar{width:6px}.step-panel-main::-webkit-scrollbar-thumb{border-radius:999px;background:var(--surface-highest)}.case-app.dark .step-panel{box-shadow:0 20px 70px #00000052}.work-step-enter-active,.work-step-leave-active{transition:opacity .36s ease,transform .36s cubic-bezier(.22,1,.36,1),filter .36s ease}.work-step-enter-from{opacity:0;transform:translateY(18px) scale(.985);filter:blur(8px)}.work-step-leave-to{opacity:0;transform:translateY(-14px) scale(.99);filter:blur(6px)}.step-hero{flex:1;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.step-hero>span{margin-bottom:28px;color:var(--on-surface-variant);font-size:64px}.step-hero p,.step-toolbar span{color:var(--on-surface-variant);font-size:1rem}.step-hero h1{margin:10px 0 18px;color:var(--on-surface);font-size:clamp(3rem,6vw,5.4rem);font-weight:400;line-height:1.08}.step-hero small{max-width:680px;color:var(--on-surface-variant);font-size:1.15rem;line-height:1.8}.step-primary,.step-footer button,.inline-run,.step-toolbar button,.portrait-regen-bar .inline-run{border-radius:4px;background:var(--login-button-bg);color:var(--login-button-text);font-size:1rem;transition:background .2s ease,transform .12s ease,opacity .2s ease}.step-primary{margin-top:42px;padding:14px 46px}.step-primary:hover,.step-footer button:hover:not(:disabled),.inline-run:hover:not(:disabled),.step-toolbar button:hover:not(:disabled),.portrait-regen-bar .inline-run:hover:not(:disabled){background:var(--login-button-hover);transform:translateY(-1px)}.step-footer{flex-shrink:0;display:flex;justify-content:flex-end;align-items:center;gap:12px;margin-top:auto;padding-top:14px;border-top:1px solid var(--outline-variant);background:var(--surface);box-shadow:0 -10px 28px #0f172a0f;z-index:2}.case-app.dark .step-footer{box-shadow:0 -10px 28px #00000047}.step-footer button{min-width:160px;padding:12px 22px}.step-toolbar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.step-toolbar button,.inline-run,.portrait-regen-bar .inline-run{padding:10px 18px}.step-toolbar button:disabled{opacity:.45;cursor:not-allowed}.witness-step{display:flex;flex-direction:column;gap:0}.step-witness-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;align-content:start}.step-witness-card{min-height:0;display:flex;flex-direction:column;padding:18px;border:1px solid var(--outline-variant);border-radius:6px;background:var(--surface-low)}.step-witness-card>div{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.step-witness-card b,.feature-columns h3,.step-summary h3,.report-step h3,.overview-card h3{color:var(--on-surface);font-size:1.35rem;font-weight:400}.step-witness-card button{background:transparent;color:var(--error)}.step-witness-card textarea{flex:1;min-height:clamp(96px,18vh,160px);resize:none;padding:12px 14px;border:1px solid var(--outline-variant);border-radius:6px;background:#fff;color:#0f172a;font-size:1.04rem;line-height:1.7}.step-witness-card textarea::placeholder{color:#64748b}.step-witness-card textarea:focus{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 22%,transparent)}.align-step{display:flex;flex-direction:column;gap:18px}.inline-run{align-self:flex-start}.step-summary,.report-step article,.overview-card{padding:20px;border:1px solid var(--outline-variant);border-radius:6px;background:var(--surface-low)}.step-summary p,.feature-columns p,.conflict-item p,.report-step p,.report-step li,.overview-card p{color:var(--on-surface-variant);font-size:1.02rem;line-height:1.7}.feature-columns{min-height:0;flex:1;display:grid;grid-template-columns:1fr 1fr;gap:18px}.feature-columns>div{min-height:0;overflow:auto;padding:20px;border:1px solid var(--outline-variant);border-radius:6px;background:var(--surface-low)}.feature-columns ul,.report-step ul{margin-top:14px;padding-left:22px;color:var(--on-surface-variant);line-height:1.8}.conflict-item{margin-top:16px;padding-top:16px;border-top:1px solid var(--outline-variant)}.conflict-item b{display:block;margin-bottom:8px;color:var(--on-surface);font-size:1.08rem;font-weight:400}.portrait-gen{display:flex;flex-direction:column;gap:20px}.portrait-empty{flex:1;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:18px;max-width:560px}.portrait-empty p{color:var(--on-surface-variant);font-size:1.02rem;line-height:1.7}.portrait-flow{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;padding:14px 16px;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-low)}.portrait-flow-step{display:flex;flex-direction:column;gap:2px;min-width:120px}.portrait-flow-step .material-symbols-outlined{font-size:22px;color:var(--on-surface-variant)}.portrait-flow-step b{color:var(--on-surface);font-size:.95rem;font-weight:700}.portrait-flow-step small{color:var(--on-surface-variant);font-size:.78rem}.portrait-flow-step.is-highlight .material-symbols-outlined{color:var(--primary)}.portrait-flow-arrow{color:var(--on-surface-variant);font-size:20px}.portrait-witness-section h3,.portrait-composite-section h3,.portrait-conflicts-section h3,.portrait-aligned-panel h3{margin-bottom:12px;color:var(--on-surface);font-size:1.2rem;font-weight:700}.portrait-witness-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.portrait-witness-card{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-low)}.portrait-witness-card header{color:var(--on-surface);font-size:.92rem;font-weight:700}.portrait-frame{aspect-ratio:4 / 5;overflow:hidden;border-radius:6px;background:#111827}.portrait-frame img{width:100%;height:100%;object-fit:contain}.witness-snippet{color:var(--on-surface-variant);font-size:.8rem;line-height:1.45}.portrait-composite-layout{display:grid;grid-template-columns:minmax(260px,1.1fr) minmax(220px,.9fr);gap:18px;align-items:stretch}.portrait-composite-visual{position:relative;min-height:280px;display:grid;place-items:center;overflow:hidden;border-radius:8px;background:#111827}.portrait-composite-visual img{width:100%;height:100%;max-height:420px;object-fit:contain}.composite-badge{position:absolute;top:12px;right:12px;padding:6px 12px;border-radius:999px;background:#0000009e;color:#fff;font-size:.78rem;font-weight:700}.portrait-aligned-panel{padding:16px;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-low)}.panel-muted{color:var(--on-surface-variant);font-size:.95rem;line-height:1.6}.aligned-feature-list{display:flex;flex-direction:column;gap:8px;list-style:none}.aligned-feature-list li{padding:8px 10px;border-radius:6px;border:1px solid rgba(13,148,136,.22);background:#ccfbf159;color:var(--on-secondary-container);font-size:.92rem;line-height:1.45}.case-app.dark .aligned-feature-list li{background:#2430388c;border-color:#94a3b840}.portrait-conflict-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.portrait-conflict-card{padding:14px;border:1px solid rgba(219,39,119,.22);border-radius:8px;background:#fce7f347}.case-app.dark .portrait-conflict-card{background:#2c26308c;border-color:#e2e8f024}.portrait-conflict-card>b{display:block;margin-bottom:10px;color:var(--on-surface);font-size:1rem;font-weight:700}.conflict-witness-rows{display:flex;flex-direction:column;gap:8px}.conflict-witness-row{padding:8px 10px;border-radius:6px;background:var(--surface);border:1px solid var(--outline-variant)}.conflict-witness-row span{display:block;margin-bottom:4px;color:var(--on-surface-variant);font-size:.75rem;font-weight:700}.conflict-witness-row p{color:var(--on-surface);font-size:.88rem;line-height:1.45}.conflict-note{margin-top:10px;color:var(--on-surface-variant);font-size:.86rem;line-height:1.5}.portrait-regen-bar{flex-shrink:0;padding-top:4px}.report-step{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.step-panel--overview{padding:0}.overview-board{display:flex;flex-direction:column;min-height:0;flex:1;gap:0}.overview-canvas{flex:1;min-height:0;display:grid;grid-template-columns:minmax(220px,3fr) minmax(320px,5fr) minmax(260px,4fr);gap:0;padding:24px;overflow:hidden}.overview-col{min-height:0;display:flex;flex-direction:column;gap:10px}.overview-col--witness,.overview-col--align{padding-right:24px;border-right:1px solid var(--outline-variant)}.overview-col--align,.overview-col--portrait{padding-left:24px}.case-app.dark .overview-col--witness,.case-app.dark .overview-col--align{border-right-color:color-mix(in srgb,var(--outline-variant) 85%,#303645)}.overview-col-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:10px}.overview-col-head h3{display:flex;align-items:center;gap:8px;color:var(--on-surface);font-size:1.15rem;font-weight:700}.overview-col-head h3 .material-symbols-outlined{color:var(--primary);font-size:22px}.overview-col-head .secondary-icon{color:var(--secondary)}.overview-kicker{color:var(--on-surface-variant);font-size:.72rem;font-weight:600;letter-spacing:.06em}.overview-tags{display:flex;gap:8px}.tag-ok,.tag-bad{padding:4px 8px;border-radius:4px;font-size:.65rem;font-weight:700;letter-spacing:.04em}.tag-ok{color:var(--secondary);background:color-mix(in srgb,var(--secondary) 18%,transparent);border:1px solid color-mix(in srgb,var(--secondary) 35%,transparent)}.tag-bad{color:var(--tertiary);background:color-mix(in srgb,var(--tertiary) 14%,transparent);border:1px solid color-mix(in srgb,var(--tertiary) 30%,transparent)}.overview-scroll{flex:1;min-height:0;display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding-right:4px;scrollbar-width:thin}.tech-card{border:1px solid color-mix(in srgb,var(--outline-variant) 90%,#303645);border-radius:12px;background:var(--surface-low);transition:border-color .2s ease,box-shadow .2s ease}.tech-card:hover{border-color:color-mix(in srgb,var(--primary) 35%,var(--outline-variant));box-shadow:0 0 18px color-mix(in srgb,var(--primary) 12%,transparent)}.overview-witness-card{padding:14px}.overview-witness-meta{margin-bottom:10px}.witness-code{color:var(--secondary);font-size:.68rem;font-weight:700;letter-spacing:.08em}.overview-witness-text{color:var(--on-surface);font-size:.88rem;line-height:1.65;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.overview-placeholder{color:var(--on-surface-variant);font-size:.9rem;line-height:1.6}.feature-group-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}.feature-group-head b{color:var(--on-surface);font-size:1rem;font-weight:700}.dot-ok,.dot-bad{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-ok{background:var(--secondary)}.dot-bad{background:var(--tertiary)}.overview-summary-card,.overview-feature-card{padding:16px}.overview-summary-card p,.feature-value{color:var(--on-surface-variant);font-size:.9rem;line-height:1.65}.feature-value{color:var(--on-surface)}.overview-conflict-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px}.overview-conflict-cell{padding:8px;text-align:center;border-radius:6px;background:color-mix(in srgb,var(--surface-mid) 80%,transparent);border:1px solid var(--outline-variant)}.overview-conflict-cell p{color:var(--on-surface-variant);font-size:.62rem;font-weight:700;letter-spacing:.06em}.overview-conflict-cell span{display:block;margin-top:4px;color:var(--on-surface);font-size:.78rem;line-height:1.35}.ai-suggest{padding:12px;border-radius:8px}.ai-suggest p{font-size:.86rem;line-height:1.6}.ai-suggest--ok{background:color-mix(in srgb,var(--secondary) 12%,transparent);border:1px solid color-mix(in srgb,var(--secondary) 28%,transparent);color:var(--on-secondary-container)}.ai-suggest--warn{background:color-mix(in srgb,var(--tertiary) 12%,transparent);border:1px solid color-mix(in srgb,var(--tertiary) 25%,transparent);color:var(--on-tertiary-container)}.overview-redraw{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--outline-variant);border-radius:8px;background:var(--surface-mid);color:var(--on-surface);font-size:.85rem;transition:background .2s ease}.overview-redraw:hover:not(:disabled){background:var(--surface-high)}.overview-redraw .material-symbols-outlined{font-size:18px}.overview-portrait-card{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;padding:0}.overview-portrait-stage{position:relative;flex:1;min-height:240px;display:grid;place-items:center;padding:16px;background:#0d0f14}.overview-portrait-stage.is-paper-empty,.portrait-composite-visual.is-paper-empty{background:#f3efe6;padding:0}.overview-portrait-stage.is-paper-empty img,.portrait-composite-visual.is-paper-empty img{width:100%;height:100%;object-fit:cover;border-radius:0;box-shadow:none}.overview-portrait-stage img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 18px 40px #00000073;z-index:1}.overview-portrait-badges{position:absolute;top:16px;right:16px;z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.overview-portrait-badges span{padding:4px 10px;border-radius:999px;background:#0009;color:#fff;font-size:.62rem;font-weight:700;letter-spacing:.06em;border:1px solid rgba(255,255,255,.18)}.overview-portrait-badges span:last-child{color:var(--primary);background:color-mix(in srgb,var(--primary) 22%,rgba(0,0,0,.55));border-color:color-mix(in srgb,var(--primary) 35%,transparent)}.overview-dot-grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.2;pointer-events:none;background-image:radial-gradient(circle,#64748b 1px,transparent 1px);background-size:40px 40px}.overview-mini-sketches{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--outline-variant);overflow-x:auto}.overview-mini-sketch{flex-shrink:0;width:56px;text-align:center}.overview-mini-sketch img{width:56px;height:68px;object-fit:cover;border-radius:4px;border:1px solid var(--outline-variant);background:#111827}.overview-mini-sketch span{display:block;margin-top:4px;color:var(--on-surface-variant);font-size:.65rem;font-weight:700}.overview-portrait-foot{padding:14px 16px;border-top:1px solid var(--outline-variant);background:color-mix(in srgb,var(--surface-low) 90%,transparent)}.overview-portrait-foot h4{color:var(--on-surface);font-size:1rem;font-weight:700}.param-line{margin-top:4px;color:var(--on-surface-variant);font-size:.68rem;letter-spacing:.04em}.overview-hash-tags{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px 14px}.overview-hash-tags span{padding:4px 8px;border-radius:4px;background:var(--surface-mid);color:var(--on-surface-variant);font-size:.72rem}.overview-status-footer{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:72px;padding:0 24px;border-top:1px solid var(--outline-variant);background:var(--surface-mid)}.overview-status-left{display:flex;align-items:center;gap:20px;min-width:0}.overview-status-item .label{display:block;color:var(--on-surface-variant);font-size:.62rem;font-weight:600;letter-spacing:.08em}.overview-status-item b{color:var(--on-surface);font-size:.92rem}.overview-status-divider{width:1px;height:32px;background:var(--outline-variant)}.overview-status-steps{display:flex;flex-wrap:wrap;gap:14px 20px}.overview-status-steps>span{display:inline-flex;align-items:center;gap:6px;color:var(--on-surface-variant);font-size:.86rem}.overview-status-steps>span.done{color:var(--on-surface)}.overview-status-steps .material-symbols-outlined{font-size:18px;color:var(--on-surface-variant)}.overview-status-steps>span.done .material-symbols-outlined{color:var(--secondary)}.overview-status-actions{display:flex;flex-shrink:0;gap:12px}.overview-btn-ghost,.overview-btn-primary{padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:700;transition:background .2s ease,transform .12s ease}.overview-btn-ghost{border:1px solid var(--outline-variant);background:transparent;color:var(--on-surface)}.overview-btn-ghost:hover{background:var(--surface-low)}.overview-btn-primary{display:inline-flex;align-items:center;gap:8px;border:0;background:var(--primary-container);color:var(--on-primary-container)}.overview-btn-primary:hover{filter:brightness(1.08)}.workflow-sidebar .side-nav a{position:relative}.workflow-sidebar .side-nav a:before{content:"";position:absolute;left:0;width:2px;height:0;border-radius:999px;background:var(--on-surface);transition:height .25s ease}.workflow-sidebar .side-nav a.active:before{height:56%}@media(max-width:1200px){.overview-canvas{grid-template-columns:1fr;gap:0;overflow-y:auto}.overview-col{max-height:none}.overview-col--witness,.overview-col--align{padding-right:0;padding-bottom:20px;margin-bottom:20px;border-right:none;border-bottom:1px solid var(--outline-variant)}.overview-col--align,.overview-col--portrait{padding-left:0}.overview-col--portrait{padding-bottom:0;margin-bottom:0;border-bottom:none}.overview-portrait-stage{min-height:200px}.overview-status-footer{flex-direction:column;align-items:stretch;padding:14px 16px;min-height:auto}.overview-status-actions{justify-content:stretch}.overview-status-actions button{flex:1}}@media(max-width:980px){.feature-columns,.portrait-composite-layout,.report-step{grid-template-columns:1fr}.portrait-flow{flex-direction:column;align-items:flex-start}.portrait-flow-arrow{transform:rotate(90deg)}}@media(max-height:820px),(max-width:900px){.workflow-workspace{padding:8px}.step-panel:not(.step-panel--overview){padding:12px 12px 10px}.overview-canvas{padding:12px;gap:14px}.step-hero>span{margin-bottom:16px;font-size:48px}.step-hero h1{font-size:clamp(2rem,8vw,3rem)}.step-primary{margin-top:24px;padding:12px 32px}.step-footer{padding-top:10px;padding-bottom:max(6px,env(safe-area-inset-bottom,0px))}.step-footer button{width:100%;min-width:0}}
