.spk-app{height:100dvh;background:var(--bg);color:var(--text);overflow:hidden;display:grid;grid-template-rows:auto minmax(0,1fr) auto}.spk-app:before{content:none}.app-topbar{min-height:56px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-soft)}.app-brand{display:inline-flex;align-items:center;gap:.65rem;color:var(--text);text-decoration:none;font-weight:800}.app-brand-mark{width:2rem;height:2rem;border-radius:var(--radius);display:grid;place-items:center;background:var(--brand);color:#06110e;font-size:.74rem}.app-status{color:var(--muted)}.app-top-links{display:flex;gap:.75rem;flex-wrap:wrap}.app-top-links a{min-height:2.35rem;display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--radius);padding:.45rem .8rem;color:var(--text);background:var(--panel);text-decoration:none;font-weight:760}.app-top-links a:hover{border-color:var(--brand)}.app-footer{min-height:42px;border-top:1px solid var(--line);background:var(--bg-soft);color:var(--muted);display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.45rem 1rem;font-size:.84rem}.app-footer p{margin:0}.app-footer nav{display:flex;gap:.8rem;flex-wrap:wrap}.app-footer a{color:var(--text)}.restore-panel{display:flex;align-items:center;gap:1rem;border-bottom:1px solid var(--line);padding:1rem;background:var(--panel)}.restore-panel h2{margin:0 0 .2rem;font-size:1rem}.restore-panel p{margin:0;color:var(--muted)}.app-shell{position:relative;display:grid;grid-template-columns:320px minmax(0,1fr) 360px;grid-template-rows:minmax(0,1fr);height:auto;min-height:0;overflow:hidden}.panel-toggle-bar{position:absolute;inset:.55rem .75rem auto;z-index:12;display:flex;justify-content:space-between;gap:.5rem;pointer-events:none}.panel-toggle-bar button{pointer-events:auto;min-height:2.25rem;padding:.42rem .7rem;background:#12231feb;box-shadow:var(--shadow)}.app-shell.left-collapsed{grid-template-columns:0 minmax(0,1fr) 360px}.app-shell.right-collapsed{grid-template-columns:320px minmax(0,1fr) 0}.app-shell.left-collapsed.right-collapsed{grid-template-columns:0 minmax(0,1fr) 0}.left-panel,.right-panel{min-height:0;border-right:1px solid var(--line);padding:3.55rem 1rem 1rem;background:var(--bg-soft);overflow:auto}.left-collapsed .left-panel,.right-collapsed .right-panel{visibility:hidden;padding:0;border:0;overflow:hidden}.right-panel{border-right:0;border-left:1px solid var(--line)}.main-panel{padding:3.55rem 1rem 1rem;min-width:0;min-height:0;overflow:hidden;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;align-content:stretch}.upload-box{border:1px dashed var(--brand);border-radius:var(--radius);padding:1rem;background:var(--panel)}.upload-box h1{font-size:1.35rem;line-height:1.2;margin:0 0 .75rem}.upload-box p,.hint{color:var(--muted);line-height:1.55}.security-note{border:1px solid rgba(255,209,102,.36);border-radius:var(--radius);background:#ffd16614;padding:.7rem}.upload-promises{display:grid;gap:.45rem;padding:0;margin:0 0 .75rem;list-style:none}.upload-promises li{border:1px solid var(--line);border-radius:var(--radius);padding:.6rem .7rem;background:var(--bg-soft);font-weight:700}.upload-box input{position:absolute;inline-size:1px;block-size:1px;overflow:hidden;clip:rect(0 0 0 0)}button{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border:1px solid var(--line);background:var(--brand);color:#06110e;border-radius:var(--radius);min-height:2.55rem;padding:.6rem .85rem;font-weight:760;cursor:pointer;user-select:none;touch-action:manipulation}button:disabled{cursor:not-allowed;opacity:.58}button:focus-visible,a:focus-visible,summary:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.codemirror-shell .cm-editor.cm-focused{outline:3px solid var(--brand);outline-offset:3px}button.secondary,.mode-tabs button,.segmented button,.page-list button,.comment-list button,.suggestion-list button{background:var(--panel);color:var(--text)}button.active,.page-list button.active{border-color:var(--brand);background:var(--panel-strong)}.panel-section{margin-top:1rem}.panel-section h2,.checks h2,.export-panel h2,.coming-later h2{font-size:1.05rem;margin:0 0 .75rem}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.section-title-row span{border:1px solid var(--line);border-radius:999px;padding:.2rem .55rem;color:var(--muted)}.summary-panel{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:1rem}.summary-panel dl{display:grid;gap:.5rem;margin:0}.summary-panel dl div{display:grid;grid-template-columns:1fr auto;gap:.75rem;border-bottom:1px solid var(--line);padding-bottom:.45rem}.summary-panel dt{color:var(--muted)}.summary-panel dd{margin:0;text-align:right;overflow-wrap:anywhere}.summary-panel p{color:var(--muted);line-height:1.55;margin-bottom:0}.import-result{border-left:4px solid var(--line)}.import-result.warning-low{border-left-color:var(--brand)}.import-result.warning-medium{border-left-color:var(--warn)}.import-result.warning-high,.import-result.warning-critical{border-left-color:var(--danger)}.import-result dl{display:grid;gap:.35rem;margin:.75rem 0}.import-result dl div{display:flex;justify-content:space-between;gap:1rem}.import-result dt{color:var(--muted)}.import-result dd{margin:0;font-weight:760;text-align:right}.import-result h3{margin-bottom:.35rem;font-size:.9rem}.import-result ul{margin-top:0;padding-left:1.2rem}.capability-badge{overflow-wrap:anywhere;font-size:.68rem;font-weight:800;letter-spacing:.03em}.asset-inventory summary{justify-content:space-between}.asset-inventory summary span{border:1px solid var(--line);border-radius:999px;padding:.15rem .5rem;color:var(--muted);font-size:.82rem}.asset-inventory ul{list-style:none;display:grid;gap:.45rem;margin:.75rem 0 0;padding:0}.asset-inventory li{display:grid;gap:.18rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:.55rem .65rem}.asset-inventory li.changed{border-color:var(--brand)}.asset-inventory li.blocked{border-color:var(--danger)}.asset-inventory li span,.asset-inventory li small{overflow-wrap:anywhere}.asset-inventory li small{color:var(--muted)}.page-list{display:grid;gap:.75rem}.page-group{display:grid;gap:.45rem}.page-group h3{color:var(--muted);font-size:.82rem;margin:0;text-transform:uppercase}.page-list button{display:grid;text-align:left;gap:.2rem;min-height:3.1rem}.page-list small{color:var(--muted);overflow-wrap:anywhere}.recovery{border:1px solid var(--warn);border-radius:var(--radius);padding:1rem;background:#ffd16614}.recovery p{color:var(--muted);line-height:1.55}.recovery-block{margin-top:.9rem}.recovery-block h3{font-size:.94rem;margin:0 0 .35rem}.recovery-block ul{margin:0;padding-left:1.2rem;color:var(--muted)}.recommended{border-top:1px solid rgba(255,209,102,.32);padding-top:.75rem}.mode-tabs,.toolbar,.segmented{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.mode-tabs{padding-bottom:.75rem;border-bottom:1px solid var(--line)}.toolbar{justify-content:space-between;padding:.55rem 0}.toolbar p{margin:0;color:var(--brand-strong);font-size:.9rem}.safe-mode-toggle{display:inline-flex;align-items:center;gap:.45rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:.45rem .65rem;font-weight:760}.safe-mode-toggle input{width:auto}.preview-frame{position:relative;margin:0 auto;border:1px solid var(--line);background:#fff;border-radius:var(--radius);overflow:hidden;height:100%;min-height:0;box-shadow:var(--shadow)}.preview-frame.desktop{width:min(100%,1440px)}.preview-frame.tablet{width:min(100%,820px)}.preview-frame.mobile{width:min(100%,390px)}.preview-frame iframe{width:100%;height:100%;min-height:0;border:0;background:#fff}.preview-frame.mode-comment iframe,.preview-frame.mode-suggest iframe,.preview-frame.mode-edit iframe{pointer-events:none}.comment-hit-target{position:absolute;inset:0;width:100%;height:100%;display:block;min-height:0;padding:0;border:0;border-radius:0;background:transparent;cursor:crosshair;z-index:5}.comment-draft-popover{position:absolute;z-index:7;width:min(320px,calc(100% - 1.5rem));transform:translate(-50%,.85rem);display:grid;gap:.55rem;border:1px solid var(--brand);border-radius:var(--radius);background:#0d1f1bfa;color:var(--text);padding:.75rem;box-shadow:var(--shadow)}.comment-draft-popover:before{content:"";position:absolute;left:50%;top:-.55rem;width:.9rem;height:.9rem;transform:translate(-50%) rotate(45deg);border-left:1px solid var(--brand);border-top:1px solid var(--brand);background:#0d1f1bfa}.comment-draft-popover label{font-weight:800}.comment-draft-popover textarea{min-height:84px;margin-top:0}.suggest-hit-target{background:#4ee0a10f}.edit-hit-target{background:#ffd16614}.pin{position:absolute;transform:translate(-50%,-50%);width:2rem;height:2rem;display:grid;place-items:center;border-radius:50%;background:var(--danger);color:#fff;font-weight:900;border:2px solid #fff;padding:0;min-height:0;box-shadow:0 8px 22px #00000052;z-index:3}textarea,select,input{width:100%;border-radius:var(--radius);border:1px solid var(--line);background:var(--panel);color:var(--text);padding:.75rem;margin-top:.35rem}.customer-mode-note{border:1px solid rgba(255,209,102,.36);border-radius:var(--radius);background:#ffd16614;padding:.75rem;color:var(--warn)}.client-package-form{display:grid;gap:.7rem;margin-top:1rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:1rem}.client-package-form h3{margin:0}.client-package-form fieldset{border:1px solid var(--line);border-radius:var(--radius);display:grid;gap:.45rem}.checkbox-row{display:flex;align-items:center;gap:.55rem}.checkbox-row input{width:auto}.pin.note{background:var(--accent);color:#06110e}.pin.change{background:var(--brand);color:#06110e}.pin.issue{background:var(--danger)}.pin.question{background:var(--warn);color:#06110e}.pin.approval{background:var(--ok);color:#06110e}.pin.done{opacity:.7}.pin.suggestion-pin{width:2.35rem;height:2.35rem;border-radius:var(--radius)}.pin.suggestion-pin.text{background:var(--brand);color:#06110e}.pin.suggestion-pin.image{background:var(--accent);color:#06110e}.pin.suggestion-pin.link{background:var(--warn);color:#06110e}.pin.suggestion-pin.section{background:#f4a261;color:#06110e}.pin.suggestion-pin.style{background:#c7a4ff;color:#06110e}.pin.suggestion-pin.other{background:var(--danger)}.pin.accepted{outline:3px solid var(--ok)}.pin.rejected{opacity:.55}.pin.marker-green{background:var(--brand);color:#06110e}.pin.marker-blue{background:var(--accent);color:#06110e}.pin.marker-yellow{background:var(--warn);color:#06110e}.pin.marker-red{background:var(--danger);color:#fff}.pin.marker-purple{background:#c7a4ff;color:#06110e}.pin.marker-soft{opacity:.72}.pin.marker-normal{opacity:1}.pin.marker-strong{box-shadow:0 0 0 5px #ffffff38,0 12px 34px #0000006b}.preview-context-menu{position:absolute;z-index:8;width:220px;display:grid;gap:.35rem;border:1px solid var(--line);border-radius:var(--radius);background:#0d1f1bfa;padding:.45rem;box-shadow:var(--shadow)}.preview-context-menu button{width:100%;justify-content:flex-start;background:var(--panel);color:var(--text)}textarea{min-height:100px;resize:vertical}label+select{margin-bottom:.5rem}.upload-actions,.comment-filters,.form-actions{display:flex;gap:.5rem;flex-wrap:wrap}.comment-filters{margin-top:.75rem}.marker-toolbar{display:grid;gap:.55rem;margin-top:.75rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:.75rem}.marker-toolbar span{color:var(--muted);font-size:.88rem}.marker-options{display:flex;gap:.45rem;margin-top:.4rem}.marker-swatch{width:2rem;height:2rem;min-height:0;padding:0;border-radius:50%;border:2px solid transparent}.marker-swatch.marker-green{background:var(--brand)}.marker-swatch.marker-blue{background:var(--accent)}.marker-swatch.marker-yellow{background:var(--warn)}.marker-swatch.marker-red{background:var(--danger)}.marker-swatch.marker-purple{background:#c7a4ff}.marker-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--brand)}.comment-filters button{background:var(--panel);color:var(--text)}.comment-filters button.active{background:var(--panel-strong);border-color:var(--brand)}.comment-list,.suggestion-list ul{list-style:none;padding:0;display:grid;gap:.75rem}.comment-list li,.suggestion-list li,.suggestion-form,.suggest-intro,.changed-files,.check,.export-panel,.coming-later,.empty-state{border:1px solid var(--line);background:var(--panel);border-radius:var(--radius);padding:1rem}.suggest-intro{pointer-events:none}.comment-meta{display:grid;gap:.2rem}.comment-meta span{color:var(--muted);font-size:.86rem}.comment-list p,.suggestion-list p,.empty-state p,.export-panel p,.coming-later p,.checks p,.suggest-intro p{color:var(--muted)}.suggestion-section,.edit-section{border-bottom:1px solid var(--line);padding-bottom:1rem}.panel-details{border:1px solid var(--line);border-radius:var(--radius);background:#ffffff05;padding:.7rem}.panel-details summary{cursor:pointer;display:flex;align-items:center;gap:.5rem}.panel-details summary h2{margin:0}.panel-details>*:not(summary){margin-top:.75rem}.warning-text{border:1px solid var(--warn);border-radius:var(--radius);padding:.75rem;color:var(--warn);background:#ffd16614;line-height:1.55}.suggestion-form{display:grid;gap:.55rem}.suggestion-form h3,.suggestion-group h3{margin:0 0 .35rem;font-size:.98rem}.suggestion-list{display:grid;gap:.9rem;margin-top:.9rem}.suggestion-group ul{margin:0}.visible-file-input{background:var(--bg-soft)}.changed-files{margin-top:.8rem}.changed-files h3{margin:0 0 .5rem;font-size:.98rem}.changed-files ul,.changed-files ol{margin:.5rem 0 0;padding-left:1.2rem;color:var(--muted)}.check-group{margin-top:1.2rem}.check-group h3{margin:0 0 .65rem}.check-list{display:grid;gap:.8rem}.check{border-left:6px solid var(--ok)}.check.warning{border-left-color:var(--warn)}.check.problem{border-left-color:var(--danger)}.check span{text-transform:uppercase;color:var(--muted);font-size:.76rem;font-weight:800}.check h4{margin:.25rem 0;font-size:1.03rem}.export-panel{display:grid;gap:.75rem;max-width:520px}.code-panel{display:grid;gap:1rem;min-height:0;overflow:auto}.code-header{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:1rem}.code-header h2{margin:0 0 .35rem;font-size:1.15rem}.code-header p{margin:0;color:var(--muted);line-height:1.55}.code-layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:1rem;min-height:0}.code-file-tree,.code-editor-area{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:1rem}.code-file-tree h3{margin:0 0 .6rem;font-size:.94rem}.code-file-tree ul{list-style:none;padding:0;margin:0 0 1rem;display:grid;gap:.4rem}.code-file-tree button{width:100%;background:var(--bg-soft);color:var(--text);display:grid;gap:.25rem;text-align:left}.code-file-tree button strong{color:var(--brand-strong);font-size:.78rem}.binary-list li{color:var(--muted);overflow-wrap:anywhere}.binary-list span{color:var(--brand-strong)}.code-current-file{display:flex;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.code-current-file p{margin-top:0}.warning-text{border:1px solid var(--warn);border-radius:var(--radius);background:#ffd16614;color:var(--text);padding:.75rem;line-height:1.5}.codemirror-shell{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#101816;min-height:460px}.codemirror-shell .cm-editor{min-height:460px;background:#101816;color:#eef7f3;font-size:.95rem}.codemirror-shell .cm-gutters{background:#0b1311;color:#a8bbb3;border-right-color:var(--line)}.code-textarea{min-height:460px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}@media(max-width:1120px){.app-shell{grid-template-columns:280px 1fr}.app-shell.left-collapsed,.app-shell.right-collapsed,.app-shell.left-collapsed.right-collapsed,.code-layout{grid-template-columns:1fr}.right-panel{grid-column:1 / -1;border-left:0;border-top:1px solid var(--line)}}@media(max-width:760px){.spk-app{height:auto;min-height:100vh;overflow:visible}.app-footer{display:grid;align-items:start}.app-shell{grid-template-columns:1fr;height:auto;overflow:visible}.panel-toggle-bar{display:none}.left-panel,.right-panel{border:0;border-bottom:1px solid var(--line)}.preview-frame iframe{height:520px}.preview-frame{height:auto}}
