:root{--color-blue-light: #CCF4FF;--color-blue-mid: #00C8FF;--color-blue-dark: #00A0CC;--color-green-light: #E7FF99;--color-green-mid: #A4D600;--color-green-dark: #89B300;--color-yellow-light: #FFF1B3;--color-yellow-mid: #ffbf00;--color-yellow-dark: #CCA700;--color-gray-light: #F6F6F3;--color-gray-mid: #E2E2E2;--color-gray-dark: #B3B3B3;--color-orange-light: #F9CFB9;--color-orange-mid: #EE7D3F;--color-orange-dark: #CC6B36;--color-red-light: #F7AAA1;--color-red-mid: #ED4634;--color-red-dark: #CC3C2D;--color-purple-light: #DA96E8;--color-purple-mid: #df3fff;--color-purple-dark: #b62fd1;--color-pink-light: #FFD6E8;--color-pink-mid: #FF6EB4;--color-pink-dark: #E04A92;--color-teal-light: #B2DFDB;--color-teal-mid: #00baa8;--color-teal-dark: #008d7c;--color-indigo-light: #b8b7ff;--color-indigo-mid: #5838f8;--color-indigo-dark: #462ad1;--color-black: #2a2a2a;--color-white: #ffffff;--color-shop-backdrop: #9e9e9e;--color-shop-awning-light: #c0392b;--color-shop-awning-dark: #992d22}*{-webkit-tap-highlight-color:transparent}@font-face{font-family:Roboto Mono;src:url(/assets/fonts/Roboto_Mono/RobotoMono-VariableFont_wght.ttf) format("truetype");font-weight:100 700;font-style:normal;font-display:swap}@font-face{font-family:Roboto Mono;src:url(/assets/fonts/Roboto_Mono/RobotoMono-Italic-VariableFont_wght.ttf) format("truetype");font-weight:100 700;font-style:italic;font-display:swap}@font-face{font-family:"Noto Color Emoji";src:url(/assets/fonts/Noto_Color_Emoji/NotoColorEmoji-Regular.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Fira Code;src:url(/assets/fonts/Fira_Code/FiraCode-VariableFont_wght.ttf) format("truetype");font-weight:300 700;font-style:normal;font-display:swap}.container{display:flex;flex-direction:column;height:100dvh;width:100dvw;max-width:600px;margin:0 auto;overflow:hidden;background-color:var(--color-gray-light);box-shadow:0 0 20px #0000001a;position:relative}header{min-height:72px;width:100%;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:10px 20px 0;gap:8px;background-color:var(--color-white);z-index:10}main{flex-grow:1;width:100%;overflow-y:auto;padding:0 20px 20px;background-color:var(--color-white);-webkit-overflow-scrolling:touch}footer{height:60px;width:100%;flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:10px;background-color:var(--color-white);z-index:5}footer:empty{display:none}main>*{max-width:100%}.pill{display:inline-flex;align-items:stretch;border-radius:12px;overflow:hidden;font-weight:700;font-size:16px;color:#fff;min-width:80px;height:48px;box-sizing:border-box;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000a}.pill-icon{display:flex;align-items:center;justify-content:center;padding:0 12px}.pill-text{display:flex;align-items:center;justify-content:center;padding:0 16px;flex-grow:1;text-align:center}.pill.yellow{background-color:var(--color-yellow-mid)}.pill.yellow .pill-icon{background-color:#fff3}.pill.green{background-color:var(--color-green-mid);color:#fff}.pill.green .pill-icon{background-color:#fff3}.pill.orange{background-color:var(--color-orange-mid);color:#fff}.pill.orange .pill-icon{background-color:#fff3}.pill.red{background-color:var(--color-red-mid);color:#fff}.pill.red .pill-icon{background-color:#fff3}.pill.blue{background-color:var(--color-blue-mid);color:var(--color-black)}.pill.blue .pill-icon{background-color:#fff3}.pill.purple{background-color:var(--color-purple-mid);color:#fff}.pill.purple .pill-icon{background-color:#fff3}.pill.teal{background-color:var(--color-teal-mid);color:#fff}.pill.teal .pill-icon{background-color:#fff3}.word-tile{width:40px;height:40px;background-color:var(--color-gray-mid);border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:var(--color-black);cursor:pointer;position:relative;box-sizing:border-box;z-index:1;-webkit-user-select:none;user-select:none;box-shadow:0 4px 0 var(--color-gray-light);transition:transform 80ms ease,box-shadow 80ms ease}.word-tile:active,.word-tile.pressed{transform:scale(.92);box-shadow:0 1px 0 var(--color-gray-light)}.word-tile.correct{background-color:var(--color-green-mid);box-shadow:0 4px 0 var(--color-green-light)}.word-tile.correct:active,.word-tile.correct.pressed{box-shadow:0 1px 0 var(--color-green-light)}.word-tile.wrong{background-color:var(--color-red-mid);box-shadow:0 4px 0 var(--color-red-light)}.word-tile.wrong:active,.word-tile.wrong.pressed{box-shadow:0 1px 0 var(--color-red-light)}.level-tile{width:60px;height:60px;background-color:var(--color-gray-mid);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:24px;color:var(--color-black);cursor:pointer;position:relative;border:solid transparent;border-width:0 0 4px;box-sizing:border-box;transform:translateZ(0);-webkit-user-select:none;user-select:none;z-index:1}.level-tile:after{background-clip:padding-box;background-color:var(--color-gray-light);border:solid transparent;border-width:0 0 4px;content:"";inset:0 0 -4px;position:absolute;z-index:-1;border-radius:14px}.level-tile:active,.level-tile.pressed{border-width:4px 0 0;background-color:transparent!important;transform:none}.level-tile.gift-tile{background-color:var(--color-orange-dark);color:var(--color-white)}.level-tile.gift-tile:after{background-color:var(--color-orange-mid)}.level-tile.eagerness-tile{background-color:var(--color-yellow-dark);color:var(--color-white)}.level-tile.eagerness-tile:after{background-color:var(--color-yellow-mid)}.level-tile.locked{opacity:.35;cursor:not-allowed;pointer-events:none}.level-tile.locked:after{background-color:var(--color-gray-light)}.level-tile.gift-tile.locked,.level-tile.eagerness-tile.locked{background-color:var(--color-gray-mid);color:var(--color-gray-dark)}.level-tile.gift-tile.locked:after,.level-tile.eagerness-tile.locked:after{background-color:var(--color-gray-light)}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;font-weight:700;font-size:16px;outline:none;transition:transform .1s ease,border-width .1s ease;-webkit-user-select:none;user-select:none;font-family:inherit}.btn.w-full{width:100%}.btn-primary,.btn-icon-square{position:relative;border:solid transparent;border-width:0 0 4px;box-sizing:border-box;transform:translateZ(0);box-shadow:none;margin-bottom:0;z-index:1}.btn-primary:after,.btn-icon-square:after{background-clip:padding-box;border:solid transparent;border-width:0 0 4px;content:"";inset:0 0 -4px;position:absolute;z-index:-1}.btn-primary:active,.btn-icon-square:active{border-width:4px 0 0;background-color:transparent!important;transform:none}.btn-primary{width:100%;padding:12px;border-radius:12px;color:#fff}.btn-primary:after{border-radius:12px}.btn-primary.green{background-color:var(--color-green-dark)}.btn-primary.green:after{background-color:var(--color-green-mid)}.btn-primary.brown,.btn-primary.red{background-color:var(--color-orange-dark)}.btn-primary.brown:after,.btn-primary.red:after{background-color:var(--color-orange-mid)}.btn-icon-square{width:48px;height:48px;border-radius:12px;color:#fff}.btn-icon-square:after{border-radius:12px}.btn-icon-square.blue{background-color:var(--color-blue-dark)}.btn-icon-square.blue:after{background-color:var(--color-blue-mid)}.btn-icon-square.brown{background-color:var(--color-orange-dark)}.btn-icon-square.brown:after{background-color:var(--color-orange-mid)}.btn-icon-square.red{background-color:var(--color-red-dark)}.btn-icon-square.red:after{background-color:var(--color-red-mid)}.btn-icon-square.yellow{background-color:var(--color-yellow-dark)}.btn-icon-square.yellow:after{background-color:var(--color-yellow-mid)}.btn-icon-square.green{background-color:var(--color-green-dark)}.btn-icon-square.green:after{background-color:var(--color-green-mid)}.btn-icon-square.orange{background-color:var(--color-orange-dark)}.btn-icon-square.orange:after{background-color:var(--color-orange-mid)}.btn-icon-square.purple{background-color:var(--color-purple-dark)}.btn-icon-square.purple:after{background-color:var(--color-purple-mid)}.btn-icon-square.teal{background-color:var(--color-teal-dark)}.btn-icon-square.teal:after{background-color:var(--color-teal-mid)}.btn-primary.blue{background-color:var(--color-blue-dark)}.btn-primary.blue:after{background-color:var(--color-blue-mid)}.btn-primary.teal{background-color:var(--color-teal-dark)}.btn-primary.teal:after{background-color:var(--color-teal-mid)}.btn-primary.danger{background-color:var(--color-red-dark)}.btn-primary.danger:after{background-color:var(--color-red-mid)}.btn-secondary{width:100%;padding:12px;border-radius:12px;background-color:transparent;color:var(--color-black);border:2px solid var(--color-gray-mid)}.btn-secondary:active{background-color:var(--color-gray-mid)}.btn-list{width:100%;padding:12px;background-color:var(--color-gray-light);border-radius:12px;font-weight:400;color:var(--color-black);justify-content:space-between;text-align:left;border:1px solid var(--color-gray-mid);box-shadow:0 4px 6px -1px #0000000d}.btn-list .btn-list-content{display:flex;align-items:center;gap:16px}.btn-list:active{background-color:var(--color-gray-mid);transform:scale(.98)}.label{display:inline-flex;align-items:center;gap:8px;padding:4px 12px;background-color:var(--color-gray-light);border-radius:8px;font-size:14px;font-weight:600;color:var(--color-black);border:1px solid var(--color-gray-mid)}.label i{width:16px;height:16px}.word-block{background-color:var(--color-gray-light);border-radius:12px;padding:24px;margin-bottom:16px;border:1px solid var(--color-gray-mid)}.word-block-header{display:flex;align-items:center;gap:8px;font-weight:800;font-size:14px;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}.word-block-content{font-size:16px;line-height:1.6;color:var(--color-black)}.word-block.lessons .word-block-header{color:var(--color-blue-dark)}.word-block.reflection .word-block-header{color:var(--color-red-dark)}.word-block.challenge .word-block-header{color:var(--color-orange-dark)}.modal-backdrop{position:fixed;inset:0;background-color:#2a2a2a80;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;animation:fadeIn .3s ease-out forwards}.modal-backdrop.is-closing{animation:fadeOut .4s ease-in forwards}@keyframes fadeIn{0%{background-color:#2a2a2a00}to{background-color:#2a2a2a80}}@keyframes fadeOut{0%{background-color:#2a2a2a80}to{background-color:#2a2a2a00}}.modal-card{background-color:var(--color-gray-light);border-radius:24px;padding:60px 24px 24px;width:100%;max-width:400px;position:relative;text-align:center;border:1px solid var(--color-gray-mid);border-bottom:6px solid var(--color-gray-mid);animation:bounceInDown .6s cubic-bezier(.215,.61,.355,1) forwards}.modal-backdrop.is-closing .modal-card{animation:pullUpOut .4s ease-in forwards}@keyframes bounceInDown{0%{opacity:0;transform:translateY(-800px)}60%{opacity:1;transform:translateY(25px)}80%{transform:translateY(-10px)}to{transform:translateY(0)}}@keyframes pullUpOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(-800px);opacity:0}}.modal-badge{position:absolute;top:-32px;left:50%;transform:translate(-50%);width:64px;height:64px;border-radius:50%;background-color:var(--color-gray-mid);color:var(--color-black);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;border:4px solid var(--color-gray-light)}.modal-badge i,.modal-badge svg{width:32px;height:32px}.modal-badge.blue{background-color:var(--color-blue-mid);color:var(--color-black)}.modal-badge.green{background-color:var(--color-green-mid);color:var(--color-black)}.modal-badge.yellow{background-color:var(--color-yellow-mid);color:var(--color-black)}.modal-badge.gray{background-color:var(--color-gray-mid);color:var(--color-black)}.modal-badge.purple{background-color:var(--color-purple-mid);color:var(--color-black)}.modal-badge.red{background-color:var(--color-red-mid);color:var(--color-white)}.modal-title{font-size:24px;font-weight:800;color:var(--color-black);margin-bottom:8px}.modal-subtitle{font-size:16px;color:var(--color-black);margin-bottom:24px}.modal-backdrop.bottom .modal-card{margin-top:auto;margin-bottom:-20px;border-bottom-left-radius:0;border-bottom-right-radius:0;max-width:600px}.selection-card{background-color:var(--color-gray-light);border-radius:20px;padding:24px;text-align:left;border:1px solid var(--color-gray-mid);box-shadow:0 4px 6px -1px #0000000d}.selection-card-title{font-size:14px;font-weight:600;color:var(--color-gray-dark);margin-bottom:16px}.selection-option{display:flex;align-items:center;gap:16px;padding:12px 0;cursor:pointer}.selection-radio{width:24px;height:24px;border-radius:50%;border:2px solid var(--color-gray-mid);display:flex;align-items:center;justify-content:center}.selection-option.selected .selection-radio{border-color:var(--color-blue-mid)}.selection-option.selected .selection-radio:after{content:"";width:12px;height:12px;background-color:var(--color-blue-mid);border-radius:50%}.selection-footer-text{font-size:12px;color:var(--color-gray-dark);margin-top:16px;line-height:1.4}.game-tile-wrapper{display:flex;flex-direction:column;align-items:center;gap:12px}.game-tile{width:100%;aspect-ratio:1;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;background-color:var(--bg-color);box-shadow:0 6px 0 var(--border-color);margin-bottom:6px;transition:transform .1s,box-shadow .1s;color:var(--color-black)}.game-tile:active{transform:translateY(6px);box-shadow:0 0 0 var(--border-color);margin-bottom:6px}.game-tile i,.game-tile svg{width:32px;height:32px}.game-tile.blue{--bg-color: var(--color-blue-mid);--border-color: var(--color-blue-dark)}.game-tile.green{--bg-color: var(--color-green-mid);--border-color: var(--color-green-dark)}.game-tile.yellow{--bg-color: var(--color-yellow-mid);--border-color: var(--color-yellow-dark)}.game-tile.gray{--bg-color: var(--color-gray-mid);--border-color: var(--color-gray-dark)}.game-tile.purple{--bg-color: var(--color-purple-mid);--border-color: var(--color-purple-dark)}.game-tile.pink{--bg-color: var(--color-pink-mid);--border-color: var(--color-pink-dark)}.game-tile.teal{--bg-color: var(--color-teal-mid);--border-color: var(--color-teal-dark)}.game-tile-title{font-size:14px;font-weight:500;color:var(--color-black);text-align:center;font-family:inherit;min-height:18px}.game-tile-subtitle{font-size:11px;font-weight:600;color:var(--color-gray-dark);text-align:center;font-family:inherit;margin-top:-6px}.choice-tile{display:flex;align-items:center;justify-content:center;background-color:var(--color-gray-mid);border-radius:16px;border:none;border-bottom:5px solid var(--color-gray-dark);cursor:pointer;font-family:Fira Code,monospace;font-size:clamp(1rem,2.7vw,1.2rem);font-weight:600;color:var(--color-black);text-align:center;padding:12px;line-height:1.3;transition:background-color .15s ease,border-color .15s ease,transform .1s ease;width:100%;height:100%;min-height:0;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.choice-tile:active:not([disabled]){transform:translateY(3px);border-bottom-width:2px}.choice-tile.correct{background-color:var(--color-green-mid);border-bottom-color:var(--color-green-dark);color:var(--color-black);pointer-events:none}.choice-tile.wrong{background-color:var(--color-red-mid);border-bottom-color:var(--color-red-dark);color:#fff;pointer-events:none}.choice-tile.faded{opacity:.4;pointer-events:none}.choice-tile[disabled]{cursor:default}.progress-dots{display:flex;align-items:center;justify-content:space-evenly;gap:0;flex-wrap:nowrap;width:100%}.progress-dot{width:14px;height:14px;border-radius:50%;background-color:var(--color-gray-mid);border:3px solid transparent;transition:background-color .2s ease,border-color .2s ease,transform .2s ease;flex-shrink:0}.progress-dot.current{border-color:var(--color-black);background-color:var(--color-gray-light);transform:scale(1.15)}.progress-dot.correct{background-color:var(--color-yellow-mid);border-color:transparent}.progress-dot.wrong{background-color:var(--color-red-mid);border-color:transparent}.footer-tab-bar{display:flex;width:100%;height:60px;overflow:hidden}.footer-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;border-right:1px solid rgba(0,0,0,.2);cursor:pointer;font-family:inherit;color:#ffffffb3;background-color:var(--color-orange-dark);position:relative;overflow:hidden}.footer-tab.active{background-color:var(--color-orange-mid);color:#fff}.footer-tab-first{border-top-left-radius:0}.footer-tab-last{border-top-right-radius:0;border-right:none}.footer-tab i,.footer-tab svg{width:22px;height:22px}.footer-tab-label{font-size:10px;font-weight:700;letter-spacing:.5px}.footer-tab.active:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);animation:footerShine 2s ease-in-out infinite}@keyframes footerShine{0%{left:-100%}to{left:100%}}.keyboard-container{display:flex;flex-direction:column;gap:6px;width:100%;max-width:500px;margin:0 auto;box-sizing:border-box;--key-gap: 6px;--key-width: calc((100% - (9 * var(--key-gap))) / 10)}.keyboard-row{display:flex;justify-content:center;gap:var(--key-gap);width:100%}.keyboard-key{width:var(--key-width);max-width:46px;height:48px;flex-shrink:0;border-radius:8px;background-color:var(--color-white);color:var(--color-black);font-size:1.15rem;font-weight:700;border:1px solid var(--color-gray-light);box-shadow:0 4px 0 var(--color-gray-mid);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s cubic-bezier(.4,0,.2,1),box-shadow .1s cubic-bezier(.4,0,.2,1);-webkit-tap-highlight-color:transparent;font-family:inherit}.keyboard-key:active{transform:translateY(4px);box-shadow:0 0 0 var(--color-gray-light)}.keyboard-key.backspace-key{width:calc(var(--key-width) * 1.5);max-width:70px;background-color:var(--color-white);border-color:var(--color-gray-light);box-shadow:0 4px 0 var(--color-gray-mid)}.keyboard-key.backspace-key:active{transform:translateY(4px);box-shadow:0 0 0 var(--color-gray)}.keyboard-key.correct{background-color:var(--color-yellow-mid);color:var(--color-white);border-color:var(--color-yellow-dark);box-shadow:0 4px 0 var(--color-yellow-dark)}.keyboard-key.correct:active{box-shadow:0 0 0 var(--color-yellow-dark)}.keyboard-key.wrong{background-color:var(--color-red);color:var(--color-white);border-color:var(--color-red-dark);box-shadow:0 4px 0 var(--color-red-dark)}.keyboard-key.wrong:active{box-shadow:0 0 0 var(--color-red-dark)}.keyboard-key.faded{opacity:.5}.keyboard-key.present{background-color:var(--color-yellow-mid);color:var(--color-white);border-color:var(--color-yellow-dark);box-shadow:0 4px 0 var(--color-yellow-dark)}.keyboard-key.present:active{box-shadow:0 0 0 var(--color-yellow-dark)}.keyboard-key.absent{background-color:var(--color-gray-dark);color:var(--color-white);border-color:var(--color-gray-dark);box-shadow:0 4px 0 var(--color-black)}.keyboard-key.absent:active{box-shadow:0 0 0 var(--color-black)}.explanation-page-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000073;z-index:900;display:flex;justify-content:center;align-items:flex-end;animation:fadeIn .2s ease-out forwards}.explanation-page-container{width:100%;max-width:600px;height:94%;display:flex;flex-direction:column;background-color:var(--color-white);padding:24px 24px 32px;box-shadow:0 -8px 40px #0003;border-top-left-radius:32px;border-top-right-radius:32px;animation:slideInUpContainer .4s cubic-bezier(.34,1.56,.64,1) forwards}.explanation-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.explanation-ref-label{color:var(--color-gray-dark);font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.5px}.explanation-content-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:20px;padding-right:4px;padding-bottom:40px}.explanation-title{font-size:1.8rem;font-weight:800;margin:0;color:var(--color-black)}.explanation-question{font-size:1.05rem;font-style:italic;color:var(--color-gray-dark);line-height:1.5}.explanation-text{font-size:1.05rem;color:var(--color-black);line-height:1.6}.explanation-text p{margin-bottom:12px}.explanation-text ul,.explanation-text ol{margin:12px 0;padding-left:20px}.explanation-text li{margin-bottom:6px}.explanation-text strong{font-weight:700}.explanation-text em{font-style:italic}.explanation-page-footer{display:flex;gap:12px;padding-top:16px;background-color:var(--color-white);margin-top:auto}.explanation-page-overlay.is-closing{animation:fadeOut .3s ease-in forwards}.explanation-page-overlay.is-closing .explanation-page-container{animation:slideOutDownContainer .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideInUpContainer{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideOutDownContainer{0%{transform:translateY(0)}to{transform:translateY(100%)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.article-tile{display:flex;align-items:center;gap:14px;background:var(--color-gray-light);border-radius:14px;padding:10px 14px;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;min-height:72px}.article-tile:not(.locked):active{transform:scale(.98);box-shadow:0 2px 8px #00000014}.article-tile.locked{cursor:default;opacity:.7}.article-tile-thumb{width:56px;height:56px;border-radius:10px;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.article-tile-image-wrap{background:var(--color-gray-mid)}.article-tile-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.article-tile-sa-icon{transform:rotate(0)}.article-tile-sa-icon i,.article-tile-sa-icon svg{width:24px;height:24px;color:var(--color-black)}.article-tile-sa-icon.blue{background:linear-gradient(45deg,var(--color-blue-light),var(--color-blue-mid))}.article-tile-sa-icon.green{background:linear-gradient(45deg,var(--color-green-light),var(--color-green-mid))}.article-tile-sa-icon.yellow{background:linear-gradient(45deg,var(--color-yellow-light),var(--color-yellow-mid))}.article-tile-sa-icon.purple{background:linear-gradient(45deg,var(--color-purple-light),var(--color-purple-mid))}.article-tile-sa-icon.pink{background:linear-gradient(45deg,var(--color-pink-light),var(--color-pink-mid))}.article-tile-sa-icon.orange{background:linear-gradient(45deg,var(--color-orange-light),var(--color-orange-mid))}.article-tile-sa-icon.teal{background:linear-gradient(45deg,var(--color-teal-light),var(--color-teal-mid))}.article-tile-locked-thumb{background:var(--color-gray-mid)}.article-tile-locked-thumb i,.article-tile-locked-thumb svg{width:22px;height:22px;color:var(--color-gray-dark)}.article-tile-title{font-size:15px;font-weight:700;color:var(--color-black);line-height:1.3;flex:1}.article-tile-title-locked{font-size:15px;font-weight:700;color:var(--color-gray-dark);letter-spacing:2px}.home-title-group{display:flex;align-items:center;gap:12px}.home-logo{height:30px;width:auto;object-fit:contain}.home-game-grid{display:grid;grid-template-columns:1fr 1fr;row-gap:24px;column-gap:24px;padding-top:20px}.settings-header{display:flex;align-items:center;justify-content:space-between;width:100%}.settings-header-title{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1.25rem}.settings-menu{display:flex;flex-direction:column;gap:12px;flex-grow:1}.settings-footer-text{font-size:10px;color:var(--color-black);text-align:center;margin-top:auto;padding-top:100px;padding-bottom:24px}.settings-main{display:flex;flex-direction:column;min-height:70vh}.about-content{display:flex;flex-direction:column;align-items:center;margin-top:48px;text-align:center;gap:24px}.about-logo-wrapper{width:96px;height:96px;background-color:var(--color-yellow, #ffcc00);border-radius:16px;display:flex;align-items:center;justify-content:center}.about-logo-img{width:56px;height:56px;object-fit:contain}.about-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--color-black)}.about-description{font-size:14px;line-height:1.5;color:var(--color-gray-dark);margin:0;max-width:250px}.about-contact-wrapper{width:100%;max-width:250px;margin-top:16px}.license-detail-loading{display:flex;justify-content:center;align-items:center;height:100vh}.license-detail-content{margin-top:16px;font-size:11px;white-space:pre-wrap;color:var(--color-black);line-height:1.4}.changelog-content{text-align:left;color:var(--color-black)}.markdown-body ul{padding-left:20px;margin-top:12px;margin-bottom:16px;list-style-type:disc}.markdown-body li{margin-bottom:8px;line-height:1.6;font-size:13px;color:var(--color-black)}.markdown-body p{margin-bottom:8px;font-size:13px;line-height:1.5}.markdown-body strong{font-weight:700;font-size:15px;color:var(--color-blue-dark)}.markdown-body em{font-style:italic;color:var(--color-gray-dark)}.ts-content{display:flex;flex-direction:column;gap:32px}.ts-section{display:flex;flex-direction:column;gap:12px}.ts-section-title{font-weight:700;font-size:15px;color:var(--color-black);margin:0}.ts-section-title.danger{color:var(--color-red-mid)}.ts-section-desc{font-size:13px;color:var(--color-black);margin:0;line-height:1.5}.ts-section-desc.danger{color:var(--color-red-mid);font-family:monospace;font-size:12px}.ts-row{display:flex;gap:12px}.ts-modal-actions{display:flex;flex-direction:column;gap:12px;margin-top:8px}.audio-content{display:flex;flex-direction:column;gap:32px;padding-top:8px}.audio-row{display:flex;flex-direction:column;gap:10px}.audio-label{font-size:14px;font-weight:600;color:var(--color-black)}.audio-slider-track{width:100%}.audio-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;outline:none;cursor:pointer;background:linear-gradient(to right,var(--color-orange-mid) 0%,var(--color-orange-mid) var(--fill, 70%),var(--color-gray-mid) var(--fill, 70%),var(--color-gray-mid) 100%)}.audio-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--color-orange-mid);box-shadow:0 1px 4px #00000040;cursor:pointer;transition:transform .1s ease}.audio-slider::-moz-range-thumb{width:22px;height:22px;border:none;border-radius:50%;background:var(--color-orange-mid);box-shadow:0 1px 4px #00000040;cursor:pointer}.audio-slider:active::-webkit-slider-thumb{transform:scale(1.15)}.level-header-row{display:flex;align-items:center;justify-content:space-between;width:100%}.level-header-title-group{display:flex;align-items:center;gap:8px}.level-header-back{cursor:pointer;display:flex;align-items:center;justify-content:center}.level-header-back-icon{font-size:24px;color:var(--color-black)}.level-header-title{font-weight:700;font-size:1.25rem;color:var(--color-black)}.level-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;justify-items:center;align-items:center}.feedback-backdrop{position:fixed;inset:0;background-color:#2a2a2a73;z-index:50;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer}.feedback-backdrop.peeking{background:linear-gradient(to top,#0080ff59,#0080ff00 10% 90%,#0080ff59);pointer-events:all}.feedback-backdrop.peeking .feedback-sheet{transform:translateY(100%);transition:transform .25s cubic-bezier(.4,0,.2,1);pointer-events:none}.feedback-sheet{background-color:var(--color-white);border-radius:28px 28px 0 0;padding:0 20px 28px;width:100%;max-width:600px;margin:0 auto;position:relative;animation:feedbackSlideUp .35s cubic-bezier(.34,1.2,.64,1) forwards;will-change:transform}.feedback-sheet:after{content:"";position:absolute;top:99%;left:0;right:0;height:500px;background-color:inherit;z-index:-1}.feedback-sheet.pulling-down{transition:transform .3s ease;transform:translateY(calc(100% - 48px))}.feedback-sheet.pull-reset,.feedback-sheet.peek-return{transition:transform .35s cubic-bezier(.34,1.2,.64,1);transform:translateY(0)}@keyframes feedbackSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.feedback-badge{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:absolute;top:-30px;left:50%;transform:translate(-50%);border:4px solid var(--color-white);z-index:1;color:#fff}.feedback-badge i,.feedback-badge svg{width:28px;height:28px;stroke-width:2.5}.feedback-badge.correct{background-color:var(--color-yellow-mid);color:var(--color-black)}.feedback-badge.wrong,.feedback-badge.timeout{background-color:var(--color-red-mid);color:#fff}.feedback-content{padding-top:40px;text-align:center;display:flex;flex-direction:column;gap:4px}.feedback-exclamation{font-size:22px;font-weight:800;color:var(--color-black)}.feedback-exclamation.correct,.feedback-exclamation.wrong,.feedback-exclamation.timeout{color:var(--color-black)}.feedback-reference{font-size:14px;color:var(--color-gray-dark);margin-top:2px}.feedback-actions{display:flex;gap:10px;margin-top:20px;align-items:center}.feedback-cta-btn{flex:1;height:48px;border-radius:12px;border:none;border-bottom:5px solid transparent;font-size:16px;font-weight:800;color:#fff;cursor:pointer;letter-spacing:.5px;font-family:inherit;transition:transform .1s ease,border-bottom-width .1s ease;display:flex;align-items:center;justify-content:center}.feedback-cta-btn:active{transform:translateY(3px);border-bottom-width:2px}.feedback-cta-btn.next{background-color:var(--color-green-mid);border-bottom-color:var(--color-green-dark)}.feedback-cta-btn.finish{background-color:var(--color-blue-mid);border-bottom-color:var(--color-blue-dark)}.pause-overlay{position:fixed;inset:0;background-color:#e8e8e8;z-index:300;display:flex;align-items:center;justify-content:center;overflow:hidden;contain:layout style;animation:pauseFadeIn .2s ease forwards}.pause-overlay:before{content:"";position:absolute;inset:-50%;width:200%;height:200%;pointer-events:none;z-index:0;opacity:.09;background-image:url("data:image/svg+xml,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");will-change:transform;animation:grain .4s steps(1) infinite}@keyframes pauseFadeIn{0%{opacity:0}to{opacity:1}}@keyframes grain{0%{transform:translateZ(0)}10%{transform:translate3d(-4%,-6%,0)}20%{transform:translate3d(-9%,5%,0)}30%{transform:translate3d(5%,-9%,0)}40%{transform:translate3d(-5%,13%,0)}50%{transform:translate3d(-9%,4%,0)}60%{transform:translate3d(13%,0,0)}70%{transform:translate3d(0,9%,0)}80%{transform:translate3d(-13%,0,0)}90%{transform:translate3d(9%,5%,0)}}.pause-card{background-color:var(--color-white);border-radius:24px;padding:60px 28px 28px;max-width:300px;width:90%;text-align:center;position:relative;z-index:1;box-shadow:0 8px 32px #00000026}.pause-badge{position:absolute;top:-32px;left:50%;transform:translate(-50%);width:64px;height:64px;border-radius:50%;background-color:var(--color-yellow-mid);color:var(--color-black);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:900;border:4px solid var(--color-white)}.pause-title{font-size:22px;font-weight:800;color:var(--color-black);margin-bottom:6px;font-family:Fira Code,monospace}.pause-subtitle{font-size:14px;color:var(--color-gray-dark);margin-bottom:24px}.pause-actions{display:flex;flex-direction:column;gap:10px}.mc-quiz-container main{overflow:hidden;display:flex;flex-direction:column;padding:12px 16px;gap:0}.mc-quiz-container footer{padding:0 16px;height:52px}.mc-quiz-progress-label{font-size:12px;color:var(--color-gray-dark);font-weight:500;flex-shrink:0;padding-bottom:6px}.mc-quiz-question{font-family:Fira Code,monospace;font-weight:700;color:var(--color-black);line-height:1.4;flex-shrink:0;font-size:clamp(1rem,4.5vw,1.5rem);padding:48px 0}.mc-quiz-question .blank-line{display:inline-block;width:120px;border-bottom:3px solid var(--color-black);vertical-align:bottom;margin:0 4px}.mc-quiz-choices{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:10px;flex:1;min-height:0}@keyframes timerBlink{0%{background-color:var(--color-red-mid);color:#fff}50%{background-color:var(--color-white);color:var(--color-red-mid)}to{background-color:var(--color-red-mid);color:#fff}}.pill.timer-urgent{animation:timerBlink 2s step-start infinite}.feedback-open .pill.timer-urgent{animation-play-state:paused}.pill.timer-zero{background-color:var(--color-red-mid)!important;color:#fff!important;animation:none!important}.pill.level-pill{min-width:64px}.pill.level-pill .pill-text{display:flex;flex-direction:column;line-height:1;padding:0 10px;gap:1px;align-items:center;justify-content:center}.pill.level-pill .pill-label{font-size:8px;font-weight:700;letter-spacing:.06em;opacity:.85;text-transform:uppercase}.pill.level-pill .pill-number{font-size:18px;font-weight:900;line-height:1}.end-game-overlay{position:fixed;inset:0;background-color:#2a2a2a8c;z-index:400;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .25s ease forwards}.end-game-card{background-color:var(--color-white);border-radius:24px;padding:56px 28px 28px;max-width:300px;width:100%;text-align:center;position:relative;border:1px solid var(--color-gray-mid);border-bottom:6px solid var(--color-gray-mid);animation:bounceInDown .55s cubic-bezier(.215,.61,.355,1) forwards}@keyframes bounceInDown{0%{opacity:0;transform:translateY(-60px)}60%{opacity:1;transform:translateY(12px)}80%{transform:translateY(-6px)}to{transform:translateY(0)}}.end-game-badge{position:absolute;top:-36px;left:50%;transform:translate(-50%);width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:900;color:var(--color-black);border:5px solid var(--color-white);font-family:Fira Code,monospace}.end-game-badge.win{background-color:var(--color-yellow-mid)}.end-game-badge.lose{background-color:var(--color-red-mid);color:#fff}.end-game-title{font-size:26px;font-weight:900;color:var(--color-black);margin-bottom:10px;font-family:Fira Code,monospace}.end-game-stars{display:flex;justify-content:center;gap:3px;margin-bottom:6px}.end-star{display:inline-flex;align-items:center;justify-content:center;line-height:1}.end-star i,.end-star svg{width:20px;height:20px}.end-star.empty svg{stroke:var(--color-gray-mid);fill:none}.end-star.filled svg{stroke:var(--color-yellow-dark);fill:var(--color-yellow-mid)}.end-game-sub{font-size:14px;color:var(--color-gray-dark);margin-bottom:20px;line-height:1.5;font-family:Roboto Mono,monospace}.end-game-actions{display:flex;gap:10px;align-items:center}.end-game-cta-btn{flex:1;height:52px;border-radius:14px;border:none;border-bottom:5px solid transparent;font-size:16px;font-weight:800;color:#fff;cursor:pointer;font-family:inherit;letter-spacing:.3px;transition:transform .1s ease,border-bottom-width .1s ease}.end-game-cta-btn:active{transform:translateY(3px);border-bottom-width:2px}.end-game-cta-btn.win{background-color:var(--color-green-mid);border-bottom-color:var(--color-green-dark)}.end-game-cta-btn.lose{background-color:var(--color-red-mid);border-bottom-color:var(--color-red-dark)}.word-scramble-container main{overflow:visible;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 16px}@keyframes ws-shake{0%{transform:translate(0)}15%{transform:translate(-4px)}35%{transform:translate(4px)}50%{transform:translate(-4px)}65%{transform:translate(4px)}80%{transform:translate(-2px)}to{transform:translate(0)}}.ws-top-grid.shake{animation:ws-shake .5s ease-in-out}.shop-backdrop{position:fixed;inset:0 0 60px;background-color:var(--color-shop-backdrop);z-index:15;max-width:600px;margin:0 auto}.shop-main{padding:0!important;background-color:transparent!important;display:flex;flex-direction:column;overflow-y:auto;position:relative;z-index:16}.shop-body{display:flex;flex-direction:column;flex-grow:1;min-height:100%}.shop-header{display:flex;align-items:center;justify-content:space-between;width:100%}header.shop-header-active{background:repeating-linear-gradient(90deg,var(--color-shop-awning-light) 0px,var(--color-shop-awning-light) 20px,var(--color-shop-awning-dark) 20px,var(--color-shop-awning-dark) 40px);overflow:visible;z-index:16}header.shop-header-active:after{content:"";position:absolute;bottom:-12px;left:0;width:100%;height:14px;background:radial-gradient(circle at 10px -4px,transparent 12px,var(--color-shop-awning-light) 12px,var(--color-shop-awning-light) 14px,transparent 14px);background-size:20px 14px;z-index:16;pointer-events:none}.shop-header-title{font-size:20px;font-weight:700;color:var(--color-white);text-shadow:0 1px 3px rgba(0,0,0,.3)}.shop-content{flex-grow:1;display:flex;align-items:center;justify-content:center;padding:40px 24px}.shop-empty-card{background-color:var(--color-white);border-radius:24px;padding:60px 24px 24px;width:100%;max-width:380px;position:relative;text-align:center;box-shadow:0 8px 32px #00000026;animation:bounceInDown .6s cubic-bezier(.215,.61,.355,1) forwards}.shop-empty-badge{position:absolute;top:-28px;left:50%;transform:translate(-50%);width:56px;height:56px;border-radius:50%;background-color:var(--color-gray-mid);color:var(--color-black);display:flex;align-items:center;justify-content:center;border:4px solid var(--color-white);box-shadow:0 4px 12px #0000001a}.shop-empty-badge i,.shop-empty-badge svg{width:24px;height:24px}.shop-empty-title{font-size:22px;font-weight:800;color:var(--color-black);margin-bottom:8px}.shop-empty-description{font-size:14px;color:var(--color-black);margin-bottom:24px;line-height:1.5;opacity:.7}.report-overlay{position:fixed;inset:0;background:#f9f9f4;z-index:2000;display:flex;flex-direction:column;padding:40px 24px 32px;overflow-y:auto;animation:report-slide-in .3s ease}@keyframes report-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.report__title{font-family:var(--font-display, "Fira Code", monospace);font-size:1rem;font-weight:700;color:var(--color-red-mid);line-height:1.45;margin:0 0 20px}.report__reasons{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.report__reason-btn{background:#fdfdf9;border:1.5px solid var(--color-gray-mid);border-radius:12px;padding:14px 18px;text-align:left;font-family:var(--font-display, "Fira Code", monospace);font-size:.9rem;color:var(--color-black);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease;outline:none}.report__reason-btn--selected{background:#fff0f0;border-color:var(--color-red-mid);color:var(--color-red-mid)}.report__reason-btn:active{transform:scale(.98)}.report__section-label{font-family:var(--font-display, "Fira Code", monospace);font-size:.82rem;color:var(--color-black);margin:0 0 10px;line-height:1.45}.report__textarea{width:100%;border:1.5px solid var(--color-gray-mid);border-radius:12px;padding:14px 16px;font-family:var(--font-display, "Fira Code", monospace);font-size:.88rem;color:var(--color-black);background:#fdfdf9;resize:none;outline:none;transition:border-color .2s ease;box-sizing:border-box;margin-bottom:20px}.report__textarea:focus{border-color:var(--color-gray-dark)}.report__textarea::placeholder{color:var(--color-gray-dark)}.report__email-input{width:100%;border:1.5px solid var(--color-gray-mid);border-radius:12px;padding:14px 16px;font-family:var(--font-display, "Fira Code", monospace);font-size:.88rem;color:var(--color-black);background:#fdfdf9;outline:none;transition:border-color .2s ease;box-sizing:border-box;margin-bottom:6px}.report__email-input:focus{border-color:var(--color-gray-dark)}.report__email-input::placeholder{color:var(--color-gray-dark)}.report__email-input--error{border-color:var(--color-red-mid)!important}.report__email-error{font-family:var(--font-display, "Fira Code", monospace);font-size:.78rem;color:var(--color-red-mid);margin-bottom:22px;display:none}.report__email-error--visible{display:block}.report__actions{display:flex;gap:12px;align-items:center;margin-top:auto}.report__close-btn{flex-shrink:0;background-color:var(--color-gray-dark)!important;color:var(--color-black)!important;border-color:var(--color-gray-dark)!important}.report__close-btn:after{background-color:var(--color-gray-mid)!important}.report__submit-btn{flex:1;background-color:var(--color-orange-dark);color:#fff}.report__submit-btn:after{background-color:var(--color-orange-mid)}.report__submit-btn:disabled{opacity:.7;cursor:not-allowed}.report-overlay--confirmation{display:flex;align-items:center;justify-content:center;background:#2a2a2a73;animation:report-fade-in .25s ease}@keyframes report-fade-in{0%{opacity:0}to{opacity:1}}.report__confirm-card{background:var(--color-gray-light);border-radius:24px;padding:60px 24px 28px;width:100%;max-width:340px;position:relative;text-align:center;border:1px solid var(--color-gray-mid);border-bottom:6px solid var(--color-gray-mid);display:flex;flex-direction:column;gap:14px;animation:report-bounce-in .5s cubic-bezier(.215,.61,.355,1) forwards}@keyframes report-bounce-in{0%{opacity:0;transform:translateY(-60px)}60%{opacity:1;transform:translateY(10px)}80%{transform:translateY(-4px)}to{transform:translateY(0)}}.report__confirm-badge{position:absolute;top:-32px;left:50%;transform:translate(-50%);width:64px;height:64px;border-radius:50%;background:var(--color-green-mid);border:4px solid var(--color-gray-light);display:flex;align-items:center;justify-content:center;color:#fff}.report__confirm-badge i,.report__confirm-badge svg{width:28px;height:28px}.report__confirm-heading{font-family:var(--font-display, "Fira Code", monospace);font-size:1.5rem;font-weight:800;color:var(--color-black);margin:0}.report__confirm-msg{font-family:var(--font-display, "Fira Code", monospace);font-size:.88rem;color:var(--color-black);line-height:1.55;margin:0}.report__confirm-next-btn,.report__confirm-home-btn{margin-top:0}.gift-page-header{display:flex;align-items:center;justify-content:space-between;width:100%}.gift-page-header-title{display:flex;align-items:center;gap:8px;font-weight:800;font-size:1.1rem;color:var(--color-black)}.gift-page-header-icon{width:20px;height:20px}.gift-page-content{display:flex;flex-direction:column}.gift-image-wrap{width:100%;aspect-ratio:3 / 4;overflow:hidden;background-color:var(--color-gray-mid);margin-left:calc(-1 * var(--page-padding, 20px));width:calc(100% + 2 * var(--page-padding, 20px))}.gift-image{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.gift-caption{font-size:11px;color:var(--color-gray-dark);margin-top:6px;margin-bottom:0;font-style:italic}.gift-body{margin-top:16px;display:flex;flex-direction:column;gap:12px}.gift-title{font-size:22px;font-weight:800;color:var(--color-black);margin:0;line-height:1.2}.gift-paragraph{font-size:14px;line-height:1.6;color:var(--color-black);margin:0;font-family:Roboto Mono,monospace}.gift-block{border-radius:16px;padding:14px 16px;border:1.5px solid transparent}.gift-block-header{display:flex;align-items:center;gap:8px;font-weight:800;font-size:12px;letter-spacing:.06em;margin-bottom:10px}.gift-block-header i,.gift-block-header svg{width:16px;height:16px;flex-shrink:0}.gift-block-label{font-weight:800;font-size:12px;letter-spacing:.08em}.gift-block-content{font-size:13px;line-height:1.6;color:var(--color-black);margin:0;font-family:Roboto Mono,monospace}.gift-body-cta{margin-top:20px;padding-bottom:8px}.gift-hub-header-row{display:flex;align-items:center;justify-content:space-between;width:100%}.gift-hub-header-title{font-size:22px;font-weight:800;color:var(--color-black)}.gift-hub-grid{padding-top:20px}.gift-category-header-row{display:flex;align-items:center;justify-content:space-between;width:100%}.gift-category-header-title{font-size:20px;font-weight:800;color:var(--color-black);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:8px}.gift-hub-loading{display:flex;align-items:center;justify-content:center;min-height:50vh;padding-top:20px}.gift-hub-spinner{width:36px;height:36px;border:3px solid var(--color-gray-mid);border-top-color:var(--color-orange-mid);border-radius:50%;animation:gift-spin .7s linear infinite}@keyframes gift-spin{to{transform:rotate(360deg)}}.gift-category-page{display:flex;flex-direction:column;gap:0}.gift-category-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:4px}.gift-category-title{font-size:22px;font-weight:800;color:var(--color-black);margin:0 0 6px;line-height:1.2}.gift-category-description{font-size:13px;color:var(--color-black);line-height:1.5;margin:0 0 8px;font-family:Roboto Mono,monospace}.gift-category-subheading{font-size:13px;font-weight:600;font-style:italic;color:var(--color-green-dark);margin:0}.gift-category-list{display:flex;flex-direction:column;gap:10px;margin-top:16px}.gift-category-play-more{font-size:13px;font-style:italic;color:var(--color-orange-dark);margin:6px 0 2px;font-family:Roboto Mono,monospace}.gift-category-all-unlocked{font-size:13px;font-style:italic;color:var(--color-green-dark);margin:12px 0 4px;font-family:Roboto Mono,monospace;line-height:1.5;text-align:center}.loading-page{position:fixed;inset:0;background-color:var(--color-white);display:flex;align-items:center;justify-content:center;z-index:100;animation:loading-fade-in .2s ease-out forwards}.loading-page.loading-page-out{animation:loading-fade-out .3s ease-in forwards}@keyframes loading-fade-in{0%{opacity:0}to{opacity:1}}@keyframes loading-fade-out{0%{opacity:1}to{opacity:0}}.loading-page-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:0 40px;width:100%;max-width:360px}.loading-title{font-family:Roboto Mono,monospace;font-size:20px;font-weight:800;color:var(--color-black)}.loading-dots:after{content:"..."}.loading-bar-track{width:100%;height:16px;background-color:var(--color-gray-mid);border-radius:999px;overflow:hidden}.loading-bar-fill{height:100%;width:0%;background-color:var(--color-green-mid);border-radius:999px;animation:loading-progress 2s linear forwards}@keyframes loading-progress{0%{width:0%}to{width:100%}}.loading-trivia{font-family:Roboto Mono,monospace;font-size:13px;color:var(--color-black);text-align:center;line-height:1.6;margin-top:4px}.splash-screen{position:fixed;inset:0;background-color:var(--color-yellow-mid);display:flex;align-items:center;justify-content:center;z-index:9999;animation:splash-fade-in .2s ease-out}.splash-screen.splash-out{animation:splash-fade-out .4s ease-in forwards}@keyframes splash-fade-in{0%{opacity:0}to{opacity:1}}@keyframes splash-fade-out{0%{opacity:1}to{opacity:0}}.splash-content{display:flex;flex-direction:column;align-items:center;justify-content:space-between;width:100%;max-width:360px;height:65%;padding:0 40px}.splash-brand{display:flex;flex-direction:row;align-items:center;gap:16px;flex:1}.splash-logo{width:72px;height:72px;object-fit:contain}.splash-brand-text{display:flex;flex-direction:column;font-family:Roboto Mono,monospace;font-size:26px;font-weight:800;color:var(--color-black);line-height:1.15}.splash-loading{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}.splash-loading-label{font-family:Roboto Mono,monospace;font-size:18px;font-weight:800;color:var(--color-black)}.splash-dots:after{content:"..."}.splash-bar-track{width:100%;height:16px;background-color:#ffffff8c;border-radius:999px;overflow:hidden}.splash-bar-fill{height:100%;width:0%;background-color:var(--color-green-mid);border-radius:999px;transition:width .25s ease-out}.word-guess-container main{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 12px;overflow:hidden}.word-guess-container .keyboard-key{height:40px;font-size:1rem}.word-guess-container .keyboard-row:first-child{display:none}.word-guess-container .wg-footer{gap:8px}.wg-grid{display:flex;flex-direction:column;gap:5px;align-items:center}.wg-row{display:flex;gap:5px}.wg-tile{width:var(--wg-tile-size, 44px);height:var(--wg-tile-size, 44px);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--wg-font-size, 1.2rem);background-color:var(--color-white);border:2px solid var(--color-gray-mid);color:var(--color-black);box-shadow:0 3px 0 var(--color-gray-mid);transition:background-color .15s,border-color .15s,color .15s,box-shadow .15s}.wg-tile.filled{border-color:var(--color-gray-dark);background-color:var(--color-gray-light);color:var(--color-black);box-shadow:0 3px 0 var(--color-gray-dark)}.wg-tile.correct{background-color:var(--color-green-mid);border-color:var(--color-green-dark);box-shadow:0 3px 0 var(--color-green-dark);color:var(--color-white)}.wg-tile.present{background-color:var(--color-yellow-mid);border-color:var(--color-yellow-dark);box-shadow:0 3px 0 var(--color-yellow-dark);color:var(--color-white)}.wg-tile.absent{background-color:var(--color-gray-dark);border-color:var(--color-gray-dark);box-shadow:0 3px 0 var(--color-black);color:var(--color-white)}.wg-footer{width:100%;background-color:#d4d0c8;padding:10px 8px 8px;display:flex;flex-direction:column;gap:16px;box-sizing:border-box}@keyframes wg-shake{0%{transform:translate(0)}15%{transform:translate(-6px)}35%{transform:translate(6px)}50%{transform:translate(-6px)}65%{transform:translate(6px)}80%{transform:translate(-3px)}to{transform:translate(0)}}.wg-row.shake{animation:wg-shake .4s ease-in-out}@keyframes wg-pop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.wg-tile.pop{animation:wg-pop .1s ease-in-out}.wg-tile.invalid{background-color:var(--color-red-mid);border-color:var(--color-red-dark);box-shadow:0 3px 0 var(--color-red-dark);color:var(--color-white)}.word-search-container{display:flex;flex-direction:column;width:100%}.ws-layout{display:flex;flex-direction:column;gap:24px;width:100%;align-items:center;margin-top:10px}#ws-grid-wrap{position:relative;width:100%;max-width:400px;aspect-ratio:1;margin:0 auto;container-type:inline-size}#ws-stroke-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}#ws-grid{border-collapse:collapse;position:relative;z-index:1;background:var(--color-gray-light);border-radius:12px;overflow:hidden;user-select:none;-webkit-user-select:none;width:100%;height:100%;table-layout:fixed;box-sizing:border-box}#ws-grid td{padding:0;text-align:center;vertical-align:middle;font-family:var(--font-mono);font-size:clamp(12px,calc(100cqw / var(--grid-size) * .55),24px);font-weight:500;color:var(--color-black);cursor:crosshair;transition:opacity .15s;position:relative}#ws-grid td.hover{opacity:.6}#ws-grid td.found{color:var(--color-black)}.ws-sidebar{width:100%;background:var(--color-gray-light);border-radius:12px;padding:10px;margin:0 auto}.ws-sidebar h3{font-size:.8rem;text-transform:uppercase;font-weight:800;color:var(--color-blue-mid);margin-bottom:12px;text-align:center;font-family:inherit}.ws-word-list{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);column-gap:10px;row-gap:12px;justify-content:center;padding:0;text-transform:uppercase}.ws-word-list li{font-family:var(--font-mono);font-size:1rem;text-align:center;color:var(--color-black);transition:color .25s,opacity .25s}.ws-word-list li.found{color:var(--color-gray-dark);text-decoration:line-through}.ws-found-line{stroke-linecap:round;opacity:.4;transition:opacity .3s}.ws-active-line{stroke:var(--color-gray-dark);stroke-linecap:round;opacity:.4}#dev-unlock-toast{position:fixed;bottom:88px;left:50%;transform:translate(-50%) translateY(20px);opacity:0;transition:opacity .3s ease,transform .3s ease;display:flex;align-items:center;gap:12px;background:#1a1a2e;color:#e0e0ff;border:1.5px solid rgba(160,120,255,.5);border-radius:14px;padding:12px 20px;box-shadow:0 8px 32px #00000073;font-family:Roboto Mono,monospace;font-size:13px;white-space:nowrap;z-index:9999;pointer-events:none}#dev-unlock-toast.dev-toast-visible{opacity:1;transform:translate(-50%) translateY(0)}.dev-toast-icon{font-size:22px;line-height:1}.dev-toast-text{display:flex;flex-direction:column;gap:2px}.dev-toast-text strong{font-size:13px;font-weight:700;color:#c8b8ff}.dev-toast-text small{font-size:11px;color:#a0a0c0}*{box-sizing:border-box;margin:0;padding:0;-webkit-user-select:none;user-select:none;font-family:Roboto Mono,"monospace"}body,html{margin:0;padding:0;height:100%;width:100%;overflow:hidden;background-color:var(--color-white)}button{cursor:pointer;border:none;background:none}i{display:inline-flex;align-items:center;justify-content:center}
