/* ============================================================
   ИИ-Трансформатор — стиль
   Тёмная премиальная тема, фиолет/индиго, мобильный-first 380px,
   адаптив до десктопа (контейнер 480px по центру).
   В Telegram переменные --bg/--surface/--text/--dim переопределяются
   из themeParams (см. app.js).
   ============================================================ */

:root{
  --bg:#0a0a16;
  --bg-glow-1:#1c1740;
  --bg-glow-2:#101030;
  --surface:#16162c;
  --surface-2:#1e1e3a;
  --border:rgba(255,255,255,.08);
  --text:#edecfa;
  --dim:#9d9ac2;
  --accent:#7c6bff;
  --accent-2:#5a8bff;
  --danger:#ff5f7e;
  --ok:#4bd6a3;
  --radius:18px;
}
:root[data-scheme="light"]{
  --bg-glow-1:transparent;
  --bg-glow-2:transparent;
  --border:rgba(20,20,60,.12);
  --surface-2:rgba(20,20,60,.06);
}

*{box-sizing:border-box; -webkit-tap-highlight-color:transparent}
html,body{margin:0; height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  background:
    radial-gradient(90% 55% at 50% -8%, var(--bg-glow-1), transparent 62%),
    radial-gradient(80% 50% at 50% 112%, var(--bg-glow-2), transparent 62%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text);
  min-height:100dvh;
  -webkit-font-smoothing:antialiased;
}

#app{max-width:480px; margin:0 auto; min-height:100dvh; display:flex; flex-direction:column; position:relative}

.hidden{display:none!important}

.view{
  flex:1; display:flex; flex-direction:column;
  padding:calc(16px + env(safe-area-inset-top)) 20px calc(96px + env(safe-area-inset-bottom));
  animation:fadein .25s ease;
}
.view.center{align-items:center; justify-content:center; text-align:center}
@keyframes fadein{from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:none}}

.hint{color:var(--dim); font-size:14px; line-height:1.5; text-align:center; padding:14px 0}

/* ---------- мини-орб (лого/заглушки) ---------- */
.orb-mini{
  width:64px; height:64px; border-radius:50%; margin:0 auto;
  background:radial-gradient(circle at 50% 32%, #b9a4ff, var(--accent) 55%, #241b56 100%);
  box-shadow:0 0 34px rgba(124,107,255,.4);
}
.orb-mini.pulsing{animation:pulse-mini 1.6s infinite}
.orb-mini.calm{opacity:.75}
@keyframes pulse-mini{
  0%{box-shadow:0 0 0 0 rgba(124,107,255,.4)}
  70%{box-shadow:0 0 0 22px rgba(124,107,255,0)}
  100%{box-shadow:0 0 0 0 rgba(124,107,255,0)}
}

/* ---------- регистрация ---------- */
.auth-head{text-align:center; padding:14px 0 26px}
.auth-head h1{margin:16px 0 0; font-size:24px; letter-spacing:.2px}
.auth-head p{margin:6px 0 0; color:var(--dim); font-size:14px}

.field{margin-bottom:16px}
.field label{display:block; font-size:13px; color:var(--dim); margin-bottom:7px}
input[type="text"]{
  width:100%; background:var(--surface); border:1px solid var(--border); border-radius:14px;
  color:var(--text); font-size:16px; padding:14px 15px; -webkit-appearance:none; appearance:none;
}
input[type="text"]::placeholder{color:var(--dim); opacity:.7}
input[type="text"]:focus{outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(124,107,255,.18)}
.static-value{
  width:100%; background:var(--surface); border:1px solid var(--border); border-radius:14px;
  color:var(--dim); font-size:16px; padding:14px 15px;
}
.field-err{color:var(--danger); font-size:13px; min-height:17px; margin-top:6px}

.sec-title{font-size:13px; font-weight:600; color:var(--dim); text-transform:uppercase;
  letter-spacing:.8px; margin:22px 0 12px}

.q{margin-bottom:16px}
.q-text{margin:0 0 10px; font-size:15px; line-height:1.45}
.pills{display:flex; gap:10px}
.pill{
  flex:1; padding:13px; border-radius:14px; background:var(--surface); border:1px solid var(--border);
  color:var(--dim); font-size:15px; font-weight:600; font-family:inherit; cursor:pointer;
  transition:background .15s, border-color .15s, color .15s;
}
.pill.on{background:rgba(124,107,255,.18); border-color:var(--accent); color:var(--text)}

.check{display:flex; gap:12px; align-items:flex-start; margin:12px 0; font-size:14px;
  line-height:1.45; color:var(--text); cursor:pointer; position:relative}
.check input{position:absolute; opacity:0; pointer-events:none}
.check .box{
  flex:0 0 22px; width:22px; height:22px; border-radius:7px; border:1.5px solid var(--dim);
  margin-top:1px; position:relative; transition:background .15s, border-color .15s;
}
.check input:checked + .box{background:var(--accent); border-color:var(--accent)}
.check input:checked + .box::after{
  content:""; position:absolute; left:7px; top:3px; width:5px; height:10px;
  border:solid #fff; border-width:0 2px 2px 0; transform:rotate(45deg);
}

/* ---------- кнопки ---------- */
button{font-family:inherit; cursor:pointer}
.btn-primary{
  width:100%; border:none; border-radius:16px; padding:16px 24px; margin-top:20px;
  font-size:17px; font-weight:600; color:#fff;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow:0 6px 24px rgba(124,107,255,.35);
  transition:transform .1s, opacity .2s;
}
.btn-primary:active{transform:scale(.98)}
.btn-primary:disabled{opacity:.4; box-shadow:none; cursor:default}
.btn-ghost{
  width:100%; background:transparent; border:1px solid var(--border); border-radius:16px;
  padding:14px 24px; margin-top:12px; font-size:15px; font-weight:500; color:var(--dim);
  transition:transform .1s;
}
.btn-ghost:active{transform:scale(.98)}
.btn-ghost.danger{color:var(--danger); border-color:rgba(255,95,126,.35); margin-top:20px}

/* ---------- мягкий отказ ---------- */
.refusal{max-width:340px; margin:0 auto}
.refusal h1{font-size:22px; margin:22px 0 10px}
.refusal p{color:var(--dim); font-size:15px; line-height:1.55; margin:0 0 8px}

/* ---------- звонок ---------- */
.view.call{justify-content:space-between}
.call-head{text-align:center; padding:8px 0 4px}
.call-head h1{font-size:19px; font-weight:600; margin:0; letter-spacing:.2px}
.call-head p{margin:4px 0 0; color:var(--dim); font-size:13px}

.call-body{flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px; min-height:0}

.orb{
  width:200px; height:200px; border-radius:50%; position:relative; flex:0 0 auto;
  background:radial-gradient(circle at 50% 32%, #b9a4ff, var(--accent) 52%, #241b56 100%);
  box-shadow:0 0 60px rgba(124,107,255,.35), inset 0 0 44px rgba(255,255,255,.12);
  transition:transform .25s ease, opacity .3s ease, filter .3s ease;
}
.orb::after{content:""; position:absolute; inset:-16px; border-radius:50%; border:1px solid rgba(124,107,255,.22)}
.orb.idle{opacity:.5; filter:saturate(.55)}
.orb.listening{animation:pulse 1.6s infinite}
.orb.speaking{animation:speak .9s infinite}
.orb.thinking{animation:think 1.4s infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(124,107,255,.45), 0 0 60px rgba(124,107,255,.35)}
  70%{box-shadow:0 0 0 36px rgba(124,107,255,0), 0 0 60px rgba(124,107,255,.35)}
  100%{box-shadow:0 0 0 0 rgba(124,107,255,0), 0 0 60px rgba(124,107,255,.35)}
}
@keyframes speak{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
@keyframes think{0%,100%{opacity:.7}50%{opacity:1}}

.status{font-size:17px; min-height:23px; font-weight:500; text-align:center}
.substatus{font-size:13px; color:var(--dim); min-height:18px; text-align:center; margin-top:-12px; padding:0 10px}

.chips{display:flex; gap:8px; flex-wrap:wrap; justify-content:center}
.chip{
  background:var(--surface); border:1px solid var(--border); color:var(--dim);
  padding:5px 12px; border-radius:999px; font-size:12px; font-variant-numeric:tabular-nums;
}

.subtitle{
  width:100%; max-width:420px; background:var(--surface); border:1px solid var(--border);
  border-radius:14px; padding:12px 15px; font-size:14px; line-height:1.5;
  max-height:26dvh; overflow-y:auto; white-space:pre-wrap;
}

.recap{
  width:100%; max-width:420px; background:rgba(75,214,163,.08); border:1px solid rgba(75,214,163,.28);
  border-radius:16px; padding:16px; font-size:14px; line-height:1.55;
  max-height:34dvh; overflow-y:auto;
}
.recap-title{font-weight:600; color:var(--ok); margin-bottom:8px; font-size:13px;
  text-transform:uppercase; letter-spacing:.7px}
.recap-text{white-space:pre-wrap}

.call-controls{padding:10px 0 4px}
.btn-call{
  width:100%; border:none; border-radius:18px; padding:18px 24px;
  display:flex; align-items:center; justify-content:center; gap:10px;
  font-size:18px; font-weight:600; color:#fff;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow:0 8px 30px rgba(124,107,255,.4);
  transition:transform .1s;
}
.btn-call:active{transform:scale(.98)}
.btn-call svg{width:22px; height:22px}

.in-call{display:flex; align-items:center; justify-content:center; gap:26px}
.ctl{
  width:56px; height:56px; border-radius:50%; border:1px solid var(--border);
  background:var(--surface); color:var(--dim); font-size:16px; font-weight:600;
  display:flex; align-items:center; justify-content:center; transition:transform .1s, border-color .15s, color .15s;
}
.ctl:active{transform:scale(.94)}
.ctl.on{border-color:var(--accent); color:var(--text); background:rgba(124,107,255,.16)}
.ctl.end{
  width:70px; height:70px; border:none; color:#fff;
  background:linear-gradient(135deg, #ff5f7e, #e0355b);
  box-shadow:0 8px 26px rgba(255,95,126,.4);
}
.ctl.end svg{width:28px; height:28px; transform:rotate(135deg)}
.ctl.spacer{visibility:hidden; pointer-events:none; border:none; background:transparent}

/* ---------- страницы (история / прогресс / профиль) ---------- */
.page-head{padding:6px 0 16px}
.page-head h1{margin:0; font-size:24px; letter-spacing:.2px}
.page-head p{margin:5px 0 0; color:var(--dim); font-size:13px}

.card{
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:16px; margin-bottom:12px;
}

.empty{text-align:center; padding:52px 20px; color:var(--dim)}
.empty .orb-mini{opacity:.45; margin-bottom:18px}
.empty p{font-size:15px; margin:0}

.session-top{display:flex; justify-content:space-between; align-items:baseline; gap:10px; margin-bottom:8px}
.session-date{font-weight:600; font-size:14px}
.session-dur{color:var(--dim); font-size:13px; flex:0 0 auto}
.session-summary{margin:0; font-size:14px; line-height:1.55; color:var(--dim); white-space:pre-wrap}
.clamp{display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden}

.hero{text-align:center; padding:30px 16px 26px}
.hero-num{
  font-size:72px; font-weight:700; line-height:1;
  background:linear-gradient(135deg, #b9a4ff, var(--accent-2));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero-lbl{color:var(--dim); margin-top:8px; font-size:14px}

.metric{margin-top:13px}
.metric:first-of-type{margin-top:10px}
.metric-lab{display:flex; justify-content:space-between; gap:10px; font-size:13px; color:var(--dim); margin-bottom:6px}
.metric-val{color:var(--text); font-variant-numeric:tabular-nums; flex:0 0 auto}
.bar{height:8px; border-radius:99px; background:var(--surface-2); overflow:hidden}
.bar-fill{height:100%; border-radius:99px; background:linear-gradient(90deg, var(--accent-2), var(--accent)); transition:width .6s ease}

.req-list{margin:0; padding:0; list-style:none}
.req-list li{
  padding:11px 0; font-size:14px; line-height:1.5; border-bottom:1px solid var(--border);
  display:flex; gap:10px; align-items:flex-start;
}
.req-list li:last-child{border-bottom:none}
.req-list li::before{content:""; flex:0 0 7px; width:7px; height:7px; border-radius:50%;
  background:var(--accent); margin-top:6px}

.avatar{
  width:72px; height:72px; border-radius:50%; margin:2px auto 12px;
  display:flex; align-items:center; justify-content:center;
  font-size:30px; font-weight:700; color:#fff;
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
}
.profile-name{text-align:center; font-size:20px; font-weight:700}
.profile-meta{text-align:center; color:var(--dim); font-size:13px; margin-top:5px}

.setting{display:flex; align-items:center; justify-content:space-between; gap:14px}
.setting-name{font-size:15px; font-weight:500}
.setting-hint{font-size:12px; color:var(--dim); margin-top:3px}

.switch{position:relative; width:50px; height:30px; flex:0 0 auto}
.switch input{opacity:0; width:0; height:0; position:absolute}
.knob{position:absolute; inset:0; border-radius:99px; background:var(--surface-2); cursor:pointer; transition:background .2s; border:1px solid var(--border)}
.knob::after{content:""; position:absolute; width:24px; height:24px; border-radius:50%;
  background:#fff; top:2px; left:2px; transition:left .2s; box-shadow:0 1px 4px rgba(0,0,0,.35)}
.switch input:checked + .knob{background:var(--accent); border-color:var(--accent)}
.switch input:checked + .knob::after{left:22px}

/* ---------- таб-бар ---------- */
#tabbar{
  position:fixed; bottom:0; left:50%; transform:translateX(-50%);
  width:100%; max-width:480px; z-index:20;
  display:flex;
  padding:8px 8px calc(8px + env(safe-area-inset-bottom));
  background:var(--bg);
  background:color-mix(in srgb, var(--bg) 84%, transparent);
  -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  border-top:1px solid var(--border);
}
.tab{
  flex:1; display:flex; flex-direction:column; align-items:center; gap:3px;
  background:none; border:none; color:var(--dim); padding:6px 4px; border-radius:12px;
  font-size:11px; font-weight:500; transition:color .15s;
}
.tab svg{width:23px; height:23px}
.tab.active{color:var(--accent)}

/* ---------- оверлей ---------- */
.overlay{
  position:fixed; inset:0; z-index:50;
  background:rgba(5,5,15,.62);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  padding:24px 24px calc(24px + env(safe-area-inset-bottom));
}
.ov-card{max-width:380px; width:100%; margin:0; padding:22px}
.ov-card h2{margin:0 0 10px; font-size:18px}
.ov-card p{margin:0; color:var(--dim); font-size:14px; line-height:1.55}
.ov-card .btn-primary{margin-top:18px}

/* ---------- тост ---------- */
.toast{
  position:fixed; left:50%; transform:translateX(-50%);
  bottom:calc(96px + env(safe-area-inset-bottom));
  max-width:min(440px, calc(100vw - 40px));
  background:var(--surface-2); border:1px solid var(--border); color:var(--text);
  padding:12px 18px; border-radius:14px; font-size:14px; line-height:1.4; text-align:center;
  z-index:60; box-shadow:0 10px 34px rgba(0,0,0,.45);
  animation:fadein .2s ease;
}

/* ---------- десктоп ---------- */
@media (min-width: 600px){
  #app{border-left:1px solid var(--border); border-right:1px solid var(--border)}
  #tabbar{border-left:1px solid var(--border); border-right:1px solid var(--border)}
}
