@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--bg: #f5f3ef;--surface: #ffffff;--surface-2: #eeebe4;--text: #1a1a1a;--text-muted: #6b6b6b;--accent: #2d6a4f;--accent-light: #d8f3dc;--accent-hover: #1b4332;--accent-2: #e76f51;--accent-3: #f4a261;--border: #ddd9d0;--success: #2d6a4f;--success-bg: #d8f3dc;--error: #c1121f;--error-bg: #ffe5e5;--radius: 12px;--radius-lg: 18px;--radius-xl: 24px;--shadow-sm: 0 1px 4px rgba(0,0,0,.06);--shadow-md: 0 6px 28px rgba(0,0,0,.1);--shadow-lg: 0 12px 48px rgba(0,0,0,.13)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Plus Jakarta Sans,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;font-size:15px;-webkit-font-smoothing:antialiased}.app-shell{min-height:100vh;display:flex;flex-direction:column}header{display:flex;justify-content:space-between;align-items:center;padding:0 2rem;height:64px;background:var(--accent);position:sticky;top:0;z-index:100}header h1{margin:0;font-size:1.25rem;font-weight:800;color:#fff;letter-spacing:-.02em}nav{display:flex;align-items:center;gap:.25rem}nav a,.link-button{display:inline-flex;align-items:center;text-decoration:none;color:#fffc;font-weight:600;font-size:.875rem;background:none;border:none;cursor:pointer;padding:.45rem .875rem;border-radius:99px;transition:background .15s,color .15s;margin-top:0;line-height:1;font-family:inherit}nav a:hover,.link-button:hover{background:#ffffff26;color:#fff;text-decoration:none}main{padding:2.5rem 1.5rem;flex:1}.page{max-width:860px;margin:0 auto;width:100%}.page>h2{font-size:2rem;font-weight:800;margin:0 0 .5rem;letter-spacing:-.03em;color:var(--text)}.page>.page-subtitle{font-size:1rem;color:var(--text-muted);margin:0 0 2rem;font-weight:500}.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.dash-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;cursor:pointer;transition:box-shadow .15s,transform .15s,border-color .15s;text-decoration:none;display:flex;flex-direction:column;gap:.875rem;box-shadow:var(--shadow-sm)}.dash-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:#c5c0b8}.dash-card-icon{width:52px;height:52px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.dash-card-icon.green{background:var(--accent-light)}.dash-card-icon.orange{background:#fde8d8}.dash-card-icon.yellow{background:#fef3cd}.dash-card-icon.blue{background:#dbeafe}.dash-card-title{font-size:1rem;font-weight:700;color:var(--text);margin:0}.dash-card-desc{font-size:.8rem;color:var(--text-muted);margin:0;font-weight:500}section{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.75rem;margin-bottom:1.25rem;box-shadow:var(--shadow-sm)}section h3{font-size:1.05rem;font-weight:700;margin:0 0 1.25rem;color:var(--text);padding-bottom:.875rem;border-bottom:1.5px solid var(--border);letter-spacing:-.01em;display:flex;align-items:center;gap:.5rem}section h3 .section-icon{font-size:1.1rem}.form-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}label{display:flex;flex-direction:column;gap:.4rem;font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}input,textarea,select{border:1.5px solid var(--border);border-radius:var(--radius);padding:.7rem .875rem;font:inherit;font-size:.95rem;background:var(--bg);color:var(--text);min-width:0;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2d6a4f1f;background:var(--surface)}textarea{min-height:90px;resize:vertical}button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.35rem;border:none;border-radius:var(--radius);background:var(--accent);color:#fff;cursor:pointer;font-family:inherit;font-weight:700;font-size:.9rem;transition:background .15s,transform .1s;margin-top:1rem;letter-spacing:-.01em}button:hover{background:var(--accent-hover)}button:active{transform:scale(.97)}button:disabled{opacity:.4;cursor:not-allowed;transform:none}button.secondary{background:var(--surface-2);color:var(--text);border:1.5px solid var(--border)}button.secondary:hover{background:var(--border)}button.danger{background:var(--error)}button.danger:hover{background:#a00f1a}.button-group{display:flex;gap:.625rem;flex-wrap:wrap;margin-top:1.25rem}.tab-group{display:flex;border-bottom:1.5px solid var(--border);margin-bottom:1.75rem;gap:.25rem}.tab-group button{padding:.75rem 1.1rem;margin-top:0;background:transparent;color:var(--text-muted);border:none;border-bottom:2.5px solid transparent;border-radius:0;cursor:pointer;font-weight:600;font-size:.9rem;transition:color .15s,border-color .15s}.tab-group button:hover{color:var(--text);background:transparent}.tab-group button.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}.list-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.1rem;border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:.625rem;background:var(--bg);flex-wrap:wrap;gap:.75rem;transition:border-color .15s,box-shadow .15s}.list-item:hover{border-color:#b5b0a5;box-shadow:var(--shadow-sm)}.list-item-content{flex:1;min-width:150px}.list-item-title{font-weight:700;font-size:.95rem;margin-bottom:.2rem}.list-item-meta{font-size:.8rem;color:var(--text-muted)}.list-item-actions{display:flex;gap:.4rem}.list-item-actions button{padding:.4rem .75rem;font-size:.8rem;margin-top:0}.notice{padding:.875rem 1.1rem;background:#e8f4fd;border-left:3px solid var(--accent);border-radius:var(--radius);color:#0a3d62;margin:1rem 0 0;font-size:.9rem;font-weight:500}.notice.success{background:var(--success-bg);border-left-color:var(--success);color:var(--success)}.notice.error{background:var(--error-bg);border-left-color:var(--error);color:var(--error)}.practice-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem 2.25rem 2rem;box-shadow:var(--shadow-lg)}.practice-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.practice-text{font-size:3.5rem;font-weight:800;color:var(--text);letter-spacing:-.04em;line-height:1.1;margin:0 0 .75rem;word-break:break-word}.practice-type-badge{display:inline-block;background:var(--accent-light);color:var(--accent);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.25rem .75rem;border-radius:99px;margin-bottom:1.75rem}.practice-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem}.practice-actions button{flex:1;min-width:100px;margin-top:0;padding:1rem;font-size:1.25rem;border-radius:var(--radius)}.practice-actions button:first-child{background:var(--surface-2);color:var(--text);border:1.5px solid var(--border);flex:0 0 56px;min-width:unset}.practice-actions button:first-child:hover{background:var(--border)}audio{width:100%;margin:.5rem 0}.progress-bar-wrap{margin:1.25rem 0 0}.progress-bar-labels{display:flex;justify-content:space-between;margin-bottom:.35rem}.progress-bar-track{height:8px;background:var(--border);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:99px;transition:width .4s ease}.help-text{font-size:.875rem;color:var(--text-muted);margin:0 0 1.25rem;line-height:1.5;font-weight:500}.login-wrap{display:flex;min-height:calc(100vh - 64px);margin:-2.5rem -1.5rem}.login-left{flex:1;background:var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.login-left-title{font-size:2.5rem;font-weight:800;color:#fff;letter-spacing:-.04em;line-height:1.15;margin:0 0 1rem}.login-left-sub{font-size:1rem;color:#ffffffbf;font-weight:500;max-width:280px;line-height:1.6;margin:0}.login-left-emoji{font-size:4rem;margin-bottom:1.5rem;line-height:1}.login-right{flex:1;display:flex;align-items:center;justify-content:center;padding:3rem 2rem}.login-card{width:100%;max-width:400px}.login-card h2{font-size:2rem;font-weight:800;margin:0 0 .4rem;letter-spacing:-.03em;color:var(--text)}.login-card .subtitle{font-size:.95rem;color:var(--text-muted);margin:0 0 2rem;font-weight:500}.login-card .form-grid{grid-template-columns:1fr;gap:1.1rem}.login-card button[type=submit]{width:100%;margin-top:1.25rem;padding:.9rem;font-size:1rem;border-radius:var(--radius)}.name-grid{grid-template-columns:repeat(3,1fr)!important}@media (max-width: 640px){header{padding:0 .875rem;height:52px}header h1{font-size:.95rem;white-space:nowrap}nav a,.link-button{padding:.35rem .5rem;font-size:.78rem}main{padding:1rem .875rem}.page>h2{font-size:1.4rem;margin-bottom:.25rem}.page>.page-subtitle{font-size:.875rem;margin-bottom:1.25rem}section{padding:1rem;margin-bottom:.875rem}section h3{font-size:.95rem;margin-bottom:1rem;padding-bottom:.625rem}input,textarea,select{padding:.55rem .75rem;font-size:.9rem;border-radius:10px}.form-grid{grid-template-columns:1fr;gap:.625rem}.name-grid{grid-template-columns:1fr!important}button{width:100%;padding:.65rem 1rem;font-size:.875rem}.button-group{flex-direction:column;gap:.5rem}.button-group button{width:100%}.practice-text{font-size:2.25rem}.practice-card{padding:1.5rem 1rem 1.25rem;border-radius:var(--radius-lg)}.practice-actions{gap:.5rem}.practice-actions button{min-width:70px;padding:.75rem .5rem;font-size:1rem}.list-item{flex-direction:column;align-items:flex-start;padding:.875rem}.list-item-actions{width:100%}.list-item-actions button{flex:1}.login-wrap{flex-direction:column;margin:-1rem -.875rem}.login-left{padding:2rem 1.25rem}.login-left-title{font-size:1.6rem}.login-left-emoji{font-size:2.5rem;margin-bottom:1rem}.login-left-sub{font-size:.9rem}.login-right{padding:1.75rem 1.25rem}.login-card h2{font-size:1.5rem}.login-card .subtitle{margin-bottom:1.25rem}.dash-cards{grid-template-columns:repeat(2,1fr);gap:.75rem}.dash-card{padding:1rem;gap:.625rem}.dash-card-icon{width:44px;height:44px;font-size:1.25rem}.dash-card-title{font-size:.9rem}.dash-card-desc{font-size:.75rem}}@media (min-width: 641px) and (max-width: 1024px){.page{max-width:100%}.form-grid{grid-template-columns:repeat(2,1fr)}}
