/* components.css — Спикарт v4 */

/* ═══ LOGIN ══════════════════════════════════════════════ */
#login-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg);z-index:999}
.login-box{background:var(--bg2);border:1px solid var(--c);border-radius:4px;box-shadow:0 0 30px var(--cglow);padding:32px 28px;width:300px;display:flex;flex-direction:column;align-items:center;gap:10px}
.login-logo{width:80px;height:80px;border-radius:50%;overflow:hidden;border:2px solid var(--accent);box-shadow:0 0 20px var(--cglow);margin-bottom:4px}
.login-logo video{width:100%;height:100%;object-fit:cover}
.login-title{font-size:18px;font-weight:700;color:var(--accent);letter-spacing:4px}
.login-sub{font-size:11px;color:var(--text2);letter-spacing:1px;margin-bottom:6px}
.login-box input{width:100%;padding:8px 12px}
.login-box .btn{width:100%;padding:10px;font-size:13px;letter-spacing:1px}
.login-err{color:var(--red);font-size:11px;min-height:14px}

/* ═══ APP LAYOUT ══════════════════════════════════════════ */
#app{display:none;height:100vh;flex-direction:row;gap:3px;padding:3px;background:var(--bg)}

/* ═══ SIDEBAR ═════════════════════════════════════════════ */
#sidebar{width:160px;min-width:160px;flex-shrink:0;background:var(--bg2);border:1px solid var(--c);box-shadow:0 0 14px var(--cglow);display:flex;flex-direction:column;overflow:hidden;border-radius:3px}
.sb-logo-wrap{display:flex;flex-direction:column;align-items:center;padding:12px 8px 8px;border-bottom:1px solid rgba(0,212,255,.2)}
.sb-logo-ring{width:80px;height:80px;border-radius:50%;overflow:hidden;border:2px solid var(--accent);box-shadow:0 0 28px var(--cglow),0 0 8px var(--accent);margin-bottom:6px}
.sb-logo-ring video{width:100%;height:100%;object-fit:cover}
.sb-brand{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:4px}
.sb-sysinfo{display:grid;grid-template-columns:1fr 1fr;gap:2px;padding:6px 8px;border-bottom:1px solid rgba(0,212,255,.15)}
.ssi{background:var(--bg3);border:1px solid rgba(0,212,255,.2);border-radius:2px;padding:3px 5px;display:flex;justify-content:space-between;align-items:center}
.ssi-lbl{font-size:9px;color:var(--text2);letter-spacing:.5px}
.ssi-val{font-size:10px;color:var(--accent);font-weight:600}
.sb-section{font-size:9px;color:var(--text2);letter-spacing:2px;padding:6px 10px 3px;text-transform:uppercase}
.sb-nav{display:flex;flex-direction:column;gap:1px;padding:2px 5px;overflow-y:auto;flex:1}
.nav-btn{display:flex;align-items:center;gap:8px;width:100%;padding:7px 8px;background:transparent;border:1px solid transparent;color:var(--text);cursor:pointer;border-radius:2px;font-size:12px;font-weight:500;text-align:left;letter-spacing:.5px;transition:background .12s,border-color .12s}
.nav-btn:hover{background:rgba(0,212,255,.07);border-color:rgba(0,212,255,.2)}
.nav-btn.active{background:rgba(0,212,255,.1);border-color:rgba(0,212,255,.4);color:var(--accent);box-shadow:0 0 8px var(--cglow)}
.nav-ico{font-size:13px;width:18px;text-align:center}
.sb-extra{padding:5px 8px;border-top:1px solid rgba(0,212,255,.15)}
.sb-extra-btn{width:100%;padding:6px 8px;margin-bottom:3px;background:var(--bg3);border:1px solid rgba(0,212,255,.25);border-radius:2px;color:var(--text);font-size:11px;cursor:pointer;text-align:left}
.sb-extra-btn:hover{border-color:var(--accent);color:var(--accent)}
.sb-steps{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;background:var(--bg3);border:1px solid rgba(0,212,255,.2);border-radius:2px;margin-bottom:4px}
.sb-steps-lbl{font-size:9px;color:var(--text2);letter-spacing:1px}
.sb-steps-val{font-size:20px;font-weight:700;color:var(--accent);line-height:1;text-shadow:0 0 10px var(--cglow)}
.sb-bottom{border-top:1px solid rgba(0,212,255,.15);padding:5px}

/* ═══ MAIN AREA ════════════════════════════════════════════ */
#main-area{flex:1;display:flex;gap:0;min-width:0;overflow:hidden}

/* ═══ LEFT PANEL ══════════════════════════════════════════ */
#left-panel{width:380px;min-width:160px;flex-shrink:0;margin-right:0;background:var(--bg2);border:1px solid var(--c);box-shadow:0 0 14px var(--cglow);border-radius:3px;display:flex;flex-direction:column;overflow:hidden;position:relative}

/* ═══ VIEWS ════════════════════════════════════════════════ */
.view{display:none;flex-direction:column;flex:1;overflow:hidden;min-height:0}
.view.active{display:flex}
.view-header{display:flex;align-items:center;gap:6px;padding:5px 10px;border-bottom:1px solid var(--c);background:var(--bg3);flex-shrink:0;min-height:34px}
.view-title{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:2px}

/* ═══ CHAT ══════════════════════════════════════════════════ */
.chat-topbar{padding:5px 8px;border-bottom:1px solid rgba(0,212,255,.15);display:flex;align-items:center;gap:6px;background:var(--bg3);flex-shrink:0}
#messages{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:6px}
.msg-wrap{display:flex;flex-direction:column;max-width:88%}
.msg-wrap.user{align-self:flex-end}
.msg-wrap.assistant{align-self:flex-start}
.msg-wrap.system{align-self:center;max-width:100%}
.msg-bubble{padding:7px 11px;border-radius:6px;font-size:13px;line-height:1.55;word-break:break-word}
.msg-wrap.user .msg-bubble{background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3)}
.msg-wrap.assistant .msg-bubble{background:var(--bg3);border:1px solid rgba(0,212,255,.2)}
.msg-wrap.system .msg-bubble{background:transparent;color:var(--text2);font-size:11px;font-style:italic;border:none;padding:3px 0}
.msg-tools{margin-top:3px;display:flex;flex-direction:column;gap:1px}
.tool-item{font-size:11px;color:var(--text2);font-family:var(--mono);padding:1px 4px}
.tool-item.error{color:var(--red)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.typing-cursor::after{content:'▋';animation:blink 1s infinite;color:var(--accent);font-size:11px}
@keyframes think-dot{0%,80%,100%{transform:scale(0);opacity:.3}40%{transform:scale(1);opacity:1}}
.think-spinner{display:inline-flex;align-items:center;gap:5px;padding:4px 0}
.think-spinner span{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;animation:think-dot 1.2s infinite ease-in-out}
.think-spinner span:nth-child(1){animation-delay:0s}
.think-spinner span:nth-child(2){animation-delay:.2s}
.think-spinner span:nth-child(3){animation-delay:.4s}
.welcome-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text2);text-align:center;gap:8px}
.welcome-ico{font-size:32px;color:var(--accent);text-shadow:0 0 20px var(--cglow)}
.welcome-text{font-size:13px;line-height:1.6}
#input-panel{border-top:1px solid var(--c);background:var(--bg3);flex-shrink:0}

/* ═══ RESIZE HANDLE ═══════════════════════════════════════ */
.resize-h{width:4px;background:transparent;cursor:col-resize;flex-shrink:0;border-radius:2px;transition:background .15s}
.resize-h:hover,.resize-h.dragging{background:var(--accent)}

/* ═══ RIGHT PANEL ═════════════════════════════════════════ */
#right-panel{flex:1;min-width:200px;background:var(--bg2);border:1px solid var(--c);box-shadow:0 0 14px var(--cglow);border-radius:3px;display:flex;flex-direction:column;overflow:hidden}
#panel-tabs{display:flex;gap:2px;padding:4px 6px;flex-wrap:wrap;border-bottom:1px solid var(--c);background:var(--bg3);flex-shrink:0}
.panel-tab{padding:3px 10px;font-size:11px;font-weight:600;letter-spacing:.5px;border-radius:var(--radius);background:transparent;border:1px solid transparent;color:var(--text2);cursor:pointer;transition:all .15s;user-select:none}
.panel-tab:hover{color:var(--accent);background:rgba(0,212,255,.07)}
.panel-tab.active{background:rgba(0,212,255,.12);border-color:var(--c);color:var(--accent);box-shadow:0 0 6px var(--cglow)}
.panel-tab.purple.active{background:rgba(124,58,237,.15);border-color:rgba(124,58,237,.5);color:#a78bfa}
#panel-content{flex:1;overflow:hidden;position:relative}
.panel-view{display:none;height:100%;flex-direction:column;overflow:hidden}
.panel-view.active{display:flex}
#render-area{flex:1;overflow:auto;position:relative}
#render-area iframe{width:100%;height:100%;border:none}

/* ═══ EXTERNAL CHAT ═══════════════════════════════════════ */
.ext-chat-header{padding:6px 10px;border-bottom:1px solid var(--c);display:flex;align-items:center;gap:8px;flex-shrink:0;background:var(--bg3)}
.ext-status{width:8px;height:8px;border-radius:50%;background:var(--text3);flex-shrink:0}
.ext-status.online{background:var(--green);box-shadow:0 0 6px var(--green)}
#ext-messages{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:6px}
.ext-input-area{padding:6px 8px;border-top:1px solid var(--c);display:flex;gap:6px;align-items:flex-end;background:var(--bg3);flex-shrink:0}
#ext-input{flex:1;padding:7px 10px;min-height:36px;max-height:100px;font-size:13px}
.no-api-placeholder{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--text2);padding:20px;text-align:center}
.no-api-placeholder .ni{font-size:28px;opacity:.4}

/* ═══ ROOM ════════════════════════════════════════════════ */
.room-msg{display:flex;gap:6px;align-items:flex-start;padding:3px 5px;border-radius:2px}
.room-msg:hover{background:rgba(0,212,255,.04)}
.rm-icon{flex-shrink:0;font-size:13px}
.rm-text{font-size:11px;color:var(--text2);font-family:var(--mono);word-break:break-all;flex:1}
.rm-ts{font-size:10px;color:var(--text3);flex-shrink:0}
.from-claude .rm-text{color:var(--accent)}
.from-qwen .rm-text{color:var(--green)}
.from-sonnet .rm-text{color:var(--accent)}
.from-haiku .rm-text{color:var(--purple)}
.from-topic .rm-text{color:var(--yellow);font-weight:600}

/* ═══ DEBUG ═══════════════════════════════════════════════ */
.debug-entry{padding:2px 0;border-bottom:1px solid rgba(0,212,255,.06);color:var(--text2);font-family:var(--mono);font-size:11px}
.debug-entry.tool{color:var(--accent)}
.debug-entry.think{color:rgba(124,58,237,.8)}
.debug-entry.error{color:var(--red)}
.debug-entry.status{color:var(--text3)}

/* ═══ ADMIN ═══════════════════════════════════════════════ */
.admin-wrap{padding:10px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;height:100%}
.admin-section{background:var(--bg3);border:1px solid rgba(0,212,255,.2);border-radius:4px;padding:10px}
.admin-title{font-size:9px;font-weight:700;color:var(--accent);letter-spacing:2px;margin-bottom:8px;text-transform:uppercase}
.admin-row{display:flex;flex-direction:column;gap:3px;margin-bottom:6px}
.admin-row label{font-size:10px;color:var(--text2);letter-spacing:.5px}
.admin-row input,.admin-row select,.admin-row textarea{width:100%;padding:6px 10px}
.admin-row textarea{min-height:70px}
.admin-row-h{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.admin-row-h label{font-size:10px;color:var(--text2);white-space:nowrap}
.admin-row-h input{width:80px}
.admin-btns{display:flex;gap:8px;margin-top:4px}

/* ═══ SETTINGS SECTIONS ═══════════════════════════════════ */
.st-section{background:var(--bg2);border:1px solid rgba(0,212,255,.18);border-radius:4px;overflow:hidden;flex-shrink:0}
.st-head{display:flex;align-items:center;justify-content:space-between;padding:9px 12px;font-size:11px;font-weight:700;color:var(--accent);letter-spacing:1px;cursor:pointer;user-select:none;text-transform:uppercase}
.st-head:hover{background:rgba(0,212,255,.04)}
.st-arrow{font-size:10px;color:var(--text2)}
.st-body{display:flex;flex-direction:column;gap:6px;padding:8px 12px 12px;border-top:1px solid rgba(0,212,255,.1)}
.st-row{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.st-row label{font-size:10px;color:var(--text2);white-space:nowrap;width:100px;flex-shrink:0}
.st-row input,.st-row select{padding:5px 8px;font-size:12px}

/* ═══ CODE BLOCKS ═════════════════════════════════════════ */
.code-block{margin:8px 0;border-radius:4px;overflow:hidden;border:1px solid rgba(0,212,255,.2);background:#1d1f21}
.code-header{display:flex;align-items:center;justify-content:space-between;padding:4px 10px;background:rgba(0,0,0,.4);border-bottom:1px solid rgba(0,212,255,.15)}
.code-lang{font-size:10px;color:var(--accent);letter-spacing:1px;text-transform:uppercase;font-family:var(--mono)}
.code-copy{background:transparent;border:1px solid rgba(0,212,255,.25);color:var(--text2);padding:2px 8px;border-radius:2px;font-size:10px;cursor:pointer;transition:all .15s}
.code-copy:hover{border-color:var(--accent);color:var(--accent)}
.code-block pre{margin:0!important;border-radius:0!important;border:none!important;background:#1d1f21!important;font-size:12px!important;line-height:1.6!important;padding:10px 12px!important;overflow-x:auto}
.code-block code{font-family:'Cascadia Code','Fira Code',monospace!important;font-size:12px!important}
/* Prism tomorrow theme overrides */
code[class*="language-"],pre[class*="language-"]{background:#1d1f21!important;text-shadow:none!important}

/* ═══ ПТО ════════════════════════════════════════════════ */
.pto-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.pto-header h2{font-size:16px;font-weight:700;color:var(--accent);margin:0}
.pto-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;margin-bottom:16px}
.pto-project-card{background:var(--bg2);border:1px solid var(--c);border-radius:6px;padding:14px;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.pto-project-card:hover{border-color:var(--accent);box-shadow:0 0 10px rgba(0,212,255,.1)}
.pto-project-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px;line-height:1.4}
.pto-project-id{font-size:11px;color:var(--text2);font-family:monospace;margin-bottom:8px}
.pto-project-meta{display:flex;gap:6px;flex-wrap:wrap}
.pto-badge{font-size:10px;padding:2px 7px;border-radius:10px;border:1px solid}
.pto-badge.green{color:#4caf50;border-color:#4caf50;background:rgba(76,175,80,.08)}
.pto-badge.grey{color:var(--text2);border-color:var(--c)}
.pto-empty{color:var(--text2);font-size:13px;padding:24px;text-align:center;border:1px dashed var(--c);border-radius:6px}
.pto-form{background:var(--bg2);border:1px solid var(--c);border-radius:6px;padding:16px;margin-top:12px;max-width:400px}
.pto-form h3{margin:0 0 12px;font-size:14px;color:var(--accent)}
.pto-form label{display:block;font-size:11px;color:var(--text2);margin-bottom:4px}
.pto-input{width:100%;background:var(--bg);border:1px solid var(--c);color:var(--text);padding:6px 8px;border-radius:4px;font-size:13px;box-sizing:border-box}
.pto-form-actions{display:flex;gap:8px;margin-top:12px}
/* Кнопки */
.pto-btn{background:var(--bg2);border:1px solid var(--c);color:var(--text);padding:5px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:border-color .2s}
.pto-btn:hover{border-color:var(--accent);color:var(--accent)}
.pto-btn-primary{border-color:var(--accent);color:var(--accent)}
.pto-btn-primary:hover{background:rgba(0,212,255,.08)}
.pto-btn-muted{opacity:.6}
.pto-btn-sm{padding:3px 8px;font-size:11px}
/* Страница проекта */
.pto-project-page{display:flex;flex-direction:column;gap:10px}
.pto-project-topbar{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.pto-project-topbar h2{flex:1;font-size:14px;font-weight:700;color:var(--accent);margin:0}
.pto-project-id-badge{font-size:10px;font-family:monospace;color:var(--text2);padding:2px 6px;background:var(--bg3);border-radius:3px}
/* Секции */
.pto-section{background:var(--bg2);border:1px solid var(--c);border-radius:6px;overflow:hidden}
.pto-section-header{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;user-select:none}
.pto-section-header:hover{background:var(--bg3)}
.pto-section-icon{font-size:14px}
.pto-section-header>span:nth-child(2){flex:1;font-size:12px;font-weight:600;color:var(--text)}
.pto-count-badge{font-size:10px;padding:2px 7px;border-radius:10px}
.pto-count-badge.ready,.pto-count-badge.done{color:#4caf50;border:1px solid #4caf50;background:rgba(76,175,80,.08)}
.pto-count-badge.missing,.pto-count-badge.pending{color:var(--text2);border:1px solid var(--c)}
/* Прогресс */
.pto-progress-wrap{display:flex;align-items:center;gap:6px}
.pto-progress-bar{width:80px;height:4px;background:var(--bg3);border-radius:2px;overflow:hidden}
.pto-progress-fill{height:100%;border-radius:2px;transition:width .3s}
.pto-progress-fill.done{background:#4caf50}
.pto-progress-fill.partial{background:var(--accent)}
.pto-progress-fill.pending{background:var(--c)}
.pto-progress-label{font-size:10px;color:var(--text2);white-space:nowrap}
/* Список шагов */
.pto-steps-list{border-top:1px solid var(--c);overflow:hidden;max-height:2000px;transition:max-height .3s}
.pto-steps-list.collapsed{max-height:0;border-top:none}
.pto-step-row{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--bg3)}
.pto-step-row:last-child{border-bottom:none}
.pto-step-row.done{opacity:.7}
.pto-step-icon{font-size:13px;flex-shrink:0}
.pto-step-label{flex:1;font-size:12px;color:var(--text)}
.pto-step-actions{display:flex;gap:6px;flex-shrink:0}
/* Обязательные документы */
.pto-required-docs{padding:8px 12px;display:flex;flex-direction:column;gap:6px}
.pto-doc-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--bg3)}
.pto-doc-row:last-child{border-bottom:none}
.pto-doc-icon{font-size:13px;flex-shrink:0}
.pto-doc-label{flex:1;font-size:12px;color:var(--text)}
.pto-doc-status{font-size:10px;color:var(--text2);white-space:nowrap}
.pto-upload-btn{font-size:11px;color:var(--accent);cursor:pointer;white-space:nowrap;padding:3px 8px;border:1px solid var(--accent);border-radius:3px}
/* Реестр */
.pto-registry .pto-section-header{background:rgba(0,212,255,.04)}
/* Регистрация — последовательная форма */
.pto-reg-section{background:var(--bg2);border:1px solid var(--c);border-radius:6px;padding:12px 14px}
.pto-reg-head{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.5px;text-transform:uppercase;margin-bottom:10px}
.pto-reg-row{display:flex;align-items:center;gap:10px;padding:5px 0;border-bottom:1px solid var(--bg3);flex-wrap:wrap}
.pto-reg-row:last-child{border-bottom:none}
.pto-reg-label{font-size:12px;color:var(--text);min-width:160px;flex-shrink:0}
.pto-reg-files{display:flex;gap:6px;flex-wrap:wrap;flex:1}
.pto-reg-file{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--accent);
              cursor:pointer;padding:2px 8px;border:1px solid var(--c);border-radius:10px;
              background:var(--bg3);white-space:nowrap}
.pto-reg-file:hover{border-color:var(--accent)}
/* Вкладки проекта */
.pto-tabs{display:flex;gap:2px;border-bottom:2px solid var(--c);margin-bottom:12px}
.pto-tab{background:none;border:none;color:var(--text2);padding:8px 18px;cursor:pointer;font-size:12px;font-weight:600;letter-spacing:.5px;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s}
.pto-tab:hover{color:var(--text)}
.pto-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
/* Toast */
.pto-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--bg2);border:1px solid var(--accent);color:var(--text);padding:8px 18px;border-radius:6px;font-size:12px;z-index:9999;transition:opacity .3s;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.pto-loading{color:var(--text2);font-size:13px;padding:20px;text-align:center}
.pto-error{color:#f44336;font-size:13px;padding:12px}
/* Файлы в секциях */
.pto-section-files{padding:6px 12px 8px;display:flex;flex-wrap:wrap;gap:6px;border-top:1px solid var(--bg3)}
.pto-file-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--bg3);border:1px solid var(--c);border-radius:12px;cursor:pointer;font-size:11px;color:var(--text);transition:border-color .2s,color .2s;max-width:240px;overflow:hidden}
.pto-file-chip:hover{border-color:var(--accent);color:var(--accent)}
.pto-file-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

