body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--layout-max-width:800px;--layout-gutter:var(--spacing-sm);--header-height:120px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-family-code:"source-code-pro",Menlo,Monaco,Consolas,"Courier New",monospace;--font-size-body:1rem;--font-size-card-title:1.2rem;--font-size-card-title-large:1.4rem;--font-size-card-title-small:1.1rem;--font-size-nav:0.9375rem;--font-size-small:0.75rem;--font-size-sm:0.875rem;--font-size-h3:1.125rem;--font-size-lg:1.125rem;--font-size-display:1.8rem;--font-weight-bold:700;--line-height-body:1.6;--line-height-heading:1.2;--color-text:#1a1a1a;--color-text-muted:#6b7280;--color-text-light:#9ca3af;--color-border:#e5e7eb;--color-background:#fff;--color-background-secondary:#f9fafb;--color-accent:#3b82f6;--color-accent-hover:#2563eb;--color-accent-light:#dbeafe;--color-accent-dark:#1e40af;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--home-gap-after-search:var(--spacing-lg);--home-section-gap-min:var(--spacing-md);--home-section-gap-max:var(--spacing-2xl)}.dark{--color-text:#fff;--color-text-muted:#d1d5db;--color-text-light:#9ca3af;--color-border:#4b5563;--color-background:#0a0a0a;--color-background-secondary:#18181b;--color-accent:#60a5fa;--color-accent-hover:#3b82f6;--color-accent-light:#1e3a5f;--color-accent-dark:#93c5fd}body,html{background:#fff;background:var(--color-background);transition:background-color .2s ease}html{scrollbar-gutter:stable}*{transition:color .2s ease,background-color .2s ease,border-color .2s ease,box-shadow .2s ease}.app{background:#0000;color:#1a1a1a;color:var(--color-text);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);font-size:1rem;font-size:var(--font-size-body);line-height:1.6;line-height:var(--line-height-body);margin-inline:auto;min-height:100dvh;padding:0}.app,.header-container{max-width:800px;max-width:var(--layout-max-width);width:min(100% - 2 * .5rem,800px);width:min(100% - 2 * var(--layout-gutter),var(--layout-max-width))}.header-container{background:#fff;background:var(--color-background);box-shadow:0 0 8px 0 #fff,0 0 16px 0 #fff;box-shadow:0 0 8px 0 var(--color-background),0 0 16px 0 var(--color-background);left:50%;padding:.5rem;padding:var(--spacing-sm) var(--spacing-sm);padding-left:calc(.5rem + env(safe-area-inset-left, 0px));padding-left:calc(var(--spacing-sm) + env(safe-area-inset-left, 0px));padding-right:calc(.5rem + env(safe-area-inset-right, 0px));padding-right:calc(var(--spacing-sm) + env(safe-area-inset-right, 0px));padding-top:calc(.5rem + env(safe-area-inset-top, 0px));position:fixed;top:0;transform:translateX(-50%);z-index:1000}.header-bar{align-items:center;display:flex;gap:.5rem;min-height:3.25rem;width:100%}.header-bar-actions{align-items:center;display:flex;flex-shrink:0}.header,.header-brand{align-items:center;display:flex;flex:0 1 auto;margin:0;min-width:0;padding:0;width:auto}.header-title-row{align-items:center;display:flex;flex-wrap:nowrap;gap:1rem;gap:var(--spacing-md)}.header h1{color:#1a1a1a;color:var(--color-text);font-size:clamp(1.35rem,3vw + .5rem,2rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:0;white-space:nowrap}.header-copyright{align-items:center;color:#6b7280;color:var(--color-text-muted);display:inline-flex;font-size:.75rem;font-weight:400;letter-spacing:.01em;line-height:1.1;white-space:nowrap}.header-tagline,.header-text p{color:#6b7280;color:var(--color-text-muted);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;line-height:1.35;margin:0}.header-link{align-items:center;color:#1a1a1a;color:var(--color-text);display:flex;flex:0 1 auto;gap:.5rem;gap:var(--spacing-sm);margin-left:0;min-width:0}.header-link,.header-link:hover{text-decoration:none!important}.header-logo{align-items:center;display:flex;position:relative}.header-text{align-items:flex-start;display:flex;flex-direction:column;gap:0;justify-content:center;min-width:0}.nav-breadcrumb{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);box-shadow:0 2px 4px #0000000d;margin-top:.5rem;margin-top:var(--spacing-sm);min-height:40px;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg)}.nav-breadcrumb,.third-area .breadcrumb{align-items:center;display:flex;justify-content:flex-start}.third-area .breadcrumb{background:none!important;border:none!important;box-shadow:none!important;margin:0 0 -4rem;margin:0 0 calc(var(--spacing-xl)*-2) 0;min-height:auto;padding:0}.third-area .breadcrumb *{border:none!important;outline:none!important}.breadcrumb-list{list-style:none;margin:0;padding:0}.breadcrumb-item,.breadcrumb-list{align-items:center;display:flex;gap:.25rem;gap:var(--spacing-xs)}.breadcrumb-link{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.875rem;line-height:1;text-decoration:none;transition:color .2s ease}.breadcrumb-link:hover{color:var(--color-primary);text-decoration:underline}.breadcrumb-current{color:#1a1a1a;color:var(--color-text);font-size:.875rem;font-weight:500}.breadcrumb-current,.breadcrumb-separator{align-items:center;display:flex;line-height:1}.breadcrumb-separator{color:var(--color-text-tertiary);flex-shrink:0}.breadcrumb-home-icon{align-items:center;display:flex;flex-shrink:0;margin-right:.25rem;margin-right:var(--spacing-xs)}.breadcrumb-compact{font-size:.8rem;min-height:32px;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}.breadcrumb-hidden{display:none}.navigation{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.third-area{align-items:flex-start;display:flex;flex-direction:column;margin-top:.25rem;margin-top:var(--spacing-xs);min-height:1.5rem;transition:none}.third-area-return-button{align-items:center;background:none;border:none;color:#1a1a1a;color:var(--color-text);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--font-size-body);font-weight:500;gap:.25rem;gap:var(--spacing-xs);height:auto;line-height:1.4;min-height:24px;padding:.5rem 0;padding:var(--spacing-sm) 0;transition:all .2s ease;white-space:nowrap}.third-area-return-button:hover{color:#3b82f6;color:var(--color-accent);transform:translateX(-2px)}.third-area-return-button:focus{box-shadow:0 0 0 3px #3b82f61a;outline:none}.third-area-return-button:focus:not(:focus-visible){box-shadow:none}.third-area-hidden{display:none}.nav-back-button{align-items:center;background:none;border:none;color:#1a1a1a;color:var(--color-text);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--font-size-body);font-weight:500;gap:.25rem;gap:var(--spacing-xs);height:auto;line-height:1.4;min-height:24px;padding:.5rem 0;padding:var(--spacing-sm) 0;transition:all .2s ease;white-space:nowrap}.nav-back-button:hover{color:#3b82f6;color:var(--color-accent);transform:translateX(-2px)}.nav-back-button:focus{box-shadow:0 0 0 3px #3b82f61a;outline:none}.nav-back-button:focus:not(:focus-visible){box-shadow:none}.header-logo-img{height:2.85rem;object-fit:contain;width:auto}.header-bar .dark-mode-toggle{height:2.9rem;min-height:2.9rem;min-width:2.9rem;padding:.25rem;padding:var(--spacing-xs);width:2.9rem}.navigation{align-items:center;display:flex;flex:1 1 auto;margin:0;min-width:0;padding:0}.nav-top{display:flex;flex-wrap:nowrap;gap:1rem;gap:var(--spacing-md)}.nav-links{display:flex;flex:0 0 auto;flex-wrap:nowrap;gap:.25rem;gap:var(--spacing-xs);justify-content:flex-start}.nav-search{align-items:center;display:flex;flex:1 1 10rem;margin-left:auto;max-width:15rem;min-width:0;position:relative}.nav-link{border-bottom:2px solid #0000;color:#1a1a1a;color:var(--color-text);display:flex;font-size:.8rem;font-weight:500;gap:.25rem;gap:var(--spacing-xs);padding:.25rem;padding:var(--spacing-xs);text-decoration:none;transition:all .2s ease}.nav-link.active,.nav-link:hover{border-bottom-color:#3b82f6;border-bottom-color:var(--color-accent);color:#3b82f6;color:var(--color-accent)}.nav-search-input{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);box-sizing:border-box;color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);height:2.7rem;min-width:0;padding:0 2.1rem 0 1rem;padding:0 2.1rem 0 var(--spacing-md);width:100%}.nav-search-input:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 3px #3b82f61a;outline:none}.nav-search-icon,.nav-search-input::placeholder{color:#6b7280;color:var(--color-text-muted)}.nav-search-icon{pointer-events:none;position:absolute;right:.5rem;right:var(--spacing-sm)}.search-highlight{background-color:#fff3cd;border-radius:3px;color:#856404;font-weight:600;padding:2px 4px}.dark-mode-toggle{align-items:center;background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);color:#1a1a1a;color:var(--color-text);cursor:pointer;display:flex;height:44px;justify-content:center;padding:.5rem;padding:var(--spacing-sm);transition:all .2s ease;width:44px}.dark-mode-toggle:hover{background:#f9fafb;background:var(--color-background-secondary);border-color:#3b82f6;border-color:var(--color-accent);transform:translateY(-1px)}.dark-mode-toggle:active{transform:translateY(0)}.dark-mode-toggle:focus{box-shadow:0 0 0 3px #3b82f61a;outline:none}.dark-mode-toggle:focus:not(:focus-visible){box-shadow:none}.search-results-overlay{align-items:flex-start;background:#0000;bottom:0;display:flex;justify-content:center;left:0;pointer-events:auto;position:fixed;right:0;top:0;z-index:3000}.search-active .main-content{display:none}.search-active .header-container{position:fixed;z-index:4000}.search-results-container{animation:searchResultsSlideIn .2s ease-out;background:#0000;border:none;border-radius:0;box-shadow:none;display:block;max-width:600px;overflow:visible;pointer-events:auto}.search-results-container.exiting{animation:searchResultsSlideOut .2s ease-in}@keyframes searchResultsSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes searchResultsSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}@keyframes searchResultSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.search-results-header{align-items:center;background:#0000;border-bottom:none;border-radius:0;display:flex;justify-content:space-between;padding:1rem 0 .5rem;padding:var(--spacing-md) 0 var(--spacing-sm) 0}.search-results-header h3{margin:0}.search-results-close{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;color:var(--color-text-muted);cursor:pointer;display:flex;height:32px;justify-content:center;padding:.5rem;padding:var(--spacing-sm);transition:all .2s ease;width:32px}.search-results-close:hover{background:#0000000d;color:#1a1a1a;color:var(--color-text);transform:scale(1.05)}.search-results-header h3{color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);font-weight:600;margin:0 0 .25rem;margin:0 0 var(--spacing-xs) 0}.search-results-header p{color:#6b7280;color:var(--color-text-muted);font-size:.75rem;font-size:var(--font-size-small);margin:0}.search-results-content{display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-sm);padding:0}.search-results-page{margin-bottom:1rem;margin-bottom:var(--spacing-md)}.search-results-page:last-child{margin-bottom:0}.search-results-page-title{color:#6b7280;color:var(--color-text-muted);margin:0 0 .5rem;margin:0 0 var(--spacing-sm) 0}.search-results-page-link,.search-results-page-title{font-size:.75rem;font-size:var(--font-size-small);font-weight:500}.search-results-page-link{color:#3b82f6;color:var(--color-accent);text-decoration:none}.search-results-page-link:hover{color:#1a1a1a;color:var(--color-text);text-decoration:underline}.search-results-sections{display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs)}.search-results-section{animation:searchResultSlideIn .3s ease-out forwards;background:#0000;border:none;border-left:1px solid #e5e7eb;border-left:1px solid var(--color-border);border-radius:0;display:block;margin-bottom:.25rem;margin-bottom:var(--spacing-xs);opacity:0;padding:.5rem 0 .5rem .5rem;padding:var(--spacing-sm) 0 var(--spacing-sm) var(--spacing-sm);pointer-events:auto;transform:translateY(10px);transition:all .2s ease}.search-results-section-clickable{cursor:pointer;pointer-events:auto;position:relative;transition:all .2s ease;z-index:1}.search-results-section-clickable:focus,.search-results-section-clickable:hover{background:#00000005;border-left-color:#3b82f6;border-left-color:var(--color-accent);outline:none}.search-results-section-title{color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);font-weight:600;line-height:1.4;margin:0 0 .25rem;margin:0 0 var(--spacing-xs) 0}.search-results-section-content{font-size:1rem;font-size:var(--font-size-body);line-height:1.5}.no-results,.search-results-section-content{color:#6b7280;color:var(--color-text-muted);margin:0}.no-results{font-size:.75rem;font-size:var(--font-size-small);padding:.5rem 0;padding:var(--spacing-sm) 0;text-align:center}.search-status{margin-bottom:.5rem;margin-bottom:var(--spacing-sm);text-align:left}.search-status p{color:#6b7280;color:var(--color-text-muted);font-size:.75rem;font-size:var(--font-size-small);font-weight:500;margin:0}.main-content{display:flex;flex:1 1;flex-direction:column;margin-top:120px;margin-top:var(--header-height,120px);padding:.5rem;padding:var(--spacing-sm)}html:has(.app--home):not(:has(.search-active)),html:has(.app--home):not(:has(.search-active)) body{background:#fff;background:var(--color-background);height:100%;overflow:hidden}.main-content:has(.home){box-sizing:border-box;display:flex;flex:1 1 auto;flex-direction:column;height:calc(100dvh - 120px);height:calc(100dvh - var(--header-height, 120px));justify-content:center;max-height:calc(100dvh - 120px);max-height:calc(100dvh - var(--header-height, 120px));min-height:0;overflow:hidden;padding-bottom:.25rem;padding-bottom:var(--spacing-xs);padding-top:.5rem;padding-top:var(--spacing-sm)}.task-view .main-content{margin-top:0!important;min-height:calc(100dvh - 120px);min-height:calc(100dvh - var(--header-height, 120px));padding:0 0 1.5rem!important;padding:0 0 var(--spacing-lg) 0!important;transform:none!important}.task-view,[class*=task-view],body .task-view .main-content{margin-top:0!important}.task-view .main-content>div{padding:0 0 1.5rem!important;padding:0 0 var(--spacing-lg) 0!important}.task-view .task-content{padding-top:4.1rem;padding-top:calc(3.1rem + var(--spacing-md))}.task-view .exercise-questions{padding-bottom:2rem;padding-bottom:var(--spacing-xl)}.task-view .main-content h1{color:#1a1a1a!important;color:var(--color-text)!important;font-size:1.8rem!important;font-size:var(--font-size-display)!important;font-weight:700!important;font-weight:var(--font-weight-bold)!important;line-height:1.2!important}.task-view .main-content h1,.task-view h1{margin:-5px 0 .5rem!important;margin:-5px 0 var(--spacing-sm) 0!important}.task-view .main-content p{color:#6b7280!important;color:var(--color-text-muted)!important;font-size:1rem!important;font-size:var(--font-size-body)!important;line-height:1.5!important;margin:0 0 1.5rem!important;margin:0 0 var(--spacing-lg) 0!important}.section-header{margin-bottom:1rem;margin-bottom:var(--spacing-md);padding-bottom:.25rem;padding-bottom:var(--spacing-xs)}.section-header h1{color:#1a1a1a;color:var(--color-text);font-size:1.8rem;font-size:var(--font-size-display);font-weight:600;line-height:1.2;line-height:var(--line-height-heading);margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.section-header p{color:#6b7280;color:var(--color-text-muted)}.section-nav{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.section-nav a{color:#666;font-size:.9rem;text-decoration:none}.section-nav a:hover{color:#000}.section-nav span{color:#ccc}.content-area{margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.content-area h2{color:#1a1a1a;color:var(--color-text);font-size:1.125rem;font-size:var(--font-size-h3);font-weight:600;margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.content-area p{color:#6b7280;color:var(--color-text-muted);margin-bottom:1rem}.subcategory-filter{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.subcategory-filter-header{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.subcategory-filter-controls{align-items:center;display:inline-flex;gap:.5rem;gap:var(--spacing-sm)}.view-toggle-button{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#6b7280;color:var(--color-text-muted);cursor:pointer;font-size:.8rem;font-weight:600;padding:.35rem .65rem;white-space:nowrap}.view-toggle-button:hover{border-color:#3b82f6;border-color:var(--color-accent);color:#1a1a1a;color:var(--color-text)}.view-toggle-button.active{background:color-mix(in srgb,#3b82f6 14%,#fff);background:color-mix(in srgb,var(--color-accent) 14%,var(--color-background));border-color:color-mix(in srgb,#3b82f6 45%,#e5e7eb);border-color:color-mix(in srgb,var(--color-accent) 45%,var(--color-border));color:#1a1a1a;color:var(--color-text)}.subcategory-grid{grid-gap:.25rem;grid-gap:var(--spacing-xs);display:grid;gap:.25rem;gap:var(--spacing-xs);grid-template-columns:repeat(auto-fit,minmax(9.5rem,1fr))}.subcategory-card{background:#f9fafb;background:var(--color-background-secondary);border:2px solid #0000;border-radius:6px;border-radius:var(--radius-md);box-shadow:0 0 0 1px #e5e7eb,0 8px 18px #00000014;box-shadow:0 0 0 1px var(--color-border),0 8px 18px #00000014;color:#1a1a1a;color:var(--color-text);cursor:pointer;font-size:1rem;font-size:var(--font-size-body);font-weight:500;padding:.5rem;padding:var(--spacing-sm);text-align:left;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,color .15s ease,border-color .15s ease}.subcategory-card.active{background:#3b82f6;background:var(--color-accent);border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 10px 24px #00000026;color:#fff}.subcategory-card:focus-visible{outline:3px solid color-mix(in srgb,#3b82f6 60%,#0000);outline:3px solid color-mix(in srgb,var(--color-accent) 60%,#0000);outline-offset:2px}.subcategory-card-inner{align-items:center;display:flex}.subcategory-label{font-size:1rem;font-weight:600;letter-spacing:.1px}.subcategory-count{font-size:.85rem;opacity:.7}.subcategory-card.active .subcategory-count{opacity:.9}.task-groups{min-height:60vh}.task-group-header{align-items:baseline;border-bottom:1px dashed color-mix(in srgb,#e5e7eb 85%,#0000);border-bottom:1px dashed color-mix(in srgb,var(--color-border) 85%,#0000);display:flex;gap:.5rem;gap:var(--spacing-sm);justify-content:space-between;padding-bottom:.25rem;padding-bottom:var(--spacing-xs)}.task-grid,.task-group-header{margin-top:1.5rem;margin-top:var(--spacing-lg)}.task-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.compact-view .task-grid{gap:.5rem;gap:var(--spacing-sm);grid-template-columns:1fr;margin-top:.5rem;margin-top:var(--spacing-sm)}.task-card{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);box-shadow:0 1px 0 color-mix(in srgb,#e5e7eb 80%,#0000);box-shadow:0 1px 0 color-mix(in srgb,var(--color-border) 80%,#0000);cursor:pointer;overflow:hidden;padding:1rem;padding:var(--spacing-md);position:relative;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.compact-view .task-card{padding:.7rem .8rem}.compact-view .task-card h3{font-size:1rem}.compact-view .task-description{line-height:1.45;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.compact-view .task-card-header{margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.compact-view .difficulty-badge{font-size:.68rem;padding:.2rem .45rem}.task-card:hover{border-color:color-mix(in srgb,#3b82f6 45%,#e5e7eb);border-color:color-mix(in srgb,var(--color-accent) 45%,var(--color-border));box-shadow:0 8px 20px #00000014;transform:translateY(-2px)}.task-card:focus-visible{outline:2px solid color-mix(in srgb,#3b82f6 55%,#0000);outline:2px solid color-mix(in srgb,var(--color-accent) 55%,#0000);outline-offset:2px}.task-card:before{bottom:0;content:"";left:0;opacity:.9;position:absolute;top:0;width:4px}.subcategory-card:hover{box-shadow:0 12px 24px #00000026;transform:translateY(-2px)}.subcategory-card:active{box-shadow:0 6px 12px #0000001f;transform:translateY(0)}.subcategory-card.active:hover{transform:translateY(-1px)}.task-card.completed{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#10b981}.task-card.difficulty-beginner:before{background:#22c55e}.task-card.difficulty-intermediate:before{background:#f59e0b}.task-card.difficulty-advanced:before{background:#ef4444}.task-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.task-card h3{color:#1a1a1a;color:var(--color-text);flex:1 1;font-size:1.2rem;font-size:var(--font-size-card-title);font-weight:600;margin:0}.task-badges{gap:.5rem;gap:var(--spacing-sm)}.completed-badge,.task-badges{align-items:center;display:flex}.completed-badge{background:#10b981;border-radius:50%;color:#fff;font-size:14px;font-weight:700;height:24px;justify-content:center;width:24px}.completed-text{color:#10b981;font-weight:600}.completed-text,.difficulty-badge{font-size:.75rem;font-size:var(--font-size-small)}.difficulty-badge{border-radius:4px;border-radius:var(--radius-sm);font-weight:500;letter-spacing:.5px;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);text-transform:uppercase}.difficulty-beginner{background:color-mix(in srgb,#22c55e 20%,#fff);background:color-mix(in srgb,#22c55e 20%,var(--color-background));border:1px solid color-mix(in srgb,#22c55e 35%,#0000);color:#166534}.difficulty-intermediate{background:color-mix(in srgb,#f59e0b 18%,#fff);background:color-mix(in srgb,#f59e0b 18%,var(--color-background));border:1px solid color-mix(in srgb,#f59e0b 35%,#0000);color:#92400e}.difficulty-advanced{background:color-mix(in srgb,#ef4444 16%,#fff);background:color-mix(in srgb,#ef4444 16%,var(--color-background));border:1px solid color-mix(in srgb,#ef4444 35%,#0000);color:#991b1b}.task-description{color:#6b7280;color:var(--color-text-muted);line-height:1.6;line-height:var(--line-height-body);margin:0 0 1rem;margin:0 0 var(--spacing-md) 0}.task-meta{align-items:center;border-top:none;display:flex;justify-content:space-between;margin-top:.5rem;margin-top:var(--spacing-sm);padding-top:0}.task-type{color:#9ca3af;color:var(--color-text-light);font-size:.75rem;font-size:var(--font-size-small);font-weight:500}.task-view{margin-top:.5rem;margin-top:var(--spacing-sm)}.exercise-instructions{background:none;border:none;border-radius:0;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1rem 0;padding:var(--spacing-md) 0}.exercise-instructions h3{color:#3b82f6;color:var(--color-accent);font-size:1.4rem;font-size:var(--font-size-card-title-large);margin:0 0 1rem;margin:0 0 var(--spacing-md) 0}.exercise-instructions p{line-height:1.6;line-height:var(--line-height-body);margin:0 0 .5rem;margin:0 0 var(--spacing-sm) 0}.exercise-instructions p:last-child{margin-bottom:0}.exercise-instructions strong{color:#1a1a1a;color:var(--color-text);font-weight:600}.task-header{align-items:center;background:#fff;background:var(--color-background);border-bottom:1px solid color-mix(in srgb,#e5e7eb 65%,#0000);border-bottom:1px solid color-mix(in srgb,var(--color-border) 65%,#0000);display:flex;gap:1rem;gap:var(--spacing-md);justify-content:center;left:0;margin-bottom:.5rem;margin-bottom:var(--spacing-sm);margin-left:auto;margin-right:auto;min-height:3.1rem;padding:.25rem 0;padding:var(--spacing-xs) 0;position:fixed;right:0;top:114px;width:min(100% - 2rem,960px);z-index:60}.task-header:after{background:linear-gradient(180deg,color-mix(in srgb,#fff 100%,#0000) 0,color-mix(in srgb,#fff 99%,#0000) 8%,color-mix(in srgb,#fff 96%,#0000) 18%,color-mix(in srgb,#fff 90%,#0000) 32%,color-mix(in srgb,#fff 80%,#0000) 48%,color-mix(in srgb,#fff 64%,#0000) 66%,color-mix(in srgb,#fff 42%,#0000) 82%,color-mix(in srgb,#fff 22%,#0000) 92%,#0000);background:linear-gradient(to bottom,color-mix(in srgb,var(--color-background) 100%,#0000) 0,color-mix(in srgb,var(--color-background) 99%,#0000) 8%,color-mix(in srgb,var(--color-background) 96%,#0000) 18%,color-mix(in srgb,var(--color-background) 90%,#0000) 32%,color-mix(in srgb,var(--color-background) 80%,#0000) 48%,color-mix(in srgb,var(--color-background) 64%,#0000) 66%,color-mix(in srgb,var(--color-background) 42%,#0000) 82%,color-mix(in srgb,var(--color-background) 22%,#0000) 92%,#0000 100%);content:"";height:52px;left:0;pointer-events:none;position:absolute;right:0;top:calc(100% - 6px)}.back-button{align-items:center;background:none;border:none;color:#6b7280;color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--font-size-body);font-weight:500;gap:.25rem;gap:var(--spacing-xs);margin-bottom:1rem;margin-bottom:var(--spacing-md);padding:.25rem 0;padding:var(--spacing-xs) 0;text-decoration:none;transition:all .2s ease}.back-button:hover{color:#3b82f6;color:var(--color-accent);transform:translateX(-2px)}.return-to-section-button{align-items:center;background:#fff;background:var(--color-background);border:1px solid #3b82f6;border:1px solid var(--color-accent);border-radius:6px;border-radius:var(--radius-md);color:#3b82f6;color:var(--color-accent);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--font-size-body);font-weight:500;gap:.5rem;gap:var(--spacing-sm);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);margin-top:0;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease}.return-to-section-button--header{margin:0}.return-to-section-button--header:active,.return-to-section-button--header:hover{transform:none}.return-to-section-button:hover{background:#3b82f6;background:var(--color-accent);box-shadow:0 2px 4px #3b82f633;color:#fff;transform:translateY(-1px)}.return-to-section-button:active{transform:translateY(0)}.task-header h1{color:#1a1a1a;color:var(--color-text);font-size:1.4rem;font-size:var(--font-size-card-title-large);font-weight:600;margin:0}.task-content{margin-left:auto;margin-right:auto;margin-top:0;max-width:960px;padding-top:4.1rem;padding-top:calc(3.1rem + var(--spacing-md));position:relative;width:100%;z-index:1}.task-header p{color:#6b7280;color:var(--color-text-muted);margin:0}.task-exercise{background:#fff;background:var(--color-background);border:none;border-radius:0;margin-bottom:2rem;margin-bottom:var(--spacing-xl);margin-top:0;padding:0;transition:all .2s ease;width:100%}.task-content>.coming-soon,.task-content>.drag-drop-exercise,.task-content>.matching-exercise,.task-content>.multi-select-exercise,.task-content>.ordering-exercise,.task-content>.reading-exercise,.task-content>.task-completion,.task-content>.task-exercise{margin-left:auto;margin-right:auto;max-width:900px;width:100%}.task-exercise h3{border-bottom:none;color:#1a1a1a;color:var(--color-text);font-size:1.2rem;font-size:var(--font-size-card-title);font-weight:600;margin:0 0 1rem;margin:0 0 var(--spacing-md) 0;padding-bottom:.5rem;padding-bottom:var(--spacing-sm)}.exercise-questions{align-items:stretch;display:flex;flex-direction:column;gap:1.5rem;gap:var(--spacing-lg);margin:0 auto;max-width:760px;padding-left:0;width:100%}.question{background:none;border-left:none;border-radius:0;margin-left:0;padding:1rem 0;padding:var(--spacing-md) 0;width:100%}.question p{color:#1a1a1a;color:var(--color-text);font-weight:500;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.blank-space{background:#f9fafb;background:var(--color-background-secondary);border:2px dashed #e5e7eb;border:2px dashed var(--color-border);color:#6b7280;color:var(--color-text-muted);min-width:40px;text-align:center}.blank-space,.filled-answer{border-radius:4px;border-radius:var(--radius-sm);display:inline-block;font-weight:600;margin:0 2px;padding:2px 6px}.filled-answer{animation:fillIn .5s ease-in-out;background:#10b981;box-shadow:0 2px 4px #10b9814d;color:#fff}@keyframes fillIn{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.answer-input{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);margin-top:.5rem;margin-top:var(--spacing-sm);padding:.5rem;padding:var(--spacing-sm);width:100%}.answer-input:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f61a;outline:none}.answer-input-small{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#1a1a1a;color:var(--color-text);display:inline-block;font-size:1rem;font-size:var(--font-size-body);margin-top:.5rem;margin-top:var(--spacing-sm);max-width:120px;min-width:40px;padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);text-align:center;width:auto}.answer-input-small:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f61a;outline:none}.multiple-blanks{display:flex;gap:.5rem;gap:var(--spacing-sm)}.answer-container,.multiple-blanks{align-items:center;margin-top:.5rem;margin-top:var(--spacing-sm)}.answer-container{display:inline-flex;gap:.25rem;gap:var(--spacing-xs)}.checkmark{animation:checkmarkAppear .3s ease-in-out;color:#10b981;font-size:1.2em;font-weight:700}.input-with-checkmark{align-items:center;display:flex;gap:10px}.input-with-checkmark .checkmark{flex-shrink:0;margin-right:5px}.fill-blank-container{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start;margin-left:0;position:static}.fill-blank-container .checkmark-inline{flex-shrink:0;position:static}.question-with-checkmark{align-items:flex-start;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start}.question-with-checkmark .checkmark-inline{flex-shrink:0;margin-top:2px}@keyframes checkmarkAppear{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.task-completion{animation:completionAppear .5s ease-in-out;border-radius:12px;box-shadow:0 4px 12px #0003;color:#fff;margin-bottom:2rem;margin-bottom:var(--spacing-xl);margin-top:8rem;margin-top:calc(var(--spacing-xl)*4);overflow:hidden;padding:0;text-align:center}.completion-message.perfect{background:#fff;background:var(--color-background);background-image:radial-gradient(circle at 20% 50%,#10b98108 0,#0000 50%),radial-gradient(circle at 80% 20%,#10b98108 0,#0000 50%),radial-gradient(circle at 40% 80%,#10b98105 0,#0000 50%);border:2px solid #10b981;border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #10b9811a;padding:2rem;padding:var(--spacing-xl)}.completion-message.score-0-10,.completion-message.score-1-10,.completion-message.score-2-10,.completion-message.score-3-10{background:#fff;background:var(--color-background);background-image:linear-gradient(45deg,#9ca3af05 25%,#0000 0),linear-gradient(-45deg,#9ca3af05 25%,#0000 0),linear-gradient(45deg,#0000 75%,#9ca3af05 0),linear-gradient(-45deg,#0000 75%,#9ca3af05 0);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px;border:2px solid #e5e7eb;border:2px solid var(--color-border);border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000000d;padding:2rem;padding:var(--spacing-xl)}.completion-message.score-4-10,.completion-message.score-5-10,.completion-message.score-6-10{background:#fff;background:var(--color-background);background-image:repeating-linear-gradient(45deg,#0000,#0000 10px,#f59e0b08 0,#f59e0b08 20px);border:2px solid #f59e0b;border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #f59e0b1a;padding:2rem;padding:var(--spacing-xl)}.completion-message.score-7-10,.completion-message.score-8-10,.completion-message.score-9-10{background:#fff;background:var(--color-background);background-image:radial-gradient(circle at 25% 25%,#3b82f60a 0,#0000 50%),radial-gradient(circle at 75% 75%,#3b82f60a 0,#0000 50%);border:2px solid #3b82f6;border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #3b82f61a;padding:2rem;padding:var(--spacing-xl)}.completion-message[class*=score-0-],.completion-message[class*=score-1-],.completion-message[class*=score-2-],.completion-message[class*=score-3-]{background:#fff;background:var(--color-background);background-image:linear-gradient(45deg,#9ca3af05 25%,#0000 0),linear-gradient(-45deg,#9ca3af05 25%,#0000 0),linear-gradient(45deg,#0000 75%,#9ca3af05 0),linear-gradient(-45deg,#0000 75%,#9ca3af05 0);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px;border:2px solid #e5e7eb;border:2px solid var(--color-border);border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000000d;padding:2rem;padding:var(--spacing-xl)}.completion-message[class*=score-4-],.completion-message[class*=score-5-],.completion-message[class*=score-6-]{background:#fff;background:var(--color-background);background-image:repeating-linear-gradient(45deg,#0000,#0000 10px,#f59e0b08 0,#f59e0b08 20px);border:2px solid #f59e0b;border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #f59e0b1a;padding:2rem;padding:var(--spacing-xl)}.completion-message[class*=score-10-],.completion-message[class*=score-11-],.completion-message[class*=score-12-],.completion-message[class*=score-13-],.completion-message[class*=score-14-],.completion-message[class*=score-7-],.completion-message[class*=score-8-],.completion-message[class*=score-9-]{background:#fff;background:var(--color-background);background-image:radial-gradient(circle at 25% 25%,#3b82f60a 0,#0000 50%),radial-gradient(circle at 75% 75%,#3b82f60a 0,#0000 50%);border:2px solid #3b82f6;border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #3b82f61a;padding:2rem;padding:var(--spacing-xl)}.completion-icon{font-size:3.5rem;font-weight:400;margin-bottom:1rem;margin-bottom:var(--spacing-md);opacity:.95;text-shadow:0 2px 4px #0000004d;transition:all .3s ease}.completion-message.perfect .completion-icon{color:#fbbf24;text-shadow:0 2px 8px #fbbf2466}.completion-message[class*=score-10-] .completion-icon,.completion-message[class*=score-11-] .completion-icon,.completion-message[class*=score-12-] .completion-icon,.completion-message[class*=score-13-] .completion-icon,.completion-message[class*=score-14-] .completion-icon,.completion-message[class*=score-7-] .completion-icon,.completion-message[class*=score-8-] .completion-icon,.completion-message[class*=score-9-] .completion-icon{color:#60a5fa;text-shadow:0 2px 6px #60a5fa4d}.completion-message[class*=score-4-] .completion-icon,.completion-message[class*=score-5-] .completion-icon,.completion-message[class*=score-6-] .completion-icon{color:#fbbf24;text-shadow:0 2px 6px #fbbf244d}.completion-message[class*=score-0-] .completion-icon,.completion-message[class*=score-1-] .completion-icon,.completion-message[class*=score-2-] .completion-icon,.completion-message[class*=score-3-] .completion-icon{color:#d1d5db;text-shadow:0 2px 4px #d1d5db33}@keyframes completionAppear{0%{opacity:0;transform:translateY(-20px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.completion-message h3{color:#1a1a1a;color:var(--color-text);font-size:1.4rem;font-size:var(--font-size-card-title-large);font-weight:600;margin:.5rem 0;margin:var(--spacing-sm) 0}.completion-message p{color:#6b7280;color:var(--color-text-muted);font-size:1rem;font-size:var(--font-size-body);margin:0}.completion-checkmark{animation:celebration 1s ease-in-out infinite alternate;display:block;font-size:2.5rem;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}@keyframes celebration{0%{transform:scale(1) rotate(0deg)}to{transform:scale(1.1) rotate(5deg)}}.reset-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#6b7280cc;border:2px solid #6b7280e6;border-radius:6px;border-radius:var(--radius-md);color:#fff;cursor:pointer;flex:1 1;font-size:1rem;font-size:var(--font-size-body);font-weight:500;min-width:100px;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease}.reset-button:hover{background:#6b7280;border-color:#6b7280;box-shadow:0 4px 8px #0003;transform:translateY(-1px)}.reset-button:active{transform:translateY(0)}.score-display{margin:1rem 0;margin:var(--spacing-md) 0;text-align:center}.score-text{color:#1a1a1a;color:var(--color-text);display:block;font-size:1.125rem;font-size:var(--font-size-lg);font-weight:600;margin-bottom:.25rem;margin-bottom:var(--spacing-xs)}.perfect-score{color:#10b981}.partial-score,.perfect-score{display:block;font-size:1rem;font-size:var(--font-size-body);font-weight:500}.partial-score{color:#6b7280;color:var(--color-text-muted)}.completion-buttons{display:flex;gap:1rem;gap:var(--spacing-md);justify-content:center;margin-left:auto;margin-right:auto;margin-top:1.5rem;margin-top:var(--spacing-lg);max-width:400px}.back-to-tasks-button{background:#f9fafb;background:var(--color-background-secondary);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);color:#1a1a1a;color:var(--color-text);cursor:pointer;flex:1 1;font-size:1rem;font-size:var(--font-size-body);font-weight:500;min-width:100px;padding:.5rem 1.5rem;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease}.back-to-tasks-button:hover{background:#e5e7eb;background:var(--color-border);transform:translateY(-1px)}.back-to-tasks-button:active{transform:translateY(0)}.answer-select{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);margin-top:.5rem;margin-top:var(--spacing-sm);padding:.5rem;padding:var(--spacing-sm);width:100%}.answer-select:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f61a;outline:none}.question input[type=text]{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);padding:.5rem;padding:var(--spacing-sm);width:100%}.question input[type=text]:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f61a;outline:none}.question select{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);padding:.5rem;padding:var(--spacing-sm);width:100%}.question select:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #3b82f61a;outline:none}.options{display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs)}.options label{align-items:center;border-radius:4px;border-radius:var(--radius-sm);cursor:pointer;display:flex;gap:.5rem;gap:var(--spacing-sm);padding:.25rem;padding:var(--spacing-xs)}.options label:hover{background:#fff;background:var(--color-background)}.options input[type=radio]{accent-color:#3b82f6;accent-color:var(--color-accent);-webkit-appearance:none;appearance:none;border:2px solid #e5e7eb;border:2px solid var(--color-border);border-radius:50%;cursor:pointer;flex-shrink:0;height:18px;margin:0;min-height:18px;min-width:18px;position:relative;width:18px}.options input[type=radio],.options input[type=radio]:checked{background-color:#fff;background-color:var(--color-background)}.options input[type=radio]:checked{border-color:#3b82f6;border-color:var(--color-accent)}.options input[type=radio]:checked:before{background-color:#3b82f6;background-color:var(--color-accent);border-radius:50%;content:"";height:10px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:10px}.dark .options input[type=radio]{background-color:#fff;background-color:var(--color-background);border-color:#e5e7eb;border-color:var(--color-border)}.dark .options input[type=radio]:checked{border-color:#3b82f6;border-color:var(--color-accent)}.dark .options input[type=radio]:checked:before{background-color:#3b82f6;background-color:var(--color-accent)}.task-placeholder{background:#f9fafb;background:var(--color-background-secondary);border-left:3px solid #e5e7eb;border-left:3px solid var(--color-border);border-radius:4px;margin-bottom:1rem;padding:1rem}.task-placeholder h3{color:#1a1a1a;color:var(--color-text);font-size:1rem;font-weight:600;margin-bottom:.5rem}.home{align-items:center;display:flex;flex:1 1 auto;flex-direction:column;min-height:0;overflow:hidden;padding:0;position:relative;text-align:center;width:100%}.home-backdrop{inset:0;pointer-events:none;position:fixed;z-index:0}.home-blob{animation:homeBlobFloat 14s ease-in-out infinite;border-radius:50%;filter:blur(48px);opacity:.45;position:absolute}.home-blob--1{background:color-mix(in srgb,#3b82f6 35%,#0000);background:color-mix(in srgb,var(--color-accent) 35%,#0000);height:12rem;left:-8%;top:8%;width:12rem}.home-blob--2{animation-delay:-4s;background:color-mix(in srgb,#a855f7 28%,#0000);height:10rem;right:-6%;top:42%;width:10rem}.home-blob--3{animation-delay:-8s;background:color-mix(in srgb,#22c55e 25%,#0000);bottom:18%;height:9rem;left:20%;width:9rem}@keyframes homeBlobFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(6px,-10px) scale(1.06)}}.home-hero,.home-intro,.welcome-content{position:relative;z-index:1}.home-hero,.welcome-content{align-items:center;display:flex;flex:1 1 auto;flex-direction:column;max-height:100%;min-height:0;overflow:hidden;width:100%}.home-hero{gap:clamp(1rem,2.8vh,3rem);gap:clamp(var(--home-section-gap-min),2.8vh,var(--home-section-gap-max));justify-content:center;margin:0 auto;max-width:680px;padding:0;text-align:center}.home-intro{align-items:center;display:flex;flex:1 1 auto;flex-direction:column;gap:clamp(.5rem,2vh,1.5rem);gap:clamp(var(--spacing-sm),2vh,var(--spacing-lg));justify-content:center;min-height:0;overflow:hidden;width:100%}.home-section-grid{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(2,minmax(0,1fr));max-width:520px;width:100%}.home-section-card{align-items:center;background:#fff;background:var(--color-background);border:2px solid #0000;border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 4px 14px #0000000f;color:#1a1a1a;color:var(--color-text);display:flex;flex-direction:column;gap:.5rem;gap:var(--spacing-sm);justify-content:center;padding:clamp(.5rem,1.9vh,1.5rem) 1rem;padding:clamp(var(--spacing-sm),1.9vh,var(--spacing-lg)) var(--spacing-md);text-decoration:none;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.home-section-card:hover{box-shadow:0 10px 24px #0000001a;transform:translateY(-3px) rotate(-.5deg)}.home-section-card:active{transform:translateY(-1px)}.home-section-card:focus-visible{outline:3px solid color-mix(in srgb,#3b82f6 55%,#0000);outline:3px solid color-mix(in srgb,var(--color-accent) 55%,#0000);outline-offset:2px}.home-section-card-icon{align-items:center;border-radius:50%;display:flex;height:3.1rem;justify-content:center;transition:transform .25s ease;width:3.1rem}.home-section-card:hover .home-section-card-icon{transform:scale(1.08) rotate(4deg)}.home-section-card-icon svg{height:1.5rem;width:1.5rem}.home-section-card-label{font-size:clamp(1.02rem,1.9vh,1.22rem);font-weight:600;letter-spacing:.02em}.home-section-card--grammar{background:linear-gradient(145deg,color-mix(in srgb,#3b82f6 12%,#fff),#fff);background:linear-gradient(145deg,color-mix(in srgb,#3b82f6 12%,var(--color-background)),var(--color-background));border-color:color-mix(in srgb,#3b82f6 35%,#e5e7eb);border-color:color-mix(in srgb,#3b82f6 35%,var(--color-border))}.home-section-card--grammar .home-section-card-icon{background:color-mix(in srgb,#3b82f6 22%,#fff);background:color-mix(in srgb,#3b82f6 22%,var(--color-background));color:#2563eb}.home-section-card--vocabulary{background:linear-gradient(145deg,color-mix(in srgb,#22c55e 12%,#fff),#fff);background:linear-gradient(145deg,color-mix(in srgb,#22c55e 12%,var(--color-background)),var(--color-background));border-color:color-mix(in srgb,#22c55e 35%,#e5e7eb);border-color:color-mix(in srgb,#22c55e 35%,var(--color-border))}.home-section-card--vocabulary .home-section-card-icon{background:color-mix(in srgb,#22c55e 22%,#fff);background:color-mix(in srgb,#22c55e 22%,var(--color-background));color:#16a34a}.home-section-card--reading{background:linear-gradient(145deg,color-mix(in srgb,#f59e0b 14%,#fff),#fff);background:linear-gradient(145deg,color-mix(in srgb,#f59e0b 14%,var(--color-background)),var(--color-background));border-color:color-mix(in srgb,#f59e0b 35%,#e5e7eb);border-color:color-mix(in srgb,#f59e0b 35%,var(--color-border))}.home-section-card--reading .home-section-card-icon{background:color-mix(in srgb,#f59e0b 24%,#fff);background:color-mix(in srgb,#f59e0b 24%,var(--color-background));color:#d97706}.home-section-card--writing{background:linear-gradient(145deg,color-mix(in srgb,#a855f7 12%,#fff),#fff);background:linear-gradient(145deg,color-mix(in srgb,#a855f7 12%,var(--color-background)),var(--color-background));border-color:color-mix(in srgb,#a855f7 35%,#e5e7eb);border-color:color-mix(in srgb,#a855f7 35%,var(--color-border))}.home-section-card--writing .home-section-card-icon{background:color-mix(in srgb,#a855f7 22%,#fff);background:color-mix(in srgb,#a855f7 22%,var(--color-background));color:#9333ea}.dark .home-section-card--grammar .home-section-card-icon{color:#93c5fd}.dark .home-section-card--vocabulary .home-section-card-icon{color:#86efac}.dark .home-section-card--reading .home-section-card-icon{color:#fcd34d}.dark .home-section-card--writing .home-section-card-icon{color:#d8b4fe}.home-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1a1a1a,#6b7280);background:linear-gradient(135deg,var(--color-text),var(--color-text-muted));-webkit-background-clip:text;background-clip:text;color:#1a1a1a;color:var(--color-text);font-size:2.5rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin:0 0 1.5rem;margin:0 0 var(--spacing-lg) 0;text-align:center}.home-subtitle{color:#6b7280;color:var(--color-text-muted);flex-shrink:1;font-size:clamp(1.12rem,2.9vh,1.55rem);font-weight:500;letter-spacing:.01em;line-height:1.52;margin:0;max-width:560px;text-align:center}.home-footer{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:.5rem;gap:var(--spacing-sm);margin-top:auto;width:100%}.home-copyright{color:#6b7280;color:var(--color-text-muted);font-size:.82rem;line-height:1.2;margin:0 0 -2px}.home-progress{max-width:520px;width:100%}.home-progress-track{background:color-mix(in srgb,#e5e7eb 80%,#0000);background:color-mix(in srgb,var(--color-border) 80%,#0000);border-radius:999px;height:8px;overflow:hidden}.home-progress-fill{background:linear-gradient(90deg,#3b82f6,#a855f7);background:linear-gradient(90deg,var(--color-accent),#a855f7);border-radius:999px;height:100%;transition:width .5s ease}.home-stats{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border);border-top:none;display:flex;flex-shrink:0;gap:clamp(1rem,4vw,3rem);gap:clamp(var(--spacing-md),4vw,var(--spacing-2xl));justify-content:center;padding:clamp(.5rem,1.6vh,1.5rem) 0;padding:clamp(var(--spacing-sm),1.6vh,var(--spacing-lg)) 0}.stat-item{display:flex;gap:.5rem;gap:var(--spacing-sm)}.stat-number{color:#3b82f6;color:var(--color-accent);font-size:clamp(1.5rem,4vh,2.25rem);font-weight:700;line-height:1}.stat-label{color:#6b7280;color:var(--color-text-muted);font-size:.75rem;font-size:var(--font-size-small);font-weight:500;letter-spacing:.5px;text-transform:uppercase}.random-task-section{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:.5rem}.random-task-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#6366f1 55%,#a855f7);background:linear-gradient(135deg,var(--color-accent) 0,#6366f1 55%,#a855f7 100%);border:none;border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 6px 20px color-mix(in srgb,#3b82f6 35%,#0000);box-shadow:0 6px 20px color-mix(in srgb,var(--color-accent) 35%,#0000);color:#fff;cursor:pointer;display:inline-flex;font-size:clamp(1.02rem,2.1vh,1.22rem);font-weight:700;gap:.5rem;gap:var(--spacing-sm);justify-content:center;letter-spacing:.06em;min-width:250px;padding:clamp(1rem,1.8vh,1.5rem) clamp(2rem,5vw,4rem);padding:clamp(var(--spacing-md),1.8vh,var(--spacing-lg)) clamp(var(--spacing-xl),5vw,var(--spacing-3xl));text-transform:uppercase;transition:transform .2s ease,box-shadow .2s ease}.random-task-button-icon{animation:surpriseIconPulse 2.2s ease-in-out infinite;height:1.25rem;width:1.25rem}@keyframes surpriseIconPulse{0%,to{opacity:1;transform:scale(1) rotate(0deg)}50%{opacity:.9;transform:scale(1.12) rotate(-8deg)}}.random-task-button:hover{box-shadow:0 10px 28px color-mix(in srgb,#3b82f6 45%,#0000);box-shadow:0 10px 28px color-mix(in srgb,var(--color-accent) 45%,#0000);transform:translateY(-3px) scale(1.02)}.random-task-button:active{box-shadow:0 2px 6px #0000001a;transform:translateY(0)}.random-task-button:focus{box-shadow:0 0 0 3px color-mix(in srgb,#3b82f6 40%,#0000);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 40%,#0000);outline:none}.random-task-button:focus:not(:focus-visible){box-shadow:0 6px 20px color-mix(in srgb,#3b82f6 35%,#0000);box-shadow:0 6px 20px color-mix(in srgb,var(--color-accent) 35%,#0000)}.app--home{background:#0000;min-height:0}.app--home .header-container{background:#0000;border-bottom:none;box-shadow:none}.app--home .header h1{-webkit-text-fill-color:unset;background:none;color:#1a1a1a;color:var(--color-text)}.app--home .header-copyright{color:#6b7280;color:var(--color-text-muted)}.app--home .navigation{background:#0000}.app--home .home-blob{filter:blur(64px);opacity:.2}.navigation--home .nav-top{justify-content:center}.navigation--home .nav-search{flex:1 1 auto;margin-left:0;max-width:none}.app--home .nav-search-input,.app--home .nav-search-input:focus{background:#f9fafb;background:var(--color-background-secondary);border-color:#e5e7eb;border-color:var(--color-border);box-shadow:none}.app--home .nav-search-icon{color:#6b7280;color:var(--color-text-muted)}.app--home .dark-mode-toggle,.app--home .dark-mode-toggle:hover{background:#f9fafb;background:var(--color-background-secondary);border-color:#e5e7eb;border-color:var(--color-border)}.app--home .home-section-card{background:color-mix(in srgb,#f9fafb 55%,#fff);background:color-mix(in srgb,var(--color-background-secondary) 55%,var(--color-background));border:1px solid color-mix(in srgb,#e5e7eb 65%,#0000);border:1px solid color-mix(in srgb,var(--color-border) 65%,#0000);box-shadow:none}.app--home .home-section-card:hover{box-shadow:0 6px 16px color-mix(in srgb,#1a1a1a 6%,#0000);box-shadow:0 6px 16px color-mix(in srgb,var(--color-text) 6%,#0000)}.app--home .home-section-card--grammar{background:color-mix(in srgb,#fff 88%,#3b82f6 12%);background:color-mix(in srgb,var(--color-background) 88%,#3b82f6 12%);border-color:color-mix(in srgb,#3b82f6 14%,#e5e7eb);border-color:color-mix(in srgb,#3b82f6 14%,var(--color-border))}.app--home .home-section-card--grammar .home-section-card-icon{background:color-mix(in srgb,#3b82f6 14%,#f9fafb);background:color-mix(in srgb,#3b82f6 14%,var(--color-background-secondary))}.app--home .home-section-card--vocabulary{background:color-mix(in srgb,#fff 88%,#22c55e 12%);background:color-mix(in srgb,var(--color-background) 88%,#22c55e 12%);border-color:color-mix(in srgb,#22c55e 14%,#e5e7eb);border-color:color-mix(in srgb,#22c55e 14%,var(--color-border))}.app--home .home-section-card--vocabulary .home-section-card-icon{background:color-mix(in srgb,#22c55e 14%,#f9fafb);background:color-mix(in srgb,#22c55e 14%,var(--color-background-secondary))}.app--home .home-section-card--reading{background:color-mix(in srgb,#fff 88%,#f59e0b 12%);background:color-mix(in srgb,var(--color-background) 88%,#f59e0b 12%);border-color:color-mix(in srgb,#f59e0b 14%,#e5e7eb);border-color:color-mix(in srgb,#f59e0b 14%,var(--color-border))}.app--home .home-section-card--reading .home-section-card-icon{background:color-mix(in srgb,#f59e0b 16%,#f9fafb);background:color-mix(in srgb,#f59e0b 16%,var(--color-background-secondary))}.app--home .home-section-card--writing{background:color-mix(in srgb,#fff 88%,#a855f7 12%);background:color-mix(in srgb,var(--color-background) 88%,#a855f7 12%);border-color:color-mix(in srgb,#a855f7 14%,#e5e7eb);border-color:color-mix(in srgb,#a855f7 14%,var(--color-border))}.app--home .home-section-card--writing .home-section-card-icon{background:color-mix(in srgb,#a855f7 14%,#f9fafb);background:color-mix(in srgb,#a855f7 14%,var(--color-background-secondary))}.app--home .home-stats{background:#0000;border-bottom:none;border-top:none}.app--home .home-progress-track{background:color-mix(in srgb,#e5e7eb 50%,#0000);background:color-mix(in srgb,var(--color-border) 50%,#0000)}.dark .app--home{background:#fff;background:var(--color-background)}.dark .app--home .home-section-card{background:color-mix(in srgb,#f9fafb 70%,#fff);background:color-mix(in srgb,var(--color-background-secondary) 70%,var(--color-background));border-color:color-mix(in srgb,#e5e7eb 55%,#0000);border-color:color-mix(in srgb,var(--color-border) 55%,#0000)}@media (max-height:720px){.app--home .home-section-card-icon{height:2.25rem;width:2.25rem}.app--home .home-section-card-icon svg{height:1.1rem;width:1.1rem}.app--home .home-section-card-label{font-size:.75rem}.app--home .random-task-button{max-width:280px;min-width:0;width:100%}.app--home .stat-label{font-size:.625rem}}@media (prefers-reduced-motion:reduce){.home-blob,.home-section-card:hover .home-section-card-icon,.random-task-button-icon{animation:none}.home-section-card:hover,.random-task-button:hover{transform:none}}.change-story-button:hover{background:#1a1a1a;background:var(--color-text);box-shadow:0 2px 6px #0000001a;color:#fff;color:var(--color-background);transform:translateY(-1px)}.change-story-button:active{transform:translateY(0)}.random-task-description{color:#9ca3af;color:var(--color-text-light);font-size:.75rem;line-height:1.5;margin:0;max-width:400px}@media (-webkit-min-device-pixel-ratio:1.5),(min-resolution:144dpi){.home-hero{gap:clamp(1.5rem,5vh,4rem);gap:clamp(var(--spacing-lg),5vh,var(--spacing-3xl))}.home-subtitle{line-height:1.9;margin:0}.home-stats{gap:3rem;gap:var(--spacing-2xl);margin:0;padding:1.5rem 0;padding:var(--spacing-lg) 0}.random-task-section{gap:1.5rem;gap:var(--spacing-lg);margin:0}.random-task-button{min-width:250px;padding:2rem 4rem;padding:var(--spacing-xl) var(--spacing-3xl)}}.home-sections{margin-top:3rem;margin-top:var(--spacing-2xl);text-align:left}.home-sections h2{color:#1a1a1a;color:var(--color-text);font-size:1.4rem;font-size:var(--font-size-card-title-large);font-weight:600;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}.section-grid{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:1.5rem;margin-top:var(--spacing-lg)}.section-card{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-lg);padding:1.5rem;padding:var(--spacing-lg);transition:all .2s ease}.section-card:hover{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.section-card h3{color:#1a1a1a;color:var(--color-text);font-size:1.2rem;font-size:var(--font-size-card-title);font-weight:600;margin:0 0 .5rem;margin:0 0 var(--spacing-sm) 0}.section-card p{color:#6b7280;color:var(--color-text-muted);font-size:1rem;font-size:var(--font-size-body);line-height:1.6;line-height:var(--line-height-body);margin:0}.page-filters{margin-bottom:2rem}.filter-bar{align-items:stretch;display:flex;flex-direction:column;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md)}.filter-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.filter-button{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;color:#6b7280;color:var(--color-text-muted);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.filter-button:hover{color:#1a1a1a;color:var(--color-text)}.filter-button.active,.filter-button:hover{border-color:#3b82f6;border-color:var(--color-accent)}.filter-button.active{background:#3b82f6;background:var(--color-accent);color:#fff}.search-container{align-items:center;display:flex;position:relative}.search-input{border:1px solid #e0e0e0;border-radius:4px;font-size:.9rem;padding:.5rem 2.5rem .5rem 1rem;width:200px}.search-input:focus{border-color:#000;outline:none}.search-icon{color:#666;pointer-events:none;position:absolute;right:.75rem}.not-found{align-items:center;display:flex;justify-content:center;min-height:60vh;padding:2rem;text-align:center}.not-found-content{max-width:400px}.not-found-logo{height:80px;margin-bottom:1.5rem;object-fit:contain;opacity:.8;width:80px}.not-found h1{color:#000;font-size:4rem;font-weight:700;line-height:1;margin:0 0 .5rem}.not-found h2{color:#333;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.not-found p{color:#666;font-size:1rem;margin-bottom:2rem}.not-found-link{background:#000;border-radius:4px;color:#fff;display:inline-block;font-weight:500;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.not-found-link:hover{background:#333;transform:translateY(-1px)}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:2rem}.loading-spinner{height:80px;margin-bottom:1rem;position:relative;width:80px}.loading-logo{animation:logoSpin 2s linear infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1));height:60px;object-fit:contain;width:60px}@keyframes logoSpin{0%{transform:rotate(0deg) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(1turn) scale(1)}}.loading-text{animation:pulse 1.5s ease-in-out infinite;color:#666;font-size:.9rem;margin:0}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.search-input{width:100%}.subcategory-filter-header{align-items:flex-start;flex-direction:column;gap:.5rem;gap:var(--spacing-sm)}.third-area{min-height:24px;padding:0 .5rem;padding:0 var(--spacing-sm)}.breadcrumb-current,.breadcrumb-link{font-size:.8rem}.reading-exercise{margin:0 auto;max-width:800px}.reading-passage{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:3rem;margin-bottom:var(--spacing-2xl);padding:1.5rem;padding:var(--spacing-lg)}.reading-passage h3{font-size:1.125rem;font-size:var(--font-size-h3);font-weight:600;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.passage-content,.reading-passage h3{color:#1a1a1a;color:var(--color-text)}.passage-content{font-size:1rem;font-size:var(--font-size-body);line-height:1.8}.passage-paragraph{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);text-align:left}.passage-source{border-top:1px solid #e5e7eb;border-top:1px solid var(--color-border);color:#6b7280;color:var(--color-text-muted);font-size:.75rem;font-size:var(--font-size-small);margin-top:1.5rem;margin-top:var(--spacing-lg);padding-top:1.5rem;padding-top:var(--spacing-lg)}.reading-questions{margin-top:3rem;margin-top:var(--spacing-2xl)}.reading-questions h3{color:#1a1a1a;color:var(--color-text);font-size:1.125rem;font-size:var(--font-size-h3);font-weight:600;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.writing-exercise{margin:0 auto;max-width:800px}.writing-instructions{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:3rem;margin-bottom:var(--spacing-2xl);padding:1.5rem;padding:var(--spacing-lg)}.writing-instructions h3{color:#1a1a1a;color:var(--color-text);font-size:1.125rem;font-size:var(--font-size-h3);font-weight:600;margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.instructions-content{color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);line-height:1.6}.instruction-line{margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.writing-source{border-top:1px solid #e5e7eb;border-top:1px solid var(--color-border);color:#6b7280;color:var(--color-text-muted);font-size:.75rem;font-size:var(--font-size-small);margin-top:1.5rem;margin-top:var(--spacing-lg);padding-top:1.5rem;padding-top:var(--spacing-lg)}.writing-prompt{background:#dbeafe;background:var(--color-accent-light);border:1px solid #3b82f6;border:1px solid var(--color-accent);border-radius:6px;border-radius:var(--radius-md);margin-bottom:3rem;margin-bottom:var(--spacing-2xl);padding:1.5rem;padding:var(--spacing-lg)}.writing-prompt h3{font-size:1.125rem;font-size:var(--font-size-h3);font-weight:600;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.prompt-text,.writing-prompt h3{color:#1a1a1a;color:var(--color-text)}.prompt-text{font-size:1rem;font-size:var(--font-size-body);font-style:italic;line-height:1.6}.writing-area{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.writing-area h3{font-size:1.125rem;font-size:var(--font-size-h3);font-weight:600;margin-bottom:1rem;margin-bottom:var(--spacing-md)}.writing-area h3,.writing-textarea{color:#1a1a1a;color:var(--color-text)}.writing-textarea{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);font-family:inherit;font-size:1rem;font-size:var(--font-size-body);line-height:1.6;min-height:clamp(12rem,40dvh,18.75rem);padding:1rem;padding:var(--spacing-md);resize:vertical;width:100%}.writing-textarea:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #dbeafe;box-shadow:0 0 0 2px var(--color-accent-light);outline:none}.word-count{color:#6b7280;color:var(--color-text-muted);font-size:.75rem;font-size:var(--font-size-small);margin-top:.5rem;margin-top:var(--spacing-sm);text-align:right}.writing-actions{text-align:center}.save-writing-btn{background:#3b82f6;background:var(--color-accent);border:none;border-radius:6px;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:1rem;font-size:var(--font-size-body);font-weight:600;padding:1rem 2rem;padding:var(--spacing-md) var(--spacing-xl);transition:all .2s ease}.save-writing-btn:hover{background:#1e40af;background:var(--color-accent-dark);transform:translateY(-1px)}.save-writing-btn:active{transform:translateY(0)}.dark .reading-passage,.dark .writing-instructions{background:#fff;background:var(--color-background);border-color:#e5e7eb;border-color:var(--color-border)}.dark .writing-prompt{background:#1e40af;background:var(--color-accent-dark);border-color:#3b82f6;border-color:var(--color-accent)}.dark .writing-textarea{background:#fff;background:var(--color-background);border-color:#e5e7eb;border-color:var(--color-border);color:#1a1a1a;color:var(--color-text)}.dark .writing-textarea:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #1e40af;box-shadow:0 0 0 2px var(--color-accent-dark)}.mad-libs-exercise{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.mad-libs-blanks{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem;margin-bottom:var(--spacing-xl)}.mad-lib-input{display:flex;flex-direction:column;gap:.25rem;gap:var(--spacing-xs)}.mad-lib-input label{font-size:.75rem;font-size:var(--font-size-small);font-weight:600}.mad-lib-field,.mad-lib-input label{color:#1a1a1a;color:var(--color-text)}.mad-lib-field{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);font-size:1rem;font-size:var(--font-size-body);padding:.5rem;padding:var(--spacing-sm)}.mad-lib-field:focus{border-color:#3b82f6;border-color:var(--color-accent);box-shadow:0 0 0 2px #dbeafe;box-shadow:0 0 0 2px var(--color-accent-light);outline:none}.mad-libs-story{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-top:1.5rem;margin-top:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}.mad-libs-story-title{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);text-align:center}.mad-libs-story-title h3{color:#3b82f6;color:var(--color-accent);font-size:1.4rem;font-size:var(--font-size-card-title-large);margin:0}.mad-libs-story-image{margin:1rem 0;margin:var(--spacing-md) 0;text-align:center}.mad-libs-story-image img{aspect-ratio:16/9;border-radius:6px;border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;height:auto;max-height:min(35dvh,200px);max-width:400px;object-fit:cover;transition:transform .2s ease;width:100%}.mad-libs-story-image img:hover{transform:scale(1.02)}.haiku-exercise{margin:0 auto;max-width:800px}.haiku-instructions{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}.haiku-examples{margin:1.5rem 0;margin:var(--spacing-lg) 0}.haiku-example{border-left:4px solid #3b82f6;border-left:4px solid var(--color-accent);border-radius:4px;border-radius:var(--radius-sm)}.haiku-lines{margin-top:.5rem;margin-top:var(--spacing-sm)}.haiku-line{font-style:italic;margin:.25rem 0;margin:var(--spacing-xs) 0}.syllable-count{color:var(--color-text-secondary);font-size:.75rem;font-size:var(--font-size-small);font-style:normal}.haiku-topics{margin:1.5rem 0;margin:var(--spacing-lg) 0}.topic-tags{display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm);margin-top:.5rem;margin-top:var(--spacing-sm)}.topic-tag{background:#3b82f6;background:var(--color-accent);border-radius:4px;border-radius:var(--radius-sm);color:#fff;font-size:.75rem;font-size:var(--font-size-small);padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm)}.haiku-writing-area{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}.haiku-textarea{font-family:inherit;line-height:1.6}.haiku-validation{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);margin-top:1.5rem;margin-top:var(--spacing-lg);padding:1rem;padding:var(--spacing-md)}.syllable-display{margin:1rem 0;margin:var(--spacing-md) 0}.syllable-line{font-weight:500;padding:.25rem 0;padding:var(--spacing-xs) 0}.syllable-line.correct{color:var(--color-success)}.syllable-line.incorrect{color:var(--color-error)}.haiku-success{background:var(--color-success-light);border:1px solid var(--color-success);border-radius:4px;border-radius:var(--radius-sm);color:var(--color-success)}.haiku-feedback,.haiku-success{margin-top:1rem;margin-top:var(--spacing-md);padding:1rem;padding:var(--spacing-md)}.haiku-feedback{background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:4px;border-radius:var(--radius-sm);color:var(--color-warning)}.haiku-actions{text-align:center}.haiku-anti-cheat-warning{background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:4px;border-radius:var(--radius-sm);color:var(--color-warning);margin-top:1rem;margin-top:var(--spacing-md);padding:1rem;padding:var(--spacing-md);text-align:center}.haiku-anti-cheat-warning p{font-weight:500;margin:0}.limerick-exercise{margin:0 auto;max-width:800px}.limerick-instructions{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}.limerick-examples{margin:1.5rem 0;margin:var(--spacing-lg) 0}.limerick-example{background:#fff;background:var(--color-background);border-left:4px solid #3b82f6;border-left:4px solid var(--color-accent);border-radius:4px;border-radius:var(--radius-sm);margin-bottom:1rem;margin-bottom:var(--spacing-md);padding:1rem;padding:var(--spacing-md)}.limerick-lines{margin-top:.5rem;margin-top:var(--spacing-sm)}.limerick-line{font-style:italic;margin:.25rem 0;margin:var(--spacing-xs) 0}.limerick-writing-area{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}.limerick-textarea{font-family:inherit;line-height:1.6}.limerick-actions{text-align:center}.limerick-anti-cheat-warning{background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:4px;border-radius:var(--radius-sm);color:var(--color-warning);margin-top:1rem;margin-top:var(--spacing-md);padding:1rem;padding:var(--spacing-md);text-align:center}.limerick-anti-cheat-warning p{font-weight:500;margin:0}.limerick-rhyme-warning{background:var(--color-info-light);border:1px solid var(--color-info);border-radius:4px;border-radius:var(--radius-sm);color:var(--color-info);margin-top:1rem;margin-top:var(--spacing-md);padding:1rem;padding:var(--spacing-md);text-align:center}.limerick-rhyme-warning p{font-weight:500;margin:0}.picture-prompt-exercise{margin:0 auto;max-width:800px}.picture-prompt-header{margin-bottom:2rem;margin-bottom:var(--spacing-xl);text-align:center}.picture-prompt-header h3{color:#3b82f6;color:var(--color-accent);font-size:1.4rem;font-size:var(--font-size-card-title-large);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.picture-prompt-image{margin:1.5rem 0;margin:var(--spacing-lg) 0}.picture-prompt-image img{aspect-ratio:16/9;border-radius:6px;border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;height:auto;max-height:min(40dvh,300px);max-width:500px;object-fit:cover;transition:transform .2s ease;width:100%}.picture-prompt-image img:hover{transform:scale(1.02)}.picture-prompt-description{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin:1.5rem 0;margin:var(--spacing-lg) 0;padding:1.5rem;padding:var(--spacing-lg);text-align:left}.picture-prompt-description p{font-size:1rem;font-size:var(--font-size-body);line-height:1.6;margin:0}.picture-prompt-questions{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin:1.5rem 0;margin:var(--spacing-lg) 0;padding:1.5rem;padding:var(--spacing-lg);text-align:left}.picture-prompt-questions h4{color:#3b82f6;color:var(--color-accent);font-size:1.2rem;font-size:var(--font-size-card-title);margin-bottom:1rem;margin-bottom:var(--spacing-md)}.picture-prompt-questions ul{margin:0;padding-left:1.5rem;padding-left:var(--spacing-lg)}.picture-prompt-questions li{font-size:1rem;font-size:var(--font-size-body);line-height:1.5;margin-bottom:.5rem;margin-bottom:var(--spacing-sm)}.mad-libs-actions{display:flex;flex-wrap:wrap;gap:1rem;gap:var(--spacing-md);justify-content:center;margin:1.5rem 0;margin:var(--spacing-lg) 0;text-align:center}.browse-story-btn{background:#2563eb!important;background:var(--color-accent-hover)!important;border:none!important;border-radius:6px!important;border-radius:var(--radius-md)!important;color:#fff!important;cursor:pointer!important;font-size:1rem!important;font-size:var(--font-size-body)!important;font-weight:500!important;padding:.5rem 1.5rem!important;padding:var(--spacing-sm) var(--spacing-lg)!important;transition:all .2s ease!important}.browse-story-btn:hover{background:#3b82f6!important;background:var(--color-accent)!important;transform:translateY(-2px)}.story-blank{background:#3b82f6;background:var(--color-accent);border-radius:3px;color:#fff;font-weight:700;padding:2px 4px}.completion-message .completion-buttons,.new-story-btn{margin-top:1.5rem;margin-top:var(--spacing-lg)}.completion-message .completion-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm);justify-content:center}.completion-message .back-to-tasks-button,.completion-message .reset-button{border:none;border-radius:6px;border-radius:var(--radius-md);cursor:pointer;flex-shrink:0;font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;padding:.5rem 1rem;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease;white-space:nowrap}.completion-message .reset-button{background:#3b82f6;background:var(--color-accent);border:1px solid #3b82f6;border:1px solid var(--color-accent);color:#fff}.completion-message .reset-button:hover{background:#2563eb;background:var(--color-accent-hover);transform:translateY(-2px)}.completion-message .back-to-tasks-button{background:#f9fafb;background:var(--color-background-secondary);border:1px solid #e5e7eb;border:1px solid var(--color-border);color:#1a1a1a;color:var(--color-text)}.completion-message .back-to-tasks-button:hover{background:#e5e7eb;background:var(--color-border);transform:translateY(-2px)}.story-preview{color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);line-height:1.8}.story-blank{background:#dbeafe;background:var(--color-accent-light);border:1px solid #3b82f6;border:1px solid var(--color-accent);border-radius:4px;border-radius:var(--radius-sm);color:#1e40af;color:var(--color-accent-dark);font-weight:600;padding:2px 6px}.picture-prompt{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.image-description{background:#dbeafe;background:var(--color-accent-light);border:1px solid #3b82f6;border:1px solid var(--color-accent);border-radius:6px;border-radius:var(--radius-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg);padding:1.5rem;padding:var(--spacing-lg)}.prompt-questions ul{list-style:none;padding:0}.prompt-questions li{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border);padding:.5rem 0;padding:var(--spacing-sm) 0}.prompt-questions li:last-child{border-bottom:none}.character-creation{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.character-cards{display:flex;flex-direction:column;gap:2rem;gap:var(--spacing-xl)}.character-category h4{color:#1a1a1a;color:var(--color-text);font-size:var(--font-size-h4);margin-bottom:1rem;margin-bottom:var(--spacing-md)}.card-grid{grid-gap:1rem;grid-gap:var(--spacing-md);display:grid;gap:1rem;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.character-card{background:#fff;background:var(--color-background);border:2px solid #e5e7eb;border:2px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);cursor:pointer;padding:1rem;padding:var(--spacing-md);text-align:center;transition:all .2s ease}.character-card:hover{transform:translateY(-2px)}.character-card.selected,.character-card:hover{border-color:#3b82f6;border-color:var(--color-accent)}.character-card.selected{background:#dbeafe;background:var(--color-accent-light)}.character-card h5{color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);margin:0 0 .5rem;margin:0 0 var(--spacing-sm) 0}.character-card p{color:#6b7280;color:var(--color-text-muted);font-size:.75rem;font-size:var(--font-size-small);margin:0}.six-word-examples{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.examples-list{display:flex;flex-direction:column;gap:1rem;gap:var(--spacing-md);margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.example-story{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);padding:1rem;padding:var(--spacing-md);text-align:center}.example-story p{color:#1a1a1a;color:var(--color-text);font-size:1rem;font-size:var(--font-size-body);font-style:italic;margin:0}.story-challenges ul{list-style:none;padding:0}.story-challenges li{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border);padding:.5rem 0;padding:var(--spacing-sm) 0}.dialogue-characters{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.character-pairs{display:flex;flex-direction:column;gap:2rem;gap:var(--spacing-xl)}.character-pair{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);padding:1.5rem;padding:var(--spacing-lg)}.character-pair h4{color:#1a1a1a;color:var(--color-text);margin-bottom:1rem;margin-bottom:var(--spacing-md)}.characters{grid-gap:1.5rem;grid-gap:var(--spacing-lg);display:grid;gap:1.5rem;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.character{background:#dbeafe;background:var(--color-accent-light);border:1px solid #3b82f6;border:1px solid var(--color-accent);border-radius:6px;border-radius:var(--radius-md);padding:1rem;padding:var(--spacing-md)}.character h5{color:#1e40af;color:var(--color-accent-dark);margin:0 0 .5rem;margin:0 0 var(--spacing-sm) 0}.character p{color:#1a1a1a;color:var(--color-text);font-size:.75rem;font-size:var(--font-size-small);margin:0 0 .25rem;margin:0 0 var(--spacing-xs) 0}.haiku-guide{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.haiku-examples{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.haiku-example{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:1rem;margin-bottom:var(--spacing-md);padding:1rem;padding:var(--spacing-md);text-align:center}.haiku-example h5{margin:0 0 .5rem;margin:0 0 var(--spacing-sm) 0}.haiku-example h5,.haiku-example pre{color:#1a1a1a;color:var(--color-text)}.haiku-example pre{font-family:inherit;margin:0;white-space:pre-wrap}.haiku-topics ul{grid-gap:.5rem;grid-gap:var(--spacing-sm);display:grid;gap:.5rem;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));list-style:none;padding:0}.haiku-topics li{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:4px;border-radius:var(--radius-sm);color:#1a1a1a;color:var(--color-text);padding:.5rem;padding:var(--spacing-sm);text-align:center}.story-starters{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.starter-options{display:flex;flex-direction:column;gap:2rem;gap:var(--spacing-xl)}.story-starter{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);padding:1.5rem;padding:var(--spacing-lg)}.story-beginning,.story-starter h4{color:#1a1a1a;color:var(--color-text);margin-bottom:1rem;margin-bottom:var(--spacing-md)}.story-beginning{background:#dbeafe;background:var(--color-accent-light);border:1px solid #3b82f6;border:1px solid var(--color-accent);border-radius:6px;border-radius:var(--radius-md);font-style:italic;padding:1rem;padding:var(--spacing-md)}.story-questions ul{list-style:none;padding:0}.story-questions li{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--color-border);padding:.5rem 0;padding:var(--spacing-sm) 0}.acrostic-guide{margin-bottom:3rem;margin-bottom:var(--spacing-2xl)}.acrostic-examples{margin-bottom:1.5rem;margin-bottom:var(--spacing-lg)}.acrostic-example{background:#fff;background:var(--color-background);border:1px solid #e5e7eb;border:1px solid var(--color-border);border-radius:6px;border-radius:var(--radius-md);margin-bottom:1rem;margin-bottom:var(--spacing-md);padding:1rem;padding:var(--spacing-md)}.acrostic-example h5{color:#1a1a1a;color:var(--color-text);font-weight:600;margin:0 0 .5rem;margin:0 0 var(--spacing-sm) 0}.acrostic-example pre{color:#1a1a1a;color:var(--color-text);font-family:inherit;margin:0;white-space:pre-wrap}.acrostic-suggestions{margin-top:1.5rem;margin-top:var(--spacing-lg)}.suggestion-tags{display:flex;flex-wrap:wrap;gap:.5rem;gap:var(--spacing-sm)}.suggestion-tag{background:#3b82f6;background:var(--color-accent);border-radius:4px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.75rem;font-size:var(--font-size-small);padding:.25rem .5rem;padding:var(--spacing-xs) var(--spacing-sm);transition:all .2s ease}.suggestion-tag:hover{background:#1e40af;background:var(--color-accent-dark);transform:translateY(-1px)}.dark .story-blank{color:#dbeafe;color:var(--color-accent-light)}.dark .character,.dark .character-card.selected,.dark .story-blank{background:#1e40af;background:var(--color-accent-dark);border-color:#3b82f6;border-color:var(--color-accent)}.dark .character h5{color:#dbeafe;color:var(--color-accent-light)}.dark .suggestion-tag{background:#1e40af;background:var(--color-accent-dark)}.dark .suggestion-tag:hover{background:#3b82f6;background:var(--color-accent)}:root{--layout-gutter:var(--spacing-xs);--home-gap-after-search:var(--spacing-sm);--home-section-gap-min:var(--spacing-sm);--mobile-tab-bar-height:3.5rem}.mobile-tab-bar{display:none}.search-results-overlay{align-items:stretch;padding-top:calc(120px + env(safe-area-inset-top, 0px));padding-top:calc(var(--header-height, 120px) + env(safe-area-inset-top, 0px))}.search-results-container{margin-inline:var(--spacing-xs);margin-inline:var(--layout-gutter);max-height:calc(100dvh - 120px - var(--spacing-md));max-height:calc(100dvh - var(--header-height, 120px) - var(--spacing-md));width:min(100% - 2 * var(--spacing-xs),600px);width:min(100% - 2 * var(--layout-gutter),600px)}.header-container{padding:var(--spacing-sm) var(--spacing-xs);padding-top:calc(var(--spacing-sm) + env(safe-area-inset-top, 0px))}.header-bar{gap:var(--spacing-sm);min-height:2.9rem}.header-title-row{gap:var(--spacing-xs)}.header h1{font-size:clamp(1.2rem,3.4vw + .45rem,1.55rem)}.header-copyright{display:none}.header-logo-img{height:2.5rem}.header-tagline{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.nav-top{align-items:center;flex-direction:row;gap:var(--spacing-sm);justify-content:flex-end;width:100%}.nav-links--header{display:flex;flex:0 0 auto;flex-wrap:nowrap;gap:var(--spacing-xs);justify-content:flex-start}.nav-top .nav-search{flex:1 1 auto;margin-left:0;max-width:none}.mobile-tab-bar{background:var(--color-background);border-top:1px solid var(--color-border);bottom:0;box-shadow:0 -4px 16px #0000000f;display:flex;left:50%;max-width:var(--layout-max-width);padding-bottom:env(safe-area-inset-bottom,0);position:fixed;transform:translateX(-50%);width:min(100% - 2 * var(--spacing-xs),var(--layout-max-width));width:min(100% - 2 * var(--layout-gutter),var(--layout-max-width));z-index:1001}.mobile-tab-bar-links{display:grid;grid-template-columns:repeat(4,1fr);margin:0;padding:0;width:100%}.mobile-tab-bar-link{align-items:center;border-bottom:none;border-top:2px solid #0000;color:var(--color-text-muted);display:flex;flex-direction:column;font-size:.625rem;font-weight:500;gap:2px;justify-content:center;min-height:3.5rem;min-height:var(--mobile-tab-bar-height);padding:var(--spacing-xs) 2px;text-decoration:none;transition:color .2s ease,border-color .2s ease}.mobile-tab-bar-link.active,.mobile-tab-bar-link:hover{border-top-color:var(--color-accent);color:var(--color-accent)}.mobile-tab-bar-link .nav-link-label{clip:auto;height:auto;line-height:1.1;margin:0;max-width:100%;overflow:hidden;position:static;text-overflow:ellipsis;white-space:nowrap;width:auto}.app{padding-bottom:calc(3.5rem + env(safe-area-inset-bottom, 0px));padding-bottom:calc(var(--mobile-tab-bar-height) + env(safe-area-inset-bottom, 0px))}.app--home{height:100dvh;max-height:100dvh;overflow:hidden;padding-bottom:env(safe-area-inset-bottom,0)}.app--home .main-content{background:#0000;height:calc(100dvh - 120px - env(safe-area-inset-bottom, 0px));height:calc(100dvh - var(--header-height, 120px) - env(safe-area-inset-bottom, 0px));max-height:calc(100dvh - 120px - env(safe-area-inset-bottom, 0px));max-height:calc(100dvh - var(--header-height, 120px) - env(safe-area-inset-bottom, 0px));overflow:hidden;padding-bottom:var(--spacing-xs)}.main-content{padding-bottom:calc(var(--spacing-md) + var(--mobile-tab-bar-height) + env(safe-area-inset-bottom, 0px))}.search-active .mobile-tab-bar{display:none}.search-active .app{padding-bottom:0}.search-active .main-content{padding-bottom:var(--spacing-md)}.header-container--collapsed .header-tagline{display:none}.header-container--collapsed .header-logo-img{height:1.8rem;transition:height .2s ease}.header-container--collapsed .header-bar{min-height:2.25rem}.header-container--collapsed .header-text{gap:0}.header-container--collapsed .header-text p{margin:0}.nav-link-icon{height:18px;width:18px}.third-area{min-height:28px;padding:0 var(--spacing-xs)}.main-content{padding:var(--spacing-xs) var(--spacing-xs) var(--spacing-md)}.home-hero{gap:clamp(var(--spacing-sm),2.5vh,var(--spacing-lg));gap:clamp(var(--home-section-gap-min),2.5vh,var(--spacing-lg));max-width:100%;padding-inline:var(--spacing-xs);padding-top:0}.home-intro{gap:var(--spacing-lg)}.home-title{font-size:clamp(1.75rem,5vw + .5rem,2.5rem)}.home-subtitle{font-size:clamp(1.02rem,4.2vw,1.28rem);line-height:1.5;max-width:100%}.home-stats{flex-direction:row;flex-wrap:nowrap;gap:var(--spacing-md);justify-content:space-between;margin:0;padding:var(--spacing-md) 0;width:100%}.random-task-section{gap:var(--spacing-sm);margin:0}.stat-item{align-items:center;flex:1 1;flex-direction:column;gap:2px;min-width:0}.stat-number{font-size:1.35rem}.stat-label{font-size:.68rem;letter-spacing:.03em}.random-task-button{font-size:clamp(.98rem,3.7vw,1.16rem);max-width:340px;min-width:0;padding:var(--spacing-md) var(--spacing-xl);width:100%}.random-task-description{font-size:var(--font-size-small);line-height:1.4}.section-header{margin-bottom:var(--spacing-sm)}.section-header h1{font-size:1.35rem}.section-header p{font-size:var(--font-size-sm);line-height:1.45}.content-area h2{font-size:var(--font-size-body)}.subcategory-filter{margin-bottom:var(--spacing-md)}.subcategory-filter-header h2{font-size:var(--font-size-body)!important}.view-toggle-button{font-size:var(--font-size-small);padding:var(--spacing-xs) var(--spacing-sm)}.content-area .task-card{padding:var(--spacing-sm)}.content-area .task-card h3{font-size:var(--font-size-sm)}.task-view .main-content h1{font-size:1.35rem!important}.task-view .main-content p{margin-bottom:var(--spacing-md)!important}.reading-passage{margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.exercise-questions,.reading-questions{gap:var(--spacing-sm)}@media (min-width:480px){:root{--layout-gutter:var(--spacing-sm)}.header-copyright{display:inline;font-size:.65rem}.nav-link{font-size:var(--font-size-small)}.home-stats{gap:var(--spacing-lg);justify-content:center}.stat-number{font-size:1.5rem}.stat-label{font-size:var(--font-size-small)}.random-task-button{width:auto}}@media (max-width:479px){.header-tagline{display:none}.mobile-tab-bar-link{font-size:.5625rem}}@media (min-width:768px){:root{--layout-gutter:var(--spacing-2xl);--home-gap-after-search:var(--spacing-lg);--home-section-gap-min:var(--spacing-md);--home-section-gap-max:var(--spacing-2xl)}.header-container{padding:var(--spacing-md) var(--spacing-2xl);padding-top:calc(var(--spacing-md) + env(safe-area-inset-top, 0px))}.header-bar{gap:var(--spacing-lg);min-height:3.6rem}.header-title-row{gap:var(--spacing-sm)}.header-copyright{display:inline;font-size:.8rem}.header-logo-img{height:3.35rem}.main-content{padding:var(--spacing-lg)}.main-content:has(.home){height:calc(100dvh - 120px);height:calc(100dvh - var(--header-height, 120px));max-height:calc(100dvh - 120px);max-height:calc(100dvh - var(--header-height, 120px));overflow:hidden;padding-bottom:var(--spacing-xs);padding-top:var(--spacing-sm)}.header h1{font-size:2.05rem}.header-link{gap:var(--spacing-md)}.navigation{align-items:stretch;flex-direction:row;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg)}.nav-links{gap:2rem}.mobile-tab-bar{display:none!important}.app{padding-bottom:0}.main-content{padding-bottom:var(--spacing-lg)}.nav-links--header{display:flex;flex:0 0 auto;flex-wrap:nowrap;gap:var(--spacing-sm);justify-content:flex-start}.nav-top{align-items:center;flex-direction:row;flex-wrap:nowrap;gap:var(--spacing-lg)}.nav-top .nav-search{flex:1 1 10rem;margin-left:auto;max-width:16rem;min-width:8rem}.nav-link{flex-direction:row;font-size:var(--font-size-nav);min-height:44px;padding:var(--spacing-sm) 0;text-align:left}.nav-link-label{clip:auto;height:auto;margin:0;overflow:visible;position:static;white-space:normal;width:auto}.nav-search-input{font-size:var(--font-size-body);height:3rem;padding:0 2.4rem 0 var(--spacing-md);width:100%}.header-container .header-bar .dark-mode-toggle{height:3rem;min-height:3rem;min-width:3rem;width:3rem}.third-area{min-height:32px;padding:0 var(--spacing-lg)}.breadcrumb-current,.breadcrumb-link{font-size:.875rem}.content-area h2{font-size:1.2rem}.section-header{margin-bottom:1.5rem;padding-bottom:.5rem}.section-header h1{font-size:1.8rem;margin-bottom:.5rem}.section-header p{font-size:inherit;line-height:inherit}.content-area{margin-bottom:3rem}.subcategory-grid{gap:var(--spacing-sm);grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.content-area .task-card{padding:var(--spacing-md)}.content-area .task-card h3{font-size:var(--font-size-card-title)}.task-view .main-content h1{font-size:var(--font-size-display)!important}.task-view .main-content p{margin-bottom:var(--spacing-lg)!important}.reading-passage{margin-bottom:var(--spacing-2xl);padding:var(--spacing-lg)}.filter-bar,.subcategory-filter-header{align-items:center;flex-direction:row}.search-input{width:200px}.task-view .main-content{margin-top:0!important;min-height:calc(100dvh - 120px);min-height:calc(100dvh - var(--header-height, 120px));padding:0 0 var(--spacing-lg) 0!important}.task-view,[class*=task-view],body .task-view .main-content{margin-top:0!important}.task-view .main-content>div{padding:0 0 var(--spacing-lg) 0!important}.task-view .task-content{padding-top:calc(3.1rem + var(--spacing-md))}.home-hero{gap:clamp(var(--spacing-sm),4vh,var(--home-section-gap-max));gap:clamp(var(--home-section-gap-min),4vh,var(--home-section-gap-max));max-width:600px;padding-inline:0}.home-intro{gap:var(--spacing-2xl)}.nav-top{justify-content:flex-end}.navigation--home .nav-top{justify-content:stretch}.home-title{font-size:2.5rem}.home-stats{flex-direction:row;gap:var(--spacing-2xl);margin:0;padding:var(--spacing-lg) 0}.random-task-section{margin:0}.stat-number{font-size:2rem}.random-task-button{font-size:var(--font-size-body);min-width:260px;padding:var(--spacing-lg) var(--spacing-3xl)}.search-results-overlay{align-items:flex-start;padding-top:calc(var(--header-height, 188px) + var(--spacing-md))}.search-results-container{margin-inline:var(--spacing-lg);max-height:calc(100dvh - 188px - var(--spacing-2xl));max-height:calc(100dvh - var(--header-height, 188px) - var(--spacing-2xl));width:90%}.writing-textarea{min-height:300px}.passage-paragraph{text-align:justify}.mad-libs-story-image img,.picture-prompt-image img{max-height:300px}.completion-message .completion-buttons{flex-wrap:nowrap}.drag-drop-item-fine{cursor:grab}}.check-answers-btn,.mobile-tab-bar-link,.nav-link,.ordering-move-btn,.search-results-close,.subcategory-card,.view-toggle-button{min-height:44px}.header-bar .dark-mode-toggle{height:2.7rem;min-height:2.7rem;min-width:2.7rem;width:2.7rem}.nav-link{align-items:center;display:inline-flex;min-width:auto;padding:var(--spacing-sm) var(--spacing-xs)}.subcategory-card{min-width:44px}.search-results-close{width:44px}.exercise-questions label,.reading-questions label{align-items:flex-start;cursor:pointer;display:flex;gap:var(--spacing-sm);min-height:44px;padding:var(--spacing-sm) 0}.exercise-questions input[type=radio],.reading-questions input[type=radio]{flex-shrink:0;height:1.25rem;margin-top:.35rem;width:1.25rem}.ordering-list{padding-left:1.25rem}.ordering-item{align-items:center;display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs) 0}.ordering-item-text{flex:1 1}.ordering-item-controls{display:flex;gap:.25rem}.ordering-move-btn{background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;line-height:1;min-height:44px;min-width:44px;padding:var(--spacing-sm)}.ordering-move-btn:disabled{cursor:not-allowed;opacity:.5}button.task-card{appearance:none;-webkit-appearance:none;color:inherit;font:inherit;text-align:left;width:100%}button.task-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.drag-drop-zone{border:1px dashed var(--color-border);border-radius:var(--radius-md);min-height:60px;padding:var(--spacing-sm)}.drag-drop-zone-drop{min-height:80px}.drag-drop-zones-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.drag-drop-item{align-items:center;background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;margin-bottom:.4rem;min-height:44px;padding:var(--spacing-sm) var(--spacing-md)}.drag-drop-item-selected{outline:2px solid var(--color-accent);outline-offset:2px}.drag-drop-item-coarse{cursor:pointer}.drag-drop-tap-hint{color:var(--color-text-muted);font-size:var(--font-size-small);margin-bottom:var(--spacing-sm)}@media (pointer:coarse){.drag-drop-item[draggable=true]{cursor:pointer}}
/*# sourceMappingURL=main.8b03769c.css.map*/