:root{--accent: #2337ff;--accent-dark: #000d8a;--black: 15, 18, 25;--gray: 96, 115, 159;--gray-light: 229, 233, 240;--gray-dark: 34, 41, 57;--gray-gradient: rgba(var(--gray-light), 50%), #fff;--box-shadow: 0 2px 6px rgba(var(--gray), 25%), 0 8px 24px rgba(var(--gray), 33%), 0 16px 32px rgba(var(--gray), 33%);--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: rgb(15, 18, 25);--text-secondary: rgb(34, 41, 57);--text-muted: rgb(96, 115, 159);--border-color: #e2e8f0;--border-light: #f1f5f9}[data-theme=dark]{--accent: #6366f1;--accent-dark: #4f46e5;--black: 248, 250, 252;--gray: 148, 163, 184;--gray-light: 51, 65, 85;--gray-dark: 226, 232, 240;--gray-gradient: rgba(15, 23, 42, 50%), #0f172a;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: rgb(248, 250, 252);--text-secondary: rgb(226, 232, 240);--text-muted: rgb(148, 163, 184);--border-color: #334155;--border-light: #1e293b}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}body{font-family:Atkinson,sans-serif;margin:0;padding:0;text-align:left;background:linear-gradient(var(--gray-gradient)) no-repeat;background-color:var(--bg-primary);color:var(--text-primary);background-size:100% 600px;word-wrap:break-word;overflow-wrap:break-word;color:rgb(var(--gray-dark));font-size:20px;line-height:1.7}main{max-width:calc(100% - 2em);margin:auto;padding:3em 1em}article{width:720px;max-width:calc(100% - 2em);margin:auto;padding:3em 1em}h1,h2,h3,h4,h5,h6{margin:0 0 .5rem;color:rgb(var(--black));line-height:1.2}h1{font-size:3.052em}h2{font-size:2.441em}h3{font-size:1.953em}h4{font-size:1.563em}h5{font-size:1.25em}strong,b{font-weight:700}a,a:hover{color:var(--accent)}p{margin-bottom:1em}.prose p{margin-bottom:2em}textarea{width:100%;font-size:16px}input{font-size:16px}table{width:100%}img{max-width:100%;height:auto;border-radius:8px}img[width][height]{height:auto;aspect-ratio:attr(width) / attr(height)}.prose img[alt*=icon i],.prose img[src*=icon i]{object-fit:contain;max-height:none}code{padding:2px 5px;background-color:rgb(var(--gray-light));border-radius:2px}pre{padding:1.5em;border-radius:8px}pre>code{all:unset}blockquote{border-left:4px solid var(--accent);padding:0 0 0 20px;margin:0;font-size:1.333em}hr{border:none;border-top:1px solid rgb(var(--gray-light))}@media(max-width:720px){body{font-size:18px}main{padding:1em}}.sr-only{border:0;padding:0;margin:0;position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}.social-links{display:flex;justify-content:center;gap:1em;margin-top:1em}.social-links a{text-decoration:none;color:rgb(var(--gray))}.social-links a:hover{color:rgb(var(--gray-dark))}:where(a,button,input,select,textarea,summary,[role=button],[tabindex]:not([tabindex="-1"])):focus-visible{outline:3px solid var(--accent-dark);outline-offset:2px}.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:-1;background:var(--accent);color:#fff;border-radius:8px;padding:.5rem .75rem;text-decoration:none}.skip-link:focus-visible{position:fixed;left:1rem;top:1rem;width:auto;height:auto;z-index:2000;outline:3px solid var(--accent-dark);outline-offset:2px}.quiz-container{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:1.25rem;box-shadow:0 2px 8px #0000000d}.question-fieldset{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:1rem;margin:0 0 1rem}.question-legend{font-weight:600;color:rgb(var(--black));margin:0 0 .5rem;padding:0 .25rem}.options-wrapper{display:grid;gap:.5rem}.option-item{border:1px solid #e5e7eb;border-radius:10px;background:#f8fafc;padding:.75rem 1rem;transition:background .2s ease,border-color .2s ease,transform .06s ease;cursor:pointer}.option-item:hover{background:#eff6ff;border-color:#93c5fd}.option-item:active{transform:translateY(1px)}.option-item .flex{display:flex;align-items:center;gap:.75rem}.option-item label{color:#222939;cursor:pointer}.quiz-container input[type=radio],.quiz-container input[type=checkbox]{width:1.25rem;height:1.25rem;margin-top:0;accent-color:var(--accent)}.quiz-container .text-sm{font-size:.875rem}.quiz-container .text-slate-500{color:#60739f}.quiz-container .bg-green-100{background:#dcfce7}.quiz-container .text-green-700{color:#15803d}.quiz-container .bg-red-100{background:#fee2e2}.quiz-container .text-red-700{color:#b91c1c}[data-testid=quiz-submit-button]{appearance:none;border:0;border-radius:999px;background:var(--accent);color:#fff;padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;line-height:1;min-height:44px;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 2px 8px #00000026;cursor:pointer}[data-testid=quiz-submit-button]:hover{filter:brightness(.96)}[data-testid=quiz-submit-button]:focus-visible{outline:3px solid var(--accent-dark);outline-offset:2px}[data-testid=quiz-submit-button][disabled]{opacity:.6;cursor:not-allowed}[data-testid=quiz-retake-button]{appearance:none;border:1px solid #e2e8f0;border-radius:999px;background:#fff;color:rgb(var(--gray-dark));padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;line-height:1;min-height:44px;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 1px 3px #0000000f;cursor:pointer}[data-testid=quiz-retake-button]:hover{background:#f8fafc;border-color:#cbd5e1}[data-testid=quiz-retake-button]:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2337ff26}.mermaid{display:block;margin:1.5rem auto;text-align:center;max-width:100%;overflow-x:auto}.mermaid>svg{display:block;margin-left:auto;margin-right:auto;max-width:100%;height:auto}svg.mermaid{display:block;margin:1.5rem auto;max-width:100%;height:auto}.sw-update-banner,.sw-offline-banner{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:var(--box-shadow);z-index:9999;max-width:90vw}.sw-update-banner{background:var(--accent);color:#fff;border-color:var(--accent-dark)}.sw-offline-banner{background:#f59e0b;color:#fff;border-color:#d97706}.sw-update-btn{background:#fff;color:var(--accent);border:none;padding:.5rem 1rem;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease}.sw-update-btn:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.sw-notification{position:fixed;bottom:20px;right:20px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem 1.5rem;box-shadow:var(--box-shadow);z-index:9999;opacity:0;transform:translateY(100px);transition:all .3s ease}.sw-notification.show{opacity:1;transform:translateY(0)}.offline-downloader{margin:1rem 0}.download-btn,.remove-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.95rem}.download-btn{background:var(--accent);color:#fff}.download-btn:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.download-btn:disabled{opacity:.6;cursor:not-allowed}.remove-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.remove-btn:hover{background:var(--bg-tertiary);transform:translateY(-2px)}.download-btn svg,.remove-btn svg{width:20px;height:20px}.spinner{width:20px;height:20px;animation:spin 1s linear infinite}.spinner-circle{fill:none;stroke:currentColor;stroke-width:3;stroke-dasharray:50;stroke-dashoffset:25}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:640px){.sw-update-banner,.sw-offline-banner{bottom:10px;left:10px;right:10px;transform:none;max-width:none}.sw-notification{right:10px;left:10px}}.keyboard-shortcuts-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease-out}.keyboard-shortcuts-modal{background:var(--color-bg, white);color:var(--color-text, #1a1a1a);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-border, #e5e7eb)}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-muted, #6b7280);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .2s}.close-button:hover{background-color:var(--color-bg-secondary, #f3f4f6)}.shortcuts-content{overflow-y:auto;padding:0 24px 24px}.shortcuts-category{margin-top:24px}.shortcuts-category:first-child{margin-top:16px}.shortcuts-category h3{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted, #6b7280);margin:0 0 12px}.shortcuts-list{display:flex;flex-direction:column;gap:8px}.shortcut-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;border-radius:6px;transition:background-color .2s}.shortcut-item:hover{background-color:var(--color-bg-secondary, #f9fafb)}.shortcut-keys{display:flex;align-items:center;gap:4px;min-width:140px}.shortcut-keys kbd{background:var(--color-bg-tertiary, #e5e7eb);color:var(--color-text, #1a1a1a);border:1px solid var(--color-border, #d1d5db);border-radius:4px;padding:2px 8px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:.875rem;font-weight:500;box-shadow:0 1px 2px #0000000d}.key-separator{font-size:.75rem;color:var(--color-text-muted, #9ca3af);margin:0 4px}.shortcut-description{color:var(--color-text-secondary, #4b5563);font-size:.9375rem;text-align:right;flex:1}[data-theme=dark] .keyboard-shortcuts-modal{background:var(--color-bg, #1a1a1a);color:var(--color-text, #f3f4f6)}[data-theme=dark] .modal-header{border-bottom-color:var(--color-border, #374151)}[data-theme=dark] .shortcut-keys kbd{background:var(--color-bg-tertiary, #374151);color:var(--color-text, #f3f4f6);border-color:var(--color-border, #4b5563)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:640px){.keyboard-shortcuts-modal{max-height:90vh}.shortcut-item{flex-direction:column;align-items:flex-start;gap:4px}.shortcut-keys{min-width:unset}.shortcut-description{text-align:left}}@media print{header,footer,.course-navigation,.lesson-navigation,.share-buttons,.lesson-feedback,.toc-container,.breadcrumbs,nav,button:not(.print-button),.nav-button,.complete-lesson,.inline-module-nav{display:none!important}@page{margin:2cm;size:A4}body{background:#fff!important;color:#000!important;font-size:12pt;line-height:1.6}main,article,.lesson-content{max-width:100%!important;margin:0!important;padding:0!important}h1{font-size:24pt;page-break-after:avoid;margin-top:0}h2{font-size:18pt;page-break-after:avoid;margin-top:1em}h3{font-size:14pt;page-break-after:avoid}h4,h5,h6{font-size:12pt;page-break-after:avoid}p,li{orphans:3;widows:3}pre,code{background:#f5f5f5!important;border:1px solid #ddd!important;page-break-inside:avoid;font-size:10pt}pre{padding:1em;white-space:pre-wrap;word-wrap:break-word}img{max-width:100%!important;page-break-inside:avoid}a[href^=http]:after{content:" (" attr(href) ")";font-size:10pt;color:#666}a[href^="#"]:after,a[href^="/"]:after{content:""}table{border-collapse:collapse;width:100%;page-break-inside:avoid}th,td{border:1px solid #ddd;padding:8px;text-align:left}th{background:#f5f5f5!important;font-weight:700}blockquote{border-left:4px solid #ddd;padding-left:1em;margin:1em 0;font-style:italic;page-break-inside:avoid}ul,ol{page-break-inside:avoid}.quiz-container{border:2px solid #000;padding:1em;page-break-inside:avoid}.quiz-question{font-weight:700;margin-bottom:.5em}.quiz-options{list-style-type:none;padding-left:0}.quiz-option{padding:.25em 0}.print-header{display:block!important;text-align:center;margin-bottom:2em;padding-bottom:1em;border-bottom:2px solid #000}.print-footer{display:block!important;margin-top:2em;padding-top:1em;border-top:1px solid #ddd;font-size:10pt;color:#666}}.print-button{position:fixed;bottom:20px;right:20px;background:var(--accent);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:600;box-shadow:0 4px 12px #00000026;transition:all .2s ease;z-index:999}.print-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.print-button svg{width:20px;height:20px;margin-right:8px;vertical-align:middle}@media print{.print-button{display:none!important}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
