*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:#0a0a0a}.landing{color:#f0d8c0;background:radial-gradient(90% 65% at 50% 42%,#2e0404 0%,#0000 68%),radial-gradient(60% 40% at 15% 85%,#1a0202 0%,#0000 55%),radial-gradient(50% 35% at 85% 15%,#200303 0%,#0000 50%),#080404;flex-direction:column;justify-content:flex-start;align-items:center;min-height:100vh;padding-top:max(7vh,2rem);padding-bottom:4.5rem;font-family:Georgia,serif;display:flex;position:relative;overflow:hidden}.ninja-bg{pointer-events:none;position:absolute;inset:0}.shuriken{opacity:.13;animation:linear infinite spin;position:absolute}.shuriken-1{color:#c0392b;font-size:6rem;animation-duration:18s;top:8%;left:5%}.shuriken-2{color:#c8a84b;font-size:9rem;animation-duration:24s;animation-direction:reverse;top:60%;left:3%}.shuriken-3{color:#c8a84b;font-size:5rem;animation-duration:14s;top:15%;right:6%}.shuriken-4{color:#c0392b;font-size:10rem;animation-duration:30s;animation-direction:reverse;top:55%;right:4%}.shuriken-5{color:#c8a84b;font-size:4rem;animation-duration:20s;top:80%;left:45%}@keyframes spin{to{transform:rotate(360deg)}}.hero{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:1.25rem;width:100%;padding:2rem 1.5rem;display:flex;position:relative}.dojo-emblem{filter:drop-shadow(0 0 22px #c0392bcc);font-size:3.5rem;line-height:1;animation:3s ease-in-out infinite alternate glow}@keyframes glow{0%{filter:drop-shadow(0 0 12px #8b000077)}to{filter:drop-shadow(0 0 32px #e84040cc)}}.title{letter-spacing:.06em;background:linear-gradient(135deg,#f5dfa0 0%,#c8a84b 35%,#e84040 70%,#8b1010 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 16px #8b000066);-webkit-background-clip:text;background-clip:text;margin:0;padding-left:.06em;font-size:clamp(3rem,10vw,6rem);font-weight:900;line-height:1}.title-kanji{opacity:.4;color:#c8a84b;margin-bottom:-.5rem;font-size:1.8rem;line-height:1}.subtitle{color:#c97878;letter-spacing:.18em;text-transform:uppercase;text-align:center;margin:0;padding-left:.18em;font-size:clamp(1rem,3vw,1.4rem);font-style:italic}.divider{align-items:center;gap:.75rem;width:min(340px,80vw);margin:.5rem 0;display:flex}.divider-icon{color:#c8a84b;font-size:.9rem}.btn-start{letter-spacing:.12em;text-transform:uppercase;color:#1a0000;cursor:pointer;background:linear-gradient(135deg,#f5dfa0 0%,#c8a84b 40%,#c0392b 80%,#7a0f0f 100%);border:none;border-radius:4px;align-items:center;gap:.6rem;margin-top:.5rem;padding:.9rem 2.6rem;font-family:inherit;font-size:1.1rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex;box-shadow:0 0 20px #c0392b66,0 0 40px #c8a84b33,inset 0 1px #fff3}.btn-start:hover{transform:translateY(-2px)scale(1.03);box-shadow:0 0 36px #c0392baa,0 0 60px #c8a84b55,inset 0 1px #fff3}.btn-start:active{transform:translateY(0)scale(.98)}.btn-join-inline{color:#70b0e0;letter-spacing:.06em;cursor:pointer;text-align:center;background:linear-gradient(135deg,#1a2a3a,#0e1820);border:1px solid #3a6080;border-radius:6px;margin-top:.7rem;padding:.55rem 1.8rem;font-family:inherit;font-size:.92rem;transition:border-color .15s,color .15s,box-shadow .15s}.btn-join-inline:hover{color:#a0d0f0;border-color:#60a0d0;box-shadow:0 0 12px #50a0dc40}.btn-icon{font-size:1.2rem}.dojo-footer{letter-spacing:.2em;color:#b07050;text-transform:uppercase;flex-direction:column;align-items:center;gap:.25rem;font-size:.8rem;display:flex;position:absolute;bottom:1.5rem}.dojo-footer-copyright{letter-spacing:.12em;color:#b07050;text-transform:none;font-size:.68rem}.btn-admin-link{color:#6a4040;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;border-radius:3px;padding:.2rem .6rem;font-family:inherit;font-size:.7rem;transition:color .15s}.btn-admin-link:hover{color:#c8a84b}.teacher-section{z-index:1;flex-direction:column;align-items:center;gap:.6rem;margin-top:auto;margin-bottom:1.5rem;display:flex;position:relative}.btn-teacher{color:#b07050;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;text-align:center;background:0 0;border:1px solid #7a4a2a;border-radius:3px;max-width:min(320px,88vw);padding:.45rem 1.2rem;font-family:inherit;font-size:.75rem;line-height:1.7;transition:color .15s,border-color .15s}.btn-teacher:hover{color:#c8a84b;border-color:#c8a84b}.admin-page{color:#e8d5c0;background:#0d0808;flex-direction:column;min-height:100vh;font-family:system-ui,-apple-system,sans-serif;display:flex}.save-status-bar{text-align:center;letter-spacing:.01em;padding:.45rem 1.25rem;font-size:.82rem;font-weight:500}.save-status-ok{color:#6fcf6f;background:#0d2a0d;border-bottom:1px solid #1a4a1a}.save-status-error{color:#ff7070;background:#3a0a0a;border-bottom:1px solid #600}.admin-header{z-index:10;background:#180f0f;border-bottom:1px solid #3a1a1a;align-items:center;gap:1.25rem;padding:.7rem 1.25rem;display:flex;position:sticky;top:0}.admin-header h1{color:#c8a84b;letter-spacing:.05em;margin:0;font-size:1.05rem;font-weight:600}.header-spacer{flex:1}.btn-import-seed,.btn-import-json{color:#c8a84b;cursor:pointer;white-space:nowrap;background:#1a1505;border:1px solid #3a300a;border-radius:4px;padding:.35rem .85rem;font-size:.82rem;transition:background .12s}.btn-import-seed:hover,.btn-import-json:hover{background:#252010}.btn-back{color:#c97878;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #5a2a2a;border-radius:4px;padding:.35rem .85rem;font-size:.88rem;transition:background .12s}.admin-body{flex:1;height:calc(100vh - 48px);display:flex;overflow:hidden}.cat-panel{background:#120a0a;border-right:1px solid #2a1212;flex-direction:column;flex-shrink:0;width:380px;min-width:300px;display:flex;overflow:hidden}.cat-panel-title{text-transform:uppercase;letter-spacing:.14em;color:#7a4a4a;border-bottom:1px solid #2a1212;flex-shrink:0;padding:.65rem 1rem;font-size:.7rem}.cat-list{flex:1;padding:.4rem 0;overflow-y:auto}.main-cat-row{align-items:center;gap:.35rem;padding:.38rem .6rem;display:flex}.main-cat-row:hover{background:#1e0e0e}.cat-toggle{color:#7a4a4a;cursor:pointer;background:0 0;border:none;flex-shrink:0;width:14px;padding:0;font-size:.6rem}.cat-name{color:#e0c090;cursor:default;-webkit-user-select:none;user-select:none;flex:1;font-size:.92rem;font-weight:600}.cat-actions{opacity:0;gap:.15rem;transition:opacity .1s;display:flex}.main-cat-row:hover .cat-actions,.sub-cat-row:hover .cat-actions{opacity:1}.cat-actions button{cursor:pointer;color:#7a5a5a;background:0 0;border:none;border-radius:3px;padding:.1rem .22rem;font-size:.75rem}.cat-actions button:hover{color:#c8a84b;background:#2a1a0a}.cat-actions button.btn-danger:hover{color:#e84040;background:#2a0a0a}.cat-actions button.btn-reorder:disabled{opacity:.2;cursor:default;pointer-events:none}.sub-list{padding-left:1.25rem}.sub-cat-row{cursor:pointer;border-left:2px solid #0000;border-radius:4px;align-items:center;gap:.35rem;padding:.28rem .6rem .28rem .4rem;display:flex}.sub-cat-row:hover{background:#1e0e0e}.sub-cat-row.selected{background:#200c0c;border-left-color:#c0392b}.sub-name{color:#c8a090;flex:1;align-items:center;gap:.4rem;font-size:.85rem;display:flex}.cat-count{color:#6a3a2a;font-variant-numeric:tabular-nums;background:#1e0c0c;border:1px solid #3a1a1a;border-radius:8px;flex-shrink:0;padding:0 .4em;font-size:.68rem;line-height:1.5}.sub-cat-row.selected .cat-count{color:#c0392b;border-color:#5a1a1a}.cat-name .cat-count{color:#5a3020;background:#180a0a;border-color:#2e1010;font-size:.65rem}.cat-inline-input{color:#e8d5c0;background:#1e0e0e;border:1px solid #4a2020;border-radius:3px;outline:none;flex:1;min-width:0;padding:.22rem .45rem;font-size:.85rem}.cat-inline-input:focus{border-color:#c0392b}.add-sub-row{gap:.3rem;padding:.3rem .4rem .5rem;display:flex}.add-subgroup-row{border-top:1px dashed #2a3040;gap:.3rem;margin-top:.2rem;padding:.3rem .4rem .2rem;display:flex}.subgroup-block{border-left:2px solid #3a6080;margin:.3rem 0 .3rem .4rem;padding-left:.3rem}.subgroup-header-row{cursor:default;align-items:center;gap:.35rem;padding:.2rem .4rem;display:flex}.subgroup-name{color:#9eb8d4;letter-spacing:.04em;flex:1;align-items:center;gap:.4rem;font-size:.82rem;display:flex}.subgroup-children{padding-left:.5rem}.sub-cat-row--indented{padding-left:1.2rem}.add-main-row{gap:.3rem;padding:.3rem .4rem .5rem;display:flex}.btn-add-small{color:#c8a84b;cursor:pointer;background:#200c0c;border:1px solid #4a2020;border-radius:3px;flex-shrink:0;padding:.22rem .55rem;font-size:1rem;line-height:1}.btn-add-small:hover{background:#2e1010}.item-panel{flex-direction:column;flex:1;gap:1rem;padding:1.25rem 1.5rem;display:flex;overflow-y:auto}.item-empty{color:#4a2a2a;flex:1;justify-content:center;align-items:center;font-size:1rem;display:flex}.item-panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.item-panel-header h2{color:#c8a84b;margin:0;font-size:1rem;font-weight:600}.item-header-actions{gap:.5rem;display:flex}.btn-add{color:#f5dfa0;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#b03020,#7a0808);border:none;border-radius:4px;padding:.45rem 1.1rem;font-size:.88rem;font-weight:600}.btn-add:hover{background:linear-gradient(135deg,#d04030,#960a0a)}.btn-excel{color:#c8a84b;cursor:pointer;white-space:nowrap;background:#1a1505;border:1px solid #3a300a;border-radius:4px;padding:.45rem .9rem;font-size:.88rem}.btn-excel:hover{background:#252010}.excel-section{background:#150d0d;border:1px solid #2a1818;border-radius:6px;flex-direction:column;gap:.65rem;padding:1rem;display:flex}.excel-hint{color:#9a7060;margin:0;font-size:.82rem;line-height:1.5}.excel-hint strong{color:#c8a84b}.excel-hint em{color:#8a7060}.excel-textarea{color:#e8d5c0;resize:vertical;background:#0d0808;border:1px solid #3a2020;border-radius:4px;outline:none;padding:.5rem .65rem;font-family:Consolas,monospace;font-size:.82rem}.excel-textarea:focus{border-color:#c8a84b}.excel-error{color:#e84040;white-space:pre-wrap;background:#1a0808;border:1px solid #4a1010;border-radius:4px;margin:0;padding:.4rem .6rem;font-size:.8rem}.dupe-notice{color:#d89060;background:#b4641426;border:1px solid #7a4010;border-radius:6px;padding:.7rem .9rem;font-size:.85rem}.dupe-notice-header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.4rem;font-weight:600;display:flex}.dupe-notice-close{color:#d89060;cursor:pointer;opacity:.8;background:0 0;border:none;padding:0;font-size:.95rem;line-height:1}.dupe-notice-close:hover{opacity:1}.dupe-notice-list{flex-direction:column;gap:.1rem;margin:0;padding-left:1.2rem;display:flex}.item-form{background:#150d0d;border:1px solid #2a1818;border-radius:6px;flex-direction:column;gap:.7rem;padding:1.1rem;display:flex}.item-form h3{color:#c8a84b;margin:0 0 .1rem;font-size:.9rem}.form-row{flex-direction:column;gap:.28rem;display:flex}.form-row label{color:#7a5a4a;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem}.form-row input,.form-row textarea{color:#e8d5c0;resize:vertical;background:#0d0808;border:1px solid #3a2020;border-radius:4px;outline:none;padding:.45rem .65rem;font-family:inherit;font-size:.92rem}.form-row input:focus,.form-row textarea:focus{border-color:#c8a84b}.image-drop-zone{cursor:pointer;background:#0d0808;border:2px dashed #3a2020;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;min-height:90px;transition:border-color .15s,background .15s;display:flex;position:relative;overflow:hidden}.image-drop-zone:hover{background:#130d08;border-color:#c8a84b}.image-drop-zone.drag-over{background:#1a1205;border-color:#c8a84b;box-shadow:0 0 0 3px #c8a84b22}.image-drop-hint{color:#5a3a3a;pointer-events:none;text-align:center;padding:.5rem;font-size:.85rem}.image-drop-zone.has-image{min-height:120px}.image-preview-drop{object-fit:contain;border-radius:4px;width:100%;max-height:160px;display:block}.image-drop-replace{color:#9a7a5a;text-align:center;opacity:0;background:#000a;padding:.25rem;font-size:.72rem;transition:opacity .15s;position:absolute;bottom:0;left:0;right:0}.image-drop-zone:hover .image-drop-replace{opacity:1}.image-drop-zone.uploading{opacity:.6;cursor:wait}.image-upload-error{color:#e05050;margin:.25rem 0 0;font-size:.78rem}.image-url-input{color:#9a7060;box-sizing:border-box;background:#0d0808;border:1px solid #2a1818;border-radius:4px;outline:none;width:100%;margin-top:.35rem;padding:.3rem .55rem;font-family:inherit;font-size:.78rem}.image-url-input:focus{color:#e8d5c0;border-color:#c8a84b}.image-input-group{gap:.4rem;display:flex}.image-input-group input{flex:1}.btn-file{color:#c8a84b;cursor:pointer;white-space:nowrap;background:#181005;border:1px solid #3a2a08;border-radius:4px;padding:.45rem .7rem;font-size:.82rem}.btn-file:hover{background:#221508}.image-preview{object-fit:contain;border:1px solid #3a2020;border-radius:4px;width:120px;height:78px;margin-top:.3rem}.form-actions{gap:.5rem;display:flex}.btn-save{color:#f5dfa0;cursor:pointer;background:linear-gradient(135deg,#b03020,#7a0808);border:none;border-radius:4px;padding:.45rem 1.4rem;font-size:.88rem;font-weight:600}.btn-save:hover{background:linear-gradient(135deg,#d04030,#960a0a)}.btn-cancel{color:#7a5a5a;cursor:pointer;background:0 0;border:1px solid #3a2020;border-radius:4px;padding:.45rem 1rem;font-size:.88rem}.btn-cancel:hover{background:#1e0e0e}.no-items{color:#5a3030;font-size:.88rem;font-style:italic}.items-table{border-collapse:collapse;width:100%;font-size:.88rem}.items-table th{text-align:left;text-transform:uppercase;letter-spacing:.1em;color:#6a4a3a;border-bottom:1px solid #2a1818;padding:.4rem .65rem;font-size:.68rem}.items-table td{vertical-align:middle;border-bottom:1px solid #180e0e;padding:.55rem .65rem}.items-table tr:hover td{background:#140a0a}.items-table tr.row-editing td{background:#1e0c08}.cell-concept{color:#e0c090;width:160px;font-weight:600}.cell-concept-fi{color:#8fb8e8;margin-top:2px;font-size:.78em;font-style:italic;font-weight:400;display:block}.cell-explanation{color:#c0a880}.cell-image{width:72px}.thumb{object-fit:contain;border:1px solid #2a1818;border-radius:3px;width:56px;height:38px}.no-image{color:#3a2020}.cell-actions{white-space:nowrap;width:64px}.cell-actions button{cursor:pointer;color:#6a4a4a;background:0 0;border:none;border-radius:3px;padding:.18rem .38rem;font-size:.88rem}.cell-actions button:hover{color:#c8a84b;background:#201408}.cell-actions button.btn-danger:hover{color:#e84040;background:#200808}.teacher-page{color:#f0d8c0;background:#0a0606;min-height:100vh;padding:1.5rem 2rem 3rem;font-family:Georgia,serif}.teacher-header{align-items:center;gap:1.2rem;margin-bottom:2rem;display:flex}.teacher-header h1{color:#c8a84b;letter-spacing:.1em;margin:0;font-size:1.4rem}.btn-group-game{color:#70b0e0;cursor:pointer;background:linear-gradient(135deg,#1a2a3a,#0e1820);border:1px solid #3a6080;border-radius:6px;padding:.55rem 1.8rem;font-family:inherit;font-size:.92rem;transition:border-color .15s,color .15s}.btn-group-game:hover{color:#a0d0f0;border-color:#60a0d0}.group-game-row{justify-content:center;margin-top:.8rem;display:flex}.teacher-setup{text-align:center;color:#c8a84b;max-width:420px;margin:4rem auto;font-size:1.1rem}.teacher-notice{color:#e8a070;text-align:left;background:#b43c1426;border:1px solid #8b3a1a;border-radius:8px;margin-bottom:1.6rem;padding:.85rem 1.1rem;font-size:.9rem;line-height:1.5}.count-row{justify-content:center;gap:1rem;margin-top:1.2rem;display:flex}.count-row input{text-align:center;color:#f0d8c0;background:#1a0a0a;border:1px solid #5a2a2a;border-radius:3px;width:80px;padding:.4rem;font-family:inherit;font-size:1.5rem}.count-row button{color:#1a0000;cursor:pointer;letter-spacing:.08em;background:linear-gradient(135deg,#c8a84b 0%,#c0392b 100%);border:none;border-radius:3px;padding:.5rem 1.6rem;font-family:inherit;font-size:1rem;font-weight:700}.count-row button:disabled{opacity:.5;cursor:default}.teacher-actions{gap:.75rem;margin-bottom:1.5rem;display:flex}.teacher-actions button{color:#c8a84b;cursor:pointer;background:#1e0c0c;border:1px solid #5a2a2a;border-radius:3px;padding:.45rem 1.2rem;font-family:inherit;font-size:.85rem;transition:border-color .15s}.btn-print{color:#1a0000!important;background:linear-gradient(135deg,#c8a84b 0%,#c0392b 100%)!important;border:none!important;font-weight:700!important}.db-ok{color:#5da85d;letter-spacing:.04em;font-size:.85rem}.db-error{color:#e05050;letter-spacing:.04em;font-size:.85rem}.cred-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.6rem;max-width:900px;display:grid}.cred-card{background:#120808;border:1px dashed #5a2a2a;border-radius:4px;padding:.7rem 1rem}.cred-card-title{color:#c8a84b;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.45rem;font-size:.8rem;font-weight:700}.cred-row{justify-content:space-between;align-items:baseline;padding:.1rem 0;display:flex}.cred-row span{color:#9a6060;letter-spacing:.04em;font-size:.8rem}.cred-row strong{color:#f0d8c0;letter-spacing:.05em;font-family:Courier New,monospace;font-size:1rem}.sql-section{max-width:900px;margin-top:2.5rem}.sql-section h3{color:#c8a84b;letter-spacing:.08em;margin:0 0 .6rem;font-size:1rem}.sql-section pre{color:#7ad87a;white-space:pre-wrap;word-break:break-all;background:#060303;border:1px solid #3a1a1a;border-radius:4px;max-height:180px;padding:.9rem 1rem;font-size:.72rem;line-height:1.6;overflow-y:auto}.sql-section button{color:#c8a84b;cursor:pointer;background:#1e0c0c;border:1px solid #5a2a2a;border-radius:3px;margin-top:.5rem;padding:.35rem 1.1rem;font-family:inherit;font-size:.85rem;transition:color .15s,border-color .15s}.sql-section button:hover{color:#f0d8c0;border-color:#c8a84b}.print-materials-section{text-align:center;border-top:1px solid #2a1a1a;max-width:600px;margin:0 auto 3rem;padding-top:2rem}.pm-title{color:#c8a84b;letter-spacing:.08em;margin:0 0 .35rem;font-size:1.05rem}.pm-desc{color:#9a7060;margin:0 0 1rem;font-size:.88rem}.pm-controls{margin-bottom:.75rem}.pm-select{color:#f0d8c0;cursor:pointer;background:#1a0a0a;border:1px solid #5a2a2a;border-radius:3px;width:100%;max-width:380px;padding:.45rem .8rem;font-family:inherit;font-size:.92rem}.pm-btn-row{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.pm-btn{cursor:pointer;letter-spacing:.04em;border:1px solid;border-radius:3px;padding:.55rem 1.6rem;font-family:inherit;font-size:.9rem;font-weight:700;transition:filter .15s}.pm-btn:disabled{opacity:.4;cursor:default}.pm-btn:not(:disabled):hover{filter:brightness(1.18)}.pm-btn--concept{color:#a8a8e8;background:linear-gradient(135deg,#1e1840,#130e28);border-color:#5858b8}.pm-btn--memory{color:#88c888;background:linear-gradient(135deg,#163016,#0d1e0d);border-color:#487848}.concept-card-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.7rem;max-width:980px;padding:.5rem 0;display:grid}.concept-card{break-inside:avoid;background:#130a04;border:1px dashed #5a3a10;border-radius:4px;flex-direction:column;align-items:center;gap:.4rem;padding:.7rem .9rem;display:flex}.cc-header{color:#c8a84b;letter-spacing:.18em;text-transform:uppercase;align-self:flex-start;font-size:.72rem;font-weight:700}.cc-img{object-fit:contain;border-radius:3px;width:100%;max-height:130px}.cc-concept{color:#f0e0b0;text-align:center;font-family:Georgia,serif;font-size:1.25rem;font-weight:700;line-height:1.2}.cc-explanation{color:#a09070;text-align:center;border-top:1px solid #3a2a10;width:100%;padding-top:.35rem;font-size:.8rem;line-height:1.4}.memory-card-grid{grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:.6rem;max-width:980px;padding:.5rem 0;display:grid}.memory-card{aspect-ratio:1;break-inside:avoid;border:1px dashed;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;padding:.5rem;display:flex;position:relative}.mc-image{background:#0e0e20;border-color:#4040a0}.mc-concept{background:#1a1206;border-color:#6a5020}.mc-expl{background:#0e1a0e;border-color:#386038}.mc-pair{color:#66668a;font-family:Courier New,monospace;font-size:.62rem;position:absolute;top:4px;right:6px}.mc-img{object-fit:contain;border-radius:2px;width:100%;height:75%}.mc-text{color:#f0e0c0;text-align:center;font-size:clamp(.9rem,2.5vw,1.2rem);font-weight:700;line-height:1.3}.mc-text--expl{color:#88c888;font-size:clamp(.78rem,2vw,.95rem);font-weight:400}.mc-text--combo{color:#d0c090;margin-top:2px;font-size:clamp(.7rem,1.8vw,.85rem);font-weight:600}.mc-concept-fi{color:#80b0e0;text-align:center;margin-top:1px;font-size:clamp(.6rem,1.5vw,.75rem);font-style:italic;font-weight:400}.mc-image--trilingual .mc-img{height:60%}.print-only{display:none}@media print{.no-print{display:none!important}.print-only{display:block}.teacher-page{padding:10mm;color:#000!important;background:#fff!important}.print-title{text-align:center;margin-bottom:8mm}.print-title h2{margin:0 0 2mm;font-size:14pt}.print-title p{color:#555;margin:0;font-size:9pt}.cred-grid{grid-template-columns:repeat(3,1fr);gap:4mm;max-width:100%;display:grid}.cred-card{page-break-inside:avoid;break-inside:avoid;border:1px dashed #aaa;border-radius:0;padding:5mm 6mm;background:#fff!important}.cred-card-title{margin-bottom:3mm;font-size:9pt;color:#333!important}.cred-row{font-size:10pt}.cred-row span{font-size:8pt;color:#666!important}.cred-row strong{font-family:Courier New,monospace;font-size:11pt;color:#000!important}.concept-card-grid{grid-template-columns:repeat(2,1fr);gap:5mm;max-width:100%;display:grid}.concept-card{border:1px dashed #bbb;border-radius:0;padding:4mm 5mm;background:#fff!important}.cc-header{font-size:7pt;color:#555!important}.cc-img{max-height:30mm}.cc-concept{font-size:14pt;color:#000!important}.cc-explanation{border-top-color:#ccc;font-size:8pt;color:#444!important}.memory-card-grid{grid-template-columns:repeat(4,1fr);gap:4mm;max-width:100%;display:grid}.memory-card{aspect-ratio:1;border:1px dashed #aaa;border-radius:0;background:#fff!important}.mc-image,.mc-concept,.mc-expl{border-color:#aaa;background:#fff!important}.mc-pair{font-size:7pt;color:#bbb!important}.mc-text{font-size:11pt;color:#000!important}.mc-text--expl{font-size:9pt;color:#333!important}.mc-text--combo{font-size:8pt;color:#333!important}.mc-concept-fi{font-size:7pt;color:#369!important}.mc-image--trilingual .mc-img{height:60%}}.tgg-page{color:#c8b890;background:#080c14;flex-direction:column;min-height:100dvh;font-family:Georgia,serif;display:flex}.tgg-header{border-bottom:1px solid #2a3040;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.tgg-title{color:#f0e0b0;margin:0;font-size:1.2rem}.tgg-back{color:#9090b0;cursor:pointer;background:0 0;border:1px solid #3a4060;border-radius:6px;padding:.35rem .8rem;font-family:inherit;font-size:.85rem}.tgg-back:hover{color:#c0c0e0;border-color:#6060a0}.tgg-back--sm{padding:.25rem .6rem;font-size:.78rem}.tgg-setup-form{flex-direction:column;gap:.8rem;max-width:440px;margin:2rem auto;padding:0 1.5rem;display:flex}.tgg-label{letter-spacing:.1em;color:#7a6a50;text-transform:uppercase;font-size:.75rem}.tgg-select{color:#c8b890;background:#0e1820;border:1px solid #2a3a50;border-radius:6px;width:100%;padding:.55rem .8rem;font-family:inherit;font-size:.95rem}.tgg-select:focus{border-color:#5070a0;outline:none}.tgg-type-btns{gap:.6rem;display:flex}.tgg-type-btn{color:#6a7a90;cursor:pointer;background:#0e1820;border:1px solid #2a3a50;border-radius:8px;flex:1;padding:.7rem .5rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,color .15s,background .15s}.tgg-type-btn.active{color:#90c8f0;background:#0e2030;border-color:#5090d0}.tgg-type-btn:hover:not(.active){color:#a0b0c0;border-color:#4060a0}.tgg-error{color:#e05050;margin:0;font-size:.82rem}.tgg-create-btn{color:#70d090;cursor:pointer;background:linear-gradient(135deg,#1a3a1a,#0e2010);border:1px solid #3a7040;border-radius:8px;margin-top:.5rem;padding:.9rem;font-family:inherit;font-size:1rem;font-weight:700;transition:border-color .15s,transform .1s}.tgg-create-btn:hover:not(:disabled){border-color:#60c070;transform:translateY(-2px)}.tgg-create-btn:disabled{opacity:.4;cursor:not-allowed}.tgg-projector{background:#04080e;padding:0}.tgg-proj-topbar{background:#080e18;border-bottom:1px solid #1a2030;justify-content:space-between;align-items:center;padding:.7rem 1.5rem;display:flex}.tgg-proj-info{color:#6080a0;font-size:.9rem}.tgg-close-btn{color:#c05050;cursor:pointer;background:0 0;border:1px solid #5a2020;border-radius:6px;padding:.3rem .7rem;font-family:inherit;font-size:.82rem}.tgg-close-btn:hover{border-color:#c05050}.tgg-pin-block{text-align:center;padding:2.5rem 1rem 2rem}.tgg-pin-label{letter-spacing:.35em;color:#c8a84b;text-transform:uppercase;text-shadow:0 0 18px #c8a84b66;margin-bottom:.5rem;font-size:clamp(1.1rem,3vw,1.6rem);font-weight:900}.tgg-pin-number{letter-spacing:.12em;color:#f0f0ff;text-shadow:0 0 40px #5090ff88,0 0 80px #3060d040;font-size:clamp(4rem,15vw,10rem);font-weight:900;line-height:1}.tgg-pin-hint{color:#4a6080;margin-top:.8rem;font-size:.95rem}.tgg-lobby-players{flex:1;padding:0 1.5rem 1.5rem}.tgg-player-count{letter-spacing:.1em;color:#5060a0;text-transform:uppercase;margin-bottom:.8rem;font-size:.8rem}.tgg-player-grid{flex-wrap:wrap;gap:.5rem;display:flex}.tgg-player-badge{color:#80b0e0;background:#0e1a2a;border:1px solid #2a4060;border-radius:6px;padding:.35rem .75rem;font-size:.9rem;animation:.3s badgePop}@keyframes badgePop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.tgg-start-btn{color:#80e090;cursor:pointer;background:linear-gradient(135deg,#1a4a1a,#0e2e0e);border:2px solid #40a050;border-radius:10px;margin:0 1.5rem 1.5rem;padding:1rem 2rem;font-family:Georgia,serif;font-size:1.15rem;font-weight:700;transition:border-color .15s,transform .1s,box-shadow .15s}.tgg-start-btn:hover:not(:disabled){border-color:#70e080;transform:translateY(-2px);box-shadow:0 6px 24px #40a05044}.tgg-start-btn:disabled{opacity:.4;cursor:not-allowed}.tgg-team-count-row{gap:.5rem;display:flex}.tgg-team-count-btn{color:#6a7a90;cursor:pointer;background:#0e1820;border:1px solid #2a3a50;border-radius:6px;width:2.6rem;height:2.6rem;font-family:inherit;font-size:1rem;font-weight:700;transition:border-color .15s,color .15s,background .15s}.tgg-team-count-btn.active{color:#90c8f0;background:#0e2030;border-color:#5090d0}.tgg-team-count-btn:hover:not(.active){color:#a0b0c0;border-color:#4060a0}.tgg-team-groups{flex-wrap:wrap;gap:1rem;display:flex}.tgg-team-col{background:#080e18;border:1px solid #1a2a3a;border-radius:8px;flex:1;min-width:100px;padding:.5rem .7rem}.tgg-team-label{letter-spacing:.1em;color:#4060a0;text-transform:uppercase;margin-bottom:.4rem;font-size:.72rem}.tgg-lb-team{background:#0a1018;border:1px solid #1a2030;border-radius:8px;margin-bottom:.4rem;padding:.6rem 1rem;transition:border-color .3s}.tgg-lb-team.tgg-lb-done{border-color:#2a5030}.tgg-lb-team.tgg-lb-playing{opacity:.75}.tgg-lb-team-header{align-items:center;gap:.8rem;display:flex}.tgg-lb-team-members{flex-wrap:wrap;gap:.35rem;margin-top:.4rem;display:flex}.tgg-lb-member{color:#7090b8;background:#0c1420;border:1px solid #1a2030;border-radius:4px;padding:.15rem .45rem;font-size:.78rem}.tgg-lb-member.done{color:#90c8a0;border-color:#2a4030}.tgg-lb-title{text-align:center;color:#f0e0b0;margin:1.2rem 0 .5rem;font-size:1.3rem}.tgg-status-playing{color:#70d090;font-size:.95rem}.tgg-status-done{color:#f0d060;font-size:.95rem}.tgg-leaderboard{flex-direction:column;flex:1;gap:.45rem;padding:0 1.5rem 1.5rem;display:flex}.tgg-no-players{color:#4060a0;text-align:center;margin-top:2rem}.tgg-lb-row{background:#0a1018;border:1px solid #1a2030;border-radius:8px;align-items:center;gap:.8rem;padding:.65rem 1rem;transition:border-color .3s;display:flex}.tgg-lb-row.tgg-lb-done{border-color:#2a5030}.tgg-lb-row.tgg-lb-playing{opacity:.7;border-color:#1a2030}.tgg-lb-rank{text-align:center;min-width:2rem;font-size:1.3rem}.tgg-lb-name{color:#e8f0ff;flex:1;font-size:1.1rem}.tgg-lb-score{color:#70ff90;text-align:right;min-width:6rem;font-size:1.05rem;font-weight:700}.tgg-lb-row.tgg-lb-playing .tgg-lb-name{color:#8090c0}.tgg-lb-row.tgg-lb-playing .tgg-lb-score{color:#5a7090;font-weight:400}.tgg-podium-page{z-index:20;background:radial-gradient(at 50% 60%,#06101c,#02040a);flex-direction:column;justify-content:flex-start;align-items:center;padding:4rem 1.5rem 1.5rem;display:flex;position:fixed;inset:0;overflow-y:auto}.tgg-podium-back{position:absolute;top:1rem;right:1.5rem}.tgg-podium-title{letter-spacing:.18em;color:#c8a84b;text-shadow:0 0 30px #c8a84b99;text-align:center;opacity:0;margin-bottom:.3rem;font-size:clamp(1.4rem,5vw,2.6rem);font-weight:900;transition:opacity .8s,transform .8s;transform:translateY(-20px)}.tgg-podium-title.visible{opacity:1;transform:translateY(0)}.tgg-podium-sub{color:#506080;letter-spacing:.1em;margin-bottom:2rem;font-size:.9rem}.tgg-podium-cards{flex-direction:column;gap:.9rem;width:100%;max-width:520px;display:flex}.tgg-podium-card{opacity:0;background:#080e18;border:2px solid #1a2030;border-radius:12px;align-items:center;gap:1.2rem;padding:1rem 1.5rem;transition:opacity .75s,transform .75s cubic-bezier(.175,.885,.32,1.275);display:flex;transform:translateY(40px)scale(.88)}.tgg-podium-card.visible{opacity:1;transform:translateY(0)scale(1)}.tgg-podium-card.gold{background:#120e04;border-color:#c8a84b}.tgg-podium-card.silver{background:#0c0c12;border-color:#9898b0}.tgg-podium-card.bronze{background:#100804;border-color:#a06030}.tgg-podium-card-left{flex:1}.tgg-podium-card-rank{letter-spacing:.15em;text-transform:uppercase;color:#506080;margin-bottom:.2rem;font-size:.72rem}.tgg-podium-card.gold .tgg-podium-card-rank{color:#c8a84b}.tgg-podium-card.silver .tgg-podium-card-rank{color:#9898b0}.tgg-podium-card.bronze .tgg-podium-card-rank{color:#a06030}.tgg-podium-card-name{color:#f0e0b0;font-size:1.3rem;font-weight:700;line-height:1.2}.tgg-podium-card.gold .tgg-podium-card-name{color:#ffe080;font-size:1.7rem}.tgg-podium-card-members{color:#5070a0;margin-top:.25rem;font-size:.75rem}.tgg-podium-card-score{color:#80e0a0;white-space:nowrap;font-size:1.3rem;font-weight:700}.tgg-podium-card.gold .tgg-podium-card-score{color:#b0ffb0;font-size:1.6rem}.tgg-podium-list-overlay{background:#04080f;border-top:2px solid #2a3a50;border-radius:16px 16px 0 0;flex-direction:column;gap:.4rem;max-height:60dvh;padding:1.2rem 1.5rem 2rem;transition:transform .9s cubic-bezier(.25,.46,.45,.94);display:flex;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%)}.tgg-podium-list-overlay.visible{transform:translateY(0)}.tgg-podium-list-title{letter-spacing:.2em;color:#5060a0;text-transform:uppercase;text-align:center;margin-bottom:.8rem;font-size:.72rem}.tgg-carousel-section{flex-shrink:0;width:100%;max-width:520px;margin:1.2rem auto 0}.tgg-carousel-label{letter-spacing:.22em;color:#4060a0;text-transform:uppercase;text-align:center;margin-bottom:.6rem;font-size:.68rem}.tgg-carousel-window{height:180px;position:relative;overflow:hidden}@keyframes tgg-carousel-scroll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.tgg-carousel-track{flex-direction:column;gap:.4rem;padding-bottom:.4rem;animation:linear infinite tgg-carousel-scroll;display:flex}.tgg-carousel-row{background:#0a1018;border:1px solid #1a2030;border-radius:8px;flex-shrink:0;align-items:center;gap:.8rem;padding:.55rem 1rem;display:flex}.tgg-carousel-row.tgg-lb-done{border-color:#2a5030}.tgg-carousel-row.tgg-lb-playing{opacity:.6}.spe-page{background:#080c14;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;display:flex;position:relative}.spe-back{color:#6070a0;cursor:pointer;background:0 0;border:1px solid #2a3040;border-radius:6px;padding:.35rem .75rem;font-family:Georgia,serif;font-size:.85rem;position:absolute;top:1.2rem;left:1.2rem}.spe-back:hover{color:#a0b0d0;border-color:#5060a0}.spe-card{background:#0c1420;border:1px solid #2a3a50;border-radius:14px;flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:360px;padding:2.5rem 2rem;display:flex;box-shadow:0 8px 40px #00000060}.spe-icon{font-size:2.5rem}.spe-title{color:#f0e0b0;text-align:center;margin:0;font-family:Georgia,serif;font-size:1.4rem}.spe-desc{color:#6080a0;text-align:center;margin:0;font-size:.85rem;line-height:1.5}.spe-input{color:#f0f0ff;letter-spacing:.3em;text-align:center;background:#080e18;border:2px solid #2a4060;border-radius:10px;width:100%;padding:.6rem .8rem;font-family:Georgia,serif;font-size:2.4rem;font-weight:900;transition:border-color .15s}.spe-input:focus{border-color:#5090d0;outline:none;box-shadow:0 0 12px #5090d030}.spe-input::placeholder{color:#2a3a50;letter-spacing:.2em}.spe-error{color:#e06060;text-align:center;margin:0;font-size:.82rem}.spe-btn{color:#80e090;cursor:pointer;background:linear-gradient(135deg,#1a3a1a,#0e2010);border:1px solid #40a050;border-radius:8px;width:100%;padding:.75rem 2rem;font-family:Georgia,serif;font-size:1rem;font-weight:700;transition:border-color .15s,transform .1s}.spe-btn:hover:not(:disabled){border-color:#70e080;transform:translateY(-2px)}.spe-btn:disabled{opacity:.4;cursor:not-allowed}.memboard-wrap{color:#e8d5c0;-webkit-user-select:none;user-select:none;background:radial-gradient(80% 55%,#1a0606 0%,#0000 70%),#080404;flex-direction:column;width:100vw;min-height:100vh;font-family:Georgia,serif;display:flex}.mb-header{background:#110808;border-bottom:1px solid #2a1212;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.9rem;padding:.55rem 1.25rem;display:flex}.mb-back{color:#c97878;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #4a2020;border-radius:4px;padding:.3rem .8rem;font-family:inherit;font-size:.85rem}.mb-back:hover{background:#1e0808}.mb-title{color:#c8a84b;letter-spacing:.06em;white-space:nowrap;font-size:1rem;font-weight:700}.mb-subname{color:#9a7060;white-space:nowrap;margin-right:auto;font-size:.82rem}.mb-hud{align-items:center;gap:1rem;display:flex}.mb-hud-item{color:#9a8060;white-space:nowrap;font-size:.82rem}.mb-hud-err{color:#c05050}.mb-hud-ok{color:#60a060}.mb-grid{flex:1;grid-template-columns:repeat(5,minmax(0,160px));place-content:center;gap:14px;padding:2rem 1.5rem;display:grid}@media (width<=700px){.mb-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:1.2rem .8rem}}@media (width<=480px){.mb-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:.8rem .5rem}}.mb-card{aspect-ratio:5/6;perspective:900px;cursor:pointer}.mb-card-inner{width:100%;height:100%;transform-style:preserve-3d;border-radius:10px;transition:transform .45s cubic-bezier(.4,0,.2,1);position:relative}.mb-card--flipped .mb-card-inner,.mb-card--wrong .mb-card-inner,.mb-card--matched .mb-card-inner{transform:rotateY(180deg)}.mb-card-back{backface-visibility:hidden;background:linear-gradient(135deg,#2e0c0c,#180606);border:2px solid #5a1a1a;border-radius:10px;justify-content:center;align-items:center;transition:border-color .15s,box-shadow .15s;display:flex;position:absolute;inset:0}.mb-card--hidden:hover .mb-card-back{border-color:#c8a84b;box-shadow:0 0 18px #c8a84b33}.mb-card-back-icon{opacity:.3;color:#c8a84b;font-size:2rem}.mb-card-front{backface-visibility:hidden;background:linear-gradient(160deg,#1e1008,#130808);border:2px solid #4a3010;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;padding:.5rem .4rem;display:flex;position:absolute;inset:0;overflow:hidden;transform:rotateY(180deg)}.mb-card-front--concept{border-color:#5a3a10}.mb-card-front--explanation{border-color:#1a3a1a}.mb-card-front--image{border-color:#2a2a50;padding:.3rem}.mb-card-front--combo{border-color:#2a3a50}.mb-card-text{color:#e8d5c0;text-align:center;-webkit-hyphens:none;hyphens:none;word-break:normal;overflow-wrap:normal;font-size:.72rem;line-height:1.35}.mb-card-text--large{letter-spacing:-.02em;color:#f0e0b0;font-size:clamp(1.4rem,4.5vw,2.4rem);font-weight:700;line-height:1}.mb-card-img{object-fit:contain;border-radius:4px;width:100%;max-height:75%}.mb-card-img--combo{max-height:65%}.mb-card-combo-label{color:#c8b890;text-align:center;word-break:break-word;font-size:.7rem;line-height:1.2}@keyframes mb-wrong-flash{0%{box-shadow:none}10%{box-shadow:0 0 0 3px #f33,0 0 20px #f338}20%{box-shadow:none}30%{box-shadow:0 0 0 3px #f33,0 0 20px #f338}40%{box-shadow:none}50%{box-shadow:0 0 0 3px #f33,0 0 20px #f338}60%{box-shadow:none}70%{box-shadow:0 0 0 3px #f33,0 0 20px #f338}80%{box-shadow:none}90%{box-shadow:0 0 0 3px #f33,0 0 20px #f338}to{box-shadow:none}}.mb-card--wrong{animation:1.5s ease-in-out forwards mb-wrong-flash}@keyframes mb-match-flash{0%{box-shadow:none}10%{box-shadow:0 0 0 3px #0c4,0 0 20px #0c48}20%{box-shadow:none}30%{box-shadow:0 0 0 3px #0c4,0 0 20px #0c48}40%{box-shadow:none}50%{box-shadow:0 0 0 3px #0c4,0 0 20px #0c48}60%{box-shadow:none}70%{box-shadow:0 0 0 3px #0c4,0 0 20px #0c48}80%{box-shadow:none}90%{box-shadow:0 0 0 3px #0c4,0 0 20px #0c48}to{box-shadow:none}}.mb-card--matched{animation:1.5s ease-in-out forwards mb-match-flash}@keyframes mb-match-out{0%{opacity:1;transform:rotateY(180deg)scale(1)}40%{opacity:.9;transform:rotateY(180deg)scale(1.12)}to{opacity:0;transform:rotateY(180deg)scale(0)}}.mb-card--matched .mb-card-inner{pointer-events:none;animation:.45s ease-in 1.5s forwards mb-match-out}.mb-finished-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#040101e6;justify-content:center;align-items:center;animation:.4s ease-out mb-overlay-in;display:flex;position:fixed;inset:0}@keyframes mb-overlay-in{0%{opacity:0}to{opacity:1}}.mb-finished-box{background:linear-gradient(160deg,#1e0c0c,#120808);border:1px solid #4a2020;border-radius:16px;flex-direction:column;align-items:center;gap:.75rem;width:90%;max-width:380px;padding:2.5rem 2rem;animation:.45s cubic-bezier(.22,.9,.42,1) mb-box-in;display:flex;box-shadow:0 8px 40px #0008}@keyframes mb-box-in{0%{opacity:0;transform:scale(.75)}to{opacity:1;transform:scale(1)}}.mb-finished-icon{font-size:3rem;line-height:1}.mb-finished-praise{color:#f0e0b0;text-align:center;margin:0;font-size:1.6rem}.mb-finished-time,.mb-finished-mistakes{color:#9a7a60;margin:0;font-size:.9rem}.mb-finished-score{color:#c8a84b;letter-spacing:.06em;text-shadow:0 0 20px #c8a84b66;margin:.25rem 0;font-family:Georgia,serif;font-size:2rem;font-weight:700}.mb-finished-btns{flex-direction:column;gap:.6rem;width:100%;margin-top:.5rem;display:flex}.mb-btn-again,.mb-btn-stats,.mb-btn-back{cursor:pointer;letter-spacing:.05em;border:none;border-radius:6px;padding:.65rem 1.2rem;font-family:Georgia,serif;font-size:.9rem;font-weight:700;transition:filter .15s,transform .1s}.mb-btn-again{color:#f8e8d8;background:linear-gradient(135deg,#7b1c1c,#a02222);box-shadow:0 3px 12px #a0222244}.mb-btn-stats{color:#c8a84b;background:0 0;border:1px solid #5a3a1a}.mb-btn-back{color:#9a6060;background:0 0;border:1px solid #3a1a1a}.mb-btn-again:hover,.mb-btn-stats:hover,.mb-btn-back:hover{filter:brightness(1.15);transform:translateY(-1px)}.gameboard-wrap{-webkit-user-select:none;user-select:none;background:#080404;flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.gb-header{z-index:10;background:#110808;border-bottom:1px solid #2a1212;flex-shrink:0;align-items:center;gap:1.25rem;padding:.55rem 1.25rem;display:flex}.gb-back{color:#c97878;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #4a2020;border-radius:4px;padding:.3rem .8rem;font-family:inherit;font-size:.85rem}.gb-back:hover{background:#1e0808}.gb-score-display{flex-direction:column;align-items:center;margin-left:auto;display:flex}.gb-score-label{text-transform:uppercase;letter-spacing:.15em;color:#5a3030;font-size:.6rem}.gb-score-value{color:#c8a84b;letter-spacing:.06em;font-family:Georgia,serif;font-size:1.3rem;font-weight:700;line-height:1}.gb-remaining{color:#5a3030;margin-left:auto;font-size:.75rem}.gb-board{background:radial-gradient(80% 60%,#1a0606 0%,#0000 70%),#080404;flex:1;position:relative;overflow:hidden}.gb-card{cursor:grab;touch-action:none;background:linear-gradient(160deg,#1e0e0e,#130808);border:1.5px solid #3a1818;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.3rem;width:160px;min-height:130px;padding:.55rem .6rem;transition:box-shadow .12s,border-color .12s;display:flex;position:absolute;box-shadow:0 4px 18px #0008}.gb-card:active{cursor:grabbing}.gb-card:hover{border-color:#6a3030;box-shadow:0 6px 28px #0009,0 0 0 1px #6a303055}.gb-card-concept{border-color:#5a3a10}.gb-card-concept:hover{border-color:#c8a84b;box-shadow:0 6px 24px #c8a84b22}.gb-card-image{border-color:#2a2a50;padding:.3rem}.gb-card-image:hover{border-color:#6060c0}.gb-card-img-concept{color:#c8b890;text-align:center;word-break:break-word;margin-top:3px;font-size:.72rem;line-height:1.2}.gb-card-img-concept-fi{color:#8fb8e8;text-align:center;word-break:break-word;margin-top:1px;font-size:.65rem;font-style:italic;line-height:1.2}.gb-card-explanation{border-color:#1a3a1a}.gb-card-explanation:hover{border-color:#4a9a4a}.gb-card-text{color:#e8d5c0;text-align:center;-webkit-hyphens:none;hyphens:none;word-break:normal;overflow-wrap:break-word;font-size:.68rem;line-height:1.4}.gb-card-text--large{letter-spacing:-.02em;color:#f0e0b0;font-family:Georgia,serif;font-size:2.6rem;font-weight:700;line-height:1}.gb-card-img{object-fit:contain;border-radius:5px;width:100%;max-height:90px}.gb-card-kind-badge{opacity:.4;font-size:.75rem;position:absolute;top:4px;right:6px}@keyframes gb-spin-out{0%{opacity:1;transform:rotate(0)scale(1)}60%{opacity:.7;transform:rotate(540deg)scale(.6)}to{opacity:0;transform:rotate(720deg)scale(0)}}.gb-card.spinning{pointer-events:none;animation:.6s ease-in forwards gb-spin-out}.gb-card.snapping{transition:left .3s cubic-bezier(.4,0,.2,1),top .3s cubic-bezier(.4,0,.2,1);border-color:#8b1a1a!important;box-shadow:0 0 18px #c0392b88!important}@keyframes gb-wrong-flash{0%{box-shadow:none;border-color:#3a1818}1%{border-color:#f33;box-shadow:0 0 16px #f33b}7%{border-color:#f33;box-shadow:0 0 16px #f33b}10%{box-shadow:none;border-color:#3a1818}11%{border-color:#f33;box-shadow:0 0 16px #f33b}17%{border-color:#f33;box-shadow:0 0 16px #f33b}20%{box-shadow:none;border-color:#3a1818}21%{border-color:#f33;box-shadow:0 0 16px #f33b}27%{border-color:#f33;box-shadow:0 0 16px #f33b}30%{box-shadow:none;border-color:#3a1818}31%{border-color:#f33;box-shadow:0 0 16px #f33b}37%{border-color:#f33;box-shadow:0 0 16px #f33b}40%{box-shadow:none;border-color:#3a1818}41%{border-color:#f33;box-shadow:0 0 16px #f33b}47%{border-color:#f33;box-shadow:0 0 16px #f33b}50%{box-shadow:none;border-color:#3a1818}51%{border-color:#fc0;box-shadow:0 0 16px #fc0b}55%{border-color:#fc0;box-shadow:0 0 16px #fc0b}58%{box-shadow:none;border-color:#3a1818}59%{border-color:#fc0;box-shadow:0 0 16px #fc0b}63%{border-color:#fc0;box-shadow:0 0 16px #fc0b}66%{box-shadow:none;border-color:#3a1818}67%{border-color:#fc0;box-shadow:0 0 16px #fc0b}71%{border-color:#fc0;box-shadow:0 0 16px #fc0b}74%{box-shadow:none;border-color:#3a1818}75%{border-color:#fc0;box-shadow:0 0 16px #fc0b}79%{border-color:#fc0;box-shadow:0 0 16px #fc0b}82%{box-shadow:none;border-color:#3a1818}83%{border-color:#fc0;box-shadow:0 0 16px #fc0b}87%{border-color:#fc0;box-shadow:0 0 16px #fc0b}90%{box-shadow:none;border-color:#3a1818}91%{border-color:#90ee90;box-shadow:0 0 14px #90ee9099}to{border-color:#90ee90;box-shadow:0 0 14px #90ee9099}}.gb-card.wrong-flashing{animation:4.2s ease-in-out forwards gb-wrong-flash}@keyframes gb-float-up{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-70px)}}.gb-float-score{color:#c8a84b;pointer-events:none;text-shadow:0 0 12px #c8a84baa;white-space:nowrap;z-index:20;font-family:Georgia,serif;font-size:1.3rem;font-weight:700;animation:.9s ease-out forwards gb-float-up;position:absolute;transform:translate(-50%,-50%)}.gb-collage{z-index:5;background:#0d0606;border-top:1px solid #2a1010;flex-wrap:wrap;flex-shrink:0;align-content:flex-start;align-items:flex-start;gap:3px;min-height:56px;padding:4px 6px;display:flex;overflow:hidden}.gb-collage-item{background:#150808;border:1px solid #2a1010;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;animation:.35s cubic-bezier(.17,.67,.37,1.4) forwards gb-collage-pop;display:flex;overflow:hidden}@keyframes gb-collage-pop{0%{opacity:0;transform:scale(0)rotate(-20deg)}to{opacity:1;transform:scale(1)rotate(0)}}.gb-collage-item img{object-fit:contain;width:100%;height:100%}.gb-collage-text{color:#9a7060;text-align:center;word-break:break-word;padding:2px;font-size:.55rem;line-height:1.2}.gb-finished-overlay{z-index:30;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.gb-finished-box{background:linear-gradient(160deg,#220e0e,#150808);border:1px solid #4a2020;border-radius:12px;flex-direction:column;align-items:center;gap:1rem;padding:2.5rem 3rem;display:flex;box-shadow:0 0 60px #c8a84b22}.gb-finished-icon{filter:drop-shadow(0 0 20px #c8a84baa);font-size:3rem}.gb-finished-box h2{color:#e8d5c0;margin:0;font-family:Georgia,serif;font-size:1.8rem}.gb-finished-score{color:#c8a84b;letter-spacing:.06em;margin:0;font-family:Georgia,serif;font-size:2.2rem;font-weight:700}.gb-btn-again{color:#1a0a00;cursor:pointer;background:linear-gradient(135deg,#c8a84b,#8b6914);border:none;border-radius:5px;margin-top:.5rem;padding:.7rem 2rem;font-family:inherit;font-size:1rem;font-weight:700}.gb-btn-again:hover{filter:brightness(1.1)}.gb-btn-back{color:#9a6060;cursor:pointer;background:0 0;border:1px solid #4a2020;border-radius:5px;padding:.5rem 1.5rem;font-family:inherit;font-size:.88rem}.gb-btn-back:hover{background:#1e0808}.gb-btn-stats{color:#1a0000;cursor:pointer;letter-spacing:.06em;background:linear-gradient(135deg,#c8a84b 0%,#c0392b 100%);border:none;border-radius:5px;padding:.75rem 2.2rem;font-family:inherit;font-size:1.05rem;font-weight:700;transition:opacity .15s}.gb-btn-stats:hover{opacity:.85}@keyframes gb-star-pulse{0%,to{filter:drop-shadow(0 0 8px var(--star-color)) drop-shadow(0 0 18px var(--star-color));transform:scale(1)}50%{filter:drop-shadow(0 0 22px var(--star-color)) drop-shadow(0 0 44px var(--star-color));transform:scale(1.12)}}.gb-finished-star{color:var(--star-color);font-size:4.5rem;line-height:1;animation:2s ease-in-out infinite gb-star-pulse}.gb-finished-subtitle{color:#c0a080;text-align:center;margin:0;font-size:.95rem;font-style:italic;line-height:1.7}.gb-finished-star-name{color:#c8a84b;letter-spacing:.08em;text-shadow:0 0 10px #c8a84b66;font-family:Georgia,serif;font-size:1.25rem;font-style:normal;font-weight:900}@keyframes gb-next-star-glow{0%,to{text-shadow:0 0 6px var(--next-color), 0 0 12px var(--next-color)}50%{text-shadow:0 0 14px var(--next-color), 0 0 28px var(--next-color)}}.gb-btn-next-level{border:1.5px solid var(--next-color);color:var(--next-color);cursor:pointer;letter-spacing:.04em;box-shadow:0 0 10px color-mix(in srgb, var(--next-color) 30%, transparent);background:0 0;border-radius:5px;padding:.7rem 2rem;font-family:inherit;font-size:1rem;font-weight:700;transition:background .15s}.gb-btn-next-level:hover{background:color-mix(in srgb, var(--next-color) 15%, transparent)}.gb-next-star{color:var(--next-color);animation:1.6s ease-in-out infinite gb-next-star-glow}.gb-batch-transition{z-index:50;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#040101e6;justify-content:center;align-items:center;animation:.3s ease-out gb-batch-fadein;display:flex;position:fixed;inset:0}.gb-batch-transition-inner{flex-direction:column;align-items:center;gap:1rem;display:flex}.gb-batch-transition-icon{color:#c8a84b;filter:drop-shadow(0 0 20px #c8a84baa);font-size:3.5rem;animation:.8s ease-in-out infinite alternate gb-batch-icon-pulse}.gb-batch-transition-text{color:#f0e0c0;text-shadow:0 0 20px #c8a84b66,0 2px 6px #0008;letter-spacing:.04em;font-family:Georgia,serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700;animation:.5s ease-out forwards gb-batch-text-in}@keyframes gb-batch-fadein{0%{opacity:0}to{opacity:1}}@keyframes gb-batch-icon-pulse{0%{opacity:.8;transform:scale(.92)}to{opacity:1;transform:scale(1.08)}}@keyframes gb-batch-text-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.sl-game-wrapper{width:100%;height:100%;position:relative}.sl-live-toggle{z-index:200;color:#70b0e0;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a1423e0;border:1px solid #2a4060;border-radius:20px;padding:.35rem .85rem;font-family:inherit;font-size:.82rem;font-weight:700;transition:border-color .15s,color .15s;position:fixed;top:.7rem;right:.7rem}.sl-live-toggle.open{color:#a0d0f0;border-color:#5090d0}.sl-live-toggle:hover{border-color:#5090d0}.sl-player-badge{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none;white-space:nowrap;background:#080e1ae0;border:1px solid #2a4060;border-radius:20px;align-items:center;gap:.6rem;padding:.35rem 1rem;display:flex;position:fixed;bottom:.8rem;left:50%;transform:translate(-50%)}.sl-player-badge-name{color:#b0cce8;font-family:Georgia,serif;font-size:.88rem;font-weight:700}.sl-player-badge-team{color:#70b0e0;padding-left:.3rem;font-size:.78rem}.sl-live-panel{z-index:199;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#080e1aed;border:1px solid #1a3050;border-radius:10px;flex-direction:column;gap:.3rem;width:min(280px,90vw);max-height:60vh;padding:.6rem .8rem .8rem;display:flex;position:fixed;top:3rem;right:.7rem;overflow-y:auto}.sl-live-title{letter-spacing:.12em;color:#4060a0;text-transform:uppercase;margin-bottom:.2rem;font-size:.72rem}.sl-live-empty{color:#3a5070;font-size:.8rem}.sl-live-row{color:#5070a0;border-radius:5px;align-items:center;gap:.5rem;padding:.2rem .3rem;font-size:.8rem;display:flex}.sl-live-row.done{color:#80a870}.sl-live-row.me{color:#90c0f0;background:#28467859}.sl-live-rank{min-width:1.5rem;font-size:.85rem}.sl-live-name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sl-live-team{opacity:.7;font-size:.7rem}.sl-live-score{white-space:nowrap;font-weight:700}.sl-page{color:#c8b890;background:#080c14;flex-direction:column;align-items:center;min-height:100dvh;padding:1.5rem 1rem 2rem;font-family:Georgia,serif;display:flex;position:relative}.sl-back{color:#6070a0;cursor:pointer;background:0 0;border:1px solid #2a3040;border-radius:6px;padding:.35rem .75rem;font-family:inherit;font-size:.85rem;position:absolute;top:1.2rem;left:1.2rem}.sl-back:hover{color:#a0b0d0;border-color:#5060a0}.sl-warrior-block{text-align:center;flex-direction:column;gap:.4rem;margin-top:4rem;display:flex}.sl-warrior-label{letter-spacing:.12em;color:#5060a0;text-transform:uppercase;font-size:.78rem}.sl-warrior-name{color:#f0e0b0;letter-spacing:.04em;font-size:2rem;font-weight:700}.sl-team-badge{color:#70b0e0;background:#0a1828;border:1px solid #1a4060;border-radius:6px;margin:.3rem 0;padding:.2rem .6rem;font-size:.85rem;display:inline-block}.sl-lb-team{color:#4a80b0;text-align:center;background:#0a1420;border:1px solid #1a2a3a;border-radius:4px;min-width:2rem;padding:.1rem .35rem;font-size:.75rem}.sl-subcategory{color:#6080a0;font-size:.85rem}.sl-waiting-status{flex-direction:column;align-items:center;gap:1rem;margin-top:3rem;display:flex}.sl-spinner{border:3px solid #1a2a40;border-top-color:#4080d0;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}.sl-waiting-text{color:#5070a0;text-align:center;font-size:.9rem}.sl-results-hero{text-align:center;flex-direction:column;align-items:center;gap:.4rem;margin-top:2rem;display:flex}.sl-results-icon{font-size:3rem}.sl-your-score{color:#90e0a0;font-size:1.6rem;font-weight:700}.sl-no-score{color:#5070a0;font-size:1rem}.sl-rank-badge{color:#70d080;background:#1a3a1a;border:1px solid #40a050;border-radius:20px;margin-top:.2rem;padding:.25rem .8rem;font-size:.82rem}.sl-leaderboard{flex-direction:column;gap:.4rem;width:100%;max-width:420px;margin-top:1.5rem;display:flex}.sl-lb-row{background:#0a1018;border:1px solid #1a2030;border-radius:8px;align-items:center;gap:.7rem;padding:.55rem .9rem;display:flex}.sl-lb-row.sl-lb-me{background:#0c180e;border-color:#3a6040}.sl-lb-rank{text-align:center;min-width:1.8rem;font-size:1.1rem}.sl-lb-name{color:#b0c0d0;flex:1;font-size:.95rem}.sl-lb-score{color:#80c090;font-size:.9rem;font-weight:700}.sl-lb-row.sl-lb-me .sl-lb-name{color:#d0e8b0}.sl-lb-row.sl-lb-me .sl-lb-score{color:#90e0a0}.sl-done-btn{color:#80e090;cursor:pointer;background:linear-gradient(135deg,#1a3a1a,#0e2010);border:1px solid #40a050;border-radius:8px;margin-top:1.5rem;padding:.7rem 1.8rem;font-family:inherit;font-size:.95rem}.sl-done-btn:hover{border-color:#70e080}.sl-waiting-others{color:#4a5a70;margin-top:1.5rem;font-size:.8rem}.login-page{color:#f0d8c0;background:radial-gradient(90% 65% at 50% 42%,#2e0404 0%,#0000 68%),#080404;justify-content:center;align-items:center;min-height:100vh;font-family:Georgia,serif;display:flex}.login-card{background:#110606cc;border:1px solid #3a1a1a;border-radius:8px;flex-direction:column;align-items:center;gap:.9rem;width:min(380px,92vw);padding:2.5rem 2.8rem 2rem;display:flex;box-shadow:0 0 40px #8b000033}.login-emblem{filter:drop-shadow(0 0 18px #c0392bcc);font-size:2.4rem}.login-title{color:#c8a84b;letter-spacing:.08em;margin:0;font-size:1.5rem}.login-sub{color:#9a6060;letter-spacing:.06em;text-align:center;margin:0;font-size:.85rem}.login-fields{flex-direction:column;gap:.6rem;width:100%;display:flex}.login-input{box-sizing:border-box;color:#f0d8c0;background:#1a0808;border:1px solid #5a2a2a;border-radius:4px;outline:none;width:100%;padding:.6rem .9rem;font-family:inherit;font-size:1rem;transition:border-color .15s}.login-input:focus{border-color:#c8a84b}.login-input:disabled{opacity:.5}.login-error{color:#e05050;text-align:center;margin:0;font-size:.85rem}.btn-login{color:#1a0000;letter-spacing:.1em;cursor:pointer;background:linear-gradient(135deg,#c8a84b 0%,#c0392b 100%);border:none;border-radius:4px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;font-weight:700;transition:opacity .15s,transform .1s}.btn-login:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-login:disabled{opacity:.5;cursor:default}.login-divider{align-items:center;gap:.7rem;width:100%;display:flex}.divider-line{background:linear-gradient(90deg,#0000,#3a1a1aaa,#0000);flex:1;height:1px}.divider-text{color:#6a2a2a;letter-spacing:.1em;font-size:.8rem}.btn-guest{color:#9a6060;letter-spacing:.08em;cursor:pointer;background:0 0;border:1px solid #5a2a2a;border-radius:4px;width:100%;padding:.6rem;font-family:inherit;font-size:.9rem;transition:color .15s,border-color .15s}.btn-guest:hover{color:#c8a84b;border-color:#c8a84b}.btn-login-back{color:#5a2a2a;cursor:pointer;letter-spacing:.1em;background:0 0;border:none;padding:0;font-family:inherit;font-size:.78rem;transition:color .15s}.btn-login-back:hover{color:#9a6060}.np-page{color:#f0d8c0;background:radial-gradient(90% 65% at 50% 42%,#2e0404 0%,#0000 68%),#080404;justify-content:center;align-items:center;min-height:100vh;font-family:Georgia,serif;display:flex}.np-card{background:#110606cc;border:1px solid #3a1a1a;border-radius:8px;flex-direction:column;align-items:center;gap:1rem;width:min(400px,92vw);padding:2.5rem 2.8rem 2rem;display:flex;box-shadow:0 0 40px #8b000033}.np-emblem{filter:drop-shadow(0 0 18px #c0392bcc);font-size:2.4rem}.np-title{color:#c8a84b;letter-spacing:.08em;margin:0;font-size:1.5rem}.np-loading{color:#9a6060;letter-spacing:.06em;margin:0;font-size:.9rem}.np-error{color:#e05050;text-align:center;margin:0;font-size:.85rem}.np-cred-box{background:#1a0808;border:1px solid #5a2a2a;border-radius:6px;flex-direction:column;gap:.65rem;width:100%;padding:1.1rem 1.3rem;display:flex}.np-cred-row{flex-direction:column;gap:.15rem;display:flex}.np-cred-label{color:#9a6060;letter-spacing:.08em;text-transform:uppercase;font-size:.75rem}.np-cred-value{color:#f0d8c0;letter-spacing:.05em;word-break:break-all;font-size:1.25rem}.np-notice{color:#c8a84b;text-align:center;background:#1a0f0022;border:1px dashed #5a3a0a;border-radius:4px;margin:0;padding:.7rem .9rem;font-size:.85rem;line-height:1.5}.np-btn-login{color:#1a0000;letter-spacing:.1em;cursor:pointer;background:linear-gradient(135deg,#c8a84b 0%,#c0392b 100%);border:none;border-radius:4px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;font-weight:700;transition:opacity .15s,transform .1s}.np-btn-login:hover{opacity:.9;transform:translateY(-1px)}.np-btn-back{color:#5a2a2a;cursor:pointer;letter-spacing:.1em;background:0 0;border:none;padding:0;font-family:inherit;font-size:.78rem;transition:color .15s}.np-btn-back:hover{color:#9a6060}.stats-page{color:#f0d8c0;background:#0a0606;max-width:960px;min-height:100vh;margin:0 auto;padding:1.5rem 2rem 4rem;font-family:Georgia,serif}.stats-ninja-banner{width:calc(100% + 4rem);height:260px;margin-top:-.5rem;margin-bottom:1.5rem;margin-left:-2rem;position:relative;overflow:hidden}.stats-hero-banner{width:calc(100% + 4rem);height:310px;margin-top:-.5rem;margin-bottom:1.5rem;margin-left:-2rem;position:relative;overflow:hidden}.stats-ninja-img{object-fit:cover;object-position:center 20%;width:100%;height:100%;display:block;-webkit-mask-image:linear-gradient(#000 55%,#0000 100%);mask-image:linear-gradient(#000 55%,#0000 100%)}.stats-hero-overlay{pointer-events:none;position:absolute;inset:0}.stats-hero-topleft{pointer-events:auto;flex-direction:column;gap:.5rem;display:flex;position:absolute;top:1rem;left:1.5rem}.stat-pill-username{letter-spacing:.05em;font-size:1.3rem}.stats-hero-left{pointer-events:auto;position:absolute;top:50%;left:1.5rem;transform:translateY(-50%)}.stats-hero-top{pointer-events:auto;flex-direction:column;align-items:flex-end;gap:.5rem;display:flex;position:absolute;top:1rem;right:1.5rem}.stats-hero-top-right{display:contents}.stats-hero-stars{pointer-events:auto;justify-content:flex-start;display:flex;position:absolute;bottom:2.6rem;left:1.5rem;right:0}.stats-hero-progress{pointer-events:auto;position:absolute;bottom:1.2rem;left:1.5rem;right:1.5rem}.stats-header{align-items:center;gap:1.2rem;margin-bottom:2rem;display:flex}.stats-title-block{align-items:center;gap:.7rem;display:flex}.stats-emblem{filter:drop-shadow(0 0 10px #c0392baa);font-size:1.6rem}.stats-title{color:#c8a84b;letter-spacing:.08em;margin:0;font-size:1.5rem}.stats-subtitle{color:#8a3535;letter-spacing:.18em;text-transform:uppercase;font-size:.78rem}.stats-error,.stats-loading{text-align:center;color:#9a6060;margin-top:4rem}.star-legend{color:#9a5a3a;letter-spacing:.06em;flex-wrap:nowrap;gap:1.2rem;margin-bottom:1.2rem;font-size:.78rem;display:flex}@media (width<=340px){.star-legend{flex-wrap:wrap}}.star-legend-item{flex-direction:column;align-items:center;gap:.15rem;display:flex}.star-legend-icon{filter:drop-shadow(0 0 5px);font-size:1.1rem;line-height:1}.star-legend-name{letter-spacing:.1em;text-transform:uppercase;color:#d0b080;text-shadow:0 1px 4px #000c;font-size:.75rem}.star-legend-count{text-shadow:0 0 8px;font-family:Georgia,serif;font-size:1rem;font-weight:700;line-height:1}.star-row{gap:.2rem;margin-top:auto;padding-top:.45rem;display:flex}.star-row-md .star-item{font-size:1.1rem}.star-row-sm .star-item{font-size:.85rem}.star-item{line-height:1;transition:transform .1s}.star-earned{filter:drop-shadow(0 0 4px)}.star-empty{opacity:.35}.stats-summary{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.stat-pill{background:#120808;border:1px solid #3a1a1a;border-radius:8px;flex-direction:column;align-items:center;min-width:120px;padding:.75rem 1.6rem;display:flex}.stat-pill-hero{-webkit-backdrop-filter:blur(4px);background:#0a0404b8;border-color:#5a2a2a;min-width:100px;padding:.5rem 1.1rem}.stat-pill-value{color:#c8a84b;font-size:1.8rem;font-weight:700;line-height:1}.stat-pill-label{color:#9a5a3a;letter-spacing:.12em;text-transform:uppercase;margin-top:.3rem;font-size:.72rem}.stats-overall{margin-bottom:0}.progress-label{color:#b07060;letter-spacing:.08em;justify-content:space-between;margin-bottom:.4rem;font-size:.8rem;display:flex}.progress-pct{color:#c8a84b;font-weight:700}.progress-track{background:#1e0a0a;border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#c8a84b 0%,#c0392b 100%);border-radius:4px;height:100%;transition:width .6s}.stats-main-section{margin-bottom:1rem}.stats-main-card{cursor:pointer;text-align:left;background:#16100a;border:1px solid #4a3010;border-radius:8px;flex-direction:column;gap:.5rem;width:100%;padding:.75rem 1rem 0;font-family:inherit;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.stats-main-card:hover{border-color:#c8a84b;box-shadow:0 4px 16px #c8a84b22}.stats-main-card.expanded{border-color:#c0392b #c0392b currentColor;border-bottom-style:none;border-bottom-width:medium;border-bottom-right-radius:0;border-bottom-left-radius:0}.stats-main-card-top{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.stats-main-card-name{color:#c8a84b;letter-spacing:.1em;text-transform:uppercase;font-size:1rem;font-weight:700}.stats-main-card-right{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.stats-main-card-score{color:#c8a84b;letter-spacing:.04em;font-size:.8rem}.stats-main-card-count{color:#8a3535;letter-spacing:.06em;background:#1a0808;border:1px solid #4a1e1e;border-radius:10px;padding:.1rem .5rem;font-size:.75rem}.stats-main-card-chevron{color:#7a5a5a;font-size:.7rem}.stats-main-card-bar{background:#2a1a0a;border-radius:0 0 8px 8px;height:3px;margin:0 -1rem;overflow:hidden}.stats-main-card.expanded .stats-main-card-bar{border-radius:0}.stats-main-card-fill{background:linear-gradient(90deg,#c0392b,#c8a84b);border-radius:2px;height:100%;transition:width .4s}.stats-main-expanded{background:#0f0808;border:1px solid #c0392b;border-top:none;border-radius:0 0 8px 8px;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;padding:1rem;display:flex}.btn-close-main{color:#c8a84b;letter-spacing:.1em;cursor:pointer;background:#1e0808;border:1px solid #4a1e1e;border-radius:20px;align-self:center;margin-top:.5rem;padding:.4rem 1.2rem;font-family:inherit;font-size:.75rem;transition:background .12s,border-color .12s}.btn-close-main:hover{background:#2e1010;border-color:#c0392b}.stats-subgroup-section{margin-top:.5rem;margin-bottom:.25rem}.stats-subgroup-title{color:#9eb8d4;letter-spacing:.1em;text-transform:uppercase;border-left:3px solid #3a6080;margin:0 0 .6rem;padding-left:.6rem;font-size:.85rem}.stats-sub-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;display:grid}.stats-sub-card{cursor:pointer;text-align:left;border-radius:6px;flex-direction:column;gap:.25rem;width:100%;padding:.8rem 1rem;font-family:inherit;transition:transform .12s,border-color .15s,box-shadow .15s;display:flex;position:relative}.stats-sub-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #c0392b33;border-color:#c0392b!important}.stats-sub-card:active{transform:translateY(-1px)}.stats-sub-card.played{background:#12100a;border:1px solid #5a3a1a}.stats-sub-card.unplayed{opacity:.82;background:#0e0808;border:1px solid #2a1212}.sub-badge{letter-spacing:.14em;text-transform:uppercase;font-size:.68rem;font-weight:700}.played-badge{color:#7ad87a}.unplayed-badge{color:#c04848}.sub-name{color:#f0d8c0;margin-top:.15rem;font-size:1rem;font-weight:700;line-height:1.2}.sub-meta{color:#b86050;letter-spacing:.06em;font-size:.72rem}.sub-score{color:#c8a84b;margin-top:.3rem;font-size:1.3rem;font-weight:700;line-height:1}.sub-score span{color:#7a4a2a;letter-spacing:.1em;font-size:.7rem}.sub-score.unplayed-score{color:#8a3535}.sub-progress-track{background:#1e0a0a;border-radius:2px;height:4px;margin-top:.3rem;overflow:hidden}.sub-progress-fill{background:linear-gradient(90deg,#c8a84b 0%,#c0392b 100%);border-radius:2px;height:100%;transition:width .5s}.sub-detail{color:#9a5a3a;letter-spacing:.04em;margin-top:.1rem;font-size:.68rem}.btn-back{color:#9a6060;cursor:pointer;background:0 0;border:1px solid #5a2a2a;border-radius:3px;padding:.35rem 1rem;font-family:inherit;font-size:.85rem;transition:color .15s,border-color .15s}.btn-back:hover{color:#c8a84b;border-color:#c8a84b}.stats-header-right{align-items:stretch;gap:.5rem;margin-left:auto;display:flex}.btn-settings{color:#9a7060;cursor:pointer;background:0 0;border:1px solid #5a2a2a;border-radius:3px;align-items:center;padding:.4rem .6rem;font-size:1.1rem;line-height:1;transition:color .15s,border-color .15s;display:flex}.btn-settings:hover{color:#c8a84b;border-color:#c8a84b}.btn-logout{color:#9a6060;cursor:pointer;background:0 0;border:1px solid #5a2a2a;border-radius:3px;align-items:center;padding:.4rem 1rem;font-family:inherit;font-size:.85rem;transition:color .15s,border-color .15s;display:flex}.btn-logout:hover{color:#e05050;border-color:#e05050}.profile-edit-page{color:#e8d5c0;background:#080404;min-height:100vh;padding:0 1.5rem 3rem;font-family:Georgia,serif}.profile-edit-header{border-bottom:1px solid #2a1212;align-items:center;gap:1.5rem;margin-bottom:2rem;padding:.8rem 0 1.5rem;display:flex}.profile-edit-header h1{color:#c8a84b;letter-spacing:.08em;margin:0;font-size:1.2rem}.btn-back{color:#c8a84b;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #5a2a2a;border-radius:6px;padding:.4rem 1rem;font-family:inherit;font-size:.9rem;transition:background .15s}.btn-back:hover{background:#1a0a0a}.profile-current-user{color:#9a7060;margin:0 0 1.5rem;font-size:.9rem}.profile-current-user strong{color:#e8d5c0}.profile-edit-card{background:#110808;border:1px solid #2a1212;border-radius:10px;max-width:480px;margin:0 auto;padding:2rem}.profile-edit-form{flex-direction:column;gap:1.5rem;display:flex}fieldset{border:1px solid #3a1a1a;border-radius:8px;margin:0;padding:1rem 1.2rem 1.2rem}legend{color:#c8a84b;letter-spacing:.12em;text-transform:uppercase;padding:0 .4rem;font-size:.82rem}label{color:#b09080;flex-direction:column;gap:.4rem;margin-top:.8rem;font-size:.88rem;display:flex}label:first-of-type{margin-top:0}.required{color:#c04848}input[type=text],input[type=password]{color:#e8d5c0;background:#1a0a0a;border:1px solid #4a2020;border-radius:6px;outline:none;padding:.55rem .9rem;font-family:inherit;font-size:1rem;transition:border-color .15s}input[type=text]:focus,input[type=password]:focus{border-color:#c8a84b}input::placeholder{color:#5a3a3a}.current-pw-fieldset{background:#5a14141f;border-color:#5a2a2a}.suggestion-btn{color:#c8a84b;cursor:pointer;text-align:left;background:#c8a84b1a;border:1px solid #c8a84b;border-radius:6px;margin-top:.6rem;padding:.4rem .9rem;font-family:inherit;font-size:.85rem;transition:background .15s}.suggestion-btn:hover{background:#c8a84b33}.profile-error{color:#e05050;margin:0;font-size:.9rem}.profile-success{color:#50c050;margin:0;font-size:.9rem}.btn-save{color:#e8d5c0;cursor:pointer;letter-spacing:.06em;background:#5a1a1a;border:1px solid #8b2a2a;border-radius:8px;align-self:flex-start;padding:.7rem 2rem;font-family:inherit;font-size:1rem;transition:background .15s}.btn-save:hover:not(:disabled){background:#7a2222}.btn-save:disabled{opacity:.5;cursor:not-allowed}.gameflow{color:#e8d5c0;background:radial-gradient(90% 65% at 50% 42%,#2e0404 0%,#0000 68%),#080404;flex-direction:column;min-height:100vh;font-family:Georgia,serif;display:flex;position:relative;overflow:hidden}.gf-ninja-bg{pointer-events:none;position:absolute;inset:0}.gf-shuriken{color:#c8a84b;opacity:.08;animation:linear infinite gf-spin;position:absolute}.s1{font-size:8rem;animation-duration:22s;top:5%;left:3%}.s2{font-size:12rem;animation-duration:28s;animation-direction:reverse;top:60%;right:2%}.s3{font-size:6rem;animation-duration:17s;top:80%;left:40%}@keyframes gf-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.gf-header{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2;background:#120808cc;border-bottom:1px solid #2a1212;align-items:center;gap:1.2rem;padding:.85rem 1.5rem;display:flex;position:relative}.gf-back{color:#c97878;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #4a2020;border-radius:4px;padding:.3rem .85rem;font-family:inherit;font-size:.85rem}.gf-back:hover{background:#200c0c}.gf-header-title{color:#c8a84b;letter-spacing:.08em;font-size:1.1rem;font-weight:700}.gf-main{z-index:1;flex-direction:column;flex:1;align-items:center;gap:0;padding:2.5rem 1.5rem 4rem;display:flex;position:relative}.gf-section{flex-direction:column;align-items:center;gap:1.4rem;width:100%;max-width:820px;padding-bottom:.5rem;display:flex}.gf-section-reveal{animation:.35s ease-out both gf-reveal}@keyframes gf-reveal{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gf-section-divider{background:linear-gradient(90deg,#0000,#3a1a1a,#0000);width:60%;height:1px;margin:1.5rem 0 .5rem}.gf-section-title{color:#e0c090;letter-spacing:.04em;text-align:center;margin:0;font-size:clamp(1.15rem,3.5vw,1.7rem);font-weight:700}.gf-crumb{color:#c8a84b}.gf-mode-subtitle{color:#9a7a60;letter-spacing:.06em;text-transform:uppercase;margin:0;font-size:1rem}.gf-grid{flex-wrap:wrap;justify-content:center;gap:1rem;width:100%;display:flex}.gf-card{cursor:pointer;background:linear-gradient(160deg,#1e0c0c,#140808);border:1px solid #3a1a1a;border-radius:8px;flex-direction:column;align-items:center;gap:.4rem;min-width:140px;padding:1.1rem 1.8rem;font-family:inherit;transition:border-color .15s,transform .15s,box-shadow .15s,background .15s;display:flex}.gf-card:hover{border-color:#c8a84b;transform:translateY(-3px);box-shadow:0 6px 24px #c8a84b22}.gf-card.selected{background:linear-gradient(160deg,#2e1e08,#1c1208);border-color:#c8a84b;transform:translateY(-2px);box-shadow:0 4px 20px #c8a84b33}.gf-card.selected .gf-card-name{color:#c8a84b}.gf-card-name{color:#e8d5c0;font-size:1rem;font-weight:600;transition:color .15s}.gf-card-count{color:#7a5040;font-size:.75rem}.gf-modes{grid-template-columns:repeat(2,1fr);gap:1rem;width:100%;max-width:480px;display:grid}.gf-mode-card{cursor:pointer;text-align:center;box-sizing:border-box;background:linear-gradient(160deg,#1e0c0c,#140808);border:1px solid #3a1a1a;border-radius:10px;flex-direction:column;align-items:center;gap:.5rem;width:100%;padding:1.4rem 1.2rem;font-family:inherit;transition:border-color .15s,transform .15s,box-shadow .15s;display:flex}.gf-mode-card:hover:not(.disabled){border-color:#c0392b;transform:translateY(-3px);box-shadow:0 6px 28px #c0392b33}.gf-mode-card.disabled{opacity:.35;cursor:not-allowed}.gf-mode-card.locked{opacity:.4;cursor:not-allowed;filter:grayscale(60%)}.gf-mode-label{color:#e8d5c0;font-size:.95rem;font-weight:700}.gf-mode-desc{color:#7a5040;font-size:.75rem;font-style:italic}.gf-mode-tier{letter-spacing:.14em;text-shadow:0 0 8px;margin-bottom:.2rem;font-size:.7rem;font-weight:700}.gf-mode-stars{gap:.22rem;margin-top:.4rem;display:flex}.gf-mode-star{font-size:1rem;line-height:1}.gf-mode-star.current{animation:1.4s ease-in-out infinite alternate star-pulse}.gf-mode-played{letter-spacing:.12em;margin-top:.1rem;font-size:.62rem;font-weight:700}.gf-mode-played.yes{color:#6dbf6d}.gf-mode-played.no{color:#7a5040}.gf-memory-section{justify-content:center;width:100%;max-width:480px;margin-top:.5rem;display:flex}.gf-memory-btn{color:#c0b0f0;letter-spacing:.06em;cursor:pointer;background:linear-gradient(160deg,#1a1830,#100e20);border:1px solid #4a4080;border-radius:10px;flex-direction:column;align-items:center;gap:.3rem;width:100%;padding:.9rem 2rem;font-family:Georgia,serif;font-size:1rem;font-weight:700;transition:border-color .15s,transform .15s,box-shadow .15s;display:flex}.gf-memory-btn:hover{border-color:#9080e0;transform:translateY(-2px);box-shadow:0 6px 24px #9080e033}.gf-memory-btn-desc{color:#7060a0;letter-spacing:.05em;font-size:.72rem;font-weight:400}@keyframes star-pulse{0%{filter:brightness();transform:scale(1)}to{filter:brightness(1.4);transform:scale(1.18)}}.gf-stats-btn{color:#c8a84b;letter-spacing:.08em;cursor:pointer;background:0 0;border:1px solid #5a3a1a;border-radius:4px;align-items:center;gap:.4rem;margin-left:auto;padding:.25rem .7rem;font-family:inherit;font-size:.82rem;transition:color .15s,border-color .15s;display:flex;overflow:hidden}.gf-stats-ninja{object-fit:cover;object-position:center 15%;filter:grayscale(30%);border:1px solid #5a3a1a;border-radius:50%;width:28px;height:28px;display:block}.gf-stats-btn:hover{color:gold;border-color:gold}.gf-stats-btn:hover .gf-stats-ninja{filter:grayscale(0%);border-color:gold}.gf-countdown-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#040101ed;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gf-countdown-num{color:#c8a84b;text-shadow:0 0 40px #c8a84baa,0 0 100px #c8a84b55;font-family:Georgia,serif;font-size:clamp(9rem,22vw,15rem);font-weight:900;line-height:1;animation:.65s cubic-bezier(.22,.9,.42,1) forwards gf-pop;display:block}.gf-countdown-cry{color:#f0e0c0;text-align:center;text-shadow:0 0 30px #c8a84b66,0 2px 8px #0008;max-width:680px;padding:0 2rem;font-family:Georgia,serif;font-size:clamp(1.6rem,5vw,3rem);font-weight:700;line-height:1.35;animation:.55s ease-out forwards gf-cry-in;display:block}@keyframes gf-pop{0%{opacity:0;transform:scale(.3)rotate(-8deg)}65%{opacity:1;transform:scale(1.12)rotate(2deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes gf-cry-in{0%{opacity:0;transform:translateY(30px)scale(.92)}to{opacity:1;transform:translateY(0)scale(1)}}
