*{box-sizing:border-box}html{overflow-x:hidden}:root{color-scheme:light;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-color: #f5f6fb;--bg-elevated: #ffffff;--card-border: rgba(15, 23, 42, .08);--text-color: #0f172a;--muted-text: #64748b;--accent: #6366f1;--accent-strong: #4f46e5;--button-bg: #1d4ed8;--button-bg-hover: #1e40af;--button-border: transparent;--button-text: #f8fafc;--input-bg: rgba(15, 23, 42, .03);--input-border: rgba(15, 23, 42, .12);--input-text: #0f172a;--muted-surface: rgba(15, 23, 42, .04);--note-bg: rgba(15, 23, 42, .08)}[data-theme=dark]{color-scheme:dark;--bg-color: #0b1120;--bg-elevated: #111a2e;--card-border: rgba(148, 163, 184, .2);--text-color: #e2e8f0;--muted-text: #94a3b8;--accent: #a78bfa;--accent-strong: #c084fc;--button-bg: #2563eb;--button-bg-hover: #1d4ed8;--button-border: rgba(148, 163, 184, .35);--button-text: #f8fafc;--input-bg: rgba(148, 163, 184, .15);--input-border: rgba(148, 163, 184, .3);--input-text: #e2e8f0;--muted-surface: rgba(148, 163, 184, .12);--note-bg: rgba(30, 41, 59, .65)}a{font-weight:500;color:var(--accent);text-decoration:inherit}a:hover{color:var(--accent-strong)}body{margin:0;min-height:100vh;background:#fff;color:#1a1a1a;transition:background-color .2s ease,color .2s ease;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1;margin-top:0;color:var(--text-color)}button{border-radius:999px;border:1px solid var(--button-border);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--button-bg);color:var(--button-text);cursor:pointer;transition:background-color .2s ease,border-color .2s ease,transform .2s ease}button:hover{background-color:var(--button-bg-hover);border-color:var(--accent)}button:focus,button:focus-visible{outline:3px solid var(--accent);outline-offset:3px}.page{min-height:100vh;background:radial-gradient(circle at top,rgba(99,102,241,.15),transparent 50%),var(--bg-color)}.page-toolbar{display:flex;justify-content:flex-end;padding:1rem 2rem 0}.app-layout{display:flex;gap:2rem;max-width:1280px;margin:0 auto;padding:1rem 2rem 3rem}.app-simple-layout{max-width:800px;margin:0 auto;padding:1rem 2rem 3rem}@media(max-width:960px){.app-layout{flex-direction:column;padding:1rem 1rem 2rem}.app-simple-layout{padding:1rem 1rem 2rem}}.theme-toggle{display:inline-flex;align-items:center;gap:.5rem;background:var(--bg-elevated);color:var(--text-color);border-radius:999px;border:1px solid var(--card-border);padding:.45rem .95rem;box-shadow:0 10px 25px #0f172a1f}.theme-toggle img{width:1.5rem;height:1.5rem}.container{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.card{padding:2rem;background-color:var(--bg-elevated);border-radius:1.5rem;border:1px solid var(--card-border);box-shadow:0 20px 30px #0f172a1f}.read-the-docs{color:var(--muted-text)}.example-card{border:1px solid var(--card-border);border-radius:1.1rem;padding:1.5rem;background:var(--bg-elevated);display:flex;flex-direction:column;gap:1rem;box-shadow:0 15px 25px #0f172a14}.todo-form{display:flex;gap:.75rem}.todo-input{flex:1;padding:.6rem .9rem;border-radius:999px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--input-text)}.todo-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.todo-list li{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem .75rem;border-radius:12px;background:var(--muted-surface)}.todo-list button{padding:.3rem .75rem;font-size:.9rem}.todo-empty{color:var(--muted-text);text-align:center}.clock-display{display:flex;justify-content:center;padding:.5rem 0;font-size:1.6rem}.clock-time{font-variant-numeric:tabular-nums;font-weight:600}.note-textarea{width:100%;border-radius:12px;border:1px solid var(--input-border);padding:.75rem;background:var(--note-bg);color:var(--input-text);resize:vertical;font-family:inherit}.note-footer{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:var(--muted-text)}.note-status{min-height:1.25rem}.nav-panel{flex:0 0 320px;padding:1.5rem;background:var(--bg-elevated);border-radius:1.25rem;border:1px solid var(--card-border);box-shadow:0 15px 30px #0f172a14}@media(max-width:960px){.nav-panel{flex:1}}.nav-links{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.nav-link{display:flex;flex-direction:column;gap:.25rem;padding:.9rem 1rem;border-radius:1rem;border:1px solid transparent;background:var(--input-bg);color:var(--text-color);transition:border-color .2s ease,background .2s ease,transform .2s ease}.nav-link:hover{border-color:var(--accent);transform:translateY(-1px)}.nav-link.is-active{border-color:var(--accent);background:#6366f126}.nav-link-title{font-weight:600}.nav-link-desc{font-size:.9rem;color:var(--muted-text)}.route-content{flex:1;padding:1.5rem;border-radius:1.5rem;border:1px solid var(--card-border);background:var(--bg-elevated);box-shadow:0 25px 40px #0f172a1f;min-height:500px}.route-header{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.35rem}.route-path{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted-text)}.route-description{color:var(--muted-text)}.route-body{display:flex;flex-direction:column;gap:1.5rem}.route-stack{display:flex;flex-direction:column;gap:1.25rem}.muted-text{color:var(--muted-text)}.home-list{list-style:disc;margin:0 0 0 1.25rem;padding:0;display:flex;flex-direction:column;gap:.4rem;color:var(--muted-text)}.nav-header{margin-bottom:.75rem}.nav-header h2{margin:0}.param-form{display:flex;flex-direction:column;gap:1rem}.param-inputs{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.param-inputs label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:var(--muted-text)}.param-inputs input{padding:.65rem .9rem;border-radius:.85rem;border:1px solid var(--input-border);background:var(--input-bg);color:var(--input-text)}th{text-align:left;border-bottom:1px solid #ccc}th,td{padding:.5rem}.breathing-page{width:100%;max-width:720px;margin:0 auto;padding:2rem 1rem;min-height:100vh;box-sizing:border-box}.breathing-container{display:flex;flex-direction:column;gap:1.5rem;padding:0;width:100%;box-sizing:border-box}.breathing-today{text-align:center;padding:0;background:transparent}.breathing-today-label{font-size:1.1rem;color:#666;margin-bottom:.5rem;font-weight:400}.breathing-today-time{font-size:2.8rem;font-weight:550;color:#1a1a1a;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.breathing-visual{border-radius:1.5rem;overflow:hidden;position:relative;box-sizing:border-box;min-height:300px;display:flex;align-items:center;justify-content:center;background:#fff;margin:0 .75rem}.breathing-illustration{width:100%;max-width:100%;height:auto;display:block;border-radius:1.5rem}.breathing-animation-container{position:relative;width:100%;height:100%;min-height:400px;display:flex;align-items:center;justify-content:center;background:transparent;overflow:hidden}.breathing-circle-middle,.breathing-circle-inner{position:absolute;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);filter:blur(.3px)}.breathing-circle-middle{width:260px;height:260px;background:radial-gradient(circle,rgba(198,238,234,.82) 0%,rgba(125,190,243,.74) 32%,rgba(135,206,250,.62) 58%,rgba(162,217,251,.52) 78%,rgba(188,234,249,.4) 90%,rgba(240,248,255,.32) 96%,transparent 100%);will-change:transform,opacity;transition:transform .3s cubic-bezier(.25,.46,.45,.94),opacity .3s cubic-bezier(.25,.46,.45,.94);box-shadow:0 0 40px #64b5f673,0 0 70px #87cefa4d,0 0 110px #87cefa29,inset 0 0 20px #ffffff4d}.breathing-circle-inner{width:160px;height:160px;background:radial-gradient(circle,#f6f6f6b8,#d1f8f3a3 30%,#c6f6f08a 56%,#95fcf775,#9df7f731);display:flex;align-items:center;justify-content:center;will-change:transform,opacity;transition:transform .3s cubic-bezier(.25,.46,.45,.94),opacity .3s cubic-bezier(.25,.46,.45,.94);box-shadow:0 0 60px #40e0d080,0 0 90px #40e0d052,0 0 120px #64b5f633,inset 0 0 45px #ffffff47}.breathing-phase-hold1 .breathing-circle-middle,.breathing-phase-hold1 .breathing-circle-inner,.breathing-phase-hold2 .breathing-circle-middle,.breathing-phase-hold2 .breathing-circle-inner{transition:none!important}.breathing-countdown-number{font-size:3.5rem;font-weight:400;color:#4a5568;font-variant-numeric:tabular-nums;line-height:1;transition:opacity .2s ease;text-shadow:0 2px 12px rgba(255,255,255,.8),0 0 20px rgba(255,255,255,.6),0 4px 8px rgba(0,0,0,.1);z-index:1;position:relative;letter-spacing:-.02em}.breathing-sound-button{position:absolute;bottom:1rem;right:1rem;width:56px;height:56px;border-radius:50%;background:#fff;color:#1a1a1a;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #00000026;transition:all .2s ease;padding:0;z-index:10}.breathing-sound-button svg{width:28px;height:28px;flex-shrink:0}.breathing-sound-button:hover{transform:scale(1.05);box-shadow:0 6px 16px #0003;background:#fff}.breathing-session{display:flex;flex-direction:column;align-items:center;gap:1.75rem;background:transparent;width:100%;box-sizing:border-box}.breathing-session-title{font-size:2rem;margin:0;color:#1a1a1a;text-align:center;font-weight:600}.breathing-control{display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:100%}.breathing-circle-container{position:relative;width:126px;height:126px;display:flex;align-items:center;justify-content:center}.breathing-circle{width:98px;height:98px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #00000014;transition:box-shadow .3s ease;border:3px solid #2D3748}.breathing-circle.active{box-shadow:0 6px 24px #0000001f}.breathing-circle:hover{box-shadow:0 6px 28px #00000026}.breathing-play-button{width:100%;height:100%;border:none;background:transparent;color:#2d3748;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:color .2s ease}.breathing-play-button:hover{background:transparent;border:none;color:#1a1a1a}.breathing-play-button:focus{outline:none}.breathing-phase-indicator{margin-top:-1.2rem;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:fit-content;margin-left:auto;margin-right:auto}.breathing-phase-label{font-size:1.5rem;font-weight:600;color:#2d3748;margin-bottom:.5rem;animation:phase-label-fade .4s ease}@keyframes phase-label-fade{0%{opacity:0;transform:translateY(8px)}60%{opacity:1;transform:translateY(0)}to{opacity:1;transform:translateY(0)}}.breathing-phase-countdown{font-size:2rem;font-weight:700;color:#2d3748;font-variant-numeric:tabular-nums}.breathing-cycle-counter{font-size:.9rem;font-weight:500;color:#5dd4c8;margin-top:.5rem}.breathing-params-wrapper{display:flex;align-items:center;gap:0;width:86%;max-width:600px;justify-content:center;padding:0;background:transparent;border-radius:0;border:none;overflow:hidden}.breathing-timer-icon{flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;color:#5dd4c8;background:transparent;border-radius:0;border:none;border-right:1px solid #E0E0E0;cursor:pointer;transition:all .2s ease;padding:0}.breathing-timer-icon:hover{background:#f0f0f0;color:#4ec2b6}.breathing-params{display:flex;gap:0;flex:1;flex-wrap:nowrap;background:transparent;border-radius:0;border:none}.breathing-param{flex:1 1 0;min-width:0;text-align:center;padding:.5rem;background:transparent;border-radius:0;border:none;border-right:1px solid #E0E0E0;position:relative}.breathing-param:last-child{border-right:none}.breathing-param-time{font-size:1.4rem;font-weight:700;color:#2d3748;margin-bottom:.25rem;line-height:1.2}.breathing-param-label{font-size:.76rem;color:#999;text-transform:uppercase;letter-spacing:.05em;font-weight:500;line-height:1}.breathing-patterns-scroll{width:100%;max-width:100%;overflow-x:scroll;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:.5rem 0 1rem;position:relative;scroll-snap-type:x mandatory;margin:0 -1rem}.breathing-patterns-scroll::-webkit-scrollbar{display:none}.breathing-patterns{display:grid;grid-auto-flow:column;grid-auto-columns:100%;gap:0}.breathing-pattern-card-wrapper{width:100%;scroll-snap-align:start;display:flex;justify-content:center;padding:0 1rem;box-sizing:border-box;cursor:pointer}.breathing-pattern-card{background:#fff;border:1px solid #ECECEC;border-radius:1.5rem;transition:all .25s ease;text-align:left;display:flex;flex-direction:column;gap:1.25rem;width:100%;max-width:680px;box-shadow:0 2px 16px #0000000a;box-sizing:border-box;padding:2rem 1.75rem}.breathing-pattern-card:hover{border-color:#d8d8d8;transform:translateY(-1px);box-shadow:0 6px 20px #00000014}.breathing-pattern-card.active{border-color:#e0e0e0;background:#fff;box-shadow:0 4px 20px #00000014;transform:scale(1)}.breathing-pattern-name{font-size:1.5rem;font-weight:600;color:#2d3748;line-height:1.4;text-align:left}.breathing-pattern-tags{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-start}.breathing-pattern-tag{padding:.5rem 1rem;border-radius:1.25rem;font-size:.875rem;font-weight:500;white-space:nowrap}.breathing-pattern-tag.tag-0{background:#e8ddf5;color:#9b7ab8}.breathing-pattern-tag.tag-1{background:#ffdcd6;color:#e89688}.breathing-pattern-tag.tag-deep-relaxation{background:#e0f2f1;color:#5dd4c8}.breathing-indicators{display:flex;gap:.625rem;justify-content:center;align-items:center;margin-top:.5rem}.breathing-indicator{width:10px;height:10px;border-radius:50%;background:#c8c8c8;border:none;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;padding:4px;position:relative;flex-shrink:0}.breathing-indicator:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:18px;height:18px}.breathing-indicator:hover{background:#999}.breathing-indicator.active{background:#2d3748;width:32px;height:10px;border-radius:5px}.breathing-indicator.active:hover{background:#1a1a1a}.breathing-history{padding:2rem 1.75rem;background:#fff;border-radius:1.5rem;border:1px solid #ECECEC;box-shadow:0 2px 16px #0000000a}.breathing-history-title{font-size:1.8rem;margin:0 0 1.5rem;color:#2d3748;text-align:center;font-weight:600}.breathing-history-item{display:flex;flex-direction:column;align-items:center;gap:1rem;background:transparent;border-radius:1rem;border:none;cursor:pointer;transition:all .2s ease}.breathing-history-item:hover{background:#f9f9f9}.breathing-history-date{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:#2d3748;font-weight:500}.breathing-history-icons{display:flex;gap:.375rem;color:#5dd4c8}.breathing-history-time{font-size:2rem;font-weight:700;color:#2d3748;font-variant-numeric:tabular-nums}.breathing-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.breathing-modal{background:#fff;border-radius:1.5rem;width:100%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.breathing-modal-header{display:flex;justify-content:space-between;align-items:center;padding:2rem 2rem 1.5rem;border-bottom:1px solid #F0F0F0}.breathing-modal-title{font-size:2rem;font-weight:600;margin:0;color:#1a1a1a}.breathing-modal-close{width:40px;height:40px;border-radius:50%;background:transparent;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:all .2s ease;padding:0}.breathing-modal-close:hover{background:#f5f5f5;color:#1a1a1a}.breathing-modal-body{padding:3rem 2rem 2rem;display:flex;flex-direction:column;gap:2.5rem}.breathing-timer-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;width:100%;max-width:450px;margin:0 auto}.breathing-timer-btn{width:64px;height:64px;border-radius:50%;background:#fff;border:2px solid #E0E0E0;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666;transition:background .2s ease,border-color .2s ease;flex-shrink:0;padding:0}.breathing-timer-btn:hover{border-color:#1a1a1a;background:#f9f9f9}.breathing-timer-btn:active{background:#f0f0f0}.breathing-timer-display{display:flex;align-items:center;gap:1rem;justify-content:center;min-width:0;flex:1}.breathing-timer-value{font-size:1.5rem;font-weight:600;color:#1a1a1a;white-space:nowrap;min-width:80px;text-align:right}.breathing-timer-divider{width:2px;height:32px;background:#e0e0e0;flex-shrink:0}.breathing-timer-duration{font-size:1.5rem;font-weight:600;color:#1a1a1a;white-space:nowrap;min-width:80px;text-align:left}.breathing-timer-actions{display:flex;gap:1rem}.breathing-timer-action-btn{padding:1rem 1.5rem;border-radius:2rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:2px solid #5DD4C8;background:#5dd4c8;color:#fff;flex:1;width:100%}.breathing-timer-action-btn:hover{background:#4ec2b6;border-color:#4ec2b6;box-shadow:0 6px 16px #5dd4c866}.breathing-calendar-modal{max-width:600px}.breathing-calendar{width:100%}.breathing-date-list{display:flex;flex-direction:column;gap:.75rem}.breathing-date-item{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:#fff;border:2px solid #E0E0E0;border-radius:1rem;cursor:pointer;transition:all .2s ease;text-align:left}.breathing-date-item:hover{border-color:#5dd4c8;background:#f9fffe}.breathing-date-item.selected{border-color:#5dd4c8;background:#f0fffe;box-shadow:0 4px 12px #5dd4c833}.breathing-date-label{font-size:.9rem;color:#666;font-weight:500;min-width:60px}.breathing-date-day{font-size:1.5rem;font-weight:700;color:#2d3748;min-width:40px;text-align:center}.breathing-date-duration{font-size:1rem;font-weight:600;color:#2d3748;text-align:right;flex:1}@media(max-width:640px){.breathing-page{padding:1.5rem .75rem}.breathing-today-time{font-size:2.2rem}.breathing-session-title{font-size:1.6rem}.breathing-params-wrapper{gap:0;padding:0}.breathing-timer-icon{width:44px;height:44px}.breathing-timer-icon svg{width:22px;height:22px}.breathing-params{gap:0}.breathing-circle-container{width:98px;height:98px}.breathing-circle{width:84px;height:84px;border:3px solid #2D3748}.breathing-play-button svg{width:28px;height:28px}.breathing-param{min-width:0;flex:1 1 0;padding:.25rem}.breathing-param-time{font-size:1.2rem}.breathing-patterns-scroll{padding:.5rem 0 .75rem;margin:0 -.75rem}.breathing-patterns{gap:0}.breathing-pattern-card-wrapper{padding:0 .75rem}.breathing-pattern-card{padding:1.75rem 1.5rem;gap:1rem}.breathing-pattern-name{font-size:1.3rem}.breathing-pattern-tag{font-size:.8rem;padding:.45rem .9rem}.breathing-indicators{margin-top:.25rem}.breathing-indicator{width:8px;height:8px}.breathing-indicator:before{width:16px;height:16px}.breathing-indicator.active{width:26px;height:8px}.breathing-sound-button{width:56px;height:56px;bottom:3.6rem;right:1rem}.breathing-sound-button svg{width:28px;height:28px}.breathing-history{padding:1.5rem 1.25rem;margin:0 .75rem}.breathing-history-title{font-size:1.5rem}.breathing-history-item{gap:.75rem}.breathing-history-date{font-size:.9rem}.breathing-history-time{font-size:1.75rem}.breathing-animation-container{min-height:340px}.breathing-circle-middle{width:200px;height:200px;box-shadow:0 0 55px #64b5f661,0 0 80px #87cefa3b,0 0 105px #87cefa1c}.breathing-circle-inner{width:100px;height:100px;box-shadow:0 0 48px #40e0d07a,0 0 72px #40e0d04d,0 0 96px #64b5f62e,inset 0 0 36px #ffffff42}.breathing-countdown-number{font-size:3rem}.breathing-calendar-modal{max-width:90%}.breathing-date-item{padding:1rem 1.25rem}.breathing-date-label{font-size:.85rem;min-width:50px}.breathing-date-day{font-size:1.3rem;min-width:35px}.breathing-date-duration{font-size:.9rem}.breathing-modal{max-width:90%}.breathing-modal-header{padding:1.5rem 1.5rem 1rem}.breathing-modal-title{font-size:1.5rem}.breathing-modal-close{width:36px;height:36px}.breathing-modal-body{padding:2rem 1.5rem 1.5rem;gap:2rem}.breathing-timer-controls{gap:1rem;max-width:100%}.breathing-timer-btn{width:52px;height:52px}.breathing-timer-btn svg{width:20px;height:20px}.breathing-timer-display{gap:.75rem}.breathing-timer-value,.breathing-timer-duration{font-size:1.25rem;min-width:65px}.breathing-timer-divider{height:28px}.breathing-timer-actions{gap:.75rem}.breathing-timer-action-btn{padding:.875rem 1rem;font-size:.9rem}}
