@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";:root{--color-sky-blue: #5BA3D1;--color-sky-blue-dark: #4A8FBD;--color-sky-blue-light: #8CC4E8;--color-sky-blue-pale: #E8F4FA;--color-navy: #2B4B6F;--color-navy-light: #3D6490;--color-accent-green: #7AC943;--color-accent-green-dark: #65B036;--color-accent-green-light: #C5E8A8;--color-fox-orange: #F97316;--color-fox-orange-dark: #EA580C;--color-fox-orange-light: #FDBA74;--color-fox-orange-pale: #FFF7ED;--color-warm-coral: #FB923C;--color-warm-cream: #FFFBEB;--color-white: #FFFFFF;--color-off-white: #F8FAFC;--color-slate-50: #F1F5F9;--color-slate-100: #E2E8F0;--color-slate-200: #CBD5E1;--color-slate-300: #94A3B8;--color-slate-400: #64748B;--color-slate-500: #475569;--color-slate-600: #334155;--color-slate-700: #1E293B;--color-error: #DC2626;--color-error-light: #FEE2E2;--color-success: #16A34A;--color-success-light: #DCFCE7;--color-processing: #5BA3D1;--color-processing-light: #E8F4FA;--font-heading: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .05em;--letter-spacing-wider: .1em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 2.5rem;--space-8: 3rem;--space-9: 4rem;--space-10: 5rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(43, 75, 111, .05);--shadow-md: 0 4px 6px -1px rgba(43, 75, 111, .1), 0 2px 4px -2px rgba(43, 75, 111, .1);--shadow-lg: 0 10px 15px -3px rgba(43, 75, 111, .1), 0 4px 6px -4px rgba(43, 75, 111, .1);--shadow-glass: 0 8px 32px rgba(43, 75, 111, .12);--shadow-button: 0 4px 14px rgba(91, 163, 209, .3);--shadow-button-green: 0 4px 14px rgba(122, 201, 67, .3);--shadow-button-orange: 0 4px 14px rgba(249, 115, 22, .35);--shadow-card: 0 2px 8px rgba(43, 75, 111, .06), 0 1px 3px rgba(43, 75, 111, .04);--shadow-card-hover: 0 8px 24px rgba(43, 75, 111, .1), 0 2px 8px rgba(43, 75, 111, .06);--glass-bg: rgba(255, 255, 255, .7);--glass-bg-light: rgba(255, 255, 255, .5);--glass-bg-medium: rgba(255, 255, 255, .75);--glass-bg-strong: rgba(255, 255, 255, .85);--glass-bg-heavy: rgba(255, 255, 255, .92);--glass-border: rgba(255, 255, 255, .5);--glass-blur: 12px;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 500;--z-modal: 1000;--z-toast: 1100;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--duration-quick: .15s;--duration-normal: .2s;--duration-slow: .3s;--hover-lift: translateY(-2px);--active-press: translateY(0)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-body);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-slate-700);background:linear-gradient(135deg,var(--color-sky-blue-pale) 0%,var(--color-off-white) 50%,#F0FDF4 100%);min-height:100vh;overflow-x:hidden;width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:var(--line-height-tight);color:var(--color-slate-700)}p{margin-bottom:var(--space-4)}p:last-child{margin-bottom:0}a{color:var(--color-sky-blue-dark);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-sky-blue)}::selection{background:var(--color-sky-blue-light);color:var(--color-navy)}:focus-visible{outline:2px solid var(--color-sky-blue);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-slate-100)}::-webkit-scrollbar-thumb{background:var(--color-slate-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-slate-400)}.glass-card{background:var(--glass-bg-strong);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-glass);border-radius:var(--radius-xl)}@media(max-width:640px){:root{--font-size-3xl: 1.75rem;--font-size-2xl: 1.375rem;--space-6: 1.5rem;--space-7: 2rem;--space-8: 2.5rem}}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.card{background:var(--color-white);border:1px solid var(--color-slate-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-normal),transform var(--transition-normal)}.card:hover{box-shadow:var(--shadow-card-hover)}.card-glass{background:var(--glass-bg-strong);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.focus-ring:focus-visible{outline:2px solid var(--color-sky-blue);outline-offset:2px;border-radius:var(--radius-md)}[id]{scroll-margin-top:80px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.btn-interactive{transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.btn-interactive:hover:not(:disabled){transform:var(--hover-lift)}.btn-interactive:active:not(:disabled){transform:var(--active-press)}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-slate-50);padding:var(--space-6);position:relative}.login-back-btn{position:absolute;top:var(--space-6);left:var(--space-6);display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-white);color:var(--color-slate-600);border:1px solid var(--color-slate-200);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.login-back-btn:hover{background:var(--color-slate-50);border-color:var(--color-slate-300);color:var(--color-slate-700)}.login-brand{text-align:center;margin-bottom:var(--space-7)}.brand-logo{display:block;width:80px;height:80px;margin:0 auto var(--space-4);object-fit:contain;filter:drop-shadow(0 4px 12px rgba(91,163,209,.3))}.brand-name{font-family:var(--font-heading);font-size:var(--font-size-3xl);font-weight:700;color:var(--color-navy);margin:0 0 var(--space-2);letter-spacing:var(--letter-spacing-tight)}.brand-tagline{font-family:var(--font-body);font-size:var(--font-size-sm);color:var(--color-slate-400);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;margin:0}.login-form{background:var(--glass-bg-strong);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));padding:var(--space-8);border-radius:var(--radius-xl);border:1px solid var(--glass-border);box-shadow:var(--shadow-glass);width:100%;max-width:380px;position:relative;overflow:hidden}.login-form:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--color-sky-blue)}.form-title{font-family:var(--font-heading);font-size:var(--font-size-2xl);font-weight:600;color:var(--color-navy);margin:0 0 var(--space-6);text-align:center}.form-group{margin-bottom:var(--space-5)}.form-group label{display:block;margin-bottom:var(--space-2);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:500;color:var(--color-slate-500);letter-spacing:var(--letter-spacing-wide);text-transform:uppercase}.form-group input{width:100%;padding:var(--space-4);border:1px solid var(--color-slate-200);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--font-size-base);color:var(--color-slate-700);background:var(--color-white);transition:border-color var(--transition-normal),box-shadow var(--transition-normal)}.form-group input::placeholder{color:var(--color-slate-400)}.form-group input:focus{outline:none;border-color:var(--color-sky-blue);box-shadow:0 0 0 3px #5ba3d133}.login-form button[type=submit]{width:100%;padding:var(--space-4);background:var(--color-sky-blue);color:var(--color-white);border:none;border-radius:var(--radius-lg);font-family:var(--font-body);font-size:var(--font-size-base);font-weight:600;cursor:pointer;margin-top:var(--space-4);box-shadow:var(--shadow-button);transition:all var(--transition-normal)}.login-form button[type=submit]:hover:not(:disabled){background:var(--color-sky-blue-dark);box-shadow:0 6px 20px #5ba3d166;transform:translateY(-1px)}.login-form button[type=submit]:active:not(:disabled){transform:translateY(0)}.login-form button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:var(--color-error-light);color:var(--color-error);padding:var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-5);text-align:center;font-size:var(--font-size-sm);border:1px solid rgba(220,38,38,.2)}.form-footer{text-align:center;margin-top:var(--space-5);font-size:var(--font-size-sm);color:var(--color-slate-500)}.form-link{background:none;border:none;padding:0;font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:600;color:var(--color-sky-blue);cursor:pointer;transition:color var(--transition-fast)}.form-link:hover{color:var(--color-sky-blue-dark);text-decoration:underline}.form-forgot{text-align:right;margin-top:calc(var(--space-2) * -1);margin-bottom:var(--space-4)}.form-description{font-size:var(--font-size-sm);color:var(--color-slate-500);text-align:center;margin-bottom:var(--space-5);line-height:1.5}.success-message{font-size:var(--font-size-sm);color:var(--color-slate-600);text-align:center;line-height:1.6;margin-bottom:var(--space-5)}.success-message strong{color:var(--color-slate-700)}.form-button-secondary{width:100%;padding:var(--space-4);background:var(--color-white);color:var(--color-sky-blue);border:2px solid var(--color-sky-blue);border-radius:var(--radius-lg);font-family:var(--font-body);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.form-button-secondary:hover{background:var(--color-sky-blue);color:var(--color-white)}@media(max-width:640px){.login-container{padding:var(--space-4)}.login-form{padding:var(--space-6)}.login-brand{margin-bottom:var(--space-5)}}.workspace{max-width:700px;margin:0 auto}.upload-zone{margin-bottom:1.5rem}.upload-zone input[type=file]{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.upload-zone label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3.5rem 2rem;border:2px dashed var(--color-sky-blue);border-radius:var(--radius-xl);background:radial-gradient(ellipse 80% 50% at 50% 120%,rgba(122,201,67,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 20% 0%,rgba(91,163,209,.1) 0%,transparent 50%),radial-gradient(ellipse 50% 30% at 80% 10%,rgba(249,115,22,.06) 0%,transparent 50%),linear-gradient(180deg,#5ba3d10a,#7ac94305);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.upload-zone label:before,.upload-zone label:after{content:"";position:absolute;width:48px;height:48px;border:3px solid var(--color-sky-blue-light);opacity:.5;transition:all .3s ease}.upload-zone label:before{top:16px;left:16px;border-right:none;border-bottom:none;border-radius:12px 0 0}.upload-zone label:after{bottom:16px;right:16px;border-left:none;border-top:none;border-radius:0 0 12px}.upload-zone label:hover{background:radial-gradient(ellipse 80% 50% at 50% 120%,rgba(122,201,67,.12) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 20% 0%,rgba(91,163,209,.15) 0%,transparent 50%),radial-gradient(ellipse 50% 30% at 80% 10%,rgba(249,115,22,.08) 0%,transparent 50%),linear-gradient(180deg,#5ba3d10f,#7ac9430a);border-color:var(--color-sky-blue-dark);border-style:solid;transform:translateY(-2px);box-shadow:0 8px 24px #5ba3d126}.upload-zone label:hover:before,.upload-zone label:hover:after{opacity:.8;border-color:var(--color-sky-blue)}.upload-zone label:hover:before{transform:translate(-4px,-4px)}.upload-zone label:hover:after{transform:translate(4px,4px)}.upload-zone label:focus-within{outline:2px solid var(--color-sky-blue);outline-offset:2px}.upload-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:1.25rem}.upload-icon-wrapper:before{content:"";position:absolute;inset:0;border-radius:50%;background:linear-gradient(135deg,var(--color-sky-blue-pale) 0%,rgba(122,201,67,.15) 100%);animation:iconPulse 3s ease-in-out infinite}.upload-icon-wrapper:after{content:"";position:absolute;inset:-6px;border:2px dashed var(--color-sky-blue-light);border-radius:50%;opacity:.6;animation:iconRingSpin 20s linear infinite}@keyframes iconPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}@keyframes iconRingSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.upload-icon{position:relative;z-index:1;font-size:2rem;font-weight:400;color:var(--color-sky-blue-dark);line-height:1;display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-white);border-radius:50%;box-shadow:0 4px 12px #5ba3d133;transition:all .3s ease}.upload-zone label:hover .upload-icon{transform:scale(1.08);box-shadow:0 6px 16px #5ba3d14d;color:var(--color-sky-blue)}.upload-text{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;color:var(--color-navy);letter-spacing:-.01em}.upload-hint{font-size:.85rem;color:var(--color-slate-400);margin-top:.5rem}.upload-hints{display:flex;justify-content:center;gap:2rem;padding-top:1.25rem;margin-top:.5rem;border-top:1px solid var(--color-slate-100)}.upload-hint-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:default}.upload-hint-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-white);border:1px solid var(--color-slate-100);border-radius:var(--radius-lg);color:var(--color-slate-400);transition:all .25s ease;box-shadow:0 2px 8px #2b4b6f0a}.upload-hint-item:hover .upload-hint-icon{background:var(--color-sky-blue-pale);border-color:var(--color-sky-blue-light);color:var(--color-sky-blue-dark);transform:translateY(-3px);box-shadow:0 6px 16px #5ba3d126}.upload-hint-icon svg{width:22px;height:22px}.upload-hint-label{font-size:.75rem;font-weight:500;color:var(--color-slate-400);text-align:center;transition:color .2s ease}.upload-hint-item:hover .upload-hint-label{color:var(--color-slate-600)}.error-banner{padding:1rem 1.25rem;background:var(--color-error-light);color:var(--color-error);border-left:3px solid var(--color-error);border-radius:0 var(--radius-md) var(--radius-md) 0;margin-bottom:1.5rem;font-size:.9rem}.error-banner p{margin:0}.error-banner details{margin-top:.75rem}.error-banner summary{cursor:pointer;font-weight:500;font-size:.85rem}.error-banner pre{margin-top:.5rem;padding:.75rem;background:var(--color-white);border-radius:4px;overflow-x:auto;font-family:var(--font-mono);font-size:.75rem;white-space:pre-wrap;word-break:break-word}.spinner{width:20px;height:20px;border:2px solid var(--color-slate-200);border-top-color:var(--color-sky-blue);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.upload-zone .spinner{width:28px;height:28px;margin-bottom:.75rem}.loading-message{animation:fadeIn .4s ease}.upload-zone .loading-message{font-size:1.125rem;font-weight:500;color:var(--color-slate-700)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.preview{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--color-slate-200);margin-bottom:2rem}.preview img{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.preview-name{font-size:.85rem;color:var(--color-slate-400)}.exercises-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--color-slate-200)}.exercises-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}.download-pdf-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:var(--font-body);font-size:.85rem;font-weight:600;color:var(--color-white);background:linear-gradient(135deg,var(--color-accent-green) 0%,var(--color-accent-green-dark) 100%);border:none;border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-button-green);transition:all .2s ease}.download-pdf-btn:hover{box-shadow:0 6px 20px #7ac94366;transform:translateY(-1px)}.download-pdf-btn:focus{outline:none}.download-pdf-btn:focus-visible{outline:2px solid var(--color-accent-green);outline-offset:2px}.download-pdf-btn:active{transform:translateY(0)}.download-pdf-btn svg{flex-shrink:0}.download-pdf-btn:disabled{opacity:.8;cursor:wait}.download-pdf-btn:disabled:hover{transform:none;box-shadow:var(--shadow-button-green)}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-white);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.language-badge{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-accent-green-dark);background:var(--color-accent-green-light);padding:.25rem .75rem;border-radius:100px}.topics{display:flex;flex-wrap:wrap;gap:.5rem}.topic{font-size:.8rem;color:var(--color-slate-500)}.topic:not(:last-child):after{content:"·";margin-left:.5rem;color:var(--color-slate-300)}.vocab-section{margin-bottom:2.5rem}.section-title{font-family:var(--font-body);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--color-slate-400);margin:0 0 1rem}.vocab-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin:0}.vocab-item{display:flex;flex-direction:column;gap:.25rem;padding:.75rem 1rem;background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-slate-100);transition:all .15s ease}.vocab-list dt{font-weight:600;font-size:.95rem;color:var(--color-navy)}.vocab-list dd{color:var(--color-slate-500);font-size:.875rem;margin:0;line-height:1.4}.exercise-list{display:flex;flex-direction:column;gap:2.5rem}.exercise-type{font-family:var(--font-body);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--color-navy);margin:0;padding-bottom:.5rem;border-bottom:2px solid var(--color-navy);display:inline-block}.exercise-instruction{font-style:italic;color:var(--color-slate-400);margin:.75rem 0 1.25rem;font-size:.9rem;line-height:1.5}.questions{display:flex;flex-direction:column}.question{padding:1rem 0 1rem 1.5rem;border-bottom:1px solid var(--color-slate-100);cursor:pointer;position:relative;transition:background .15s ease}.question:hover{background:#5ba3d10a}.question:focus{outline:none;background:#5ba3d10f}.options{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;margin-top:.75rem;padding-left:1.5rem}.answer{max-height:0;overflow:hidden;opacity:0;transition:all .25s ease;margin-top:0}.question.revealed .answer{max-height:150px;opacity:1;margin-top:1rem;padding:.875rem 1rem;background:var(--color-accent-green-light);border-radius:var(--radius-md);color:var(--color-accent-green-dark);font-size:.9rem;line-height:1.5}.results-summary{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-slate-100);margin-bottom:2rem}.results-thumbnail{width:64px;height:64px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.results-meta{display:flex;flex-direction:column;gap:.5rem;min-width:0;flex:1}.results-meta .topics{flex-wrap:wrap}.results-summary .download-pdf-btn{flex-shrink:0;align-self:center}.floating-download-btn{position:fixed;bottom:calc(56px + env(safe-area-inset-bottom,0px) + 1.5rem);right:1.5rem;display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-family:var(--font-body);font-size:.9rem;font-weight:600;color:var(--color-white);background:linear-gradient(135deg,var(--color-accent-green) 0%,var(--color-accent-green-dark) 100%);border:none;border-radius:var(--radius-lg);cursor:pointer;box-shadow:0 4px 20px #7ac94359;transition:box-shadow .2s ease,transform .2s ease;z-index:100;animation:floatBtnIn .3s ease-out}@keyframes floatBtnIn{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.floating-download-btn:hover{box-shadow:0 6px 24px #7ac94373;transform:translateY(-2px)}.floating-download-btn:focus{outline:none}.floating-download-btn:focus-visible{outline:2px solid var(--color-accent-green);outline-offset:2px}.floating-download-btn:active{transform:translateY(0)}.floating-download-btn svg{flex-shrink:0}.floating-download-btn:disabled{opacity:.8;cursor:wait}.floating-download-btn:disabled:hover{transform:none;box-shadow:0 4px 20px #7ac94359}.upload-zone--compact{margin-top:2.5rem;margin-bottom:4rem;animation:fadeSlideIn .4s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}.upload-zone--compact label{padding:1.5rem 2rem;border-style:dashed;background:#5ba3d105;flex-direction:row;gap:1rem}.upload-zone--compact label:before,.upload-zone--compact label:after{display:none}.upload-zone--compact label:hover{background:#5ba3d10f;transform:none;box-shadow:none}.upload-icon--compact{width:44px;height:44px;font-size:1.25rem;margin-bottom:0;box-shadow:0 2px 8px #5ba3d126}.upload-zone--compact .upload-text{font-size:1rem}.upload-zone--compact .upload-hint{font-size:.75rem;margin-top:.25rem}.batch-preview{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-slate-100);padding:1.5rem;margin-bottom:2rem}.batch-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.batch-title{font-size:1rem;font-weight:600;color:var(--color-slate-700);margin:0}.batch-clear-btn{font-family:var(--font-body);font-size:.85rem;color:var(--color-slate-400);background:none;border:none;cursor:pointer;padding:.25rem .5rem;transition:color .15s ease}.batch-clear-btn:hover{color:var(--color-error)}.batch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;margin-bottom:1.5rem}.batch-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.batch-thumbnail{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-slate-100)}.batch-remove-btn{position:absolute;top:-.5rem;right:-.5rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;color:var(--color-white);background:var(--color-error);border:2px solid var(--color-white);border-radius:50%;cursor:pointer;transition:transform .15s ease,background .15s ease}.batch-remove-btn:hover{transform:scale(1.1);background:#c53030}.batch-filename{font-size:.7rem;color:var(--color-slate-400);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-add-more{display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:1;border:2px dashed var(--color-slate-200);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;background:transparent}.batch-add-more:hover{border-color:var(--color-sky-blue);background:#5ba3d10d}.batch-add-more input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.add-more-icon{font-size:1.5rem;font-weight:300;color:var(--color-slate-400);line-height:1}.add-more-text{font-size:.7rem;color:var(--color-slate-400);margin-top:.25rem}.process-batch-btn{width:100%;padding:1rem 1.5rem;font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--color-white);background:linear-gradient(135deg,var(--color-sky-blue) 0%,var(--color-sky-blue-dark) 100%);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px #5ba3d159}.process-batch-btn:hover{box-shadow:0 6px 20px #5ba3d173;transform:translateY(-1px)}.process-batch-btn:active{transform:translateY(0)}.status-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-slate-100);padding:1.5rem;margin-bottom:2rem;animation:fadeSlideIn .3s ease-out}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.status-title{font-size:1rem;font-weight:600;color:var(--color-slate-700);margin:0}.status-clear-btn{font-family:var(--font-body);font-size:.85rem;color:var(--color-slate-400);background:none;border:none;cursor:pointer;padding:.25rem .5rem;transition:color .15s ease}.status-clear-btn:hover{color:var(--color-error)}.status-thumbnails{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem;margin-bottom:1.5rem}.status-thumb-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.status-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-slate-100);transition:transform .2s ease,box-shadow .2s ease}.status-thumb-wrapper:not(.status-thumb-locked):hover .status-thumb{transform:scale(1.02);box-shadow:var(--shadow-md)}.status-thumb-locked{pointer-events:none}.status-thumb-locked .status-thumb{opacity:.9}.status-thumb-locked:after{content:"";position:absolute;inset:0 0 24px;background:linear-gradient(90deg,transparent 0%,rgba(91,163,209,.15) 50%,transparent 100%);background-size:200px 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md);pointer-events:none}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.status-thumb-remove{position:absolute;top:-.5rem;right:-.5rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:600;color:var(--color-white);background:var(--color-error);border:2px solid var(--color-white);border-radius:50%;cursor:pointer;transition:transform .15s ease,background .15s ease,opacity .15s ease;opacity:0}.status-thumb-wrapper:hover .status-thumb-remove{opacity:1}.status-thumb-remove:hover{transform:scale(1.1);background:#c53030}.status-thumb-name{font-size:.7rem;color:var(--color-slate-400);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-add-more{display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:1;border:2px dashed var(--color-slate-200);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;background:transparent}.status-add-more:hover{border-color:var(--color-sky-blue);background:#5ba3d10d}.status-add-more input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.status-action{display:flex;flex-direction:column;align-items:stretch}.status-action>*{animation:contentFadeIn .3s ease-out}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stage-indicator{display:flex;align-items:flex-start;justify-content:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-slate-100)}.stage{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:80px}.stage-dot{width:24px;height:24px;border-radius:50%;background:var(--color-slate-200);display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative}.stage.active .stage-dot{background:var(--color-sky-blue);box-shadow:0 0 0 4px #5ba3d133;animation:stagePulse 2s ease-in-out infinite}@keyframes stagePulse{0%,to{box-shadow:0 0 0 4px #5ba3d133}50%{box-shadow:0 0 0 8px #5ba3d11a}}.stage.complete .stage-dot{background:var(--color-accent-green)}.stage-dot .check-icon{width:12px;height:12px;color:var(--color-white);animation:checkPop .3s ease-out}@keyframes checkPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.stage-connector{width:60px;height:2px;background:var(--color-slate-200);margin:11px .75rem 0;transition:background .5s ease;position:relative;overflow:hidden}.stage-connector.active{background:linear-gradient(90deg,var(--color-accent-green),var(--color-sky-blue))}.stage-connector.active:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:connectorGlow 1.5s ease-in-out infinite}@keyframes connectorGlow{0%{left:-100%}to{left:100%}}.stage-label{font-size:.7rem;font-weight:600;color:var(--color-slate-400);text-transform:uppercase;letter-spacing:.05em;transition:color .3s ease}.stage.active .stage-label{color:var(--color-sky-blue-dark)}.stage.complete .stage-label{color:var(--color-accent-green-dark)}.upload-progress-inline{width:100%}.upload-progress-inline .progress-bar{height:8px;background:var(--color-slate-100);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.upload-progress-inline .progress-fill{height:100%;background:linear-gradient(90deg,var(--color-sky-blue) 0%,var(--color-accent-green) 100%);border-radius:4px;transition:width .3s ease}.upload-progress-inline .progress-text{font-size:.85rem;color:var(--color-slate-500);text-align:center;display:block}.analyzing-indicator{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem 0}.analyzing-spinner{width:32px;height:32px;border:3px solid var(--color-slate-200);border-top-color:var(--color-sky-blue);border-radius:50%;animation:spin .8s linear infinite}.analyzing-message{font-size:.95rem;color:var(--color-slate-600);text-align:center;animation:fadeIn .4s ease}.upload-progress{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-slate-100);padding:1rem 1.25rem;margin-bottom:1rem}.progress-bar{height:8px;background:var(--color-slate-100);border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-sky-blue) 0%,var(--color-accent-green) 100%);border-radius:4px;transition:width .3s ease}.progress-text{font-size:.85rem;color:var(--color-slate-500)}.results-thumbnails{display:flex;align-items:center;flex-shrink:0}.results-thumbnails .results-thumbnail{width:48px;height:48px;margin-left:-12px;border:2px solid var(--color-white);box-shadow:var(--shadow-sm)}.results-thumbnails .results-thumbnail:first-child{margin-left:0}.results-more-count{width:48px;height:48px;margin-left:-12px;display:flex;align-items:center;justify-content:center;background:var(--color-slate-100);border:2px solid var(--color-white);border-radius:var(--radius-md);font-size:.75rem;font-weight:600;color:var(--color-slate-500)}.image-count-badge{font-size:.75rem;font-weight:500;color:var(--color-slate-500);background:var(--color-slate-100);padding:.2rem .6rem;border-radius:100px}@media(max-width:600px){.workspace{padding:0 1rem}.upload-zone label{padding:2.5rem 1.5rem}.upload-zone label:before,.upload-zone label:after{width:36px;height:36px}.upload-icon-wrapper{width:70px;height:70px}.upload-icon{width:56px;height:56px}.upload-icon svg{width:24px;height:24px}.upload-text{font-size:1.125rem}.upload-hints{gap:1.25rem;padding-top:1rem}.upload-hint-icon{width:40px;height:40px}.upload-hint-icon svg{width:18px;height:18px}.upload-hint-label{font-size:.7rem}.exercises-header{flex-direction:column;align-items:flex-start}.download-pdf-btn{width:100%;justify-content:center;padding:.75rem 1rem}.vocab-list{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.options{flex-direction:column;gap:.25rem}.results-summary{flex-direction:column;align-items:center;text-align:center}.results-meta{align-items:center}.results-meta .topics{justify-content:center}.results-summary .download-pdf-btn{width:100%;justify-content:center;margin-top:.5rem}.floating-download-btn{left:1rem;right:1rem;bottom:calc(52px + env(safe-area-inset-bottom,0px) + 1rem);justify-content:center}.upload-zone--compact{margin-bottom:5rem}.batch-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem}.batch-preview{padding:1rem}.process-batch-btn{font-size:.9rem;padding:.875rem 1rem}.status-card{padding:1rem}.status-thumbnails{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem}.stage-indicator{margin-bottom:1rem;padding-bottom:.75rem}.stage-connector{width:40px}.stage{min-width:60px}.stage-label{font-size:.65rem}.analyzing-indicator{padding:.75rem 0}.analyzing-message{font-size:.85rem}}.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--color-sky-blue-pale) 0%,var(--color-off-white) 50%,#F0FDF4 100%);width:100%;max-width:100vw;overflow-x:hidden}.header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:var(--glass-bg-heavy);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.6);box-shadow:0 1px 3px #2b4b6f0a,0 4px 16px #2b4b6f0a;position:sticky;top:0;z-index:var(--z-sticky)}.brand{display:flex;align-items:center;gap:.5rem}.brand-logo{width:40px;height:40px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(249,115,22,.15));transition:transform var(--transition-normal)}.brand:hover .brand-logo{transform:scale(1.05) rotate(-3deg)}.brand-name{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--color-navy);letter-spacing:-.02em}.user-section{display:flex;align-items:center;gap:.75rem}.user-email{font-size:.8rem;color:var(--color-slate-400);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sign-out{padding:.5rem 1rem;background:var(--color-white);color:var(--color-slate-500);border:1px solid var(--color-slate-200);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.8rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 1px 2px #2b4b6f0a}.sign-out:hover{background:var(--color-slate-50);border-color:var(--color-sky-blue);color:var(--color-sky-blue-dark);box-shadow:0 2px 4px #5ba3d11a}.main{flex:1;padding:3rem 2rem;padding-bottom:calc(56px + env(safe-area-inset-bottom,0px) + var(--space-6))}@media(max-width:600px){.header{padding:.75rem 1rem}.user-email{display:none}.main{padding:1.5rem 0;padding-bottom:calc(52px + env(safe-area-inset-bottom,0px) + var(--space-5))}}.history-card{display:flex;flex-direction:column;gap:.625rem;padding:1rem 1.125rem;margin:0 .75rem .625rem;background:#ffffffd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.7);border-radius:var(--radius-lg);box-shadow:0 1px 3px #2b4b6f0a,0 4px 12px #2b4b6f08;transition:all .2s ease;position:relative;width:auto;border-left:3px solid var(--color-sky-blue)}.history-card[data-language=Spanish]{border-left-color:#f59e0b}.history-card[data-language=French]{border-left-color:#3b82f6}.history-card[data-language=German]{border-left-color:#10b981}.history-card[data-language=Italian]{border-left-color:#8b5cf6}.history-card[data-language=Portuguese]{border-left-color:#06b6d4}.history-card[data-language=Japanese]{border-left-color:#ec4899}.history-card[data-language=Korean]{border-left-color:#f43f5e}.history-card[data-language=Chinese]{border-left-color:#ef4444}.history-card--clickable{cursor:pointer}.history-card--clickable:hover{background:#fffffff2;transform:translateY(-1px);box-shadow:0 4px 12px #2b4b6f14,0 8px 24px #2b4b6f0a}.history-card--clickable:focus{outline:none;background:#fffffff2}.history-card--clickable:active{transform:translateY(0);background:#ffffffe6}.history-card--failed{border-left-color:#dc2626;background:#fef2f2e6}.history-card__primary{display:flex;align-items:center;gap:.5rem;min-width:0}.history-card__language{flex-shrink:0;padding:.25rem .625rem;background:linear-gradient(135deg,var(--color-sky-blue) 0%,var(--color-sky-blue-dark) 100%);color:#fff;border-radius:var(--radius-full);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;box-shadow:0 2px 6px #5ba3d140}.history-card[data-language=Spanish] .history-card__language{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 6px #f59e0b4d}.history-card[data-language=French] .history-card__language{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 6px #3b82f64d}.history-card[data-language=German] .history-card__language{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 6px #10b9814d}.history-card[data-language=Italian] .history-card__language{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 2px 6px #8b5cf64d}.history-card[data-language=Portuguese] .history-card__language{background:linear-gradient(135deg,#06b6d4,#0891b2);box-shadow:0 2px 6px #06b6d44d}.history-card[data-language=Japanese] .history-card__language{background:linear-gradient(135deg,#ec4899,#db2777);box-shadow:0 2px 6px #ec48994d}.history-card[data-language=Korean] .history-card__language{background:linear-gradient(135deg,#f43f5e,#e11d48);box-shadow:0 2px 6px #f43f5e4d}.history-card[data-language=Chinese] .history-card__language{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 6px #ef44444d}.history-card__title{flex:1;font-family:var(--font-heading);font-size:.925rem;font-weight:600;color:var(--color-navy);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.history-card__delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;border-radius:4px;color:var(--color-slate-400);cursor:pointer;opacity:0;transform:translate(4px);transition:all .15s ease}.history-card:hover .history-card__delete,.history-card:focus-within .history-card__delete{opacity:1;transform:translate(0)}.history-card__delete:hover{background:#fee2e2;color:#dc2626}.history-card__delete:focus-visible{opacity:1;transform:translate(0);outline:2px solid #DC2626;outline-offset:1px}.history-card__secondary{display:flex;align-items:center;gap:.5rem;font-size:.75rem;min-height:1.25rem}.history-card__stats{display:flex;align-items:center;gap:.75rem}.history-card__stat{display:flex;align-items:center;gap:.3rem;color:var(--color-slate-500);font-size:.8rem}.history-card__stat-icon{width:14px;height:14px;color:var(--color-slate-400);flex-shrink:0}.history-card__stat strong{color:var(--color-navy);font-weight:600}.history-card__separator{color:var(--color-slate-300);margin:0 .25rem;display:none}.history-card__error{color:#dc2626;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px;font-size:.7rem}.history-card__spacer{flex:1}.history-card__meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.history-card__status{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .375rem;border-radius:100px;font-size:.6rem;font-weight:500;text-transform:uppercase;letter-spacing:.025em}.history-card__status--uploading{background:#dbeafe;color:#1e40af}.history-card__status--processing{background:#fef3c7;color:#92400e}.history-card__status--ready{background:#d1fae5;color:#065f46}.history-card__status--failed{background:#fee2e2;color:#991b1b}.history-card__spinner{width:8px;height:8px;border:1.5px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.history-card__date{color:var(--color-slate-400);font-size:.75rem}@media(hover:none){.history-card__delete{opacity:1;transform:translate(0)}}.history-main{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px) + var(--space-6))}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding:0 1rem 1rem;border-bottom:1px solid var(--color-slate-100)}.history-title{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--color-navy);margin:0;letter-spacing:-.02em}.history-count{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--color-slate-50);border-radius:var(--radius-full);font-size:.8rem;color:var(--color-slate-500);margin:0}.history-count strong{color:var(--color-navy);font-weight:600}.history-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--color-slate-400)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-slate-200);border-top-color:var(--color-sky-blue);border-radius:50%;animation:spin .8s linear infinite}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;background:var(--color-slate-50);border-radius:16px;color:var(--color-slate-300);margin-bottom:1.5rem}.empty-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;color:var(--color-navy);margin:0 0 .5rem}.empty-text{font-size:.95rem;color:var(--color-slate-400);margin:0}.history-grid{display:flex;flex-direction:column;gap:0;padding:.25rem 0}.history-load-more{display:flex;justify-content:center;padding:2rem 1rem}.load-more-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 2rem;background:#fff;color:var(--color-slate-600);border:1px solid var(--color-slate-200);border-radius:8px;font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.load-more-btn:hover:not(:disabled){background:var(--color-slate-50);border-color:var(--color-sky-blue);color:var(--color-sky-blue-dark)}.load-more-btn:disabled{opacity:.7;cursor:not-allowed}.btn-spinner{width:16px;height:16px;border:2px solid var(--color-slate-200);border-top-color:var(--color-sky-blue);border-radius:50%;animation:spin .8s linear infinite}.error-banner{margin:1rem;padding:1rem;background:#fef2f2;border:1px solid #FECACA;border-radius:8px;color:#991b1b;font-size:.9rem}@media(max-width:600px){.history-header{flex-direction:column;gap:.5rem;align-items:flex-start}.history-title{font-size:1.5rem}}.detail-main{max-width:800px;margin:0 auto;overflow-x:hidden}.detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:var(--color-slate-400)}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;padding:0 1rem 1.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-slate-100)}.detail-info{flex:1;min-width:0}.detail-title{font-family:var(--font-heading);font-size:1.375rem;font-weight:700;color:var(--color-navy);margin:0 0 .75rem;line-height:1.3;letter-spacing:-.01em}.detail-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.detail-date{font-size:.85rem;color:var(--color-slate-400)}.detail-topics{display:flex;flex-wrap:wrap;gap:.375rem}.topic{display:inline-block;padding:.3rem .75rem;background:var(--color-white);color:var(--color-slate-600);border:1px solid var(--color-slate-200);border-radius:var(--radius-md);font-size:.75rem;font-weight:500;transition:all .15s ease}.topic:hover{background:var(--color-sky-blue-pale);border-color:var(--color-sky-blue-light);color:var(--color-sky-blue-dark)}.detail-actions{display:flex;flex-direction:column;gap:.5rem;flex-shrink:0}.download-pdf-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,var(--color-accent-green) 0%,var(--color-accent-green-dark) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 8px #7ac9434d}.download-pdf-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #7ac94366}.download-pdf-btn:active:not(:disabled){transform:translateY(0)}.download-pdf-btn:disabled{opacity:.8;cursor:not-allowed}.download-pdf-btn.loading{background:var(--color-slate-400);box-shadow:none}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.delete-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;background:var(--color-slate-50);color:var(--color-slate-500);border:1px solid var(--color-slate-200);border-radius:var(--radius-lg);font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.delete-btn:hover{background:#fee2e2;border-color:#fecaca;color:#dc2626}.exercise-type{font-family:var(--font-heading);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-sky-blue-dark);margin:0;padding:.5rem 0 .75rem;border-bottom:2px solid var(--color-sky-blue);display:inline-block;margin-bottom:.75rem}.exercise-instruction{font-size:.9rem;font-style:italic;color:var(--color-slate-500);margin:0 0 1.25rem;padding-bottom:1rem;border-bottom:1px dashed var(--color-slate-200);line-height:1.5}.questions{display:flex;flex-direction:column;gap:0}.question{padding:1rem 1.25rem;margin:0 -1.5rem;background:transparent;border-bottom:1px solid var(--color-slate-100);cursor:pointer;transition:all .15s ease;position:relative}.question:last-child{border-bottom:none}.question:hover{background:var(--color-slate-50)}.question:focus{outline:none;background:var(--color-slate-50)}.question:focus-visible{outline:2px solid var(--color-sky-blue);outline-offset:-2px}.question:before{content:"+";position:absolute;left:0;top:1rem;font-size:1rem;font-weight:500;color:var(--color-sky-blue);transition:transform .2s ease}.question.revealed:before{content:"−"}.question-content{display:flex;gap:.5rem;line-height:1.6}.q-num{font-weight:600;color:var(--color-sky-blue-dark);flex-shrink:0}.q-text{color:var(--color-slate-700)}.options{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;margin-top:.75rem;padding-left:1.5rem}.option{font-size:.9rem;color:var(--color-slate-500)}.answer{margin-top:0;padding:0;font-size:.9rem;color:var(--color-accent-green-dark);opacity:0;max-height:0;overflow:hidden;transition:all .25s ease}.question.revealed .answer{opacity:1;max-height:150px;margin-top:1rem;padding:.875rem 1rem;background:linear-gradient(135deg,var(--color-accent-green-light) 0%,rgba(122,201,67,.15) 100%);border-radius:var(--radius-md);border-left:3px solid var(--color-accent-green)}.answer strong{font-weight:600}.language-badge{display:inline-flex;align-items:center;padding:.375rem .75rem;background:linear-gradient(135deg,var(--color-sky-blue-pale) 0%,rgba(122,201,67,.1) 100%);color:var(--color-navy);border-radius:var(--radius-full);font-size:.8rem;font-weight:600;border:1px solid rgba(91,163,209,.2)}.error-banner{margin:1rem;padding:1rem;background:#fef2f2;border:1px solid #FECACA;border-radius:var(--radius-lg);color:#991b1b;font-size:.9rem}.card-carousel{display:flex;flex-direction:column;gap:1.25rem;margin:0 1rem}.carousel-card{background:var(--color-white);border:1px solid var(--color-slate-100);border-radius:var(--radius-xl);padding:0;overflow:hidden;box-shadow:0 2px 8px #2b4b6f0a}.carousel-card>h3.exercise-type,.carousel-card>.card-title{margin:0;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--color-sky-blue-pale) 0%,rgba(122,201,67,.08) 100%);border-bottom:1px solid var(--color-slate-100)}.carousel-card>h3.exercise-type{border-bottom-width:0;padding-bottom:.75rem}.carousel-card>p.exercise-instruction{padding:0 1.5rem 1rem;margin:0;border-bottom:1px solid var(--color-slate-100)}.carousel-card>.questions{padding:.5rem 0}.carousel-card>.questions .question{margin:0;padding-left:2rem;padding-right:1.5rem}.carousel-card>.questions .question:before{left:1rem}.card-title{font-family:var(--font-heading);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-navy);display:flex;align-items:center;gap:.75rem}.card-title:after{content:"";flex:1;height:1px;background:var(--color-slate-200)}.vocab-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin:0;padding:1.25rem 1.5rem}.vocab-item{padding:.875rem 1rem;background:linear-gradient(135deg,var(--color-slate-50) 0%,var(--color-white) 100%);border:1px solid var(--color-slate-100);border-radius:var(--radius-lg);transition:all .2s ease}.vocab-item:hover{border-color:var(--color-sky-blue-light);box-shadow:0 2px 8px #5ba3d11a}.vocab-item dt{font-weight:600;font-size:.95rem;color:var(--color-navy);margin-bottom:.25rem}.vocab-item dd{margin:0;font-size:.85rem;color:var(--color-slate-500);line-height:1.4}@media(max-width:600px){.detail-header{flex-direction:column}.detail-actions{flex-direction:row;width:100%}.detail-actions button{flex:1;justify-content:center}.card-carousel{flex-direction:row;width:100%;max-width:100vw;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;gap:.5rem;padding:0 .5rem 1rem;margin:0;scrollbar-width:none;-ms-overflow-style:none}.card-carousel::-webkit-scrollbar{display:none}.carousel-card{flex:0 0 92%;scroll-snap-align:center;padding:1rem}.vocab-list{grid-template-columns:1fr}}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:stretch;background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.6);box-shadow:0 -1px 3px #2b4b6f0a,0 -4px 16px #2b4b6f0a;padding-bottom:env(safe-area-inset-bottom,0);z-index:1000}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.625rem .5rem;min-height:56px;background:transparent;border:none;cursor:pointer;color:var(--color-slate-400);position:relative;-webkit-tap-highlight-color:transparent;transition:color .2s ease}.tab-item:hover{color:var(--color-slate-500)}.tab-item:focus-visible{outline:2px solid var(--color-sky-blue);outline-offset:-2px;border-radius:var(--radius-md)}.tab-item--active{color:var(--color-sky-blue-dark)}.tab-item--active:before{content:"";position:absolute;top:6px;left:50%;transform:translate(-50%);width:5px;height:5px;background:var(--color-sky-blue);border-radius:50%;animation:dotPop .2s ease-out}@keyframes dotPop{0%{transform:translate(-50%) scale(0)}50%{transform:translate(-50%) scale(1.2)}to{transform:translate(-50%) scale(1)}}.tab-item--active:hover{color:var(--color-sky-blue-dark)}.tab-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);transition:all .2s ease}.tab-item--active .tab-icon{background:var(--color-sky-blue-pale)}.tab-icon svg{width:22px;height:22px;transition:transform .2s ease}.tab-item--active .tab-icon svg{transform:scale(1.05)}.tab-label{font-family:var(--font-body);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}@media(max-width:600px){.tab-item{padding:.5rem .25rem;min-height:52px}.tab-icon{width:28px;height:28px}.tab-icon svg{width:20px;height:20px}}.install-prompt{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0));background:var(--color-white);border-top-left-radius:var(--radius-xl);border-top-right-radius:var(--radius-xl);box-shadow:0 -4px 20px #2b4b6f26;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-prompt-content{display:flex;align-items:center;gap:var(--space-3)}.install-prompt-icon{flex-shrink:0;width:48px;height:48px;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-md)}.install-prompt-icon img{width:100%;height:100%;object-fit:cover}.install-prompt-text{flex:1;min-width:0}.install-prompt-text h3{font-family:var(--font-heading);font-size:var(--font-size-base);font-weight:600;color:var(--color-slate-700);margin:0 0 var(--space-1)}.install-prompt-text p{font-family:var(--font-body);font-size:var(--font-size-sm);color:var(--color-slate-400);margin:0;line-height:var(--line-height-normal)}.install-prompt-share-icon{display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;color:var(--color-sky-blue)}.install-prompt-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.install-prompt-btn{display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .2s ease;font-family:var(--font-body)}.install-prompt-btn-primary{padding:var(--space-2) var(--space-4);background:var(--color-sky-blue);color:var(--color-white);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-full);box-shadow:var(--shadow-button)}.install-prompt-btn-primary:hover{background:var(--color-sky-blue-dark);transform:translateY(-1px)}.install-prompt-btn-primary:active{transform:translateY(0)}.install-prompt-btn-secondary{width:36px;height:36px;background:var(--color-slate-50);color:var(--color-slate-400);border-radius:var(--radius-full)}.install-prompt-btn-secondary:hover{background:var(--color-slate-100);color:var(--color-slate-500)}.install-prompt-never{display:block;width:100%;margin-top:var(--space-3);padding:var(--space-2);background:none;border:none;font-family:var(--font-body);font-size:var(--font-size-xs);color:var(--color-slate-300);text-align:center;cursor:pointer;transition:color .2s ease}.install-prompt-never:hover{color:var(--color-slate-400)}
