:root{--bg:#0e1b2a;--bg-2:#122a3f;--surface:#ffffff0f;--surface-2:#ffffff1a;--border:#ffffff1f;--text:#eaf2f8;--muted:#9fb3c8;--primary:#38bdf8;--primary-2:#0ea5e9;--accent:#5eead4;--danger:#fb7185;--ok:#4ade80;--radius:16px;--shadow:0 10px 30px #00000059;color:var(--text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(1200px 800px at 70% -10%, var(--bg-2), var(--bg));background-attachment:fixed;min-height:100vh}h1,h2,h3{margin:0 0 .4em;font-weight:650}.muted{color:var(--muted)}.small{font-size:.85rem}.err{color:var(--danger)}.ok{color:var(--ok)}.btn{appearance:none;color:var(--text);background:var(--surface-2);cursor:pointer;text-align:center;border:1px solid #0000;border-radius:12px;padding:.7rem 1.1rem;font-size:1rem;font-weight:600;text-decoration:none;transition:transform 50ms,background .2s,opacity .2s;display:inline-block}.btn:hover{background:#ffffff29}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(180deg, var(--primary), var(--primary-2));color:#04222e}.btn-primary:hover{filter:brightness(1.05);background:linear-gradient(180deg, var(--primary), var(--primary-2))}.btn-ghost{border-color:var(--border);background:0 0}.btn-sm{padding:.4rem .7rem;font-size:.85rem}.btn-lg{padding:.95rem 1.3rem;font-size:1.1rem}.btn-block{width:100%;margin-top:.6rem;display:block}.alert{color:#ffd9df;background:#fb71851f;border:1px solid #fb718566;border-radius:12px;padding:.7rem .9rem;font-size:.9rem}.chip{background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:.3rem .6rem;font-size:.82rem;display:inline-block}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:34px;height:34px;margin:3rem auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.centered-screen{place-items:center;min-height:100dvh;display:grid}.app-shell{flex-direction:column;min-height:100dvh;display:flex}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#08121e99;align-items:center;gap:1rem;padding:.8rem 1.1rem;display:flex;position:sticky;top:0}.brand{letter-spacing:.2px;white-space:nowrap;font-weight:700}.brand-mark{color:var(--accent);margin-right:.3rem}.nav{gap:.3rem;display:flex}.nav-link{color:var(--muted);border-radius:10px;padding:.45rem .8rem;font-size:.95rem;font-weight:600;text-decoration:none}.nav-link:hover{color:var(--text);background:var(--surface)}.nav-link.active{color:var(--text);background:var(--surface-2)}.nav-group{align-items:center;gap:.8rem;margin-left:auto;display:flex}.user-name{color:var(--muted);font-size:.9rem}.nav-toggle{border:1px solid var(--border);width:40px;height:40px;color:var(--text);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;margin-left:auto;font-size:1.15rem;line-height:1;display:none}.nav-toggle:hover{background:var(--surface)}.content{flex-direction:column;flex:1;width:100%;max-width:760px;margin:0 auto;padding:1.2rem;display:flex}.page{animation:.25s fade}@keyframes fade{0%{opacity:0;transform:translateY(4px)}}.page-title{margin-bottom:1rem;font-size:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1rem;padding:1rem 1.1rem}.card-title{color:var(--muted);margin-bottom:.8rem;font-size:1rem}.auth-screen{place-items:center;min-height:100dvh;padding:1.2rem;display:grid}.auth-card{background:var(--surface);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:20px;padding:1.6rem}.auth-brand{text-align:center;margin-bottom:1.2rem}.auth-brand h1{margin:.4rem 0 .2rem;font-size:1.5rem}.auth-brand .brand-mark{font-size:2.2rem}.seg{border:1px solid var(--border);background:#00000040;border-radius:12px;gap:.25rem;margin-bottom:1.1rem;padding:.25rem;display:flex}.seg-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:9px;flex:1;padding:.5rem .6rem;font-size:.92rem;font-weight:600}.seg-btn.active{background:var(--surface-2);color:var(--text)}.form{flex-direction:column;gap:.9rem;display:flex}.field{flex-direction:column;gap:.35rem;display:flex}.field>span{color:var(--muted);font-size:.85rem}.field input{border:1px solid var(--border);color:var(--text);background:#00000040;border-radius:11px;outline:none;padding:.7rem .8rem;font-size:1rem}.field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #38bdf82e}.row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:.7rem 0;display:flex}.row:last-child{border-bottom:none}.row-label{flex-direction:column;display:flex}.row-label>span{font-weight:600}.row-label small{font-size:.8rem}.hint-block{margin:.4rem 0 0;font-size:.9rem;line-height:1.45}.stepper{border:1px solid var(--border);background:#00000040;border-radius:12px;align-items:center;gap:.2rem;padding:.2rem;display:flex}.stepper-btn{background:var(--surface-2);width:34px;height:34px;color:var(--text);cursor:pointer;border:none;border-radius:9px;font-size:1.2rem}.stepper-btn:disabled{opacity:.4;cursor:not-allowed}.stepper-value{text-align:center;font-variant-numeric:tabular-nums;min-width:56px;font-weight:700}.stepper-suffix{color:var(--muted);margin-left:1px;font-style:normal;font-weight:500}.hold-preview{flex-wrap:wrap;gap:.4rem;padding-top:.8rem;display:flex}.switch{border:1px solid var(--border);cursor:pointer;background:#0000004d;border-radius:999px;width:50px;height:30px;transition:background .2s;position:relative}.switch.on{background:var(--primary-2);border-color:var(--primary-2)}.switch-knob{background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .2s;position:absolute;top:3px;left:3px}.switch.on .switch-knob{transform:translate(20px)}.session-screen{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.4rem;min-height:0;display:flex}.session-top{justify-content:space-between;align-items:center;width:100%;max-width:360px;display:flex}.round-pill{background:var(--surface);border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:.35rem .8rem;font-size:.85rem}.elapsed{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.9rem}.orb-wrap{cursor:default;background:0 0;border:none;place-items:center;width:300px;height:300px;padding:0;display:grid}.orb-wrap:not(:disabled){cursor:pointer}.orb{will-change:transform;background:radial-gradient(circle at 35% 30%,#5eead459,#38bdf81f 60%,#0000 70%);border:1px solid #5eead44d;border-radius:50%;place-items:center;width:230px;height:230px;transition-property:transform;transition-timing-function:ease-in-out;display:grid;box-shadow:0 0 60px #38bdf840,inset 0 0 40px #5eead433}.orb-inner{flex-direction:column;align-items:center;gap:.15rem;display:flex}.orb-action{letter-spacing:.3px;font-size:1.25rem;font-weight:600}.orb-big{font-variant-numeric:tabular-nums;font-size:2.6rem;font-weight:700;line-height:1}.orb-sub{color:var(--muted);max-width:160px;font-size:.85rem}.phase-retention .orb{background:radial-gradient(circle at 35% 30%,#94a3ff4d,#6366f11f 60%,#0000 70%);border-color:#94a3ff4d}.phase-recoveryInhale .orb,.phase-recoveryHold .orb{background:radial-gradient(circle at 35% 30%,#4ade8047,#22c55e1a 60%,#0000 70%);border-color:#4ade804d}.session-controls{gap:.6rem;display:flex}.ready-card,.done-card{background:var(--surface);border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow);border-radius:20px;padding:1.6rem}.ready-card h2,.done-card h2{font-size:1.4rem}.done-mark{width:56px;height:56px;color:var(--ok);background:#4ade802e;border-radius:50%;place-items:center;margin:0 auto .6rem;font-size:1.8rem;display:grid}.done-stats{grid-template-columns:repeat(2,1fr);gap:.6rem;margin:1.1rem 0;display:grid}.stat{border:1px solid var(--border);background:#0003;border-radius:12px;padding:.7rem}.stat-value{font-size:1.3rem;font-weight:700}.stat-label{color:var(--muted);font-size:.78rem}.done-holds{flex-wrap:wrap;justify-content:center;gap:.4rem;margin-bottom:1rem;display:flex}.save-line{min-height:1.2rem;margin-bottom:.6rem;font-size:.9rem}.done-actions{flex-direction:column;display:flex}.session-list{flex-direction:column;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.session-row{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.9rem 1rem;display:flex}.session-row-main{flex-direction:column;gap:.15rem;display:flex}.session-date{font-weight:600}.session-meta{font-size:.85rem}.session-row-stats{gap:1.1rem;display:flex}.metric{text-align:right}.metric-value{font-variant-numeric:tabular-nums;font-weight:700}.metric-label{font-size:.72rem}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:.6rem;padding-top:3rem;display:flex}.stat-grid{grid-template-columns:repeat(2,1fr);gap:.7rem;margin-bottom:1.2rem;display:grid}.big-stat{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1rem}.big-stat.accent{background:linear-gradient(160deg,#38bdf82e,#5eead414);border-color:#5eead459}.big-stat-value{font-variant-numeric:tabular-nums;font-size:1.8rem;font-weight:700}.big-stat-label{color:var(--muted);font-size:.8rem}.heatmap{gap:4px;padding-bottom:.3rem;display:flex;overflow-x:auto}.heatmap-week{flex-direction:column;gap:4px;display:flex}.heatmap-cell{background:#ffffff0f;border-radius:4px;width:15px;height:15px}.heatmap-cell.off{background:#ffffff14}.heatmap-cell.on{background:linear-gradient(160deg, var(--accent), var(--primary))}.heatmap-cell.empty{background:0 0}@media (width>=560px){.stat-grid,.done-stats{grid-template-columns:repeat(4,1fr)}}@media (width<=600px){.nav-toggle{display:inline-flex}.nav-group{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);box-shadow:var(--shadow);background:#08121efa;flex-direction:column;align-items:stretch;gap:.25rem;margin:0;padding:.6rem;display:none;position:absolute;top:100%;left:0;right:0}.nav-group.open{display:flex}.nav-group .user-name{color:var(--text);border-bottom:1px solid var(--border);order:-1;margin-bottom:.2rem;padding:.5rem .8rem;font-weight:600}.nav-group .nav{flex-direction:column;gap:.15rem}.nav-group .nav-link{border-radius:10px;padding:.7rem .8rem}.nav-group .btn{width:100%;margin-top:.3rem}}@media (width<=460px){.orb-wrap{width:260px;height:260px}.orb{width:200px;height:200px}}
