/* Kiro Mobile v3 - Interface estilo ChatGPT */

:root,[data-theme="dark"]{
    --bg:#212121;--bg2:#171717;--bg3:#2f2f2f;--bg4:#3a3a3a;
    --tx:#ececec;--tx2:#b4b4b4;--tx3:#7a7a7a;
    --green:#10a37f;--green2:#0d8c6d;--red:#ef4444;
    --brd:#3e3e3e;--sh:0 2px 8px rgba(0,0,0,.3);
}
[data-theme="light"]{
    --bg:#ffffff;--bg2:#f9f9f9;--bg3:#f0f0f0;--bg4:#e5e5e5;
    --tx:#1a1a1a;--tx2:#6b6b6b;--tx3:#999;
    --green:#10a37f;--green2:#0d8c6d;--red:#ef4444;
    --brd:#e5e5e5;--sh:0 2px 8px rgba(0,0,0,.06);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--tx);transition:background .3s,color .3s}
.screen{display:none;width:100%;height:100%}.screen.active{display:flex}

/* ── Login ── */
#screen-connect{align-items:center;justify-content:center;padding:24px}
.login-page{width:100%;max-width:360px;text-align:center}
.login-logo{margin-bottom:32px}
.logo-mark{width:52px;height:52px;border-radius:50%;background:var(--green);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:14px}
.login-logo h1{font-size:22px;font-weight:600}
.login-form{display:flex;flex-direction:column;gap:10px}
.login-row{display:flex;gap:10px}
.login-row input{flex:1}
.login-form input{width:100%;background:var(--bg3);border:1px solid var(--brd);border-radius:10px;padding:13px 16px;color:var(--tx);font-size:15px;outline:none;transition:border .2s}
.login-form input:focus{border-color:var(--green)}
.login-form input::placeholder{color:var(--tx3)}
.btn-green{width:100%;background:var(--green);color:#fff;border:none;border-radius:10px;padding:14px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:4px}
.btn-green:hover{background:var(--green2)}.btn-green:active{transform:scale(.98)}.btn-green:disabled{opacity:.5}
.login-status{margin-top:14px;font-size:13px;min-height:18px}
.login-status.error{color:var(--red)}.login-status.ok{color:var(--green)}.login-status.info{color:var(--tx2)}

/* ── Main Layout ── */
#screen-main{flex-direction:row}
#vnc-hidden{position:fixed;top:-9999px;left:-9999px;width:1920px;height:1080px;overflow:hidden;pointer-events:none}
.content{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden}

/* ── Sidebar ── */
.sidebar{position:fixed;top:0;left:0;bottom:0;width:270px;background:var(--bg2);z-index:200;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .3s;border-right:1px solid var(--brd)}
.sidebar.open{transform:translateX(0)}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150}.overlay.hidden{display:none}
.sb-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--brd)}
.sb-brand{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}.sb-brand i{color:var(--green)}
.sb-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px}
.sb-link{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:none;color:var(--tx2);font-size:14px;border-radius:8px;cursor:pointer;transition:all .15s;text-align:left}
.sb-link:hover,.sb-link.active{background:var(--bg4);color:var(--tx)}
.sb-link i{width:18px;text-align:center;font-size:14px}
.sb-danger{color:var(--red)}.sb-danger:hover{background:rgba(239,68,68,.1)}
.sb-footer{padding:8px;border-top:1px solid var(--brd);display:flex;flex-direction:column;gap:2px}

/* ── Topbar ── */
.topbar{height:50px;display:flex;align-items:center;padding:0 8px;border-bottom:1px solid var(--brd);flex-shrink:0;gap:8px}
.topbar-title{flex:1;text-align:center;font-size:15px;font-weight:600}
.btn-icon{width:40px;height:40px;border:none;background:none;color:var(--tx2);font-size:17px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.btn-icon:hover{background:var(--bg3);color:var(--tx)}

/* ── Tabs ── */
.tab{display:none;flex:1;flex-direction:column;overflow:hidden}.tab.active{display:flex}
.tab-scroll{flex:1;overflow-y:auto;padding:20px 16px;-webkit-overflow-scrolling:touch}
.section-title{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);font-weight:600;margin-bottom:12px}

/* ── Chat ── */
.chat-area{flex:1;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch}
.chat-welcome{text-align:center;padding:40px 20px}
.welcome-icon{width:48px;height:48px;border-radius:50%;background:var(--green);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px}
.chat-welcome h2{font-size:20px;font-weight:600;margin-bottom:6px}
.chat-welcome p{color:var(--tx2);font-size:14px}
#chat-messages{display:flex;flex-direction:column;gap:12px;padding-bottom:8px}
.chat-msg{display:flex}.chat-msg.user{justify-content:flex-end}.chat-msg.system{justify-content:flex-start}
.msg-bubble{max-width:85%;padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.5;word-wrap:break-word}
.user-bubble{background:var(--green);color:#fff;border-bottom-right-radius:4px}
.sys-bubble{background:var(--bg3);color:var(--tx);border-bottom-left-radius:4px;display:flex;align-items:flex-start;gap:8px}
.sys-bubble i{color:var(--green);margin-top:3px;font-size:12px;flex-shrink:0}

.chat-input-area{padding:8px 12px 12px;border-top:1px solid var(--brd);background:var(--bg)}
.input-bar{display:flex;align-items:center;gap:6px;background:var(--bg3);border:1px solid var(--brd);border-radius:24px;padding:4px 6px}
.input-bar input{flex:1;background:none;border:none;color:var(--tx);font-size:15px;padding:8px 6px;outline:none}
.input-bar input::placeholder{color:var(--tx3)}
.mic-btn{color:var(--tx3)}.mic-btn.on{color:var(--red);animation:pulse 1.5s ease infinite}
.send-btn{background:var(--green);color:#fff;border-radius:50%;width:34px;height:34px;font-size:14px}
.input-hint{text-align:center;font-size:11px;color:var(--tx3);margin-top:6px}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.3)}50%{box-shadow:0 0 0 8px rgba(239,68,68,0)}}

/* ── Actions Grid ── */
.grid-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.grid-actions.cols-2{grid-template-columns:repeat(2,1fr)}
.action-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;background:var(--bg3);border:1px solid var(--brd);border-radius:12px;color:var(--tx);font-size:12px;cursor:pointer;transition:all .15s}
.action-btn:hover{border-color:var(--green);background:var(--bg4)}
.action-btn:active{transform:scale(.96)}
.action-btn i{font-size:18px;color:var(--green)}
.action-btn span{text-align:center;line-height:1.3}
.action-btn.wide{flex-direction:row;gap:10px;padding:14px 16px;font-size:14px}

/* ── Files ── */
.file-list{display:flex;flex-direction:column;gap:8px}
.file-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg3);border:1px solid var(--brd);border-radius:12px}
.file-item i{font-size:20px;color:var(--green)}
.file-item strong{display:block;font-size:14px;margin-bottom:2px}
.file-item small{color:var(--tx3);font-size:12px}
.hint-text{color:var(--tx2);font-size:13px;line-height:1.6}

/* ── Desktop Tab ── */
#desktop-view{flex:1;background:#000;overflow:hidden}
#desktop-view #vnc-screen{width:100%;height:100%}
#desktop-view #vnc-screen canvas{width:100%!important;height:100%!important;object-fit:contain}

/* ── Bottom Sheets ── */
.bsheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1px solid var(--brd);border-radius:20px 20px 0 0;z-index:300;padding:8px 16px 24px;box-shadow:0 -4px 20px rgba(0,0,0,.3);transition:transform .3s;max-height:65vh;overflow-y:auto}
.bsheet.hidden{transform:translateY(100%);pointer-events:none}
.bsheet-bar{width:32px;height:4px;background:var(--brd);border-radius:2px;margin:4px auto 12px}
.bsheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;font-size:14px;color:var(--tx2)}
.voice-center{display:flex;justify-content:center;padding:14px 0}
.voice-dot{width:68px;height:68px;border-radius:50%;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--tx3);cursor:pointer;transition:all .3s}
.voice-dot.on{background:var(--red);color:#fff;animation:pulse-dot 1.5s ease infinite}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{box-shadow:0 0 0 14px rgba(239,68,68,0)}}
.transcript-box{background:var(--bg);border:1px solid var(--brd);border-radius:10px;padding:12px;min-height:44px;max-height:90px;overflow-y:auto;margin-bottom:10px}
.transcript-box p{font-size:14px;line-height:1.5}.transcript-box .muted{color:var(--tx3);font-style:italic}
.bsheet-btns{display:flex;gap:8px;margin-bottom:10px}
.pill{flex:1;padding:10px;border-radius:20px;border:1px solid var(--brd);background:var(--bg3);color:var(--tx2);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}
.pill:active{transform:scale(.97)}.pill:disabled{opacity:.4}
.pill.green{background:var(--green);color:#fff;border-color:var(--green)}
.bsheet-opts{display:flex;align-items:center;justify-content:space-between;padding-top:8px;border-top:1px solid var(--brd);font-size:12px;color:var(--tx3)}
.bsheet-opts label{display:flex;align-items:center;gap:6px;cursor:pointer}
.bsheet-opts select{background:var(--bg3);border:1px solid var(--brd);border-radius:6px;color:var(--tx);padding:4px 8px;font-size:12px}
.tts-box{width:100%;min-height:70px;background:var(--bg);border:1px solid var(--brd);border-radius:10px;padding:12px;color:var(--tx);font-size:14px;resize:vertical;outline:none;margin-bottom:10px;font-family:inherit}
.tts-box:focus{border-color:var(--green)}

/* ── Responsive ── */
@media(max-width:380px){.grid-actions{grid-template-columns:repeat(2,1fr)}.login-page{padding:0 4px}}
@media(min-width:768px){.sidebar{width:300px}.grid-actions{grid-template-columns:repeat(4,1fr)}}
@media(display-mode:standalone){.topbar{padding-top:env(safe-area-inset-top);height:calc(50px + env(safe-area-inset-top))}.chat-input-area{padding-bottom:calc(12px + env(safe-area-inset-bottom))}}

/* ── Typing Indicator ── */
.typing{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:13px;color:var(--tx3)}
.typing.hidden{display:none}
.typing-dots{display:flex;gap:4px}
.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--tx3);animation:blink 1.4s infinite both}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,80%,100%{opacity:.3}40%{opacity:1}}

/* ── Project Badge ── */
.topbar-badge{font-size:11px;background:var(--green);color:#fff;padding:3px 8px;border-radius:12px;font-weight:500}

/* ── Sidebar Select ── */
.sb-select{width:calc(100% - 16px);margin:0 8px;background:var(--bg3);border:1px solid var(--brd);border-radius:8px;color:var(--tx);padding:10px 12px;font-size:14px;outline:none}
.sb-select:focus{border-color:var(--green)}
.sb-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--tx3);font-weight:600;padding:4px 12px 6px}

/* ── Welcome Chips ── */
.welcome-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}
.chip-btn{background:var(--bg3);border:1px solid var(--brd);border-radius:20px;color:var(--tx2);padding:8px 14px;font-size:13px;cursor:pointer;transition:all .15s}
.chip-btn:hover{border-color:var(--green);color:var(--tx)}

/* ── Code in messages ── */
.msg-bubble code{background:var(--bg4);padding:1px 5px;border-radius:4px;font-size:13px;font-family:monospace}

/* ── Git Actions ── */
.git-actions{display:flex;gap:8px;margin-bottom:12px}
.git-btn{flex:1;padding:10px 12px;border:1px solid var(--brd);border-radius:10px;background:var(--bg3);color:var(--tx2);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}
.git-btn:active{transform:scale(.97)}
.git-btn.green-btn{background:var(--green);color:#fff;border-color:var(--green)}
.git-output{background:var(--bg3);border:1px solid var(--brd);border-radius:10px;padding:12px;font-size:13px;font-family:monospace;white-space:pre-wrap;color:var(--tx2);margin-bottom:12px;max-height:200px;overflow-y:auto}
.commit-row{display:flex;gap:8px;margin-bottom:12px}
.commit-row input{flex:1;background:var(--bg3);border:1px solid var(--brd);border-radius:10px;padding:10px 12px;color:var(--tx);font-size:13px;outline:none}
.commit-row input:focus{border-color:var(--green)}

/* ── Chat List (sidebar) ── */
.chat-list{display:flex;flex-direction:column;gap:2px;padding:0 4px}
.chat-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:none;color:var(--tx2);font-size:14px;border-radius:8px;cursor:pointer;transition:all .15s;text-align:left}
.chat-item:hover{background:var(--bg4);color:var(--tx)}
.chat-item.active{background:var(--green);color:#fff}
.chat-item i{font-size:14px;width:18px;text-align:center}
.sb-divider{height:1px;background:var(--brd);margin:8px 12px}

/* ── New Project ── */
.new-project-btn{width:100%;padding:10px;border:1px dashed var(--brd);border-radius:10px;background:none;color:var(--green);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:12px;transition:all .15s}
.new-project-btn:hover{background:var(--bg3);border-style:solid}

/* ── Delete button ── */
.del-btn{background:none;border:none;color:var(--tx3);font-size:14px;cursor:pointer;padding:6px;border-radius:6px;margin-left:auto;flex-shrink:0;transition:all .15s}
.del-btn:hover{color:var(--red);background:rgba(239,68,68,.1)}
.file-item{position:relative}

/* ── Response sizing fix ── */
.msg-bubble{max-width:90%;word-break:break-word;overflow-wrap:break-word}
.sys-bubble{font-size:14px;line-height:1.6}
.sys-bubble br+br{display:none}
#chat-messages{padding-bottom:16px}

/* ── Terminal ── */
.terminal-container{display:flex;flex-direction:column;height:100%;background:#0d0d0d}
.terminal-output{flex:1;overflow-y:auto;padding:12px;font-family:'Courier New',monospace;font-size:13px;color:#0f0;-webkit-overflow-scrolling:touch}
.term-line{margin-bottom:4px;white-space:pre-wrap;word-break:break-all}
.term-line.cmd{color:#0af}
.term-line.error{color:#f44}
.terminal-input-area{display:flex;align-items:center;gap:6px;padding:8px 12px;border-top:1px solid #333;background:#111}
.terminal-prompt{color:#0af;font-family:monospace;font-size:14px;font-weight:bold}
.terminal-input-area input{flex:1;background:none;border:none;color:#0f0;font-family:monospace;font-size:14px;outline:none}
.terminal-input-area input::placeholder{color:#555}
