*{box-sizing:border-box}body{color:#0b1f3a;background:#f7fbff;margin:0;font-family:Arial,Helvetica,sans-serif}button,input,textarea,select{font-family:inherit}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1}.site-header{z-index:1000;background:#fff;border-bottom:1px solid #dce8f5;width:100%;position:sticky;top:0;box-shadow:0 2px 8px #00418214}.header-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:10px 24px;display:flex}.logo-link{align-items:center;text-decoration:none;display:flex}.site-logo{width:auto;height:70px;display:block}.main-nav{align-items:center;gap:28px;display:flex}.nav-link{color:#0b1f3a;cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;padding:8px 0;font-size:15px;font-weight:600;text-decoration:none;transition:all .2s}.nav-link:hover,.nav-link.active{color:#028ee6;border-bottom-color:#028ee6}.logout-button{font-family:inherit}.site-footer{color:#fff;background:#0074c8;margin-top:40px}.footer-container{justify-content:space-between;align-items:center;gap:24px;max-width:1200px;margin:0 auto;padding:28px 24px;display:flex}.footer-logo-section{align-items:center;gap:18px;max-width:600px;display:flex}.footer-logo{background:#fff;border-radius:8px;width:auto;height:70px;padding:4px}.footer-logo-section p{margin:0;line-height:1.5}.footer-links{flex-wrap:wrap;gap:18px;display:flex}.footer-links a{color:#fff;font-weight:500;text-decoration:none}.footer-bottom{text-align:center;border-top:1px solid #ffffff40;padding:12px 20px;font-size:14px}.hero-section{text-align:center;background:linear-gradient(135deg,#eaf6ff,#fff);padding:70px 24px}.hero-content{max-width:900px;margin:0 auto}.hero-content h1{color:#0b1f3a;margin:0 0 16px;font-size:44px}.hero-content p{color:#4d6075;font-size:18px;line-height:1.6}.hero-button{max-width:240px;margin:20px auto 0}.home-section,.selection-page,.lesson-page,.content-page,.instruction-page,.quiz-page{text-align:center;max-width:1100px;margin:0 auto;padding:50px 24px}.home-section h2,.selection-page h1,.lesson-page h1,.content-page h1{color:#0b1f3a;margin-bottom:8px;font-size:36px}.light-card,.info-card,.login-card,.register-card,.instruction-card,.quiz-card{background:#fff;border:1px solid #dceeff;border-radius:18px;box-shadow:0 12px 30px #0053961f}.light-card{padding:34px}.grade-grid,.subject-grid,.lesson-grid,.steps-grid,.score-grid{gap:24px;margin-top:34px;display:grid}.grade-grid{grid-template-columns:repeat(2,1fr)}.subject-grid,.lesson-grid,.steps-grid,.score-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.grade-card,.subject-card,.lesson-card,.gold-quiz-card,.info-card{background:#fff;border:1px solid #dceeff;border-radius:18px;padding:26px;transition:all .2s;box-shadow:0 10px 24px #0053961c}.grade-card,.subject-card{cursor:pointer}.grade-card:hover,.subject-card:hover,.lesson-card:hover,.gold-quiz-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px #0053962b}.grade-card img{object-fit:contain;width:220px;max-width:100%;height:220px;margin-bottom:16px}.grade-card h2,.subject-card h2{color:#028ee6;font-size:24px}.two-columns{text-align:left;grid-template-columns:1fr 1fr;gap:24px;display:grid}.small-note{color:#60758a;font-size:14px}.login-page,.register-page{background:linear-gradient(135deg,#f7fbff,#eaf6ff);justify-content:center;align-items:center;min-height:calc(100vh - 180px);padding:50px 20px;display:flex}.login-card{text-align:center;width:100%;max-width:440px;padding:34px}.register-card{text-align:center;width:100%;max-width:720px;padding:34px}.login-form,.register-form{text-align:left;flex-direction:column;gap:16px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.login-form label,.register-form label{color:#0b1f3a;font-size:14px;font-weight:600}.login-form input,.register-form input,.register-form textarea,.register-form select,.blank-input,.match-row select{background:#fff;border:1px solid #bdd7ee;border-radius:10px;outline:none;width:100%;margin-top:6px;padding:12px 14px;font-size:15px}.primary-button,.secondary-button,.gold-button,.silver-button{cursor:pointer;border:none;border-radius:10px;width:100%;padding:13px 16px;font-size:16px;font-weight:700}.primary-button{color:#fff;background:#028ee6}.primary-button:hover{background:#0074c8}.primary-button:disabled{cursor:not-allowed;background:#9bcdeb}.secondary-button{color:#028ee6;background:#fff;border:2px solid #028ee6}.secondary-button:hover{background:#eaf6ff}.registration-section{border-top:1px solid #e1edf7;margin-top:24px;padding-top:20px}.error-message{color:#b00020;text-align:center;background:#ffeaea;border-radius:8px;margin:12px 0;padding:10px 12px;font-size:14px}.success-message{color:#087a2f;text-align:center;background:#eafff1;border-radius:8px;padding:10px 12px;font-size:14px}.gold-quiz-card{background:linear-gradient(135deg,#fff8e1,#fff);border:2px solid #f2c94c;max-width:720px;margin:34px auto}.gold-quiz-card h2{color:#b88700;font-size:30px}.gold-button{color:#3b2a00;background:#f2c94c}.silver-button{color:#fff;background:#028ee6}.instruction-card,.quiz-card{text-align:left;max-width:780px;margin:0 auto;padding:34px}.instruction-card h1,.quiz-card h1{text-align:center}.instruction-card li{margin:12px 0}.quiz-topline{background:#eaf6ff;border-radius:10px;justify-content:space-between;gap:16px;padding:12px;font-weight:700;display:flex}.option-row{cursor:pointer;border:1px solid #dceeff;border-radius:10px;margin:12px 0;padding:14px;display:block}.match-row{grid-template-columns:1fr 1fr;align-items:center;gap:16px;margin:12px 0;display:grid}.correct-title{color:#087a2f}.wrong-title{color:#b45d00}.answer-detail{background:#f7fbff;border-radius:10px;margin:12px 0;padding:12px 16px}.end-card{text-align:center}.medal-summary{grid-template-columns:repeat(3,1fr);gap:12px;margin:20px 0;display:grid}.medal-summary p,.attempt-row{background:#f7fbff;border-radius:10px;padding:14px}.spaced-button{margin-top:12px}.attempt-list{gap:10px;margin-top:20px;display:grid}@media (width<=768px){.header-container,.footer-container{flex-direction:column;gap:12px}.site-logo,.footer-logo{height:60px}.main-nav{flex-wrap:wrap;justify-content:center;gap:14px}.hero-content h1{font-size:32px}.grade-grid,.two-columns,.form-row,.match-row,.medal-summary{grid-template-columns:1fr}}.hint-box{color:#0b1f3a;text-align:left;background:#eef8ff;border-left:5px solid #028ee6;border-radius:10px;margin:24px 0 16px;padding:14px 16px;line-height:1.5}.explanation-box{background:#f7fbff;border:1px solid #dceeff;border-radius:12px;padding:14px 16px}.coin{letter-spacing:1px;border:8px solid #fff9;border-radius:50%;justify-content:center;align-items:center;width:170px;height:170px;margin:18px auto 24px;font-size:22px;font-weight:900;display:flex;box-shadow:inset 0 8px 18px #ffffff8c,inset 0 -12px 20px #0000002e,0 14px 34px #0000002e}.coin span{border:3px dashed #ffffffbf;border-radius:50%;justify-content:center;align-items:center;width:118px;height:118px;display:flex}.coin-gold{color:#5a3b00;background:radial-gradient(circle at 35% 30%,#fff3a3,#f2c94c 45%,#b88700 100%)}.coin-silver{color:#30343b;background:radial-gradient(circle at 35% 30%,#fff,#cfd6df 45%,#808a96 100%)}.coin-bronze{color:#fff3df;background:radial-gradient(circle at 35% 30%,#ffc784,#b87333 45%,#6b3b16 100%)}.coin-none{color:#0b1f3a;background:radial-gradient(circle at 35% 30%,#fff,#dceeff 45%,#9bcdeb 100%);font-size:16px}.encouragement-box{color:#0b1f3a;background:#f0fbf4;border:1px solid #c9efda;border-radius:16px;max-width:720px;margin:18px auto 24px;padding:18px 20px}.encouragement-box p{margin:0 0 8px;font-size:17px;font-weight:600;line-height:1.5}.encouragement-box small{color:#3c6f4d}.score-page{max-width:1120px}.score-total-card p{color:#028ee6;margin:10px 0;font-size:38px;font-weight:800}.score-total-card small{color:#4d6075;font-weight:600}.medal-cards .info-card:first-child h2,.medal-cards .info-card:first-child p{color:#8b5a2b}.medal-cards .info-card:nth-child(2) h2,.medal-cards .info-card:nth-child(2) p{color:#777}.medal-cards .info-card:nth-child(3) h2,.medal-cards .info-card:nth-child(3) p{color:#b88700}.chart-card{background:#fff;border:1px solid #dceeff;border-radius:18px;margin:28px 0;padding:24px;box-shadow:0 10px 24px #0053961c}.chart-card h2{color:#0b1f3a;margin-top:0}.chart-wrap{width:100%;overflow-x:auto}.chart-wrap svg{background:#fbfdff;border-radius:12px;width:100%;min-width:720px;height:auto}.chart-grid-line{stroke:#dce8f5;stroke-width:1px}.chart-axis-text{fill:#4d6075;font-size:12px;font-weight:600}.chart-legend{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:14px;display:flex}.chart-legend span{color:#0b1f3a;align-items:center;gap:6px;font-weight:600;display:inline-flex}.chart-legend i{border-radius:50%;width:14px;height:14px;display:inline-block}.match-answer-section{gap:16px;display:grid}.match-answer-table-wrap{width:100%;margin-top:10px;overflow-x:auto}.match-answer-table{border-collapse:collapse;background:#fff;border:1px solid #dceeff;border-radius:10px;width:100%;overflow:hidden}.match-answer-table th,.match-answer-table td{text-align:left;vertical-align:top;border-bottom:1px solid #dceeff;padding:12px 14px}.match-answer-table th{color:#0b1f3a;background:#eaf6ff}.match-answer-table tr:last-child td{border-bottom:none}.correct-match-table th{background:#eafff1}.correct-match-detail{border:1px solid #c9efda}.answer-delay-note{color:#4d6075;text-align:center;margin:10px 0 0;font-size:14px;font-weight:600}
