/* NLP Therapist — Components (v6.0) — Settings, Session, Breathing, Onboarding, PWA etc. */

/* ── Progress Tab ── */
#progressTab h2{font-size:24px;font-weight:700}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.stat-card{background:var(--card-glass);backdrop-filter:blur(8px);border-radius:var(--radius);
  padding:16px;text-align:center;border:1px solid var(--border)}
[data-theme="dark"] .stat-card{box-shadow:var(--glow-sm)}
.stat-num{font-size:24px;font-weight:700;color:var(--primary)}
.stat-label{font-size:12px;color:var(--dim);margin-top:4px}
.section-title{font-size:15px;font-weight:600;margin-bottom:10px}
.mood-chart{display:flex;justify-content:space-around;align-items:flex-end;
  background:var(--card-glass);border-radius:var(--radius);padding:12px 8px;
  margin-bottom:16px;border:1px solid var(--border)}
.mc-col{display:flex;flex-direction:column;align-items:center;flex:1;gap:2px}
.mc-bar-wrap{width:16px;height:60px;display:flex;align-items:flex-end}
.mc-bar{width:100%;border-radius:4px 4px 0 0;background:var(--primary);min-height:2px;transition:height .3s}
.mc-label{font-size:10px;color:var(--dim)}
.mc-emoji{font-size:12px;margin-bottom:2px}
.emo-chart{display:flex;justify-content:space-around;align-items:flex-end;
  background:var(--card-glass);border-radius:var(--radius);padding:12px 8px;
  margin-bottom:16px;border:1px solid var(--border)}
.ec-col{display:flex;flex-direction:column;align-items:center;flex:1;gap:2px}
.ec-bar-wrap{width:20px;height:60px;display:flex;align-items:flex-end}
.ec-bar{width:100%;border-radius:4px 4px 0 0;background:var(--accent);min-height:2px;transition:height .3s}
.ec-label{font-size:9px;color:var(--dim)}
.ec-pct{font-size:10px;color:var(--dim)}
.ec-emoji{font-size:12px;margin-bottom:2px}
.sess-list{display:flex;flex-direction:column;gap:8px}
.sess-card{background:var(--card-glass);border-radius:12px;padding:12px;border:1px solid var(--border);cursor:pointer}
.sc-date{font-size:11px;color:var(--dim)}
.sc-problem{font-size:15px;font-weight:600;margin:2px 0}
.sc-meta{font-size:13px;color:var(--dim)}
.sc-conclusion{font-size:13px;color:var(--accent);margin:4px 0 2px}
.sc-goal{font-size:13px;color:var(--primary);margin:2px 0}
.sc-essay{margin-top:8px;border-top:1px solid var(--border);padding-top:8px}
.sc-essay-text{font-size:13px;line-height:1.5;white-space:pre-wrap;margin:0;font-family:inherit;color:var(--text)}

/* ── Overlay / Modal ── */
.overlay{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.6);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}
.overlay.hidden{display:none}
.modal{background:var(--surface-solid);border-radius:var(--radius);width:92%;max-width:400px;
  max-height:85vh;overflow-y:auto;padding:22px;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.modal-hdr h2{font-size:19px}
.modal-x{background:none;border:none;color:var(--dim);font-size:22px;cursor:pointer;
  line-height:1;padding:4px;display:flex;align-items:center}
.modal-x .ico{width:20px;height:20px}

/* ── Settings ── */
.gear{position:absolute;top:16px;right:16px;z-index:10;background:none;border:none;
  font-size:28px;cursor:pointer;color:var(--dim);transition:transform .3s,color .3s}
.gear:hover,.gear:active{color:var(--primary);transform:rotate(60deg)}
.gear.sm{position:static;font-size:22px}
.srow{display:flex;justify-content:space-between;align-items:center;
  padding:11px 0;border-bottom:1px solid var(--border)}
.srow span{font-size:15px}
.sw{position:relative;width:46px;height:25px;display:inline-block}
.sw input{opacity:0;width:0;height:0}
.sl{position:absolute;inset:0;background:#3a2d55;border-radius:25px;cursor:pointer;transition:.3s}
[data-theme="light"] .sl{background:#ccc}
.sl::before{content:'';position:absolute;width:19px;height:19px;left:3px;bottom:3px;
  background:#888;border-radius:50%;transition:.3s}
.sw input:checked+.sl{background:var(--primary)}
.sw input:checked+.sl::before{transform:translateX(21px);background:#fff}
.theme-btn{background:var(--card-glass);border:1px solid var(--border);border-radius:10px;
  width:42px;height:36px;cursor:pointer;transition:background .2s;
  display:flex;align-items:center;justify-content:center;color:var(--text)}
.theme-btn .ico{width:20px;height:20px}
.voices-label{font-size:14px;color:var(--dim);margin:14px 0 8px}
.voice-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.vcard{background:var(--card-glass);border:2px solid transparent;border-radius:12px;
  padding:14px 10px;cursor:pointer;text-align:center;transition:all .2s;position:relative}
.vcard.sel{border-color:var(--primary);background:rgba(124,77,255,.12)}
[data-theme="light"] .vcard.sel{background:rgba(124,77,255,.08)}
.vcard .vn{font-size:14px;font-weight:600;margin-bottom:2px}
.vcard .vd{font-size:11px;color:var(--dim)}
.vcard .vplay{display:flex;align-items:center;justify-content:center;
  margin:8px auto 0;width:30px;height:30px;border-radius:50%;
  background:var(--primary);border:none;color:#fff;cursor:pointer;transition:transform .15s}
.vcard .vplay:active{transform:scale(.88)}
.vcard .vplay.ld{opacity:.5;pointer-events:none}
.vcard .vplay .ico{width:14px;height:14px;fill:#fff;stroke:none}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
.lang-select{background:var(--card-glass);color:var(--text);border:1px solid var(--border);
  border-radius:8px;padding:6px 10px;font-size:14px;outline:none}
.logout-row{margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}
.btn-logout{width:100%;padding:12px;border:1px solid var(--danger);border-radius:12px;
  background:transparent;color:var(--danger);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}
.btn-logout:active{background:var(--danger);color:#fff;transform:scale(.97)}

/* ── Session screen ── */
.sess-hdr{display:flex;align-items:center;justify-content:space-between;
  padding:calc(10px + env(safe-area-inset-top, 0px)) 14px 10px;background:var(--surface);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);
  flex-shrink:0;z-index:10}
.sess-hdr span{font-size:14px;color:var(--dim)}
.btn-x{background:none;border:none;color:var(--danger);font-size:22px;cursor:pointer;min-width:44px;min-height:44px;
  display:flex;align-items:center;justify-content:center;padding:4px}
.btn-x .ico{width:20px;height:20px}
.chat{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.inp-area{display:flex;gap:8px;padding:10px 14px;background:var(--surface);
  border-top:1px solid var(--border);align-items:flex-end}
.inp-area textarea{flex:1;background:var(--card-glass);color:var(--text);border:1px solid var(--border);
  border-radius:12px;padding:9px 12px;font-size:15px;resize:none;outline:none;font-family:inherit}
.inp-area textarea:focus{border-color:var(--primary)}
.inp-btns{display:flex;flex-direction:column;gap:4px;align-items:center}
.rec-timer{font-size:11px;color:var(--danger);font-weight:600;font-variant-numeric:tabular-nums}
.rec-timer.hidden{display:none}

/* ── Done ── */
.done-box{display:flex;flex-direction:column;align-items:center;
  padding:32px 20px;text-align:center;gap:14px;overflow-y:auto;height:100%}
.done-ico{color:var(--accent)}
#completedSummary{color:var(--text);font-size:14px;line-height:1.6;max-width:340px;text-align:left}
.summ-item{padding:4px 0;font-size:14px;line-height:1.4}
.summ-label{font-weight:600}
.summ-mood-q{color:var(--dim);font-size:14px;margin-top:12px;text-align:center}

/* ── Diagnostic ── */
#diagnosticScreen{position:fixed;left:0;right:0;top:0;z-index:50}
#diagnosticScreen .diag-input-area{flex-shrink:0}
.diag-input-area{padding:12px 16px;background:var(--surface);border-top:1px solid var(--border)}
.diag-ta{width:100%;background:var(--card-glass);color:var(--text);border:1.5px solid var(--border);
  border-radius:12px;padding:10px;font-size:14px;resize:none;font-family:inherit;outline:none;margin-bottom:8px}
.diag-ta:focus{border-color:var(--primary)}
.diag-btns{display:flex;flex-direction:column;gap:8px;width:100%}
.diag-btn{background:var(--card-glass);color:var(--text);border:1.5px solid var(--border);
  border-radius:12px;padding:12px 20px;font-size:14px;cursor:pointer;transition:all .15s;text-align:center}
.diag-btn:active{transform:scale(.97)}
.diag-btn.primary{background:linear-gradient(135deg,var(--primary-from),var(--primary-to));color:#fff;border-color:transparent}
.diag-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:10px}
.diag-chip-ok:disabled{opacity:.4;pointer-events:none}

/* ── Breathing ── */
.breath-zone {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 30px;
  position: relative;
  margin-top: 10vh; /* Push it towards the center vertically */
}

/* Base shape: an organic pulsing blob */
.breath-circle {
  width: 170px;
  height: 170px;
  border-radius: 50%;
  position: relative;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: radial-gradient(circle at 35% 35%, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0.02) 60%, transparent 80%);
  box-shadow: 0 0 50px rgba(0, 150, 255, 0.1), inset 0 0 20px rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: transform 2.5s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 2.5s, border-color 2.5s;
  transform: scale(0.85); /* Starting scale (exhaled state basically) */
  margin: 44px 0 50px;
}

/* Organic glowing pseudo-elements under the main circle to create a liquid/magic look */
.breath-circle::before, .breath-circle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%;
  background: linear-gradient(45deg, rgba(0, 180, 255, 0.4), rgba(0, 255, 200, 0.2));
  filter: blur(15px);
  z-index: -1;
  animation: bc-morph 8s infinite linear;
  opacity: 0.5;
  transition: all 1.5s ease;
}

.breath-circle::after {
  animation: bc-morph 10s infinite reverse linear;
  background: linear-gradient(135deg, rgba(150, 50, 255, 0.3), rgba(0, 150, 255, 0.3));
  opacity: 0.6;
}

@keyframes bc-morph {
  0% { border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%; }
  34% { border-radius: 70% 30% 50% 50% / 30% 30% 70% 70%; }
  67% { border-radius: 100% 60% 60% 100% / 100% 100% 60% 60%; }
  100% { border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%; }
}

/* Inhale State (Expanding deeply) */
.breath-circle.inhale {
  transform: scale(1.45);
  box-shadow: 0 0 100px rgba(0, 200, 255, 0.6), inset 0 0 30px rgba(255, 255, 255, 0.3);
  border-color: rgba(255, 255, 255, 0.4);
  /* transition takes exactly 3s for inhale */
  transition: transform 2.5s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 2.5s, border-color 2.5s;
}

.breath-circle.inhale::before, .breath-circle.inhale::after {
  opacity: 1;
  filter: blur(25px);
  animation-duration: 4s; /* speeds up swirling */
}

/* Exhale State (Shrinking deeply) */
.breath-circle.exhale {
  transform: scale(0.85);
  box-shadow: 0 0 20px rgba(0, 200, 255, 0.1), inset 0 0 10px rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.1);
  /* transition takes exactly 2.5s for exhale */
  transition: transform 2.5s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 2.5s, border-color 2.5s;
}

/* Hold State (Calm floating) */
.breath-circle.hold {
  transform: scale(1);
  box-shadow: 0 0 60px rgba(100, 255, 150, 0.4), inset 0 0 20px rgba(255, 255, 255, 0.2);
  border-color: rgba(100, 255, 150, 0.4);
  transition: all 1.5s ease-in-out;
}

.breath-circle.hold::before, .breath-circle.hold::after {
  background: linear-gradient(45deg, rgba(80, 255, 180, 0.4), rgba(0, 200, 150, 0.3));
  animation-duration: 15s; /* calm swirling */
  opacity: 0.7;
}

/* Typography inside the circle */
.bc-inner { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.bc-label { font-size: 16px; font-weight: 600; color: var(--text); }
.bc-count { font-size: 36px; font-weight: 700; }

#breathCounter, #preBreathCount {
  font-size: 80px;
  font-weight: 900;
  text-shadow: 0 4px 16px rgba(0,0,0,0.6);
  z-index: 20;
  letter-spacing: -2px;
  color: #ffffff;
  font-family: system-ui, -apple-system, sans-serif;
}

.breath-label {
  font-size: 24px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: 1px;
  text-transform: uppercase;
  transition: opacity 0.5s;
  text-align: center;
}

.breath-timer {
  font-size: 16px;
  color: var(--dim);
  font-weight: 600;
  text-align: center;
}

/* Rest of Wim Hof UI */
.wh-skip-btn { background: var(--accent); margin-top: 6px; }
.wh-onboard { margin-bottom: 12px; } 
.wh-daily { color: var(--accent); font-size: 14px; font-weight: 600; margin: 10px 0 4px; text-align: center; }

/* Wim Hof Modal dark theme override for full immersion */
.wh-modal {
  position: fixed; inset: 0; z-index: 999;
  background: linear-gradient(to bottom, #0f172a, #020617) !important; 
  color: #fff !important;
  display: flex; flex-direction: column; animation: fadeIn .3s;
}
.wh-modal .breath-label { color: #fff; }
.wh-modal .breath-timer { color: rgba(255,255,255,0.6); }
.wh-modal .wh-modal-hdr { color: #fff; }
.wh-modal .wh-close-btn { background: rgba(255,59,48,0.2); }
/* Wim Hof Modal structural rules (restored) */
.wh-modal.hidden{display:none!important}
.wh-modal-inner{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}
.wh-modal-hdr{position:relative;z-index:2000;display:flex;align-items:center;
  justify-content:space-between;padding:calc(16px + env(safe-area-inset-top,0px)) 20px 12px;font-size:18px;font-weight:700}
.wh-close-btn{width:48px;height:48px;border:none;background:rgba(255,59,48,.15);border-radius:50%;
  color:#ff3b30;font-size:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;
  justify-content:center;-webkit-tap-highlight-color:rgba(255,0,0,.3);touch-action:manipulation;
  z-index:2001;position:relative;flex-shrink:0}
.wh-close-btn:active{background:rgba(255,59,48,.35);transform:scale(.9)}
.wh-stop-btn{margin-top:20px;background:transparent;border:1px solid var(--danger);color:var(--danger);
  border-radius:var(--radius-btn);padding:10px 24px;font-size:14px;font-weight:600;cursor:pointer}
.wh-stop-btn:active{background:var(--danger);color:#fff}




/* Breathing Onboard Screen (restored) */
/* Breathing Onboard Screen */
.breath-onboard{flex:1;overflow-y:auto;padding:20px 16px}
.breath-active{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;padding-bottom:calc(20px + env(safe-area-inset-bottom, 0px))}
.breath-active.hidden{display:none}
.bo-skip{text-align:center;margin-top:12px;font-size:14px}
.bo-skip a{color:var(--dim);text-decoration:none;transition:color .2s}
.bo-skip a:hover{color:var(--text)}
.breath-instruction{font-size:20px;font-weight:700;text-align:center;color:var(--accent);
  min-height:28px;margin-bottom:16px;line-height:1.3;padding:0 12px}
.mic-req-text{font-size:18px;font-weight:600;text-align:center;line-height:1.4;
  margin-bottom:24px;padding:0 16px;color:var(--text)}
.mic-req-info{max-width:340px;font-size:15px;line-height:1.6;text-align:center;color:var(--text-secondary);margin:-8px 0 24px;padding:0 16px}
.mic-req-btn{font-size:16px;padding:14px 32px}
.mic-req-start{font-size:16px;padding:14px 32px;margin-top:12px}
.bo-intro{font-size:15px;line-height:1.6;margin-bottom:16px}
.bo-section{margin:12px 0 6px;font-size:15px;font-weight:600}
.bo-step{background:var(--card-glass);border-radius:12px;padding:12px;margin-bottom:8px;
  font-size:14px;line-height:1.5;border:1px solid var(--border)}
.bo-note{font-size:13px;color:var(--dim);line-height:1.5;margin-bottom:8px}
.bo-ready{text-align:center;color:var(--dim);font-size:14px;margin:16px 0 12px}

/* ── Pre-session modal ── */
.presession-modal{text-align:center}
.presession-text{font-size:15px;line-height:1.6;margin:8px 0}
.presession-text.dim{color:var(--dim);font-size:13px}
.presession-list{list-style:none;padding:0;margin:8px 0;text-align:left}
.presession-list li{font-size:13px;line-height:1.5;margin:6px 0;padding-left:4px}

/* ── Onboarding ── */
#onboardingScreen{align-items:center;justify-content:center;padding:32px;text-align:center;
  position:fixed;inset:0;z-index:10000;background:linear-gradient(to bottom,var(--bg-from),var(--bg-to))}
.onb-dots{display:flex;gap:8px;margin-bottom:24px}
.onb-dot{width:8px;height:8px;border-radius:50%;background:var(--dim);opacity:.3;transition:opacity .3s}
.onb-dot.active{opacity:1;background:var(--primary)}
.onb-sub{color:var(--dim);margin:8px 0 20px;font-size:15px}
.onb-input{width:100%;max-width:280px;background:var(--card-glass);border:2px solid var(--border);
  border-radius:12px;padding:12px 16px;font-size:17px;color:var(--text);outline:none;
  font-family:inherit;text-align:center;margin-bottom:20px}
.onb-input:focus{border-color:var(--primary)}
.onb-gender{display:flex;gap:12px;margin-bottom:24px}
.gender-card{flex:1;background:var(--card-glass);border:2px solid var(--border);border-radius:14px;
  padding:20px 12px;cursor:pointer;text-align:center;transition:all .2s;color:var(--text);
  display:flex;flex-direction:column;align-items:center;gap:8px;font-size:15px}
.gender-card.sel{border-color:var(--primary);background:rgba(124,77,255,.1)}
[data-theme="light"] .gender-card.sel{background:rgba(124,77,255,.06)}
.gender-emoji{font-size:36px}
.onb-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}
.chip{background:var(--card-glass);border:1.5px solid var(--border);border-radius:20px;
  padding:8px 16px;font-size:14px;cursor:pointer;color:var(--text);transition:all .2s}
.chip.sel{border-color:var(--primary);background:rgba(124,77,255,.15);color:var(--primary)}
.onb-next{margin-top:8px}
.reg-btns{display:flex;gap:10px;justify-content:center;margin-top:16px}
.btn-back{background:var(--card-glass);color:var(--text);border:1px solid var(--border);
  padding:15px 30px;font-size:17px;border-radius:var(--radius);cursor:pointer;transition:background .2s}
.btn-back:active{background:var(--surface)}
.reg-err{color:var(--danger);font-size:13px;text-align:center;margin-top:6px}
.empty-msg{text-align:center;color:var(--dim);font-size:14px;padding:20px}

/* ── Journal ── */
.journal-add{margin-bottom:16px}
.j-input{width:100%;background:var(--card-glass);border:1.5px solid var(--border);
  border-radius:12px;padding:12px;font-size:14px;color:var(--text);resize:none;
  font-family:inherit;outline:none;margin-bottom:8px}
.j-input:focus{border-color:var(--primary)}
.j-entry{background:var(--card-glass);border-radius:12px;padding:12px;margin-bottom:8px;
  position:relative;border:1px solid var(--border)}
.j-date{font-size:11px;color:var(--dim);margin-bottom:4px}
.j-text{font-size:14px;line-height:1.4;white-space:pre-wrap}
.j-del{position:absolute;top:8px;right:8px;background:none;border:none;
  color:var(--dim);font-size:14px;cursor:pointer;opacity:.5}
.j-del:hover,.j-del:active{opacity:1;color:var(--danger)}

/* ── PWA Install Prompt ── */
.pwa-prompt{position:fixed;inset:0;z-index:9999;background:linear-gradient(to bottom,var(--bg-from),var(--bg-to));
  display:flex;align-items:center;justify-content:center;padding:24px;
  animation:pwaFadeIn .3s ease;overflow-y:auto}
.pwa-prompt.hidden{display:none}
.pwa-prompt-content{text-align:center;max-width:360px;width:100%}
.pwa-prompt-icon{font-size:64px;margin-bottom:16px}
.pwa-prompt-title{font-size:22px;font-weight:700;margin-bottom:8px;color:var(--text)}
.pwa-prompt-desc{font-size:15px;color:var(--dim);margin-bottom:28px;line-height:1.6}
.pwa-steps{text-align:left;margin-bottom:24px}
.pwa-step{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;
  background:var(--card-glass);border-radius:12px;padding:14px 16px}
.pwa-step-num{min-width:28px;height:28px;border-radius:50%;background:var(--primary);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:14px;flex-shrink:0}
.pwa-step-text{font-size:15px;line-height:1.5;color:var(--text);padding-top:2px}
.pwa-step-text b{color:var(--accent)}
.pwa-share-ico{display:inline-block;font-size:16px;vertical-align:middle;color:var(--accent)}
.pwa-prompt-btn{width:100%;padding:14px;border:1px solid var(--border);
  border-radius:12px;background:var(--card-glass);color:var(--dim);
  font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}
.pwa-prompt-btn:active{transform:scale(.97)}
@keyframes pwaFadeIn{from{opacity:0}to{opacity:1}}
@keyframes flashRed{0%,100%{background:linear-gradient(135deg,var(--primary-from),var(--primary-to))}40%{background:var(--danger)}70%{background:var(--danger)}}
.btn-flash-red{animation:flashRed .5s ease-in-out 3}

/* ── Login bottom sheet ── */
.login-overlay{position:fixed;inset:0;z-index:10001;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;justify-content:center}
.login-overlay.hidden{display:none}
.login-sheet{background:var(--surface-solid);border-radius:20px 20px 0 0;width:100%;max-width:420px;
  padding:24px 20px calc(24px + env(safe-area-inset-bottom, 0px));animation:sheetUp .3s ease-out}
.login-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.login-hdr h2{font-size:18px}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.btn-link{background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;
  margin-top:16px;text-decoration:underline}

/* ── Subscription & Paywall ── */
.sub-info-block{background:var(--card-glass);border-radius:12px;padding:12px;margin-bottom:12px;border:1px solid var(--border)}
.sub-badge{display:inline-block;background:linear-gradient(135deg,var(--primary-from),var(--primary-to));color:#fff;
  font-size:13px;font-weight:700;padding:4px 12px;border-radius:20px;margin-bottom:6px}
.sub-exp{font-size:12px;color:var(--dim);margin-bottom:6px}
.sub-stats{display:flex;flex-wrap:wrap;gap:6px}
.sub-stats span{font-size:12px;color:var(--dim);background:var(--surface);padding:3px 8px;border-radius:8px}
.pw-modal{max-height:85vh;overflow-y:auto;
  background:var(--surface-solid);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px)}
[data-theme="light"] .pw-modal{background:rgba(255,255,255,.92)}
[data-theme="light"] .pw-plan-feats{color:#374151}
[data-theme="light"] .pw-plan-name{color:#111827}
[data-theme="light"] .pw-plan-price{color:#4f46e5}
[data-theme="light"] .pw-reason{color:#dc2626}
.pw-hdr{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--border)}
.pw-hdr span{font-size:18px;font-weight:700}
.pw-body{padding:16px;display:flex;flex-direction:column;gap:12px}
.pw-reason{text-align:center;color:var(--danger);font-size:14px;font-weight:600;margin-bottom:4px}
.pw-plan{background:var(--card-glass);border-radius:14px;padding:14px;border:2px solid var(--border)}
.pw-plan.current{border-color:var(--primary)}
.pw-plan-name{font-size:16px;font-weight:700;margin-bottom:2px}
.pw-plan-price{font-size:22px;font-weight:800;color:var(--primary);margin-bottom:8px}
.pw-plan-feats{font-size:13px;color:var(--dim);line-height:1.7}
.pw-current{text-align:center;color:var(--primary);font-size:13px;font-weight:600;margin-top:8px}
.pw-btn{width:100%;margin-top:10px}

/* Mic permission */
.btn-mic-req{display:block;width:100%;padding:14px;font-size:16px;font-weight:600;
  background:var(--card-glass);color:var(--accent);border:2px solid var(--accent);border-radius:var(--radius);
  cursor:pointer;margin-top:16px;transition:all .2s}
.btn-mic-req:active{transform:scale(.97)}
.btn-mic-req.hidden{display:none}
.mic-status{text-align:center;font-size:14px;margin-top:8px;min-height:20px}
.btn-start-disabled{opacity:.4;pointer-events:auto;cursor:not-allowed}
@keyframes micPulse{0%,100%{box-shadow:0 0 0 0 rgba(0,229,255,.4)}50%{box-shadow:0 0 0 12px transparent}}
.mic-pulse{animation:micPulse .6s ease-in-out 5}

/* ── Tool section (legacy WH in tools tab) ── */
.tool-section{background:var(--card-glass);border-radius:var(--radius-lg);padding:18px;margin-bottom:14px;
  border:1px solid var(--border);backdrop-filter:blur(8px)}
.tool-title{font-size:16px;font-weight:600;margin-bottom:4px}
.tool-desc{color:var(--text-secondary);font-size:13px;margin-bottom:12px}

@supports(padding-bottom:env(safe-area-inset-bottom)){
  .inp-area{padding-bottom:calc(10px + env(safe-area-inset-bottom))}
}

/* ── Gender Picker ── */
.gender-picker{display:flex;gap:16px;justify-content:center;margin:24px 0}
.gender-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 32px;border-radius:16px;border:2px solid var(--border);background:var(--card);cursor:pointer;transition:all .2s;font-size:16px;color:var(--text)}
.gender-btn:active{transform:scale(.96)}
.gender-btn.selected{border-color:var(--primary-from);background:linear-gradient(135deg,var(--primary-from),var(--primary-to));color:#fff}
.gender-ico{font-size:40px}

/* breath-zone z-index removed — was causing stacking issues */
.session-min-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;
  background:linear-gradient(135deg,var(--primary-from),var(--primary-to));color:#fff;
  border-radius:16px;margin:8px 12px;font-size:14px;font-weight:600;animation:fadeIn .3s}
.session-min-banner span{flex:1}
.btn-resume{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.4);
  color:#fff;padding:6px 14px;border-radius:12px;font-size:13px;cursor:pointer}
.btn-x-sm{background:none;border:none;color:rgba(255,255,255,.7);font-size:18px;
  cursor:pointer;padding:4px 8px;min-width:32px;min-height:32px}
/* PWA onboard v2 */
.pwa-section-title{font-size:16px;font-weight:700;margin-bottom:12px;color:var(--accent)}
.pwa-hint{color:var(--dim);font-size:12px;line-height:1.4}
.pwa-not-safari{background:rgba(255,149,0,.1);border:1px solid rgba(255,149,0,.3);border-radius:var(--radius-lg);padding:16px;margin-bottom:20px;text-align:center}
.pwa-warning{font-size:18px;font-weight:700;color:#ff9500;margin-bottom:8px}
.pwa-warning-text{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:12px}
.pwa-url-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;display:flex;align-items:center;gap:8px;cursor:pointer;flex-wrap:wrap;justify-content:center}
.pwa-url-text{font-size:12px;color:var(--dim);word-break:break-all;flex:1}
.pwa-copy-btn{font-size:13px;color:var(--primary);white-space:nowrap;font-weight:600}
.pwa-copied{color:var(--accent);font-weight:600}
.pwa-prompt-counter{font-size:12px;color:var(--dim);text-align:center;margin-bottom:12px}
/* Home quote — shrink on small screens so button stays visible */
.home-quote{flex-shrink:1;overflow:hidden;min-height:0}
@media(max-height:700px){.home-quote{display:none}}

/* Support button */
.support-row{margin-top:16px;text-align:center}
.btn-support{width:100%;padding:12px;border:1px solid var(--primary);color:var(--primary);
  background:transparent;border-radius:var(--radius-btn);font-size:15px;font-weight:600;cursor:pointer}
.btn-support:active{background:var(--primary);color:#fff}
