:root{
  --bg:#10182a;
  --bg-soft:#141f34;
  --card:rgba(255,255,255,.105);
  --card-strong:rgba(255,255,255,.16);
  --stroke:rgba(255,255,255,.16);
  --stroke-strong:rgba(255,255,255,.24);
  --text:#f4f8ff;
  --muted:rgba(244,248,255,.72);
  --muted-2:rgba(244,248,255,.5);
  --accent:#52ffe0;
  --accent-2:#8d6bff;
  --accent-3:#ffd166;
  --danger:#ff6b8a;
  --success:#6cff9d;
  --ink:#08111f;
  --shadow:0 18px 46px rgba(5,10,20,.24);
  --radius-xl:24px;
  --radius-lg:20px;
  --radius-md:16px;
  --title-page:24px;
  --title-section:24px;
  --title-card:18px;
  --text-body:15px;
  --text-small:13px;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

[hidden]{display:none!important}
*{box-sizing:border-box}
html{min-height:100%;background:var(--bg);color-scheme:dark}
body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  background:
    radial-gradient(circle at 12% 8%,rgba(82,255,224,.18),transparent 34%),
    radial-gradient(circle at 88% 14%,rgba(141,107,255,.18),transparent 34%),
    linear-gradient(135deg,#10182a 0%,#111b2e 48%,#151a33 100%);
  background-attachment:fixed;
  overflow:hidden;
  font-size:var(--text-body);
}
button,input,textarea,select{font:inherit}
button{border:0;cursor:pointer;min-width:0}
button:disabled{opacity:.55;cursor:not-allowed}
input,textarea,select{
  width:100%;
  min-width:0;
  border:1px solid rgba(255,255,255,.12);
  outline:0;
  color:var(--text);
  background:rgba(11,20,35,.58);
  border-radius:16px;
  padding:14px 15px;
  line-height:1.35;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
textarea{resize:vertical;line-height:1.45}
select{
  appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);
  background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;
  background-size:5px 5px,5px 5px;
  background-repeat:no-repeat;
  padding-right:34px;
}
input:focus,textarea:focus,select:focus{
  border-color:rgba(82,255,224,.55);
  box-shadow:0 0 0 4px rgba(82,255,224,.1),inset 0 1px 0 rgba(255,255,255,.08);
}
input::placeholder,textarea::placeholder{color:var(--muted-2)}
h1,h2,h3,h4,p{margin-top:0;overflow-wrap:anywhere}
h1{margin-bottom:0;font-size:var(--title-page);line-height:1.12;font-weight:900}
h2{font-size:var(--title-section);line-height:1.16;font-weight:900}
h3{font-size:var(--title-card);line-height:1.22;font-weight:900}
.brand-block h1{
  overflow:hidden;
  overflow-wrap:normal;
  text-overflow:ellipsis;
  white-space:nowrap;
  word-break:normal;
}

.app-shell{
  position:relative;
  width:min(100%,520px);
  height:100vh;
  min-height:100vh;
  margin:0 auto;
  padding:18px 16px 108px;
  overflow:hidden;
}
.ambient{
  position:fixed;
  width:240px;
  height:240px;
  border-radius:999px;
  filter:blur(60px);
  opacity:.22;
  pointer-events:none;
}
.ambient-one{top:80px;left:calc(50% - 320px);background:#00ffd5}
.ambient-two{top:330px;right:calc(50% - 340px);background:#8d6bff}
.glass-card{
  border:1px solid var(--stroke);
  background:linear-gradient(145deg,rgba(255,255,255,.13),rgba(255,255,255,.065));
  box-shadow:var(--shadow);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
}

.auth-screen{
  min-height:calc(100vh - 126px);
  display:grid;
  place-items:center;
}
.auth-card{
  position:relative;
  width:min(100%,460px);
  border-radius:var(--radius-xl);
  padding:22px;
}
.auth-brand{margin-bottom:16px}
.auth-copy{color:var(--muted);line-height:1.45;margin-bottom:18px}

.app-screen{
  height:100%;
  min-height:0;
  display:grid;
  grid-template-rows:auto minmax(0,1fr);
}
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:8px 0 22px;
}
.brand-block{display:flex;align-items:center;gap:12px;min-width:0}
.brand-mark{
  width:48px;
  height:48px;
  flex:0 0 48px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,rgba(82,255,224,.9),rgba(141,107,255,.95));
  box-shadow:0 16px 45px rgba(82,255,224,.18);
}
.brand-mark span{
  width:22px;
  height:22px;
  border-radius:8px;
  background:var(--bg);
  position:relative;
}
.brand-mark span::before,.brand-mark span::after{
  content:"";
  position:absolute;
  width:5px;
  height:5px;
  top:7px;
  border-radius:999px;
  background:var(--accent);
}
.brand-mark span::before{left:5px}
.brand-mark span::after{right:5px}
.eyebrow{
  margin:0 0 4px;
  font-size:11px;
  letter-spacing:0;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:850;
}
.top-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.profile-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:42px;
  padding:10px 12px;
  color:var(--text);
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.09);
  border-radius:999px;
  white-space:nowrap;
}
.profile-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  min-height:44px;
  max-width:190px;
  padding:7px 11px 7px 7px;
  color:var(--text);
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.1);
  border-radius:999px;
}
.profile-button:hover{
  border-color:rgba(82,255,224,.42);
  background:rgba(255,255,255,.14);
}
.profile-name{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-weight:850;
  font-size:14px;
}
.profile-avatar{
  width:30px;
  height:30px;
  flex:0 0 30px;
  display:grid;
  place-items:center;
  border-radius:12px;
  color:var(--ink);
  background:linear-gradient(135deg,var(--accent),var(--accent-3));
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}
.profile-avatar.large{
  width:66px;
  height:66px;
  flex-basis:66px;
  border-radius:24px;
  font-size:22px;
}
.status-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--success);
  box-shadow:0 0 18px var(--success);
}

.content{position:relative;z-index:1;min-height:0}
.content-scroll{
  overflow:auto;
  padding:0 2px 28px;
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.18) transparent;
}
.content-scroll::-webkit-scrollbar,.chat-log::-webkit-scrollbar{width:8px}
.content-scroll::-webkit-scrollbar-thumb,.chat-log::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.page{display:none;animation:fadeUp .32s ease both}
.page.active{
  display:grid;
  align-content:start;
  gap:24px;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

.hero-card{
  min-height:176px;
  border-radius:var(--radius-xl);
  padding:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  overflow:hidden;
  position:relative;
}
.hero-card::after{
  content:"";
  position:absolute;
  inset:auto -40px -80px auto;
  width:210px;
  height:210px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(82,255,224,.14),transparent 64%);
}
.hero-copy{position:relative;z-index:1;max-width:310px}
.hero-copy h2{font-size:var(--title-section);line-height:1.16;margin-bottom:12px}
.hero-copy p:last-child{color:var(--muted);line-height:1.45;margin-bottom:0}
.ai-orb{
  position:relative;
  z-index:1;
  width:112px;
  height:112px;
  flex:0 0 112px;
  display:grid;
  place-items:center;
}
.orb-ring{
  position:absolute;
  inset:0;
  border-radius:50%;
  background:conic-gradient(from 40deg,var(--accent),var(--accent-2),transparent,var(--accent));
  animation:spin 8s linear infinite;
}
.orb-core{
  width:84px;
  height:84px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:var(--bg);
  color:var(--accent);
  font-weight:900;
  letter-spacing:0;
  box-shadow:inset 0 0 28px rgba(82,255,224,.22);
}
@keyframes spin{to{transform:rotate(360deg)}}

.quick-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin:0;
}
.metric-card,.task-card,.security-item{
  border-radius:var(--radius-lg);
  padding:16px;
}
.metric-icon{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:13px;
  background:rgba(82,255,224,.14);
  color:var(--accent);
  margin-bottom:12px;
  font-weight:900;
}
.metric-card p{color:var(--muted);margin-bottom:6px}
.metric-card h3{font-size:25px;margin-bottom:5px}
.metric-card span{color:var(--muted-2);font-size:13px}

.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin:4px 0 0;
}
.section-head-tight{align-items:center;margin-top:0}
.section-head h2{margin-bottom:0}
.small-button,.primary-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  color:#06111f;
  background:linear-gradient(135deg,var(--accent),#b8fff2 62%,var(--accent-3));
  padding:12px 15px;
  border-radius:999px;
  font-weight:850;
  box-shadow:0 18px 50px rgba(82,255,224,.18);
  text-align:center;
  overflow-wrap:anywhere;
}
.primary-btn{width:max-content;max-width:100%;border-radius:18px}
.ghost-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 12px;
  border-radius:16px;
  color:var(--text);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.13);
}
.form-stack{display:grid;gap:14px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.profile-card .form-grid{grid-template-columns:1fr}
.field-stack{display:grid;gap:14px}
.widget-stack,.task-board,.integration-list{display:grid;gap:18px}
.timeline-card,.assistant-preview,.template-upload{
  border-radius:var(--radius-xl);
  padding:18px;
}
.section-title{
  margin-bottom:16px;
}
.section-title span{
  display:block;
  color:var(--text);
  font-size:var(--title-card);
  font-weight:900;
  line-height:1.22;
}
.timeline-header,.assistant-preview{
  display:flex;
  align-items:center;
  gap:14px;
}
.timeline-header{justify-content:space-between;margin-bottom:12px}
.timeline-header h3,.assistant-preview h3{margin-bottom:4px}
.timeline-header p,.assistant-preview p{color:var(--muted);margin-bottom:0;line-height:1.45}
.chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 11px;
  border-radius:999px;
  color:var(--ink);
  background:var(--accent);
  font-size:12px;
  font-weight:900;
  text-align:center;
  white-space:normal;
}
.assistant-mini-orb{
  width:54px;
  height:54px;
  flex:0 0 54px;
  display:grid;
  place-items:center;
  border-radius:20px;
  background:linear-gradient(135deg,var(--accent-2),var(--accent));
  color:var(--ink);
  font-weight:900;
}

.command-panel{
  border-radius:var(--radius-xl);
  padding:18px;
}
.command-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
}
.command-head h3{font-size:var(--title-card);line-height:1.22;margin-bottom:0}
.command-actions{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  margin-top:10px;
}
.record-btn,.mic-button{
  position:relative;
  width:64px;
  height:64px;
  flex:0 0 64px;
  display:grid;
  place-items:center;
  border-radius:24px;
  color:var(--ink);
  background:linear-gradient(135deg,var(--accent),#ffffff);
  box-shadow:0 18px 55px rgba(82,255,224,.24);
}
.record-glyph{
  position:relative;
  width:16px;
  height:24px;
  border:2px solid currentColor;
  border-radius:999px;
  z-index:2;
}
.record-glyph::before{
  content:"";
  position:absolute;
  left:50%;
  bottom:-9px;
  width:2px;
  height:8px;
  background:currentColor;
  transform:translateX(-50%);
  border-radius:999px;
}
.record-glyph::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-12px;
  width:16px;
  height:2px;
  background:currentColor;
  transform:translateX(-50%);
  border-radius:999px;
}
.record-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.recording{background:linear-gradient(135deg,var(--danger),#ffb199);color:#fff}
.recording .record-glyph{
  width:18px;
  height:18px;
  border-radius:6px;
  background:currentColor;
}
.recording .record-glyph::before,.recording .record-glyph::after{display:none}
.recording .pulse{
  position:absolute;
  inset:-8px;
  border-radius:30px;
  border:2px solid rgba(82,255,224,.65);
  animation:pulse 1.1s ease-out infinite;
}
@keyframes pulse{to{transform:scale(1.22);opacity:0}}

.list-stack{display:grid;gap:12px}
.list-stack.compact{gap:10px}
.list-item,.task-item,.readiness-item{
  min-width:0;
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  background:rgba(11,20,35,.42);
  padding:13px;
}
.list-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.memory-item{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:flex-start;
}
.memory-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
.memory-delete-btn{
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border-radius:12px;
  color:var(--muted);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:20px;
  line-height:1;
}
.memory-delete-btn:hover{
  color:#ffd9e1;
  border-color:rgba(255,107,138,.38);
  background:rgba(255,107,138,.12);
}
.list-item b,.task-item b,.readiness-item b{
  display:block;
  min-width:0;
  font-size:16px;
  overflow-wrap:anywhere;
}
.list-item span,.readiness-item span{
  display:block;
  color:var(--muted);
  font-size:14px;
  line-height:1.4;
  margin-top:4px;
  overflow-wrap:anywhere;
}
.list-item small,.readiness-item small,.task-meta small{
  color:var(--muted-2);
  font-size:13px;
  white-space:nowrap;
}
.task-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  color:var(--muted-2);
  font-size:13px;
  margin-bottom:8px;
}
.task-top span,.status-pill{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:6px 10px;
  color:var(--ink);
  background:var(--accent);
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
}
.task-controls{
  display:flex;
  align-items:center;
  gap:8px;
  flex:0 0 auto;
}
.task-delete-btn,.task-call-btn{
  width:32px;
  height:32px;
  display:grid;
  place-items:center;
  border-radius:12px;
  color:var(--muted);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:20px;
  line-height:1;
}
.task-call-btn{
  color:var(--ink);
  background:var(--accent);
  border-color:transparent;
  font-size:15px;
  font-weight:900;
}
.task-call-btn:hover{
  background:#b8fff2;
}
.task-delete-btn:hover{
  color:#ffd9e1;
  border-color:rgba(255,107,138,.38);
  background:rgba(255,107,138,.12);
}
.task-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:9px}
.task-meta small{
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  padding:5px 8px;
  background:rgba(255,255,255,.06);
}
.task-extra{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(255,255,255,.08);
}
.task-extra small{
  color:var(--muted);
  line-height:1.35;
  overflow-wrap:anywhere;
}
.task-extra .task-warning{
  color:#ffd9a8;
}
.task-safe-pause{
  flex:1 1 100%;
  display:grid;
  gap:3px;
  color:var(--muted);
}
.task-safe-pause b{
  color:var(--ink);
  font-size:13px;
}
.task-done-note{
  color:var(--success);
  font-weight:850;
}
.task-online-actions{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  min-width:0;
}
.quiet-link.compact{
  min-height:32px;
  padding:6px 9px;
  border-radius:12px;
  font-size:12px;
}
.quiet-btn.compact{
  min-height:32px;
  padding:6px 9px;
  border-radius:12px;
  font-size:12px;
  font-weight:850;
}
.task-tabs{
  display:inline-grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:4px;
  width:min(100%,360px);
  margin-bottom:14px;
  padding:4px;
  border-radius:18px;
  background:rgba(255,255,255,.065);
  border:1px solid rgba(255,255,255,.1);
}
.task-tabs button{
  min-height:42px;
  min-width:0;
  border-radius:14px;
  color:var(--muted);
  background:transparent;
  border:0;
  font-weight:900;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.task-tabs button.active{
  color:var(--ink);
  background:var(--accent);
}
.task-pane{
  display:grid;
  gap:16px;
}
.readiness-item{display:flex;justify-content:space-between;gap:12px}
.readiness-item small{color:var(--accent)}
.empty-state{
  border:1px dashed rgba(255,255,255,.22);
  border-radius:18px;
  padding:14px;
  color:var(--muted);
  background:rgba(255,255,255,.045);
}

.call-history-list{
  display:grid;
  gap:12px;
}
.call-history-item{
  display:grid;
  gap:11px;
  padding:13px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.052);
}
.call-history-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:start;
}
.call-history-head small,.call-history-result small,.call-script-preview small{
  display:block;
  margin-bottom:4px;
  color:var(--muted-2);
  font-size:12px;
  font-weight:900;
}
.call-history-head b{
  display:block;
  overflow-wrap:anywhere;
}
.call-history-meta{
  color:var(--muted-2);
  font-size:13px;
  line-height:1.35;
}
.call-history-result,.call-script-preview{
  padding:10px 11px;
  border-radius:15px;
  border:1px solid rgba(255,255,255,.085);
  background:rgba(11,20,35,.34);
}
.call-history-result p,.call-script-preview p{
  margin:0;
  color:var(--muted);
  line-height:1.42;
  overflow-wrap:anywhere;
}
.call-history-result.transcript-result{
  display:grid;
  gap:8px;
}
.call-history-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.template-upload h3{font-size:var(--title-card);line-height:1.22;margin-bottom:16px}
.file-drop{
  position:relative;
  display:grid;
  gap:6px;
  min-height:98px;
  align-content:center;
  border:1px solid rgba(255,255,255,.14);
  border-radius:20px;
  padding:16px;
  margin-bottom:12px;
  background:rgba(11,20,35,.5);
  overflow:hidden;
  cursor:pointer;
}
.file-drop input{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:pointer;
}
.file-drop span{font-size:18px;font-weight:850}
.file-drop small{color:var(--muted)}
.template-list .template-file-name{
  font-size:17px;
  line-height:1.2;
  overflow-wrap:break-word;
  word-break:normal;
}
.template-list .list-item{display:grid}
.template-list .list-item small{white-space:normal}

.search-panel{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) minmax(160px,.5fr);
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:var(--radius-lg);
  margin-bottom:0;
}
.search-panel span{color:var(--accent);font-weight:900}
.admin-grid{
  display:grid;
  grid-template-columns:minmax(280px,.8fr) minmax(0,1.2fr);
  gap:18px;
}
.admin-user{display:grid;gap:12px}
.admin-user-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:start;
}
.admin-user-head span{color:var(--muted);font-size:13px;line-height:1.4}
.admin-controls{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}
.admin-controls input[data-admin-field="notes"]{grid-column:span 2}
.admin-quick-actions{display:flex;gap:8px;flex-wrap:wrap}
.admin-quick-actions .profile-pill,.admin-quick-actions .quiet-btn{min-height:38px;padding:8px 10px}
.quiet-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:0;
  color:var(--text);
  border:1px solid var(--stroke);
  background:rgba(255,255,255,.09);
  border-radius:16px;
  padding:10px 12px;
  text-align:center;
  overflow-wrap:anywhere;
}

.apps-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}
.apps-search-panel{
  grid-template-columns:auto minmax(0,1fr);
  margin-bottom:0;
}
.apps-catalog{
  align-items:stretch;
}
.app-card{
  min-height:210px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  border-radius:var(--radius-lg);
  padding:16px;
}
.app-icon{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  border-radius:17px;
  margin-bottom:13px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.1);
  color:var(--text);
  font-size:15px;
  font-weight:900;
}
.app-icon.food{color:var(--accent);background:rgba(82,255,224,.12)}
.app-icon.sport{color:#d8ff76;background:rgba(216,255,118,.11)}
.app-icon.money{color:var(--accent-3);background:rgba(255,209,102,.12)}
.app-icon.travel{color:#9bb7ff;background:rgba(141,107,255,.14)}
.app-icon.docs{color:#f0f4ff;background:rgba(255,255,255,.12)}
.app-icon.health{color:#ff9ab0;background:rgba(255,107,138,.12)}
.app-icon.home{color:var(--accent);background:rgba(82,255,224,.1)}
.app-card h3{
  margin-bottom:8px;
  font-size:var(--title-card);
  line-height:1.22;
}
.app-card p{
  color:var(--muted);
  line-height:1.44;
  margin-bottom:14px;
  font-size:14px;
}
.app-chip{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:7px 10px;
  border-radius:999px;
  color:var(--text);
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.12);
  font-size:12px;
  font-weight:900;
}
.app-chip.active{
  color:var(--ink);
  background:var(--accent);
  border-color:transparent;
}
.security-item h3{margin-bottom:8px}
.security-item p{color:var(--muted);line-height:1.44;margin-bottom:0;font-size:14px}

.profile-grid{
  display:grid;
  gap:18px;
}
.profile-card{
  border-radius:var(--radius-xl);
  padding:18px;
  overflow:hidden;
}
.profile-identity{
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}
.profile-identity > div{min-width:0}
.profile-identity h3{
  margin-bottom:5px;
  font-size:var(--title-card);
  line-height:1.22;
  overflow-wrap:anywhere;
}
.profile-identity p{
  margin-bottom:0;
  color:var(--muted);
  overflow-wrap:anywhere;
  line-height:1.4;
}
.field-label{
  display:block;
  margin:0;
  color:var(--muted);
  font-size:13px;
  line-height:1.25;
  font-weight:800;
}
.profile-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.integration-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  min-width:0;
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  background:rgba(11,20,35,.42);
  padding:13px;
}
.integration-row.connected{
  border-color:rgba(82,255,224,.28);
  background:rgba(82,255,224,.08);
}
.integration-row b{
  display:block;
  overflow-wrap:anywhere;
}
.integration-row span{
  display:block;
  margin-top:4px;
  color:var(--muted);
  font-size:14px;
  line-height:1.38;
}
.integration-row .quiet-btn{
  min-height:38px;
  white-space:nowrap;
}
.integration-state{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:38px;
  padding:8px 12px;
  border-radius:16px;
  color:var(--muted);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:13px;
  font-weight:900;
  white-space:nowrap;
}
.integration-state.is-connected{
  color:var(--ink);
  background:var(--accent);
  border-color:transparent;
}

.bottom-nav{
  position:fixed;
  z-index:8;
  left:50%;
  bottom:max(14px,env(safe-area-inset-bottom));
  transform:translateX(-50%);
  width:min(calc(100% - 24px),500px);
  height:78px;
  display:grid;
  grid-template-columns:1fr 1fr 86px 1fr 1fr;
  align-items:center;
  padding:8px;
  border:1px solid var(--stroke);
  border-radius:30px;
  background:rgba(12,22,38,.8);
  box-shadow:0 20px 52px rgba(5,10,20,.34);
  backdrop-filter:blur(26px);
  -webkit-backdrop-filter:blur(26px);
}
.nav-item{
  height:58px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:4px;
  border-radius:22px;
  color:var(--muted-2);
  background:transparent;
  font-size:11px;
  font-weight:800;
  min-width:0;
}
.nav-item span:last-child{
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.nav-icon{font-size:18px}
.nav-item.active{
  color:var(--text);
  background:rgba(255,255,255,.1);
}
.bot-fab{
  width:76px;
  height:76px;
  margin:-28px auto 0;
  border-radius:30px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 18px 50px rgba(82,255,224,.25);
}
.bot-face{
  width:46px;
  height:38px;
  position:relative;
  border-radius:16px;
  background:var(--bg);
}
.bot-face::before,.bot-face::after{
  content:"";
  position:absolute;
  top:13px;
  width:7px;
  height:7px;
  border-radius:999px;
  background:var(--accent);
}
.bot-face::before{left:12px}
.bot-face::after{right:12px}
.bot-face i{
  position:absolute;
  left:16px;
  right:16px;
  bottom:9px;
  height:2px;
  border-radius:999px;
  background:var(--accent);
}

.bot-sheet{
  position:fixed;
  inset:0;
  z-index:20;
}
.sheet-backdrop{
  position:absolute;
  inset:0;
  background:rgba(5,10,20,.46);
}
.sheet-panel{
  position:absolute;
  left:50%;
  bottom:0;
  transform:translateX(-50%);
  width:min(100%,520px);
  max-height:88vh;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:10px 16px max(18px,env(safe-area-inset-bottom));
  border-radius:34px 34px 0 0;
  background:radial-gradient(circle at 30% 0%,rgba(82,255,224,.12),transparent 34%),#10182a;
  border:1px solid var(--stroke);
  box-shadow:0 -18px 52px rgba(5,10,20,.42);
}
.sheet-handle{
  width:48px;
  height:5px;
  border-radius:999px;
  background:rgba(255,255,255,.22);
  margin:0 auto 2px;
}
.bot-header{
  display:flex;
  align-items:center;
  gap:12px;
}
.bot-header > div{min-width:0}
.bot-avatar{
  width:54px;
  height:54px;
  border-radius:20px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
}
.bot-avatar span{
  width:30px;
  height:24px;
  border-radius:11px;
  background:var(--bg);
}
.bot-header h2{
  margin-bottom:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.icon-button{
  margin-left:auto;
  width:40px;
  height:40px;
  border-radius:16px;
  color:var(--text);
  background:rgba(255,255,255,.1);
  font-size:24px;
}
.chat-log-shell{
  position:relative;
  min-width:0;
  min-height:160px;
  flex:1 1 auto;
  display:flex;
}
.chat-log{
  display:grid;
  gap:12px;
  overflow:auto;
  min-height:160px;
  width:100%;
  flex:1 1 auto;
  padding-right:2px;
}
.chat-scroll-btn{
  position:absolute;
  right:12px;
  bottom:12px;
  z-index:2;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:16px;
  color:var(--ink);
  background:var(--accent);
  border:1px solid rgba(255,255,255,.32);
  box-shadow:0 14px 34px rgba(5,10,20,.34);
  font-size:24px;
  font-weight:900;
  line-height:1;
}
.chat-scroll-btn:hover{background:#b8fff2}
.msg{
  width:fit-content;
  max-width:86%;
  padding:12px 14px;
  border-radius:18px;
  line-height:1.45;
  white-space:pre-wrap;
  overflow-wrap:anywhere;
}
.msg.assistant{background:rgba(255,255,255,.1);border:1px solid var(--stroke)}
.msg.user{margin-left:auto;color:var(--ink);background:linear-gradient(135deg,var(--accent),#c9fff6)}
.msg a{color:inherit;text-decoration:underline;text-underline-offset:3px}
.quick-replies{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.quick-reply{
  min-height:34px;
  max-width:100%;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid rgba(124,255,235,.38);
  color:var(--ink);
  background:rgba(124,255,235,.16);
  font-size:13px;
  font-weight:800;
  line-height:1.2;
  overflow-wrap:anywhere;
  cursor:pointer;
}
.quick-reply:hover{background:rgba(124,255,235,.28)}
.chat-tools{
  display:grid;
  grid-template-columns:minmax(0,1fr) 72px;
  gap:10px;
  align-items:center;
}
.chat-tools .mic-button{width:72px;height:72px;border-radius:28px}
.composer{
  display:flex;
  align-items:flex-end;
  gap:10px;
  padding:10px;
  border-radius:24px;
  background:rgba(255,255,255,.08);
  border:1px solid var(--stroke);
}
.composer textarea{
  min-height:46px;
  max-height:220px;
  flex:1 1 auto;
  border:0;
  background:transparent;
  padding:12px 4px 10px;
  resize:none;
  overflow-y:hidden;
  line-height:1.35;
}
.composer textarea:focus{
  box-shadow:none;
}
.visually-hidden-input{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.attach-button{
  width:46px;
  height:46px;
  flex:0 0 46px;
  display:grid;
  place-items:center;
  border-radius:17px;
  color:var(--text);
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.1);
}
.attach-button:disabled{opacity:.5}
.attach-icon{
  width:22px;
  height:22px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.2;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.send-button{
  width:46px;
  height:46px;
  flex:0 0 46px;
  border-radius:17px;
  color:var(--ink);
  background:var(--accent);
  font-weight:900;
}

.call-widget{
  position:fixed;
  z-index:18;
  left:50%;
  bottom:104px;
  width:min(calc(100% - 24px),500px);
  transform:translateX(-50%);
  pointer-events:none;
}
.call-widget-toggle,.call-widget-panel{
  pointer-events:auto;
}
.call-widget-toggle{
  min-height:56px;
  width:min(100%,250px);
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  grid-template-areas:"dot title" "dot status";
  align-items:center;
  gap:2px 10px;
  margin-left:auto;
  padding:10px 14px;
  border-radius:22px;
  color:var(--text);
  background:rgba(10,19,34,.88);
  border:1px solid rgba(82,255,224,.28);
  box-shadow:0 16px 44px rgba(5,10,20,.34);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  text-align:left;
}
.call-widget-toggle span:not(.call-live-dot){
  grid-area:title;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-weight:900;
}
.call-widget-toggle small{
  grid-area:status;
  color:var(--muted);
  font-size:12px;
  line-height:1.1;
}
.call-live-dot{
  grid-area:dot;
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--muted-2);
}
.call-live-dot.is-live{
  background:var(--success);
  box-shadow:0 0 0 6px rgba(108,255,157,.12),0 0 22px rgba(108,255,157,.5);
  animation:callPulse 1.2s ease-out infinite;
}
@keyframes callPulse{to{box-shadow:0 0 0 13px rgba(108,255,157,0),0 0 22px rgba(108,255,157,.45)}}
.call-widget-panel{
  position:absolute;
  right:0;
  bottom:66px;
  width:min(100%,500px);
  max-height:min(76vh,720px);
  display:flex;
  flex-direction:column;
  gap:13px;
  overflow:auto;
  padding:16px;
  border-radius:28px;
  background:radial-gradient(circle at 20% 0%,rgba(82,255,224,.12),transparent 34%),rgba(11,20,35,.95);
}
.call-widget-head{
  position:sticky;
  top:-16px;
  z-index:3;
  display:flex;
  align-items:center;
  gap:12px;
  margin:-16px -16px 0;
  padding:16px 16px 12px;
  background:linear-gradient(180deg,rgba(11,20,35,.98),rgba(11,20,35,.92));
  border-bottom:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}
.call-widget-head > div{min-width:0}
.call-widget-head h2{
  margin-bottom:0;
  font-size:20px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.call-start-form{
  display:grid;
  gap:10px;
  padding:12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  background:rgba(255,255,255,.055);
}
.call-form-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(120px,.7fr);
  gap:10px;
}
.active-call-details{
  display:grid;
  gap:12px;
}
.active-call-card,.call-empty-state{
  display:grid;
  gap:12px;
  padding:13px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:20px;
  background:rgba(11,20,35,.52);
}
.call-empty-state span{
  color:var(--muted);
  line-height:1.42;
}
.call-meta-row,.call-meta-grid{
  display:grid;
  gap:10px;
}
.call-meta-row{
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
}
.call-meta-grid{
  grid-template-columns:repeat(auto-fit,minmax(120px,1fr));
}
.call-meta-row small,.call-meta-grid small,.call-live-block small,.call-transcript small{
  display:block;
  margin-bottom:4px;
  color:var(--muted-2);
  font-size:12px;
  font-weight:800;
}
.call-meta-row b,.call-meta-grid b{
  display:block;
  overflow-wrap:anywhere;
}
.call-status-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:32px;
  padding:7px 10px;
  border-radius:999px;
  color:var(--muted);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  font-size:12px;
  font-weight:900;
  white-space:nowrap;
  max-width:160px;
  overflow:hidden;
  text-overflow:ellipsis;
}
.call-status-pill.is-active{
  color:var(--ink);
  background:var(--success);
  border-color:transparent;
}
.call-inline-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.quiet-link{
  display:inline-flex;
  align-items:center;
  min-height:40px;
  padding:9px 12px;
  border-radius:15px;
  color:var(--ink);
  background:var(--accent);
  text-decoration:none;
  font-weight:900;
}
.call-live-block,.call-transcript{
  padding:12px;
  border-radius:18px;
  background:rgba(255,255,255,.065);
  border:1px solid rgba(255,255,255,.09);
}
.call-live-block p,.call-transcript p{
  margin:0;
  color:var(--muted);
  line-height:1.42;
  overflow-wrap:anywhere;
}
.semantic-transcript{
  position:relative;
  display:grid;
  gap:8px;
}
.semantic-transcript.is-collapsed{
  max-height:168px;
  overflow:hidden;
}
.call-transcript .semantic-transcript.is-collapsed{
  max-height:138px;
}
.semantic-transcript.is-collapsed::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:54px;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(21,31,48,0),rgba(21,31,48,.96));
}
.transcript-turn{
  display:grid;
  grid-template-columns:minmax(92px,.28fr) minmax(0,1fr);
  gap:8px;
  align-items:start;
  padding:8px 9px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.052);
}
.transcript-turn strong{
  color:var(--muted-2);
  font-size:12px;
  line-height:1.35;
  overflow-wrap:anywhere;
}
.transcript-turn span{
  color:var(--text);
  line-height:1.4;
  overflow-wrap:anywhere;
}
.transcript-turn.remote{
  border-color:rgba(255,209,102,.22);
  background:rgba(255,209,102,.075);
}
.transcript-turn.remote strong{color:#ffd166}
.transcript-turn.assistant{
  border-color:rgba(82,255,224,.22);
  background:rgba(82,255,224,.075);
}
.transcript-turn.assistant strong{color:var(--accent)}
.transcript-turn.operator{
  border-color:rgba(141,107,255,.24);
  background:rgba(141,107,255,.09);
}
.transcript-turn.operator strong{color:#b9a9ff}
.transcript-turn.plain{
  grid-template-columns:1fr;
}
.transcript-toggle{
  justify-self:start;
  min-height:34px;
  padding:7px 10px;
  border-radius:13px;
  color:var(--ink);
  background:var(--accent);
  font-weight:900;
}
.call-recording-player{
  display:grid;
  gap:7px;
  padding:10px 11px;
  border-radius:15px;
  border:1px solid rgba(82,255,224,.16);
  background:rgba(82,255,224,.065);
}
.call-recording-player small{
  color:var(--muted-2);
  font-size:12px;
  font-weight:900;
}
.call-recording-player audio{
  width:100%;
  min-width:0;
}
.call-recording-placeholder{
  padding:9px 11px;
  border-radius:14px;
  color:var(--muted);
  background:rgba(255,255,255,.052);
  border:1px dashed rgba(255,255,255,.14);
  font-size:13px;
  line-height:1.35;
}
.call-timeline-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:0 4px;
}
.call-timeline-head small{
  color:var(--muted-2);
  font-size:12px;
  font-weight:900;
}
.call-timeline-head span{
  color:var(--muted);
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
}
.call-chat-log{
  display:grid;
  gap:9px;
  max-height:300px;
  overflow:auto;
  padding-right:2px;
}
.call-message{
  display:grid;
  gap:4px;
  padding:10px 11px;
  border-radius:16px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
}
.call-message small{
  color:var(--muted-2);
  font-size:11px;
}
.call-message span{
  color:var(--text);
  line-height:1.38;
  overflow-wrap:anywhere;
}
.call-message.assistant{
  border-color:rgba(82,255,224,.18);
  background:rgba(82,255,224,.08);
}
.call-message.remote{
  border-color:rgba(255,209,102,.2);
  background:rgba(255,209,102,.08);
}
.call-message.operator{
  margin-left:24px;
  border-color:rgba(141,107,255,.2);
  background:rgba(141,107,255,.1);
}
.call-chat-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) 46px;
  gap:10px;
  align-items:center;
}
.recent-calls-list{
  display:grid;
  gap:8px;
}
.recent-calls-title{
  color:var(--muted);
  font-size:12px;
  font-weight:900;
}
.recent-call-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  width:100%;
  min-height:42px;
  padding:9px 11px;
  border-radius:16px;
  color:var(--text);
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.09);
  text-align:left;
}
.recent-call-row span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-weight:850;
}
.recent-call-row small{
  color:var(--muted);
}

.error-box,.inline-status{
  margin-top:10px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid rgba(255,107,138,.34);
  background:rgba(255,107,138,.12);
  color:#ffd9e1;
  white-space:pre-wrap;
}
.inline-status{
  border-color:rgba(82,255,224,.32);
  background:rgba(82,255,224,.1);
  color:#dffcf8;
}
.inline-status.is-error{
  border-color:rgba(255,107,138,.34);
  background:rgba(255,107,138,.12);
  color:#ffd9e1;
}
.inline-status.is-success{
  border-color:rgba(108,255,157,.32);
  background:rgba(108,255,157,.1);
  color:#e2ffeb;
}

.otp-dialog-backdrop{
  position:fixed;
  inset:0;
  z-index:40;
  display:grid;
  place-items:center;
  padding:22px;
  background:rgba(8,15,28,.68);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  animation:fadeUp .2s ease both;
}
.otp-dialog{
  position:relative;
  width:min(100%,420px);
  border-radius:28px;
  padding:24px;
}
.otp-close-btn{
  position:absolute;
  top:14px;
  right:14px;
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:14px;
  color:var(--muted);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
  font-size:26px;
  line-height:1;
}
.otp-close-btn:hover,.ghost-btn:hover{border-color:rgba(82,255,224,.38)}
.otp-dialog-head{padding-right:44px;margin-bottom:20px}
.otp-dialog-head h2{margin-bottom:8px}
.otp-dialog-head p:last-child{
  margin:0;
  color:var(--muted);
  line-height:1.45;
}
.otp-digits{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:8px;
}
.otp-digit{
  height:58px;
  padding:0;
  text-align:center;
  border-radius:16px;
  font-size:28px;
  font-weight:900;
  color:var(--text);
  background:rgba(11,20,35,.72);
}
.otp-digit:disabled{opacity:.72}
.otp-progress{
  height:6px;
  margin-top:16px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.09);
}
.otp-progress span{
  display:block;
  width:var(--otp-progress,0%);
  height:100%;
  border-radius:inherit;
  background:linear-gradient(90deg,var(--accent),var(--accent-3));
  transition:width .18s ease;
}
.otp-dialog.is-verifying .otp-progress span{
  width:100%;
  animation:pulseWidth .8s ease-in-out infinite alternate;
}
.otp-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:14px;
}
@keyframes pulseWidth{from{opacity:.55}to{opacity:1}}

@media(min-width:900px){
  .app-shell{width:min(100%,1180px);padding-left:28px;padding-right:28px}
  .hero-card{min-height:190px}
  .hero-copy h2{font-size:var(--title-section)}
  .quick-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .widget-stack{grid-template-columns:1.08fr .92fr}
  .command-panel,.timeline-card:first-child{grid-column:auto}
  .assistant-preview{grid-column:1 / -1}
  .page[data-page="home"] .widget-stack{grid-template-columns:1fr}
  .page[data-page="home"] .widget-stack .timeline-card{grid-column:1 / -1}
  .page[data-page="apps"] .apps-catalog{grid-template-columns:repeat(4,minmax(0,1fr))}
  .page[data-page="apps"] .app-card{min-height:174px;padding:16px}
  .page[data-page="apps"] .app-icon{
    width:40px;
    height:40px;
    border-radius:15px;
    margin-bottom:10px;
    font-size:13px;
  }
  .page[data-page="apps"] .app-card h3{margin-bottom:8px}
  .page[data-page="apps"] .app-card p{font-size:14px;line-height:1.4;margin-bottom:12px}
  .page[data-page="apps"] .app-chip{min-height:30px;padding:6px 10px}
  .page[data-page="ops"] .widget-stack{grid-template-columns:.9fr 1.1fr}
  .page[data-page="client"] .apps-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .profile-grid{grid-template-columns:minmax(300px,.9fr) minmax(0,1.1fr)}
}

@media(max-width:720px){
  .top-actions{gap:6px}
  .profile-pill{min-height:40px;padding:9px 11px}
  .profile-button{max-width:138px}
  .admin-grid{grid-template-columns:1fr}
  .search-panel{grid-template-columns:auto minmax(0,1fr)}
  .search-panel select{grid-column:1 / -1}
  .admin-controls{grid-template-columns:1fr}
  .admin-controls input[data-admin-field="notes"]{grid-column:auto}
  .apps-grid{grid-template-columns:1fr 1fr}
  .list-item{display:grid}
  .list-item small{white-space:normal}
  .memory-item{grid-template-columns:1fr}
  .memory-actions{justify-content:space-between}
  .integration-row{grid-template-columns:1fr}
  .integration-row .quiet-btn{width:100%}
  .integration-state{width:100%}
  .call-widget-panel{
    left:0;
    right:0;
    width:100%;
    max-height:72vh;
  }
  .call-form-grid,.call-meta-grid{grid-template-columns:1fr}
  .transcript-turn{grid-template-columns:1fr}
  .transcript-turn strong{font-size:11px}
}

@media(max-width:430px){
  .app-shell{padding-left:14px;padding-right:14px}
  .auth-card{padding:18px}
  .otp-dialog{padding:20px}
  .otp-digits{gap:6px}
  .otp-digit{height:50px;font-size:24px;border-radius:14px}
  .otp-actions{grid-template-columns:1fr}
  .hero-card{padding:20px}
  .hero-copy h2{font-size:var(--title-section)}
  .hero-copy{max-width:250px}
  .profile-button{max-width:54px;padding:7px}
  .profile-name{display:none}
  .ai-orb{width:86px;height:86px;flex-basis:86px}
  .orb-core{width:64px;height:64px}
  .form-grid,.command-actions{grid-template-columns:1fr}
  .apps-grid{grid-template-columns:1fr}
  .bottom-nav{grid-template-columns:1fr 1fr 78px 1fr 1fr}
  .nav-item span:last-child{display:none}
  .command-head h3{font-size:var(--title-card)}
  .profile-actions{display:grid;grid-template-columns:1fr}
  .profile-actions .primary-btn,.profile-actions .ghost-btn{width:100%}
  .call-widget{bottom:96px}
  .call-widget-toggle{width:min(100%,220px)}
  .call-widget-panel{padding:14px}
  .call-widget-head{top:-14px;margin:-14px -14px 0;padding:14px 14px 11px}
  .call-chat-form{grid-template-columns:minmax(0,1fr) 44px}
}

@media(max-width:370px){
  .brand-mark{width:42px;height:42px;flex-basis:42px}
  .topbar h1{font-size:20px}
  .profile-pill{font-size:13px;padding:8px 9px}
  .profile-button{max-width:96px;padding-right:7px}
  .profile-name{display:none}
  .bottom-nav{width:calc(100% - 16px)}
}

/* Booking profile fields */
.section-hint{font-size:12px;font-weight:400;opacity:.55;margin-left:8px}
.booking-profile-fields{display:flex;flex-direction:column;gap:12px}
.profile-field-row{display:flex;flex-direction:column;gap:6px;position:relative}
.profile-field-label{font-size:12px;letter-spacing:.04em;text-transform:uppercase;opacity:.6}
.profile-field-input-row{display:flex;gap:8px;align-items:stretch}
.profile-field-input{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 14px;color:inherit;font-size:14px;transition:border-color .15s ease,background .15s ease}
.profile-field-input:focus{outline:none;border-color:rgba(127,232,201,.45);background:rgba(255,255,255,.06)}
.profile-field-save,.profile-field-clear{width:38px;display:flex;align-items:center;justify-content:center;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);color:inherit;cursor:pointer;font-size:14px;transition:transform .12s ease,background .15s ease,border-color .15s ease}
.profile-field-save:hover{background:rgba(127,232,201,.18);border-color:rgba(127,232,201,.4)}
.profile-field-clear:hover{background:rgba(255,140,140,.16);border-color:rgba(255,140,140,.38)}
.profile-field-save:active,.profile-field-clear:active{transform:scale(.96)}
.profile-field-status{position:absolute;top:0;right:0;font-size:11px;padding:3px 8px;border-radius:10px;background:rgba(127,232,201,.16);color:#9be9c8}
.profile-field-status[data-tone="error"]{background:rgba(255,140,140,.18);color:#ffb1b1}

/* SVG-иконки внутри metric/app/nav контейнеров */
.metric-icon svg{width:24px;height:24px;display:block}
.app-icon svg{width:30px;height:30px;display:block}
.nav-icon svg{width:22px;height:22px;display:block;margin:0 auto}
.nav-btn .nav-icon{font-size:0;display:flex;align-items:center;justify-content:center;height:24px}
.nav-item.active .nav-icon svg{filter:drop-shadow(0 0 8px rgba(82,255,224,.45))}
.app-icon{font-size:0;display:flex;align-items:center;justify-content:center}
.metric-icon{font-size:0;display:flex;align-items:center;justify-content:center}
.app-icon.habits{color:#bd9bff;background:rgba(189,155,255,.12)}

/* Компактная форма поручения */
.task-compact-form{padding:18px 18px 14px;display:flex;flex-direction:column;gap:14px}
.task-compact-form textarea{border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.03);border-radius:14px;padding:14px 16px;color:inherit;font-size:15px;line-height:1.45;resize:none;min-height:60px;transition:border-color .2s ease,background .2s ease}
.task-compact-form textarea:focus{outline:none;border-color:rgba(82,255,224,.4);background:rgba(255,255,255,.05)}
.task-form-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px}
.task-options-toggle{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.7);padding:9px 12px;border-radius:11px;font-size:13px;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}
.task-options-toggle:hover{background:rgba(255,255,255,.04);color:inherit;border-color:rgba(255,255,255,.16)}
.task-options-toggle[aria-expanded="true"]{background:rgba(82,255,224,.08);color:var(--accent);border-color:rgba(82,255,224,.3)}
.task-submit-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;font-size:14px}
.task-options-panel{display:flex;flex-direction:column;gap:14px;padding-top:6px;opacity:0;transform:translateY(-6px);transition:opacity .25s ease,transform .25s ease;will-change:opacity,transform}
.task-options-panel.is-open{opacity:1;transform:translateY(0)}
.task-options-panel select,.task-options-panel input{border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);border-radius:11px;padding:10px 14px;color:inherit;font-size:14px;transition:border-color .15s ease,background .15s ease}
.task-options-panel select:focus,.task-options-panel input:focus{outline:none;border-color:rgba(82,255,224,.35);background:rgba(255,255,255,.05)}
.task-options-panel .field-stack{display:flex;flex-direction:column;gap:6px}
.task-options-panel .field-label{font-size:11px;opacity:.55;text-transform:uppercase;letter-spacing:.06em}

/* Брендовый знак */
.brand-mark{background:transparent;overflow:visible;display:inline-flex;align-items:center;justify-content:center;position:relative}
.brand-mark span{display:none !important}
.brand-mark svg{width:36px;height:36px;display:block}
.brand-mark .brand-ring{transform-origin:16px 16px;animation:brandRingRotate 12s linear infinite}
.brand-mark .brand-core{transform-origin:16px 16px;animation:brandCorePulse 3.2s ease-in-out infinite}
@keyframes brandRingRotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes brandCorePulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.92);opacity:.85}}

/* FAB агент в навигации — центрирование SVG-логотипа */
.bot-fab{display:flex !important;align-items:center;justify-content:center}
.bot-face{background:transparent !important;overflow:visible;width:42px !important;height:42px !important;border-radius:50% !important;display:flex;align-items:center;justify-content:center;position:relative}
.bot-face::before,.bot-face::after,.bot-face i{display:none !important}
.bot-face svg{width:42px;height:42px;display:block}
.bot-face .bot-ring-outer{transform-origin:16px 16px;animation:brandRingRotate 18s linear infinite}
.bot-face .bot-core{animation:botCoreFloat 2.6s ease-in-out infinite;transform-origin:center}
.bot-face .bot-eye{animation:botBlink 5s ease-in-out infinite;transform-origin:center}
@keyframes botCoreFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-0.6px)}}
@keyframes botBlink{0%,40%,46%,100%{transform:scaleY(1)}43%{transform:scaleY(0.1)}}
.bot-fab:hover .bot-core{filter:brightness(1.08)}
.bot-fab:active{transform:translateY(2px) scale(.96)}

/* Аватар в чате */
.bot-avatar{background:transparent;overflow:visible;display:inline-flex;align-items:center;justify-content:center}
.bot-avatar span{display:none !important}
.bot-avatar svg{width:42px;height:42px;display:block}

/* ─── Apple-уровень: смягчение системы ──────────────────────────────── */
:root{
  --ease-out: cubic-bezier(.16, 1, .3, 1);
  --ease-soft: cubic-bezier(.4, 0, .2, 1);
  --duration-fast: 180ms;
  --duration-base: 260ms;
  --duration-slow: 420ms;
}
*,*::before,*::after{-webkit-tap-highlight-color:transparent}
button,.list-item,.app-card,.metric-card,.notification-item{transition:transform var(--duration-fast) var(--ease-soft), box-shadow var(--duration-base) var(--ease-soft), background var(--duration-base) var(--ease-soft), border-color var(--duration-base) var(--ease-soft), opacity var(--duration-base) var(--ease-soft)}
button:active:not(:disabled){transform:scale(.97)}
.app-card,.metric-card{transition:transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out)}
.app-card:hover,.metric-card:hover{transform:translateY(-2px)}
.app-card:active,.metric-card:active{transform:translateY(0) scale(.98)}
.app-card-active{cursor:pointer;position:relative}
.app-card-active::after{content:'';position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at top right, rgba(82,255,224,.08), transparent 50%);pointer-events:none;opacity:0;transition:opacity var(--duration-base) var(--ease-soft)}
.app-card-active:hover::after{opacity:1}

/* Переход между табами: плавный fade-in */
.page.screen{transition:opacity var(--duration-base) var(--ease-soft), transform var(--duration-base) var(--ease-soft)}
.page.screen.active{animation:pageEnter var(--duration-slow) var(--ease-out) both}
@keyframes pageEnter{from{opacity:0;transform:translateY(8px) scale(.995)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Списочные элементы — поэтапное появление */
.list-stack>*{animation:listItemEnter var(--duration-slow) var(--ease-out) both}
.list-stack>*:nth-child(1){animation-delay:0ms}
.list-stack>*:nth-child(2){animation-delay:40ms}
.list-stack>*:nth-child(3){animation-delay:80ms}
.list-stack>*:nth-child(4){animation-delay:120ms}
.list-stack>*:nth-child(5){animation-delay:160ms}
.list-stack>*:nth-child(6){animation-delay:200ms}
@keyframes listItemEnter{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ─── Habits ────────────────────────────────────────────────────────── */
.habit-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);transition:background var(--duration-base) var(--ease-soft),transform var(--duration-fast) var(--ease-soft)}
.habit-item:hover{background:rgba(255,255,255,.05)}
.habit-item.is-done{background:rgba(82,255,224,.06);border-color:rgba(82,255,224,.18)}
.habit-check{width:36px;height:36px;border-radius:50%;border:1.5px solid rgba(255,255,255,.18);background:transparent;color:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-base) var(--ease-soft)}
.habit-check svg{opacity:0;transform:scale(.6);transition:all var(--duration-base) var(--ease-out)}
.habit-check.is-active{background:linear-gradient(135deg,#52ffe0,#7a6bff);border-color:transparent;color:#0b1020;box-shadow:0 4px 14px rgba(82,255,224,.3)}
.habit-check.is-active svg{opacity:1;transform:scale(1)}
.habit-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.habit-content b{font-size:15px;color:#fff}
.habit-streak{font-size:12px;opacity:.6}
.habit-item.is-done .habit-streak{color:#7fe8c9;opacity:.9}
.habit-delete{width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:rgba(255,255,255,.3);cursor:pointer;font-size:16px;transition:all var(--duration-base) var(--ease-soft)}
.habit-delete:hover{background:rgba(255,140,140,.16);color:#ffb1b1}

/* ─── Goals ─────────────────────────────────────────────────────────── */
.goal-item{display:flex;gap:12px;padding:16px;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);align-items:flex-start}
.goal-item.is-done{opacity:.65}
.goal-item.is-done .goal-content b{text-decoration:line-through}
.goal-content{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.goal-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.goal-head b{font-size:15px;color:#fff}
.goal-date{font-size:11px;opacity:.55;white-space:nowrap}
.goal-description{font-size:13px;opacity:.65;line-height:1.4}
.goal-progress-row{display:flex;align-items:center;gap:10px;margin-top:6px}
.goal-progress-row input[type="range"]{flex:1;-webkit-appearance:none;background:rgba(255,255,255,.08);height:6px;border-radius:3px;outline:none;cursor:pointer}
.goal-progress-row input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#52ffe0,#7a6bff);cursor:grab;box-shadow:0 2px 6px rgba(0,0,0,.3);transition:transform var(--duration-fast) var(--ease-soft)}
.goal-progress-row input[type="range"]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}
.goal-progress-value{font-size:12px;font-weight:600;color:#7fe8c9;min-width:38px;text-align:right}
.goal-actions{display:flex;flex-direction:column;gap:6px}
.goal-done,.goal-delete{width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.08);background:transparent;color:rgba(255,255,255,.4);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-base) var(--ease-soft)}
.goal-done.is-active{background:rgba(82,255,224,.18);border-color:transparent;color:#52ffe0}
.goal-done:hover{background:rgba(82,255,224,.1);color:#7fe8c9}
.goal-delete:hover{background:rgba(255,140,140,.14);color:#ffb1b1;border-color:transparent}

/* ─── Dashboard Widgets ─────────────────────────────────────────────── */
.dashboard-widget{position:relative;padding:18px 18px 16px;border-radius:18px;cursor:pointer;display:flex;flex-direction:column;gap:14px;animation:listItemEnter var(--duration-slow) var(--ease-out) both}
.dashboard-widget:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,0,0,.3)}
.dashboard-widget.is-dragging{opacity:.85;transform:scale(1.02);z-index:10;box-shadow:0 18px 50px rgba(0,0,0,.5);cursor:grabbing}
.widget-handle{position:absolute;top:14px;right:50px;opacity:0;color:rgba(255,255,255,.4);transition:opacity var(--duration-base) var(--ease-soft);cursor:grab;touch-action:none}
.dashboard-widget:hover .widget-handle{opacity:1}
.widget-handle:active{cursor:grabbing}
.widget-remove{position:absolute;top:12px;right:14px;width:26px;height:26px;border-radius:50%;border:none;background:rgba(255,255,255,.06);color:rgba(255,255,255,.5);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--duration-base) var(--ease-soft)}
.dashboard-widget:hover .widget-remove{opacity:1}
.widget-remove:hover{background:rgba(255,140,140,.2);color:#ffb1b1}
.widget-header{display:flex;align-items:center;gap:12px}
.widget-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);color:#fff;flex-shrink:0}
.widget-title-block{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.widget-title{font-size:15px;font-weight:600;color:#fff}
.widget-subtitle{font-size:12px;opacity:.55}
.widget-body{display:flex;flex-direction:column;gap:14px}
.widget-metric{display:flex;align-items:baseline;gap:10px}
.widget-metric strong{font-size:26px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}
.widget-metric span{font-size:13px;opacity:.55}
.widget-preview{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px;border-top:1px solid rgba(255,255,255,.06);padding-top:12px}
.widget-preview li{font-size:13px;opacity:.78;display:flex;justify-content:space-between;gap:8px;align-items:center}
.widget-preview li.done{opacity:.5;text-decoration:line-through}
.widget-preview li.empty{opacity:.4;font-style:italic}
.widget-preview li small{font-size:11px;opacity:.55}
.widget-accent,.widget-tasks .widget-icon{background:rgba(82,255,224,.12);color:#7fe8c9}
.widget-cool .widget-icon{background:rgba(122,107,255,.14);color:#bda5ff}
.widget-warm .widget-icon{background:rgba(255,209,102,.14);color:#ffd166}
.widget-violet .widget-icon{background:rgba(141,107,255,.16);color:#b29eff}
.widget-mint .widget-icon{background:rgba(127,232,201,.16);color:#7fe8c9}
.widget-empty{padding:30px 20px;text-align:center}

.add-widget-fab{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:rgba(255,255,255,.04);border:1.5px dashed rgba(255,255,255,.14);border-radius:14px;color:rgba(255,255,255,.7);cursor:pointer;font-size:14px;transition:all var(--duration-base) var(--ease-soft);margin-top:8px}
.add-widget-fab:hover{background:rgba(82,255,224,.06);border-color:rgba(82,255,224,.3);color:#7fe8c9}

/* Каталог виджетов — тот же стиль что у nutrition-sheet */
.widget-catalog-backdrop[hidden]{display:none !important}
.widget-catalog-backdrop{
  position:fixed;inset:0;
  background:rgba(11,16,32,.72);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  z-index:1100;
  display:flex;align-items:flex-end;justify-content:center;
  padding:0;
  opacity:0;
  transition:opacity var(--duration-base) var(--ease-soft);
}
.widget-catalog-backdrop.is-open{opacity:1}
.widget-catalog{
  width:100%;max-width:100%;
  height:92vh;max-height:92vh;
  border-radius:24px 24px 0 0;
  padding:20px 18px max(24px, env(safe-area-inset-bottom));
  display:flex;flex-direction:column;gap:18px;
  transform:translateY(100%);
  transition:transform var(--duration-slow) var(--ease-out);
  overflow-y:auto;overflow-x:hidden;
  box-shadow:0 -20px 60px rgba(0,0,0,.5);
  border-top:1px solid rgba(255,255,255,.06);
  border-left:none;border-right:none;border-bottom:none;
  -webkit-overflow-scrolling:touch;
  box-sizing:border-box;
}
.widget-catalog-backdrop.is-open .widget-catalog{transform:translateY(0)}
/* Drag-handle сверху как в nutrition-sheet */
.widget-catalog::before{
  content:'';
  position:sticky;top:0;
  display:block;
  width:36px;height:4px;
  background:rgba(255,255,255,.18);
  border-radius:2px;
  margin:-8px auto 4px;
  flex-shrink:0;
}
.widget-catalog > *{max-width:100%;box-sizing:border-box}

/* Десктоп: модалка по центру со всеми скруглениями */
@media (min-width: 768px){
  .widget-catalog-backdrop{
    align-items:center;
    padding:24px;
  }
  .widget-catalog{
    max-width:560px;
    height:auto;
    max-height:min(85vh, 720px);
    border-radius:24px;
    border:1px solid rgba(255,255,255,.08);
    transform:translateY(20px) scale(.96);
    box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
    padding:28px;
  }
  .widget-catalog::before{display:none}
  .widget-catalog-backdrop.is-open .widget-catalog{transform:translateY(0) scale(1)}
}
.widget-catalog-head{display:flex;justify-content:space-between;align-items:flex-start}
.widget-catalog-list{display:flex;flex-direction:column;gap:10px;max-height:60vh;overflow-y:auto}
.widget-catalog-item{display:flex;align-items:center;gap:14px;padding:14px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);cursor:pointer;text-align:left;transition:all var(--duration-base) var(--ease-soft)}
.widget-catalog-item:hover:not(:disabled){background:rgba(255,255,255,.07);transform:translateY(-1px)}
.widget-catalog-item.is-installed{opacity:.45;cursor:default}
.widget-catalog-text{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.widget-catalog-text strong{font-size:14px;color:#fff}
.widget-catalog-text span{font-size:12px;opacity:.6}
.widget-catalog-state{font-size:12px;color:#7fe8c9;font-weight:600;white-space:nowrap}
.widget-catalog-item.is-installed .widget-catalog-state{color:rgba(255,255,255,.4)}

/* ─── Notifications ──────────────────────────────────────────────────── */
.notifications-button{position:relative;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.75);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-base) var(--ease-soft)}
.notifications-button:hover{background:rgba(255,255,255,.08);color:#fff}
.notifications-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:linear-gradient(135deg,#ff6b8a,#ff8c5a);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;animation:badgePop var(--duration-base) var(--ease-out)}
@keyframes badgePop{from{transform:scale(0)}to{transform:scale(1)}}

.notifications-panel[hidden]{display:none !important}
.notifications-panel:not([hidden]){position:fixed;top:72px;right:14px;width:min(370px,calc(100vw - 28px));max-height:70vh;display:flex;flex-direction:column;gap:14px;padding:18px;z-index:900;opacity:0;transform:translateY(-8px) scale(.97);transform-origin:top right;transition:opacity var(--duration-base) var(--ease-soft),transform var(--duration-base) var(--ease-soft)}
.notifications-panel.is-open{opacity:1;transform:translateY(0) scale(1)}
.notifications-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.notifications-actions{display:flex;gap:8px;align-items:center}
.notifications-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:50vh}
.notification-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);transition:background var(--duration-base) var(--ease-soft)}
.notification-item.is-unread{background:rgba(82,255,224,.05);border-color:rgba(82,255,224,.15)}
.notification-item:hover{background:rgba(255,255,255,.06)}
.notification-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(82,255,224,.12);color:#7fe8c9;flex-shrink:0}
.notification-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.notification-body b{font-size:13px;color:#fff}
.notification-body span{font-size:12px;opacity:.7;line-height:1.4}
.notification-body small{font-size:11px;opacity:.4;margin-top:4px}
.notification-dismiss{width:26px;height:26px;border-radius:50%;border:none;background:transparent;color:rgba(255,255,255,.4);cursor:pointer;font-size:14px;transition:all var(--duration-fast) var(--ease-soft)}
.notification-dismiss:hover{background:rgba(255,140,140,.14);color:#ffb1b1}
.notifications-foot{padding-top:8px;border-top:1px solid rgba(255,255,255,.06)}

/* ─── Toast ─────────────────────────────────────────────────────────── */
.toast-container{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:1200;display:flex;flex-direction:column;gap:10px;pointer-events:none;align-items:center}
.toast{pointer-events:auto;min-width:280px;max-width:380px;padding:14px 18px;border-radius:14px;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;opacity:0;transform:translateY(-20px);transition:opacity var(--duration-base) var(--ease-soft),transform var(--duration-base) var(--ease-out)}
.toast.is-visible{opacity:1;transform:translateY(0)}
.toast-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.toast-content b{font-size:14px;color:#fff}
.toast-content span{font-size:12px;opacity:.75}
.toast-close{width:24px;height:24px;border-radius:50%;border:none;background:transparent;color:rgba(255,255,255,.5);cursor:pointer;font-size:14px;flex-shrink:0;transition:all var(--duration-fast) var(--ease-soft)}
.toast-close:hover{background:rgba(255,255,255,.08);color:#fff}

/* ─── Скелетон лоадер ─────────────────────────────────────────────── */
.skeleton{background:linear-gradient(90deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 100%);background-size:200% 100%;animation:skeletonShimmer 1.4s ease-in-out infinite;border-radius:8px}
@keyframes skeletonShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ─── Reduced motion ─────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
}

/* ─── Чат — красивые пузыри в стиле iOS Messages ─────────────── */
.chat-log{padding:14px 14px 6px;display:flex;flex-direction:column;gap:14px;scroll-behavior:smooth}
.msg{display:flex;gap:10px;animation:msgEnter var(--duration-slow) var(--ease-out) both}
@keyframes msgEnter{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.msg.user{justify-content:flex-end}
.msg.assistant{justify-content:flex-start}
.msg-avatar{width:28px;height:28px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;align-self:flex-end;margin-bottom:2px}
.msg-avatar svg{width:28px;height:28px;display:block}
.msg-bubble{max-width:78%;display:flex;flex-direction:column;gap:8px}
.msg-text{padding:11px 15px;border-radius:20px;font-size:14.5px;line-height:1.45;letter-spacing:.01em;word-wrap:break-word;white-space:pre-wrap}
.msg.user .msg-text{background:linear-gradient(135deg,#52ffe0,#7fe8c9);color:#0a1320;border-bottom-right-radius:6px;font-weight:500;box-shadow:0 6px 18px rgba(82,255,224,.18)}
.msg.assistant .msg-text{background:rgba(255,255,255,.06);color:#e8efff;border-bottom-left-radius:6px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05)}
.msg-text a{color:#7fe8c9;text-decoration:underline}
.msg.user .msg-text a{color:#0a1320}

/* Quick replies */
.quick-replies{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.quick-reply{background:rgba(82,255,224,.08);border:1px solid rgba(82,255,224,.22);color:#9be9c8;padding:7px 13px;border-radius:18px;font-size:13px;cursor:pointer;transition:all var(--duration-fast) var(--ease-soft);font-weight:500}
.quick-reply:hover{background:rgba(82,255,224,.14);border-color:rgba(82,255,224,.4);transform:translateY(-1px)}
.quick-reply:active{transform:translateY(0) scale(.97)}

/* Composer (input area) */
.composer{padding:10px 12px 16px;background:linear-gradient(180deg,rgba(11,16,32,0),rgba(11,16,32,.92) 30%);position:sticky;bottom:0;display:flex;align-items:flex-end;gap:8px}
.composer textarea{flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:11px 18px;color:#fff;font-size:14.5px;resize:none;max-height:120px;min-height:42px;transition:all var(--duration-base) var(--ease-soft);line-height:1.4}
.composer textarea:focus{outline:none;border-color:rgba(82,255,224,.4);background:rgba(255,255,255,.07)}
.composer textarea::placeholder{color:rgba(255,255,255,.35)}
.attach-button,.send-button{width:42px;height:42px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-base) var(--ease-soft)}
.attach-button{background:rgba(255,255,255,.06);color:rgba(255,255,255,.65)}
.attach-button:hover{background:rgba(255,255,255,.1);color:#fff;transform:rotate(15deg)}
.send-button{background:linear-gradient(135deg,#52ffe0,#7a6bff);color:#0a1320;font-size:20px;box-shadow:0 6px 18px rgba(82,255,224,.25)}
.send-button:hover{box-shadow:0 8px 26px rgba(82,255,224,.4)}
.send-button:active{transform:scale(.92)}

/* Mic button — Telegram-style press-and-hold */
.mic-button{width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,#52ffe0,#7a6bff);color:#0a1320;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--duration-base) var(--ease-soft);box-shadow:0 6px 18px rgba(82,255,224,.25);user-select:none;-webkit-user-select:none;touch-action:none}
.mic-button:hover{box-shadow:0 8px 26px rgba(82,255,224,.4)}
.mic-button.is-recording{background:linear-gradient(135deg,#ff5a8a,#ff7a3a);box-shadow:0 8px 30px rgba(255,90,138,.5);animation:micPulse 1.4s ease-in-out infinite}
@keyframes micPulse{0%,100%{box-shadow:0 8px 30px rgba(255,90,138,.5),0 0 0 0 rgba(255,90,138,.5)}50%{box-shadow:0 8px 30px rgba(255,90,138,.4),0 0 0 12px rgba(255,90,138,0)}}
.mic-button svg{width:22px;height:22px}
.mic-button .pulse,.mic-button .record-glyph,.mic-button .record-text{display:none}

/* Hint bubble over mic button */
.mic-hint{position:absolute;bottom:120%;right:0;background:rgba(11,16,32,.95);border:1px solid rgba(82,255,224,.3);color:#fff;padding:10px 14px;border-radius:14px;font-size:13px;white-space:nowrap;pointer-events:none;opacity:0;transform:translateY(8px);transition:all var(--duration-base) var(--ease-out);box-shadow:0 12px 30px rgba(0,0,0,.4);z-index:50}
.mic-hint.is-visible{opacity:1;transform:translateY(0)}
.mic-hint::after{content:'';position:absolute;top:100%;right:22px;border:6px solid transparent;border-top-color:rgba(11,16,32,.95)}

/* Recording overlay (zaжато) */
.recording-overlay{position:absolute;bottom:60px;right:14px;left:14px;background:rgba(11,16,32,.95);border:1px solid rgba(255,90,138,.4);border-radius:18px;padding:14px 18px;display:flex;align-items:center;gap:14px;box-shadow:0 18px 50px rgba(255,90,138,.25);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:60}
.recording-overlay-dot{width:14px;height:14px;border-radius:50%;background:#ff5a8a;flex-shrink:0;animation:recDotPulse 1.2s ease-in-out infinite}
@keyframes recDotPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
.recording-overlay-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}
.recording-overlay-info b{font-size:14px;color:#fff}
.recording-overlay-info span{font-size:12px;opacity:.65}
.recording-overlay-timer{font-size:16px;font-weight:600;color:#ff8c5a;font-variant-numeric:tabular-nums}
.recording-overlay-cancel{background:rgba(255,90,138,.15);color:#ffb1b1;border:none;padding:8px 14px;border-radius:12px;font-size:13px;cursor:pointer}
.recording-waveform{flex:1;display:flex;align-items:center;gap:3px;height:24px}
.recording-waveform span{flex:1;background:linear-gradient(180deg,#ff5a8a,#ff8c5a);border-radius:2px;opacity:.85;transition:height 80ms linear}

/* Chat tools row */
.chat-tools{display:flex;gap:8px;padding:0 14px 4px;align-items:center}
.chat-tools select{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:8px 14px;color:#fff;font-size:13px;max-width:50%}

/* Bot sheet header polish */
.bot-header{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;gap:12px}

/* ─── Schedule builder для привычек ───────────────────────── */
.schedule-builder{display:flex;flex-direction:column;gap:10px;padding:12px;background:rgba(255,255,255,.02);border-radius:14px;border:1px solid rgba(255,255,255,.04)}
.schedule-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;opacity:.55;font-weight:600}
.schedule-presets{display:flex;flex-wrap:wrap;gap:6px}
.schedule-preset{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.7);padding:8px 13px;border-radius:14px;font-size:13px;cursor:pointer;transition:all var(--duration-fast) var(--ease-soft)}
.schedule-preset:hover{background:rgba(255,255,255,.07);color:#fff}
.schedule-preset.is-active{background:linear-gradient(135deg,rgba(82,255,224,.2),rgba(122,107,255,.2));border-color:rgba(82,255,224,.4);color:#7fe8c9;font-weight:600}
.schedule-days-picker{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding-top:6px}
.schedule-day{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.7);padding:10px 0;border-radius:10px;font-size:12px;cursor:pointer;text-align:center;transition:all var(--duration-fast) var(--ease-soft)}
.schedule-day:hover{background:rgba(255,255,255,.07)}
.schedule-day.is-active{background:linear-gradient(135deg,#52ffe0,#7a6bff);color:#0a1320;border-color:transparent;font-weight:700}
.schedule-count-picker{display:flex;flex-direction:column;gap:8px;padding-top:6px}
.schedule-count-picker span{font-size:12px;opacity:.7}
.schedule-count-row{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.schedule-count-btn{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.7);padding:8px 0;border-radius:10px;font-size:13px;cursor:pointer;text-align:center;transition:all var(--duration-fast) var(--ease-soft);font-weight:600}
.schedule-count-btn:hover{background:rgba(255,255,255,.07)}
.schedule-count-btn.is-active{background:linear-gradient(135deg,#52ffe0,#7a6bff);color:#0a1320;border-color:transparent}

/* Habit schedule label inside list-item */
.habit-schedule{font-size:11px;opacity:.5;margin-top:2px;text-transform:lowercase}
.habit-skip{font-size:11px;color:rgba(255,209,102,.7);margin-top:2px}
.habit-item.is-skip{opacity:.65}

/* Habit mini in widget */
.habit-mini{display:flex;align-items:center;gap:8px}
.habit-mini-check{width:22px;height:22px;border-radius:50%;border:1.5px solid rgba(255,255,255,.18);background:transparent;color:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-base) var(--ease-soft);padding:0}
.habit-mini-check svg{opacity:0;transform:scale(.6);transition:all var(--duration-base) var(--ease-out)}
.habit-mini-check.is-active{background:linear-gradient(135deg,#52ffe0,#7a6bff);border-color:transparent;color:#0a1320}
.habit-mini-check.is-active svg{opacity:1;transform:scale(1)}
.habit-mini span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.habit-mini.done{opacity:.55}
.habit-mini.done span{text-decoration:line-through}

/* Goals — без ползунка, чек слева */
.goal-check{width:36px;height:36px;border-radius:50%;border:1.5px solid rgba(255,255,255,.18);background:transparent;color:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-base) var(--ease-soft);align-self:flex-start;margin-top:4px}
.goal-check svg{opacity:0;transform:scale(.6);transition:all var(--duration-base) var(--ease-out)}
.goal-check.is-active{background:linear-gradient(135deg,#52ffe0,#7a6bff);border-color:transparent;color:#0a1320}
.goal-check.is-active svg{opacity:1;transform:scale(1)}


/* ─── Auth — двухшаговый логин ──────────────────────────── */
.auth-step-back{font-size:12px;opacity:.55;margin:0 0 4px;letter-spacing:.02em}
.auth-step-title{font-size:20px;font-weight:600;color:#fff;margin:0 0 8px}
#nameAuth{animation:authStepEnter var(--duration-base) var(--ease-out) both}
@keyframes authStepEnter{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ─── Admin plans CRUD ─────────────────────────────────────────────── */
.admin-plan-card{
  display:grid;
  gap:12px;
  padding:14px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(11,20,35,.42);
}
.admin-plan-new{
  border-color:rgba(82,255,224,.22);
  background:rgba(82,255,224,.055);
}
.admin-plan-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
  align-items:start;
}
.admin-plan-head b{display:block;font-size:15px;color:#fff}
.admin-plan-head span{display:block;margin-top:4px;color:var(--muted);font-size:13px;line-height:1.35}
.admin-plan-head small{color:var(--accent);font-weight:850;white-space:nowrap}
.admin-plan-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}
.admin-plan-form textarea{grid-column:1 / -1;min-height:74px}
.admin-plan-form .primary-btn,
.admin-plan-actions{grid-column:1 / -1}
.admin-plan-actions{display:flex;gap:8px;flex-wrap:wrap}
.quiet-btn.danger{color:#ffd9e1;border-color:rgba(255,107,138,.32);background:rgba(255,107,138,.1)}
.primary-btn.compact,.quiet-btn.compact{min-height:36px;padding:8px 10px;border-radius:13px;font-size:12px}

/* ─── Apps as iPhone-like icons ────────────────────────────────────── */
.page[data-page="apps"] .apps-search-panel{
  margin-bottom:4px;
  border-radius:24px;
  background:rgba(255,255,255,.08);
}
.apps-catalog{
  grid-template-columns:repeat(auto-fill,minmax(104px,1fr));
  gap:22px 14px;
  align-items:start;
  padding:18px 4px 4px;
}
.app-card,
.page[data-page="apps"] .app-card{
  min-height:142px;
  padding:8px 5px;
  align-items:center;
  justify-content:flex-start;
  text-align:center;
  border:0;
  background:transparent;
  box-shadow:none;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.app-card:hover{transform:translateY(-3px)}
.app-card:active .app-icon{transform:scale(.9);filter:saturate(1.14) brightness(1.07)}
.app-icon,
.page[data-page="apps"] .app-icon{
  width:70px;
  height:70px;
  margin:0 0 9px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.22);
  box-shadow:0 16px 36px rgba(5,10,20,.3), inset 0 1px 0 rgba(255,255,255,.35);
  color:#fff;
  transition:transform var(--duration-base) var(--ease-out),filter var(--duration-base) var(--ease-soft);
}
.app-icon svg{width:33px;height:33px}
.app-icon.food{background:linear-gradient(145deg,#38d18a,#f4c542);color:#08331f}
.app-icon.sport{background:linear-gradient(145deg,#1f2937,#b7ff4a);color:#faffef}
.app-icon.habits{background:linear-gradient(145deg,#8d6bff,#52ffe0);color:#080f1b}
.app-icon.money{background:linear-gradient(145deg,#0f8b6f,#ffd166);color:#06251e}
.app-icon.travel{background:linear-gradient(145deg,#2f80ed,#ff7a59);color:#fff}
.app-icon.docs{background:linear-gradient(145deg,#f8fbff,#7aa7ff);color:#17233b}
.app-icon.health{background:linear-gradient(145deg,#ff5a8a,#ffd1dc);color:#351020}
.app-icon.home{background:linear-gradient(145deg,#26364f,#69f0ae);color:#f7fff9}
.app-card h3,
.page[data-page="apps"] .app-card h3{
  width:100%;
  margin:0;
  font-size:13px;
  line-height:1.18;
  font-weight:850;
  color:#fff;
}
.app-card p,
.page[data-page="apps"] .app-card p{
  width:100%;
  margin:5px 0 0;
  color:rgba(244,248,255,.58);
  font-size:11px;
  line-height:1.25;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.app-chip,
.page[data-page="apps"] .app-chip{
  min-height:22px;
  margin-top:7px;
  padding:4px 7px;
  border-radius:999px;
  font-size:10px;
  background:rgba(255,255,255,.08);
}
.app-chip.active{background:rgba(255,255,255,.9);color:#101827}

/* ─── Nutrition AI ─────────────────────────────────────────────────── */
.nutrition-date{
  width:auto;
  min-width:148px;
  min-height:42px;
  padding:10px 12px;
  border-radius:15px;
}
.nutrition-hero{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:18px;
  align-items:center;
  padding:18px;
  border-radius:26px;
  background:
    linear-gradient(135deg,rgba(56,209,138,.18),rgba(255,209,102,.1)),
    rgba(255,255,255,.08);
}
.nutrition-score{display:flex;align-items:center;gap:16px;min-width:0}
.nutrition-score h3{margin:0 0 5px}
.nutrition-score p:last-child{margin:0;color:var(--muted);line-height:1.38}
.nutrition-ring{
  --value:0%;
  width:116px;
  height:116px;
  flex:0 0 116px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  border-radius:50%;
  background:conic-gradient(#38d18a var(--value),rgba(255,255,255,.12) 0);
  position:relative;
}
.nutrition-ring::after{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:50%;
  background:#f7f8fb;
  box-shadow:inset 0 1px 8px rgba(15,23,42,.08);
}
.nutrition-ring span,.nutrition-ring small{position:relative;z-index:1;color:#111827}
.nutrition-ring span{font-size:26px;font-weight:900;line-height:1}
.nutrition-ring small{max-width:74px;margin:0;text-align:center;font-size:10px;line-height:1.08;color:#657084;font-weight:800}
.nutrition-macro-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.nutrition-macro-grid div{
  min-height:70px;
  padding:12px;
  border-radius:17px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
}
.nutrition-macro-grid b{display:block;color:#fff;font-size:16px;line-height:1.18}
.nutrition-macro-grid span{display:block;margin-top:5px;color:var(--muted);font-size:12px}
.nutrition-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
  margin-top:16px;
  margin-bottom:16px;
}
.nutrition-photo-drop{
  position:relative;
  display:grid;
  gap:6px;
  min-height:118px;
  align-content:center;
  padding:16px;
  border-radius:22px;
  border:1.5px dashed rgba(56,209,138,.34);
  background:linear-gradient(135deg,rgba(56,209,138,.1),rgba(255,209,102,.07));
  cursor:pointer;
  overflow:hidden;
}
.nutrition-photo-drop input{position:absolute;inset:0;opacity:0;cursor:pointer}
.nutrition-photo-drop span{font-size:18px;font-weight:900;color:#fff}
.nutrition-photo-drop small{color:var(--muted)}
.nutrition-number-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
}
.nutrition-meal-item{
  display:grid;
  grid-template-columns:58px minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
}
.nutrition-meal-item img,.nutrition-meal-icon{
  width:58px;
  height:58px;
  border-radius:18px;
  object-fit:cover;
  background:linear-gradient(145deg,#38d18a,#ffd166);
}
.nutrition-meal-icon{
  display:grid;
  place-items:center;
  color:#102018;
  font-weight:900;
}
.nutrition-meal-body{min-width:0}
.nutrition-meal-body small{
  display:block;
  margin-top:5px;
  color:var(--muted-2);
  line-height:1.34;
  white-space:normal;
}
.widget-fresh .widget-icon{background:rgba(56,209,138,.16);color:#8dffbf}

/* ─── Habit widget strike fix ──────────────────────────────────────── */
.widget-preview li.habit-mini.done{text-decoration:none}
.habit-mini-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.habit-mini.done .habit-mini-title{text-decoration:line-through}
.habit-mini-streak{flex:0 0 auto;color:#ffd166;opacity:1;text-decoration:none}

/* ─── Chat: calm iOS-like surface ──────────────────────────────────── */
.sheet-backdrop{background:rgba(5,10,20,.52);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.sheet-panel{
  width:min(100%,640px);
  max-height:91vh;
  gap:0;
  padding:8px 0 max(12px,env(safe-area-inset-bottom));
  border-radius:30px 30px 0 0;
  background:#f4f5f8;
  border:1px solid rgba(255,255,255,.65);
  box-shadow:0 -28px 70px rgba(0,0,0,.28);
  overflow:hidden;
}
.sheet-handle{background:rgba(17,24,39,.18);margin:3px auto 1px}
.bot-header{
  padding:12px 16px 13px;
  border-bottom:1px solid rgba(17,24,39,.08);
  background:rgba(249,250,252,.86);
  color:#121826;
}
.bot-header .eyebrow{color:#007aff}
.bot-header h2{color:#121826}
.bot-avatar{
  width:44px;
  height:44px;
  border-radius:16px;
  background:linear-gradient(145deg,#0a84ff,#34c759);
  box-shadow:0 10px 24px rgba(10,132,255,.24);
}
.bot-avatar svg{width:36px;height:36px}
.bot-header .icon-button{
  color:#1f2937;
  background:rgba(17,24,39,.06);
  border:1px solid rgba(17,24,39,.05);
}
.chat-log-shell{
  min-height:220px;
  background:
    linear-gradient(180deg,#f8f9fb 0%,#eef1f6 100%);
}
.chat-log{
  padding:16px 14px 12px;
  gap:10px;
}
.msg{
  width:100%;
  max-width:none;
  padding:0;
  border-radius:0;
  background:transparent;
  border:0;
  display:flex;
  gap:8px;
  line-height:1.4;
  white-space:normal;
}
.msg.user{justify-content:flex-end;background:transparent;color:inherit;margin-left:0}
.msg.assistant{justify-content:flex-start;background:transparent;border:0}
.msg-avatar{width:30px;height:30px;margin-bottom:2px;align-self:flex-end}
.msg-avatar svg{width:30px;height:30px}
.msg-bubble{max-width:min(78%,430px);gap:7px}
.msg-text{
  padding:10px 13px;
  border-radius:19px;
  font-size:15px;
  line-height:1.42;
  letter-spacing:0;
  color:#121826;
  background:#fff;
  box-shadow:0 1px 1px rgba(17,24,39,.05),0 8px 24px rgba(17,24,39,.06);
  border:1px solid rgba(17,24,39,.04);
}
.msg.user .msg-text{
  color:#fff;
  background:linear-gradient(180deg,#0a84ff,#0072e5);
  border:0;
  border-bottom-right-radius:6px;
  box-shadow:0 8px 22px rgba(10,132,255,.2);
}
.msg.assistant .msg-text{
  background:#fff;
  color:#121826;
  border-bottom-left-radius:6px;
}
.msg-text a{color:#006bd6}
.msg.user .msg-text a{color:#fff}
.quick-replies{gap:7px;margin-top:0}
.quick-reply{
  min-height:34px;
  color:#006bd6;
  background:rgba(10,132,255,.09);
  border:1px solid rgba(10,132,255,.16);
  font-weight:750;
}
.chat-tools{
  padding:10px 14px 8px;
  background:#f4f5f8;
  border-top:1px solid rgba(17,24,39,.06);
}
.chat-tools select{
  max-width:none;
  min-height:38px;
  color:#172033;
  background:#fff;
  border:1px solid rgba(17,24,39,.09);
  border-radius:13px;
  box-shadow:0 5px 18px rgba(17,24,39,.04);
}
.chat-tools .mic-button,.mic-button{
  width:46px;
  height:46px;
  border-radius:50%;
  color:#fff;
  background:#34c759;
  box-shadow:0 8px 20px rgba(52,199,89,.22);
}
.composer{
  position:relative;
  bottom:auto;
  gap:8px;
  padding:8px 14px 0;
  background:#f4f5f8;
  border:0;
  border-radius:0;
}
.composer textarea{
  min-height:42px;
  max-height:132px;
  padding:10px 15px;
  color:#121826;
  background:#fff;
  border:1px solid rgba(17,24,39,.09);
  border-radius:20px;
  box-shadow:0 6px 20px rgba(17,24,39,.05);
}
.composer textarea::placeholder{color:#8b95a5}
.composer textarea:focus{
  border-color:rgba(10,132,255,.45);
  background:#fff;
  box-shadow:0 0 0 4px rgba(10,132,255,.09);
}
.attach-button,.send-button{
  width:42px;
  height:42px;
  border-radius:50%;
}
.attach-button{
  color:#007aff;
  background:rgba(10,132,255,.09);
  border:1px solid rgba(10,132,255,.08);
}
.send-button{
  color:#fff;
  background:#007aff;
  box-shadow:0 8px 22px rgba(0,122,255,.24);
}
.chat-scroll-btn{
  color:#fff;
  background:#007aff;
  border:0;
  box-shadow:0 12px 26px rgba(0,122,255,.22);
}
.recording-overlay{
  background:rgba(255,255,255,.96);
  color:#121826;
  border-color:rgba(255,69,58,.22);
}
.recording-overlay-info b{color:#121826}
.recording-overlay-info span{color:#647084;opacity:1}

/* ─── Nutrition AI: onboarding, database, drinks ───────────────────── */
.nutrition-head-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.nutrition-onboarding{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:18px;
  align-items:stretch;
  margin-bottom:16px;
  padding:20px;
  border-radius:26px;
  background:
    linear-gradient(135deg,rgba(56,209,138,.18),rgba(255,209,102,.08) 46%,rgba(122,107,255,.12)),
    rgba(255,255,255,.08);
}
.nutrition-onboarding[hidden]{display:none}
.nutrition-onboarding-copy{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:18px;
  min-height:100%;
}
.nutrition-onboarding-copy h3,.nutrition-advice h3{margin:0 0 6px;font-size:24px}
.nutrition-onboarding-copy p:last-of-type,.nutrition-advice p{margin:0;color:var(--muted);line-height:1.42}
.nutrition-onboard-preview{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.nutrition-onboard-preview span{
  padding:8px 10px;
  border-radius:13px;
  color:#102018;
  background:rgba(141,255,191,.88);
  font-weight:900;
  font-size:13px;
}
.nutrition-onboard-form{display:grid;gap:10px}
.nutrition-slider{display:grid;gap:8px;color:var(--muted);font-size:13px;font-weight:800}
.nutrition-slider div{display:grid;grid-template-columns:minmax(0,1fr) 96px;gap:10px;align-items:center}
.nutrition-slider input[type="range"]{accent-color:#38d18a}
.nutrition-slider input[type="number"]{text-align:center}
.nutrition-advice{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:16px;
  padding:16px 18px;
  border-radius:22px;
  background:
    linear-gradient(135deg,rgba(122,107,255,.14),rgba(82,255,224,.09)),
    rgba(255,255,255,.07);
}
.nutrition-advice span{
  flex:0 0 auto;
  padding:9px 11px;
  border-radius:999px;
  color:#101827;
  background:#ffd166;
  font-weight:900;
  font-size:13px;
}
.nutrition-settings{
  margin-top:16px;
  padding:16px;
  border-radius:22px;
}
.nutrition-drink-hint{
  margin:8px 0 10px;
  color:var(--muted);
  font-size:12px;
  line-height:1.35;
}
.nutrition-drinks-list,.nutrition-foods-list{display:grid;gap:8px;margin-top:10px}
.nutrition-drink-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:8px 9px;
  border-radius:14px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
  color:var(--muted);
}
.nutrition-drink-row b{color:#8dffbf}
.nutrition-drink-row.muted-row{grid-template-columns:1fr}
.nutrition-weight-form{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}
.nutrition-food-row{
  width:100%;
  display:grid;
  gap:3px;
  padding:10px 11px;
  border-radius:15px;
  text-align:left;
  color:var(--text);
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
  cursor:pointer;
}
.nutrition-food-row:hover,.nutrition-food-row.active{
  background:rgba(82,255,224,.12);
  border-color:rgba(82,255,224,.28);
}
.nutrition-food-row span{color:var(--muted);font-size:12px;line-height:1.3}
.nutrition-meal-item{
  grid-template-columns:58px minmax(0,1fr) auto auto;
  align-items:start;
}
.nutrition-expand-btn{
  align-self:center;
  min-height:32px;
  padding:0 10px;
  white-space:nowrap;
}
.nutrition-meal-details{
  margin-top:9px;
  padding:10px;
  border-radius:14px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.08);
}
.nutrition-meal-details strong{display:block;margin-bottom:6px;font-size:12px;color:#8dffbf}
.nutrition-meal-details p{margin:4px 0;color:var(--muted);font-size:12px;line-height:1.34}

/* ─── Pretty calendar ──────────────────────────────────────────────── */
.date-picker-popover{
  position:fixed;
  z-index:80;
  width:min(316px,calc(100vw - 24px));
  padding:12px;
  border-radius:22px;
  color:#f7fbff;
  background:rgba(12,18,33,.96);
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 24px 70px rgba(0,0,0,.42);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}
.date-picker-popover[hidden]{display:none}
.date-picker-head{display:grid;grid-template-columns:38px minmax(0,1fr) 38px;align-items:center;gap:8px;margin-bottom:10px}
.date-picker-head strong{text-align:center;text-transform:capitalize}
.date-picker-head button,.date-picker-actions button{
  min-height:36px;
  border:0;
  border-radius:13px;
  color:#f7fbff;
  background:rgba(255,255,255,.09);
}
.date-picker-week,.date-picker-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.date-picker-week span{text-align:center;color:rgba(247,251,255,.48);font-size:11px;font-weight:800}
.date-picker-grid button{
  aspect-ratio:1;
  border:0;
  border-radius:12px;
  color:#eef5ff;
  background:transparent;
  font-weight:800;
}
.date-picker-grid button:hover{background:rgba(82,255,224,.12)}
.date-picker-grid button.muted{color:rgba(238,245,255,.34)}
.date-picker-grid button.today{box-shadow:inset 0 0 0 1px rgba(255,209,102,.62)}
.date-picker-grid button.selected{color:#08111c;background:linear-gradient(135deg,#52ffe0,#8dffbf)}
.date-picker-time{display:grid;grid-template-columns:1fr 120px;align-items:center;gap:10px;margin-top:10px;color:rgba(247,251,255,.64);font-size:13px;font-weight:800}
.date-picker-time input{min-height:38px;color:#f7fbff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:13px}
.date-picker-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.date-picker-actions button:last-child{color:#08111c;background:#52ffe0;font-weight:900}

/* ─── Chat: compact premium surface ────────────────────────────────── */
.sheet-backdrop{background:rgba(3,7,16,.62);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.sheet-panel{
  width:min(100%,620px);
  max-height:88vh;
  gap:0;
  padding:8px 0 max(12px,env(safe-area-inset-bottom));
  border-radius:28px 28px 0 0;
  color:#f7fbff;
  background:
    radial-gradient(circle at 18% -10%,rgba(82,255,224,.13),transparent 34%),
    linear-gradient(180deg,rgba(14,22,39,.98),rgba(8,13,24,.98));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 -28px 80px rgba(0,0,0,.48);
  overflow:hidden;
}
.sheet-handle{background:rgba(255,255,255,.22);margin:3px auto 1px}
.bot-header{
  padding:12px 16px 13px;
  color:#f7fbff;
  background:rgba(255,255,255,.035);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.bot-header .eyebrow{color:#52ffe0}
.bot-header h2{color:#fff}
.bot-avatar{
  width:42px;
  height:42px;
  border-radius:16px;
  background:linear-gradient(145deg,#52ffe0,#7a6bff);
  box-shadow:0 12px 28px rgba(82,255,224,.17);
}
.bot-avatar svg{width:35px;height:35px}
.bot-header .icon-button{
  color:#f7fbff;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
}
.chat-log-shell{
  min-height:220px;
  background:linear-gradient(180deg,rgba(6,11,22,.92),rgba(9,15,27,.96));
}
.chat-log{
  padding:14px 14px 10px;
  gap:10px;
  scroll-behavior:auto;
}
.msg{
  width:100%;
  max-width:none;
  padding:0;
  border-radius:0;
  background:transparent;
  border:0;
  display:flex;
  gap:8px;
  line-height:1.4;
  white-space:normal;
}
.msg.user{justify-content:flex-end;background:transparent;color:inherit;margin-left:0}
.msg.assistant{justify-content:flex-start;background:transparent;border:0}
.msg-avatar{width:29px;height:29px;margin-bottom:2px;align-self:flex-end}
.msg-avatar svg{width:29px;height:29px}
.msg-bubble{max-width:min(78%,430px);gap:7px}
.msg-text{
  padding:10px 13px;
  border-radius:19px;
  font-size:14px;
  line-height:1.42;
  color:#eaf1ff;
  background:rgba(255,255,255,.09);
  box-shadow:0 10px 26px rgba(0,0,0,.16);
  border:1px solid rgba(255,255,255,.08);
}
.msg.user .msg-text{
  color:#06111d;
  background:linear-gradient(180deg,#52ffe0,#8dffbf);
  border:0;
  border-bottom-right-radius:6px;
}
.msg.assistant .msg-text{border-bottom-left-radius:6px}
.msg-text a{color:#52ffe0}
.msg.user .msg-text a{color:#06111d}
.quick-replies{gap:7px;margin-top:0}
.quick-reply{
  min-height:34px;
  color:#52ffe0;
  background:rgba(82,255,224,.08);
  border:1px solid rgba(82,255,224,.16);
  font-weight:750;
}
.chat-tools{
  padding:9px 14px 7px;
  background:rgba(8,13,24,.98);
  border-top:1px solid rgba(255,255,255,.07);
}
.chat-tools select{
  max-width:none;
  min-height:36px;
  color:#edf7ff;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  box-shadow:none;
}
.composer{
  position:relative;
  bottom:auto;
  gap:8px;
  padding:8px 14px 0;
  background:rgba(8,13,24,.98);
  border:0;
  border-radius:0;
}
.composer textarea{
  min-height:40px;
  max-height:128px;
  padding:10px 14px;
  color:#f7fbff;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.1);
  border-radius:19px;
  box-shadow:none;
}
.composer textarea::placeholder{color:rgba(247,251,255,.46)}
.composer textarea:focus{
  border-color:rgba(82,255,224,.34);
  background:rgba(255,255,255,.1);
  box-shadow:0 0 0 4px rgba(82,255,224,.07);
}
.attach-button,.send-button{
  width:40px;
  height:40px;
  flex:0 0 40px;
  border-radius:50%;
}
.attach-button{
  color:#52ffe0;
  background:rgba(82,255,224,.08);
  border:1px solid rgba(82,255,224,.12);
}
.chat-action-button{
  position:relative;
  display:grid;
  place-items:center;
  color:#07111d;
  background:#52ffe0;
  border:0;
  box-shadow:0 10px 24px rgba(82,255,224,.2);
}
.chat-action-button.recording,.chat-action-button.is-recording{
  color:#fff;
  background:#ff453a;
  box-shadow:0 10px 26px rgba(255,69,58,.26);
}
.chat-action-icon{grid-area:1/1;width:21px;height:21px;display:grid;place-items:center;transition:opacity .16s ease,transform .16s ease}
.chat-action-icon svg{width:21px;height:21px}
.chat-action-send{opacity:0;transform:scale(.72)}
.chat-action-button.is-send .chat-action-mic{opacity:0;transform:scale(.72)}
.chat-action-button.is-send .chat-action-send{opacity:1;transform:scale(1)}
.chat-scroll-btn{
  color:#07111d;
  background:#52ffe0;
  border:0;
  box-shadow:0 12px 26px rgba(82,255,224,.18);
}
.recording-overlay{
  background:rgba(10,16,30,.96);
  color:#f7fbff;
  border-color:rgba(255,69,58,.3);
}
.recording-overlay-info b{color:#fff}
.recording-overlay-info span{color:rgba(247,251,255,.62);opacity:1}

@media(min-width:900px){
  .page[data-page="apps"] .apps-catalog{grid-template-columns:repeat(6,minmax(0,1fr))}
  .nutrition-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:720px){
  .admin-plan-form,.nutrition-grid,.nutrition-hero,.nutrition-onboarding{grid-template-columns:1fr}
  .nutrition-number-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .nutrition-score{align-items:flex-start}
  .sheet-panel{max-height:92vh;border-radius:26px 26px 0 0}
}
@media(max-width:430px){
  .apps-catalog{grid-template-columns:repeat(3,minmax(0,1fr));gap:19px 10px}
  .app-icon,.page[data-page="apps"] .app-icon{width:64px;height:64px;border-radius:18px}
  .app-card p,.page[data-page="apps"] .app-card p{display:none}
  .nutrition-date{width:100%}
  .section-head:has(.nutrition-date){display:grid}
  .nutrition-ring{width:104px;height:104px;flex-basis:104px}
  .nutrition-head-actions{width:100%;justify-content:stretch}
  .nutrition-head-actions .small-button,.nutrition-head-actions .nutrition-date{flex:1 1 140px}
  .nutrition-slider div{grid-template-columns:1fr}
  .nutrition-advice{align-items:flex-start;flex-direction:column}
  .nutrition-meal-item{grid-template-columns:50px minmax(0,1fr) auto;align-items:center}
  .nutrition-meal-item .nutrition-expand-btn{grid-column:2/3;justify-self:start}
  .nutrition-meal-item .habit-delete{grid-column:3;grid-row:1}
  .nutrition-meal-item img,.nutrition-meal-icon{width:50px;height:50px;border-radius:16px}
  .msg-bubble{max-width:84%}
}

/* ─── Питание: новая страница в стиле Yazio/MyFitnessPal ──────── */
.nutrition-page.active{padding-bottom:120px;display:flex;flex-direction:column;gap:14px}
.nutrition-top{display:flex;justify-content:space-between;align-items:center;gap:12px}
.nutrition-head-actions{display:flex;gap:8px;align-items:center}
.nutrition-settings-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.75);display:flex;align-items:center;justify-content:center}
.nutrition-settings-btn:hover{background:rgba(255,255,255,.08)}
.nutrition-date{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:8px 12px;color:#fff;font-size:13px}

/* Hero — большое кольцо + БЖУ-бары */
.nutrition-hero{padding:24px 20px 22px;display:flex;flex-direction:column;gap:22px}
.nutrition-ring-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}
.nutrition-ring{position:relative;width:200px;height:200px}
.nutrition-ring-svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(0deg)}
.nutrition-ring-progress{stroke-dashoffset:calc(100 - var(--value,0));transition:stroke-dashoffset 600ms cubic-bezier(.16,1,.3,1)}
.nutrition-ring-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:2px}
.nutrition-ring-inner strong{font-size:40px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums;line-height:1}
.nutrition-ring-inner small{font-size:11px;opacity:.55;text-transform:uppercase;letter-spacing:.05em}
.nutrition-ring-inner span{font-size:13px;opacity:.7;margin-top:4px;font-variant-numeric:tabular-nums}
.nutrition-hero-hint{font-size:13px;opacity:.65;text-align:center;max-width:280px;line-height:1.4;margin:0}

.nutrition-macro-bars{display:flex;flex-direction:column;gap:12px}
.macro-bar header{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}
.macro-bar header span{opacity:.65}
.macro-bar header b{color:#fff;font-weight:600;font-variant-numeric:tabular-nums}
.macro-track{height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.macro-fill{height:100%;border-radius:3px;width:calc(var(--p,0) * 1%);transition:width 600ms cubic-bezier(.16,1,.3,1)}
.macro-bar[data-macro="protein"] .macro-fill{background:linear-gradient(90deg,#52ffe0,#7fe8c9)}
.macro-bar[data-macro="fat"] .macro-fill{background:linear-gradient(90deg,#ffd166,#ff9a4c)}
.macro-bar[data-macro="carbs"] .macro-fill{background:linear-gradient(90deg,#bd9bff,#7a6bff)}
.macro-bar[data-macro="water"] .macro-fill{background:linear-gradient(90deg,#52b6ff,#52ffe0)}

/* AI совет */
.nutrition-advice{display:flex;gap:14px;align-items:flex-start;padding:16px 18px}
.nutrition-advice-icon{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,rgba(82,255,224,.18),rgba(122,107,255,.18));display:flex;align-items:center;justify-content:center;color:#7fe8c9;flex-shrink:0}
.nutrition-advice-text{flex:1;min-width:0}
.nutrition-advice-text h3{margin:4px 0;font-size:16px}
.nutrition-advice-text p{margin:0;font-size:13px;opacity:.7;line-height:1.45}
.nutrition-advice-next{font-size:11px;opacity:.5;flex-shrink:0;align-self:flex-start;text-transform:uppercase;letter-spacing:.04em}

/* FAB добавить приём пищи */
.nutrition-add-fab{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 20px;background:linear-gradient(135deg,#52ffe0,#7a6bff);color:#0a1320;border:none;border-radius:18px;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 14px 40px rgba(82,255,224,.28);transition:all var(--duration-base) var(--ease-soft);width:100%}
.nutrition-add-fab:hover{transform:translateY(-2px);box-shadow:0 18px 50px rgba(82,255,224,.4)}
.nutrition-add-fab:active{transform:translateY(0) scale(.98)}

/* Список приёмов пищи */
.nutrition-meals .list-stack>*{padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05)}

/* ─── Sheet общий: на мобильном снизу, на десктопе модалка по центру ──────── */
.nutrition-sheet-backdrop[hidden]{display:none !important}
.nutrition-sheet-backdrop{
  position:fixed;inset:0;
  background:rgba(11,16,32,.72);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  z-index:1100;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;
  transition:opacity var(--duration-base) var(--ease-soft);
}
.nutrition-sheet-backdrop:not([hidden]){opacity:1}
.nutrition-sheet{
  width:100%;max-width:100%;
  /* На мобильном — занимаем 92vh с небольшим отступом сверху, чтобы виден был контекст */
  height:92vh;max-height:92vh;
  border-radius:24px 24px 0 0;
  padding:20px 18px max(24px, env(safe-area-inset-bottom));
  display:flex;flex-direction:column;gap:16px;
  transform:translateY(100%);
  transition:transform var(--duration-slow) var(--ease-out);
  overflow-y:auto;overflow-x:hidden;
  box-shadow:0 -20px 60px rgba(0,0,0,.5);
  border-top:1px solid rgba(255,255,255,.06);
  border-left:none;border-right:none;border-bottom:none;
  -webkit-overflow-scrolling:touch;
  box-sizing:border-box;
}
.nutrition-sheet-backdrop:not([hidden]) .nutrition-sheet{transform:translateY(0)}

/* Маленькая «ручка» сверху на мобильном — для интуитивного «свайпа» */
.nutrition-sheet::before{
  content:'';
  position:sticky;top:0;
  display:block;
  width:36px;height:4px;
  background:rgba(255,255,255,.18);
  border-radius:2px;
  margin:-8px auto 4px;
  flex-shrink:0;
}
.nutrition-sheet > *{max-width:100%;box-sizing:border-box}
.nutrition-sheet input,.nutrition-sheet select,.nutrition-sheet textarea,.nutrition-sheet button{max-width:100%;box-sizing:border-box}

/* Десктоп: модалка по центру со всеми скруглениями и красивой тенью */
@media (min-width: 768px){
  .nutrition-sheet-backdrop{
    align-items:center;
    padding:24px;
  }
  .nutrition-sheet{
    max-width:560px;
    height:auto;
    max-height:min(85vh, 720px);
    border-radius:24px;
    border:1px solid rgba(255,255,255,.08);
    border-bottom:1px solid rgba(255,255,255,.08);
    transform:translateY(20px) scale(.96);
    box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
    padding:28px;
  }
  /* На десктопе уберём drag-handle */
  .nutrition-sheet::before{display:none}
  .nutrition-sheet-backdrop:not([hidden]) .nutrition-sheet{
    transform:translateY(0) scale(1);
  }
  .nutrition-sheet-head h2{font-size:22px}
}
.nutrition-sheet-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.nutrition-sheet-head h2{font-size:20px;margin:0}

/* Табы внутри bottom-sheet */
.nutrition-tabs{display:flex;gap:6px;padding:4px;background:rgba(255,255,255,.04);border-radius:12px}
.nutrition-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 8px;background:transparent;border:none;color:rgba(255,255,255,.55);font-size:12px;font-weight:500;border-radius:9px;cursor:pointer;transition:all var(--duration-base) var(--ease-soft)}
.nutrition-tab:hover{color:#fff}
.nutrition-tab.is-active{background:rgba(255,255,255,.08);color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.nutrition-tab-panels>section{display:none}
.nutrition-tab-panels>section.is-active{display:flex;flex-direction:column;gap:12px;animation:tabPanelEnter var(--duration-base) var(--ease-out) both}
@keyframes tabPanelEnter{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.nutrition-sheet-form{display:flex;flex-direction:column;gap:10px}
.nutrition-sheet-form input,.nutrition-sheet-form select,.nutrition-sheet-form textarea{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:11px 14px;color:#fff;font-size:14px;width:100%;transition:border-color var(--duration-base) var(--ease-soft)}
.nutrition-sheet-form input:focus,.nutrition-sheet-form select:focus,.nutrition-sheet-form textarea:focus{outline:none;border-color:rgba(82,255,224,.4)}
.nutrition-photo-drop{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px;border:2px dashed rgba(255,255,255,.12);border-radius:16px;cursor:pointer;transition:all var(--duration-base) var(--ease-soft);background:rgba(255,255,255,.02)}
.nutrition-photo-drop:hover{border-color:rgba(82,255,224,.35);background:rgba(82,255,224,.04)}
.nutrition-photo-drop input[type=file]{display:none}
.nutrition-photo-icon{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,rgba(82,255,224,.18),rgba(122,107,255,.18));display:flex;align-items:center;justify-content:center;color:#7fe8c9}
.nutrition-photo-drop span{font-size:14px;color:#fff;font-weight:500}
.nutrition-photo-drop small{font-size:12px;opacity:.55}
.nutrition-foods-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}
.nutrition-foods-list .food-item{padding:10px 12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:10px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all var(--duration-fast) var(--ease-soft)}
.nutrition-foods-list .food-item:hover,.nutrition-foods-list .food-item.is-selected{background:rgba(82,255,224,.08);border-color:rgba(82,255,224,.3)}
.nutrition-foods-list .food-item b{font-size:13px;color:#fff}
.nutrition-foods-list .food-item small{font-size:11px;opacity:.55;font-variant-numeric:tabular-nums}
.nutrition-selected-label{font-size:13px;padding:8px 12px;background:rgba(82,255,224,.08);border-radius:10px;color:#7fe8c9}
.nutrition-new-food-btn{margin-top:4px}

.nutrition-water-quick{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.nutrition-water-preset{padding:14px 6px;background:rgba(82,182,255,.08);border:1px solid rgba(82,182,255,.22);border-radius:12px;color:#9fd8ff;font-weight:600;font-size:13px;cursor:pointer;transition:all var(--duration-fast) var(--ease-soft)}
.nutrition-water-preset:hover{background:rgba(82,182,255,.16);transform:translateY(-1px)}
.nutrition-drinks-list{display:flex;flex-direction:column;gap:6px}
.nutrition-drink-hint{font-size:12px;opacity:.6}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.nutrition-number-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
@media (max-width:520px){.nutrition-number-grid{grid-template-columns:repeat(2,1fr)}}
.nutrition-slider{display:flex;flex-direction:column;gap:8px;padding:12px;background:rgba(255,255,255,.03);border-radius:12px}
.nutrition-slider>div{display:flex;gap:10px;align-items:center}
.nutrition-slider input[type=range]{flex:1}
.nutrition-slider input[type=number]{width:80px;text-align:right}

/* ─── Fullscreen онбординг ──────── */
.nutrition-onboarding-fullscreen[hidden]{display:none !important}
.nutrition-onboarding-fullscreen:not([hidden]){position:fixed;inset:0;background:linear-gradient(180deg,#0a1020 0%,#10182a 100%);z-index:1500;display:flex;flex-direction:column;animation:onboardFadeIn var(--duration-slow) var(--ease-out) both}
@keyframes onboardFadeIn{from{opacity:0}to{opacity:1}}
.nutrition-onboard-header{display:flex;align-items:center;gap:14px;padding:20px 24px 8px}
.nutrition-onboard-progress{flex:1;height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.nutrition-onboard-progress-fill{height:100%;background:linear-gradient(90deg,#52ffe0,#7a6bff);border-radius:2px;width:calc(var(--p,0) * 1%);transition:width 400ms cubic-bezier(.16,1,.3,1)}
.nutrition-onboard-skip{padding:6px 14px;font-size:13px}
.nutrition-onboard-slides{flex:1;position:relative;overflow:hidden}
.nutrition-onboard-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 32px;gap:20px;opacity:0;transform:translateX(40px);pointer-events:none;transition:opacity var(--duration-slow) var(--ease-out),transform var(--duration-slow) var(--ease-out);text-align:center}
.nutrition-onboard-slide.is-active{opacity:1;transform:translateX(0);pointer-events:auto}
.nutrition-onboard-slide.is-prev{opacity:0;transform:translateX(-40px);pointer-events:none}
.nutrition-onboard-icon{width:120px;height:120px;display:flex;align-items:center;justify-content:center;animation:onboardIconPulse 3s ease-in-out infinite}
@keyframes onboardIconPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.nutrition-onboard-slide h2{font-size:28px;font-weight:700;color:#fff;margin:0;letter-spacing:-.02em;line-height:1.2}
.nutrition-onboard-slide>p{font-size:15px;opacity:.7;max-width:340px;line-height:1.5;margin:0}
.nutrition-onboard-slide .eyebrow{font-size:11px;color:#7fe8c9;text-transform:uppercase;letter-spacing:.1em;margin:0}
.nutrition-onboard-hint{font-size:14px;opacity:.6}
.nutrition-onboard-options{display:flex;flex-direction:column;gap:10px;width:100%;max-width:380px}
.nutrition-onboard-options button{padding:16px 20px;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.08);color:#fff;border-radius:14px;font-size:15px;font-weight:500;cursor:pointer;text-align:left;transition:all var(--duration-base) var(--ease-soft)}
.nutrition-onboard-options button:hover{background:rgba(82,255,224,.08);border-color:rgba(82,255,224,.3);transform:translateY(-1px)}
.nutrition-onboard-options button.is-active{background:linear-gradient(135deg,rgba(82,255,224,.18),rgba(122,107,255,.18));border-color:rgba(82,255,224,.5);color:#7fe8c9}
.nutrition-onboard-options-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;max-width:420px}
.nutrition-onboard-options-grid button{text-align:center;padding:18px 12px}
.nutrition-onboard-body-form{display:flex;flex-direction:column;gap:14px;width:100%;max-width:340px}
.nutrition-onboard-field{display:flex;flex-direction:column;gap:6px;text-align:left}
.nutrition-onboard-field>span{font-size:12px;opacity:.55;text-transform:uppercase;letter-spacing:.05em}
.nutrition-onboard-field input{background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 18px;color:#fff;font-size:18px;font-variant-numeric:tabular-nums;transition:border-color var(--duration-base) var(--ease-soft)}
.nutrition-onboard-field input:focus{outline:none;border-color:rgba(82,255,224,.5)}
.nutrition-onboard-field-large input{font-size:32px;text-align:center;padding:20px;font-weight:600;letter-spacing:-.02em;width:240px}
.nutrition-onboard-slider{display:flex;flex-direction:column;gap:14px;width:100%;max-width:380px}
.nutrition-onboard-slider input[type=range]{-webkit-appearance:none;width:100%;height:8px;background:rgba(255,255,255,.06);border-radius:4px;outline:none}
.nutrition-onboard-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#52ffe0,#7a6bff);box-shadow:0 4px 14px rgba(82,255,224,.4);cursor:grab}
.nutrition-onboard-slider-value{display:flex;align-items:baseline;justify-content:center;gap:8px}
.nutrition-onboard-slider-value input{background:transparent;border:none;color:#fff;font-size:36px;font-weight:700;text-align:right;width:90px;font-variant-numeric:tabular-nums}
.nutrition-onboard-slider-value input:focus{outline:none}
.nutrition-onboard-slider-value span{opacity:.6;font-size:14px}
.nutrition-onboard-preview{padding:16px 20px;background:rgba(82,255,224,.08);border:1px solid rgba(82,255,224,.22);border-radius:14px;display:flex;flex-direction:column;gap:8px;width:100%;max-width:340px}
.nutrition-onboard-preview-row{display:flex;justify-content:space-between;align-items:center}
.nutrition-onboard-preview-row span{opacity:.65;font-size:13px}
.nutrition-onboard-preview-row b{font-size:17px;color:#fff;font-variant-numeric:tabular-nums}
.nutrition-onboard-next{min-width:200px;padding:14px 24px;font-size:15px;margin-top:8px}
.nutrition-onboard-final-form{width:100%;max-width:340px}
.nutrition-onboard-final-form button{width:100%;padding:16px;font-size:15px;font-weight:600}
.nutrition-onboard-footer{padding:16px 24px;display:flex;justify-content:flex-start}
.nutrition-onboard-footer button{padding:8px 14px;font-size:14px;opacity:.7}
.nutrition-onboard-footer button:hover{opacity:1}

/* ─── App-карточки: чистый вид без чипов ──────────── */
.app-chip{display:none !important}
.app-card{position:relative;cursor:pointer;transition:all var(--duration-base) var(--ease-soft)}
.app-card.is-disabled{opacity:.4;cursor:default;filter:saturate(.4)}
.app-card.is-disabled:hover{transform:none;box-shadow:none}
.app-card.is-disabled::after{content:'';position:absolute;inset:0;border-radius:inherit;background:repeating-linear-gradient(135deg,rgba(255,255,255,.02) 0,rgba(255,255,255,.02) 8px,transparent 8px,transparent 16px);pointer-events:none}

/* ─── Уведомления: единый стиль со всеми блоками — скругления со всех сторон ──── */
.notifications-panel{
  border-radius:22px !important;
  top:74px !important;
  right:14px !important;
  width:min(380px,calc(100vw - 28px)) !important;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 24px 60px rgba(0,0,0,.45);
}
@media (max-width: 520px){
  .notifications-panel{
    right:10px !important;
    left:10px;
    width:auto !important;
    max-width:none !important;
  }
}

/* ─── Apple Fitness кольца ────────────────────── */
.nutrition-rings-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}
.nutrition-rings{width:240px;height:240px;display:block;filter:drop-shadow(0 8px 30px rgba(0,0,0,.35))}
.nutrition-rings circle{transition:stroke-dashoffset 800ms cubic-bezier(.16,1,.3,1)}

.nutrition-rings-legend{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:520px;margin:0 auto}
.ring-legend{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:14px}
.ring-legend-water{grid-column:span 2}
.ring-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 12px currentColor}
.ring-legend-text{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.ring-legend-text span{font-size:11px;opacity:.55;text-transform:uppercase;letter-spacing:.05em}
.ring-legend-text b{font-size:14px;color:#fff;font-variant-numeric:tabular-nums;font-weight:600}

/* Старые .macro-bar / .nutrition-ring* — больше не используются, прячем чтобы старый CSS не мешал */
.nutrition-hero .nutrition-ring,.nutrition-hero .macro-bar,.nutrition-hero .nutrition-macro-bars{display:none}

/* ─── Wizard: фикс инпута на шаге 6 ────────── */
.nutrition-onboard-slider-value{
  position:relative;
  z-index:5;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  padding:14px 22px;
  gap:14px;
}
.nutrition-onboard-slider-value input{
  width:auto !important;
  min-width:120px;
  max-width:160px;
  text-align:center !important;
  font-size:38px !important;
  /* убираем стрелочки number input */
  -moz-appearance:textfield;
}
.nutrition-onboard-slider-value input::-webkit-outer-spin-button,
.nutrition-onboard-slider-value input::-webkit-inner-spin-button{
  -webkit-appearance:none;
  margin:0;
}
.nutrition-onboard-slider-value span{
  font-size:13px;
  opacity:.6;
  white-space:nowrap;
}

/* ─── Bottom-nav прячется когда открыт любой sheet ─── */
body.has-open-sheet .bottom-nav{
  transform:translateY(120%);
  pointer-events:none;
}
.bottom-nav{transition:transform 320ms cubic-bezier(.16,1,.3,1)}

/* ─── To-do v2: списки + смарт-фильтры + чек-боксы ─────────── */
.todo-page.active{display:flex;flex-direction:column;gap:18px;padding-bottom:120px}

/* Сегмент-контрол Задачи/Звонки */
.todo-segment{display:flex;gap:4px;padding:4px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.05);border-radius:14px;width:fit-content;margin:0 auto}
.todo-segment-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border:none;background:transparent;color:rgba(255,255,255,.55);font-size:14px;font-weight:500;border-radius:11px;cursor:pointer;transition:all var(--duration-base) var(--ease-soft)}
.todo-segment-btn:hover{color:#fff}
.todo-segment-btn.is-active{background:rgba(255,255,255,.08);color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.2)}

/* Горизонтальный скролл со списками */
.todo-lists-scroller{display:flex;gap:8px;overflow-x:auto;padding:4px 14px;margin:0 -14px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.todo-lists-scroller::-webkit-scrollbar{display:none}
.todo-list-chip{flex-shrink:0;display:inline-flex;align-items:center;gap:8px;padding:9px 14px;background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.06);color:rgba(255,255,255,.75);font-size:13px;font-weight:500;border-radius:14px;cursor:pointer;transition:all var(--duration-base) var(--ease-soft);scroll-snap-align:start;white-space:nowrap}
.todo-list-chip:hover{background:rgba(255,255,255,.07)}
.todo-list-chip.is-active{background:color-mix(in srgb, var(--list-color, #52ffe0) 16%, transparent);border-color:color-mix(in srgb, var(--list-color, #52ffe0) 45%, transparent);color:var(--list-color, #52ffe0)}
.todo-list-chip-dot{width:8px;height:8px;border-radius:50%;background:var(--list-color, #52ffe0);box-shadow:0 0 8px var(--list-color, #52ffe0)}
.todo-list-chip-count{padding:1px 8px;background:rgba(255,255,255,.08);border-radius:10px;font-size:11px;font-weight:600;font-variant-numeric:tabular-nums}
.todo-list-chip.is-active .todo-list-chip-count{background:rgba(255,255,255,.12)}
.todo-list-add{padding:9px 12px;color:rgba(255,255,255,.55);border-style:dashed}
.todo-list-add:hover{color:#fff;border-color:rgba(255,255,255,.18)}

/* Заголовок текущего списка */
.todo-list-header{display:flex;justify-content:space-between;align-items:flex-start;padding:0 4px}
.todo-list-header h2{font-size:28px;font-weight:700;margin:0;letter-spacing:-.02em}
.todo-list-header p{font-size:13px;opacity:.55;margin:4px 0 0}
.todo-list-menu{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.04)}

/* Quick-add input */
.todo-quick-add{display:flex;align-items:center;gap:10px;padding:8px 12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:16px;transition:border-color var(--duration-base) var(--ease-soft)}
.todo-quick-add:focus-within{border-color:rgba(82,255,224,.35);background:rgba(255,255,255,.06)}
.todo-add-circle{width:30px;height:30px;border-radius:50%;border:none;background:linear-gradient(135deg,#52ffe0,#7a6bff);color:#0a1320;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:transform var(--duration-fast) var(--ease-soft)}
.todo-add-circle:hover{transform:scale(1.08)}
.todo-quick-add textarea{flex:1;background:transparent;border:none;color:#fff;font-size:15px;resize:none;outline:none;padding:6px 0;font-family:inherit;line-height:1.4}
.todo-quick-add textarea::placeholder{color:rgba(255,255,255,.4)}
.todo-options-btn{width:30px;height:30px;border-radius:50%;border:none;background:rgba(255,255,255,.04);color:rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-fast) var(--ease-soft)}
.todo-options-btn:hover,.todo-options-btn[aria-expanded="true"]{background:rgba(82,255,224,.12);color:#7fe8c9}

/* Список задач */
.todo-items{display:flex;flex-direction:column;gap:6px}
.todo-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:14px;transition:all var(--duration-base) var(--ease-soft);position:relative}
.todo-row::before{content:'';position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:0 3px 3px 0;background:var(--row-color, #7fe8c9);opacity:.65}
.todo-row:hover{background:rgba(255,255,255,.05);transform:translateX(2px)}
.todo-row.is-done{opacity:.55}
.todo-row.is-done .todo-content b{text-decoration:line-through}
.todo-check{width:24px;height:24px;border-radius:50%;border:1.5px solid rgba(255,255,255,.25);background:transparent;color:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all var(--duration-base) var(--ease-soft);margin-top:2px}
.todo-check svg{opacity:0;transform:scale(.5);transition:all var(--duration-base) var(--ease-out)}
.todo-row.is-done .todo-check{background:linear-gradient(135deg,#52ffe0,#7a6bff);border-color:transparent;color:#0a1320}
.todo-row.is-done .todo-check svg{opacity:1;transform:scale(1)}
.todo-check:hover{border-color:rgba(82,255,224,.5)}
.todo-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.todo-content b{font-size:14.5px;color:#fff;font-weight:500;line-height:1.4;word-wrap:break-word}
.todo-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.todo-priority{width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.todo-priority.urgent{background:rgba(255,90,138,.18);color:#ff5a8a}
.todo-priority.high{background:rgba(255,209,102,.18);color:#ffd166}
.todo-list-tag{padding:2px 8px;border-radius:8px;background:rgba(255,255,255,.06);font-size:11px;opacity:.75}
.todo-due,.todo-loc{font-size:11px;opacity:.55}
.todo-delete{width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:rgba(255,255,255,.3);cursor:pointer;font-size:16px;flex-shrink:0;transition:all var(--duration-fast) var(--ease-soft);align-self:center}
.todo-delete:hover{background:rgba(255,140,140,.16);color:#ffb1b1}

.todo-done-divider{padding:14px 4px 6px;font-size:11px;opacity:.45;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.todo-empty{padding:48px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;opacity:.55}
.todo-empty-icon{color:#7fe8c9;opacity:.4}
.todo-empty p{font-size:16px;color:#fff;margin:0}
.todo-empty small{font-size:13px}

/* Color picker для нового списка */
.todo-color-picker{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;padding:8px 0}
.color-swatch{width:100%;aspect-ratio:1/1;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:all var(--duration-base) var(--ease-soft)}
.color-swatch:hover{transform:scale(1.1)}
.color-swatch.is-active{border-color:#fff;transform:scale(1.12);box-shadow:0 0 0 3px rgba(255,255,255,.1)}

/* Старые стили task-tabs прячем, чтобы не конфликтовали */
.task-tabs{display:none !important}

/* ═══════════════════════════════════════════════════════════
   МОБИЛЬНЫЕ ФИКСЫ: выделение, зум, safe-area, drag
   ═══════════════════════════════════════════════════════════ */

/* 1. Запрет выделения текста на всём UI (кнопки, нав, виджеты, заголовки).
   Текст выделяется ТОЛЬКО в полях ввода и сообщениях чата. */
*{
  -webkit-user-select:none;
  -moz-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
  -webkit-tap-highlight-color:transparent;
}
input, textarea, [contenteditable="true"],
.msg-text, .msg-bubble, .transcript-text, .selectable,
.memory-item span, .notification-body span, .goal-description{
  -webkit-user-select:text;
  -moz-user-select:text;
  user-select:text;
  -webkit-touch-callout:default;
}

/* 2. Жёсткая защита от горизонтального вылета за край экрана */
html, body{
  max-width:100%;
  overflow-x:hidden;
}
.app-shell{
  max-width:100vw;
  /* safe-area сверху для PWA (Dynamic Island / notch) */
  padding-top:max(18px, env(safe-area-inset-top));
}

/* 3. Drag виджетов: отключаем нативные жесты браузера (скролл/зум/выделение),
   чтобы long-press drag работал чисто */
.dashboard-widget,
.dashboard-widget *,
.widget-handle{
  touch-action:none;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
.dashboard-widget.is-dragging{
  touch-action:none;
}

/* 4. Кнопка микрофона: при зажатии не выделять и не вызывать callout */
.mic-button, .mic-button *{
  touch-action:none;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}

/* 5. Кнопки и интерактив — без подсветки тапа и выделения */
button, .nav-btn, .nav-item, .todo-row, .habit-item, .goal-item,
.app-card, .metric-card, .todo-list-chip, .nutrition-tab,
.schedule-preset, .schedule-day, .color-swatch{
  -webkit-touch-callout:none;
  -webkit-user-select:none;
  user-select:none;
}

/* 6. PWA standalone: топбар уезжает под Dynamic Island — компенсируем.
   Когда приложение добавлено на домашний экран iPhone */
@media (display-mode: standalone){
  .app-shell{
    padding-top:max(8px, env(safe-area-inset-top));
  }
  .topbar{
    padding-top:max(8px, calc(env(safe-area-inset-top) - 6px));
  }
}

/* 7. Sheets/overlays — тоже без выделения и горизонтального вылета */
.nutrition-sheet, .widget-catalog, .notifications-panel,
.nutrition-sheet *, .widget-catalog *{
  max-width:100%;
}

/* 8. Отключаем «pull-to-refresh» и оверскролл на body (мешает в PWA) */
body{
  overscroll-behavior-y:contain;
}
