.copilot-shell{display:flex;flex-direction:column;height:calc(100vh - 0px);padding:1rem 1.25rem;gap:.75rem;background:var(--bg)}.copilot-topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}.copilot-title{font-size:1.4rem;font-weight:700;margin:0;letter-spacing:-.01em;color:var(--text)}.copilot-subtitle{margin:.2rem 0 0;color:var(--text2);font-size:.875rem}.copilot-mode-tag{background:var(--surface2);border:1px solid var(--border);color:var(--text2);font-size:.78rem;padding:.3rem .6rem;border-radius:999px;font-weight:500}.copilot-mode-tag code{font-family:var(--font-mono),monospace;background:transparent;color:var(--accent);font-size:.75rem}.copilot-layout{display:grid;grid-template-columns:1fr 380px;gap:1rem;flex:1;min-height:0;position:relative}.copilot-layout.collapsed{grid-template-columns:1fr auto}@media (max-width:1100px){.copilot-layout{grid-template-columns:1fr}.copilot-preview{max-height:320px}.copilot-layout.collapsed{grid-template-columns:1fr}}.copilot-preview{position:relative}.copilot-preview-collapse{position:absolute;top:.8rem;right:.8rem;background:var(--surface2);border:1px solid var(--border);color:var(--text2);width:30px;height:30px;border-radius:6px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;z-index:2;transition:color .15s,border-color .15s}.copilot-preview-collapse:hover{color:var(--text);border-color:var(--accent)}.copilot-preview-expand{align-self:stretch;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text2);cursor:pointer;font-size:.8rem;font-weight:600;writing-mode:vertical-rl;text-orientation:mixed;padding:.8rem .4rem;transition:color .15s,border-color .15s,background .15s}.copilot-preview-expand:hover{color:var(--text);border-color:var(--accent);background:var(--surface2)}.copilot-chat{display:flex;flex-direction:column;overflow:hidden}.copilot-chat,.copilot-preview{min-height:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.copilot-preview{padding:1rem 1.1rem;overflow-y:auto}.copilot-scroll{flex:1;overflow-y:auto;padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.65rem}.copilot-bubble{max-width:84%;padding:.7rem .9rem;border-radius:14px;font-size:.92rem;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.copilot-bubble.user{align-self:flex-end;background:linear-gradient(135deg,var(--accent) 0,var(--accent-d) 100%);color:white;border-bottom-right-radius:4px}.copilot-bubble.assistant{align-self:flex-start;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.copilot-bubble-content{font-size:.92rem}.copilot-bubble.typing{display:flex;gap:.3rem;padding:.85rem 1rem}.copilot-bubble.typing .dot{width:7px;height:7px;border-radius:50%;background:var(--text2);animation:copilot-typing 1.2s ease-in-out infinite}.copilot-bubble.typing .dot:nth-child(2){animation-delay:.15s}.copilot-bubble.typing .dot:nth-child(3){animation-delay:.3s}@keyframes copilot-typing{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}.copilot-traces{margin-top:.55rem;display:flex;flex-direction:column;gap:.25rem}.copilot-trace{display:flex;align-items:baseline;gap:.5rem;font-family:var(--font-mono),monospace;font-size:.72rem;padding:.25rem .55rem;border-radius:6px;background:rgba(74,222,128,.07);border-left:2px solid var(--green)}.copilot-trace.fail{background:rgba(248,113,113,.08);border-left-color:var(--red)}.trace-name{font-weight:700;color:var(--text)}.trace-detail{color:var(--text2)}.copilot-charts{margin-top:.7rem;display:flex;flex-direction:column;gap:.6rem}.inline-chart{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.7rem .85rem;font-size:.84rem}.inline-chart-title{font-size:.72rem;text-transform:uppercase;font-weight:700;color:var(--text2);letter-spacing:.05em;margin-bottom:.55rem}.spark-grid{display:flex;flex-direction:column;gap:.45rem}.spark-row{display:flex;align-items:center;gap:.7rem}.spark-label{flex:1;min-width:0}.spark-row-title{font-weight:600;color:var(--text);font-size:.82rem;white-space:nowrap}.spark-row-stats{display:flex;gap:.4rem;align-items:baseline;font-family:var(--font-mono),monospace;font-size:.74rem}.spark-latest{color:var(--text);font-weight:700;font-size:.88rem}.spark-unit{color:var(--text3)}.spark-sum{margin-left:auto;color:var(--text2)}.spark{flex-shrink:0;width:224px}.spark svg{display:block}.spark-axis{display:flex;justify-content:space-between;font-family:var(--font-mono),monospace;font-size:.66rem;color:var(--text3);margin-top:1px}.chart-empty{font-size:.78rem;color:var(--text3);font-style:italic}.mix-bar{display:flex;height:14px;background:var(--surface2);border-radius:4px;overflow:hidden}.mix-seg{transition:opacity .15s}.mix-seg:hover{opacity:.75}.mix-legend{list-style:none;margin:.55rem 0 0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.2rem .7rem;font-size:.78rem}.mix-legend li{display:flex;align-items:center;gap:.4rem}.mix-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.mix-key{flex:1;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mix-val{font-family:var(--font-mono),monospace;font-weight:600;color:var(--text)}.cost-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.stat{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.5rem .6rem}.stat.accent{border-color:var(--accent)}.stat-label{font-size:.68rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:.18rem}.stat-value{font-family:var(--font-mono),monospace;font-size:1rem;font-weight:700;color:var(--text)}.stat.accent .stat-value{color:var(--accent)}.cost-detail{margin-top:.55rem;font-size:.78rem}.cost-detail summary{cursor:pointer;color:var(--text2);padding:.25rem 0}.cost-detail table{width:100%;border-collapse:collapse;font-family:var(--font-mono),monospace}.cost-detail td{padding:.2rem .4rem;border-bottom:1px dashed var(--border)}.cost-detail td:last-child{text-align:right;color:var(--text2)}.cost-notes{margin:.5rem 0 0;padding-left:1.1rem;font-size:.74rem;color:var(--text3)}.compare-table{width:100%;border-collapse:collapse;font-size:.82rem}.compare-table td,.compare-table th{padding:.35rem .4rem;text-align:left;border-bottom:1px solid var(--border)}.compare-table th{font-size:.7rem;color:var(--text3);text-transform:uppercase;font-weight:600;letter-spacing:.05em}.compare-table td{font-family:var(--font-mono),monospace}.compare-table td:first-child{font-family:inherit;font-weight:600}.compare-table tr.winner{background:rgba(74,222,128,.07)}.compare-table tr.winner td:first-child{color:var(--green)}.compare-winner{margin-top:.45rem;padding:.45rem .65rem;background:rgba(74,222,128,.1);border-left:3px solid var(--green);border-radius:4px;font-size:.82rem;color:var(--text)}.compliance-clean{padding:.7rem .9rem;background:rgba(74,222,128,.1);border:1px solid var(--green);color:var(--green);border-radius:6px;text-align:center;font-weight:600;font-size:.86rem}.compliance-list,.suggestion-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.compliance-list li,.suggestion-list li{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.55rem .7rem}.compliance-head,.suggestion-head{display:flex;align-items:center;gap:.55rem;font-size:.86rem}.compliance-sev,.suggestion-prio{font-size:.66rem;color:white;padding:.08rem .4rem;text-transform:uppercase;font-weight:700;letter-spacing:.04em}.compliance-area,.compliance-sev,.suggestion-prio{font-family:var(--font-mono),monospace;border-radius:3px}.compliance-area{font-size:.7rem;color:var(--text3);background:var(--bg);padding:.06rem .35rem}.compliance-what{flex:1;font-weight:600;color:var(--text)}.compliance-evidence{margin-top:.25rem;font-size:.74rem;color:var(--text2);font-family:var(--font-mono),monospace;font-style:italic}.compliance-fix{color:var(--text)}.compliance-fix,.suggestion-why{margin-top:.25rem;font-size:.78rem}.suggestion-why{color:var(--text2)}.suggestion-do{margin-top:.3rem;padding:.35rem .55rem;background:var(--bg);border-left:2px solid var(--accent);border-radius:4px;font-size:.8rem;color:var(--text)}.suggestion-do em{color:var(--text);font-style:italic}.suggestion-do-label{font-family:var(--font-mono),monospace;font-size:.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.report-card{display:flex;align-items:center;gap:.7rem;padding:.7rem .85rem;background:var(--surface2);border:1px solid var(--border);border-radius:6px}.report-card>div:first-child{flex:1}.report-filename{font-weight:700;color:var(--text)}.report-filename,.report-meta{font-family:var(--font-mono),monospace}.report-meta{margin-top:.15rem;font-size:.72rem;color:var(--text3)}.report-download{background:var(--accent);color:white;border:0;padding:.5rem .9rem;border-radius:6px;cursor:pointer;font-weight:600;font-size:.86rem;transition:background .15s}.report-download:hover{background:var(--accent-d)}.report-preview{margin:.5rem 0 0;padding:.6rem;background:var(--bg);border:1px solid var(--border);border-radius:4px;font-family:var(--font-mono),monospace;font-size:.74rem;max-height:220px;overflow:auto;white-space:pre-wrap;color:var(--text2)}.patterns-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}.patterns-col-title{font-size:.7rem;text-transform:uppercase;font-weight:700;letter-spacing:.05em;margin-bottom:.4rem}.patterns-col-title.good{color:var(--green)}.patterns-col-title.bad{color:var(--red)}.patterns-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem}.patterns-list li{display:flex;justify-content:space-between;gap:.4rem;padding:.2rem .4rem;background:var(--surface2);border-radius:3px;font-size:.78rem}.patterns-phrase{flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.patterns-count,.patterns-phrase{font-family:var(--font-mono),monospace;font-size:.74rem}.patterns-count{flex-shrink:0;color:var(--text3)}.patterns-insights{margin-top:.55rem;display:flex;flex-direction:column;gap:.3rem}.patterns-insight{padding:.45rem .6rem;background:rgba(96,165,250,.08);border-left:3px solid var(--blue);border-radius:4px;font-size:.78rem;color:var(--text)}.copilot-toolbar{display:flex;align-items:center;gap:.4rem;padding:.45rem .6rem;border-bottom:1px solid var(--border);background:var(--surface)}.copilot-toolbar-btn{background:transparent;border:1px solid var(--border);color:var(--text2);padding:.3rem .65rem;border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;transition:color .15s,border-color .15s,background .15s;display:inline-flex;align-items:center;gap:.3rem}.copilot-toolbar-btn:hover:not(:disabled){color:var(--text);border-color:var(--accent);background:var(--surface2)}.copilot-toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.copilot-toolbar-btn.active{background:var(--accent);color:white;border-color:var(--accent)}.copilot-toolbar-btn.active:hover:not(:disabled){background:var(--accent-d);color:white}.copilot-toolbar-spacer{flex:1}.copilot-toolbar-hint{font-family:var(--font-mono),monospace;font-size:.7rem;color:var(--text3)}.copilot-mic{width:42px;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:1.1rem;cursor:pointer;transition:background .15s,border-color .15s}.copilot-mic:hover:not(:disabled){border-color:var(--accent);background:var(--surface)}.copilot-mic:disabled{opacity:.35;cursor:not-allowed}.copilot-mic.listening{background:var(--red);color:white;border-color:var(--red);animation:copilot-pulse 1.2s ease-in-out infinite}@keyframes copilot-pulse{0%,to{box-shadow:0 0 0 0 rgba(248,113,113,.5)}50%{box-shadow:0 0 0 6px rgba(248,113,113,0)}}.copilot-mic-error{margin:0 .75rem .75rem;padding:.5rem .7rem;background:rgba(248,113,113,.1);border:1px solid var(--red);color:var(--red);border-radius:6px;font-size:.78rem}.palette-backdrop{position:fixed;inset:0;z-index:1000;background:rgba(8,12,20,.55);backdrop-filter:blur(3px);display:flex;justify-content:center;align-items:flex-start;padding-top:10vh;animation:palette-fade-in .12s ease-out}@keyframes palette-fade-in{0%{opacity:0}to{opacity:1}}.palette{width:min(640px,92vw);background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 25px 60px -10px rgba(0,0,0,.55);display:flex;flex-direction:column;max-height:70vh;overflow:hidden;animation:palette-slide-in .16s ease-out}@keyframes palette-slide-in{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.palette-input{background:transparent;border:0;border-bottom:1px solid var(--border);color:var(--text);padding:1rem 1.1rem;font-size:.98rem;font-family:inherit;outline:none}.palette-input::-moz-placeholder{color:var(--text3)}.palette-input::placeholder{color:var(--text3)}.palette-list{overflow-y:auto;padding:.4rem 0}.palette-empty{padding:1.1rem;color:var(--text3);font-size:.88rem;text-align:center}.palette-group{padding:.2rem 0 .4rem}.palette-group-label{padding:.4rem .85rem .2rem;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);font-weight:700}.palette-row{display:flex;align-items:center;gap:.55rem;width:100%;padding:.5rem .85rem;background:transparent;border:0;color:var(--text);text-align:left;cursor:pointer;font-size:.88rem;font-family:inherit;border-left:2px solid transparent}.palette-row.active{background:var(--surface2);border-left-color:var(--accent)}.palette-row-label{flex-shrink:0}.palette-row-hint{flex:1;color:var(--text3);font-size:.76rem;margin-left:.4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.palette-row-shortcut{color:var(--text2);background:var(--surface2);border:1px solid var(--border);padding:.1rem .4rem;border-radius:4px}.palette-footer,.palette-row-shortcut{font-family:var(--font-mono),monospace;font-size:.72rem}.palette-footer{display:flex;gap:1rem;padding:.55rem .9rem;border-top:1px solid var(--border);background:var(--surface);color:var(--text3)}.copilot-cursor{display:inline-block;margin-left:2px;color:var(--accent);animation:copilot-blink 1s steps(2) infinite}@keyframes copilot-blink{to{opacity:0}}.copilot-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.6rem;align-self:flex-start;max-width:84%}.copilot-chip{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.45rem .85rem;border-radius:999px;font-size:.82rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s}.copilot-chip:hover:not(:disabled){border-color:var(--accent);background:var(--surface)}.copilot-chip:disabled{opacity:.4;cursor:not-allowed}.copilot-chip.template{background:transparent;border-color:var(--border2);color:var(--text2);font-size:.78rem;padding:.35rem .7rem}.copilot-chip.template:hover:not(:disabled){color:var(--text);border-color:var(--purple)}.copilot-chip-row-label{margin:.8rem 0 .3rem;font-size:.75rem;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.06em;align-self:flex-start;max-width:84%}.copilot-bubble.failed{position:relative;opacity:.7;border:1px solid var(--red)}.copilot-bubble.failed:before{content:"Failed — couldn't send";position:absolute;top:-1.2rem;right:0;font-size:.7rem;color:var(--red);font-weight:600}.copilot-retry{display:inline-block;margin-top:.5rem;background:transparent;border:1px solid;color:inherit;padding:.25rem .7rem;border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s}.copilot-retry:hover{background:rgba(255,255,255,.1)}.copilot-error{align-self:stretch;margin:.5rem .2rem 0;padding:.7rem .9rem;background:rgba(248,113,113,.12);border:1px solid var(--red);color:var(--red);border-radius:8px;font-size:.85rem}.copilot-input-row{display:flex;gap:.6rem;padding:.75rem;border-top:1px solid var(--border);background:var(--surface)}.copilot-input{flex:1;resize:none;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.65rem .8rem;border-radius:8px;font-family:inherit;font-size:.92rem;line-height:1.4;transition:border-color .15s}.copilot-input:focus{outline:none;border-color:var(--accent)}.copilot-input:disabled{opacity:.55;cursor:not-allowed}.copilot-send{padding:0 1.1rem;background:var(--accent);color:white;border:0;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:background .15s;min-width:72px}.copilot-send:hover:not(:disabled){background:var(--accent-d)}.copilot-send:disabled{opacity:.4;cursor:not-allowed}.preview-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.5rem}.preview-header h3{margin:0;font-size:.95rem;font-weight:700;color:var(--text);letter-spacing:.02em;text-transform:uppercase}.preview-progress{font-family:var(--font-mono),monospace;font-size:.78rem;color:var(--text2);font-weight:600}.preview-progress-bar{height:3px;background:var(--surface2);border-radius:2px;margin-bottom:1rem;overflow:hidden}.preview-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--green));transition:width .4s ease}.preview-saved{margin-bottom:1rem;padding:.6rem .8rem;background:rgba(74,222,128,.1);border:1px solid var(--green);border-radius:8px;color:var(--green);font-size:.85rem}.preview-saved a{color:var(--green);text-decoration:underline;font-weight:600}.preview-section{margin-bottom:1.1rem;padding-bottom:.8rem;border-bottom:1px dashed var(--border)}.preview-section:last-child{border-bottom:0}.preview-section h4{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text2);margin:0 0 .5rem}.preview-kv{display:flex;gap:.6rem;align-items:baseline;padding:.25rem 0;font-size:.85rem}.preview-kv.long{flex-direction:column;gap:.2rem;align-items:stretch}.preview-k{color:var(--text2);font-size:.78rem;min-width:100px;flex-shrink:0}.preview-v{color:var(--text);font-weight:500;word-break:break-word}.preview-chips{list-style:none;padding:0;margin:.1rem 0 0;display:flex;flex-wrap:wrap;gap:.3rem}.preview-chips li{background:var(--surface2);border:1px solid var(--border);padding:.18rem .55rem;border-radius:999px;font-size:.76rem;color:var(--text)}.preview-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}.preview-list li{background:var(--surface2);border:1px solid var(--border);padding:.5rem .7rem;border-radius:8px;font-size:.84rem}.preview-tag{display:inline-block;background:var(--accent);color:white;font-size:.68rem;padding:.08rem .4rem;border-radius:4px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;vertical-align:middle}.preview-required{color:var(--red);font-weight:700}.preview-q{color:var(--text2);font-size:.8rem;margin-top:.2rem;font-style:italic}.preview-empty{color:var(--text3);font-size:.82rem;font-style:italic}