body,html{margin:0;padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-50:#faf5f0;--primary-100:#f0e6d8;--primary-200:#e0ccb3;--primary-300:#c9a87a;--primary-400:#b88f4e;--primary-500:#a67b3d;--primary-600:#8c6432;--primary-700:#704f28;--primary-800:#5a3f21;--primary-900:#47321a;--gray-50:#f8f9fa;--gray-100:#f1f3f5;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#868e96;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--success:#2d8a5d;--success-light:#d4edda;--warning:#c9a227;--warning-light:#fff3cd;--danger:#c9302c;--danger-light:#f8d7da;--info:#2d6a8a;--info-light:#d1ecf1;--learn-color:#4a6fa5;--articulation-color:#6b5b95;--bank-color:#2d8a5d;--bestfriend-color:#c97b63;--font-serif:"Source Serif 4",Georgia,serif;--font-sans:"Source Sans 3",-apple-system,BlinkMacSystemFont,sans-serif;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 10px 15px #0000001a;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:linear-gradient(135deg,#f8f9fa,#faf5f0);background:linear-gradient(135deg,var(--gray-50) 0,var(--primary-50) 100%);color:#343a40;color:var(--gray-800);font-family:Source Sans\ 3,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-sans);line-height:1.6;min-height:100vh}.app-container{background:#fff;box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);margin:0 auto;max-width:480px;min-height:100vh}@media (min-width:768px){.app-container{border-radius:16px;border-radius:var(--radius-xl);margin-bottom:2rem;margin-bottom:var(--space-xl);margin-top:2rem;margin-top:var(--space-xl);min-height:calc(100vh - 4rem)}}.home-view{display:flex;flex-direction:column;min-height:100vh;padding:1.5rem;padding:var(--space-lg)}.app-header{border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--gray-200);margin-bottom:1.5rem;margin-bottom:var(--space-lg);padding:2rem 0;padding:var(--space-xl) 0;text-align:center}.app-title{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:2.5rem;font-weight:700;letter-spacing:.05em;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.app-subtitle{color:#868e96;color:var(--gray-600);font-size:.9rem;font-weight:400}.modules-grid{flex:1 1;flex-direction:column}.module-card,.modules-grid{display:flex;gap:1rem;gap:var(--space-md)}.module-card{align-items:center;background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;padding:1.5rem;padding:var(--space-lg);text-align:left;transition:all .2s ease;width:100%}.module-card:hover{border-color:#dee2e6;border-color:var(--gray-300);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md);transform:translateY(-2px)}.module-card .module-icon{align-items:center;border-radius:8px;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.module-card.learn .module-icon{background:#4a6fa51a;color:#4a6fa5;color:var(--learn-color)}.module-card.learn.primary{border-color:#4a6fa5;border-color:var(--learn-color)}.module-card.learn.completed{border-color:#2d8a5d;border-color:var(--success)}.module-card.articulation .module-icon{background:#6b5b951a;color:#6b5b95;color:var(--articulation-color)}.module-card.bank .module-icon{background:#2d8a5d1a;color:#2d8a5d;color:var(--bank-color)}.module-card.bestfriend .module-icon{background:#c97b631a;color:#c97b63;color:var(--bestfriend-color)}.module-content{flex:1 1}.module-content h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem;font-weight:600;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.module-content p{color:#868e96;color:var(--gray-600);font-size:.85rem}.module-content .badge{background:#f1f3f5;background:var(--gray-100);border-radius:100px;color:#495057;color:var(--gray-700);display:inline-block;font-size:.75rem;margin-top:.25rem;margin-top:var(--space-xs);padding:2px 8px}.module-card .chevron{color:#ced4da;color:var(--gray-400);flex-shrink:0}.app-footer{border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);margin-top:auto;padding:1.5rem 0;padding:var(--space-lg) 0;text-align:center}.footer-text{color:#adb5bd;color:var(--gray-500);font-size:.8rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.footer-link a{align-items:center;color:#8c6432;color:var(--primary-600);display:inline-flex;font-size:.8rem;gap:4px;text-decoration:none}.footer-link a:hover{text-decoration:underline}.view-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--gray-200);display:flex;gap:1rem;gap:var(--space-md);padding:1.5rem;padding:var(--space-lg);position:-webkit-sticky;position:sticky;top:0;z-index:10}.view-header h1{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem;font-weight:600}.back-btn{align-items:center;background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);color:#495057;color:var(--gray-700);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.back-btn:hover{background:#f8f9fa;background:var(--gray-50);border-color:#dee2e6;border-color:var(--gray-300)}.nav-btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;gap:var(--space-sm);justify-content:center;padding:.5rem 1.5rem;padding:var(--space-sm) var(--space-lg);transition:all .2s}.nav-btn.primary{background:#212529;background:var(--gray-900);color:#fff}.nav-btn.primary:hover:not(:disabled){background:#343a40;background:var(--gray-800)}.nav-btn.secondary{background:#fff;border:1px solid #dee2e6;border:1px solid var(--gray-300);color:#495057;color:var(--gray-700)}.nav-btn.secondary:hover:not(:disabled){background:#f8f9fa;background:var(--gray-50)}.nav-btn:disabled{cursor:not-allowed;opacity:.5}.nav-btn.complete,.nav-btn.save{background:#2d8a5d;background:var(--success)}.progress-bar{background:#e9ecef;background:var(--gray-200);height:4px;position:relative}.progress-fill{background:#a67b3d;background:var(--primary-500);height:100%;transition:width .3s ease}.step-progress{display:flex;gap:.5rem;gap:var(--space-sm);justify-content:center;padding:1.5rem;padding:var(--space-lg)}.step-dot{background:#e9ecef;background:var(--gray-200);border-radius:50%;cursor:pointer;height:10px;transition:all .2s;width:10px}.step-dot.active{background:#a67b3d;background:var(--primary-500);transform:scale(1.2)}.step-dot.done{background:#2d8a5d;background:var(--success)}.learn-view{display:flex;flex-direction:column;min-height:100vh}.slide-container{flex:1 1;overflow-y:auto;padding:1.5rem;padding:var(--space-lg)}.slide{max-width:100%}.slide-title{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.slide-content{font-size:1rem;line-height:1.7}.slide-content p,.slide-content ul{margin-bottom:1rem;margin-bottom:var(--space-md)}.slide-content ul{margin-left:1.5rem;margin-left:var(--space-lg)}.slide-content li{margin-bottom:.5rem;margin-bottom:var(--space-sm)}.concept-grid{grid-gap:1rem;grid-gap:var(--space-md);display:grid;gap:1rem;gap:var(--space-md);margin:1.5rem 0;margin:var(--space-lg) 0}.concept-card{background:#f8f9fa;background:var(--gray-50);border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);padding:1rem;padding:var(--space-md)}.concept-card h4{font-size:1.1rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.concept-card p{color:#868e96;color:var(--gray-600);font-size:.9rem;margin:0}.insight{background:#faf5f0;background:var(--primary-50);border-left:3px solid #a67b3d;border-left:3px solid var(--primary-500);border-radius:0 8px 8px 0;border-radius:0 var(--radius-md) var(--radius-md) 0;color:#495057;color:var(--gray-700);font-style:italic;margin-top:1.5rem;margin-top:var(--space-lg);padding:1rem;padding:var(--space-md)}.benefit-list,.example-list,.practice-steps,.problem-list{list-style:none;margin-left:0}.benefit-list li,.example-list li,.practice-steps li,.problem-list li{padding-left:1.5rem;padding-left:var(--space-lg);position:relative}.problem-list li:before{color:#c9302c;color:var(--danger);content:"✕";left:0;position:absolute}.benefit-list li:before{color:#2d8a5d;color:var(--success);content:"✓";left:0;position:absolute}.example-list li:before{content:"•"}.example-list li:before,.practice-steps li:before{color:#a67b3d;color:var(--primary-500);left:0;position:absolute}.practice-steps li:before{content:"→"}.formula-display{align-items:center;background:#212529;background:var(--gray-900);border-radius:12px;border-radius:var(--radius-lg);display:flex;gap:.5rem;gap:var(--space-sm);justify-content:center;margin:1.5rem 0;margin:var(--space-lg) 0;padding:2rem;padding:var(--space-xl)}.formula-part{background:#ffffff1a;border-radius:4px;border-radius:var(--radius-sm);color:#fff;font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.5rem;font-weight:700;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md)}.formula-op,.formula-result{color:#c9a87a;color:var(--primary-300);font-size:1.5rem}.formula-result{background:#ffffff1a;border-radius:4px;border-radius:var(--radius-sm);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-weight:700;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md)}.formula-legend{color:#868e96;color:var(--gray-600);text-align:center}.statement-template{background:#f8f9fa;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);margin:1.5rem 0;margin:var(--space-lg) 0;padding:1.5rem;padding:var(--space-lg);text-align:center}.statement-fixed{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-weight:600}.statement-variable{color:#8c6432;color:var(--primary-600);font-style:italic}.practice-display{grid-gap:.5rem 1rem;grid-gap:var(--space-sm) var(--space-md);align-items:center;background:#f8f9fa;background:var(--gray-50);border-radius:12px;border-radius:var(--radius-lg);display:grid;gap:.5rem 1rem;gap:var(--space-sm) var(--space-md);grid-template-columns:auto auto;justify-content:center;margin:1.5rem 0;margin:var(--space-lg) 0;padding:2rem;padding:var(--space-xl)}.practice-number{color:#8c6432;color:var(--primary-600);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:3rem;font-weight:700;text-align:right}.practice-times{color:#868e96;color:var(--gray-600);font-size:1rem}.cc-grid{grid-gap:1rem;grid-gap:var(--space-md);display:grid;gap:1rem;gap:var(--space-md);margin:1.5rem 0;margin:var(--space-lg) 0}.cc-card{background:#f8f9fa;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);padding:1.5rem;padding:var(--space-lg);text-align:center}.cc-card h4{font-size:1.2rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.cc-target{color:#2d8a5d;color:var(--success);font-size:.9rem;font-weight:600;margin-top:.5rem;margin-top:var(--space-sm)}.summary-list{display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm);margin:1.5rem 0;margin:var(--space-lg) 0}.summary-item{background:#d4edda;background:var(--success-light);border-radius:8px;border-radius:var(--radius-md);color:#2d8a5d;color:var(--success);padding:1rem;padding:var(--space-md)}.slide-nav{align-items:center;background:#fff;border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:1.5rem;padding:var(--space-lg)}.slide-count{color:#adb5bd;color:var(--gray-500);font-size:.85rem}.art-practice-view,.art-saved-view,.articulation-view{min-height:100vh}.art-menu{flex-direction:column}.art-menu,.art-menu-btn{display:flex;gap:1rem;gap:var(--space-md);padding:1.5rem;padding:var(--space-lg)}.art-menu-btn{align-items:center;background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:all .2s}.art-menu-btn:hover{border-color:#dee2e6;border-color:var(--gray-300);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.art-menu-btn.primary{background:#6b5b950d;border-color:#6b5b95;border-color:var(--articulation-color)}.art-menu-btn svg{color:#6b5b95;color:var(--articulation-color);flex-shrink:0}.art-menu-btn span{color:#212529;color:var(--gray-900);font-weight:500}.guidance-card{background:#d1ecf1;background:var(--info-light);border-radius:8px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm);margin:1.5rem;margin:var(--space-lg);padding:1.5rem;padding:var(--space-lg)}.guidance-card svg{color:#2d6a8a;color:var(--info)}.guidance-card p{color:#495057;color:var(--gray-700);font-size:.9rem}.guidance-card button{align-self:flex-start;background:#2d6a8a;background:var(--info);border:none;border-radius:4px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.85rem;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md)}.art-create-view{display:flex;flex-direction:column;min-height:100vh}.step-card{flex:1 1;padding:1.5rem;padding:var(--space-lg)}.step-card h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem;font-weight:600;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.step-subtitle{color:#868e96;color:var(--gray-600);font-size:.9rem;margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.step-nav{background:#fff;border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);justify-content:flex-end;padding:1.5rem;padding:var(--space-lg)}.step-nav,.word-inputs{display:flex;gap:1rem;gap:var(--space-md)}.word-inputs{flex-direction:column}.word-inputs input{border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);font-family:Source Sans\ 3,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-sans);font-size:1rem;padding:1rem;padding:var(--space-md)}.word-inputs input:focus{border-color:#6b5b95;border-color:var(--articulation-color);box-shadow:0 0 0 3px #6b5b951a;outline:none}.instruction{color:#495057;color:var(--gray-700);margin-bottom:.5rem;margin-bottom:var(--space-sm)}.example{color:#adb5bd;color:var(--gray-500);font-style:italic}.example,.tip{font-size:.85rem}.tip{background:#f8f9fa;background:var(--gray-50);border-radius:4px;border-radius:var(--radius-sm);color:#868e96;color:var(--gray-600);padding:.5rem 1rem;padding:var(--space-sm) var(--space-md)}.word-comparison{display:flex;flex-direction:column;gap:1rem;gap:var(--space-md)}.word-pair{align-items:center;display:flex;gap:.5rem;gap:var(--space-sm)}.from-word{background:#f1f3f5;background:var(--gray-100);border-radius:4px;border-radius:var(--radius-sm);color:#868e96;color:var(--gray-600);min-width:80px;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);text-align:center}.arrow{color:#ced4da;color:var(--gray-400)}.word-pair input{border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);flex:1 1;font-size:1rem;padding:1rem;padding:var(--space-md)}.word-pair input:focus{border-color:#6b5b95;border-color:var(--articulation-color);outline:none}.statement-builder{display:flex;flex-direction:column;gap:1rem;gap:var(--space-md)}.statement-input-group{display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm)}.statement-prefix{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-weight:600}.statement-builder textarea{border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);font-family:Source Sans\ 3,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-sans);font-size:1rem;padding:1rem;padding:var(--space-md);resize:none}.statement-builder textarea:focus{border-color:#6b5b95;border-color:var(--articulation-color);outline:none}.statement-preview{background:#faf5f0;background:var(--primary-50);border-radius:8px;border-radius:var(--radius-md);padding:1.5rem;padding:var(--space-lg);text-align:center}.statement-preview h4{color:#868e96;color:var(--gray-600);font-size:.85rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.preview-text{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.2rem;font-weight:600}.resonance-check{display:flex;flex-direction:column;gap:1.5rem;gap:var(--space-lg)}.statement-display{background:#212529;background:var(--gray-900);border-radius:8px;border-radius:var(--radius-md);padding:1.5rem;padding:var(--space-lg);text-align:center}.statement-display p{color:#fff;font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.2rem}.slider-group{gap:.5rem;gap:var(--space-sm)}.slider-group,.slider-group label{display:flex;flex-direction:column}.slider-label{color:#212529;color:var(--gray-900);font-weight:600}.slider-hint{color:#adb5bd;color:var(--gray-500);font-size:.85rem}.slider-group input[type=range]{-webkit-appearance:none;appearance:none;background:#e9ecef;background:var(--gray-200);border-radius:4px;height:8px;width:100%}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#212529;background:var(--gray-900);border-radius:50%;cursor:pointer;height:24px;width:24px}.slider-value{font-size:1.25rem;font-weight:600;text-align:center}.slider-value.good{color:#2d8a5d;color:var(--success)}.slider-value.low{color:#c9a227;color:var(--warning)}.resonance-warning{align-items:flex-start;background:#fff3cd;background:var(--warning-light);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:.5rem;gap:var(--space-sm);padding:1rem;padding:var(--space-md)}.resonance-warning svg{color:#c9a227;color:var(--warning);flex-shrink:0;margin-top:2px}.resonance-warning p{color:#495057;color:var(--gray-700);font-size:.9rem}.statements-list{display:flex;flex-direction:column;gap:1rem;gap:var(--space-md);padding:1.5rem;padding:var(--space-lg)}.empty-state{color:#adb5bd;color:var(--gray-500);padding:3rem;padding:var(--space-2xl);text-align:center}.empty-state .nav-btn{margin-top:1rem;margin-top:var(--space-md)}.statement-card{background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--space-lg)}.statement-text{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem;font-weight:500}.statement-meta,.statement-text{margin-bottom:1rem;margin-bottom:var(--space-md)}.statement-meta{display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--space-sm)}.meta-item{align-items:center;background:#f8f9fa;background:var(--gray-50);border-radius:100px;color:#adb5bd;color:var(--gray-500);display:inline-flex;font-size:.8rem;gap:4px;padding:4px 8px}.meta-item.practiced{background:#d4edda;background:var(--success-light);color:#2d8a5d;color:var(--success)}.statement-actions{display:flex;gap:.5rem;gap:var(--space-sm)}.statement-actions button{align-items:center;background:#f8f9fa;background:var(--gray-50);border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:4px;border-radius:var(--radius-sm);color:#495057;color:var(--gray-700);cursor:pointer;display:inline-flex;font-size:.85rem;gap:4px;padding:.5rem 1rem;padding:var(--space-sm) var(--space-md);transition:all .2s}.statement-actions button:hover{background:#f1f3f5;background:var(--gray-100)}.statement-actions button.danger:hover{background:#f8d7da;background:var(--danger-light);border-color:#c9302c;border-color:var(--danger);color:#c9302c;color:var(--danger)}.practice-date{align-items:center;background:#f8f9fa;background:var(--gray-50);color:#868e96;color:var(--gray-600);display:flex;font-size:.9rem;gap:.5rem;gap:var(--space-sm);justify-content:center;padding:1rem;padding:var(--space-md)}.practice-list{display:flex;flex-direction:column;gap:1rem;gap:var(--space-md)}.practice-card,.practice-list{padding:1.5rem;padding:var(--space-lg)}.practice-card{background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg)}.practice-card.complete{background:#d4edda;background:var(--success-light);border-color:#2d8a5d;border-color:var(--success)}.practice-statement{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1rem}.practice-progress,.practice-statement{margin-bottom:1rem;margin-bottom:var(--space-md)}.practice-progress{align-items:center;display:flex;gap:1rem;gap:var(--space-md)}.progress-bar-small{background:#e9ecef;background:var(--gray-200);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.progress-bar-small .progress-fill{background:#2d8a5d;background:var(--success);height:100%;transition:width .3s}.practice-progress span{color:#868e96;color:var(--gray-600);font-size:.85rem;white-space:nowrap}.practice-btn{align-items:center;background:#212529;background:var(--gray-900);border:none;border-radius:8px;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem;gap:var(--space-sm);justify-content:center;padding:1rem;padding:var(--space-md);transition:all .2s;width:100%}.practice-btn:hover{background:#343a40;background:var(--gray-800)}.practice-btn.complete{background:#2d8a5d;background:var(--success)}.practice-session-view{display:flex;flex-direction:column;min-height:100vh}.session-content{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:2rem;gap:var(--space-xl);justify-content:center;padding:1.5rem;padding:var(--space-lg)}.session-statement{text-align:center;width:100%}.session-statement .label{color:#adb5bd;color:var(--gray-500);font-size:.9rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.session-statement .statement{background:#faf5f0;background:var(--primary-50);border-radius:12px;border-radius:var(--radius-lg);color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.5rem;font-weight:600;padding:1.5rem;padding:var(--space-lg)}.rep-counter{text-align:center}.counter-display{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:4rem;font-weight:700;line-height:1}.rep-counter p{color:#adb5bd;color:var(--gray-500);font-size:.9rem}.rep-dots{display:flex;gap:.5rem;gap:var(--space-sm)}.rep-dot{background:#e9ecef;background:var(--gray-200);border-radius:50%;height:24px;transition:all .2s;width:24px}.rep-dot.done{background:#2d8a5d;background:var(--success);transform:scale(1.1)}.tap-btn{align-items:center;background:#212529;background:var(--gray-900);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;gap:var(--space-sm);height:160px;padding:2rem;padding:var(--space-xl);transition:all .2s;width:160px}.tap-btn:hover{background:#343a40;background:var(--gray-800);transform:scale(1.05)}.tap-btn:active{transform:scale(.98)}.tap-btn span{font-size:.85rem}.complete-set-btn{align-items:center;background:#2d8a5d;background:var(--success);border:none;border-radius:12px;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:500;gap:.5rem;gap:var(--space-sm);justify-content:center;padding:1.5rem 2rem;padding:var(--space-lg) var(--space-xl);transition:all .2s}.complete-set-btn:hover{transform:scale(1.02)}.session-progress{text-align:center;width:100%}.session-progress span{color:#868e96;color:var(--gray-600);display:block;font-size:.9rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.bank-add-view,.bank-history-view,.bank-view{min-height:100vh}.bank-concept,.bank-metaphor{padding:1.5rem;padding:var(--space-lg)}.bank-metaphor{background:#212529;background:var(--gray-900);border-radius:12px;border-radius:var(--radius-lg);gap:1rem;gap:var(--space-md)}.bank-metaphor,.metaphor-item{display:flex;flex-direction:column}.metaphor-item{gap:2px}.metaphor-item .role{color:#c9a87a;color:var(--primary-300);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-weight:600}.metaphor-item .meaning{color:#ced4da;color:var(--gray-400);font-size:.9rem}.bank-menu{gap:1rem;gap:var(--space-md);padding:0 1.5rem 1.5rem;padding:0 var(--space-lg) var(--space-lg)}.bank-menu,.bank-menu-btn{display:flex;flex-direction:column}.bank-menu-btn{background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;gap:.25rem;gap:var(--space-xs);padding:1.5rem;padding:var(--space-lg);position:relative;text-align:left;transition:all .2s}.bank-menu-btn:hover{border-color:#dee2e6;border-color:var(--gray-300);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.bank-menu-btn.primary{background:#2d8a5d0d;border-color:#2d8a5d;border-color:var(--bank-color)}.bank-menu-btn svg{color:#2d8a5d;color:var(--bank-color)}.bank-menu-btn span{color:#212529;color:var(--gray-900);font-weight:500}.bank-menu-btn .btn-hint{color:#adb5bd;color:var(--gray-500);font-size:.85rem;font-weight:400}.bank-menu-btn .count{background:#f1f3f5;background:var(--gray-100);border-radius:100px;color:#868e96;color:var(--gray-600);font-size:.8rem;padding:2px 8px;position:absolute;right:1rem;right:var(--space-md);top:1rem;top:var(--space-md)}.bank-form{gap:1.5rem;gap:var(--space-lg);padding:1.5rem;padding:var(--space-lg)}.bank-form,.form-section{display:flex;flex-direction:column}.form-section{gap:.5rem;gap:var(--space-sm)}.form-section label{color:#212529;color:var(--gray-900);font-weight:600}.form-section .hint{color:#adb5bd;color:var(--gray-500);font-size:.85rem}.form-section textarea{border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);font-family:Source Sans\ 3,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-sans);font-size:1rem;padding:1rem;padding:var(--space-md);resize:none}.form-section textarea:focus{border-color:#2d8a5d;border-color:var(--bank-color);box-shadow:0 0 0 3px #2d8a5d1a;outline:none}.distress-options{grid-gap:.5rem;grid-gap:var(--space-sm);display:grid;gap:.5rem;gap:var(--space-sm);grid-template-columns:1fr 1fr}.distress-btn{background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;padding:1rem;padding:var(--space-md);transition:all .2s}.distress-btn:hover{border-color:#dee2e6;border-color:var(--gray-300)}.distress-btn.active{background:#2d8a5d1a;border-color:#2d8a5d;border-color:var(--bank-color);color:#2d8a5d;color:var(--bank-color);font-weight:500}.can-do-section{border-top:1px solid #e9ecef;border-top:1px solid var(--gray-200);padding-top:1.5rem;padding-top:var(--space-lg)}.ratio-progress{background:#e9ecef;background:var(--gray-200);border-radius:4px;height:8px;margin-bottom:1rem;margin-bottom:var(--space-md);overflow:hidden}.ratio-fill{background:#2d8a5d;background:var(--bank-color);height:100%;transition:width .3s}.can-do-input-row{align-items:center;display:flex;gap:.5rem;gap:var(--space-sm);margin-bottom:.5rem;margin-bottom:var(--space-sm)}.can-do-number{color:#adb5bd;color:var(--gray-500);font-size:.9rem;min-width:20px}.can-do-input-row input{border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);flex:1 1;font-size:1rem;padding:1rem;padding:var(--space-md)}.can-do-input-row input:focus{border-color:#2d8a5d;border-color:var(--bank-color);outline:none}.add-can-do-btn{align-items:center;background:#0000;border:1px dashed #dee2e6;border:1px dashed var(--gray-300);border-radius:8px;border-radius:var(--radius-md);color:#868e96;color:var(--gray-600);cursor:pointer;display:inline-flex;font-size:.9rem;gap:.25rem;gap:var(--space-xs);margin-top:.5rem;margin-top:var(--space-sm);padding:.5rem 1rem;padding:var(--space-sm) var(--space-md)}.add-can-do-btn:hover{border-color:#2d8a5d;border-color:var(--bank-color);color:#2d8a5d;color:var(--bank-color)}.form-actions{padding-top:1.5rem;padding-top:var(--space-lg)}.bank-complete-view,.bf-complete-view{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:1.5rem;padding:var(--space-lg)}.success-card{background:#fff;border-radius:16px;border-radius:var(--radius-xl);box-shadow:0 10px 15px #0000001a;box-shadow:var(--shadow-lg);max-width:320px;padding:3rem;padding:var(--space-2xl);text-align:center}.success-icon{align-items:center;background:#d4edda;background:var(--success-light);border-radius:50%;color:#2d8a5d;color:var(--success);display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;margin:0 auto var(--space-lg);width:80px}.success-card h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.5rem;margin-bottom:1rem;margin-bottom:var(--space-md)}.success-card p{color:#868e96;color:var(--gray-600);margin-bottom:.5rem;margin-bottom:var(--space-sm)}.deposit-note,.success-card .insight{margin:1.5rem 0;margin:var(--space-lg) 0}.deposit-note{align-items:center;background:#d4edda;background:var(--success-light);border-radius:8px;border-radius:var(--radius-md);display:flex;gap:.5rem;gap:var(--space-sm);justify-content:center;padding:1rem;padding:var(--space-md)}.deposit-note p,.deposit-note svg{color:#2d8a5d;color:var(--success)}.deposit-note p{font-weight:500;margin:0}.history-list{display:flex;flex-direction:column;gap:1rem;gap:var(--space-md)}.history-card,.history-list{padding:1.5rem;padding:var(--space-lg)}.history-card{background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg)}.history-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem;margin-bottom:var(--space-md)}.history-date{color:#adb5bd;color:var(--gray-500);font-size:.85rem}.history-distress{border-radius:100px;font-size:.75rem;padding:2px 8px;text-transform:capitalize}.history-distress.mild{background:#d4edda;background:var(--success-light);color:#2d8a5d;color:var(--success)}.history-distress.moderate{background:#fff3cd;background:var(--warning-light);color:#c9a227;color:var(--warning)}.history-distress.hard{background:#ffe5e0;color:#d84315}.history-distress.severe{background:#f8d7da;background:var(--danger-light);color:#c9302c;color:var(--danger)}.history-cant{color:#495057;color:var(--gray-700)}.history-can-dos,.history-cant{margin-bottom:1rem;margin-bottom:var(--space-md)}.history-can-dos ul{margin-left:1.5rem;margin-left:var(--space-lg);margin-top:.5rem;margin-top:var(--space-sm)}.history-can-dos li{color:#868e96;color:var(--gray-600);font-size:.9rem;margin-bottom:.25rem;margin-bottom:var(--space-xs)}.history-ratio{color:#2d8a5d;color:var(--success);font-size:.85rem;font-weight:500}.bf-flow-view,.bf-history-view,.bf-view{min-height:100vh}.bf-concept{padding:1.5rem;padding:var(--space-lg)}.bf-principle{background:linear-gradient(135deg,#212529,#4a3f5c);background:linear-gradient(135deg,var(--gray-900) 0,#4a3f5c 100%);border-radius:12px;border-radius:var(--radius-lg);color:#fff;padding:2rem;padding:var(--space-xl);text-align:center}.bf-principle h3{color:#c9a87a;color:var(--primary-300);font-size:.9rem;letter-spacing:.1em;margin-bottom:1rem;margin-bottom:var(--space-md);text-transform:uppercase}.bf-principle p{margin-bottom:.5rem;margin-bottom:var(--space-sm)}.bf-question{color:#e0ccb3;color:var(--primary-200);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem;font-weight:600;margin-top:1rem;margin-top:var(--space-md)}.bf-menu{gap:1rem;gap:var(--space-md);padding:0 1.5rem 1.5rem;padding:0 var(--space-lg) var(--space-lg)}.bf-menu,.bf-menu-btn{display:flex;flex-direction:column}.bf-menu-btn{background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;gap:.25rem;gap:var(--space-xs);padding:1.5rem;padding:var(--space-lg);position:relative;text-align:left;transition:all .2s}.bf-menu-btn:hover{border-color:#dee2e6;border-color:var(--gray-300);box-shadow:0 4px 6px #00000012;box-shadow:var(--shadow-md)}.bf-menu-btn.primary{background:#c97b630d;border-color:#c97b63;border-color:var(--bestfriend-color)}.bf-menu-btn svg{color:#c97b63;color:var(--bestfriend-color)}.bf-menu-btn span{color:#212529;color:var(--gray-900);font-weight:500}.bf-menu-btn .btn-hint{color:#adb5bd;color:var(--gray-500);font-size:.85rem;font-weight:400}.bf-menu-btn .count{background:#f1f3f5;background:var(--gray-100);border-radius:100px;color:#868e96;color:var(--gray-600);font-size:.8rem;padding:2px 8px;position:absolute;right:1rem;right:var(--space-md);top:1rem;top:var(--space-md)}.bf-step-card{padding:1.5rem;padding:var(--space-lg)}.bf-step-card h2{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;margin-bottom:var(--space-lg)}.bf-input-section{display:flex;flex-direction:column;gap:1rem;gap:var(--space-md)}.bf-input-section textarea{border:1px solid #dee2e6;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius-md);font-family:Source Sans\ 3,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-sans);font-size:1rem;padding:1rem;padding:var(--space-md);resize:none}.bf-input-section textarea:focus{border-color:#c97b63;border-color:var(--bestfriend-color);box-shadow:0 0 0 3px #c97b631a;outline:none}.bf-question-section{display:flex;flex-direction:column;gap:1.5rem;gap:var(--space-lg)}.bf-big-question{background:#faf5f0;background:var(--primary-50);border-radius:12px;border-radius:var(--radius-lg);padding:2rem;padding:var(--space-xl);text-align:center}.bf-big-question p{color:#868e96;color:var(--gray-600);font-size:.9rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.bf-big-question h3{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.25rem}.bf-action-display{background:#f8f9fa;background:var(--gray-50);border-radius:8px;border-radius:var(--radius-md);padding:1rem;padding:var(--space-md)}.bf-action-display p{color:#495057;color:var(--gray-700)}.bf-choice{flex-direction:column}.bf-choice,.bf-choice-btn{display:flex;gap:1rem;gap:var(--space-md)}.bf-choice-btn{align-items:center;background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;padding:1.5rem;padding:var(--space-lg);text-align:left;transition:all .2s}.bf-choice-btn:hover{border-color:#dee2e6;border-color:var(--gray-300)}.bf-choice-btn.yes svg{color:#2d8a5d;color:var(--success)}.bf-choice-btn.no svg{color:#c97b63;color:var(--bestfriend-color)}.bf-choice-btn.selected{background:#f8f9fa;background:var(--gray-50);border-color:#212529;border-color:var(--gray-900)}.bf-choice-btn span{color:#495057;color:var(--gray-700);font-size:.95rem}.bf-commit-section{display:flex;flex-direction:column;gap:1.5rem;gap:var(--space-lg)}.bf-best-action-display{background:#faf5f0;background:var(--primary-50);border-radius:8px;border-radius:var(--radius-md);padding:1.5rem;padding:var(--space-lg);text-align:center}.bf-best-action-display p{color:#212529;color:var(--gray-900);font-family:"Source Serif 4",Georgia,serif;font-family:var(--font-serif);font-size:1.1rem}.bf-commit-check label{align-items:center;background:#fff;border:2px solid #e9ecef;border:2px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:1rem;gap:var(--space-md);padding:1.5rem;padding:var(--space-lg)}.bf-commit-check input{cursor:pointer;height:24px;width:24px}.bf-commit-check span{color:#495057;color:var(--gray-700)}.bf-history-card{background:#fff;border:1px solid #e9ecef;border:1px solid var(--gray-200);border-radius:12px;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--space-lg)}.bf-history-card .history-badge{border-radius:100px;font-size:.75rem;padding:2px 8px}.bf-history-card .history-badge.aligned{background:#d4edda;background:var(--success-light);color:#2d8a5d;color:var(--success)}.bf-history-card .history-badge.gap{background:#f0e6d8;background:var(--primary-100);color:#704f28;color:var(--primary-700)}.history-action,.history-best-action,.history-feelings,.history-situation{color:#495057;color:var(--gray-700);font-size:.9rem;margin-bottom:.5rem;margin-bottom:var(--space-sm)}.history-best-action{border-top:1px dashed #e9ecef;border-top:1px dashed var(--gray-200);padding-top:.5rem;padding-top:var(--space-sm)}@media (max-width:380px){.app-title{font-size:2rem}.formula-part,.formula-result{font-size:1.2rem;padding:.25rem .5rem;padding:var(--space-xs) var(--space-sm)}.formula-op{font-size:1.2rem}.practice-number{font-size:2rem}.tap-btn{height:140px;width:140px}}
/*# sourceMappingURL=main.79e82df5.css.map*/