:root{
  --bg:#0f1115; --panel:#161a21; --panel2:#1d222b; --line:#262c37;
  --me:#2b5278; --kirby:#20262f; --txt:#e6e9ef; --dim:#8b93a1; --accent:#4a90d9;
  /* код всегда на тёмном фоне (в обеих темах) → цвета фиксированы, НЕ наследуют --txt/--bg */
  --code-bg:#0c0e12; --code-fg:#e6e9ef; --code-head:#12151b;
  --rec:#e07b2c;   /* запись аудио — спокойный оранжевый (не агрессивно-красный) */
}
*{box-sizing:border-box}
/* Фиксируем область под видимый вьюпорт: НЕ скроллим весь WebView (баг 100vh в PWA на Android). */
html,body{margin:0;height:100%;overflow:hidden;overscroll-behavior:none}
body{background:var(--bg);color:var(--txt);font:16px/1.45 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  -webkit-text-size-adjust:100%}
.hidden{display:none!important}

/* login */
#login{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px}
#login-form{width:100%;max-width:320px;display:flex;flex-direction:column;gap:12px}
#login-form h1{text-align:center;margin:0 0 8px;font-weight:600}
#login-form input{background:var(--panel);border:1px solid var(--line);color:var(--txt);
  padding:12px 14px;border-radius:10px;font-size:16px;outline:none}
#login-form input:focus{border-color:var(--accent)}
#login-form button{background:var(--accent);color:#fff;border:0;padding:12px;border-radius:10px;font-size:16px;cursor:pointer}
.err{color:#e06c6c;font-size:14px;min-height:18px;text-align:center}

/* chat — фиксированный контейнер на весь видимый вьюпорт; скроллит только лента */
#chat{position:fixed;inset:0;display:flex;flex-direction:column}
#chat header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:calc(10px + env(safe-area-inset-top)) 14px 10px;background:var(--panel);border-bottom:1px solid var(--line)}
#chat header .title{font-weight:600}
#chat header #logout{background:none;border:0;color:var(--dim);cursor:pointer;font-size:14px}
#messages{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  padding:14px;display:flex;flex-direction:column;gap:8px}
#chat footer{flex:0 0 auto}
.msg{max-width:86%;padding:8px 12px;border-radius:14px;word-wrap:break-word;white-space:pre-wrap}
.msg.user{align-self:flex-end;background:var(--me);border-bottom-right-radius:4px}
.msg.assistant{align-self:flex-start;background:var(--kirby);border:1px solid var(--line);border-bottom-left-radius:4px;white-space:normal}
.msg .meta{display:block;font-size:11px;color:var(--dim);margin-top:4px}
.msg.assistant a{color:var(--accent)}
.msg.assistant pre{white-space:pre-wrap;background:var(--code-bg);color:var(--code-fg);border:1px solid var(--line);padding:8px;border-radius:8px;overflow-x:auto;font-size:13px}
.msg.assistant code{background:var(--code-bg);color:var(--code-fg);padding:1px 5px;border-radius:5px;font-size:13px}

#chat footer{display:flex;align-items:flex-end;gap:8px;padding:10px;background:var(--panel);border-top:1px solid var(--line);
  padding-bottom:calc(10px + env(safe-area-inset-bottom))}
/* line-height 22 → одна строка = 22 + паддинги 10+10 + бордер 2 = 44px, ровно как кнопки (не выше) */
#input{flex:1;resize:none;max-height:140px;background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  padding:10px 12px;border-radius:12px;font-size:16px;line-height:22px;outline:none}
#input:focus{border-color:var(--accent)}
/* общее правило — только геометрия (иначе его bg/border перебивал бы по специфичности
   #mic/#attach → они ошибочно красились в accent). Цвет заливки — только у #send. */
#chat footer button{width:44px;height:44px;border-radius:12px;font-size:18px;cursor:pointer;flex:0 0 auto}
#send{background:var(--accent);color:#fff;border:0}
#mic{background:var(--panel2);border:1px solid var(--line)}
#mic.rec{background:var(--rec);border-color:var(--rec);color:#fff}

/* панель записи полностью перекрывает футер (44px кнопка + 10+10 паддинги + 1px бордер) → без зазора */
#rec-bar{position:fixed;left:0;right:0;bottom:0;background:var(--rec);color:#fff;padding:10px 14px;
  padding-bottom:calc(10px + env(safe-area-inset-bottom));min-height:calc(65px + env(safe-area-inset-bottom));
  display:flex;align-items:center;gap:10px;font-size:14px}
#rec-bar button{background:rgba(255,255,255,.2);border:0;color:#fff;padding:6px 10px;border-radius:8px;cursor:pointer}

/* --- код: инлайн-копирование + блоки с шапкой --- */
.msg.assistant code.inline{cursor:pointer;position:relative}
.msg.assistant code.inline:hover{outline:1px solid var(--accent)}
.codewrap{margin:8px 0;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--code-bg);color:var(--code-fg)}
.codewrap .codehead{display:flex;justify-content:space-between;align-items:center;
  background:var(--code-head);border-bottom:1px solid var(--line);padding:4px 10px;font-size:12px;color:#8b93a1}
.codewrap .codehead button{background:#1d222b;border:1px solid var(--line);color:#e6e9ef;
  padding:2px 8px;border-radius:6px;font-size:12px;cursor:pointer}
.codewrap pre{margin:0;border:0;border-radius:0;background:transparent}
.copied{color:#5fd07a!important}
/* подсветка (встроенная, минималистичная) */
.hl-str{color:#9ece6a}.hl-num{color:#ff9e64}.hl-com{color:#5c6370;font-style:italic}.hl-kw{color:#7aa2f7}.hl-fn{color:#e0af68}

/* --- вложения (md-файлы) --- */
.attns{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.attn{display:inline-flex;align-items:center;gap:8px;background:var(--panel2);border:1px solid var(--line);
  border-radius:10px;padding:6px 10px;font-size:13px}
.attn .nm{color:var(--txt)}
.attn a,.attn button{background:none;border:0;color:var(--accent);cursor:pointer;font-size:13px;padding:0}

/* --- модалка предпросмотра md --- */
#preview{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}
#preview .pv-box{background:var(--panel);border:1px solid var(--line);border-radius:12px;width:100%;max-width:820px;
  max-height:88dvh;display:flex;flex-direction:column;overflow:hidden}
#preview .pv-head{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--line)}
#preview .pv-head #pv-title{font-weight:600;font-size:14px}
#preview .pv-actions{display:flex;gap:12px;align-items:center}
#preview .pv-actions a{color:var(--accent);text-decoration:none;font-size:14px}
#preview .pv-actions button{background:none;border:0;color:var(--dim);font-size:16px;cursor:pointer}
#pv-body{overflow-y:auto;padding:16px 18px}

/* рендер markdown */
.md{line-height:1.5}
.md h1,.md h2,.md h3{margin:.7em 0 .3em;line-height:1.25}
.md h1{font-size:1.5em}.md h2{font-size:1.3em}.md h3{font-size:1.12em}
.md p{margin:.5em 0}.md ul,.md ol{margin:.4em 0 .4em 1.3em}.md li{margin:.15em 0}
.md a{color:var(--accent)}
.md code{background:var(--code-bg);color:var(--code-fg);padding:1px 5px;border-radius:5px;font-size:13px}
.md pre{background:var(--code-bg);color:var(--code-fg);border:1px solid var(--line);padding:10px;border-radius:8px;overflow-x:auto}
.md pre code{background:transparent;padding:0}
.md blockquote{border-left:3px solid var(--line);margin:.5em 0;padding:.1em .9em;color:var(--dim)}
.md hr{border:0;border-top:1px solid var(--line);margin:1em 0}
.md table{border-collapse:collapse;margin:.6em 0;display:block;overflow-x:auto}
.md th,.md td{border:1px solid var(--line);padding:5px 9px;font-size:14px}
.md th{background:var(--panel2)}

/* --- шапка: аватар + спиннер «печатает» + команды --- */
#chat header{gap:10px}
.avatar-wrap{position:relative;width:34px;height:34px;flex:0 0 auto}
#avatar{width:34px;height:34px;border-radius:50%;display:block}
.avatar-wrap .ring{position:absolute;inset:-3px;border-radius:50%;border:2px solid transparent;pointer-events:none}
.avatar-wrap.pending .ring{border-top-color:var(--accent);border-right-color:var(--accent);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
#typing{color:var(--dim);font-size:13px;font-style:italic}
#chat header .spacer{flex:1}
#chat header #cmd-toggle{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  width:34px;height:30px;border-radius:8px;cursor:pointer;font-size:14px}
#cmdbar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;background:var(--panel);border-bottom:1px solid var(--line)}
#cmdbar button{background:var(--panel2);border:1px solid var(--line);color:var(--txt);padding:6px 10px;border-radius:8px;font-size:13px;cursor:pointer}

/* --- аудио в сообщении --- */
.msg audio{display:block;margin-top:6px;max-width:260px;height:34px}

/* --- индикатор «сообщение ушло / ассистент думает»: три точки внизу ленты --- */
.msg.dots{display:flex;gap:6px;align-items:center;width:max-content;padding:14px}
.msg.dots span{width:8px;height:8px;border-radius:50%;background:var(--dim);animation:dotpulse 1.4s infinite both}
.msg.dots span:nth-child(2){animation-delay:.18s}
.msg.dots span:nth-child(3){animation-delay:.36s}
@keyframes dotpulse{0%,70%,100%{opacity:.3;transform:translateY(0)}35%{opacity:1;transform:translateY(-3px)}}

/* --- прикрепление файла (превью до отправки) --- */
#att-pending{padding:6px 12px;display:flex;flex-wrap:wrap;gap:6px}
#att-pending .chip{display:inline-flex;align-items:center;gap:8px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:5px 10px;font-size:13px}
#att-pending .chip button{background:none;border:0;color:#e06c6c;cursor:pointer;font-size:14px}
#attach{background:var(--panel2);border:1px solid var(--line)}
#chat.dragover #messages{outline:2px dashed var(--accent);outline-offset:-6px}

/* --- широкий монитор (3440x1440): узкие сообщения слева, широкий контейнер --- */
@media (min-width:900px){
  #messages{max-width:1800px;margin-right:auto;width:100%}
  #att-pending,#cmdbar{max-width:1800px}
  .msg{max-width:800px}
  /* исключение: блоки кода/таблицы/предпросмотр — шире */
  .msg:has(.codewrap),.msg:has(pre),.msg:has(table){max-width:min(1400px,95%)}
}
/* мобильная верстка: кнопки не жмутся, безопасные отступы */
@media (max-width:640px){
  #chat header #cmd-toggle,#chat header #logout{padding:0 8px}
  .msg{max-width:90%}
  #input{font-size:16px}
}

/* --- вложения: метаданные, миниатюры картинок, превью --- */
.attn .fmeta{display:flex;flex-direction:column;gap:1px}
.attn .fmeta .nm{color:var(--txt)}
.attn .fmeta .mt{color:var(--dim);font-size:11px}
.attn.img{flex-direction:column;align-items:flex-start;gap:6px;max-width:240px}
.attn.img .thumb{max-width:220px;max-height:220px;border-radius:8px;cursor:zoom-in;display:block}
#pv-body .pv-img{max-width:100%;max-height:80dvh;display:block;margin:0 auto;border-radius:6px}

/* --- кнопка темы (как cmd-toggle) --- */
#chat header #theme-toggle{background:var(--panel2);border:1px solid var(--line);color:var(--txt);
  width:34px;height:30px;border-radius:8px;cursor:pointer;font-size:14px}

/* --- спиннер заметнее (3px арка) --- */
.avatar-wrap .ring{inset:-3px;border-width:3px}
.avatar-wrap.pending .ring{animation-duration:.7s}

/* --- СВЕТЛАЯ ТЕМА (toggle) --- */
body.light{
  --bg:#eef1f5; --panel:#ffffff; --panel2:#f2f5f9; --line:#d8dee7;
  --txt:#1a1d22; --dim:#69727f; --me:#d3e6fb; --kirby:#f5f7fa; --accent:#2f6fd0;
}
/* светлая тема: кнопка отправки — мягкая заливка + акцентная граница вместо сплошного
   яркого синего (по просьбе владельца: выбивается; делаем спокойнее, акцент на границе).
   #mic/#attach не трогаем — они уже нейтральные (panel2); логин-кнопку оставляем яркой. */
body.light #send{ background:#e8f0fb; color:var(--accent); border:1px solid var(--accent); }
body.light #send:active{ background:#d8e6f8; }
/* блоки кода остаются тёмными в обеих темах (намеренно): фон/текст берутся из
   фиксированных --code-bg/--code-fg (см. :root), НЕ из --bg/--txt — иначе в светлой
   теме получался бы чёрный текст на чёрном фоне. body.light их не переопределяет. */
