@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700&display=swap";:root{--brand-teal: #0a9396;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100vh;font-family:Montserrat,sans-serif;line-height:1.5;font-weight:400;background-color:#f4f4f4}.container{max-width:800px;margin:2rem auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d}.title{margin-top:0;color:var(--brand-teal);font-weight:700}.toast-container{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:10000;display:flex;flex-direction:column;align-items:center;gap:12px;pointer-events:none}.toast{pointer-events:auto;min-width:300px;max-width:90vw;padding:14px 20px;border-radius:12px;color:#fff;font-size:.95rem;font-weight:600;text-align:center;box-shadow:0 8px 24px #00000026;animation:slideDown .4s cubic-bezier(.2,.8,.2,1);display:flex;align-items:center;justify-content:center}.toast.success{background-color:var(--brand-teal)}.toast.error{background-color:#d32f2f}.toast.info{background-color:#1976d2}.toast.warning{background-color:#f57c00}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}:root{--brand-teal: #009688;--nav-inactive-color: #90a4ae;--nav-active-bg: #e0f2f1;--nav-hover-bg: rgba(0, 150, 136, .08)}.bottom-nav-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;justify-content:center;gap:8px;background-color:#ffffffe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:6px 8px;border-radius:50px;box-shadow:0 4px 24px #00000014;z-index:1000;border:1px solid rgba(255,255,255,.6);transition:all .3s ease}.nav-item{display:flex;align-items:center;justify-content:center;width:auto;min-width:60px;height:44px;border-radius:24px;border:none;background-color:transparent;color:var(--nav-inactive-color);cursor:pointer;transition:all .2s ease;padding:0 16px;position:relative}@media(hover:hover){.nav-item:hover:not(:disabled):not(.active){background-color:var(--nav-hover-bg);color:var(--brand-teal)}}.nav-item.active:not(.primary){background-color:var(--nav-active-bg);color:var(--brand-teal)}.nav-item.primary{width:52px;height:52px;border-radius:50%;background-color:transparent;color:var(--brand-teal);border:none;box-shadow:none;min-width:unset;padding:0;margin:0 4px}.nav-item.primary:hover{background-color:var(--nav-hover-bg);transform:scale(1.1)}.nav-item.primary.active{background-color:var(--nav-active-bg);color:var(--brand-teal)}.nav-item svg{transition:all .2s ease;fill:none;stroke:currentColor;stroke-width:2}.nav-item.active svg{fill:currentColor;stroke:none}.nav-item.primary svg{stroke:currentColor;fill:none;stroke-width:2.2}.nav-item.primary.active svg{fill:none;stroke:currentColor;stroke-width:2.2}.nav-item:disabled{color:#cfd8dc;opacity:.6;cursor:not-allowed}@media(max-width:480px){.bottom-nav-container{width:100%;bottom:0;left:0;transform:none;border-radius:24px 24px 0 0;border:none;border-top:1px solid rgba(0,0,0,.05);padding-top:10px;padding-bottom:max(10px,env(safe-area-inset-bottom));padding-left:0;padding-right:0;justify-content:space-evenly;gap:0;background-color:#fffffffa;box-shadow:0 -4px 16px #0000000a}.nav-item.primary{transform:none}}.training-visual-wrapper{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;--tv-teal: #009688}.breathing-brain{color:#7b1fa2;animation:brain-breathe 2s ease-in-out infinite;z-index:2;transform-origin:center}@keyframes brain-breathe{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.85}}.training-ring-svg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;animation:rotate-ring 2s linear infinite}.training-track{stroke:#0000000a}.training-progress{stroke:var(--tv-teal);stroke-dasharray:1,200;stroke-dashoffset:0;stroke-linecap:round;animation:dash-indeterminate 1.5s ease-in-out infinite}@keyframes rotate-ring{to{transform:rotate(360deg)}}@keyframes dash-indeterminate{0%{stroke-dasharray:1,200;stroke-dashoffset:0}50%{stroke-dasharray:89,200;stroke-dashoffset:-35px}to{stroke-dasharray:89,200;stroke-dashoffset:-124px}}.text-teal{color:var(--brand-teal)}.main-action-button{padding:14px 36px;font-size:1.1rem;font-weight:700;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00968833}.btn-primary{background:var(--brand-teal);color:#fff}.btn-primary:hover{background:#00796b;transform:translateY(-2px);box-shadow:0 8px 20px #00968866}.pulse-animation{animation:pulse-soft 2s infinite}@keyframes pulse-soft{0%{box-shadow:0 0 #00968866}70%{box-shadow:0 0 0 10px #00968800}to{box-shadow:0 0 #00968800}}.page-loader-container{height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background-color:#f8f9fa}.spinner{width:40px;height:40px;border:4px solid #e0f2f1;border-top:4px solid var(--brand-teal);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.landing-page-wrapper{min-height:80vh;display:flex;flex-direction:column;justify-content:center;padding-bottom:2rem}.landing-grid{display:flex;flex-direction:column;gap:3rem}.landing-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding-top:1rem}.brand-logo-img{height:36px;width:auto;object-fit:contain;margin-bottom:2rem;border-radius:8px}.hero-title{font-size:2.75rem;line-height:1.1;margin-bottom:1rem;color:#333;margin-top:0}.hero-subtitle{font-size:1.1rem;color:#546e7a;line-height:1.6;margin-bottom:2.5rem;max-width:500px}.hero-actions-left{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;width:100%}.full-width-mobile{width:100%;text-align:center}.hero-links{margin-top:.5rem;width:100%;text-align:center}.hero-link{color:#90a4ae;text-decoration:none;font-size:.9rem}.landing-visual{display:flex;flex-direction:column;align-items:center;justify-content:center}.carousel-card-wrapper{width:100%;max-width:400px;min-height:240px;position:relative;display:flex;justify-content:center;margin-bottom:1.5rem}.step-card{background:#fff;padding:2rem;border-radius:24px;box-shadow:0 10px 40px #0000000d;display:flex;flex-direction:column;align-items:center;text-align:center;width:100%;opacity:0;transform:scale(.98);transition:opacity .5s ease-in-out,transform .5s ease-in-out}.step-card.fade-out{opacity:0;transform:scale(.98)}.step-card.fade-in{opacity:1;transform:scale(1)}.step-icon-bg{width:64px;height:64px;background:#e0f2f1;color:var(--brand-teal);border-radius:20px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}.step-card h3{margin:0 0 .5rem;font-size:1.25rem;color:#333}.step-card p{margin:0;color:#78909c;font-size:.95rem;line-height:1.5}.carousel-indicators{display:flex;gap:12px}.indicator-dot{width:10px;height:10px;border-radius:50%;background-color:#e0e0e0;border:none;cursor:pointer;transition:all .3s ease;padding:0}.indicator-dot.active{background-color:var(--brand-teal);transform:scale(1.3)}.dashboard-container{padding-bottom:100px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin:1.5rem 0 2rem}.header-left{display:flex;flex-direction:column}.user-email{background-color:#e0f2f1;color:#00695c;font-weight:600;font-size:.85rem;padding:6px 12px;border-radius:20px;width:fit-content;margin-top:.5rem;margin-bottom:0;opacity:1;letter-spacing:.3px}.header-actions{display:flex;align-items:center;gap:8px}.icon-action-btn{background:transparent;border:none;padding:8px;border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.icon-action-btn:active{transform:scale(.95)}.settings-btn{color:var(--brand-teal)}.settings-btn:hover{background-color:#e0f2f1}.logout-btn{color:#90a4ae}.logout-btn:hover{color:#d32f2f;background-color:#ffebee}.progress-section{margin-bottom:2rem}.progress-card{background:#fff;background:linear-gradient(135deg,#fff,#f0fdfc);padding:1.5rem;border-radius:20px;box-shadow:0 4px 20px #0096881a;border:1px solid #b2dfdb}.progress-info{display:flex;justify-content:space-between;margin-bottom:.8rem;font-weight:600;color:#00695c}.progress-bar-bg{width:100%;height:12px;background-color:#e0e0e0;border-radius:6px;overflow:hidden;margin-bottom:.8rem}.progress-bar-fill{height:100%;background-color:var(--brand-teal);border-radius:6px;transition:width 1s ease-out}.progress-footer{display:flex;justify-content:flex-end}.status-highlight{font-size:.9rem}.status-highlight.purple{color:#7b1fa2}.progress-subtext{margin:0;font-size:.9rem;color:#546e7a;text-align:right}.actions-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:3rem}.dashboard-card{background:#fff;border-radius:24px;padding:1.5rem;box-shadow:0 4px 15px #0000000d;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:1.5rem;position:relative;overflow:hidden;border:1px solid transparent}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000014;border-color:#b2dfdb}.dashboard-card.locked{background-color:#f5f5f5;cursor:not-allowed;opacity:.8}.dashboard-card.locked:hover{transform:none;box-shadow:none;border-color:transparent}.card-icon-wrapper{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.library-icon{background-color:#e0f2f1;color:var(--brand-teal)}.library-icon.purple-bg{background-color:#f3e5f5;color:#8e24aa}.recognition-icon{background-color:#e3f2fd;color:#1976d2}.recognition-icon.gray{background-color:#eceff1;color:#90a4ae}.card-content{display:flex;flex-direction:column;align-items:flex-start;width:100%}.card-content h3{margin:0 0 .25rem;font-size:1.1rem;font-weight:700;color:#333}.card-content p{margin:0;font-size:.9rem;color:#78909c;line-height:1.3}.card-badge{position:static;margin-bottom:.5rem;font-size:.7rem;font-weight:800;padding:4px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px;display:inline-block}.card-badge.orange{background-color:#ffcc80;color:#e65100}.card-badge.purple{background-color:#e1bee7;color:#4a148c;animation:pulse-soft 2s infinite}@media(max-width:480px){.hero-title{font-size:2.5rem}.dashboard-card{padding:1.25rem;gap:1rem}.card-icon-wrapper{width:48px;height:48px}}@media(min-width:600px)and (max-width:899px){.full-width-mobile{width:auto;min-width:200px;padding-left:48px;padding-right:48px}.landing-content{align-items:center;text-align:center;padding-right:0}.hero-subtitle{max-width:500px;margin-left:auto;margin-right:auto}.hero-actions-left{align-items:center;width:auto}.hero-links{text-align:center}}@media(min-width:600px){.actions-grid{grid-template-columns:1fr 1fr}}@media(min-width:900px){.landing-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.full-width-mobile{width:auto}.hero-links{text-align:left;margin-left:1rem;width:auto}.hero-actions-left{flex-direction:row;align-items:center}.landing-content{padding-right:2rem}.landing-visual{justify-content:center}}.login-container{max-width:400px;margin:4rem auto;position:relative}.back-link{display:flex;align-items:center;justify-content:center;width:fit-content;margin:0 auto 2rem;padding:10px 24px;background-color:#fff;border:1px solid #e0e0e0;border-radius:30px;text-decoration:none;color:#555;font-size:.9rem;font-weight:600;transition:all .3s ease;box-shadow:0 2px 5px #00000008}.back-link:hover{border-color:var(--brand-teal);color:var(--brand-teal);transform:translateY(-2px);box-shadow:0 4px 10px #0a939626;background-color:#fcfcfc}.back-link span{margin-right:5px}.login-header{text-align:center;margin-bottom:2rem}.login-title{margin-top:0;color:var(--brand-teal);font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#666;font-size:.95rem;margin:0}.input-group{display:flex;flex-direction:column;gap:12px;margin-bottom:1.5rem}.login-input{padding:12px 16px;border-radius:8px;border:1px solid #ddd;font-size:1rem;font-family:inherit;transition:border-color .2s}.login-input:focus{outline:none;border-color:var(--brand-teal);box-shadow:0 0 0 3px #0a93961a}.consent-container{margin-bottom:1.5rem;display:flex;gap:12px;background-color:#f9f9f9;padding:12px;border-radius:8px;align-items:flex-start}.consent-link{color:var(--brand-teal);text-decoration:none;font-weight:600;margin-left:4px}.consent-link:hover{text-decoration:underline;color:#00796b}.consent-checkbox{margin-top:3px;cursor:pointer;width:18px;height:18px;accent-color:var(--brand-teal);flex-shrink:0}.consent-label{font-size:.85rem;color:#555;cursor:pointer;line-height:1.4}.auth-buttons-row{display:flex;gap:12px;margin-bottom:2rem}.auth-btn{flex:1;padding:12px;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;border:none}.btn-primary{background-color:var(--brand-teal);color:#fff}.btn-primary:hover:not(:disabled){background-color:#00796b;transform:translateY(-1px)}.btn-secondary{background-color:#fff;color:var(--brand-teal);border:1px solid var(--brand-teal)}.btn-secondary:hover:not(:disabled){background-color:#f0fcfc;transform:translateY(-1px)}.auth-btn:disabled{background-color:#e0e0e0;border-color:#e0e0e0;color:#999;cursor:not-allowed;transform:none}.divider{display:flex;align-items:center;margin:1.5rem 0;color:#999;font-size:.85rem;font-weight:500}.divider:before,.divider:after{content:"";flex:1;border-top:1px solid #eee}.divider span{padding:0 12px}.social-buttons-container{display:flex;justify-content:center;gap:1rem}.social-btn{width:50px;height:50px;border-radius:50%;border:1px solid #ddd;background-color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;box-shadow:0 2px 5px #0000000d}.social-btn:hover:not(:disabled){background-color:#f5f5f5;transform:scale(1.05);border-color:#ccc}.social-btn:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(100%)}.forgot-password-link{align-self:flex-end;font-size:.85rem;color:var(--brand-teal);background:none;border:none;cursor:pointer;padding:0;margin-top:4px;font-weight:600;text-decoration:none;transition:color .2s}.forgot-password-link:hover{color:#00796b;text-decoration:underline}.forgot-password-link:disabled{color:#ccc;cursor:not-allowed;text-decoration:none}.success-msg{color:#137333;margin-top:1rem;text-align:center;font-size:.9rem;background-color:#e6f4ea;padding:10px;border-radius:6px;border:1px solid #cce8d7}.error-msg{color:#d32f2f;margin-top:1rem;text-align:center;font-size:.9rem;background-color:#ffebee;padding:10px;border-radius:6px}:root{--brand-teal: #009688;--brand-red: #d32f2f}.rb-container{position:relative;width:64px;height:64px;display:flex;align-items:center;justify-content:center;cursor:pointer;outline:none}.rb-container.disabled{opacity:.6;cursor:not-allowed;filter:grayscale(100%)}.rb-wrapper{position:relative;width:64px;height:64px;background-color:#e0f2f1;border-radius:50%;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 2px 8px #0096881a;display:flex;align-items:center;justify-content:center;z-index:2}.rb-container:not(.disabled) .rb-wrapper:not(.recording):hover{transform:scale(1.1);background-color:#b2dfdb;box-shadow:0 4px 12px #00968833}.rb-container:not(.disabled):active .rb-wrapper{transform:scale(.95)}.rb-container:not(.disabled) .rb-wrapper:not(.recording){animation:rb-breathe 3s infinite ease-in-out}.rb-wrapper.recording{background-color:var(--brand-red);transform:scale(.9);box-shadow:none;animation:none}.rb-wrapper.recording .rb-progress-svg{opacity:0;transition:opacity .2s}.rb-icon-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--brand-teal);display:flex;transition:color .2s}.rb-wrapper.recording .rb-icon-container{color:#fff}.rb-progress-svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-90deg);pointer-events:none}.rb-progress-fill{transition:stroke-dashoffset .35s;transform-origin:50% 50%}.rb-ripple{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;border-radius:50%;border:2px solid var(--brand-red);opacity:0;z-index:0;pointer-events:none}.rb-ripple.active{animation:rb-ripple-out 2s infinite}@keyframes rb-breathe{0%{transform:scale(1);box-shadow:0 2px 8px #0096881a}50%{transform:scale(1.05);box-shadow:0 6px 16px #00968880}to{transform:scale(1);box-shadow:0 2px 8px #0096881a}}@keyframes rb-ripple-out{0%{transform:translate(-50%,-50%) scale(.8);opacity:.6}to{transform:translate(-50%,-50%) scale(2.5);opacity:0}}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100dvh;background-color:#00000080;z-index:2000;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}.modal-backdrop.open{opacity:1;pointer-events:auto}@media(min-width:768px){.modal-backdrop{align-items:center}}.recording-sheet{background:#fff;width:90vw;max-width:500px;display:flex;flex-direction:column;max-height:85dvh;border-radius:24px;box-shadow:0 20px 60px #00000040;overflow:hidden;transform:translateY(20px) scale(.98);opacity:0;transition:all .25s cubic-bezier(.2,.8,.2,1);justify-content:flex-start}@media(max-width:767px){.recording-sheet{width:100vw;max-width:none;max-height:90dvh;border-radius:24px 24px 0 0;transform:translateY(100%)}}.recording-sheet.open{transform:translateY(0) scale(1);opacity:1}.sheet-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #f0f0f0;background:#fff;flex-shrink:0}.sheet-header h3{margin:0;font-size:1.1rem;font-weight:700;color:var(--brand-teal, #009688);text-transform:uppercase;letter-spacing:1px}.close-btn{background:none;border:none;cursor:pointer;color:#90a4ae;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.close-btn:hover{color:#546e7a}.sheet-content-centered{flex-grow:1;display:flex;flex-direction:column;align-items:center;padding:24px;gap:24px;text-align:center;overflow-y:auto;-webkit-overflow-scrolling:touch}@media(max-width:767px){.sheet-content-centered{padding-bottom:calc(120px + env(safe-area-inset-bottom))}}.phrase-display{font-size:1.4rem;font-weight:700;color:#333;line-height:1.4;margin-top:1rem;margin-bottom:3rem;flex-grow:0;word-break:break-word}.control-panel{display:flex;align-items:center;gap:24px;margin-bottom:1.5rem;opacity:.3;pointer-events:none;transform:scale(.95);transition:all .3s cubic-bezier(.25,.8,.25,1);position:relative;z-index:10}.control-panel.active{opacity:1;pointer-events:auto;transform:scale(1)}.control-btn{display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;cursor:pointer;transition:all .2s cubic-bezier(.25,.8,.25,1);box-shadow:0 4px 10px #0000001a}.control-btn:active{transform:scale(.9)}.control-btn:disabled{background-color:#e0e0e0!important;color:#9e9e9e!important;cursor:wait;transform:scale(1)!important;box-shadow:none!important;pointer-events:none}.control-btn.discard{width:48px;height:48px;background-color:#ffebee;color:#c62828}.control-btn.discard:hover{background-color:#ffcdd2;box-shadow:0 6px 14px #c6282833}.control-btn.play{width:64px;height:64px;background-color:var(--brand-teal, #009688);color:#fff}.control-btn.play:hover{background-color:#00796b;transform:scale(1.05);box-shadow:0 8px 20px #0096884d}.control-btn.save{width:54px;height:54px;background-color:#c8e6c9;color:#2e7d32;transition:all .2s ease}.control-btn.save:hover{background-color:#a5d6a7;transform:scale(1.05);box-shadow:0 6px 16px #0096884d}.mic-area{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:1.5rem;transition:opacity .3s ease;min-height:80px}.mic-area.disabled{opacity:.4;pointer-events:none;filter:grayscale(100%)}.confirm-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:3000;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-backdrop.open{opacity:1;pointer-events:auto}.confirm-card{background:#fff;width:100vw;max-width:none;border-radius:24px 24px 0 0;padding:32px 24px 48px;box-shadow:0 -4px 20px #00000026;text-align:center;transform:translateY(100%);opacity:1;transition:transform .3s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;align-items:center}.confirm-card.open{transform:translateY(0)}@media(min-width:768px){.confirm-backdrop{align-items:center}.confirm-card{width:90%;max-width:400px;border-radius:24px;padding:32px 24px;box-shadow:0 20px 60px #00000040;transform:scale(.9) translateY(20px);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.confirm-card.open{transform:scale(1) translateY(0);opacity:1}}.confirm-icon-wrapper{width:64px;height:64px;border-radius:50%;background-color:#ffebee;color:#d32f2f;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;box-shadow:0 4px 12px #d32f2f26}.confirm-title{margin:0 0 12px;font-size:1.5rem;font-weight:700;color:#333}.confirm-message{margin:0 0 32px;font-size:1rem;color:#546e7a;line-height:1.6}.confirm-actions{display:flex;width:100%;gap:16px}.btn-secondary,.btn-danger{flex:1;padding:16px;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;border:none;transition:all .2s ease}.btn-secondary{background-color:#e0f2f1;color:#00695c;border:1px solid #b2dfdb}.btn-secondary:hover{background-color:#b2dfdb;color:#004d40;box-shadow:0 2px 8px #00968833}.btn-secondary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;background-color:#eee;color:#bdbdbd;border-color:#e0e0e0}.btn-danger{background-color:#d32f2f;color:#fff;box-shadow:0 4px 12px #d32f2f33}.btn-danger:hover{background-color:#b71c1c;transform:translateY(-2px);box-shadow:0 6px 16px #d32f2f4d}.btn-danger:active{transform:scale(.98)}.btn-danger:disabled{background-color:#ef9a9a;box-shadow:none;cursor:wait;transform:none}:root{--train-teal: #009688;--train-teal-dark: #004d40;--train-bg: #e0f2f1;--train-error: #d32f2f;--train-warning-bg: #fff8e1;--train-subtext: #546e7a}.container{padding-bottom:120px}.section-title{font-size:1.25rem;color:var(--train-teal);text-transform:uppercase;letter-spacing:1.2px;font-weight:800;margin:2.5rem 0 1rem;padding-bottom:8px;border-bottom:2px solid #b2dfdb;display:flex;align-items:center;gap:8px}.section-title.collapsible{cursor:pointer;justify-content:space-between;-webkit-user-select:none;user-select:none;transition:opacity .2s}.section-title.collapsible:hover{opacity:.8;border-bottom-color:var(--train-teal)}.empty-section{text-align:center;padding:2rem;color:#90a4ae;font-style:italic;font-size:.95rem;background:#f9f9f9;border-radius:12px;border:1px dashed #cfd8dc}.disclaimer-accordion{background:#fff;border:1px solid #b2dfdb;border-radius:12px;overflow:hidden;margin-bottom:2rem;box-shadow:0 4px 12px #00968814}.disclaimer-header{padding:1rem;display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:#f0fdfc;-webkit-user-select:none;user-select:none;transition:background .2s}.disclaimer-header:hover{background:#e0f2f1}.disclaimer-title{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--train-teal-dark)}.critical-warning{padding:.8rem 1rem;background:var(--train-warning-bg);color:#bf360c;font-size:.9rem;line-height:1.5;border-top:1px solid #ffe0b2;border-bottom:1px solid #ffe0b2}.disclaimer-content{padding:1rem;font-size:.9rem;color:var(--train-subtext);line-height:1.6;background:#fff;animation:slideDown .2s ease-out}.phrases-grid{display:flex;flex-direction:column;gap:1rem}.phrase-card{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 4px 12px #0000000a;position:relative;border:1px solid transparent;transition:all .2s ease;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto auto;grid-template-areas:"text actions" "error actions" "badge actions";gap:4px 16px;align-items:center}.phrase-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00968826;border-color:#b2dfdb}.phrase-card.failed{border-color:#ef9a9a;background-color:#fffdea}.phrase-text{grid-area:text;font-size:1.5rem;font-weight:700;color:#333;line-height:1.3;letter-spacing:-.02em}.phrase-error{grid-area:error;color:var(--train-error);font-size:.8rem;margin-bottom:4px}.status-badge{grid-area:badge;display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;width:fit-content;letter-spacing:.5px}.status-badge.needs_training{background:#fff3e0;color:#ef6c00}.status-badge.ready_to_train{background:#e1bee7;color:#4a148c}.status-badge.is_training{background:#f3e5f5;color:#7b1fa2}.status-badge.trained{background:#e8f5e9;color:#2e7d32}.status-badge.failed{background:#ffebee;color:#c62828}.card-actions{grid-area:actions;display:flex;align-items:center;gap:12px;justify-content:flex-end}.circular-action-btn{width:58px;height:58px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);color:#fff;box-shadow:0 6px 16px #0096884d;background-color:var(--train-teal)}.circular-action-btn:hover{transform:scale(1.1) rotate(10deg);background-color:var(--train-teal-dark);box-shadow:0 8px 24px #00968866}.circular-action-btn:active{transform:scale(.95)}.circular-action-btn:disabled{background-color:#b0bec5;box-shadow:none;cursor:wait;transform:none}.menu-container{position:relative}.kebab-btn{background:transparent;border:none;color:#90a4ae;padding:8px;cursor:pointer;border-radius:50%;display:flex;transition:background .2s}.kebab-btn:hover{background:#f5f5f5;color:var(--train-teal)}.kebab-btn:disabled{opacity:.5;cursor:not-allowed}.dropdown-menu{position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;min-width:160px;z-index:10;overflow:hidden;animation:fadeIn .15s ease;border:1px solid #eee}.menu-item{width:100%;padding:12px 16px;text-align:left;background:none;border:none;font-size:.9rem;color:var(--train-error);cursor:pointer;display:flex;align-items:center;gap:8px;font-weight:500;transition:background-color .2s,color .2s}.menu-item:hover{background:#ffebee}.menu-item:disabled{opacity:.5;cursor:not-allowed;color:#90a4ae;background:transparent}@media(max-width:600px){.phrase-card{grid-template-columns:auto 1fr auto;grid-template-areas:"text text text" "error error error" "badge . actions";gap:12px 0}.status-badge{align-self:center}}@media(max-width:480px){.phrase-text{font-size:1.3rem}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton-pulse{0%{background-color:#f0f2f5}50%{background-color:#e0e0e0}to{background-color:#f0f2f5}}.spinner-simple{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;box-sizing:border-box}.skeleton-card{background:#fff;border-radius:16px;padding:1.25rem;box-shadow:0 4px 12px #0000000a;display:flex;justify-content:space-between;align-items:center;border:1px solid #f0f0f0;height:86px;box-sizing:border-box}.skeleton-content{display:flex;flex-direction:column;gap:12px;width:60%}.skeleton-text-line{height:20px;width:80%;border-radius:4px;animation:skeleton-pulse 1.5s infinite ease-in-out}.skeleton-badge-line{height:24px;width:40%;border-radius:12px;animation:skeleton-pulse 1.5s infinite ease-in-out;animation-delay:.2s}.skeleton-action{width:56px;height:56px;border-radius:50%;animation:skeleton-pulse 1.5s infinite ease-in-out;animation-delay:.4s}.skeleton-title{height:24px;width:150px;border-radius:4px;margin:2.5rem 0 1rem;animation:skeleton-pulse 1.5s infinite ease-in-out}.add-phrase-container{display:flex;justify-content:center;margin-top:3rem;margin-bottom:2rem;animation:fadeIn .5s ease-out}.add-phrase-btn{width:64px;height:64px;border-radius:50%;border:none;background-color:var(--train-teal);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0096884d;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.add-phrase-btn:hover{background-color:var(--train-teal-dark);transform:scale(1.1) rotate(90deg);box-shadow:0 8px 24px #00968866}.add-phrase-btn:active{transform:scale(.95)}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;opacity:0;transition:opacity .3s ease;display:flex;align-items:center;justify-content:center}@media(max-width:767px){.modal-backdrop{align-items:flex-end}}.modal-backdrop.open{opacity:1}.modal-sheet{background:#fff;width:90vw;max-width:500px;display:flex;flex-direction:column;align-items:stretch;max-height:80vh;border-radius:24px;box-shadow:0 20px 60px #00000040;overflow:hidden;transform:translateY(20px) scale(.98);opacity:0;transition:all .25s cubic-bezier(.2,.8,.2,1)}@media(max-width:767px){.modal-sheet{width:100vw;max-width:none;max-height:85vh;border-radius:24px 24px 0 0;transform:translateY(100%)}}.modal-sheet.open{transform:translateY(0) scale(1);opacity:1}.sheet-header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:24px;background:#fff;z-index:10;width:100%;box-sizing:border-box;box-shadow:0 4px 12px #00000008}.sheet-header h3{margin:0;font-size:1.4rem;color:var(--brand-teal);font-weight:800;text-transform:uppercase;letter-spacing:.5px}.close-btn{background:transparent;border:none;cursor:pointer;color:#b0bec5;padding:8px;margin-right:-8px;border-radius:50%;display:flex;transition:all .2s}.close-btn:hover{background-color:#e0f2f1;color:var(--brand-teal);transform:rotate(90deg)}.sheet-content{flex-grow:1;width:100%!important;box-sizing:border-box;overflow-y:auto;overflow-x:hidden;display:flex;background-color:#fff;scrollbar-width:thin;scrollbar-color:#b2dfdb transparent}.sheet-content::-webkit-scrollbar{width:6px}.sheet-content::-webkit-scrollbar-track{background:transparent}.sheet-content::-webkit-scrollbar-thumb{background-color:#cfd8dc;border-radius:3px}.sheet-content::-webkit-scrollbar-thumb:hover{background-color:var(--brand-teal)}.phrases-list{display:flex;flex-direction:column;gap:12px;padding:20px;width:100%;box-sizing:border-box}.phrase-btn{appearance:none;outline:none;display:block;width:100%;margin:0;box-sizing:border-box;text-align:left;background-color:#f5f7f7;border:1px solid transparent;border-radius:16px;padding:18px 20px;font-family:inherit;font-size:1.1rem;font-weight:600;color:#37474f;line-height:1.4;cursor:pointer;transition:all .2s cubic-bezier(.25,.8,.25,1)}.phrase-btn:hover{background-color:#e0f2f1;color:#00796b;border-color:#00968833;transform:translateY(-2px);box-shadow:0 4px 12px #0096881a}.phrase-btn:active{transform:scale(.98);background-color:#b2dfdb}.phrase-btn:focus-visible{outline:2px solid #009688;outline-offset:2px;background-color:#f0fdfa}.empty-modal-state{flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px;color:#90a4ae;font-size:1.05rem;font-weight:500;line-height:1.6;font-style:italic;min-height:150px}.top-spacer{width:100%;height:2rem;flex-shrink:0}.controls-area{width:100%;display:flex;flex-direction:column;align-items:center;gap:3rem;flex-shrink:0;margin-top:auto;padding-bottom:1rem}.result-card{width:calc(100% - 2rem);max-width:520px;flex-grow:1;min-height:240px;height:auto;background:#fff;border-radius:24px;box-shadow:0 8px 30px #00000014;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;text-align:center;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease;border:2px solid transparent;position:relative;box-sizing:border-box;margin:0 auto 2rem}.result-card.idle{border-color:#f0f0f0}.result-card.recording{border-color:var(--brand-teal);background-color:#fafafe;box-shadow:0 0 0 4px #0a93961a}.result-card.processing{border-color:#ba68c8;background-color:#f3e5f5;box-shadow:0 0 15px #ba68c833}.result-card.match{border-color:#4caf50;background-color:#f1f8e9}.result-card.no-match{border-color:#ffb74d;background-color:#fff8e1}.result-card.manual-entry{border-color:#90caf9;background-color:#e3f2fd}.result-label{font-size:.8rem;font-weight:700;color:#aaa;text-transform:uppercase;margin-bottom:1rem}.listening-text{font-size:1.5rem;font-weight:700;color:var(--brand-teal);margin-bottom:.5rem;animation:pulse-opacity 1.5s infinite}.listening-hint{font-size:.95rem;font-weight:500;color:var(--brand-teal);opacity:.8;max-width:280px;line-height:1.4}.analyzing-text{font-size:1.5rem;font-weight:700;color:#8e24aa;margin-bottom:.5rem;animation:pulse-opacity 1s infinite}.analyzing-hint{font-size:.85rem;font-weight:500;color:#7b1fa2;opacity:.9;margin-top:.5rem;max-width:260px;line-height:1.4}.success-phrase{font-size:2rem;font-weight:800;background:linear-gradient(135deg,var(--brand-teal) 0%,#004d40 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:var(--brand-teal);line-height:1.2;margin-bottom:2rem;word-break:break-word}.result-card.manual-entry .success-phrase{background:none;-webkit-text-fill-color:initial;color:#1565c0}.result-card.manual-entry .manual-label{color:#1976d2;margin-bottom:.5rem}.no-match-title{font-size:1.5rem;font-weight:700;color:#f57c00;margin-bottom:1rem}.no-match-hint{font-size:1rem;color:#5d4037;line-height:1.5;max-width:320px}.idle-main-text{font-size:1.2rem;font-weight:600;color:#555;margin-bottom:.5rem}.idle-sub-text{font-size:.9rem;color:#999;font-weight:500;max-width:280px;line-height:1.4}.action-bar{display:flex;align-items:center;justify-content:center;gap:1.5rem;width:100%}.action-btn{display:flex;align-items:center;justify-content:center;border-radius:50%;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 10px #0000000d}.action-btn:active{transform:scale(.9)}.action-btn.secondary{width:48px;height:48px;background-color:#fff;color:#546e7a;border:1px solid #edf2f2}.action-btn.secondary:hover{background-color:#f5f7f7}.action-btn.secondary svg{width:20px;height:20px;stroke-width:2}.action-btn.primary{width:64px;height:64px;background-color:var(--brand-teal);color:#fff;box-shadow:0 4px 15px #0a93964d}.action-btn.primary:hover{background-color:#008385;transform:scale(1.05)}.action-btn.primary:active{transform:scale(.95)}.action-btn.primary svg{width:28px;height:28px;fill:currentColor;stroke:none;margin-left:4px}.switch-container{display:flex;align-items:center;gap:12px;background-color:#f8f9fa;padding:8px 16px 8px 8px;border-radius:30px;border:1px solid #eaeaea;box-shadow:0 2px 5px #00000008;transition:all .2s ease;cursor:pointer}.switch-container:active{transform:scale(.98)}.switch-input{display:none}.switch-track{position:relative;width:44px;height:26px;background-color:#d1d1d6;border-radius:13px;transition:background-color .3s ease}.switch-track:after{content:"";position:absolute;top:2px;left:2px;width:22px;height:22px;background-color:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;transition:transform .3s cubic-bezier(.4,0,.2,1)}.switch-input:checked+.switch-track{background-color:var(--brand-teal)}.switch-input:checked+.switch-track:after{transform:translate(18px)}.switch-label-text{font-size:.95rem;font-weight:600;color:var(--brand-teal);-webkit-user-select:none;user-select:none}.mic-button-wrapper{position:relative;display:flex;justify-content:center;align-items:center}.big-mic-btn{width:72px;height:72px;border-radius:50%;border:none;background-color:var(--brand-teal);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 15px #0a939666;transition:transform .1s ease,background-color .2s;z-index:2}.big-mic-btn svg{width:28px;height:28px;stroke-width:2}.big-mic-btn:active{transform:scale(.95)}.big-mic-btn.recording{background-color:#d32f2f;box-shadow:0 6px 15px #d32f2f66}.big-mic-btn.processing{background-color:#ba68c8;box-shadow:none;cursor:wait;opacity:.8;transform:scale(.95);pointer-events:none}.ripple-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid #d32f2f;opacity:0;z-index:1}.big-mic-btn.recording~.ripple-ring{animation:ripple-effect 2s infinite}.big-mic-btn.recording~.ripple-ring:nth-of-type(2){animation-delay:.5s}@keyframes ripple-effect{0%{transform:scale(1);opacity:.6}to{transform:scale(2.2);opacity:0}}@keyframes pulse-opacity{0%,to{opacity:1}50%{opacity:.6}}.select-phrase-btn{margin-top:1.5rem;background-color:transparent;border:2px solid #ffb74d;color:#e65100;padding:10px 20px;border-radius:24px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s ease}.select-phrase-btn:hover{background-color:#fff8e1;transform:translateY(-2px);box-shadow:0 4px 12px #ffa72633}.select-phrase-btn:active{transform:scale(.95)}.terms-container{max-width:700px;margin:2rem auto;padding:2rem}.terms-content{color:#444;line-height:1.7;margin-bottom:2rem}.terms-content h2{color:var(--brand-teal);font-size:1.2rem;margin-top:2rem;margin-bottom:.5rem;border-bottom:1px solid #eee;padding-bottom:.5rem}.terms-content p{margin-bottom:1rem;font-size:1rem}.terms-content ul{padding-left:20px;margin-bottom:1rem}.terms-content li{margin-bottom:.5rem}.nav-actions{display:flex;justify-content:center;margin-top:2rem}.primary-action-btn{display:flex;align-items:center;justify-content:center;padding:12px 32px;background-color:var(--brand-teal);color:#fff;border:none;border-radius:30px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 10px #0a93964d;text-decoration:none}.primary-action-btn:hover{background-color:#00796b;transform:translateY(-2px);box-shadow:0 6px 15px #0a939666}.primary-action-btn:active{transform:translateY(0)}.notFoundContainer{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:80vh}.notFoundTitle{font-size:6rem;font-weight:900;color:var(--brand-teal);margin:0;line-height:1}.notFoundSubtitle{font-size:1.5rem;font-weight:500;color:#555;margin:.5rem 0}.notFoundContainer p{font-size:1rem;color:#777;margin-bottom:1.5rem}
