  /* только кабинет-специфичные стили; темы/токены/кнопки — в centuro-ui.css */
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{height:100%}
  body{font-family:var(--font);background:var(--bg);color:var(--text);
    display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;-webkit-font-smoothing:antialiased}
  .logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--accent),var(--accent-dark));
    display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--on-accent);font-size:18px;flex-shrink:0}
  .hidden{display:none!important}
  .full{width:100%;margin-top:14px}

  /* login */
  .card{width:100%;max-width:400px;background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:36px 30px;box-shadow:var(--shadow-lg)}
  .brand{display:flex;align-items:center;gap:11px}
  .brand h1{font-size:var(--fs-2xl);font-weight:700;letter-spacing:-.5px}
  .tag{color:var(--muted);font-size:var(--fs-sm);line-height:1.55;margin:12px 0 26px}
  label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:7px}
  input[type=email],input[type=text]{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);
    padding:12px 14px;color:var(--text);font-size:15px;font-family:inherit;outline:none;transition:border-color var(--t)}
  input:focus{border-color:var(--accent)}
  .msg{margin-top:16px;font-size:var(--fs-sm);line-height:1.5;padding:12px 14px;border-radius:var(--r-md);display:none}
  .msg.show{display:block}
  .msg.ok{background:var(--user-bg);border:1px solid var(--accent);color:var(--text)}
  .msg.err{background:rgba(239,68,68,.12);border:1px solid #ef4444;color:#ef6464}
  .foot{margin-top:22px;font-size:var(--fs-xs);color:var(--muted);text-align:center;line-height:1.5}
  .legal{margin-top:12px;font-size:var(--fs-xs);text-align:center}
  .legal a{color:var(--muted);text-decoration:none}
  .legal a:hover{color:var(--text)}
  /* вход по коду из письма (нужно для установленного приложения на iOS) */
  .otp-step{margin-top:14px}
  #otp{text-align:center;letter-spacing:.3em;font-weight:700;font-size:20px}
  .linkbtn{display:block;width:100%;margin-top:12px;background:none;border:none;color:var(--muted);font-family:inherit;font-size:var(--fs-sm);cursor:pointer;text-align:center}
  .linkbtn:hover{color:var(--text)}

  /* workspace */
  #app{position:fixed;inset:0;display:none;grid-template-columns:var(--sidew,248px) 1fr}
  #app.show{display:grid}
  .side{position:relative;background:var(--side-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 12px calc(14px + env(safe-area-inset-bottom));min-width:0}
  .side .brand{margin:6px 6px 32px}
  .resizer{position:absolute;top:0;right:-3px;width:6px;height:100%;cursor:col-resize;z-index:30}
  .resizer:hover{background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.5}
  .navgroup{margin-bottom:32px}          /* раздел «действия» — отделён воздухом от поиска и списка */
  .newbtn{width:100%;text-align:left;font-weight:600;font-size:var(--fs-md);padding:11px 13px;margin-bottom:6px}
  .searchbox{position:relative;margin-bottom:8px}  /* поиск стоит вплотную над списком диалогов */
  .searchbox .search-ic{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
  .searchbox .search{width:100%;background:var(--side-field-bg);border:1px solid var(--border);border-radius:var(--r-sm);padding:6px 10px 6px 31px;color:var(--text);font-size:var(--fs-sm);font-family:inherit;outline:none}
  .searchbox .search::placeholder{color:var(--muted)}
  .searchbox .search:focus{border-color:var(--accent)}
  .searchbox:focus-within .search-ic{color:var(--accent)}
  .chatlist{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1px;margin:0 -4px;padding:0 4px;min-height:0}
  .chatlist .grp{font-size:10.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);padding:12px 10px 5px}
  .chatlist .item{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:var(--r-sm);cursor:pointer;color:var(--text);font-size:var(--fs-sm);transition:background var(--t-fast)}
  .chatlist .item:hover,.chatlist .item.active{background:var(--user-bg)}
  .chatlist .item .t{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .chatlist .item .del,.chatlist .item .edit{opacity:0;border:none;background:transparent;color:var(--muted);cursor:pointer;line-height:1;padding:0 2px;flex-shrink:0;display:flex;align-items:center}
  .chatlist .item .del{font-size:16px}
  .chatlist .item:hover .del,.chatlist .item:hover .edit{opacity:.55}
  .chatlist .item .del:hover,.chatlist .item .edit:hover{opacity:1;color:var(--text)}
  .chatlist .item input.rename{flex:1;background:var(--side-field-bg);border:1px solid var(--accent);border-radius:7px;color:var(--text);font:inherit;font-size:var(--fs-sm);padding:0 8px;outline:none;min-width:0;height:26px;box-sizing:border-box}
  /* кнопки подтверждения Да/Нет — контурные пилюли в стиле переключателя языков (.lg), общие для чатов и отчётов */
  .cbtn{border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:7px;padding:0 10px;font-size:12px;font-weight:600;letter-spacing:.3px;cursor:pointer;font-family:inherit;flex-shrink:0;height:26px;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;transition:background var(--t),color var(--t),border-color var(--t)}
  .cbtn:hover{color:var(--text);border-color:var(--accent)}
  .cbtn.yes:hover{color:#ef6464;border-color:#ef6464}   /* «Да» — красный акцент: действие необратимо */
  .chatlist .ph{color:var(--muted);font-size:12px;padding:12px 10px;line-height:1.5}

  .profilebtn{display:flex;align-items:center;gap:9px;border:1px solid var(--border);background:transparent;border-radius:var(--r-md);padding:8px 10px;cursor:pointer;width:100%;color:var(--text);transition:background var(--t);margin-top:8px;font-family:inherit}
  .profilebtn:hover{background:var(--user-bg)}
  .avatar{width:26px;height:26px;border-radius:7px;background:var(--accent);color:var(--on-accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fs-sm);flex-shrink:0}
  .pname{flex:1;text-align:left;font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .gear{color:var(--muted);flex-shrink:0}
  .settings{position:fixed;left:10px;bottom:calc(64px + env(safe-area-inset-bottom));width:calc(var(--sidew, 248px) - 20px);background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:8px;z-index:60;display:flex;flex-direction:column;gap:2px;box-shadow:var(--shadow-sm)}
  .settings.hidden{display:none}
  .set-sep{height:1px;background:var(--border);margin:6px 4px}
  .set-item{width:100%;border-radius:var(--r-sm);padding:9px 10px;display:flex;align-items:center;gap:9px;font-size:var(--fs-sm)}
  .set-item svg{opacity:.8;flex-shrink:0}

  .main{display:flex;flex-direction:column;overflow:hidden;min-width:0}
  .topbar{height:56px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 20px;flex-shrink:0}
  .burger{display:none;border:none;background:transparent;color:var(--muted);cursor:pointer;padding:4px;border-radius:7px}
  .burger:hover{background:var(--user-bg);color:var(--text)}
  #topTitle{font-size:var(--fs-md);font-weight:600;color:var(--muted)}
  .status{margin-left:auto;display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:5px 12px;cursor:default;white-space:nowrap;max-width:50%;overflow:hidden;text-overflow:ellipsis}
  .status::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--muted);flex-shrink:0}
  .status.on::before{background:#22c55e}
  .status:not(.on){cursor:pointer}
  .status:not(.on):hover{border-color:var(--accent);color:var(--text)}

  iframe.assistant{flex:1;width:100%;border:0;display:block;background:var(--bg)}
  .afb{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}
  .afb-card{text-align:center;max-width:420px}
  .afb-ic{font-size:40px;margin-bottom:16px}
  .afb h2{font-size:var(--fs-xl);font-weight:700;letter-spacing:-.3px;margin-bottom:10px}
  .afb p{color:var(--muted);font-size:var(--fs-md);line-height:1.6;margin-bottom:22px}

  .pad{flex:1;overflow-y:auto;padding:44px 26px calc(44px + env(safe-area-inset-bottom))}
  .pad .wrap{max-width:560px;margin:0 auto}
  .pad .wrap.wide{max-width:760px}
  /* галерея графиков (вкладка «Графики») */
  .chartgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:12px}
  .chartcard{display:flex;flex-direction:column;gap:7px;text-align:left;border:1px solid var(--border);background:var(--card);border-radius:var(--r-md);padding:15px 16px;cursor:pointer;color:var(--text);font-family:inherit;transition:border-color var(--t),background var(--t)}
  .chartcard:hover{border-color:var(--accent);background:var(--user-bg)}
  .chartcard .ch-top{display:flex;align-items:center;gap:9px}
  .chartcard .ch-ic{display:flex;color:var(--accent);flex-shrink:0}
  .chartcard .ch-name{font-size:var(--fs-md);font-weight:600}
  .chartcard .ch-desc{font-size:12.5px;color:var(--muted);line-height:1.45}
  .pad h2{font-size:var(--fs-xl);font-weight:700;letter-spacing:-.3px;margin-bottom:8px}
  .pad .sub{color:var(--muted);font-size:var(--fs-md);line-height:1.6;margin-bottom:26px}
  .field{margin-bottom:8px}
  .pz-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 0;border-bottom:1px solid var(--border)}
  .pz-row:last-child{border-bottom:none}
  .pz-label{font-size:var(--fs-md);font-weight:500;color:var(--text)}
  .swatches{display:flex;gap:9px}
  .sw{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;transition:transform var(--t-fast);box-shadow:inset 0 0 0 1px rgba(0,0,0,.18)}
  .sw:hover{transform:scale(1.12)}
  .sw.active{border-color:var(--text)}
  .sw[data-theme=blue]{background:#2563EB}.sw[data-theme=graphite]{background:#B08968}
  .sw[data-theme=forest]{background:#15803D}.sw[data-theme=dark]{background:#1A1F27}.sw[data-theme=retro]{background:#2BE85F}
  .langs{display:flex;gap:6px}
  .lg{border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:7px;padding:4px 11px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;letter-spacing:.3px;transition:background var(--t),color var(--t),border-color var(--t)}
  .lg:hover{color:var(--text);border-color:var(--accent)}
  .lg.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}

  /* ===== отчёты ===== */
  .navlink{width:100%;text-align:left;display:flex;align-items:center;gap:9px;border:none;background:transparent;color:var(--text);border-radius:var(--r-sm);padding:9px 11px;cursor:pointer;font-family:inherit;font-size:var(--fs-sm);font-weight:500;transition:background var(--t-fast)}
  .navlink + .navlink{margin-top:2px}   /* лёгкий зазор между пунктами меню (как между диалогами) */
  .navlink svg{opacity:.7;flex-shrink:0}
  .navlink:hover,.navlink.active{background:var(--user-bg)}
  .rep-sec{margin-bottom:30px}
  .rep-seclabel{font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);margin:0 0 12px}
  .rep-sechead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
  .rep-sechead .rep-seclabel{margin:0}
  .rep-sechead .btn{padding:6px 12px;font-size:13px}
  .rep-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .rep-card{text-align:left;border:1px solid var(--border);background:var(--card);border-radius:var(--r-md);padding:13px 14px;cursor:pointer;color:var(--text);font-family:inherit;font-size:var(--fs-sm);font-weight:500;line-height:1.4;transition:border-color var(--t),background var(--t)}
  .rep-card:hover{border-color:var(--accent);background:var(--user-bg)}
  .rep-list{display:flex;flex-direction:column;gap:6px}
  .rep-item{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:var(--r-md);padding:11px 13px;cursor:pointer;transition:border-color var(--t),background var(--t)}
  .rep-item:hover{border-color:var(--accent);background:var(--user-bg)}
  .rep-meta{flex:1;min-width:0}
  .rep-name{font-size:var(--fs-sm);font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .rep-prev{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}
  .rep-act{opacity:0;border:none;background:transparent;color:var(--muted);cursor:pointer;padding:3px;border-radius:6px;flex-shrink:0;display:flex;line-height:1;font-family:inherit}
  .rep-item:hover .rep-act{opacity:.55}
  .rep-act:hover{opacity:1!important;color:var(--text);background:var(--card)}
  .rep-act.del-x{font-size:17px;align-items:center;justify-content:center;width:23px;height:23px}
  .rep-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
  .rep-cflabel{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.2px}
  .rep-empty{color:var(--muted);font-size:12.5px;line-height:1.5;padding:6px 2px}
  .rep-form{border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin-top:12px;background:var(--card)}
  .rep-form.hidden{display:none}
  .rep-form input,.rep-form textarea{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 11px;color:var(--text);font-family:inherit;font-size:var(--fs-sm);outline:none;margin-bottom:9px;box-sizing:border-box}
  .rep-form input:focus,.rep-form textarea:focus{border-color:var(--accent)}
  .rep-form textarea{resize:vertical;min-height:92px;line-height:1.5}
  .rep-form-actions{display:flex;gap:8px;justify-content:flex-end}

  #backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:40;display:none}
  #backdrop.show{display:block}

  /* мобилка: сайдбар — выезжающий drawer */
  @media(max-width:760px){
    #app{grid-template-columns:1fr}
    .side{position:fixed;left:0;top:0;height:100%;width:268px;transform:translateX(-100%);transition:transform .2s ease;z-index:50;box-shadow:var(--shadow-lg)}
    .side.open{transform:none}
    .resizer{display:none}
    .burger{display:flex}
    .settings{width:248px}
    .pad{padding:28px 18px calc(28px + env(safe-area-inset-bottom))}
    .rep-grid{grid-template-columns:1fr}
  }
  @media(min-width:761px){ #backdrop{display:none!important} }
