/* LUMINA — TapToChill Ultra v2 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{width:100%;height:100%;overflow:hidden;background:#030812;font-family:-apple-system,'SF Pro Display','Inter',sans-serif;}
::selection{background:rgba(120,200,255,.2);}

/* ── CANVAS ── */
#lumina-canvas{position:fixed;inset:0;width:100%;height:100%;display:block;touch-action:none;}

/* ── ENTRY ── */
#lumina-entry{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#030812;transition:opacity 1.4s ease;}
#lumina-entry.hidden{opacity:0;pointer-events:none;}
.entry-glow{width:180px;height:180px;border-radius:50%;border:1.5px solid rgba(120,200,255,.25);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;margin-bottom:40px;transition:all .5s;}
.entry-glow::before{content:'';position:absolute;inset:-22px;border-radius:50%;border:1px solid rgba(120,200,255,.08);animation:entryRing 3.5s ease-in-out infinite;}
.entry-glow::after{content:'';position:absolute;inset:-50px;border-radius:50%;border:1px solid rgba(120,200,255,.04);animation:entryRing 3.5s ease-in-out infinite .5s;}
@keyframes entryRing{0%,100%{transform:scale(1);opacity:.4}50%{transform:scale(1.07);opacity:.12}}
.entry-glow:hover{border-color:rgba(120,200,255,.5);box-shadow:0 0 70px rgba(120,200,255,.18);}
.entry-inner{text-align:center;}
.entry-tap{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(120,200,255,.4);animation:entryPulse 2.2s ease-in-out infinite;display:block;}
@keyframes entryPulse{0%,100%{opacity:.35}50%{opacity:.9}}
.entry-logo{font-size:1rem;font-weight:300;color:rgba(255,255,255,.12);letter-spacing:.35em;text-transform:uppercase;margin-bottom:18px;}
.entry-name{font-size:3.8rem;font-weight:100;color:rgba(255,255,255,.9);letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px;line-height:1;}
.entry-sub{font-size:.65rem;color:rgba(255,255,255,.2);letter-spacing:.16em;text-transform:uppercase;margin-bottom:52px;}

/* ── HUD ── */
#lumina-hud{position:fixed;inset:0;z-index:100;pointer-events:none;opacity:0;transition:opacity .8s;}
#lumina-hud.visible{opacity:1;}

.hud-top{position:absolute;top:0;left:0;right:0;padding:22px 28px;display:flex;align-items:center;justify-content:space-between;pointer-events:auto;background:linear-gradient(to bottom,rgba(3,8,18,.75),transparent);}
.hud-logo{font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.22);font-weight:300;}
.hud-actions{display:flex;gap:8px;}
.hud-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);color:rgba(255,255,255,.45);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.82rem;transition:all .25s;backdrop-filter:blur(10px);}
.hud-btn:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.85);}
.hud-btn.active{background:rgba(120,200,255,.14);border-color:rgba(120,200,255,.4);color:rgba(120,200,255,.9);}

/* Centre breathing display — FIXED: no clipping, high z-index, overflow visible */
.hud-centre{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  text-align:center;pointer-events:none;
  z-index:105;
  width:320px;
  overflow:visible;
}
.hud-breath-word{
  font-size:clamp(.9rem,2.2vw,1.4rem);
  font-weight:300;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.65);
  min-height:1.6em;
  transition:opacity .6s,color .8s;
  text-shadow:0 0 40px rgba(120,200,255,.25);
}
.hud-breath-count{
  font-size:clamp(4rem,10vw,6.5rem);
  font-weight:100;
  color:rgba(255,255,255,.92);
  line-height:1.05;
  margin:2px 0;
  text-shadow:0 0 80px rgba(120,200,255,.2);
  transition:opacity .3s;
  min-height:1.1em;
}
.hud-breath-cycle{
  font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.18);
  min-height:1.2em;
}

/* Bottom bar */
.hud-bottom{position:absolute;bottom:0;left:0;right:0;padding:22px 28px;display:flex;align-items:flex-end;justify-content:space-between;pointer-events:auto;background:linear-gradient(to top,rgba(3,8,18,.82),transparent);}
.hud-sounds{display:flex;gap:7px;flex-wrap:wrap;align-items:flex-end;}
.hud-sound{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:100px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);cursor:pointer;transition:all .3s;backdrop-filter:blur(12px);user-select:none;}
.hud-sound:hover{background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.14);}
.hud-sound.on{background:rgba(120,200,255,.1);border-color:rgba(120,200,255,.3);}
.hud-sound-ico{font-size:.9rem;line-height:1;}
.hud-sound-name{font-size:.6rem;letter-spacing:.07em;color:rgba(255,255,255,.4);text-transform:uppercase;}
.hud-sound.on .hud-sound-name{color:rgba(120,200,255,.75);}
/* Sound visualizer dots */
.hud-sound-viz{display:none;gap:2px;align-items:flex-end;height:12px;margin-left:4px;}
.hud-sound.on .hud-sound-viz{display:flex;}
.hud-sound-vbar{width:2px;background:rgba(120,200,255,.6);border-radius:1px;animation:vizPulse .5s ease-in-out infinite;}
.hud-sound-vbar:nth-child(2){animation-delay:.1s;}
.hud-sound-vbar:nth-child(3){animation-delay:.2s;}
@keyframes vizPulse{0%,100%{height:3px}50%{height:10px}}

.hud-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;}
.hud-palettes{display:flex;flex-direction:column;gap:7px;align-items:flex-end;}
.hud-palette{width:26px;height:26px;border-radius:50%;cursor:pointer;transition:all .3s;border:2px solid transparent;opacity:.45;}
.hud-palette:hover{opacity:.8;transform:scale(1.2);}
.hud-palette.active{opacity:1;border-color:rgba(255,255,255,.65);transform:scale(1.15);}
.hud-streak{display:flex;align-items:center;gap:5px;padding:5px 11px;border-radius:100px;background:rgba(245,180,50,.07);border:1px solid rgba(245,180,50,.14);backdrop-filter:blur(8px);}
.hud-streak-ico{font-size:.82rem;}
.hud-streak-text{font-size:.6rem;color:rgba(245,180,50,.6);letter-spacing:.07em;}
.hud-hint{position:absolute;bottom:88px;left:50%;transform:translateX(-50%);font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.16);pointer-events:none;white-space:nowrap;transition:opacity 1s;}
.hud-credits{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.18);font-weight:300;white-space:nowrap;pointer-events:auto;}
.hud-credits a{color:rgba(255,255,255,.18);text-decoration:none;transition:color .3s;}
.hud-credits a:hover{color:rgba(255,255,255,.45);}

/* ── BILATERAL DOT (EMDR) ── */
#lumina-bilateral{position:fixed;top:50%;left:0;transform:translateY(-50%);z-index:108;pointer-events:none;display:none;}
#lumina-bilateral.show{display:block;}
.bilateral-dot{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.85);box-shadow:0 0 20px rgba(255,255,255,.4),0 0 40px rgba(120,200,255,.3);}

/* ── PANELS ── */
.lumina-panel{position:fixed;bottom:0;left:50%;transform:translateX(-50%) translateY(105%);z-index:150;width:min(520px,96%);background:rgba(3,8,18,.94);border:1px solid rgba(255,255,255,.08);border-bottom:none;border-radius:24px 24px 0 0;padding:26px 26px 44px;transition:transform .48s cubic-bezier(.34,1.15,.64,1);backdrop-filter:blur(28px);}
.lumina-panel.open{transform:translateX(-50%) translateY(0);}
.lumina-panel-handle{width:34px;height:3px;background:rgba(255,255,255,.1);border-radius:2px;margin:0 auto 22px;}
.lumina-panel-title{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:18px;}
.bp-modes{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:18px;}
.bp-mode{padding:8px 16px;border-radius:100px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);font-size:.68rem;letter-spacing:.06em;color:rgba(255,255,255,.38);cursor:pointer;transition:all .25s;font-family:inherit;}
.bp-mode.active{background:rgba(120,200,255,.1);border-color:rgba(120,200,255,.3);color:rgba(120,200,255,.9);}
.bp-info{font-size:.75rem;color:rgba(255,255,255,.28);line-height:1.75;margin-bottom:18px;min-height:52px;}
.bp-source{font-size:.62rem;color:rgba(120,200,255,.3);letter-spacing:.04em;margin-bottom:20px;}
.bp-start{width:100%;padding:13px;border-radius:100px;background:rgba(120,200,255,.1);border:1px solid rgba(120,200,255,.22);color:rgba(120,200,255,.88);font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .3s;font-family:inherit;}
.bp-start:hover{background:rgba(120,200,255,.18);box-shadow:0 0 30px rgba(120,200,255,.12);}
.bp-bilateral{display:flex;align-items:center;gap:10px;margin-top:14px;cursor:pointer;}
.bp-bilateral-toggle{width:32px;height:18px;border-radius:9px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);position:relative;transition:all .3s;flex-shrink:0;}
.bp-bilateral-toggle.on{background:rgba(120,200,255,.2);border-color:rgba(120,200,255,.4);}
.bp-bilateral-toggle::after{content:'';position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:rgba(255,255,255,.5);transition:all .3s;}
.bp-bilateral-toggle.on::after{left:16px;background:rgba(120,200,255,.9);}
.bp-bilateral-lbl{font-size:.68rem;color:rgba(255,255,255,.3);letter-spacing:.04em;}

.vol-row{display:flex;align-items:center;gap:14px;margin-bottom:14px;}
.vol-label{font-size:.7rem;color:rgba(255,255,255,.32);width:85px;flex-shrink:0;}
.vol-slider{flex:1;accent-color:rgba(120,200,255,.8);cursor:pointer;height:4px;}

/* ── MOOD RING ── */
#lumina-mood{position:fixed;top:50%;right:28px;transform:translateY(-50%);z-index:110;display:flex;flex-direction:column;gap:12px;opacity:0;pointer-events:none;transition:opacity .6s;}
#lumina-mood.show{opacity:1;pointer-events:auto;}
.mood-dot{width:10px;height:10px;border-radius:50%;cursor:pointer;transition:all .35s;opacity:.3;}
.mood-dot:hover{opacity:.8;transform:scale(1.6);}
.mood-dot.active{opacity:1;transform:scale(1.5);box-shadow:0 0 14px var(--mc);}

/* ── TOAST ── */
#lumina-toasts{position:fixed;top:76px;left:50%;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:7px;align-items:center;pointer-events:none;}
.lumina-toast{background:rgba(3,8,18,.92);border:1px solid rgba(255,255,255,.09);border-radius:100px;padding:9px 20px;font-size:.68rem;letter-spacing:.09em;color:rgba(255,255,255,.65);animation:toastIn .5s cubic-bezier(.34,1.4,.64,1);backdrop-filter:blur(18px);white-space:nowrap;}
.lumina-toast.out{animation:toastOut .3s ease forwards;}
@keyframes toastIn{from{opacity:0;transform:translateY(-14px) scale(.9)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(-8px) scale(.95)}}

/* ── INFO ── */
#lumina-info{position:fixed;inset:0;z-index:250;background:rgba(3,8,18,.95);display:flex;align-items:center;justify-content:center;overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .5s;backdrop-filter:blur(24px);}
#lumina-info.show{opacity:1;pointer-events:auto;}
.info-inner{max-width:480px;width:100%;padding:40px 28px;text-align:center;}
.info-title{font-size:1.7rem;font-weight:200;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.88);margin-bottom:10px;}
.info-sub{font-size:.78rem;color:rgba(255,255,255,.3);line-height:1.85;margin-bottom:28px;}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;text-align:left;}
.info-item{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:14px;}
.info-item-ico{font-size:1.1rem;margin-bottom:7px;}
.info-item-title{font-size:.7rem;font-weight:600;color:rgba(255,255,255,.65);margin-bottom:3px;letter-spacing:.04em;}
.info-item-text{font-size:.66rem;color:rgba(255,255,255,.28);line-height:1.65;}
.info-close{padding:11px 30px;border-radius:100px;background:rgba(120,200,255,.1);border:1px solid rgba(120,200,255,.22);color:rgba(120,200,255,.8);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .3s;font-family:inherit;}
.info-close:hover{background:rgba(120,200,255,.2);}
.info-friends{margin-top:22px;font-size:.6rem;color:rgba(255,255,255,.14);letter-spacing:.08em;}
.info-friends a{color:rgba(120,200,255,.32);text-decoration:none;transition:color .2s;}
.info-friends a:hover{color:rgba(120,200,255,.68);}
.info-faq{text-align:left;margin-bottom:22px;}
.info-faq details{border-bottom:1px solid rgba(255,255,255,.05);padding:9px 0;}
.info-faq summary{font-size:.7rem;color:rgba(255,255,255,.46);cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:12px;}
.info-faq summary::-webkit-details-marker{display:none;}
.info-faq summary::after{content:'+';color:rgba(120,200,255,.5);flex-shrink:0;}
.info-faq details[open] summary::after{content:'−';}
.info-faq p{font-size:.66rem;color:rgba(255,255,255,.25);line-height:1.75;padding-top:7px;}

@media(max-width:600px){
  .hud-bottom{padding:14px 16px;}
  .hud-sound-name{display:none;}
  .hud-top{padding:14px 18px;}
  .info-grid{grid-template-columns:1fr;}
  #lumina-mood{right:14px;}
  .hud-hint{display:none;}
  .entry-name{font-size:2.8rem;}
}
