:root{--font-heading: "Cormorant Garamond", serif;--font-body: "Lora", serif;--color-background: #f5efe6;--color-surface: #ede0d4;--color-primary-text: #3a2f2a;--color-secondary-text: #6d5c53;--color-accent: #a24a2a;--color-accent-dark: #7f341c;--color-locked: #d8c9bb;--color-border: #c9b8a6;--overlay-strong: rgba(245, 239, 230, .95);--overlay-medium: rgba(245, 239, 230, .85);--overlay-light: rgba(245, 239, 230, .65);--overlay-xlight: rgba(245, 239, 230, .4);--shadow-soft: rgba(58, 47, 42, .18);--shadow-med: rgba(58, 47, 42, .28);--shadow-strong: rgba(58, 47, 42, .4)}*{margin:0;padding:0;box-sizing:border-box}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:#3a2f2a0d;border-radius:10px}*::-webkit-scrollbar-thumb{background:#a24a2a66;border-radius:10px;transition:background .3s ease}*::-webkit-scrollbar-thumb:hover{background:#a24a2a99}*{scrollbar-width:thin;scrollbar-color:rgba(162,74,42,.4) rgba(58,47,42,.05)}body{font-family:var(--font-body);background:var(--color-background);color:var(--color-primary-text);min-height:100vh;overflow:hidden}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-background);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .5s ease}.loading-content{text-align:center;max-width:500px;padding:40px}.loading-title{font-family:var(--font-heading);font-size:3em;color:var(--color-accent);margin-bottom:40px;letter-spacing:2px}.loading-bar-container{width:100%;height:8px;background:var(--color-surface);border-radius:4px;overflow:hidden;margin-bottom:20px;box-shadow:inset 0 2px 4px var(--shadow-soft)}.loading-bar{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-dark));width:0%;transition:width .3s ease;box-shadow:0 0 10px #a24a2a80}.loading-text{font-size:1em;color:var(--color-secondary-text);font-style:italic}.view{display:none;width:100%;height:100vh;overflow:hidden}.view.active{display:block}#dashboardView{padding:20px;background:var(--color-background);overflow-y:auto;min-height:100vh}#dashboardView header{text-align:center;margin-bottom:40px;padding:20px}#dashboardView h1{font-family:var(--font-heading);font-size:4em;color:var(--color-accent);margin-bottom:10px;text-shadow:1px 1px 6px var(--shadow-soft)}#dashboardView p{font-size:1.3em;font-style:italic;color:var(--color-secondary-text)}.dashboard-content{display:flex;gap:20px;max-width:1400px;margin:0 auto;padding:0 20px}.chapters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px;flex:1}.dashboard-sidebar{position:sticky;top:20px;display:flex;flex-direction:column;gap:12px;height:fit-content;padding:0;align-self:flex-start}.sidebar-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 16px;border-radius:12px;cursor:pointer;font-family:var(--font-body);border:2px solid;box-shadow:0 4px 12px var(--shadow-soft);transition:all .3s ease;min-width:100px;background:var(--overlay-strong);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sidebar-btn:hover{transform:translate(-5px) scale(1.05);box-shadow:0 6px 20px var(--shadow-med)}.sidebar-btn:active{transform:translate(-3px) scale(1.02)}.btn-icon{font-size:2em;line-height:1}.btn-label{font-size:.85em;font-weight:700;text-align:center}.btn-achievements{color:#f39c12;border-color:#e67e22}.btn-achievements:hover{background:#f39c12;color:#fff;border-color:#e67e22}.btn-unlock-all{color:#2ecc71;border-color:#27ae60}.btn-unlock-all:hover{background:#2ecc71;color:#fff;border-color:#27ae60}.btn-reset{color:var(--color-accent);border-color:var(--color-accent-dark)}.btn-reset:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent-dark)}.btn-about{color:#3498db;border-color:#2980b9}.btn-about:hover{background:#3498db;color:#fff;border-color:#2980b9}.fab-menu-btn{display:none;position:fixed;bottom:30px;right:30px;width:60px;height:60px;border-radius:50%;background:var(--color-accent);color:#fff;border:none;box-shadow:0 6px 20px var(--shadow-strong);cursor:pointer;z-index:1000;transition:all .3s ease}.fab-menu-btn:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 8px 24px var(--shadow-strong)}.fab-menu-btn.active{transform:rotate(45deg);background:var(--color-accent-dark)}.fab-icon{font-size:1.8em;font-weight:700}.fab-menu{display:none;position:fixed;bottom:100px;right:30px;flex-direction:column;gap:12px;z-index:999;animation:fabSlideIn .3s ease-out}.fab-menu.active{display:flex}@keyframes fabSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fab-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border-radius:25px;cursor:pointer;font-family:var(--font-body);border:2px solid;box-shadow:0 4px 16px var(--shadow-med);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--overlay-strong);min-width:150px;animation:fabItemSlide .3s ease-out backwards}.fab-item:nth-child(1){animation-delay:.05s}.fab-item:nth-child(2){animation-delay:.1s}.fab-item:nth-child(3){animation-delay:.15s}.fab-item:nth-child(4){animation-delay:.2s}@keyframes fabItemSlide{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}.fab-item:hover{transform:translate(-5px);box-shadow:0 6px 20px var(--shadow-strong)}.fab-item-icon{font-size:1.5em}.fab-item-label{font-size:.95em;font-weight:700}@media(max-width:968px){.dashboard-content{flex-direction:column}.dashboard-sidebar{display:none}.fab-menu-btn{display:flex;align-items:center;justify-content:center}}.chapter-card{background:var(--color-surface);border:2px solid var(--color-border);border-radius:5px;padding:25px;text-align:center;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:0 4px 15px var(--shadow-soft)}.chapter-card:hover{transform:translateY(-8px);border-color:var(--color-accent);box-shadow:0 12px 25px var(--shadow-med)}.chapter-card.locked{opacity:.6;cursor:not-allowed;background:var(--color-locked);border-color:var(--color-border)}.chapter-card.locked:hover{transform:none;border-color:var(--color-border);box-shadow:0 4px 15px var(--shadow-soft)}.chapter-number{font-family:var(--font-heading);font-size:2.5em;font-weight:700;color:var(--color-accent);margin-bottom:10px}.chapter-title{font-family:var(--font-heading);font-size:1.5em;margin-bottom:15px;font-weight:700;color:var(--color-primary-text)}.chapter-desc{font-size:1em;color:var(--color-secondary-text);font-style:italic}#visualNovelView{position:relative;width:100%;height:100vh}.background-container{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;transition:opacity .5s ease-in-out}.character-container{position:absolute;bottom:30px;left:30px;width:15%;height:200px;display:flex;justify-content:center;align-items:flex-end;padding:0;z-index:11;pointer-events:none}.character-sprite{max-height:100%;max-width:100%;opacity:0;transition:opacity .5s ease-in-out;filter:drop-shadow(0 0 10px var(--shadow-soft));object-fit:contain}.character-sprite.active{opacity:1}.dialogue-container{position:absolute;bottom:20px;left:20px;width:calc(100% - 40px);min-height:220px;background:linear-gradient(to top,var(--overlay-strong),var(--overlay-medium));padding:20px 30px;padding-left:calc(15% + 50px);border:4px solid var(--color-accent);border-radius:15px;z-index:10}.dialogue-box{max-width:100%;margin:0;position:relative}.dialogue-speaker{font-family:var(--font-heading);color:var(--color-accent);font-size:1.1em;margin-bottom:8px}.dialogue-text{color:var(--color-primary-text);font-size:1.4em;line-height:1.7;min-height:120px;text-shadow:0 1px 2px var(--shadow-soft)}.click-indicator{text-align:center;color:var(--color-accent);font-size:1em;margin-top:15px;animation:bounce 1.2s infinite;opacity:.9}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.btn-back{position:absolute;top:20px;left:20px;background:var(--color-surface);color:var(--color-primary-text);border:2px solid var(--color-border);padding:12px 20px;border-radius:5px;cursor:pointer;z-index:10000;font-size:1em;transition:all .3s ease;font-family:var(--font-body)}.btn-back:hover{background:var(--color-accent);border-color:var(--color-accent-dark);color:#fff}.about-screen.active~#visualNovelView .btn-back,.about-screen.active~#dashboardView .btn-back{display:none!important;visibility:hidden;pointer-events:none}.story-action-bar{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:12px;z-index:100}.btn-challenge{position:relative;background:var(--color-accent);color:#fff;border:2px solid var(--color-accent-dark);padding:12px 20px;border-radius:5px;cursor:pointer;font-size:1em;transition:all .3s ease;font-family:var(--font-body);font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-challenge:hover{background:var(--color-accent-dark);transform:scale(1.05);box-shadow:0 4px 12px var(--shadow-med)}.btn-audio-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:5px;cursor:pointer;border:2px solid var(--color-border);background:var(--overlay-strong);color:var(--color-primary-text);font-family:var(--font-body);font-size:.95em;transition:all .3s ease;box-shadow:0 3px 10px var(--shadow-soft)}.btn-audio-toggle:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent-dark);box-shadow:0 4px 12px var(--shadow-med)}.btn-audio-toggle[data-muted=true]{background:var(--overlay-medium);color:var(--color-secondary-text);border-color:var(--color-border);box-shadow:none}.btn-audio-toggle[data-muted=true]:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent-dark);box-shadow:0 4px 12px var(--shadow-med)}.audio-toggle-icon{font-size:1.1em;line-height:1}.audio-toggle-label{font-weight:600;white-space:nowrap}.btn-next-chapter{position:absolute;top:20px;right:20px;background:var(--color-accent);color:#fff;border:2px solid var(--color-accent-dark);padding:12px 24px;border-radius:5px;cursor:pointer;z-index:100;font-size:1.1em;transition:all .3s ease;font-family:var(--font-heading);font-weight:700;animation:pulse-glow 2s infinite}.btn-next-chapter:hover{background:var(--color-accent-dark);transform:scale(1.08) translateY(-2px);box-shadow:0 6px 20px var(--shadow-strong)}@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px var(--shadow-med)}50%{box-shadow:0 4px 20px var(--color-accent),0 0 30px #a24a2a66}}.story-choices-container{position:absolute;bottom:250px;left:20px;width:calc(100% - 40px);padding:0 30px;padding-left:calc(22% + 10px);display:none;flex-direction:column;gap:12px;z-index:50}.choice-btn{background:linear-gradient(180deg,rgba(255,255,255,.9),var(--overlay-medium));color:var(--color-primary-text);border:1px solid var(--color-border);padding:16px 22px;border-radius:8px;cursor:pointer;text-align:center;font-size:1.1em;font-family:var(--font-body);transition:all .3s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 6px 18px var(--shadow-soft)}.choice-btn:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent-dark);transform:translateY(-2px) scale(1.02);box-shadow:0 10px 24px var(--shadow-med)}.story-choices-container:not(:empty)~.dialogue-container .click-indicator{display:none}.quiz-choice{background:var(--color-accent)!important;border-color:var(--color-accent-dark)!important;font-weight:700}.quiz-choice:hover{background:var(--color-accent-dark)!important}#miniGameView{position:relative;background:var(--color-background);padding:20px;overflow-y:auto}.achievements-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#3a2f2ad9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;align-items:center;justify-content:center;padding:1rem}.achievements-modal-content{background:var(--color-background);border:3px solid var(--color-border);border-radius:10px;padding:2rem;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px var(--shadow-strong);position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0;padding-bottom:0;border-bottom:none;position:relative}.modal-title{margin:0;color:var(--color-accent);font-family:var(--font-heading);font-size:2.2rem;letter-spacing:1px}.close-btn{font-size:2.5rem;color:var(--color-accent);cursor:pointer;transition:all .3s ease;line-height:1;padding:0;background:none;border:none;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;position:absolute;top:0;right:0;z-index:10}.close-btn:hover{color:var(--color-accent-dark);background:var(--overlay-light);transform:rotate(90deg)}.achievements-modal-header{display:none}.btn-close-modal{background:var(--color-accent);border:none;font-size:1.5em;cursor:pointer;color:#fff;transition:all .3s ease;padding:0;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}.btn-close-modal:hover{background:#c0392b;transform:rotate(90deg)}.achievements-table{display:none}@media(max-width:768px){#dashboardView h1{font-size:2.5em}#dashboardView p{font-size:1.1em}.chapters-grid{grid-template-columns:1fr;padding:10px;gap:20px}.character-container{width:100%;height:150px;justify-content:center;bottom:230px}.character-sprite{max-width:40%;max-height:100%}.dialogue-container{width:calc(100% - 20px);margin:10px;padding:20px}.dialogue-text{font-size:1.2em;min-height:80px}.story-choices-container{width:calc(100% - 20px);left:10px;bottom:200px;padding:0 10px}.story-action-bar{top:12px;right:12px;flex-direction:column;align-items:flex-end;gap:8px}.btn-audio-toggle,.btn-challenge{font-size:.9em;padding:10px 14px}.choice-btn{padding:15px 20px;font-size:1.1em}}.eye-blink-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(to bottom,#3a2f2af2,#3a2f2afa,#3a2f2af2);z-index:9999;pointer-events:none;opacity:0;transition:opacity .6s cubic-bezier(.4,0,.2,1)}.eye-blink-overlay.closing{opacity:1;transition:opacity .8s cubic-bezier(.4,0,.6,1)}.eye-blink-overlay.opening{opacity:0;transition:opacity 1s cubic-bezier(.4,0,.2,1)}.leaderboard-section{margin:1.5rem 0;padding:2rem;background:var(--color-surface);border:2px solid var(--color-border);border-radius:10px;box-shadow:0 4px 12px var(--shadow-med);animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.leaderboard-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border)}.leaderboard-title{font-family:var(--font-heading);font-size:2.2rem;color:var(--color-accent);margin-bottom:.5rem;letter-spacing:1px}.leaderboard-subtitle{font-size:1.1rem;color:var(--color-secondary-text);font-style:italic}.leaderboard-table-wrapper{overflow-x:auto;border-radius:8px;background:var(--overlay-xlight);padding:1rem;border:1px solid var(--color-border)}.leaderboard-table{width:100%;border-collapse:collapse;background:transparent}.leaderboard-table thead{background:var(--color-accent);border-bottom:2px solid var(--color-accent-dark)}.leaderboard-table th{padding:1rem .875rem;text-align:left;font-size:1rem;color:#fff;font-weight:600;text-transform:uppercase;letter-spacing:.5px;vertical-align:middle}.leaderboard-table tbody tr{border-bottom:1px solid var(--color-border);transition:all .3s ease}.leaderboard-table tbody tr:hover{background:var(--overlay-light);transform:translate(3px)}.leaderboard-table td{padding:1rem .875rem;color:var(--color-primary-text);font-size:1.05rem;vertical-align:middle}.rank-col{width:60px;text-align:center!important;font-weight:700;font-size:1.1rem;vertical-align:middle}.name-col{min-width:150px;font-weight:500;vertical-align:middle}.score-col{width:100px;text-align:center!important;font-weight:700;color:var(--color-primary);vertical-align:middle}.chapters-col,.plays-col{min-width:80px;text-align:center!important;vertical-align:middle}.time-col{width:120px;text-align:center!important;vertical-align:middle}.chapter-time-col{width:100px;text-align:center!important;vertical-align:middle}.accuracy-col,.special-col,.spirit-col,.production-col,.belief-col,.order-col,.economy-col{width:100px;text-align:center!important;font-weight:500;color:var(--color-secondary-text);vertical-align:middle}.chapter-col{min-width:180px;vertical-align:middle}.date-col{min-width:100px;text-align:center!important;font-size:.85rem;color:#95a5a6;vertical-align:middle}.rank-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;background:var(--color-accent);color:#fff;font-weight:700;font-size:.9rem}.top-three{background:var(--overlay-medium);font-weight:500}.top-three .rank-badge{font-size:1.1rem}.player-row{background:linear-gradient(90deg,rgba(46,204,113,.2),transparent)!important;border:2px solid rgba(46,204,113,.5)!important;font-weight:600}.player-row td{color:#2ecc71!important}.player-row .score-col{color:#27ae60!important}.leaderboard-note{margin-top:1.5rem;padding:1rem;background:var(--overlay-light);border-left:4px solid var(--color-accent);border-radius:4px;text-align:center;color:var(--color-secondary-text);font-size:.9rem}.note-icon{margin-right:.5rem;font-size:1.1rem}.chapter-scoring-info{margin:1.5rem 0;padding:1.5rem;background:var(--overlay-light);border:2px solid var(--color-border);border-radius:8px;box-shadow:0 2px 8px var(--shadow-light)}.scoring-info-title{font-family:var(--font-heading);font-size:1.2rem;color:var(--color-accent);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.scoring-info-content{display:flex;flex-direction:column;gap:1rem}.scoring-components-list{font-size:.95rem;color:var(--color-primary-text)}.scoring-components-list strong{color:var(--color-accent);margin-right:.5rem}.scoring-formula-display{font-size:.95rem;color:var(--color-primary-text)}.scoring-formula-display strong{color:var(--color-accent);display:block;margin-bottom:.5rem}.scoring-formula-display code{display:block;padding:.75rem;background:var(--overlay-medium);border-left:3px solid var(--color-primary);border-radius:4px;font-family:monospace;font-size:.9rem;color:var(--color-primary-text);line-height:1.6;overflow-x:auto}.scoring-special-note{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem;background:var(--color-info-bg);border-left:3px solid var(--color-info);border-radius:4px;font-size:.9rem;color:var(--color-primary-text)}.scoring-max-score{font-size:1rem;color:var(--color-primary-text);padding:.75rem;background:var(--overlay-xlight);border-radius:4px;text-align:center}.scoring-max-score strong{color:var(--color-accent);margin-right:.5rem}.max-score-value{font-size:1.2rem;font-weight:700;color:var(--color-primary)}.no-data{text-align:center;padding:3rem;color:var(--color-secondary-text);font-size:1.1rem}.no-data-message{text-align:center;padding:3rem 2rem;background:var(--overlay-light);border-radius:8px;margin-top:1rem;border:2px dashed var(--color-border)}.no-data-icon{font-size:4rem;margin-bottom:1rem}.no-data-title{font-size:1.3rem;font-weight:700;color:var(--color-accent);margin:.5rem 0}.no-data-desc{color:var(--color-secondary-text);font-size:1rem;margin:.5rem 0}.leaderboard-note{margin-top:1rem;padding:.75rem 1rem;background:var(--overlay-light);border-left:3px solid var(--color-accent);border-radius:4px;color:var(--color-secondary-text);font-size:.9rem;font-style:italic}.practice-chapter{opacity:.85}.practice-chapter td{color:var(--color-secondary-text)}.personal-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:var(--overlay-medium);border-radius:8px;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease;border:2px solid var(--color-border)}.summary-card:hover{transform:translateY(-3px);border-color:var(--color-accent);box-shadow:0 4px 12px var(--shadow-med)}.summary-icon{font-size:2.5rem;line-height:1}.summary-content{flex:1}.summary-value{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;color:var(--color-accent);line-height:1.2}.summary-label{font-size:.85rem;color:var(--color-secondary-text);margin-top:.25rem}.personal-subtitle{font-family:var(--font-heading);font-size:1.3rem;color:var(--color-primary-text);margin:1.5rem 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.personal-table .chapter-col{min-width:180px}.personal-table .chapter-col strong{color:var(--color-accent);font-size:1rem}.personal-table .chapter-col small{color:var(--color-secondary-text);font-size:.8rem;display:block;margin-top:.25rem}@media(max-width:768px){.leaderboard-section{padding:1rem}.leaderboard-title{font-size:1.5rem}.leaderboard-subtitle{font-size:.9rem}.leaderboard-table th,.leaderboard-table td{padding:.75rem .5rem;font-size:.85rem}.personal-summary{grid-template-columns:repeat(2,1fr);gap:1rem}.summary-card{padding:1rem}.summary-icon{font-size:2rem}.summary-value{font-size:1.4rem}.summary-label{font-size:.8rem}.chapters-col,.accuracy-col,.date-col{display:none}}@media(max-width:480px){.personal-summary{grid-template-columns:1fr}.leaderboard-table th,.leaderboard-table td{font-size:.8rem;padding:.5rem .25rem}.rank-col{width:40px;font-size:.9rem}.name-col{min-width:100px}}.leaderboard-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;z-index:9999;overflow-y:auto}.leaderboard-modal.active{display:flex;align-items:center;justify-content:center;padding:2rem}.leaderboard-modal-content{background:#1a1a1a;border-radius:16px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;padding:2rem;position:relative}.leaderboard-modal-close{position:absolute;top:1rem;right:1rem;background:var(--color-accent);color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.5rem;cursor:pointer;transition:all .3s ease}.leaderboard-modal-close:hover{background:#c0392b;transform:rotate(90deg)}.leaderboard-tabs{display:flex;justify-content:space-between;gap:1rem;margin-bottom:2rem;border-bottom:2px solid var(--color-border);flex-wrap:nowrap;width:100%;padding-right:50px}.leaderboard-tab{flex:1;padding:1rem;background:transparent;border:none;color:var(--color-secondary-text);font-family:var(--font-heading);font-size:1.15rem;font-weight:600;cursor:pointer;transition:all .3s ease;border-bottom:3px solid transparent;position:relative;top:2px;text-align:center;white-space:nowrap;letter-spacing:.5px;text-transform:uppercase}.leaderboard-tab:hover{color:var(--color-primary-text);background:var(--overlay-xlight);transform:translateY(-2px)}.leaderboard-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);font-weight:700;letter-spacing:1px}.leaderboard-tab-content{display:none}.leaderboard-tab-content.active{display:block;animation:fadeIn .3s ease-in}.scoring-formula-box{background:var(--overlay-medium);border:2px solid var(--color-accent);border-radius:8px;padding:1.5rem;margin-bottom:2rem;text-align:center}.formula-title{font-family:var(--font-heading);font-size:1.3rem;color:var(--color-accent);margin-bottom:1rem}.formula-main{font-family:var(--font-body);font-size:1.1rem;color:var(--color-primary-text);font-weight:600;padding:1rem;background:var(--overlay-light);border-radius:6px}.scoring-components{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.component-card{background:var(--overlay-light);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem;transition:all .3s ease}.component-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px var(--shadow-med);border-color:var(--color-accent)}.component-name{font-family:var(--font-heading);font-size:1.1rem;color:var(--color-accent);margin-bottom:.75rem}.component-formula{background:var(--overlay-medium);padding:.75rem;border-radius:6px;font-family:monospace;font-size:.95rem;color:var(--color-primary-text);margin-bottom:.75rem;border-left:3px solid var(--color-accent)}.component-desc{color:var(--color-secondary-text);font-size:.9rem;margin-bottom:.5rem;line-height:1.5}.component-example{background:var(--color-background);padding:.5rem;border-radius:4px;font-size:.85rem;color:var(--color-primary-text);font-style:italic;margin-top:.5rem}.component-examples{margin-top:.75rem;font-size:.85rem}.component-examples strong{color:var(--color-accent);display:block;margin-bottom:.5rem}.component-examples ul{margin:0;padding-left:1.5rem;color:var(--color-secondary-text)}.component-examples li{margin:.25rem 0;line-height:1.4}.component-examples-table{margin-top:1rem;overflow-x:auto}.component-examples-table table{width:100%;border-collapse:collapse;background:var(--overlay-xlight);border:1px solid var(--color-border);border-radius:4px;overflow:hidden}.component-examples-table th{background:var(--overlay-medium);padding:.75rem;text-align:left;font-size:.85rem;font-weight:600;color:var(--color-accent);border-bottom:2px solid var(--color-border)}.component-examples-table td{padding:.75rem;border-bottom:1px solid var(--color-border);font-size:.85rem;color:var(--color-primary-text)}.component-examples-table tr:last-child td{border-bottom:none}.component-examples-table .highlight-row{background:var(--overlay-light);font-weight:600}.example-input{color:var(--color-primary-text);font-weight:500}.example-calc{color:var(--color-secondary-text);font-family:monospace;font-size:.8rem}.example-result{color:var(--color-accent);font-weight:600;text-align:right}.scoring-intro{background:var(--overlay-light);border-left:4px solid var(--color-accent);padding:1rem 1.5rem;margin-bottom:2rem;border-radius:6px;font-size:.95rem;line-height:1.6;color:var(--color-primary-text)}.chapter-bonus-section{margin:2rem 0}.section-title{font-family:var(--font-heading);font-size:1.4rem;color:var(--color-accent);margin-bottom:1.5rem;text-align:center;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.chapter-bonus-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.chapter-bonus-card{background:var(--overlay-light);border:2px solid var(--color-border);border-radius:8px;padding:1.25rem;transition:all .3s ease}.chapter-bonus-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px var(--shadow-med);border-color:var(--color-accent)}.chapter-bonus-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.chapter-bonus-name{font-weight:600;color:var(--color-primary-text);font-size:1rem}.chapter-bonus-max{font-family:var(--font-heading);font-size:1.2rem;color:var(--color-accent);font-weight:700}.chapter-bonus-type{font-size:.85rem;color:var(--color-accent);font-weight:600;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.chapter-bonus-formula{background:var(--overlay-xlight);padding:.5rem .75rem;border-radius:4px;font-family:monospace;font-size:.8rem;color:var(--color-secondary-text);margin-bottom:.75rem;border:1px dashed var(--color-border)}.chapter-bonus-example{font-size:.85rem;color:var(--color-primary-text);line-height:1.5}.chapter-bonus-example strong{color:var(--color-accent)}.chapter-bonus-section-inline{margin-top:1rem;padding-top:1rem;border-top:2px solid var(--color-border)}.inline-section-title{font-family:var(--font-heading);font-size:1rem;color:var(--color-accent);margin-bottom:1rem;display:block}.chapter-bonus-section-inline .chapter-bonus-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.chapter-bonus-section-inline .chapter-bonus-card{padding:1rem}.chapter-bonus-metric{font-size:.85rem;color:var(--color-secondary-text);margin-bottom:.5rem;font-weight:500}.real-example-section{margin:2rem 0}.real-example-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.real-example-card{background:var(--overlay-light);border:2px solid var(--color-accent);border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px var(--shadow-light)}.real-example-title{font-family:var(--font-heading);font-size:1.2rem;color:var(--color-accent);margin-bottom:1rem;text-align:center;padding-bottom:.75rem;border-bottom:2px solid var(--color-border)}.example-metrics{background:var(--overlay-xlight);border-radius:6px;padding:1rem;margin-bottom:1rem;border:1px solid var(--color-border)}.metric-item{padding:.5rem 0;font-size:.9rem;color:var(--color-primary-text);border-bottom:1px dashed var(--color-border)}.metric-item:last-child{border-bottom:none}.metric-item strong{color:var(--color-accent);font-weight:600}.calculation-table{width:100%;border-collapse:collapse}.calculation-table td{padding:.75rem;border-bottom:1px solid var(--color-border)}.calculation-table tr:last-child td{border-bottom:none}.calculation-table .total-row{background:var(--overlay-medium);font-weight:700}.calculation-table .total-row td{color:var(--color-accent);font-size:1.1rem;padding-top:1rem;border-top:2px solid var(--color-accent)}.calc-label{color:var(--color-primary-text);font-size:.9rem}.calc-value{text-align:right;color:var(--color-accent);font-weight:600;font-family:var(--font-heading);font-size:1rem}.max-score-section{background:var(--overlay-light);border-radius:8px;padding:1.5rem;margin:2rem 0;border:2px solid var(--color-border)}.max-score-info{background:var(--overlay-medium);border-radius:6px;padding:1.25rem;margin-bottom:1.5rem;border:1px solid var(--color-border)}.max-score-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--overlay-xlight);border-radius:4px;border-left:3px solid var(--color-accent)}.breakdown-label{font-size:.9rem;color:var(--color-primary-text)}.breakdown-value{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--color-accent)}.max-score-total{text-align:center;padding:1rem;background:var(--color-accent);color:#fff;border-radius:6px;font-size:1.2rem;font-family:var(--font-heading)}.max-score-title{font-family:var(--font-heading);font-size:1.3rem;color:var(--color-accent);margin-bottom:1rem;text-align:center}.max-score-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.max-score-card{background:var(--overlay-medium);border:1px solid var(--color-border);border-radius:6px;padding:1rem;text-align:center}.max-score-chapter{font-weight:600;color:var(--color-primary-text);margin-bottom:.5rem;font-size:.9rem}.max-score-value{font-family:var(--font-heading);font-size:1.4rem;color:var(--color-accent);font-weight:700;margin:.5rem 0}.max-score-note{font-size:.8rem;color:var(--color-secondary-text);font-style:italic}.tips-section{background:var(--overlay-light);border-radius:8px;padding:1.5rem;border:2px solid var(--color-border)}.tips-title{font-family:var(--font-heading);font-size:1.3rem;color:var(--color-accent);margin-bottom:1rem}.tips-list{list-style:none;padding:0;margin:0}.tips-list li{padding:.75rem;margin:.5rem 0;background:var(--overlay-medium);border-radius:6px;border-left:4px solid var(--color-accent);color:var(--color-primary-text);line-height:1.5;transition:all .3s ease}.tips-list li:hover{transform:translate(5px);background:var(--color-background)}@media(max-width:768px){.leaderboard-tabs{gap:.5rem;padding-right:45px}.leaderboard-tab{font-size:.9rem;padding:.75rem .5rem}}@media(max-width:480px){.leaderboard-tabs{flex-wrap:wrap;padding-right:0;gap:.25rem}.leaderboard-tab{flex:1 1 45%;font-size:.85rem;padding:.65rem .5rem}.modal-header .close-btn{top:-45px;right:-10px}}.scoring-components-simple{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2rem 0}.component-simple{display:flex;align-items:flex-start;gap:1rem;background:var(--overlay-light);border:1px solid var(--color-border);border-radius:8px;padding:1.25rem;transition:all .3s ease}.component-simple:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-med);border-color:var(--color-accent)}.component-icon{font-size:2rem;line-height:1;flex-shrink:0}.component-info{flex:1}.component-info h4{font-family:var(--font-heading);font-size:1rem;color:var(--color-accent);margin:0 0 .5rem}.component-info .formula-text{font-family:monospace;font-size:.9rem;color:var(--color-primary-text);background:var(--overlay-medium);padding:.5rem;border-radius:4px;border-left:3px solid var(--color-accent);margin-bottom:.5rem}.component-info .formula-note{font-size:.85rem;color:var(--color-accent);font-weight:600;font-style:italic}.chapter-scoring-table{margin:2rem 0}.chapter-scoring-table .section-title{font-family:var(--font-heading);font-size:1.3rem;color:var(--color-accent);margin-bottom:1rem;text-align:center}.chapter-table{width:100%;border-collapse:collapse;background:var(--overlay-light);border-radius:8px;overflow:hidden}.chapter-table thead th{background:var(--overlay-medium);color:var(--color-accent);font-family:var(--font-heading);font-weight:700;text-align:left;padding:.75rem 1rem;border-bottom:2px solid var(--color-border)}.chapter-table tbody td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-primary-text)}.chapter-table tbody tr:last-child td{border-bottom:none}.chapter-table tbody tr:hover{background:var(--overlay-medium)}.chapter-table .excluded-chapter{opacity:.6;font-style:italic}.chapter-table .excluded-chapter:hover{background:#ff453a1a}.chapter-id-col{width:60px;text-align:center}.chapter-name-col{width:200px}.chapter-metrics-col{width:auto;max-width:500px;line-height:1.8}.chapter-max-col{width:120px;text-align:right;color:var(--color-accent)}.metric-badge{display:inline-block;background:var(--overlay-medium);color:var(--color-primary-text);padding:.3rem .6rem;border-radius:4px;font-size:.85rem;margin-right:.35rem;margin-bottom:.35rem;border:1px solid var(--color-border);line-height:1.4;white-space:nowrap}.scoring-notes{margin:2rem 0;background:var(--overlay-light);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem}.scoring-notes .section-title{font-family:var(--font-heading);font-size:1.2rem;color:var(--color-accent);margin:0 0 1rem}.notes-list{list-style:none;padding:0;margin:0}.notes-list li{padding:.75rem 0;border-bottom:1px solid var(--color-border);color:var(--color-primary-text);line-height:1.6}.notes-list li:last-child{border-bottom:none}.notes-list li strong{color:var(--color-accent)}@media(max-width:768px){.scoring-components-simple{grid-template-columns:1fr}.chapter-table{font-size:.9rem}.chapter-table thead th,.chapter-table tbody td{padding:.5rem .75rem}.metric-badge{font-size:.75rem;padding:.2rem .4rem}}.minigame-container{max-width:1000px;margin:20px auto;padding:20px;background:var(--overlay-medium);border-radius:10px;color:var(--color-primary-text);border:2px solid var(--color-border);box-shadow:0 0 30px var(--shadow-soft);display:flex;flex-direction:column;min-height:500px;max-height:none;overflow:visible;position:relative}.minigame-container.game-paused,.ch9-game-container.game-paused{pointer-events:none;-webkit-user-select:none;user-select:none}.minigame-container.game-paused .minigame-dashboard-btn{pointer-events:auto}.minigame-container.game-paused:after,.ch9-game-container.game-paused:after{content:"";position:absolute;inset:0;background:#3a2f2a0d;pointer-events:none;z-index:1}.minigame-container.game-paused .minigame-header-actions,.ch9-game-container.game-paused .minigame-header-actions,.minigame-container.game-paused .minigame-dashboard-btn,.ch9-game-container.game-paused .minigame-dashboard-btn,.minigame-container.game-paused .minigame-start-btn,.ch9-game-container.game-paused .minigame-start-btn{pointer-events:auto}.minigame-lock-overlay{position:absolute;inset:0;border-radius:inherit;background:#fff4e9c7;box-shadow:inset 0 0 35px #573d351f;-webkit-backdrop-filter:blur(1.8px);backdrop-filter:blur(1.8px);border:1px solid rgba(125,96,78,.08);opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:3}.minigame-container.game-locked .minigame-lock-overlay,.ch9-game-container.game-locked .minigame-lock-overlay{opacity:1;pointer-events:auto;cursor:not-allowed}.minigame-container.game-locked .minigame-start-btn,.ch9-game-container.game-locked .minigame-start-btn{animation:minigame-pulse 1.3s ease-in-out infinite}.minigame-container.game-locked .minigame-start-btn:disabled,.ch9-game-container.game-locked .minigame-start-btn:disabled{animation:none}@keyframes minigame-pulse{0%{transform:scale(1);box-shadow:0 0 #ff453a73}70%{transform:scale(1.03);box-shadow:0 0 0 8px #ff453a00}to{transform:scale(1);box-shadow:0 0 #ff453a00}}.ghost-dragging{animation:ghost-float .3s ease-in-out}@keyframes ghost-float{0%{opacity:1;transform:scale(1)}to{opacity:.8;transform:rotate(3deg) scale(1.05)}}.minigame-header{position:relative;z-index:5;text-align:center;padding:15px 80px 15px 15px;border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;gap:10px}.minigame-header-actions{position:absolute;top:15px;right:15px;display:flex;align-items:center;gap:10px;z-index:10}.minigame-start-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:999px;font-family:var(--font-heading);font-weight:600;font-size:.95em;color:var(--color-primary-text);background:var(--color-accent);border:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;box-shadow:0 2px 8px #ff453a66}.minigame-start-btn:hover:not(:disabled){transform:translateY(-1px);background:var(--color-accent-dark)}.minigame-start-btn:active:not(:disabled){transform:translateY(0)}.minigame-start-btn:disabled{opacity:.8;cursor:not-allowed;box-shadow:none}.minigame-start-btn.is-active{background:var(--color-accent-dark);color:#fff}.minigame-start-btn.is-hidden{display:none}.minigame-start-btn__icon{font-size:1.1em;line-height:1}.minigame-dashboard-btn{width:45px;height:45px;border:2px solid var(--color-border);background:var(--overlay-medium);border-radius:50%;cursor:pointer;font-size:1.5em;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #0003}.minigame-dashboard-btn:hover{background:var(--color-accent);border-color:var(--color-accent);transform:scale(1.1);box-shadow:0 4px 12px #ff453a66}.minigame-dashboard-btn:active{transform:scale(.95)}.minigame-title{font-family:var(--font-heading);color:var(--color-accent);text-align:center;font-size:2.2em;margin-bottom:10px;line-height:1.2}.minigame-instructions{text-align:center;margin-bottom:20px;font-size:1.1em;font-style:italic;color:var(--color-secondary-text);line-height:1.6}.minigame-hint{position:relative;z-index:2;font-size:.95em;color:var(--color-accent);margin-top:10px;padding:8px 12px;background:#ff453a1a;border-radius:4px;border-left:3px solid var(--color-accent);display:inline-block;text-align:left}.minigame-button{position:relative;z-index:2;display:block;margin:20px auto 0;padding:15px 30px;font-size:1.2em;font-weight:700;color:var(--color-primary-text);background:var(--color-accent);border:none;border-radius:5px;cursor:pointer;transition:all .3s ease;font-family:var(--font-heading)}.minigame-button:hover:not(:disabled){background-color:var(--color-accent-dark);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-soft)}.minigame-button:disabled{background:#757575;cursor:not-allowed;transform:none;opacity:.6}.minigame-end-message,.minigame-success-message,.minigame-final-message{position:relative;z-index:2;padding:20px;border-radius:8px;text-align:center;line-height:1.6;animation:minigame-fadeInScale .5s ease}.minigame-end-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:var(--overlay-strong);display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:100;animation:minigame-fadeInScale .5s;padding:20px}.minigame-end-overlay h2{font-family:var(--font-heading);font-size:3em;margin-bottom:20px}.minigame-end-overlay p{font-size:1.3em;font-style:italic;color:var(--color-secondary-text);margin-bottom:25px;line-height:1.6;max-width:600px}.minigame-end-overlay.success h2{color:#2ecc71}.minigame-end-overlay.fail h2{color:var(--color-accent)}@keyframes minigame-fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.minigame-ending-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--overlay-strong);display:none;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .5s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.minigame-ending-overlay.show{display:flex}.minigame-ending-modal{background:var(--color-surface);border:3px solid var(--color-border);border-radius:12px;padding:40px;max-width:700px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 8px 30px var(--shadow-strong);animation:slideUp .6s cubic-bezier(.34,1.56,.64,1);position:relative}.minigame-ending-modal.success{border-color:var(--color-accent);box-shadow:0 8px 30px var(--shadow-strong),0 0 20px #a24a2a33}.minigame-ending-modal.fail{border-color:var(--color-accent-dark);box-shadow:0 8px 30px var(--shadow-strong),0 0 20px #7f341c33}.minigame-ending-header{text-align:center;margin-bottom:30px;border-bottom:2px solid var(--color-border);padding-bottom:20px}.minigame-ending-title{font-family:var(--font-heading);font-size:2.5em;font-weight:700;margin:0 0 15px;text-transform:uppercase;letter-spacing:2px;color:var(--color-primary-text);text-shadow:0 2px 4px var(--shadow-soft)}.minigame-ending-modal.success .minigame-ending-title{color:var(--color-accent)}.minigame-ending-modal.fail .minigame-ending-title{color:var(--color-accent-dark)}.minigame-ending-subtitle{font-size:1.2em;color:var(--color-secondary-text);font-style:italic;margin:10px 0;line-height:1.6}.minigame-ending-quote{background:#a24a2a0d;border-left:4px solid var(--color-border);padding:20px 25px;margin:25px 0;font-size:1.1em;font-style:italic;color:var(--color-primary-text);border-radius:8px;line-height:1.8;position:relative}.minigame-ending-quote:before{content:'"';font-size:3.5em;position:absolute;top:-10px;left:10px;color:#a24a2a1a;font-family:var(--font-heading)}.minigame-ending-modal.success .minigame-ending-quote{border-left-color:var(--color-accent);background:#a24a2a14}.minigame-ending-modal.fail .minigame-ending-quote{border-left-color:var(--color-accent-dark);background:#7f341c14}.minigame-ending-stats{margin:30px 0;background:#3a2f2a08;border-radius:12px;padding:25px;border:1px solid var(--color-border)}.minigame-ending-stats-title{font-family:var(--font-heading);font-size:1.4em;font-weight:700;margin-bottom:20px;text-align:center;color:var(--color-primary-text);text-transform:uppercase;letter-spacing:2px}.minigame-ending-stat-row{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;margin:8px 0;background:var(--overlay-light);border-radius:8px;border-left:3px solid var(--color-border);transition:all .3s ease}.minigame-ending-stat-row:hover{background:var(--overlay-medium);border-left-color:var(--color-accent);transform:translate(5px);box-shadow:0 2px 8px var(--shadow-soft)}.minigame-ending-stat-label{font-size:1.05em;color:var(--color-secondary-text);font-weight:500}.minigame-ending-stat-value{font-size:1.2em;font-weight:700;color:var(--color-primary-text)}.minigame-ending-stat-value.success{color:var(--color-accent)}.minigame-ending-stat-value.warning{color:#d68910}.minigame-ending-stat-value.fail{color:var(--color-accent-dark)}.minigame-ending-stat-value.divider{color:var(--color-secondary-text);font-weight:400;font-size:1em;letter-spacing:-1px}.minigame-ending-stat-row:has(.divider){margin:8px 0;padding:0;min-height:auto;background:transparent;border:none;box-shadow:none}.minigame-ending-stat-row:has(.divider):hover{background:transparent;transform:none;box-shadow:none}.minigame-ending-stat-value.score-breakdown{color:#8b7355;font-size:1.15em}.minigame-ending-stat-value.total-score{color:var(--color-accent);font-size:1.4em;font-weight:900}.minigame-ending-stat-row:has(.total-score){background:#a24a2a1a;border:2px solid var(--color-accent);border-radius:8px;margin-top:12px}.minigame-ending-stat-row:has(.total-score) .minigame-ending-stat-label{font-size:1.15em;font-weight:900;color:var(--color-accent)}.minigame-ending-stat-value.section-header{font-weight:900;font-size:1.05em;color:var(--color-accent);letter-spacing:.5px}.minigame-ending-stat-row:has(.section-header){background:#a24a2a14;border-left:4px solid var(--color-accent);padding-left:12px;margin-top:8px;margin-bottom:4px}.minigame-ending-stat-row:has(.section-header):hover{background:#a24a2a1f}.minigame-ending-stat-row:has(.section-header) .minigame-ending-stat-label{font-weight:900;color:var(--color-accent)}.minigame-ending-stat-value.score-value{color:var(--color-accent);font-weight:700;font-size:1.1em}.minigame-ending-divider{height:2px;background:linear-gradient(to right,transparent,var(--color-border),transparent);margin:20px 0}.minigame-ending-buttons{display:flex;gap:15px;margin-top:35px;flex-wrap:wrap;justify-content:center}.minigame-ending-btn{flex:1;min-width:200px;padding:14px 28px;font-size:1.1em;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;border:2px solid;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px var(--shadow-soft);position:relative;overflow:hidden;font-family:var(--font-heading);background:var(--color-surface);color:var(--color-primary-text)}.minigame-ending-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#a24a2a33;transform:translate(-50%,-50%);transition:width .5s,height .5s}.minigame-ending-btn:hover:before{width:300px;height:300px}.minigame-ending-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow-med)}.minigame-ending-btn:active{transform:translateY(0)}.minigame-ending-btn-restart{border-color:var(--color-accent);color:var(--color-accent)}.minigame-ending-btn-restart:hover{background:var(--color-accent);color:var(--color-background);border-color:var(--color-accent-dark)}.minigame-ending-btn-dashboard{border-color:var(--color-secondary-text);color:var(--color-secondary-text)}.minigame-ending-btn-dashboard:hover{background:var(--color-secondary-text);color:var(--color-background);border-color:var(--color-primary-text)}.minigame-ending-btn-next{border-color:var(--color-accent);color:var(--color-accent);font-weight:900}.minigame-ending-btn-next:hover{background:var(--color-accent);color:var(--color-background);border-color:var(--color-accent-dark)}.minigame-header-overlay{position:fixed;top:0;left:0;width:100%;height:80px;background:var(--overlay-strong);display:none;align-items:center;justify-content:center;gap:20px;z-index:999;border-bottom:2px solid var(--color-accent);box-shadow:0 4px 16px var(--shadow-strong);animation:slideDown .5s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.minigame-header-overlay.show{display:flex}.minigame-header-overlay .minigame-ending-btn{min-width:180px;padding:12px 24px;font-size:1em}.minigame-feedback-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);padding:20px 40px;background:var(--overlay-strong);border:3px solid;border-radius:12px;font-family:var(--font-heading);font-size:1.6em;font-weight:700;color:var(--color-primary-text);z-index:2000;opacity:0;pointer-events:none;text-align:center;box-shadow:0 8px 24px var(--shadow-strong);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.minigame-feedback-popup.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.minigame-feedback-popup.success{border-color:var(--color-accent);color:var(--color-accent)}.minigame-feedback-popup.fail{border-color:var(--color-accent-dark);color:var(--color-accent-dark)}.minigame-feedback-popup.warning{border-color:#d68910;color:#d68910}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@media(max-width:768px){.minigame-header{padding:12px 70px 12px 12px}.minigame-header-actions{top:12px;right:12px;gap:6px}.minigame-start-btn{padding:8px 12px;font-size:.85em}.minigame-dashboard-btn{width:40px;height:40px;font-size:1.3em}.minigame-ending-modal{padding:25px;max-width:95%}.minigame-ending-title{font-size:2em;letter-spacing:1.5px}.minigame-ending-subtitle{font-size:1em}.minigame-ending-quote{font-size:1em;padding:15px 20px}.minigame-ending-stat-row{flex-direction:column;align-items:flex-start;gap:5px}.minigame-ending-buttons{flex-direction:column}.minigame-ending-btn{min-width:100%}.minigame-header-overlay{flex-direction:column;height:auto;padding:15px;gap:10px}.minigame-header-overlay .minigame-ending-btn{min-width:100%}}.minigame-ending-modal::-webkit-scrollbar{width:8px}.minigame-ending-modal::-webkit-scrollbar-track{background:#3a2f2a1a;border-radius:10px}.minigame-ending-modal::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:10px;transition:background .3s ease}.minigame-ending-modal::-webkit-scrollbar-thumb:hover{background:var(--color-accent-dark)}.about-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--color-background);display:none;align-items:flex-start;justify-content:center;z-index:9998;overflow-y:auto;overflow-x:hidden;padding:40px 20px;scroll-behavior:auto}.about-screen.active{display:flex}.about-screen.auto-scrolling{pointer-events:none;will-change:scroll-position}.about-screen.auto-scrolling .about-container{pointer-events:auto}.about-container{max-width:1100px;width:100%;background:var(--overlay-strong);border:3px solid var(--color-border);border-radius:20px;padding:60px;margin-top:40px;box-shadow:0 10px 40px var(--shadow-strong);animation:fadeInScale .8s ease-out}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.about-header{text-align:center;margin-bottom:50px;animation:slideDown .8s ease-out .2s both}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.about-main-title{font-family:var(--font-heading);font-size:5em;font-weight:700;background:linear-gradient(135deg,var(--color-accent) 0%,#d4874f 25%,var(--color-accent-dark) 50%,#d4874f 75%,var(--color-accent) 100%);background-size:300% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 15px;letter-spacing:8px;text-shadow:none;animation:gradientShift 6s ease infinite,titlePulse 2s ease-in-out infinite;position:relative;display:inline-block;filter:drop-shadow(2px 2px 4px rgba(162,74,42,.3))}.about-main-subtitle{font-family:var(--font-body);font-size:1.4em;color:var(--color-accent-dark);font-style:italic;margin:0 0 30px;letter-spacing:2px;opacity:0;animation:fadeInUp 1s ease-out .5s forwards}.title-divider{width:200px;height:3px;background:linear-gradient(90deg,transparent,var(--color-accent),var(--color-accent-dark),var(--color-accent),transparent);margin:30px auto;border-radius:2px;animation:lineExpand 1.2s ease-out .8s both,dividerGlow 3s ease-in-out infinite}.about-welcome{font-size:1.2em;color:var(--color-secondary-text);font-style:italic;line-height:1.9;max-width:850px;margin:0 auto;opacity:0;animation:fadeInUp 1s ease-out 1s forwards}@keyframes titlePulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes lineExpand{0%{width:0;opacity:0}to{width:200px;opacity:1}}@keyframes dividerGlow{0%,to{box-shadow:0 0 5px #a24a2a4d}50%{box-shadow:0 0 15px #a24a2a99,0 0 25px #a24a2a4d}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.about-section{margin-bottom:40px;animation:fadeInUp .8s ease-out both}.about-section:nth-child(2){animation-delay:.3s}.about-section:nth-child(3){animation-delay:.4s}.about-section:nth-child(4){animation-delay:.5s}.about-section:nth-child(5){animation-delay:.6s}.about-section:nth-child(6){animation-delay:.7s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.section-title{font-family:var(--font-heading);font-size:2em;color:var(--color-accent-dark);margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--color-border)}.section-content{font-size:1.1em;line-height:1.8;color:var(--color-primary-text);text-align:justify}.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:25px;margin-top:30px}.team-member{background:var(--color-surface);border:2px solid var(--color-border);border-radius:15px;padding:25px;text-align:center;transition:all .3s ease;animation:popIn .6s ease-out both}.team-member:nth-child(1){animation-delay:.6s}.team-member:nth-child(2){animation-delay:.7s}.team-member:nth-child(3){animation-delay:.8s}.team-member:nth-child(4){animation-delay:.9s}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.team-member:hover{transform:translateY(-5px);box-shadow:0 8px 20px var(--shadow-med);border-color:var(--color-accent)}.member-name{font-family:var(--font-heading);font-size:1.8em;color:var(--color-accent);margin-bottom:15px}.member-quote{font-size:1em;font-style:italic;color:var(--color-secondary-text);line-height:1.6;quotes:"" " " "" "'" "'"}.member-quote:before{content:open-quote}.member-quote:after{content:close-quote}.github-link{display:inline-block;margin-top:20px;padding:12px 30px;background:var(--color-accent);color:#fff;text-decoration:none;border-radius:8px;font-weight:700;transition:all .3s ease;box-shadow:0 4px 12px var(--shadow-med)}.github-link:hover{background:var(--color-accent-dark);transform:translateY(-2px);box-shadow:0 6px 16px var(--shadow-strong)}.contact-info{text-align:center;margin-top:20px;padding:20px;background:var(--color-surface);border-radius:10px;border:2px solid var(--color-border)}.contact-email{color:var(--color-accent);font-weight:700;text-decoration:none;font-size:1.1em}.contact-email:hover{text-decoration:underline}.btn-continue{display:block;margin:40px auto 0;padding:15px 40px;background:var(--color-accent);color:#fff;border:2px solid var(--color-accent-dark);border-radius:10px;font-size:1.2em;font-weight:700;font-family:var(--font-body);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px var(--shadow-med);animation:pulseButton 2s ease-in-out infinite}@keyframes pulseButton{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.btn-continue:hover{background:var(--color-accent-dark);transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px var(--shadow-strong);animation:none}.about-footer{text-align:center;margin-top:40px;padding-top:30px;border-top:2px solid var(--color-border);color:var(--color-secondary-text);font-style:italic;animation:fadeIn 1s ease-out 1s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.about-container{padding:30px 20px}.about-title{font-size:2.2em}.about-subtitle{font-size:1em}.section-title{font-size:1.6em}.section-content{font-size:1em}.team-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.member-name{font-size:1.4em}.member-quote{font-size:.9em}.about-main-title{font-size:3em;letter-spacing:4px}.about-main-subtitle{font-size:1.1em}}.confirm-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#3a2f2ab3;display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;transition:opacity .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-modal-overlay.active{opacity:1}.confirm-modal{background:var(--color-background);border:3px solid var(--color-border);border-radius:12px;padding:32px 40px;max-width:500px;width:90%;box-shadow:0 10px 40px var(--shadow-strong),0 0 0 1px #3a2f2a1a;transform:scale(.9) translateY(-20px);opacity:0;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-family:var(--font-body)}.confirm-modal.active{transform:scale(1) translateY(0);opacity:1}.confirm-modal-icon{font-size:48px;text-align:center;margin-bottom:16px;animation:iconPulse 2s ease-in-out infinite}@keyframes iconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.confirm-modal-message{color:var(--color-primary-text);font-size:18px;line-height:1.6;text-align:center;margin-bottom:28px;font-family:var(--font-body)}.confirm-modal-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.confirm-modal-btn{padding:12px 32px;font-size:16px;font-family:var(--font-heading);font-weight:600;border-radius:8px;border:2px solid var(--color-border);cursor:pointer;transition:all .2s ease;min-width:120px;position:relative;overflow:hidden}.confirm-modal-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.confirm-modal-btn:hover:before{width:300px;height:300px}.confirm-modal-btn-cancel{background:var(--color-surface);color:var(--color-primary-text);border-color:var(--color-border)}.confirm-modal-btn-cancel:hover{background:var(--color-locked);border-color:var(--color-secondary-text);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-soft)}.confirm-modal-btn-cancel:active{transform:translateY(0);box-shadow:0 2px 6px var(--shadow-soft)}.confirm-modal-btn-confirm{background:var(--color-accent);color:#fff;border-color:var(--color-accent-dark)}.confirm-modal-btn-confirm:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark);transform:translateY(-2px);box-shadow:0 4px 12px #a24a2a66}.confirm-modal-btn-confirm:active{transform:translateY(0);box-shadow:0 2px 6px #a24a2a4d}.confirm-modal-btn:focus{outline:3px solid var(--color-accent);outline-offset:2px}@media(max-width:600px){.confirm-modal{padding:24px 28px;width:95%}.confirm-modal-icon{font-size:40px}.confirm-modal-message{font-size:16px;margin-bottom:24px}.confirm-modal-buttons{flex-direction:column}.confirm-modal-btn{width:100%;min-width:auto}}body.modal-active{overflow:hidden}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.confirm-modal-overlay.active .confirm-modal-icon{animation:iconPulse 2s ease-in-out infinite,shake .5s ease-in-out}
