.welcome{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;padding:var(--spacing-lg);overflow-y:auto;width:100%;-webkit-overflow-scrolling:touch;transition:background .3s ease}html.dark-theme .welcome{background:linear-gradient(135deg,#2a2d47,#1e2139)}.welcome-content{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:500px;width:100%;text-align:center;box-shadow:0 10px 40px #0000001a;transition:background-color .3s ease,box-shadow .3s ease}html.dark-theme .welcome-content{box-shadow:0 10px 40px #0000004d}.welcome-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-md)}.welcome-subtitle{font-size:var(--font-size-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.welcome-actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.btn{min-height:var(--touch-target-min);padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-medium);font-weight:500;border-radius:var(--border-radius);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.1);user-select:none;-webkit-user-select:none;position:relative;z-index:1}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-secondary{background-color:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-secondary:hover:not(:disabled){background-color:var(--color-bg-secondary)}.btn-guest{background-color:var(--color-bg-secondary);color:var(--color-text);border:2px dashed var(--color-text-secondary);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.1);user-select:none;-webkit-user-select:none;position:relative;z-index:10;pointer-events:auto;width:100%;display:block}.btn-guest:hover:not(:disabled),.btn-guest:active:not(:disabled){background-color:var(--color-bg);border-color:var(--color-primary)}.guest-mode-description{font-size:var(--font-size-small);color:var(--color-text-secondary);margin-top:var(--spacing-xs);margin-bottom:0;font-style:italic;pointer-events:none;position:relative;z-index:0}@media(min-width:768px)and (max-width:1024px){.welcome{padding:var(--ipad-spacing-xl)}.welcome-content{max-width:650px;padding:calc(var(--spacing-xl) * 2);border-radius:16px}.welcome-title{font-size:calc(var(--font-size-large) * 1.5);margin-bottom:var(--spacing-lg)}.welcome-subtitle{font-size:calc(var(--font-size-medium) * 1.2);margin-bottom:calc(var(--spacing-xl) * 1.5)}.welcome-actions{gap:var(--ipad-spacing-md)}.welcome-actions .btn{min-height:56px;padding:1.25rem 2rem;font-size:1.15rem;border-radius:10px}}@media(max-width:767px){.welcome{padding:var(--spacing-md)}.welcome-content{padding:var(--spacing-lg)}.welcome-actions .btn{min-height:var(--touch-target-ideal)}}.account-setup{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;padding:var(--spacing-lg);overflow-y:auto;width:100%;-webkit-overflow-scrolling:touch}.account-setup-content{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:500px;width:100%;box-shadow:0 10px 40px #0000001a}.account-setup-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm);text-align:center}.account-setup-subtitle{font-size:var(--font-size-normal);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);text-align:center}.account-setup-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-hint{color:var(--color-text-secondary);font-size:var(--font-size-small);margin-top:var(--spacing-xs)}@media(min-width:768px)and (max-width:1024px){.account-setup{padding:var(--ipad-spacing-xl)}.account-setup-content{max-width:650px;padding:calc(var(--spacing-xl) * 2);border-radius:16px}.account-setup-title{font-size:calc(var(--font-size-large) * 1.4);margin-bottom:var(--spacing-md)}.account-setup-subtitle{font-size:calc(var(--font-size-normal) * 1.15);margin-bottom:calc(var(--spacing-xl) * 1.5)}.account-setup-form{gap:var(--ipad-spacing-lg)}.form-group{gap:var(--spacing-sm)}.form-label{font-size:calc(var(--font-size-normal) * 1.1);margin-bottom:var(--spacing-sm)}.form-input{min-height:56px;padding:1.25rem 1rem;font-size:1.1rem;border-radius:10px}.btn-submit{min-height:56px;padding:1.25rem 2rem;font-size:1.15rem;margin-top:var(--spacing-lg);border-radius:10px}.form-error-message{padding:var(--spacing-md);font-size:1rem;border-radius:10px}}@media(max-width:767px){.account-setup{padding:var(--spacing-md)}.account-setup-content{padding:var(--spacing-lg)}.form-input,.btn-submit{min-height:var(--touch-target-ideal)}}.login{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;padding:var(--spacing-lg);overflow-y:auto;width:100%;-webkit-overflow-scrolling:touch}.login-content{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:500px;width:100%;box-shadow:0 10px 40px #0000001a}.login-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm);text-align:center}.login-subtitle{font-size:var(--font-size-normal);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);text-align:center}.login-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-input{min-height:var(--touch-target-min);padding:var(--spacing-md);font-size:var(--font-size-normal);border:2px solid var(--color-border);border-radius:var(--border-radius);transition:border-color .2s ease}.form-input:focus{outline:none;border-color:var(--color-primary)}.form-input:disabled{background-color:var(--color-bg-secondary);cursor:not-allowed}.form-checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-normal);color:var(--color-text);cursor:pointer}.form-checkbox{width:20px;height:20px;cursor:pointer}.form-checkbox:disabled{cursor:not-allowed}.login-divider{display:flex;align-items:center;text-align:center;margin:var(--spacing-md) 0;color:var(--color-text-secondary)}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--color-border)}.login-divider span{padding:0 var(--spacing-md);font-size:var(--font-size-small)}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);background:#fff;color:#3c4043;border:1px solid #dadce0;padding:var(--spacing-md);font-size:var(--font-size-normal);font-weight:500;border-radius:var(--border-radius);transition:all .2s ease}.btn-google:hover:not(:disabled){background:#f8f9fa;box-shadow:0 1px 3px #0000001a}.btn-google:disabled{opacity:.6;cursor:not-allowed}.google-icon{flex-shrink:0}.photo-editor-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:var(--spacing-lg)}.photo-editor{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:500px;width:100%;box-shadow:0 10px 40px #0000004d}.photo-editor-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm);text-align:center}.photo-editor-subtitle{font-size:var(--font-size-small);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);text-align:center}.photo-editor-preview-container{display:flex;justify-content:center;margin-bottom:var(--spacing-xl)}.photo-editor-preview{width:300px;height:300px;border-radius:50%;overflow:hidden;border:4px solid var(--color-primary);position:relative;background:var(--color-bg-secondary);cursor:grab;-webkit-user-select:none;user-select:none}.photo-editor-preview:active{cursor:grabbing}.photo-editor-image-wrapper{position:absolute;top:50%;left:50%;transform-origin:center center;-webkit-user-select:none;user-select:none;will-change:transform}.photo-editor-image{display:block;-webkit-user-select:none;user-select:none;pointer-events:none;max-width:none;max-height:none}.photo-editor-image-wrapper img{width:auto;height:auto;max-width:300px;max-height:300px;object-fit:contain}.photo-editor-controls{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.photo-editor-control-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.photo-editor-label{font-size:var(--font-size-normal);font-weight:500;color:var(--color-text)}.photo-editor-scale-controls{display:flex;align-items:center;gap:var(--spacing-md)}.btn-icon{width:40px;height:40px;border-radius:50%;background:var(--color-bg-secondary);border:2px solid var(--color-border);font-size:24px;font-weight:700;color:var(--color-text);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-icon:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.photo-editor-slider{flex:1;height:8px;border-radius:4px;background:var(--color-bg-secondary);outline:none;-webkit-appearance:none}.photo-editor-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer}.photo-editor-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none}.photo-editor-scale-value{font-size:var(--font-size-small);color:var(--color-text-secondary);text-align:center;min-width:50px}.btn-reset{width:100%}.photo-editor-actions{display:flex;gap:var(--spacing-md)}.photo-editor-actions .btn{flex:1}.child-profile-setup{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;padding:var(--spacing-lg);overflow-y:auto;width:100%;-webkit-overflow-scrolling:touch}.child-profile-setup-content{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:500px;width:100%;box-shadow:0 10px 40px #0000001a}.child-profile-setup-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm);text-align:center}.child-profile-setup-subtitle{font-size:var(--font-size-normal);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);text-align:center}.child-profile-setup-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.photo-hint{font-size:var(--font-size-small);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.btn-submit{width:100%;margin-top:var(--spacing-md)}.btn-link{background:transparent;color:var(--color-primary);text-decoration:underline;padding:var(--spacing-sm);font-size:var(--font-size-normal)}.btn-link:hover:not(:disabled){background-color:var(--color-bg-secondary)}.child-home{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;padding:0;-webkit-overflow-scrolling:touch;overflow-y:auto;width:100%;box-sizing:border-box}.child-home-content{background:var(--color-bg);border-radius:0;padding:var(--spacing-lg);max-width:100%;width:100%;box-shadow:none;text-align:center;display:flex;flex-direction:column;min-height:0;box-sizing:border-box}@media(min-width:768px)and (max-width:1024px){.child-home{padding:var(--spacing-lg);align-items:center}.child-home-content{max-width:700px;padding:calc(var(--spacing-xl) * 1.5);border-radius:var(--border-radius);box-shadow:0 10px 40px #0000001a;min-height:auto;justify-content:flex-start}.child-header{margin-bottom:calc(var(--spacing-xl) * 1.5)}.child-avatar-large{width:160px;height:160px;margin-bottom:var(--spacing-lg)}.child-avatar-placeholder-large svg{width:64px;height:64px}.child-welcome{font-size:calc(var(--font-size-large) * 1.5);margin-bottom:var(--spacing-md)}.child-grade-info{font-size:calc(var(--font-size-normal) * 1.2)}.child-tools{margin:calc(var(--spacing-xl) * 1.5) 0;padding:var(--spacing-xl) 0}.child-tools-grid{max-width:600px;gap:var(--spacing-lg);margin:0 auto;justify-items:center;align-items:center}.child-tools-grid .btn-tool{width:100%;max-width:180px;margin:0 auto}.btn-tool{width:180px;height:180px;aspect-ratio:1;padding:var(--spacing-xl)}.tool-icon svg{width:48px;height:48px}.tool-label{font-size:1.1rem}.child-actions{margin-top:calc(var(--spacing-xl) * 1.5)}.child-action-buttons{gap:var(--spacing-lg);flex-wrap:wrap}.child-action-buttons .btn{flex:1;min-width:200px;max-width:300px;padding:1.25rem 2rem;font-size:1.15rem;min-height:56px}}@media(min-width:1025px){.child-home{padding:var(--spacing-xl);align-items:center}.child-home-content{max-width:600px;border-radius:var(--border-radius);box-shadow:0 10px 40px #0000001a;min-height:auto;justify-content:flex-start}}@media(max-width:767px){.child-home{padding:0;min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh}.child-home-content{padding:var(--spacing-sm);border-radius:0;min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;justify-content:space-between}.header-actions{margin-bottom:var(--spacing-xs);padding:0}.btn-header-theme,.btn-header-language{width:1.75rem;height:1.75rem;min-width:1.75rem;padding:.25rem}.btn-header-language .language-icon,.btn-header-theme .theme-icon{width:16px;height:16px}.btn-header-language .language-label{font-size:.7rem}.child-header{margin-bottom:var(--spacing-sm)}.child-avatar-large{width:60px;height:60px;margin-bottom:var(--spacing-xs);border-width:2px}.child-avatar-placeholder-large svg{width:24px;height:24px}.child-welcome{font-size:1rem;margin-bottom:0;line-height:1.2}.child-grade-info{font-size:.75rem;margin-bottom:0;margin-top:.25rem}.child-tools{margin:var(--spacing-sm) 0;padding:var(--spacing-xs) 0;border-top-width:1px;border-bottom-width:1px}.child-tools-title{font-size:.8rem;margin-bottom:var(--spacing-xs)}.child-tools-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs);max-width:100%;margin:0;padding:0;justify-items:center;align-items:center}.child-tools-grid .btn-tool{width:100%;max-width:100%;margin:0 auto;min-height:70px}.btn-tool{width:100%;max-width:100%;height:auto;min-height:70px;aspect-ratio:1;padding:var(--spacing-xs);margin:0 auto}.tool-icon svg{width:24px;height:24px}.tool-label{font-size:.75rem;line-height:1.1}.tool-coming-soon{font-size:.6rem;margin-top:.125rem}.child-actions{margin-top:auto;padding-top:var(--spacing-xs)}.coming-soon{font-size:.8rem;margin-bottom:var(--spacing-xs)}.child-action-buttons{flex-direction:column;gap:var(--spacing-xs);align-items:stretch;justify-content:center;width:100%}.child-action-buttons .btn{width:100%;max-width:100%;min-height:2.5rem;margin:0;padding:var(--spacing-sm) var(--spacing-md);font-size:.9rem}}.child-header{margin-bottom:var(--spacing-lg);flex-shrink:0}.child-avatar-large{width:120px;height:120px;border-radius:50%;overflow:hidden;margin:0 auto var(--spacing-md);border:4px solid var(--color-primary)}.child-avatar-large img{width:100%;height:100%;object-fit:cover}.child-avatar-placeholder-large{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.child-avatar-placeholder-large svg{width:48px;height:48px}.child-welcome{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm)}.child-grade-info{font-size:var(--font-size-normal);color:var(--color-text-secondary)}.child-tools{margin:var(--spacing-lg) 0;padding:var(--spacing-md) 0;border-top:1px solid var(--color-border, #e0e0e0);border-bottom:1px solid var(--color-border, #e0e0e0);flex:1;min-height:0;display:flex;flex-direction:column}.child-tools-title{font-size:var(--font-size-normal);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-md);text-align:center}.child-tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);justify-items:center;align-items:center;max-width:100%;margin:0;width:100%}.child-tools-grid .btn-tool{width:100%;max-width:100%;margin:0 auto}.btn-tool{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);width:100%;max-width:150px;height:150px;aspect-ratio:1;border-radius:var(--border-radius, 12px);transition:transform .2s ease,box-shadow .2s ease;margin:0 auto}.btn-tool:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-tool:active:not(:disabled){transform:translateY(0)}.btn-tool:disabled{opacity:.5;cursor:not-allowed}.tool-icon{display:flex;align-items:center;justify-content:center;line-height:1}.tool-icon svg{width:40px;height:40px}.tool-label{font-size:var(--font-size-normal);font-weight:500}.tool-coming-soon{font-size:var(--font-size-small);color:var(--color-text-secondary);font-weight:400;font-size:.8rem;margin-top:auto;opacity:1}.child-actions{margin-top:var(--spacing-lg);flex-shrink:0}.coming-soon{font-size:var(--font-size-normal);color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.child-action-buttons{display:flex;gap:var(--spacing-md);justify-content:center;align-items:center}.child-action-buttons .btn{flex:1;max-width:200px}.header-actions{display:flex;justify-content:flex-end;align-items:center;align-self:flex-end;margin-bottom:var(--spacing-md);gap:.5rem;width:100%;flex-shrink:0}.child-selector{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;padding:var(--spacing-lg);-webkit-overflow-scrolling:touch;overflow-y:auto;width:100%}html.dark-theme .child-selector{background:linear-gradient(135deg,#2a2d47,#1e2139)}.child-selector-content{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:600px;width:100%;box-shadow:0 10px 40px #0000001a}html.dark-theme .child-selector-content{box-shadow:0 10px 40px #0000004d}@media(min-width:768px)and (max-width:1024px){.child-selector-content{max-width:750px;padding:calc(var(--spacing-xl) * 1.5)}.child-selector-title{font-size:calc(var(--font-size-large) * 1.3);margin-bottom:var(--spacing-md)}.child-selector-subtitle{font-size:calc(var(--font-size-normal) * 1.1);margin-bottom:calc(var(--spacing-xl) * 1.5)}.child-list{gap:var(--spacing-lg);margin-bottom:calc(var(--spacing-lg) * 1.5)}.child-card{padding:var(--spacing-lg);min-height:80px;border-radius:12px;transition:all .2s ease}.child-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.child-avatar{width:80px;height:80px}.child-avatar-placeholder{font-size:32px}.child-name{font-size:calc(var(--font-size-normal) * 1.2);font-weight:600}.child-grade{font-size:calc(var(--font-size-small) * 1.1)}.active-indicator{width:36px;height:36px;font-size:1.1rem}.btn-add-child{padding:1.25rem 2rem;font-size:1.15rem;min-height:56px}}@media(max-width:767px){.child-selector{padding:var(--spacing-md)}.child-selector-content{padding:var(--spacing-lg)}.child-card{padding:var(--spacing-md);min-height:var(--touch-target-ideal);-webkit-tap-highlight-color:transparent;touch-action:manipulation}}.child-selector-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-sm);text-align:center}.child-selector-subtitle{font-size:var(--font-size-normal);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);text-align:center}.child-list{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.child-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;background:var(--color-bg)}.child-card:hover{border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}html.dark-theme .child-card:hover{box-shadow:0 4px 12px #ff8e8e4d}.child-card.active{border-color:var(--color-primary);background:#f0f4ff}html.dark-theme .child-card.active{background:linear-gradient(135deg,#ff8e8e33,#ffb3b326);border-color:var(--color-primary);box-shadow:0 4px 12px #ff8e8e4d}.child-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--color-border)}.child-avatar img{width:100%;height:100%;object-fit:cover}.child-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:24px;font-weight:700}html.dark-theme .child-avatar-placeholder{background:linear-gradient(135deg,#3a3d57,#2a2d47)}.child-info{flex:1}.child-name{font-size:var(--font-size-normal);font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-xs) 0}.child-grade{font-size:var(--font-size-small);color:var(--color-text-secondary);margin:0}.active-indicator{width:30px;height:30px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.confirm-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.confirm-dialog{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:400px;width:100%;box-shadow:0 10px 40px #0003}.confirm-dialog-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-md)}.confirm-dialog-message{font-size:var(--font-size-normal);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);line-height:1.5}.confirm-dialog-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end}.confirm-dialog.danger .confirm-dialog-title{color:var(--color-error)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#d32f2f}.settings{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;width:100%;-webkit-overflow-scrolling:touch;transition:background .3s ease}html.dark-theme .settings{background:linear-gradient(135deg,#2a2d47,#1e2139)}.settings-header{background:var(--color-bg);box-shadow:0 2px 8px #0000001a;padding:.75rem 1rem;z-index:10;flex-shrink:0;width:100%;box-sizing:border-box;transition:background-color .3s ease}html.dark-theme .settings-header{box-shadow:0 2px 8px #0000004d}.settings-header .header-content{margin:0 auto;display:grid;grid-template-columns:min-content 1fr min-content;align-items:center;gap:.75rem;position:relative;width:100%;justify-items:start;box-sizing:border-box;padding:0}.settings-header .header-left{display:flex;align-items:center;gap:.5rem;justify-self:start;align-self:center;flex-shrink:0;grid-column:1;width:auto}.settings-header .header-icon{width:2.5rem;height:2.5rem;background:var(--color-accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text);transition:background-color .3s ease,color .3s ease}html.dark-theme .settings-header .header-icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;box-shadow:0 4px 12px #ff8e8e4d}.settings-header .header-icon svg{width:24px;height:24px}.settings-header .settings-title-header{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.settings-content{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);overflow-y:auto;min-height:0}.settings-content-inner{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:600px;width:100%;box-shadow:0 10px 40px #0000001a;transition:background-color .3s ease,box-shadow .3s ease}html.dark-theme .settings-content-inner{box-shadow:0 10px 40px #0000004d}@media(min-width:768px)and (max-width:1024px){.settings-content{padding:var(--ipad-spacing-xl)}.settings-content-inner{max-width:750px;padding:calc(var(--spacing-xl) * 2);border-radius:16px}.settings-title{font-size:calc(var(--font-size-large) * 1.4);margin-bottom:calc(var(--spacing-xl) * 1.5)}.settings-section{margin-bottom:calc(var(--spacing-xl) * 1.5);padding:var(--ipad-spacing-lg);background:var(--color-bg-secondary);border-radius:12px}.settings-section-title{font-size:calc(var(--font-size-normal) * 1.2);margin-bottom:var(--ipad-spacing-md)}.child-item{padding:var(--ipad-spacing-md);border-radius:12px;min-height:80px}.child-item-avatar{width:60px;height:60px}.child-item-name{font-size:calc(var(--font-size-normal) * 1.15)}.btn-small{padding:var(--spacing-sm) var(--ipad-spacing-md);font-size:calc(var(--font-size-small) * 1.1);min-height:44px}.btn-add-child,.btn-link-account,.btn-logout{padding:1.25rem 2rem;font-size:1.15rem;min-height:56px;border-radius:10px}.script-selector-buttons .btn{padding:1rem 2rem;font-size:1.1rem;min-height:56px}}.settings-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-xl);text-align:center}.settings-header .btn-back{background:none;border:none;color:var(--color-text);font-size:1.25rem;padding:.5rem;cursor:pointer;border-radius:.5rem;transition:background-color .2s ease,color .3s ease;min-height:2.5rem;min-width:2.5rem;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.settings-header .btn-back:hover,.settings-header .btn-back:active{background-color:var(--color-bg-secondary)}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section-title{font-size:var(--font-size-normal);font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-md)}.no-children{color:var(--color-text-secondary);text-align:center;padding:var(--spacing-lg)}.children-list{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.child-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--border-radius);background:var(--color-bg)}.child-item-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.child-item-avatar{width:50px;height:50px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--color-border)}.child-item-avatar img{width:100%;height:100%;object-fit:cover}.child-item-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:20px;font-weight:700;transition:background .3s ease}html.dark-theme .child-item-avatar-placeholder{background:linear-gradient(135deg,#3a3d57,#2a2d47)}.child-item-name{font-size:var(--font-size-normal);font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-xs) 0}.child-item-grade{font-size:var(--font-size-small);color:var(--color-text-secondary);margin:0}.child-item-actions{display:flex;gap:var(--spacing-sm)}.btn-small{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-small)}.btn-add-child{width:100%}.account-info{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--border-radius)}.account-email{font-size:var(--font-size-normal);color:var(--color-text);margin:0;word-break:break-all}.linked-accounts{margin-bottom:var(--spacing-lg)}.linked-accounts-title{font-size:var(--font-size-small);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.linked-accounts-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.linked-account-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--border-radius);background:var(--color-bg)}.linked-account-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--color-text);transition:color .3s ease}.linked-account-icon svg{width:20px;height:20px}.linked-account-name{flex:1;font-size:var(--font-size-normal);color:var(--color-text)}.linked-account-badge{font-size:var(--font-size-small);color:var(--color-primary);background:#667eea1a;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius)}.account-error{padding:var(--spacing-md);background-color:#ff4d4f1a;border:1px solid var(--color-error);border-radius:var(--border-radius);color:var(--color-error);font-size:var(--font-size-small);margin-bottom:var(--spacing-md);transition:background-color .3s ease,border-color .3s ease,color .3s ease}.btn-link-account{width:100%;margin-bottom:var(--spacing-md)}.btn-logout{width:100%;margin-top:var(--spacing-md)}.settings-section-description{font-size:var(--font-size-small);color:var(--color-text-secondary);margin-bottom:var(--spacing-md);line-height:1.5}.btn-reset-app{width:100%;margin-top:var(--spacing-md)}.settings-actions{margin-top:var(--spacing-xl);text-align:center}.script-selector{margin-bottom:2rem}.script-selector-label{display:block;font-size:1rem;font-weight:500;color:var(--color-text);margin-bottom:.75rem}.script-selector-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.script-selector-buttons .btn{min-width:120px;padding:.75rem 1.5rem;font-size:1rem}@media(max-width:767px){.settings-header{padding:.5rem .75rem}.settings-header .header-content{gap:.5rem}.settings-header .settings-title-header{font-size:1.25rem;max-width:150px}.settings-content{padding:var(--spacing-md)}.settings-content-inner{padding:var(--spacing-lg)}}.settings-header .header-actions{grid-column:3;justify-self:end;align-self:center;display:flex;align-items:center;height:100%;gap:.5rem;flex-shrink:0}.settings-header .btn-header-theme{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background-color .2s ease,color .3s ease;flex-shrink:0;width:auto;min-width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text)}.settings-header .btn-header-theme:hover{background-color:var(--color-bg-secondary)}.settings-header .btn-header-theme:active{transform:scale(.95)}.settings-header .btn-header-theme .theme-icon{width:20px;height:20px;transition:transform .2s ease}.settings-header .btn-header-theme:hover .theme-icon{transform:rotate(180deg)}.settings-header .btn-header-theme:active .theme-icon{transform:rotate(180deg) scale(.95)}.settings-header .btn-header-language{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;gap:.25rem;transition:transform .2s ease,background-color .2s ease,color .3s ease;flex-shrink:0;width:auto;min-width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text)}.settings-header .btn-header-language:hover{background-color:var(--color-bg-secondary)}.settings-header .btn-header-language:active{transform:scale(.95)}.settings-header .btn-header-language .language-icon{width:20px;height:20px;transition:transform .2s ease;flex-shrink:0}.settings-header .btn-header-language .language-label{font-size:.875rem;font-weight:600;line-height:1}.settings-header .btn-header-language:hover .language-icon{transform:rotate(15deg)}.settings-header .btn-header-language:active .language-icon{transform:rotate(15deg) scale(.95)}.version-info{margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--border-radius);border:1px solid var(--color-border)}.version-item{display:flex;justify-content:center;gap:var(--spacing-sm);align-items:center;padding:.5rem 0;font-size:var(--font-size-base)}.version-item:not(:last-child){border-bottom:1px solid var(--color-border);margin-bottom:.5rem;padding-bottom:.75rem}.version-label{color:var(--color-text-secondary);font-weight:500}.version-value{color:var(--color-text);font-weight:600;font-family:Courier New,monospace}.version-update-available,.version-update-available .version-label,.version-update-available .version-value{color:var(--color-primary)}.update-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-top:var(--spacing-md)}.btn-check-update,.btn-update-now{flex:1;min-width:120px}.btn-update-now{background:var(--color-primary);color:#fff}.btn-update-now:hover:not(:disabled){background:var(--color-primary-dark)}.update-status-message{width:100%;padding:var(--spacing-sm);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-small);font-style:italic}.child-profile-edit{min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;background-size:cover;padding:var(--spacing-lg);overflow-y:auto;width:100%;-webkit-overflow-scrolling:touch}.child-profile-edit-content{background:var(--color-bg);border-radius:var(--border-radius);padding:var(--spacing-xl);max-width:500px;width:100%;box-shadow:0 10px 40px #0000001a}.child-profile-edit-title{font-size:var(--font-size-large);font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-xl);text-align:center}.child-profile-edit-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-label{font-size:var(--font-size-normal);font-weight:500;color:var(--color-text);margin-bottom:var(--spacing-xs)}.required{color:var(--color-error)}.form-input,.form-select{min-height:var(--touch-target-min);padding:var(--spacing-md);font-size:var(--font-size-normal);border:2px solid var(--color-border);border-radius:var(--border-radius);transition:border-color .2s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary)}.form-input-error{border-color:var(--color-error)}.form-input:disabled,.form-select:disabled{background-color:var(--color-bg-secondary);cursor:not-allowed}.form-error{color:var(--color-error);font-size:var(--font-size-small);margin-top:var(--spacing-xs)}.form-error-message{padding:var(--spacing-md);background-color:#fff2f0;border:1px solid var(--color-error);border-radius:var(--border-radius);color:var(--color-error);font-size:var(--font-size-normal)}.photo-group{align-items:center}.photo-upload-area{width:100%;display:flex;justify-content:center}.photo-preview{position:relative;width:150px;height:150px;border-radius:50%;overflow:hidden;border:3px solid var(--color-primary)}.photo-preview img{width:100%;height:100%;object-fit:cover}.photo-preview-actions{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-xs);opacity:0;transition:opacity .2s ease;background:linear-gradient(to top,rgba(0,0,0,.5),transparent)}.photo-preview:hover .photo-preview-actions{opacity:1}.btn-edit-photo,.btn-remove-photo{width:32px;height:32px;border-radius:50%;background:#fffffff2;border:2px solid var(--color-primary);color:var(--color-primary);font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-edit-photo{border-color:var(--color-primary);color:var(--color-primary)}.btn-edit-photo:hover{background:var(--color-primary);color:#fff}.btn-remove-photo{border-color:var(--color-error);color:var(--color-error)}.btn-remove-photo:hover{background:var(--color-error);color:#fff}.photo-placeholder{width:150px;height:150px;border:3px dashed var(--color-border);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s ease}.photo-placeholder:hover{border-color:var(--color-primary)}.photo-input{display:none}.photo-input-label{display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;text-align:center;padding:var(--spacing-md);color:var(--color-text-secondary);font-size:var(--font-size-small)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md)}.form-actions .btn{flex:1}.header-actions{display:flex;justify-content:flex-end;align-items:center;align-self:center;margin-bottom:var(--spacing-md);gap:.5rem;height:100%}.btn-header-theme{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background-color .2s ease,color .3s ease;width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text)}.btn-header-theme:hover{background-color:var(--color-bg-secondary)}.btn-header-theme:active{transform:scale(.95)}.btn-header-theme .theme-icon{width:20px;height:20px;transition:transform .2s ease}.btn-header-language{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;gap:.25rem;transition:transform .2s ease,background-color .2s ease,color .3s ease;width:auto;min-width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text)}.btn-header-language .language-icon{width:20px;height:20px;transition:transform .2s ease;flex-shrink:0}.btn-header-language .language-label{font-size:.875rem;font-weight:600;line-height:1}.hanzi-writer-canvas-container{display:flex;justify-content:center;align-items:center;width:100%;padding:1rem;touch-action:none;pointer-events:none}.hanzi-writer-canvas-container>*{pointer-events:auto}.hanzi-writer-container{position:relative;background-color:transparent;border-radius:.5rem;overflow:hidden;aspect-ratio:1 / 1;border:2px solid rgba(148,163,184,.6);box-sizing:border-box;touch-action:none;-webkit-touch-callout:none;user-select:none;-webkit-user-select:none;pointer-events:auto}.hanzi-writer-container svg{display:block;width:100%!important;height:100%!important;touch-action:none!important;pointer-events:auto!important;-webkit-touch-callout:none;position:relative;z-index:100!important}.hanzi-writer-container.completed-no-interaction,.hanzi-writer-container.completed-no-interaction svg,.hanzi-writer-container.completed-no-interaction canvas{pointer-events:none!important;touch-action:auto!important}.hanzi-writer-container.completed-no-interaction{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.hanzi-writer-container.with-grid{position:relative;aspect-ratio:1 / 1;border:2px solid var(--color-border);box-sizing:border-box;background-color:var(--color-bg);transition:background-color .3s ease,border-color .3s ease}.hanzi-writer-container.with-grid:before{content:"";position:absolute;inset:0;pointer-events:none!important;z-index:1;background-image:repeating-linear-gradient(to right,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to right,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to bottom,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to bottom,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px);background-repeat:no-repeat;background-position:33.33% 0,66.67% 0,0 33.33%,0 66.67%;background-size:1px 100%,1px 100%,100% 1px,100% 1px}.hanzi-writer-container.with-grid:after{content:"";position:absolute;top:33.33%;left:33.33%;width:33.34%;height:33.34%;pointer-events:none;z-index:0;background:#94a3b80d;border:1px dashed rgba(148,163,184,.3);box-sizing:border-box}@media(min-width:768px)and (max-width:1024px){.hanzi-writer-container{border-width:3px}}.stroke-order{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;height:100%;display:flex;flex-direction:column}html.dark-theme .stroke-order{background-color:transparent;box-shadow:none}.stroke-order-header{text-align:center;margin-bottom:1rem}.stroke-order-header h3{font-size:1.2rem;color:#333;margin-bottom:.5rem}html.dark-theme .stroke-order-header h3{color:var(--color-text)}.stroke-order-canvas-container{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem}.stroke-order-canvas{background-color:#f9f9f9;border:2px solid #ddd;border-radius:4px;margin-bottom:.5rem}html.dark-theme .stroke-order-canvas{background-color:var(--color-bg-accent);border:2px solid var(--color-border)}.stroke-order-hanzi-writer{background-color:#fff;border:2px solid rgba(148,163,184,.7);border-radius:4px;margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;width:300px;height:300px;position:relative;aspect-ratio:1 / 1;box-sizing:border-box;flex-shrink:0;min-width:0;max-width:300px;max-height:300px}html.dark-theme .stroke-order-hanzi-writer{background-color:var(--color-bg);border:2px solid var(--color-border)}.stroke-order-hanzi-writer:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;background-image:repeating-linear-gradient(to right,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to right,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to bottom,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to bottom,transparent 0px,rgba(148,163,184,.5) 0px,rgba(148,163,184,.5) 2px,transparent 2px,transparent 6px);background-repeat:no-repeat;background-position:33.33% 0,66.67% 0,0 33.33%,0 66.67%;background-size:1px 100%,1px 100%,100% 1px,100% 1px}html.dark-theme .stroke-order-hanzi-writer:before{background-image:repeating-linear-gradient(to right,transparent 0px,var(--color-border) 0px,var(--color-border) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to right,transparent 0px,var(--color-border) 0px,var(--color-border) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to bottom,transparent 0px,var(--color-border) 0px,var(--color-border) 2px,transparent 2px,transparent 6px),repeating-linear-gradient(to bottom,transparent 0px,var(--color-border) 0px,var(--color-border) 2px,transparent 2px,transparent 6px)}.stroke-order-hanzi-writer:after{content:"";position:absolute;top:33.33%;left:33.33%;width:33.34%;height:33.34%;pointer-events:none;z-index:0;background:#94a3b80d;border:1px dashed rgba(148,163,184,.3);box-sizing:border-box}html.dark-theme .stroke-order-hanzi-writer:after{background:#5a5d7a1a;border:1px dashed var(--color-border)}.stroke-order-hanzi-writer svg{display:block;width:100%!important;height:100%!important;min-width:0;min-height:0;flex-shrink:0;object-fit:contain}.stroke-order-info{text-align:center;color:#666;font-size:.9rem}html.dark-theme .stroke-order-info{color:var(--color-text-secondary)}.stroke-order-controls{display:flex;gap:.5rem;justify-content:center}.stroke-order-controls .btn{min-width:100px;padding:.5rem 1rem}@media(max-width:767px){.stroke-order{padding:.25rem;margin:0;border-radius:4px;height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.stroke-order-header{margin-bottom:.25rem;flex-shrink:0}.stroke-order-header h3{font-size:.75rem;margin-bottom:.2rem}.stroke-order-canvas-container{flex:1;min-height:0;margin-bottom:.25rem}.stroke-order-hanzi-writer{width:120px!important;height:120px!important;margin:0 auto .2rem;border-width:1px}.stroke-order-info{font-size:.65rem;flex-shrink:0}.stroke-order-controls{gap:.25rem}.stroke-order-controls .btn{min-width:60px;padding:.25rem .5rem;font-size:.7rem}}@media(min-width:768px)and (max-width:1024px){.stroke-order{padding:.5rem;margin:0;border-radius:6px;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.stroke-order-header{margin-bottom:.5rem;flex-shrink:0}.stroke-order-header h3{font-size:.9rem;margin-bottom:.3rem}.stroke-order-canvas-container{flex:1;min-height:0;margin-bottom:.5rem}.stroke-order-hanzi-writer{width:200px!important;height:200px!important;margin:0 auto .3rem;min-width:200px!important;min-height:200px!important;max-width:200px!important;max-height:200px!important;aspect-ratio:1 / 1;flex-shrink:0}.stroke-order-hanzi-writer svg{width:200px!important;height:200px!important;min-width:200px!important;min-height:200px!important;max-width:200px!important;max-height:200px!important}.stroke-order-info{font-size:.8rem;flex-shrink:0}}@media(min-width:900px)and (max-width:950px){.stroke-order-hanzi-writer{width:220px!important;height:220px!important;min-width:220px!important;min-height:220px!important;max-width:220px!important;max-height:220px!important;aspect-ratio:1 / 1;flex-shrink:0}.stroke-order-hanzi-writer svg{width:220px!important;height:220px!important;min-width:220px!important;min-height:220px!important;max-width:220px!important;max-height:220px!important}}@media(min-width:1025px){.stroke-order{padding:2rem}}.writing-practice{width:100%;height:100vh;height:-webkit-fill-available;height:100dvh;max-height:100vh;max-height:-webkit-fill-available;max-height:100dvh;background:radial-gradient(circle at 20% 50%,rgba(255,107,107,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(78,205,196,.15) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(255,230,109,.15) 0%,transparent 50%),linear-gradient(135deg,#fff9e6,#e8f5e9,#e3f2fd);background-attachment:fixed;display:flex;flex-direction:column;overflow:hidden;-webkit-overflow-scrolling:touch;transition:background .3s ease;position:fixed;inset:0}html.dark-theme .writing-practice{background:radial-gradient(circle at 20% 50%,rgba(255,107,107,.12) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(78,205,196,.12) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(255,230,109,.1) 0%,transparent 50%),linear-gradient(135deg,#2e3149,#252840,#1e2139)}.writing-practice-header{background:var(--color-bg);box-shadow:0 2px 8px #0000001a;padding:.75rem 1rem;z-index:10;flex-shrink:0;width:100%;max-width:100%;box-sizing:border-box;transition:background-color .3s ease,box-shadow .3s ease;display:flex;align-items:stretch;min-height:3.5rem;height:auto;overflow:visible}html.dark-theme .writing-practice-header{box-shadow:0 2px 8px #0000004d}.header-content{margin:0 auto;display:flex;align-items:stretch;gap:.75rem;position:relative;width:100%;max-width:100%;box-sizing:border-box;padding:0;flex-wrap:nowrap;height:100%;min-height:3.5rem;overflow:visible}.header-left{display:flex;align-items:center;gap:.5rem;flex-shrink:0;width:auto;align-self:stretch;overflow:visible}.header-settings{flex-shrink:0;width:auto;margin-left:auto;align-self:stretch;display:flex;align-items:center;gap:.75rem;background:#f9fafb;padding:.5rem;border-radius:.5rem;flex-wrap:nowrap;white-space:nowrap;z-index:2;position:relative;max-width:100%;overflow:hidden}.header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0;flex:0 0 auto;margin:auto 0 auto auto;align-self:stretch;z-index:2;position:relative;overflow:visible;width:auto;max-width:none}.btn-header-theme,.btn-header-settings{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background-color .2s ease,color .3s ease;flex-shrink:0;width:auto;min-width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text);align-self:center;vertical-align:middle;line-height:1}.btn-header-theme:hover,.btn-header-settings:hover{background-color:var(--color-bg-secondary)}.btn-header-theme:active,.btn-header-settings:active{transform:scale(.95)}.btn-header-theme .theme-icon,.btn-header-settings .settings-icon{width:20px;height:20px;transition:transform .2s ease;display:flex;align-items:center;justify-content:center}.btn-header-theme:hover .theme-icon{transform:rotate(180deg)}.btn-header-settings:hover .settings-icon{transform:rotate(90deg)}.btn-header-theme:active .theme-icon{transform:rotate(180deg) scale(.95)}.btn-header-settings:active .settings-icon{transform:rotate(90deg)}.btn-header-language{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;gap:.25rem;transition:transform .2s ease,background-color .2s ease,color .3s ease;flex-shrink:0;width:auto;min-width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text);align-self:center;vertical-align:middle;line-height:1}.btn-header-language:hover{background-color:var(--color-bg-secondary)}.btn-header-language:active{transform:scale(.95)}.btn-header-language .language-icon{width:20px;height:20px;transition:transform .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.btn-header-language .language-label{font-size:.875rem;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center}.btn-header-language:hover .language-icon{transform:rotate(15deg)}.btn-header-language:active .language-icon{transform:rotate(15deg) scale(.95)}.header-icon{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#ffe66d,#ff6b6b);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;box-shadow:0 4px 12px #ff6b6b4d;position:relative;z-index:1}html.dark-theme .header-icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);box-shadow:0 4px 12px #ff8e8e66}.header-icon svg{width:24px;height:24px}html.dark-theme .header-settings{background:var(--color-bg-secondary)}.header-settings-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap;white-space:nowrap}.script-toggle-buttons{display:flex;align-items:center;gap:.25rem;flex-wrap:nowrap;white-space:nowrap}.settings-divider{width:1px;height:1.5rem;background-color:#d1d5db}html.dark-theme .settings-divider{background-color:var(--color-border)}.settings-divider-vertical{width:1px;height:1.25rem;background-color:#d1d5db;margin:0 .25rem}html.dark-theme .settings-divider-vertical{background-color:var(--color-border)}.settings-buttons{display:flex;align-items:center;gap:.25rem;flex-wrap:nowrap;white-space:nowrap}.btn-compact{padding:.5rem 1.5rem;font-size:1rem;font-weight:700;border:3px solid #FFE66D;border-radius:16px;background:linear-gradient(135deg,#fff,#fff9e6);color:#2c3e50;cursor:pointer;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);min-height:2.5rem;-webkit-tap-highlight-color:transparent;touch-action:manipulation;box-shadow:0 2px 8px #ffe66d33}html.dark-theme .btn-compact{background:var(--color-bg-secondary);color:var(--color-text);border:3px solid var(--color-border);box-shadow:0 2px 8px #0000004d}.btn-compact:hover{background:linear-gradient(135deg,#fff9e6,#fff);border-color:#ff6b6b;transform:translateY(-2px) scale(1.03);box-shadow:0 4px 12px #ff6b6b4d}html.dark-theme .btn-compact:hover{background:var(--color-bg-warm);border-color:var(--color-primary);box-shadow:0 4px 12px #ff8e8e4d}.btn-compact-active{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;border-color:#e55555;transform:none;box-shadow:0 6px 20px #ff6b6b66}html.dark-theme .btn-compact-active{background:var(--color-primary);border-color:var(--color-primary-dark)}.btn-compact-active:hover{background:linear-gradient(135deg,#e55555,#ff6b6b);border-color:#e55555;transform:none;box-shadow:0 8px 25px #ff6b6b80}html.dark-theme .btn-compact-active:hover{background:var(--color-primary-dark);box-shadow:0 8px 25px #ff8e8e80}.writing-practice-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;min-height:0;max-height:100%}.status-message{display:flex;align-items:center;justify-content:center;font-size:1.35rem;font-weight:700;color:#ff6b6b;background:linear-gradient(135deg,#fffffffa,#ffe66d4d);padding:.75rem 2rem;border-radius:9999px;box-shadow:0 4px 15px #ff6b6b4d;border:2px solid #FFE66D;transition:opacity .3s;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:fit-content;min-width:0;text-shadow:1px 1px 2px rgba(0,0,0,.1);flex:1;align-self:center;height:100%;margin:0 auto;justify-self:center}html.dark-theme .status-message{color:var(--color-primary);background:linear-gradient(135deg,var(--color-bg-secondary) 0%,rgba(255,142,142,.25) 100%);border:2px solid var(--color-primary);box-shadow:0 4px 15px #ff8e8e66;text-shadow:1px 1px 2px rgba(0,0,0,.5)}@media(min-width:768px)and (max-width:1024px){.writing-practice-header{padding:.5rem .75rem}.header-content{gap:.5rem}.header-settings{padding:.375rem;gap:.5rem;margin-left:auto}.header-actions{gap:.4rem;width:auto;max-width:none;flex:0 0 auto}.btn-header-language,.btn-header-theme,.btn-header-settings{min-width:2.25rem;min-height:2.25rem;padding:.4rem}.btn-header-language .language-icon,.btn-header-theme .theme-icon,.btn-header-settings .settings-icon{width:18px;height:18px}.status-message{position:static;transform:none;width:100%;margin:.5rem 0 0}.header-icon{width:2rem;height:2rem;font-size:1.25rem}.writing-practice-title{padding:0 1rem;font-size:1.25rem;margin:0}.btn-compact{padding:.3rem .6rem;font-size:.8rem;min-height:1.75rem}.status-message{font-size:1rem;padding:.4rem .75rem;max-width:250px}.writing-practice-character{margin-top:3rem}}.btn-back{background:none;border:none;color:#333;font-size:1.25rem;padding:.5rem;cursor:pointer;border-radius:.5rem;transition:background-color .2s;min-height:2.5rem;min-width:2.5rem;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}html.dark-theme .btn-back{color:var(--color-text)}.btn-back:hover,.btn-back:active{background-color:#e0e0e0}html.dark-theme .btn-back:hover,html.dark-theme .btn-back:active{background-color:var(--color-bg-secondary)}.writing-practice-title{font-size:1.75rem;padding:0 1rem;color:#ff6b6b;margin:0;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.writing-practice .header-left .writing-practice-title{white-space:nowrap;overflow:hidden}.practice-layout-container{display:flex;gap:0;flex:1;min-height:0;overflow:hidden;align-items:stretch}.stroke-order-section{flex:0 0 auto;min-width:280px;align-self:stretch;background:linear-gradient(135deg,#fffffff2,#fff9e6f2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:3px solid #FFE66D;box-shadow:0 4px 15px #ffe66d4d;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;min-height:0}html.dark-theme .stroke-order-section{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-warm) 100%);border:3px solid var(--color-border);box-shadow:0 4px 15px #0000004d}.stroke-order-section .writing-practice-character{margin-top:0;margin-bottom:.5rem;padding:.5rem 1rem;flex-shrink:0}.writing-practice-content{flex:1 1 auto;min-width:0;align-self:stretch;display:flex;flex-direction:column;min-height:0;overflow-y:auto;overflow-x:hidden;align-items:center;justify-content:flex-start;padding:.5rem;-webkit-overflow-scrolling:touch;position:relative}@media(min-width:768px)and (max-width:1024px){.practice-layout-container{gap:0;padding:.25rem}.stroke-order-section{flex:0 0 200px;min-width:200px;max-width:200px;align-self:stretch;min-height:0}.writing-practice-content{flex:1;min-width:0;align-self:stretch;overflow-y:auto;overflow-x:hidden;justify-content:flex-start;padding:.5rem;-webkit-overflow-scrolling:touch}}@media(min-width:768px)and (max-width:1024px)and (orientation:landscape){.writing-practice-header{padding:.4rem .6rem}.header-actions{gap:.35rem;width:auto;max-width:none;flex:0 0 auto}.btn-header-language,.btn-header-theme,.btn-header-settings{min-width:2rem;min-height:2rem;padding:.35rem}.practice-layout-container{gap:0;padding:.3rem}.stroke-order-section{flex:0 0 220px;min-width:220px;max-width:220px;align-self:stretch;min-height:0}.writing-practice-character{padding:.4rem .6rem;margin:2.5rem .2rem .2rem;min-height:3rem}.stroke-order-section .writing-practice-character{margin-top:0;margin-bottom:.3rem;padding:.4rem .6rem}.character-label{font-size:1rem}.character-display{font-size:2.5rem}.full-content{font-size:1.5rem;padding:.3rem .6rem}.canvas-wrapper{padding:.4rem}}@media(min-width:1025px)and (max-width:1366px){.practice-layout-container{gap:.5rem;padding:.5rem}.stroke-order-section{flex:0 0 auto;min-width:280px;max-width:350px;width:auto;align-self:stretch;min-height:0}.writing-practice-content{flex:1 1 auto;min-width:0;max-width:none}.canvas-wrapper{max-width:none}}@media(min-width:1367px){.practice-layout-container{gap:1rem;padding:1rem}.stroke-order-section{flex:0 0 auto;min-width:320px;max-width:450px;width:auto;align-self:stretch}.writing-practice-content{flex:1 1 auto;min-width:0;max-width:none}.canvas-wrapper{max-width:none;padding:1.5rem}}@media(max-width:767px){.practice-layout-container{flex-direction:column;gap:0;align-items:stretch;padding:0 .5rem}.stroke-order-section{min-width:auto;width:100%;max-width:500px;margin:0 auto;position:static}.writing-practice-content{width:100%}}.writing-practice-character{text-align:center;padding:.75rem 1rem;flex-shrink:0;margin:3.5rem .5rem .5rem;display:flex;align-items:center;justify-content:center;min-height:4rem}.practice-layout-container>.writing-practice-character{margin-top:0;margin-bottom:0;padding:.75rem 1rem}.character-display-single{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem}.character-display-sequential{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.5rem}.character-label{font-size:1.25rem;font-weight:700;color:#374151;margin:0;line-height:1.2}html.dark-theme .character-label{color:var(--color-text)}.full-content-wrapper{display:flex;flex-direction:column;align-items:center;gap:.4rem;width:100%;margin-top:0;margin-bottom:1rem;padding-top:0;padding-bottom:1rem;border-top:none;border-bottom:2px solid #e5e7eb;flex-shrink:0}.current-character-wrapper{display:flex;flex-direction:column;align-items:center;gap:.25rem}@media(min-width:768px)and (max-width:1024px){.writing-practice-character{padding:.5rem .75rem;margin:3rem .25rem .25rem;min-height:3.5rem}.stroke-order-section .writing-practice-character{margin-top:0;margin-bottom:.5rem;padding:.5rem .75rem}.character-label{font-size:1.1rem}.character-display{font-size:3rem}.character-display-wrapper .tts-button{width:36px;height:36px}.character-hint{font-size:.8rem}.full-content{font-size:1.75rem;padding:.4rem .8rem}.character-display-sequential{gap:.5rem}.full-content-wrapper{gap:.4rem;margin-top:.75rem;padding-top:.75rem}.progress-indicator{gap:.3rem;padding:.2rem}.char-indicator .pinyin-item{font-size:.65rem}.char-indicator .char-text{font-size:1.1rem}.char-indicator{padding:.3rem .6rem;min-width:2.25rem;min-height:2.25rem}.current-character-wrapper{gap:.2rem}}.character-display-wrapper{display:flex;align-items:center;justify-content:center;position:relative;width:100%}.character-display-wrapper:before{content:"";width:40px;height:40px;flex-shrink:0;margin-right:.5rem;visibility:hidden}.character-display{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:1rem 1.5rem;border:3px solid #FFE66D;border-radius:16px;background:linear-gradient(135deg,#fff,#f8f9fa);box-shadow:0 2px 8px #ffe66d33;text-align:center;flex:0 0 auto;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);min-width:fit-content}html.dark-theme .character-display{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-accent) 100%);border:3px solid var(--color-border);box-shadow:0 2px 8px #0000004d}.character-display .character-pinyin{font-size:.875rem;color:#6b7280;line-height:1;font-weight:500;margin:0;opacity:.9}html.dark-theme .character-display .character-pinyin{color:var(--color-text-secondary)}.character-display .character-text{font-size:4rem;font-weight:700;color:#ff6b6b;line-height:1;font-family:serif;text-shadow:2px 2px 4px rgba(0,0,0,.1)}html.dark-theme .character-display .character-text{color:var(--color-primary);text-shadow:2px 2px 4px rgba(0,0,0,.3)}.character-display-wrapper .tts-button{position:relative;flex-shrink:0;transition:background-color .2s ease,border-color .2s ease,color .2s ease;margin-left:.5rem;align-self:center}.character-display-wrapper .tts-button:hover:not(:disabled){transform:scale(1.05)}.character-display-wrapper .tts-button:active:not(:disabled){transform:scale(1.05)}.tts-button{background:#f3f4f6;border:2px solid #e5e7eb;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#6b7280;padding:0;flex-shrink:0}html.dark-theme .tts-button{background:var(--color-bg-accent);border:2px solid var(--color-border);color:var(--color-text-secondary)}.tts-button:hover:not(:disabled){background:#e5e7eb;border-color:#2563eb;color:#2563eb;transform:scale(1.05)}html.dark-theme .tts-button:hover:not(:disabled){background:var(--color-bg-warm);border-color:var(--color-primary);color:var(--color-primary)}.tts-button:active:not(:disabled){transform:scale(.95)}.tts-button:disabled{cursor:not-allowed;opacity:.7}.tts-loading-icon{animation:tts-spin 1s linear infinite}@keyframes tts-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tts-button-large{width:48px;height:48px}.full-content-with-audio{display:flex;align-items:center;justify-content:center;gap:.75rem}.character-pinyin{font-size:.875rem;font-weight:500;color:#6b7280;line-height:1;margin:0;opacity:.9}.character-hint{font-size:.875rem;color:#6b7280;margin:0;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;box-sizing:border-box}html.dark-theme .character-hint{color:var(--color-text-secondary)}.full-content{font-size:1.75rem;font-weight:700;color:#2c3e50;line-height:1.3;text-align:center;padding:.75rem 1.25rem;background:linear-gradient(135deg,#ffffffe6,#fff9e6e6);border-radius:16px;border:3px solid #FFE66D;box-shadow:0 4px 15px #ffe66d4d}html.dark-theme .full-content{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-warm) 100%);border:3px solid var(--color-border);color:var(--color-text);box-shadow:0 4px 15px #0000004d}.full-content-pinyin{font-size:1rem;font-weight:500;color:#6b7280;line-height:1.2;text-align:center;margin-bottom:.5rem;opacity:.9}html.dark-theme .full-content-pinyin{color:var(--color-text-secondary)}.full-content-aligned{display:flex;flex-direction:column;align-items:center;gap:.375rem;width:100%;margin-bottom:.5rem}.full-content-pinyin-row{display:flex;align-items:center;justify-content:center;gap:.375rem;flex-wrap:wrap;font-size:1rem;font-weight:500;color:#6b7280;line-height:1.2;opacity:.9}html.dark-theme .full-content-pinyin-row{color:var(--color-text-secondary)}.full-content-text-row{display:flex;align-items:center;justify-content:center;gap:.375rem;flex-wrap:wrap;font-size:1.5rem;font-weight:700;color:#1f2937;line-height:1.3}html.dark-theme .full-content-text-row{color:var(--color-text)}.progress-indicator{display:flex;gap:.375rem;justify-content:center;flex-wrap:wrap;padding:.25rem}.char-indicator{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem .875rem;border:3px solid #FFE66D;border-radius:16px;background:linear-gradient(135deg,#fff,#f8f9fa);transition:all .3s cubic-bezier(.68,-.55,.265,1.55);min-width:2.75rem;min-height:2.75rem;text-align:center;box-shadow:0 2px 8px #ffe66d33;cursor:pointer;font-family:inherit;font-size:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;outline:none}html.dark-theme .char-indicator{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-accent) 100%);border:3px solid var(--color-border);box-shadow:0 2px 8px #0000004d}.char-indicator:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.char-indicator:hover:not(.active){background:linear-gradient(135deg,#fff9e6,#fff);border-color:#ff6b6b;transform:translateY(-3px) scale(1.05);box-shadow:0 4px 12px #ff6b6b4d}html.dark-theme .char-indicator:hover:not(.active){background:linear-gradient(135deg,var(--color-bg-warm) 0%,var(--color-bg-secondary) 100%);border-color:var(--color-primary);box-shadow:0 4px 12px #ff8e8e4d}.char-indicator:active:not(.active){transform:translateY(-1px) scale(1.02);box-shadow:0 2px 6px #ff6b6b33}.char-indicator .pinyin-item{font-size:.75rem;color:#6b7280;line-height:1;font-weight:400}html.dark-theme .char-indicator .pinyin-item{color:var(--color-text-secondary)}.char-indicator .char-text{font-size:1.25rem;color:#9ca3af;font-weight:500;line-height:1}html.dark-theme .char-indicator .char-text{color:var(--color-text-secondary)}.char-indicator.active{border-color:#ff6b6b;background:linear-gradient(135deg,#ffe5b4,#ffcccb);transform:scale(1.15);box-shadow:0 6px 20px #ff6b6b66;cursor:default;border-width:4px}html.dark-theme .char-indicator.active{border-color:var(--color-primary);background:linear-gradient(135deg,#ff8e8e4d,#ffb3b340);box-shadow:0 6px 20px #ff8e8e66}.char-indicator.active:hover{transform:scale(1.15)}.char-indicator.active .pinyin-item{color:#e55555}html.dark-theme .char-indicator.active .pinyin-item{color:var(--color-primary)}.char-indicator.active .char-text{color:#e55555;font-weight:700}html.dark-theme .char-indicator.active .char-text{color:var(--color-primary)}.char-indicator.completed:hover{background:linear-gradient(135deg,#a8e6cf,#95e1d3);border-color:#6bc4b8;transform:translateY(-3px) scale(1.05);box-shadow:0 4px 12px #6bc4b84d}html.dark-theme .char-indicator.completed:hover{background:linear-gradient(135deg,#7ecdc44d,#5fc4b840);border-color:var(--color-success);box-shadow:0 4px 12px #7ecdc44d}.char-indicator.completed .pinyin-item{color:#6bc4b8}html.dark-theme .char-indicator.completed .pinyin-item{color:var(--color-success)}.char-indicator.completed .char-text{color:#6bc4b8;font-weight:700}html.dark-theme .char-indicator.completed .char-text{color:var(--color-success)}.canvas-wrapper{display:flex;justify-content:center;align-items:center;width:100%;padding:1rem;touch-action:none;pointer-events:none;-webkit-overflow-scrolling:touch;flex:1 1 auto;min-height:0;flex-shrink:1;max-width:100%;box-sizing:border-box}.canvas-wrapper>*{max-width:100%;max-height:100%;width:100%;height:100%;pointer-events:auto;touch-action:none;object-fit:contain}@media(min-width:768px)and (max-width:1024px){.canvas-wrapper{padding:.5rem;flex:1;min-height:0;display:flex;align-items:center;justify-content:center;margin-top:.3rem;margin-bottom:.3rem}}.writing-practice-controls{display:none;gap:1rem;justify-content:center;margin-bottom:1rem;flex-wrap:wrap;padding:0 1rem;flex-shrink:0}.writing-practice-controls .btn{padding:.875rem 2rem;font-size:1rem;border:none;border-radius:8px;cursor:pointer;transition:all .2s;min-width:120px;min-height:var(--touch-target-ideal);font-weight:500;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn-primary{background-color:#4caf50;color:#fff}.btn-primary:hover{background-color:#45a049;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:#f0f0f0;color:#333;border:1px solid #ddd}.btn-secondary:hover{background-color:#e0e0e0;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn-secondary:active{transform:translateY(0)}.stroke-counter{display:none;text-align:center;color:#666;font-size:.9rem;margin-top:1rem}.attempt-history{display:none;margin-top:1rem;margin-bottom:1rem;padding:1.5rem;background-color:#f9f9f9;border-radius:8px;width:100%;max-width:100%;flex-shrink:0}.attempt-history h3{font-size:1.2rem;color:#333;margin-bottom:.5rem}.attempt-history p{color:#666;margin-bottom:1rem}.attempt-list{display:flex;flex-direction:column;gap:.5rem}.attempt-item{display:flex;justify-content:space-between;padding:.5rem;background-color:#fff;border-radius:4px;font-size:.9rem;color:#666}.live-feedback{padding:1rem;margin-bottom:1rem;border-radius:8px;text-align:center;font-size:.95rem;animation:fadeIn .3s ease-in}.live-feedback.mistake{display:none;background-color:#ffebee;border:2px solid #f44336;color:#c62828;position:absolute;top:1rem;left:50%;transform:translate(-50%);z-index:100;margin-bottom:0;min-width:200px;max-width:90%;box-shadow:0 4px 12px #0003}.live-feedback.correct{display:none;background-color:#e8f5e9;border:2px solid #4caf50;color:#2e7d32}.live-feedback.complete{display:none;background-color:#e3f2fd;border:2px solid #2196f3;color:#1565c0}.live-feedback.start{background-color:#fff3e0;border:2px solid #ff9800;color:#e65100}.accuracy-display{font-size:1.2rem;font-weight:700;margin-top:.5rem}.performance-summary{display:none;margin-top:1.5rem;padding:1.5rem;background-color:#f5f5f5;border-radius:8px;border:1px solid #ddd}.performance-summary h4{margin:0 0 1rem;color:#333;font-size:1.1rem}.performance-summary p{margin:.5rem 0;color:#666;font-size:.95rem}@media(max-width:767px){.writing-practice{height:100vh;height:-webkit-fill-available;height:100dvh;max-height:100vh;max-height:-webkit-fill-available;max-height:100dvh;position:fixed;inset:0}.writing-practice-header{padding:.35rem .5rem;min-height:2.75rem;flex-shrink:0;overflow:visible;box-sizing:border-box;width:100%;max-width:100%;position:relative}.header-content{display:flex;flex-direction:row;flex-wrap:nowrap;gap:.15rem;width:100%;max-width:100%;min-height:auto;align-items:center;justify-content:space-between;overflow:visible;box-sizing:border-box;padding:0;position:relative}.header-left{display:flex;align-items:center;gap:.15rem;flex-shrink:1;flex:0 1 auto;min-width:0;overflow:visible;max-width:calc(100% - 100px)}.btn-back{min-width:1.75rem;min-height:1.75rem;padding:.2rem;font-size:.9rem;flex-shrink:0}.header-icon{width:1.75rem;height:1.75rem;flex-shrink:0;position:relative;z-index:1}.header-icon svg{width:16px;height:16px}.writing-practice-title{font-size:.75rem;padding:0 .2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:0 1 auto;min-width:0;max-width:none}.header-actions{display:flex;gap:.1rem;margin-left:auto;align-self:center;flex-shrink:0;flex:0 0 auto;padding:0;min-width:0;width:auto;max-width:85px;justify-content:flex-end;overflow:visible;box-sizing:border-box;position:relative}.btn-header-language,.btn-header-theme,.btn-header-settings{min-width:1.6rem;min-height:1.6rem;padding:.15rem;flex-shrink:0;margin:0}.btn-header-language .language-icon,.btn-header-theme .theme-icon,.btn-header-settings .settings-icon{width:14px;height:14px}.btn-header-language .language-label{font-size:.65rem;display:none}.status-message{display:none}.header-settings{order:0;width:auto;gap:.08rem;justify-content:center;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;flex-shrink:0;min-width:0;box-sizing:border-box;overflow:visible}.header-settings-controls{gap:.1rem;flex-wrap:nowrap;justify-content:flex-end;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;min-width:0;width:auto;max-width:100%;display:flex;align-items:center}.header-settings-controls .script-toggle-buttons,.header-settings-controls .difficulty-selector{flex-shrink:0;min-width:0}.header-settings-controls .script-toggle-buttons .btn-compact,.header-settings-controls .difficulty-selector .btn-compact{flex-shrink:0;min-width:auto;white-space:nowrap;padding:.15rem .25rem;font-size:.6rem}.header-settings-controls .settings-divider-vertical{flex-shrink:0;height:.9rem;margin:0 .1rem}.btn-compact{padding:.12rem .25rem;font-size:.55rem;min-height:1.4rem;border-width:2px;border-radius:.4rem;white-space:nowrap;flex-shrink:0;line-height:1.2}.settings-divider-vertical{height:1rem;margin:0 .125rem}.character-display-sequential{gap:.2rem;width:100%;box-sizing:border-box;overflow:hidden}.character-display-sequential .character-hint{width:100%;max-width:100%;padding:0 .2rem;box-sizing:border-box}.full-content-wrapper{margin-top:.3rem;padding-top:.3rem;padding-bottom:.3rem;gap:.25rem;flex-shrink:0;width:100%;box-sizing:border-box}.settings-buttons{flex-wrap:wrap;width:100%;min-width:0;justify-content:center}.writing-practice-character{padding:.3rem .4rem;margin-top:0;min-height:2.5rem;flex-shrink:0}.stroke-order-section .writing-practice-character{margin-top:0;margin-bottom:.2rem;padding:.3rem .4rem}.character-label{font-size:.85rem;margin:0}.character-display{font-size:1.75rem;padding:.4rem .6rem}.character-display .character-text{font-size:1.75rem}.character-display .character-pinyin{font-size:.7rem}.character-display-wrapper .tts-button{width:32px;height:32px}.character-display-wrapper .tts-button svg{width:16px;height:16px}.full-content{font-size:1.1rem;padding:.3rem .5rem}.full-content-pinyin{font-size:.85rem;margin-bottom:.25rem}.tts-button-large{width:36px;height:36px}.tts-button-large svg{width:18px;height:18px}.char-indicator .pinyin-item{font-size:.7rem}.char-indicator .char-text{font-size:1.3rem}.char-indicator{padding:.5rem .75rem;min-width:2.5rem;min-height:2.5rem;border-width:2px;border-radius:.75rem;gap:.3rem}.char-indicator.active{transform:scale(1.1)}.char-indicator.active .char-text{font-size:1.4rem}.practice-layout-container{flex-direction:column;gap:.25rem;padding:.25rem;flex:1;min-height:0;overflow:hidden;width:100%;box-sizing:border-box;display:flex}.stroke-order-section{min-width:auto;width:100%;max-width:100%;max-height:130px;padding:.35rem;border-width:2px;border-radius:.75rem;overflow-y:auto;overflow-x:hidden;flex-shrink:0;margin:0;box-sizing:border-box}.stroke-order-section .writing-practice-character{margin-bottom:.25rem}.progress-indicator{gap:.4rem;padding:.4rem}.canvas-wrapper{padding:.25rem;flex:1 1 auto;min-height:200px;max-height:none;display:flex;align-items:center;justify-content:center;width:100%;box-sizing:border-box;overflow:visible}.writing-practice-content{padding:.3rem;gap:.25rem;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;width:100%;box-sizing:border-box;display:flex;flex-direction:column}.writing-practice-controls{flex-direction:column;gap:.5rem;padding:.5rem}.writing-practice-controls .btn{width:100%;max-width:280px;padding:.5rem 1rem;font-size:.9rem;min-height:2.5rem}.character-hint{font-size:.65rem;margin-top:.2rem;padding:0 .2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;box-sizing:border-box}.current-character-wrapper{gap:.15rem}}@media(min-width:768px)and (max-width:1024px){.writing-practice-controls{padding:.4rem;background:#fff;border-radius:6px;box-shadow:0 2px 8px #0000000d;margin-top:.3rem;margin-bottom:.3rem;flex-shrink:0;gap:.4rem}.writing-practice-controls .btn{padding:.5rem 1rem;font-size:.85rem;min-width:90px;min-height:36px}.stroke-counter{margin-top:.3rem;font-size:.8rem;flex-shrink:0}.live-feedback{margin-top:.3rem;margin-bottom:.3rem;padding:.5rem;border-radius:6px;font-size:.8rem;flex-shrink:0}.performance-summary{margin-top:.3rem;margin-bottom:.3rem;padding:.5rem;border-radius:6px;flex-shrink:0;max-height:150px;overflow-y:auto}.performance-summary h4{font-size:.9rem;margin-bottom:.3rem}.performance-summary p{font-size:.8rem;margin:.15rem 0}.attempt-history{margin-top:.3rem;margin-bottom:.3rem;padding:.5rem;flex-shrink:0;max-height:120px;overflow-y:auto}.attempt-history h3{font-size:.9rem;margin-bottom:.3rem}.attempt-history p{font-size:.8rem;margin-bottom:.4rem}}@media(min-width:1025px){.writing-practice-title{font-size:2rem;padding:0 1rem}.character-display{font-size:6rem}.character-hint{font-size:1.2rem}.writing-practice-controls .btn{padding:1rem 2.5rem;font-size:1.1rem;min-width:150px}}@media(min-width:1440px){.character-display{font-size:8rem}}.custom-content-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.custom-content-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.custom-content-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.custom-content-modal-header h2{margin:0;font-size:1.25rem;color:#333}.custom-content-modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.custom-content-modal-close:hover{background-color:#f3f4f6}.custom-content-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.custom-content-input-group{margin-bottom:1.5rem}.custom-content-input-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333;font-size:.9rem}.custom-content-textarea{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}.custom-content-textarea:focus{outline:none;border-color:#3b82f6}.custom-content-error{color:#ef4444;font-size:.875rem;margin-top:.5rem}.custom-content-select{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;background:#fff;cursor:pointer;transition:border-color .2s}.custom-content-select:focus{outline:none;border-color:#3b82f6}.custom-content-input{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;margin-top:.5rem;transition:border-color .2s}.custom-content-input:focus{outline:none;border-color:#3b82f6}.custom-content-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;margin-bottom:1rem}.custom-content-preview-item{display:flex;align-items:center;margin-bottom:.5rem}.custom-content-preview-item:last-child{margin-bottom:0}.custom-content-preview-label{font-weight:500;color:#666;min-width:60px;font-size:.9rem}.custom-content-preview-text{color:#333;font-size:1.1rem;flex:1}.custom-content-modal-info{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:.75rem;font-size:.875rem;color:#1e40af}.custom-content-modal-info p{margin:0;line-height:1.5}.custom-content-modal-actions{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb;justify-content:center}@media(min-width:768px)and (max-width:1024px){.custom-content-modal{max-width:600px}}.word-list-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.word-list-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026;overflow:hidden}.word-list-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.word-list-modal-header h2{margin:0;font-size:1.25rem;color:#333}.word-list-modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.word-list-modal-close:hover{background-color:#f3f4f6}.word-list-modal-body{padding:1.5rem;flex:1;overflow-y:auto}.word-list-input-group{margin-bottom:1.5rem}.word-list-input-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333;font-size:.9rem}.word-list-input{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s}.word-list-input:focus{outline:none;border-color:#3b82f6}.word-list-error{margin-top:.5rem;color:#ef4444;font-size:.875rem}.word-list-modal-info{background:#eff6ff;border:1px solid #bfdbfe;padding:1rem;border-radius:8px;margin-top:1rem}.word-list-modal-info p{margin:0;color:#1e40af;font-size:.875rem;line-height:1.5}.word-list-modal-actions{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb;justify-content:center}.word-list-modal-actions .btn{min-width:100px}.writing-practice-selection{width:100%;min-height:100vh;min-height:-webkit-fill-available;min-height:100dvh;background:radial-gradient(circle at 20% 50%,rgba(255,107,107,.15) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(78,205,196,.15) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(255,230,109,.15) 0%,transparent 50%),linear-gradient(135deg,#fff9e6,#e8f5e9,#e3f2fd);background-attachment:fixed;display:flex;flex-direction:column;overflow:hidden;transition:background .3s ease}html.dark-theme .writing-practice-selection{background:radial-gradient(circle at 20% 50%,rgba(255,107,107,.12) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(78,205,196,.12) 0%,transparent 50%),radial-gradient(circle at 40% 20%,rgba(255,230,109,.1) 0%,transparent 50%),linear-gradient(135deg,#2e3149,#252840,#1e2139)}.writing-practice-selection .header-content{grid-template-columns:min-content 1fr min-content;width:100%;justify-items:start;box-sizing:border-box;padding:0;height:100%;align-items:stretch}.writing-practice-selection .header-left{grid-column:1;justify-self:start;align-self:stretch;flex-shrink:0;width:auto;display:flex;align-items:center;height:100%;overflow:visible}.writing-practice-selection .status-message{grid-column:2;justify-self:center;align-self:stretch;width:100%;min-width:0;overflow:hidden;display:flex;align-items:center;height:100%}.writing-practice-selection .header-actions{grid-column:3;justify-self:end;align-self:stretch;display:flex;align-items:center;gap:.5rem;flex-shrink:0;height:100%}.writing-practice-selection .btn-header-theme,.writing-practice-selection .btn-header-settings{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,background-color .2s ease,color .3s ease;flex-shrink:0;width:auto;min-width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text);vertical-align:middle;line-height:1}.writing-practice-selection .btn-header-theme:hover,.writing-practice-selection .btn-header-settings:hover{background-color:var(--color-bg-secondary)}.writing-practice-selection .btn-header-theme:active,.writing-practice-selection .btn-header-settings:active{transform:scale(.95)}.writing-practice-selection .btn-header-theme .theme-icon,.writing-practice-selection .btn-header-settings .settings-icon{width:20px;height:20px;transition:transform .2s ease;display:flex;align-items:center;justify-content:center}.writing-practice-selection .btn-header-theme:hover .theme-icon{transform:rotate(180deg)}.writing-practice-selection .btn-header-settings:hover .settings-icon{transform:rotate(90deg)}.writing-practice-selection .btn-header-theme:active .theme-icon{transform:rotate(180deg) scale(.95)}.writing-practice-selection .btn-header-settings:active .settings-icon{transform:rotate(90deg)}.writing-practice-selection .btn-header-language{background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;gap:.25rem;transition:transform .2s ease,background-color .2s ease,color .3s ease;flex-shrink:0;width:auto;min-width:2.5rem;height:2.5rem;border-radius:.375rem;color:var(--color-text);vertical-align:middle;line-height:1}.writing-practice-selection .btn-header-language:hover{background-color:var(--color-bg-secondary)}.writing-practice-selection .btn-header-language:active{transform:scale(.95)}.writing-practice-selection .btn-header-language .language-icon{width:20px;height:20px;transition:transform .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.writing-practice-selection .btn-header-language .language-label{font-size:.875rem;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center}.writing-practice-selection .btn-header-language:hover .language-icon{transform:rotate(15deg)}.writing-practice-selection .btn-header-language:active .language-icon{transform:rotate(15deg) scale(.95)}.writing-practice-selection .header-left .writing-practice-title{white-space:nowrap;overflow:hidden}.writing-practice-selection .header-icon{width:2.5rem;height:2.5rem;background:linear-gradient(135deg,#ffe66d,#ff6b6b);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;box-shadow:0 4px 12px #ff6b6b4d;position:relative;z-index:1}html.dark-theme .writing-practice-selection .header-icon{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);box-shadow:0 4px 12px #ff8e8e66}.writing-practice-selection .header-icon svg{width:24px;height:24px}.writing-practice-selection-main{flex:1;display:flex;align-items:stretch;justify-content:center;padding:2rem;overflow:hidden;min-height:0}.selection-content{background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%);transition:background .3s ease;border-radius:20px;padding:1.5rem;box-shadow:0 8px 30px #ff6b6b33;border:3px solid #FFE66D;text-align:center;width:100%;align-self:stretch;display:flex;flex-direction:column;overflow:hidden;min-height:0;max-height:100%;touch-action:pan-y}html.dark-theme .selection-content{box-shadow:0 8px 30px #0006;border:3px solid var(--color-border)}.selection-content h2{font-size:2.5rem;color:#ff6b6b;margin-bottom:1rem;flex-shrink:0;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.1)}html.dark-theme .selection-content h2{color:#ff8e8e;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.selection-content p{font-size:1.25rem;color:#7f8c8d;margin-bottom:1rem;flex-shrink:0}html.dark-theme .selection-content p{color:var(--color-text-secondary)}.content-list{display:flex;flex-direction:column;gap:1.5rem;flex:1 1 0;min-height:0;max-height:100%;overflow-y:auto;overflow-x:visible;padding:1rem;-webkit-overflow-scrolling:touch;touch-action:pan-y;border-radius:16px;background:linear-gradient(135deg,#f0f8ff,#fff4e6);border:2px solid #FFE5B4;transition:background .3s ease,border-color .3s ease}html.dark-theme .content-list{background:linear-gradient(135deg,var(--color-bg-accent) 0%,var(--color-bg-warm) 100%);border:2px solid var(--color-border);scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.content-list::-webkit-scrollbar{width:8px}.content-list::-webkit-scrollbar-track{background:transparent;border-radius:4px}.content-list::-webkit-scrollbar-thumb{background:#0003;border-radius:4px;border:2px solid transparent;background-clip:padding-box}.content-list::-webkit-scrollbar-thumb:hover{background:#0000004d;background-clip:padding-box}.content-group{display:flex;flex-direction:column;gap:.75rem;background:transparent;border-radius:0;padding:0;box-shadow:none}.content-group-header{padding:0;margin-bottom:0;display:flex;align-items:center}.content-group-header-clickable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);padding:.75rem 1.25rem;border-radius:25px;background:linear-gradient(135deg,#ffe5b4,#ffcccb);border:3px solid #FF6B6B;display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.75rem;box-shadow:0 4px 15px #ff6b6b4d;white-space:nowrap;overflow:visible;min-width:fit-content}html.dark-theme .content-group-header-clickable{background:linear-gradient(135deg,#ff8e8e33,#ffb3b326);border:3px solid var(--color-primary);box-shadow:0 4px 15px #ff8e8e40}.content-group-header-clickable:hover{background:linear-gradient(135deg,#ffcccb,#ffb6c1);border-color:#e55555;box-shadow:0 6px 20px #ff6b6b66;transform:translateY(-3px)}html.dark-theme .content-group-header-clickable:hover{background:linear-gradient(135deg,#ff8e8e4d,#ffb3b340);border-color:var(--color-primary-light);box-shadow:0 6px 20px #ff8e8e59}.content-group[data-expanded=true] .content-group-header-clickable{background:linear-gradient(135deg,#ffcccb,#ffb6c1);border-color:#e55555;box-shadow:0 6px 20px #ff6b6b66}html.dark-theme .content-group[data-expanded=true] .content-group-header-clickable{background:linear-gradient(135deg,#ff8e8e4d,#ffb3b340);border-color:var(--color-primary-light);box-shadow:0 6px 20px #ff8e8e59}.content-category[data-expanded=true] .content-category-header-clickable{background-color:#e5e7eb;border-color:#9ca3af}html.dark-theme .content-category[data-expanded=true] .content-category-header-clickable{background-color:var(--color-bg-warm);border-color:var(--color-primary)}.content-group-title{font-size:1.1rem;font-weight:700;color:#e55555;margin:0;display:flex;align-items:center;gap:.5rem;white-space:nowrap}html.dark-theme .content-group-title{color:var(--color-primary)}.content-group-title-text{flex:0 0 auto}.content-group-count{font-size:.8rem;font-weight:600;color:#7c3aed;background:#ffffffb3;padding:.125rem .5rem;border-radius:12px;flex:0 0 auto}html.dark-theme .content-group-count{color:var(--color-primary-light);background:#ff8e8e33}.content-group-toggle{font-size:.7rem;color:#7c3aed;transition:transform .2s;flex:0 0 auto;margin-left:.25rem}html.dark-theme .content-group-toggle{color:var(--color-primary-light)}.content-group[data-expanded=true] .content-group-toggle,.content-group[data-expanded=false] .content-group-toggle{transform:rotate(0)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px);max-height:0}to{opacity:1;transform:translateY(0);max-height:5000px}}@keyframes slideUp{0%{opacity:1;transform:translateY(0);max-height:5000px}to{opacity:0;transform:translateY(-10px);max-height:0}}.content-group-categories{display:flex;flex-direction:column;gap:1rem;margin-top:0;padding-left:1rem;border-left:2px solid #e0e7ff;margin-left:.5rem;overflow:visible;animation:slideDown .3s ease-out}html.dark-theme .content-group-categories{border-left:2px solid var(--color-border)}.content-category{display:flex;flex-direction:column;gap:.5rem}.content-category-header{padding:0;margin-bottom:.5rem;display:flex;align-items:center}.content-category-header-clickable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s;padding:.375rem .875rem;border-radius:16px;background:#f3f4f6;border:1px solid #e5e7eb;display:inline-flex;align-items:center;gap:.5rem;margin-bottom:.5rem;box-shadow:0 1px 2px #0000000d;white-space:nowrap;overflow:visible;min-width:fit-content}html.dark-theme .content-category-header-clickable{background:var(--color-bg-secondary);border:1px solid var(--color-border);box-shadow:0 1px 2px #0003}.content-category-header-clickable:hover{background-color:#e5e7eb;border-color:#d1d5db;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}html.dark-theme .content-category-header-clickable:hover{background-color:var(--color-bg-warm);border-color:var(--color-primary);box-shadow:0 2px 4px #0000004d}.content-category-title{font-size:.875rem;font-weight:500;color:#4b5563;margin:0;display:flex;align-items:center;gap:.5rem;white-space:nowrap}html.dark-theme .content-category-title{color:var(--color-text-secondary)}.content-category-title-text{flex:0 0 auto}.content-category-count{font-size:.75rem;font-weight:600;color:#6b7280;background:#fffc;padding:.125rem .4rem;border-radius:10px;flex:0 0 auto}html.dark-theme .content-category-count{color:var(--color-text-secondary);background:#ff8e8e26}.content-category-toggle{font-size:.65rem;color:#6b7280;transition:transform .2s;flex:0 0 auto;margin-left:.25rem}html.dark-theme .content-category-toggle{color:var(--color-text-secondary)}.content-category[data-expanded=true] .content-category-toggle,.content-category[data-expanded=false] .content-category-toggle{transform:rotate(0)}.content-group-items{display:flex;flex-direction:row;flex-wrap:wrap;gap:.875rem;align-items:flex-start;padding:.5rem 0 .5rem .5rem;overflow:visible;-webkit-overflow-scrolling:touch;animation:slideDown .3s ease-out}@keyframes bounceIn{0%{transform:scale(.3) translateY(-50px);opacity:0}50%{transform:scale(1.05) translateY(0)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}.content-item{background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #FFE66D;border-radius:20px;padding:1.5rem 1.25rem;cursor:pointer;transition:all .4s cubic-bezier(.68,-.55,.265,1.55);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:110px;height:fit-content;width:auto;min-width:fit-content;flex-shrink:0;overflow:visible;position:relative;box-shadow:0 4px 15px #ffe66d4d;animation:bounceIn .6s cubic-bezier(.68,-.55,.265,1.55);animation-fill-mode:both}html.dark-theme .content-item{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-accent) 100%);border:3px solid var(--color-border);box-shadow:0 4px 15px #0000004d}.content-item:has(.content-action-buttons){transform:scale(1.02);padding:1.75rem 1.5rem}.content-item:nth-child(1){animation-delay:0s}.content-item:nth-child(2){animation-delay:.05s}.content-item:nth-child(3){animation-delay:.1s}.content-item:nth-child(4){animation-delay:.15s}.content-item:nth-child(5){animation-delay:.2s}.content-item:nth-child(6){animation-delay:.25s}.content-item:nth-child(7){animation-delay:.3s}.content-item:nth-child(8){animation-delay:.35s}.content-item:nth-child(9){animation-delay:.4s}.content-item:nth-child(10){animation-delay:.45s}.content-item:nth-child(n+11){animation-delay:.5s}.content-item:hover{border-color:#ff6b6b;transform:translateY(-5px) rotate(2deg);box-shadow:0 8px 25px #ffe66d80;background:linear-gradient(135deg,#fff,#fff9e6)}html.dark-theme .content-item:hover{border-color:var(--color-primary);box-shadow:0 8px 25px #ff8e8e66;background:linear-gradient(135deg,var(--color-bg-warm) 0%,var(--color-bg-secondary) 100%)}.content-item-selected{border-color:#ff6b6b;border-width:4px;background:linear-gradient(135deg,#ffe5b4,#ffcccb)!important;box-shadow:0 10px 30px #ff6b6b66;transform:scale(1.05) translateY(-2px)}html.dark-theme .content-item-selected{border-color:var(--color-primary);background:linear-gradient(135deg,#ff8e8e40,#ffb3b333)!important;box-shadow:0 10px 30px #ff8e8e66}.content-item-selected:hover{transform:scale(1.05) translateY(-3px);box-shadow:0 12px 35px #ff6b6b80;background:linear-gradient(135deg,#ffe5b4,#ffcccb)!important}html.dark-theme .content-item-selected:hover{background:linear-gradient(135deg,#ff8e8e40,#ffb3b333)!important}.content-item-selected:focus{background:linear-gradient(135deg,#ffe5b4,#ffcccb)!important;outline:none;border-color:#ff6b6b}html.dark-theme .content-item-selected:focus{background:linear-gradient(135deg,#ff8e8e40,#ffb3b333)!important;border-color:var(--color-primary)}.content-item-selected:active{background:linear-gradient(135deg,#ffe5b4,#ffcccb)!important;transform:scale(1.03) translateY(-1px)}html.dark-theme .content-item-selected:active{background:linear-gradient(135deg,#ff8e8e40,#ffb3b333)!important}.content-display{font-size:2rem;font-weight:600;color:#1f2937;line-height:1.5;word-wrap:break-word;word-break:break-word;overflow-wrap:break-word;text-align:center;width:100%;max-width:100%;white-space:normal;overflow:visible;display:flex;flex-direction:column;align-items:center;gap:.375rem}html.dark-theme .content-display{color:var(--color-text)}.content-text{font-size:2rem;font-weight:600;color:#1f2937;line-height:1.5;word-wrap:break-word;word-break:break-word;overflow-wrap:break-word;text-align:center;width:100%;max-width:100%;white-space:normal;overflow:visible}html.dark-theme .content-text{color:var(--color-text)}.content-pinyin{font-size:.875rem;font-weight:500;color:#6b7280;line-height:1.2;text-align:center;margin-bottom:.25rem;opacity:.8}html.dark-theme .content-pinyin{color:var(--color-text-secondary)}.content-aligned{display:table;width:100%;border-collapse:separate;border-spacing:.25rem;margin:0 auto}.content-pinyin-row{display:table-row;font-size:.875rem;font-weight:500;color:#6b7280;line-height:1.2;opacity:.8}html.dark-theme .content-pinyin-row{color:var(--color-text-secondary)}.content-text-row{display:table-row;font-size:2rem;font-weight:600;color:#1f2937;line-height:1.5}html.dark-theme .content-text-row{color:var(--color-text)}.pinyin-item,.char-item{display:table-cell;text-align:center;vertical-align:middle;padding:0 .125rem;width:auto}.content-item-selected .content-display{color:#1e40af;font-weight:700}html.dark-theme .content-item-selected .content-display{color:var(--color-primary)}.content-item-custom{border-color:#a78bfa;transition:all .4s cubic-bezier(.68,-.55,.265,1.55)}.content-item-custom:has(.content-action-buttons){transform:scale(1.03);padding:1.75rem 1.5rem}.content-item-custom.content-item-selected{border-color:#7c3aed;background:#f5f3ff}.content-action-buttons{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;width:100%;margin-bottom:.5rem;flex-shrink:0;animation:slideDownFadeIn .3s cubic-bezier(.68,-.55,.265,1.55) forwards;opacity:0;transform:translateY(-10px)}@keyframes slideDownFadeIn{0%{opacity:0;transform:translateY(-10px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.content-edit-btn{width:28px;height:28px;border-radius:50%;border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none;padding:0;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);z-index:10;box-shadow:0 2px 8px #3b82f64d;animation:buttonPopIn .4s cubic-bezier(.68,-.55,.265,1.55) .1s forwards;opacity:0;transform:scale(0)}@keyframes buttonPopIn{0%{opacity:0;transform:scale(0) rotate(-180deg)}to{opacity:1;transform:scale(1) rotate(0)}}.content-edit-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:scale(1.15);box-shadow:0 4px 12px #3b82f666}.content-edit-btn:active{transform:scale(1.05)}.content-delete-btn{width:28px;height:28px;border-radius:50%;border:none;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);z-index:10;box-shadow:0 2px 8px #ef44444d;animation:buttonPopIn .4s cubic-bezier(.68,-.55,.265,1.55) .2s forwards;opacity:0;transform:scale(0);user-select:none;-webkit-user-select:none;text-align:center}.content-delete-btn svg,.content-edit-btn svg,.content-remove-btn svg,.content-group-add-btn svg,.content-group-edit-btn svg,.content-group-delete-btn svg{width:14px;height:14px;display:block;flex-shrink:0}.content-delete-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:scale(1.15);box-shadow:0 4px 12px #ef444466}.content-delete-btn:active{transform:scale(1.05)}.content-remove-btn{width:28px;height:28px;border-radius:50%;border:none;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:1.25rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 2px 6px #f59e0b4d;user-select:none;-webkit-user-select:none}.content-remove-btn:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:scale(1.15);box-shadow:0 4px 12px #f59e0b66}.content-remove-btn:active{transform:scale(1.05)}.content-tts-button{width:32px;height:32px;border-radius:50%;border:none;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);z-index:10;box-shadow:0 2px 8px #8b5cf64d;user-select:none;-webkit-user-select:none;margin-top:.5rem;flex-shrink:0}.content-tts-button:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:scale(1.1);box-shadow:0 4px 12px #8b5cf666}.content-tts-button:active{transform:scale(1.05)}.content-tts-button svg{width:16px;height:16px;display:block;flex-shrink:0}.content-group-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto;margin-right:.5rem;animation:slideDownFadeIn .3s cubic-bezier(.68,-.55,.265,1.55) forwards;opacity:0;transform:translateY(-10px)}.content-group-add-btn,.content-group-edit-btn,.content-group-delete-btn{width:24px;height:24px;border-radius:50%;border:none;color:#fff;font-size:.875rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);user-select:none;-webkit-user-select:none;padding:0;z-index:10;animation:buttonPopIn .4s cubic-bezier(.68,-.55,.265,1.55) forwards;opacity:0;transform:scale(0)}.content-group-add-btn{background:linear-gradient(135deg,#10b981,#059669);font-size:1rem;font-weight:700;box-shadow:0 2px 8px #10b9814d;animation-delay:.05s}.content-group-add-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:scale(1.15);box-shadow:0 4px 12px #10b98166;opacity:1}.content-group-add-btn:active{transform:scale(1.05)}.content-group-edit-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f64d;animation-delay:.1s}.content-group-edit-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:scale(1.15);box-shadow:0 4px 12px #3b82f666;opacity:1}.content-group-edit-btn:active{transform:scale(1.05)}.content-group-delete-btn{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d;animation-delay:.15s}.content-group-delete-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:scale(1.15);box-shadow:0 4px 12px #ef444466;opacity:1}.content-group-delete-btn:active{transform:scale(1.05)}.content-item-draggable{cursor:grab;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:none}.content-item[draggable=true]{cursor:grab;-webkit-user-select:none;user-select:none}.content-item[draggable=true]:active,.content-item-draggable:active{cursor:grabbing}.content-item.dragging{opacity:.1!important;transform:scale(.95);z-index:1000;position:relative;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;pointer-events:none;box-shadow:none!important}.drag-ghost{position:fixed!important;pointer-events:none!important;z-index:10000!important;opacity:.9!important;transform:rotate(3deg)!important;box-shadow:0 8px 16px #0000004d!important;transition:none!important}.content-group.drag-over{background-color:#3b82f61a;border:2px dashed #3b82f6;border-radius:8px}.content-group-items.drag-over{background-color:#3b82f60d;border:2px dashed #3b82f6;border-radius:4px;min-height:50px}.content-group-ungrouped-wrapper{min-height:100px;height:auto;border:2px dotted rgba(0,0,0,.2);border-radius:8px;padding:.5rem;display:flex;flex-direction:column;align-items:stretch;flex-shrink:0;width:100%;box-sizing:border-box}html.dark-theme .content-group-ungrouped-wrapper{border-color:#ffffff4d}.content-group-header-ungrouped{margin-bottom:.75rem;padding:.5rem 0;border-bottom:1px solid rgba(0,0,0,.1);width:100%}.content-group-ungrouped-wrapper .content-group-items{min-height:50px;height:auto;flex:0 0 auto;width:100%;align-self:stretch}.content-group-ungrouped-wrapper .content-group-items.drag-over{background-color:#3b82f626;border:2px dashed #3b82f6;border-radius:8px;padding:.5rem;min-height:50px}html.dark-theme .content-group-header-ungrouped{border-bottom-color:#ffffff1a}@media(hover:none)and (pointer:coarse){.content-item-draggable,.content-item-draggable:active{cursor:default}.content-item.dragging{opacity:.6;box-shadow:0 4px 12px #0000004d}}.selection-header{display:grid;grid-template-columns:1fr auto;align-items:center;gap:1rem;margin-bottom:1rem}.selection-header-left{justify-self:start;text-align:left;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}.selection-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:1rem;justify-self:end}.selection-header-left h2,.selection-header-left p{margin:0}.selection-header-settings{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;padding:.75rem .5rem;border-radius:.5rem;flex-shrink:0}.selection-header-settings-title{font-size:.75rem;font-weight:600;color:#6b7280;margin:0;text-align:center;white-space:nowrap}html.dark-theme .selection-header-settings-title{color:var(--color-text-secondary)}.selection-header-settings-controls{display:flex;flex-direction:column;gap:.75rem;align-items:stretch;width:100%}.settings-row-first{width:100%;display:flex;align-items:center;gap:.25rem;flex-wrap:nowrap;white-space:nowrap;min-width:0;justify-content:space-between}.settings-row-first .btn-compact{flex:1;min-width:0;text-align:center;display:flex;justify-content:center;align-items:center}.settings-row-second{width:100%;display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap;white-space:nowrap;min-width:0;justify-content:space-between}.settings-row-second .script-toggle-buttons{flex:1;display:flex;gap:.25rem;min-width:0}.settings-row-second .script-toggle-buttons .btn-compact{flex:1;min-width:0;text-align:center;display:flex;justify-content:center;align-items:center}.settings-row-second .difficulty-selector{flex:1;min-width:0}.settings-row-second .difficulty-selector .difficulty-buttons{display:flex;gap:.25rem;width:100%}.settings-row-second .difficulty-selector .difficulty-buttons .btn-compact{flex:1;min-width:0;text-align:center;display:flex;justify-content:center;align-items:center}.settings-row-second .settings-divider{flex-shrink:0;width:1px}.selection-header-settings>.script-toggle-buttons,.selection-header-settings>.settings-buttons{display:flex;align-items:center;gap:.25rem;flex-wrap:nowrap;white-space:nowrap}.settings-divider{width:1px;height:1.5rem;background:#e5e7eb;flex-shrink:0}html.dark-theme .settings-divider{background:var(--color-border)}.settings-divider-vertical{width:1px;height:1.5rem;background:#e5e7eb;flex-shrink:0}html.dark-theme .settings-divider-vertical{background:var(--color-border)}.difficulty-selector{display:flex;flex-direction:column;align-items:center;gap:.5rem}.difficulty-label{font-size:.75rem;font-weight:600;color:#6b7280;margin:0;white-space:nowrap}html.dark-theme .difficulty-label{color:var(--color-text-secondary)}.difficulty-buttons{display:flex;align-items:center;gap:.25rem;flex-wrap:nowrap}.selection-header-actions{display:flex;align-items:center;gap:1rem;flex-shrink:0;justify-content:flex-end}.edit-mode-toggle{flex-shrink:0}.btn-icon{width:36px;height:36px;border-radius:8px;border:none;background:#fffc;color:#4b5563;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;flex-shrink:0;box-shadow:0 1px 3px #0000001a}html.dark-theme .btn-icon{background:#1e2139cc;color:#d1d5db;box-shadow:0 1px 3px #0000004d}.btn-icon:hover{background:#fff;transform:translateY(-1px);box-shadow:0 2px 6px #00000026}html.dark-theme .btn-icon:hover{background:#1e2139;box-shadow:0 2px 6px #0006}.btn-icon:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.btn-icon svg{width:20px;height:20px;display:block;flex-shrink:0}.btn-icon-create-list{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 6px #3b82f64d}html.dark-theme .btn-icon-create-list{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.btn-icon-create-list:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f666}html.dark-theme .btn-icon-create-list:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af)}.btn-icon-add-custom{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 6px #10b9814d}html.dark-theme .btn-icon-add-custom{background:linear-gradient(135deg,#059669,#047857)}.btn-icon-add-custom:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166}html.dark-theme .btn-icon-add-custom:hover{background:linear-gradient(135deg,#047857,#065f46)}.btn-icon-edit-mode{background:#fffc;color:#6b7280;box-shadow:0 1px 3px #0000001a}html.dark-theme .btn-icon-edit-mode{background:#1e2139cc;color:#9ca3af}.btn-icon-edit-mode:hover{background:#fff;color:#4b5563}html.dark-theme .btn-icon-edit-mode:hover{background:#1e2139;color:#d1d5db}.btn-icon-edit-mode.active{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 6px #f59e0b4d}html.dark-theme .btn-icon-edit-mode.active{background:linear-gradient(135deg,#d97706,#b45309)}.btn-icon-edit-mode.active:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #f59e0b66}html.dark-theme .btn-icon-edit-mode.active:hover{background:linear-gradient(135deg,#b45309,#92400e)}.content-search-container{margin-bottom:1rem;flex-shrink:0;display:flex;flex-direction:column;gap:.75rem}.content-search-row{display:flex;flex-direction:row;align-items:center;gap:.75rem;flex-wrap:wrap}.content-search-row .selection-header-actions{margin-left:auto;display:flex;align-items:center;gap:1rem;flex-shrink:0}.content-search-wrapper{position:relative;display:flex;align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:.5rem .75rem;transition:all .2s;flex:1;min-width:200px}html.dark-theme .content-search-wrapper{background:var(--color-bg-accent);border:2px solid var(--color-border)}.content-search-wrapper:focus-within{border-color:#2563eb;background:#fff;box-shadow:0 0 0 3px #2563eb1a}html.dark-theme .content-search-wrapper:focus-within{border-color:var(--color-primary);background:var(--color-bg-secondary);box-shadow:0 0 0 3px #ff8e8e33}.content-search-icon{margin-right:.5rem;color:#6b7280;flex-shrink:0;display:flex;align-items:center;justify-content:center}html.dark-theme .content-search-icon{color:var(--color-text-secondary)}.content-search-icon svg{width:20px;height:20px}.content-search-input{flex:1;border:none;background:transparent;font-size:1rem;color:#1f2937;outline:none;padding:.25rem 0}html.dark-theme .content-search-input{color:var(--color-text)}html.dark-theme .content-search-input::placeholder{color:var(--color-text-light)}.content-search-input::placeholder{color:#9ca3af}.content-search-clear{background:none;border:none;color:#6b7280;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;flex-shrink:0;margin-left:.5rem}html.dark-theme .content-search-clear{color:var(--color-text-secondary)}.content-search-clear:hover{background:#e5e7eb;color:#374151}html.dark-theme .content-search-clear:hover{background:var(--color-bg-warm);color:var(--color-text)}.content-search-results{margin-top:.5rem;font-size:.875rem;color:#6b7280;text-align:left}html.dark-theme .content-search-results{color:var(--color-text-secondary)}.content-list-controls{display:flex;gap:.5rem;justify-content:flex-end;flex-shrink:0;align-items:center}.content-list-controls .btn-compact{padding:.5rem 1rem;font-size:.875rem;min-height:2rem}.content-list-controls .btn-icon{width:32px;height:32px}.content-list-controls .btn-icon svg{width:18px;height:18px}.btn-icon-expand{background:#3b82f61a;color:#3b82f6}html.dark-theme .btn-icon-expand{background:#3b82f626;color:#60a5fa}.btn-icon-expand:hover{background:#3b82f633;color:#2563eb}html.dark-theme .btn-icon-expand:hover{background:#3b82f640;color:#93c5fd}.btn-icon-collapse{background:#6b72801a;color:#6b7280}html.dark-theme .btn-icon-collapse{background:#6b728026;color:#9ca3af}.btn-icon-collapse:hover{background:#6b728033;color:#4b5563}html.dark-theme .btn-icon-collapse:hover{background:#6b728040;color:#d1d5db}.content-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1.5rem;text-align:center;background:linear-gradient(135deg,#ffe66d1a,#ffcccb1a);border:2px dashed rgba(255,107,107,.3);border-radius:16px;margin:0;min-height:120px;width:100%;transition:all .3s ease}.content-group-items .content-list-empty{width:100%;min-height:150px;flex:1}.content-list-empty:hover{border-color:#ff6b6b80;background:linear-gradient(135deg,#ffe66d26,#ffcccb26)}html.dark-theme .content-list-empty{background:linear-gradient(135deg,#ff8e8e1a,#ffb3b314);border-color:#ff8e8e4d;color:var(--color-text-secondary)}html.dark-theme .content-list-empty:hover{border-color:#ff8e8e80;background:linear-gradient(135deg,#ff8e8e26,#ffb3b31f)}.content-list-empty-icon{margin-bottom:1rem;opacity:.6;display:flex;align-items:center;justify-content:center;color:#ff6b6b;transition:all .3s ease}.content-list-empty:hover .content-list-empty-icon{opacity:.8;transform:scale(1.05)}html.dark-theme .content-list-empty-icon{color:var(--color-primary)}.content-list-empty-icon svg{width:56px;height:56px;filter:drop-shadow(0 2px 4px rgba(255,107,107,.2))}html.dark-theme .content-list-empty-icon svg{filter:drop-shadow(0 2px 4px rgba(255,142,142,.3))}.content-list-empty-text{font-size:1rem;margin:0;color:#6b7280;font-weight:500;line-height:1.5;display:flex;align-items:center;justify-content:center;text-align:center}html.dark-theme .content-list-empty-text{color:var(--color-text)}.content-list-empty-clear{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff;border:none;border-radius:12px;padding:.625rem 1.25rem;font-size:.9rem;cursor:pointer;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);font-weight:600;box-shadow:0 2px 8px #ff6b6b4d}.content-list-empty-clear:hover{background:linear-gradient(135deg,#ff5252,#ff6b6b);transform:translateY(-2px) scale(1.02);box-shadow:0 4px 12px #ff6b6b66}.content-list-empty-clear:active{transform:translateY(0) scale(.98)}.edit-mode-switch{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.edit-mode-switch input{display:none}.edit-mode-slider{position:relative;width:44px;height:24px;background-color:#cbd5e1;border-radius:12px;transition:background-color .3s}.edit-mode-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background-color:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 2px 4px #0003}.edit-mode-switch input:checked+.edit-mode-slider{background-color:#3b82f6}.edit-mode-switch input:checked+.edit-mode-slider:before{transform:translate(20px)}.edit-mode-label{font-size:.9rem;color:#4b5563;font-weight:500}html.dark-theme .edit-mode-label{color:var(--color-text-secondary)}.edit-mode-switch:hover .edit-mode-label{color:#1f2937}html.dark-theme .edit-mode-switch:hover .edit-mode-label{color:var(--color-text)}@media(min-width:768px)and (max-width:1024px){.selection-header{grid-template-columns:1fr;gap:1rem}.selection-header-left{justify-self:start}.selection-header-right{justify-self:stretch;align-items:stretch}.selection-header-settings{align-items:center}.selection-header-actions{justify-content:center}.edit-mode-toggle{align-self:flex-end}.btn-icon{width:32px;height:32px}.btn-icon svg{width:18px;height:18px}}.content-characters{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:center}.char-badge{background:#f3f4f6;padding:.25rem .5rem;border-radius:4px;font-size:.875rem;color:#6b7280}html.dark-theme .char-badge{background:var(--color-bg-accent);color:var(--color-text-secondary)}.content-item-selected .char-badge{background:#dbeafe;color:#2563eb}html.dark-theme .content-item-selected .char-badge{background:#ff8e8e40;color:var(--color-primary)}.selection-actions{margin-top:1rem;flex-shrink:0}.btn-large{padding:1.25rem 3rem;font-size:1.5rem;min-height:3.5rem;font-weight:700}@media(min-width:768px)and (max-width:1024px){.writing-practice-selection-main{padding:1rem 1.5rem;align-items:stretch}.selection-content{padding:1rem;align-self:stretch}.selection-content h2{font-size:1.5rem;margin-bottom:.5rem}.selection-content p{font-size:.95rem;margin-bottom:.75rem}.content-list{margin:.75rem 0;flex:1 1 0;min-height:0;max-height:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y}.content-group-items{overflow-x:visible;overflow-y:visible}.content-item{min-height:80px;padding:.75rem;height:auto;width:auto;min-width:fit-content;flex-shrink:0;overflow:visible}.content-display{font-size:1.5rem}.selection-actions{margin-top:1rem}}@media(max-width:767px){.writing-practice-selection-main{padding:0}.writing-practice-selection .writing-practice-header{padding:.5rem .75rem}.writing-practice-selection .header-content{gap:.5rem;grid-template-columns:min-content 1fr;justify-items:start}.writing-practice-selection .header-left{grid-column:1;justify-self:start;align-self:center;flex-shrink:0;width:auto;overflow:visible}.writing-practice-selection .status-message{grid-column:2;justify-self:center;align-self:center}.selection-content{padding:1.5rem 1rem}.selection-content h2{font-size:1.5rem}.selection-content p{font-size:1rem}.selection-header{grid-template-columns:1fr;gap:1rem}.selection-header-left{justify-self:start}.selection-header-right{justify-self:stretch;align-items:stretch}.selection-header-settings{align-items:center;padding:.75rem;gap:.5rem}.selection-header-settings-title{font-size:.7rem}.selection-header-settings-controls{gap:.5rem}.settings-row-first,.settings-row-second{flex-wrap:wrap;justify-content:center}.selection-header-settings>.script-toggle-buttons,.selection-header-settings>.settings-buttons{flex-wrap:wrap;justify-content:center}.selection-header-settings .btn-compact{padding:.3rem .5rem;font-size:.75rem;min-height:1.75rem}.selection-header-actions{justify-self:end;justify-content:flex-end}.content-search-container{margin-bottom:1rem;gap:.5rem}.content-search-row{gap:.5rem;flex-wrap:wrap}.content-search-row .selection-header-actions{margin-left:0;width:100%;justify-content:flex-end;margin-top:.5rem}.content-search-wrapper{padding:.35rem .5rem;flex:1;min-width:0}.content-list-controls{flex-shrink:0}.content-list-controls .btn-compact{padding:.4rem .75rem;font-size:.8rem}.content-list-controls .btn-icon{width:28px;height:28px}.content-list-controls .btn-icon svg{width:16px;height:16px}.content-group-items{gap:.5rem;overflow-x:visible;overflow-y:visible}.content-item{padding:.65rem .5rem;min-height:70px;height:auto;width:auto;min-width:fit-content;flex-shrink:0;overflow:visible;border-width:2px;border-radius:16px;gap:.35rem}.content-display{font-size:1.25rem;word-wrap:break-word;word-break:break-word;overflow-wrap:break-word;width:100%;gap:.25rem}.content-pinyin{font-size:.75rem;margin-bottom:.15rem}.content-item:has(.content-action-buttons){padding:.75rem .6rem}.content-item-selected{border-width:3px;transform:none}.content-item-selected:hover,.content-item-selected:active{transform:none}.content-group{gap:.3rem}.content-list{gap:.75rem}.content-group-header-clickable{padding:.4rem .7rem;margin-bottom:.4rem;border-width:2px;border-radius:18px;font-size:.9rem;gap:.35rem}.content-group-header-clickable:hover{transform:none}.content-group-title{font-size:.95rem;gap:.35rem}.content-group-count{font-size:.7rem}.content-group-categories{padding-left:.5rem;margin-left:.25rem;gap:.5rem}.content-category-header-clickable{padding:.375rem .75rem;margin-bottom:.375rem}.content-group-items{padding-left:.375rem}.btn-large{padding:.875rem 2rem;font-size:1.1rem;width:100%}}.math-selection-container{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#dbeafe);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif}.math-selection-header{text-align:center;margin-bottom:3rem}.math-selection-title{font-size:2.5rem;font-weight:700;color:#4f46e5;margin-bottom:.5rem}.math-selection-subtitle{font-size:1.125rem;color:#6b7280}.math-selection-options{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:28rem;margin-bottom:2rem}.math-selection-card{background:#fff;border-radius:1.5rem;padding:2rem;border:none;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;align-items:center;text-align:center;touch-action:manipulation}.math-selection-card:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.math-selection-card:active{transform:translateY(-2px)}.math-selection-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;border-radius:50%;background:#eef2ff}.math-selection-game .math-selection-icon{color:#6366f1}.math-selection-learning .math-selection-icon{color:#10b981}.math-selection-card-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.math-selection-card-description{font-size:1rem;color:#6b7280}.math-selection-back{background:none;border:none;color:#9ca3af;font-size:1rem;cursor:pointer;padding:.75rem 1.5rem;border-radius:.5rem;transition:color .2s;touch-action:manipulation}.math-selection-back:hover{color:#4f46e5}.math-game-selection-container{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#dbeafe);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif}.math-game-selection-header{text-align:center;margin-bottom:3rem}.math-game-selection-title{font-size:2.5rem;font-weight:700;color:#4f46e5;margin-bottom:.5rem}.math-game-selection-subtitle{font-size:1.125rem;color:#6b7280}.math-game-selection-options{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:28rem;margin-bottom:2rem}.math-game-selection-card{background:#fff;border-radius:1.5rem;padding:2rem;border:none;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;align-items:center;text-align:center;touch-action:manipulation}.math-game-selection-card:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.math-game-selection-card:active{transform:translateY(-2px)}.math-game-selection-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;border-radius:50%;background:#eef2ff}.math-game-selection-icon-svg{width:48px;height:48px}.math-game-selection-challenge .math-game-selection-icon{color:#6366f1}.math-game-selection-apple .math-game-selection-icon{color:#ef4444}.math-game-selection-multiplication .math-game-selection-icon{color:#10b981}.math-game-selection-card-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.math-game-selection-card-description{font-size:1rem;color:#6b7280}.math-game-selection-back{background:none;border:none;color:#9ca3af;font-size:1rem;cursor:pointer;padding:.75rem 1.5rem;border-radius:.5rem;transition:color .2s;touch-action:manipulation}.math-game-selection-back:hover{color:#4f46e5}.math-game-container{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#dbeafe);display:flex;align-items:center;justify-content:center;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif}.math-game-wrapper{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;height:100%;min-height:100dvh;position:relative;display:flex;flex-direction:column;overflow:hidden}@media(min-width:768px){.math-game-wrapper{min-height:0;height:auto;max-width:28rem;border-radius:1.5rem;box-shadow:0 25px 50px -12px #00000040}}.math-game-gradient-bar{position:absolute;top:0;left:0;width:100%;height:8px;background:linear-gradient(to right,#60a5fa,#6366f1,#a855f7)}.math-menu-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:28rem;margin:0 auto;gap:1.5rem;padding:1rem}.math-menu-header{text-align:center;display:flex;flex-direction:column;gap:.5rem}.math-menu-title{font-size:2.25rem;font-weight:700;color:#4f46e5;display:flex;align-items:center;justify-content:center;gap:.5rem}.math-menu-icon{width:2.5rem;height:2.5rem}.math-menu-subtitle{color:#6b7280}.math-difficulty-selector{width:100%;background:#fff;padding:1rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;border:2px solid #e0e7ff}.math-difficulty-label{text-align:center;font-weight:700;color:#374151;margin-bottom:.75rem}.math-difficulty-buttons{display:flex;justify-content:space-between;gap:.5rem}.math-difficulty-btn{flex:1;padding:.5rem;border-radius:.75rem;font-size:.875rem;font-weight:700;transition:all .2s;border:none;background:#f3f4f6;color:#6b7280;cursor:pointer;touch-action:manipulation}.math-difficulty-btn:hover{background:#e5e7eb}.math-difficulty-btn-active{background:#4f46e5;color:#fff;box-shadow:0 4px 6px #0000001a;transform:scale(1.05)}.math-difficulty-btn-active:hover{background:#4338ca;color:#fff}.math-operation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;width:100%}.math-operation-btn{padding:1.5rem;border-radius:1rem;font-size:1.25rem;font-weight:700;transition:transform .2s;box-shadow:0 1px 3px #0000001a;border:none;cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none}.math-operation-btn:active{transform:scale(.95)}.math-op-blue{background:#dbeafe;color:#1e40af}.math-op-red{background:#fee2e2;color:#991b1b}.math-op-green{background:#d1fae5;color:#065f46}.math-op-orange{background:#fed7aa;color:#9a3412}.math-op-purple{background:#e9d5ff;color:#6b21a8}.math-op-wide{grid-column:span 2}.math-high-score{display:flex;align-items:center;gap:.5rem;color:#d97706;font-weight:700;background:#fef3c7;padding:.5rem 1rem;border-radius:9999px}.math-high-score-icon{width:1.25rem;height:1.25rem}.math-game-screen{display:flex;flex-direction:column;align-items:center;width:100%;max-width:28rem;margin:0 auto;height:100%;justify-content:space-between;padding:1.5rem 1rem}.math-game-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.math-score-display{display:flex;align-items:center;gap:.5rem;background:#eef2ff;padding:.375rem .75rem;border-radius:9999px;color:#4338ca;font-weight:700}.math-score-icon{width:1.25rem;height:1.25rem;fill:currentColor}.math-timer{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;font-weight:700;background:#f3f4f6;color:#374151;position:relative}.math-timer-warning{background:#fee2e2;color:#991b1b;animation:pulse 1s infinite}.math-timer-time-added{color:#22c55e!important;background:#dcfce7!important;transition:color .3s ease,background .3s ease}.math-timer-icon{width:1.25rem;height:1.25rem}.math-time-change{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:900;pointer-events:none;z-index:100;animation:timeChangeFloat 1.5s ease-out forwards;text-shadow:0 2px 4px rgba(0,0,0,.2)}.math-time-change-positive{color:#22c55e}.math-time-change-negative{color:#ef4444}@keyframes timeChangeFloat{0%{opacity:1;transform:translate(-50%,-50%) scale(.8) translateY(0)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2) translateY(-20px)}to{opacity:0;transform:translate(-50%,-50%) scale(.8) translateY(-40px)}}.math-streak-container{height:2rem;margin-bottom:.5rem}.math-streak{color:#ea580c;font-weight:700;animation:bounce 1s infinite;display:flex;align-items:center;justify-content:center;gap:.25rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.math-question-container{flex:1;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;margin-bottom:2rem;position:relative}.math-question{font-size:3.75rem;font-weight:900;color:#1f2937;display:flex;align-items:center;gap:1rem;padding:2rem;background:#fff;border-radius:1.5rem;box-shadow:0 10px 15px #0000001a;border:4px solid #e0e7ff;width:100%;justify-content:center;transition:all .3s}.math-question-correct{border-color:#4ade80;background:#f0fdf4;transform:scale(1.05)}.math-question-wrong{border-color:#f87171;background:#fef2f2;animation:shake .3s ease-in-out}.math-operator{color:#4f46e5}.math-question-mark{color:#9ca3af}.math-correct-answer{color:#22c55e;font-weight:900;animation:correctAnswerPulse 1s infinite}@keyframes correctAnswerPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.9}}.math-feedback-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.math-feedback-icon{width:8rem;height:8rem;opacity:.8;border:none!important;outline:none!important;box-shadow:none!important;background:transparent!important}.math-feedback-icon svg{border:none!important;outline:none!important;box-shadow:none!important;stroke:currentColor;fill:none;background:transparent!important;display:block}.math-feedback-icon circle,.math-feedback-icon path,.math-feedback-icon line,.math-feedback-icon *{border:none!important;outline:none!important;box-shadow:none!important}.math-feedback-correct{color:#22c55e;animation:ping 1s infinite}.math-feedback-wrong{color:#ef4444;animation:pulse 1s infinite}.math-feedback-wrong circle{display:none}@keyframes ping{0%{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:.4}to{transform:scale(1);opacity:.8}}.math-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;width:100%}.math-option-btn{font-size:1.875rem;font-weight:700;padding:1.5rem;border-radius:1rem;transition:all .1s;border:none;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;background:#fff;color:#4f46e5;box-shadow:0 6px #c7d2fe;transform:translateY(0)}.math-option-btn:active:not(:disabled){box-shadow:0 0 #c7d2fe;transform:translateY(6px)}.math-option-btn:disabled{cursor:not-allowed}.math-option-correct{background:#22c55e;color:#fff;transform:translateY(4px);box-shadow:none;animation:correctAnswerPulse 1s infinite}.math-option-wrong{background:#ef4444;color:#fff;transform:translateY(4px);box-shadow:none}.math-option-disabled{background:#f9fafb;color:#d1d5db;box-shadow:none;border:1px solid #f3f4f6}.math-exit-btn{margin-top:1.5rem;color:#9ca3af;font-size:.875rem;background:none;border:none;cursor:pointer;touch-action:manipulation}.math-exit-btn:hover{color:#4b5563}.math-menu-back{margin-top:1.5rem;color:#9ca3af;font-size:1rem;background:none;border:none;cursor:pointer;padding:.75rem 1.5rem;border-radius:.5rem;transition:color .2s;touch-action:manipulation}.math-menu-back:hover{color:#4f46e5}.math-gameover-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:28rem;margin:0 auto;gap:1.5rem;padding:1.5rem;text-align:center;height:100%}.math-gameover-header{display:flex;flex-direction:column;gap:.5rem;animation:bounce 1s infinite}.math-gameover-title{color:#6b7280;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.math-grade-card{width:100%;padding:1.5rem;border-radius:1.5rem;border:4px solid white;box-shadow:0 10px 15px #0000001a;position:relative;overflow:hidden}.math-grade-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:#ffffff80}.math-grade-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;gap:.5rem}.math-grade-icon-wrapper{background:#fff;padding:.75rem;border-radius:9999px;box-shadow:0 1px 3px #0000001a;margin-bottom:.5rem}.math-grade-icon{width:2rem;height:2rem}.math-grade-label{color:#4b5563;font-weight:700}.math-grade-rank{font-size:5rem;font-weight:900;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.math-grade-title{font-size:1.25rem;font-weight:700;background:#fff9;padding:.25rem 1rem;border-radius:9999px}.math-grade-bg-icon{position:absolute;bottom:-1rem;right:-1rem;width:8rem;height:8rem;opacity:.1;transform:rotate(12deg)}.text-purple-600{color:#9333ea}.text-red-500{color:#ef4444}.text-blue-500{color:#3b82f6}.text-green-500{color:#22c55e}.text-gray-500{color:#6b7280}.bg-purple-100{background:#f3e8ff}.bg-red-100{background:#fee2e2}.bg-blue-100{background:#dbeafe}.bg-green-100{background:#dcfce7}.bg-gray-100{background:#f3f4f6}.math-score-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;width:100%}.math-score-card{background:#fff;padding:1rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e0e7ff}.math-score-label{font-size:.75rem;color:#9ca3af;font-weight:700;text-transform:uppercase}.math-score-value{font-size:1.875rem;font-weight:900;color:#4f46e5}.math-score-value-high{font-size:1.875rem;font-weight:900;color:#eab308}.math-play-again-btn{width:100%;background:#4f46e5;color:#fff;font-size:1.25rem;font-weight:700;padding:1rem;border-radius:1rem;box-shadow:0 10px 15px #0000001a;border:none;cursor:pointer;transition:transform .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;touch-action:manipulation}.math-play-again-btn:hover{background:#4338ca}.math-play-again-btn:active{transform:scale(.95)}.math-play-again-icon{width:1.5rem;height:1.5rem}.math-back-menu-btn{color:#9ca3af;font-weight:500;background:none;border:none;cursor:pointer}.math-back-menu-btn:hover{color:#4f46e5}*{-webkit-tap-highlight-color:transparent}.math-rules-btn{width:100%;max-width:28rem;margin:0 auto 1rem;background:#4f46e51a;border:2px solid #4f46e5;border-radius:.75rem;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:all .2s;color:#4f46e5;font-weight:600;font-size:.875rem}.math-rules-btn:hover{background:#4f46e533;transform:translateY(-2px);box-shadow:0 4px 6px #4f46e533}.math-rules-btn:active{transform:translateY(0)}.math-rules-icon{width:1.25rem;height:1.25rem}.math-rules-btn-text{font-size:.875rem}.math-rules-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.math-rules-popup{background:#fff;border-radius:1.5rem;max-width:28rem;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;animation:popupSlideIn .3s ease-out}@keyframes popupSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.math-rules-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e5e7eb}.math-rules-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.math-rules-close{background:none;border:none;cursor:pointer;color:#6b7280;padding:.5rem;border-radius:.5rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.math-rules-close:hover{background:#f3f4f6;color:#1f2937}.math-rules-close-icon{width:1.25rem;height:1.25rem}.math-rules-content{padding:1.5rem}.math-rules-list{list-style:none;padding:0;margin:0}.math-rules-list li{padding:.75rem 0;color:#374151;font-size:1rem;line-height:1.6;border-bottom:1px solid #f3f4f6}.math-rules-list li:last-child{border-bottom:none}.math-rules-list li:before{content:"•";color:#4f46e5;font-weight:700;display:inline-block;width:1.5rem;margin-right:.5rem}.apple-math-container{min-height:100vh;background:linear-gradient(to bottom right,#fef3c7,#fde68a);display:flex;align-items:center;justify-content:center;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif}.apple-math-menu{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:28rem;margin:0 auto;gap:1.5rem;padding:2rem 1rem}.apple-math-menu-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.apple-math-menu-icon{width:4rem;height:4rem;color:#ef4444}.apple-math-menu-title{font-size:2.5rem;font-weight:700;color:#991b1b;margin:0}.apple-math-menu-subtitle{color:#92400e;font-size:1rem;margin:0}.apple-math-high-score{display:flex;align-items:center;gap:.5rem;color:#d97706;font-weight:700;background:#fef3c7;padding:.5rem 1rem;border-radius:9999px}.apple-math-high-score-icon{width:1.25rem;height:1.25rem}.apple-math-start-btn{width:100%;background:#ef4444;color:#fff;font-size:1.25rem;font-weight:700;padding:1rem;border-radius:1rem;box-shadow:0 10px 15px #0000001a;border:none;cursor:pointer;transition:transform .2s;touch-action:manipulation}.apple-math-start-btn:hover{background:#dc2626}.apple-math-start-btn:active{transform:scale(.95)}.apple-math-back-btn{color:#9ca3af;font-weight:500;background:none;border:none;cursor:pointer;padding:.75rem 1.5rem;touch-action:manipulation}.apple-math-back-btn:hover{color:#ef4444}.apple-math-game{display:flex;flex-direction:column;align-items:center;width:100%;max-width:28rem;margin:0 auto;height:100vh;justify-content:space-between;padding:1.5rem 1rem}.apple-math-game-header{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.apple-math-score{background:#fef3c7;padding:.375rem .75rem;border-radius:9999px;color:#991b1b;font-weight:700}.apple-math-timer{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;font-weight:700;background:#f3f4f6;color:#374151}.apple-math-timer-warning{background:#fee2e2;color:#991b1b;animation:pulse 1s infinite}.apple-math-timer-icon{width:1.25rem;height:1.25rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.apple-math-canvas-container{width:100%;flex:1;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:1rem;box-shadow:0 4px 6px #0000001a;padding:1rem;margin-bottom:1rem}.apple-math-canvas{width:100%;height:100%;touch-action:none;border-radius:.5rem}.apple-math-instruction{text-align:center;color:#92400e;font-weight:600;margin-bottom:1rem;font-size:.875rem}.apple-math-exit-btn{color:#9ca3af;font-size:.875rem;background:none;border:none;cursor:pointer;touch-action:manipulation}.apple-math-exit-btn:hover{color:#ef4444}.apple-math-gameover{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:28rem;margin:0 auto;gap:1.5rem;padding:2rem 1rem;text-align:center}.apple-math-gameover-header{display:flex;flex-direction:column;gap:.5rem}.apple-math-gameover-title{color:#991b1b;font-weight:700;font-size:2rem;margin:0}.apple-math-gameover-score{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;width:100%}.apple-math-gameover-score-item{background:#fff;padding:1rem;border-radius:1rem;box-shadow:0 1px 3px #0000001a;border:1px solid #fde68a}.apple-math-gameover-score-label{font-size:.75rem;color:#9ca3af;font-weight:700;text-transform:uppercase;margin:0 0 .5rem}.apple-math-gameover-score-value{font-size:1.875rem;font-weight:900;color:#ef4444;margin:0}.apple-math-gameover-score-value-high{font-size:1.875rem;font-weight:900;color:#d97706;margin:0}.apple-math-play-again-btn{width:100%;background:#ef4444;color:#fff;font-size:1.25rem;font-weight:700;padding:1rem;border-radius:1rem;box-shadow:0 10px 15px #0000001a;border:none;cursor:pointer;transition:transform .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;touch-action:manipulation}.apple-math-play-again-btn:hover{background:#dc2626}.apple-math-play-again-btn:active{transform:scale(.95)}.apple-math-play-again-icon{width:1.5rem;height:1.5rem}.apple-math-back-menu-btn{color:#9ca3af;font-weight:500;background:none;border:none;cursor:pointer;touch-action:manipulation}.apple-math-back-menu-btn:hover{color:#ef4444}.math-learning-selection-container{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#dbeafe);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif}.math-learning-selection-header{text-align:center;margin-bottom:3rem}.math-learning-selection-title{font-size:2.5rem;font-weight:700;color:#4f46e5;margin-bottom:.5rem}.math-learning-selection-subtitle{font-size:1.125rem;color:#6b7280}.math-learning-selection-options{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:28rem;margin-bottom:2rem}.math-learning-card{background:#fff;border-radius:1.5rem;padding:2rem;border:none;cursor:pointer;transition:all .3s;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;align-items:center;text-align:center;touch-action:manipulation}.math-learning-card:hover{transform:translateY(-4px);box-shadow:0 8px 12px #00000026}.math-learning-card:active{transform:translateY(-2px)}.math-learning-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;border-radius:50%;background:#f0fdf4}.math-learning-number{font-size:2.5rem;font-weight:900;color:#10b981}.math-learning-symbol{font-size:3rem;font-weight:900;color:#6366f1}.math-learning-card-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.math-learning-card-description{font-size:1rem;color:#6b7280}.math-learning-selection-back{background:none;border:none;color:#9ca3af;font-size:1rem;cursor:pointer;padding:.75rem 1.5rem;border-radius:.5rem;transition:color .2s;touch-action:manipulation}.math-learning-selection-back:hover{color:#4f46e5}.making-ten-container{min-height:100vh;background:linear-gradient(to bottom right,#eef2ff,#dbeafe);display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif}.making-ten-header{text-align:center;margin-bottom:2rem}.making-ten-title{font-size:2.5rem;font-weight:700;color:#4f46e5;margin-bottom:.5rem}.making-ten-subtitle{font-size:1.125rem;color:#6b7280}.making-ten-content{width:100%;max-width:28rem;display:flex;flex-direction:column;gap:2rem}.making-ten-selected{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 4px 6px #0000001a;min-height:120px;display:flex;align-items:center;justify-content:center}.making-ten-placeholder{text-align:center}.making-ten-placeholder-text{font-size:1.25rem;color:#9ca3af;font-weight:500}.making-ten-display{display:flex;align-items:center;justify-content:center;gap:1rem;font-size:2.5rem;font-weight:700;transition:all .3s}.making-ten-display.making-ten-correct{color:#10b981;transform:scale(1.1)}.making-ten-display.making-ten-wrong{color:#ef4444;animation:shake .3s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.making-ten-number{color:#4f46e5}.making-ten-operator{color:#6b7280}.making-ten-numbers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.making-ten-number-btn{aspect-ratio:1;border-radius:1rem;border:3px solid #e5e7eb;background:#fff;font-size:2rem;font-weight:700;color:#4f46e5;cursor:pointer;transition:all .2s;touch-action:manipulation;box-shadow:0 2px 4px #0000001a}.making-ten-number-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.making-ten-number-btn:active:not(:disabled){transform:translateY(0)}.making-ten-number-selected{background:#4f46e5;color:#fff;border-color:#4f46e5;transform:scale(1.1)}.making-ten-number-disabled{opacity:.4;cursor:not-allowed}.making-ten-feedback{text-align:center;padding:1rem;border-radius:.75rem;font-size:1.125rem;font-weight:600;animation:fadeIn .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.making-ten-feedback-correct{background:#d1fae5;color:#065f46}.making-ten-feedback-wrong{background:#fee2e2;color:#991b1b}.making-ten-back{margin-top:2rem;background:none;border:none;color:#9ca3af;font-size:1rem;cursor:pointer;padding:.75rem 1.5rem;border-radius:.5rem;transition:color .2s;touch-action:manipulation}.making-ten-back:hover{color:#4f46e5}.multiplication-table-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;font-family:Comic Sans MS,Chalkboard SE,Comic Neue,system-ui,-apple-system,sans-serif;overflow-x:hidden}.multiplication-table-header{text-align:center;margin-bottom:2rem}.multiplication-table-title{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.multiplication-table-subtitle{font-size:1.125rem;color:#fff;margin-bottom:.5rem;font-weight:600;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.multiplication-table-instruction{font-size:.875rem;color:#fff;font-style:italic;margin-top:.5rem;background:#fff3;padding:.5rem 1rem;border-radius:1rem;box-shadow:0 2px 4px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-shadow:1px 1px 2px rgba(0,0,0,.3)}.multiplication-table-selection{width:100%}.multiplication-table-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.multiplication-table-btn{aspect-ratio:1;border-radius:1rem;border:3px solid #e5e7eb;background:#fff;font-weight:700;color:#4f46e5;cursor:pointer;transition:all .2s;touch-action:manipulation;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem}.multiplication-table-btn-number{font-size:1.75rem;line-height:1}.multiplication-table-btn-arabic{font-size:.875rem;opacity:.6;line-height:1}.multiplication-table-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;border-color:#4f46e5}.multiplication-table-btn:active{transform:translateY(0)}.multiplication-table-content{width:100%;display:flex;flex-direction:column;gap:1.5rem}.multiplication-table-header-bar{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1rem 1.5rem;border-radius:1rem;box-shadow:0 2px 4px #0000001a}.multiplication-table-selected-title{font-size:1.5rem;font-weight:700;color:#1f2937}.multiplication-table-speak-all-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#4f46e5;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s;touch-action:manipulation}.multiplication-table-speak-all-btn:hover{background:#4338ca}.multiplication-table-speak-all-btn:disabled{opacity:.6;cursor:not-allowed}.multiplication-table-icon{width:1.25rem;height:1.25rem}.multiplication-table-grid-container{background:#fff;border-radius:1rem;padding:1rem;box-shadow:0 2px 4px #0000001a;max-height:70vh;overflow-y:auto}.multiplication-table-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.multiplication-table-cell{background:#f9fafb;border:2px solid #e5e7eb;border-radius:.75rem;padding:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;cursor:pointer;min-height:100px}.multiplication-table-cell:hover{background:#f3f4f6;border-color:#4f46e5;transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.multiplication-table-cell-speaking{background:#eef2ff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e533}.multiplication-table-cell-content{display:flex;flex-direction:column;align-items:center;gap:.25rem}.multiplication-table-equation{font-size:1.125rem;font-weight:600;color:#1f2937;text-align:center;line-height:1.5}.multiplication-table-equation-arabic{font-size:.875rem;font-weight:500;color:#6b7280;text-align:center;line-height:1.2}.multiplication-table-chinese,.multiplication-table-arabic{font-size:1rem;font-weight:600;color:#1f2937;text-align:center;line-height:1.4}.multiplication-table-header-cell{background:#f3f4f6;border:3px solid #d1d5db;border-radius:1rem;padding:.75rem 1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;font-weight:700;min-height:3.5rem;height:100%;box-sizing:border-box;width:100%;box-shadow:0 4px 8px #0003,inset 0 2px 4px #ffffff80;transition:all .3s ease}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(1){background:#fef3c7!important;border-color:#fbbf24}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(2){background:#dbeafe!important;border-color:#3b82f6}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(3){background:#d1fae5!important;border-color:#10b981}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(4){background:#fce7f3!important;border-color:#ec4899}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(5){background:#e9d5ff!important;border-color:#a855f7}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(6){background:#fed7aa!important;border-color:#f97316}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(7){background:#cffafe!important;border-color:#06b6d4}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(8){background:#fde68a!important;border-color:#eab308}.multiplication-table-header-row .multiplication-table-header-cell:nth-child(9){background:#e0e7ff!important;border-color:#6366f1}.multiplication-table-corner-cell{background:#e5e7eb;border-color:#9ca3af}.multiplication-table-col-header,.multiplication-table-row-header{background:#f9fafb;border-color:#e5e7eb;transition:all .2s}.multiplication-table-col-header:hover{background:#eef2ff;border-color:#4f46e5;transform:scale(1.05) rotate(1deg);box-shadow:0 6px 12px #4f46e566,inset 0 2px 4px #fff9}.multiplication-table-header-speaking{background:#eef2ff!important;border-color:#4f46e5!important;box-shadow:0 0 0 4px #4f46e566,0 6px 12px #4f46e54d,inset 0 2px 4px #fff9!important;animation:pulse 1s ease-in-out infinite;transform:scale(1.05) rotate(1deg)}.multiplication-table-header-number,.multiplication-table-header-arabic{font-size:1rem;font-weight:700;color:#4f46e5;line-height:1.4}.multiplication-table-speak-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:#eef2ff;color:#4f46e5;border:none;border-radius:50%;cursor:pointer;transition:all .2s;touch-action:manipulation}.multiplication-table-speak-btn:hover{background:#4f46e5;color:#fff}.multiplication-table-speak-btn:disabled{opacity:.4;cursor:not-allowed}.multiplication-table-icon-small{width:1.125rem;height:1.125rem}.multiplication-table-back{background:#fff;border:2px solid #4f46e5;color:#4f46e5;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;border-radius:.75rem;cursor:pointer;transition:all .2s;touch-action:manipulation}.multiplication-table-back:hover{background:#4f46e5;color:#fff}.multiplication-table-home{margin-top:1rem;background:#ffffffe6;color:#4f46e5;font-size:1rem;font-weight:600;cursor:pointer;padding:.75rem 1.5rem;border-radius:1rem;transition:all .3s ease;touch-action:manipulation;box-shadow:0 4px 8px #0003,inset 0 2px 4px #ffffff80;border:3px solid #fff}.multiplication-table-home:hover{color:#fff;background:#4f46e5;transform:translateY(-2px) scale(1.05);box-shadow:0 6px 12px #4f46e566,inset 0 2px 4px #ffffff4d}.multiplication-table-grid-container::-webkit-scrollbar{width:8px}.multiplication-table-grid-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.multiplication-table-grid-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.multiplication-table-grid-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.multiplication-table-full-grid-container{width:100%;margin-top:2rem;background:#fffffff2;border-radius:2rem;padding:1.5rem;box-shadow:0 10px 30px #0000004d,0 0 0 4px #fff,0 0 0 8px #ff6b6b4d;border:4px solid #fff;overflow-x:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.multiplication-table-full-title{text-align:center;font-size:1.5rem;font-weight:700;color:#4f46e5;margin-bottom:1rem}.multiplication-table-full-grid{display:flex;flex-direction:column;gap:.75rem}.multiplication-table-row{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));gap:.5rem;align-items:stretch;width:100%}.multiplication-table-header-row{grid-template-columns:repeat(9,minmax(0,1fr))}.multiplication-table-full-cell{background:#fff;border:3px solid #e5e7eb;border-radius:1rem;padding:.75rem 1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.68,-.55,.265,1.55);min-height:3.5rem;display:flex;align-items:center;justify-content:center;word-break:keep-all;white-space:nowrap;min-width:0;box-sizing:border-box;box-shadow:0 4px 8px #00000026,inset 0 2px 4px #ffffff80;position:relative}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell{background:#f9fafb}.multiplication-table-row:nth-child(odd) .multiplication-table-full-cell{background:#fff}.multiplication-table-row .multiplication-table-full-cell:nth-child(1){background:#fef3c7!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(2){background:#dbeafe!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(3){background:#d1fae5!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(4){background:#fce7f3!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(5){background:#e9d5ff!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(6){background:#fed7aa!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(7){background:#cffafe!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(8){background:#fde68a!important}.multiplication-table-row .multiplication-table-full-cell:nth-child(9){background:#e0e7ff!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(1){background:#fef9c3!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(2){background:#bfdbfe!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(3){background:#a7f3d0!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(4){background:#fbcfe8!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(5){background:#ddd6fe!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(6){background:#fdba74!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(7){background:#a5f3fc!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(8){background:#fde047!important}.multiplication-table-row:nth-child(2n) .multiplication-table-full-cell:nth-child(9){background:#c7d2fe!important}.multiplication-table-full-cell .multiplication-table-cell-content{display:flex;flex-direction:column;align-items:center;gap:.25rem;width:100%}.multiplication-table-full-cell:hover{background:#eef2ff;border-color:#4f46e5;transform:scale(1.08) rotate(1deg);box-shadow:0 8px 16px #4f46e54d,0 0 0 2px #4f46e533,inset 0 2px 4px #fff9;z-index:10}.multiplication-table-full-cell.multiplication-table-cell-speaking{background:#eef2ff;border-color:#4f46e5;box-shadow:0 0 0 4px #4f46e566,0 8px 16px #4f46e54d,inset 0 2px 4px #fff9;transform:scale(1.05) rotate(-1deg);animation:pulse 1s ease-in-out infinite;z-index:10}@keyframes pulse{0%,to{box-shadow:0 0 0 4px #4f46e566,0 8px 16px #4f46e54d,inset 0 2px 4px #fff9}50%{box-shadow:0 0 0 6px #4f46e599,0 10px 20px #4f46e566,inset 0 2px 4px #fff9}}.multiplication-table-full-cell:hover .multiplication-table-chinese{color:#4f46e5}@media(max-width:640px){.multiplication-table-container{padding:1rem .5rem;overflow-x:hidden}.multiplication-table-header{margin-bottom:1rem;width:100%}.multiplication-table-title{font-size:1.75rem}.multiplication-table-subtitle{font-size:1rem}.multiplication-table-instruction{font-size:.75rem;padding:.375rem .75rem;margin:.5rem .5rem 0}.multiplication-table-full-grid-container{width:100%;padding:.75rem;margin-top:1rem;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:1rem}.multiplication-table-full-grid{min-width:900px}.multiplication-table-grid{grid-template-columns:repeat(2,1fr)}.multiplication-table-cell{min-height:90px;padding:.75rem}.multiplication-table-equation{font-size:1rem}.multiplication-table-row{grid-template-columns:repeat(9,minmax(90px,1fr));gap:.25rem;min-width:900px}.multiplication-table-header-row{grid-template-columns:repeat(9,minmax(90px,1fr));min-width:900px}.multiplication-table-header-cell{min-height:2.5rem;padding:.5rem 1.5rem!important}.multiplication-table-header-cell .multiplication-table-header-number{font-size:.75rem}.multiplication-table-header-cell .multiplication-table-header-arabic{font-size:.625rem}.multiplication-table-full-cell{padding:.5rem 1.5rem!important;min-height:2.5rem}.multiplication-table-full-cell .multiplication-table-chinese{font-size:.75rem;line-height:1.2}.multiplication-table-full-cell .multiplication-table-arabic{font-size:.625rem;line-height:1.1}.multiplication-table-home{margin-top:1rem;font-size:1rem;padding:.6rem 1.5rem}}.app{min-height:100vh;display:flex;flex-direction:column}*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #4A90E2;--color-primary-dark: #357ABD;--color-success: #52C41A;--color-error: #FF4D4F;--color-warning: #FAAD14;--color-text: #262626;--color-text-secondary: #8C8C8C;--color-bg: #FFFFFF;--color-bg-secondary: #F5F5F5;--color-border: #D9D9D9;--font-size-large: 24px;--font-size-medium: 18px;--font-size-normal: 16px;--font-size-small: 14px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--ipad-spacing-md: 20px;--ipad-spacing-lg: 32px;--ipad-spacing-xl: 48px;--border-radius: 8px;--touch-target-min: 44px;--touch-target-ideal: 48px;--color-primary-light: #6BB3FF;--color-accent: #FFE66D;--color-bg-accent: #F0F0F0;--color-bg-warm: #FFF9E6;--color-text-light: #BFBFBF;--color-border-light: #E0E0E0;--color-success-dark: #389E0D}html.dark-theme{--color-primary: #FF8E8E;--color-primary-light: #FFB3B3;--color-primary-dark: #FF6B6B;--color-secondary: #6ECDC4;--color-accent: #FFE66D;--color-success: #7FE1D3;--color-success-dark: #5BC4B8;--color-error: #FF6D6F;--color-warning: #F38181;--color-text: #F0F0F0;--color-text-secondary: #C8C8C8;--color-text-light: #9A9A9A;--color-bg: #1E2139;--color-bg-secondary: #2A2D47;--color-bg-accent: #252840;--color-bg-warm: #2E3149;--color-border: #5A5D7A;--color-border-light: #4A4D6A}html{height:100%;height:-webkit-fill-available;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:var(--font-size-normal);color:var(--color-text);background-color:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-overflow-scrolling:touch;min-height:100%;min-height:-webkit-fill-available;min-height:100dvh;overflow-y:auto;position:relative;margin:0;padding:0}#root{min-height:100%;min-height:-webkit-fill-available;min-height:100dvh;display:flex;flex-direction:column;width:100%}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;border-radius:var(--border-radius);transition:all .2s ease}button:disabled{opacity:.6;cursor:not-allowed}.btn{padding:var(--spacing-md) var(--spacing-lg);font-weight:500;min-height:var(--touch-target-ideal);display:inline-flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text);border:2px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}input{font-family:inherit;font-size:inherit}
