*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--indigo-900:#1e1b4b;--indigo-800:#312e81;--indigo-700:#3730a3;--indigo-600:#4338ca;--indigo-500:#4f46e5;--indigo-400:#6366f1;--indigo-300:#818cf8;--indigo-200:#a5b4fc;--indigo-100:#e0e7ff;--indigo-50:#eef2ff;--amber:#f59e0b;--amber-light:#fef3c7;--success:#10b981;--success-light:#d1fae5;--danger:#ef4444;--danger-light:#fee2e2;--white:#fff;--gray-900:#111827;--gray-700:#374151;--gray-500:#6b7280;--gray-300:#d1d5db;--gray-200:#e5e7eb;--gray-100:#f3f4f6;--bg:#f8fafc;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.05);--shadow-md:0 4px 16px rgba(0,0,0,.1);--shadow-lg:0 10px 40px rgba(0,0,0,.15)}body,html{height:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--gray-900);line-height:1.6;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button,input,select,textarea{font-family:inherit}.login-page{min-height:100vh;background:linear-gradient(160deg,var(--indigo-900) 0,var(--indigo-600) 60%,#7c3aed 100%);display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{background:var(--white);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:420px;box-shadow:0 25px 60px rgba(0,0,0,.35)}.login-logo{text-align:center;margin-bottom:1.5rem}.login-logo img{width:80px;height:80px;border-radius:50%;object-fit:cover;box-shadow:0 4px 20px rgba(79,70,229,.3)}.login-title{font-size:1.5rem;font-weight:800;color:var(--indigo-900);text-align:center;line-height:1.25;margin-bottom:.35rem}.login-title span{color:var(--indigo-500)}.login-subtitle{text-align:center;font-size:.875rem;font-weight:600;color:var(--gray-500);letter-spacing:.06em;text-transform:uppercase;margin-bottom:2rem}.login-form{gap:1rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.4rem}.form-group label{font-size:.82rem;font-weight:600;color:var(--gray-700)}.form-group input{padding:.7rem 1rem;border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);font-size:.95rem;color:var(--gray-900);background:var(--white);transition:border-color .2s,box-shadow .2s;outline:none}.form-group input:focus{border-color:var(--indigo-500);box-shadow:0 0 0 3px rgba(79,70,229,.15)}.login-error{font-size:.85rem;color:#dc2626;background:var(--danger-light);border-left:3px solid #dc2626;border-radius:var(--radius-sm);padding:.6rem .85rem}.login-btn{margin-top:.5rem;padding:.8rem 1.5rem;background:var(--indigo-500);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:700;cursor:pointer;transition:background .18s,transform .1s,box-shadow .18s;box-shadow:0 4px 14px rgba(79,70,229,.35)}.login-btn:hover:not(:disabled){background:var(--indigo-600);transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,70,229,.45)}.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.login-help{text-align:center;font-size:.8rem;color:var(--gray-500);margin-top:1.5rem}.dashboard-layout{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--indigo-900);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-header{padding:1.5rem 1.25rem 1.1rem;border-bottom:1px solid hsla(0,0%,100%,.07)}.sidebar-logo img{width:48px;height:48px;border-radius:50%;object-fit:cover;margin-bottom:.5rem;display:block;box-shadow:0 2px 10px rgba(0,0,0,.4)}.sidebar-app-name{font-size:.95rem;font-weight:800;color:var(--white);line-height:1.2}.sidebar-app-sub{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--indigo-300);margin-top:.25rem}.sidebar-nav{flex:1 1;padding:.75rem 0}.sidebar-link{display:flex;align-items:center;gap:.65rem;padding:.65rem 1.25rem;font-size:.875rem;font-weight:500;color:hsla(0,0%,100%,.6);transition:all .15s;border-left:2px solid transparent}.sidebar-link:hover{color:var(--white);background:hsla(0,0%,100%,.06)}.sidebar-link.active{color:var(--white);background:hsla(0,0%,100%,.1);border-left-color:var(--indigo-300)}.sidebar-link-icon{font-size:1.1rem;width:22px;text-align:center}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid hsla(0,0%,100%,.07)}.sidebar-student-name{font-size:.875rem;font-weight:700;color:var(--white);margin-bottom:.15rem}.sidebar-student-pts{font-size:.75rem;color:var(--amber);font-weight:600;margin-bottom:.75rem}.logout-btn{width:100%;padding:.45rem .85rem;background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.15);border-radius:var(--radius-sm);color:hsla(0,0%,100%,.7);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.logout-btn:hover{background:hsla(0,0%,100%,.15);color:var(--white)}.main-content{flex:1 1;min-width:0;padding:2rem 2.5rem;overflow-y:auto}.welcome-banner{background:linear-gradient(135deg,var(--indigo-600) 0,var(--indigo-400) 100%);border-radius:var(--radius-lg);padding:1.75rem 2rem;margin-bottom:2rem;color:var(--white);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.welcome-text h1{font-size:1.5rem;font-weight:800;line-height:1.2;margin-bottom:.25rem}.welcome-text p{font-size:.9rem;opacity:.85}.points-badge{display:flex;flex-direction:column;align-items:center;background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.25);border-radius:var(--radius-md);padding:.75rem 1.25rem;text-align:center}.points-badge-value{font-size:2rem;font-weight:800;line-height:1;color:var(--amber)}.points-badge-label{font-size:.7rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;opacity:.8;margin-top:.2rem}.section-heading{font-size:1rem;font-weight:700;color:var(--gray-700);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem}.activity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:1rem;gap:1rem}.activity-card{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-md);padding:1.5rem 1.25rem;display:flex;flex-direction:column;align-items:center;gap:.6rem;text-align:center;transition:all .2s;text-decoration:none;color:inherit}.activity-card--active{border-color:var(--indigo-200);box-shadow:var(--shadow-sm);cursor:pointer}.activity-card--active:hover{border-color:var(--indigo-400);box-shadow:var(--shadow-md);transform:translateY(-3px)}.activity-card--coming-soon{opacity:.55;cursor:not-allowed;background:var(--gray-100)}.activity-card-icon{font-size:2.5rem}.activity-card-name{font-size:.9rem;font-weight:700;color:var(--indigo-900)}.activity-card-desc{font-size:.75rem;color:var(--gray-500)}.activity-card-tag{font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:.2em .6em;border-radius:100px}.tag-active{background:var(--success-light);color:#065f46}.tag-soon{background:var(--gray-200);color:var(--gray-500)}.game-container{max-width:780px;margin:0 auto}.game-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.game-title{font-size:1.4rem;font-weight:800;color:var(--indigo-900)}.game-meta{display:flex;align-items:center;gap:1rem}.timer-display{font-size:1.1rem;color:var(--indigo-600);background:var(--indigo-50);border-radius:var(--radius-sm);border:1.5px solid var(--indigo-200)}.score-display,.timer-display{display:flex;align-items:center;gap:.4rem;font-weight:700;padding:.4rem .85rem}.score-display{font-size:1rem;color:#065f46;background:var(--success-light);border-radius:var(--radius-sm);border:1.5px solid #6ee7b7}.list-picker{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);padding:2rem;text-align:center}.list-picker h2{font-size:1.25rem;font-weight:700;color:var(--indigo-900);margin-bottom:.5rem}.list-picker p{font-size:.9rem;color:var(--gray-500);margin-bottom:1.5rem}.list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:.75rem;gap:.75rem;text-align:left}.list-btn{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.1rem;background:var(--indigo-50);border:1.5px solid var(--indigo-100);border-radius:var(--radius-md);cursor:pointer;transition:all .15s;text-align:left}.list-btn:hover{border-color:var(--indigo-400);background:var(--indigo-100);transform:translateY(-2px)}.list-btn-name{font-size:.9rem;font-weight:700;color:var(--indigo-900)}.list-btn-level{font-size:.72rem;color:var(--indigo-500);font-weight:600}.list-btn-count{font-size:.7rem;color:var(--gray-500)}.match-board{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-sm)}.match-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-bottom:1.5rem}.match-column{display:flex;flex-direction:column;gap:.6rem}.match-column-label{font-size:.7rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.07em;text-align:center;margin-bottom:.25rem}.word-card{padding:.75rem 1rem;border:2px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;transition:all .15s;font-size:.9rem;font-weight:600;color:var(--gray-700);background:var(--white);text-align:center;min-height:52px;display:flex;align-items:center;justify-content:center;gap:.4rem;-webkit-user-select:none;-moz-user-select:none;user-select:none}.word-card:hover{border-color:var(--indigo-300);background:var(--indigo-50);color:var(--indigo-700)}.word-card--selected{border-color:var(--indigo-500)!important;background:var(--indigo-100)!important;color:var(--indigo-800)!important;box-shadow:0 0 0 3px rgba(79,70,229,.2)}.word-card--matched{border-color:var(--success)!important;background:var(--success-light)!important;color:#065f46!important;cursor:default;opacity:.75;transform:scale(.97)}.word-card--wrong{border-color:var(--danger)!important;background:var(--danger-light)!important;color:#991b1b!important;animation:shake .3s ease}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}.match-progress{height:6px;background:var(--gray-200);border-radius:99px;overflow:hidden;margin-top:1rem}.match-progress-fill{height:100%;background:linear-gradient(90deg,var(--indigo-500),var(--success));border-radius:99px;transition:width .3s ease}.result-screen{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);padding:2.5rem;text-align:center;box-shadow:var(--shadow-sm)}.result-icon{font-size:4rem;margin-bottom:1rem}.result-title{font-size:1.5rem;font-weight:800;color:var(--indigo-900);margin-bottom:.5rem}.result-stats{display:flex;gap:1.5rem;justify-content:center;margin:1.5rem 0;flex-wrap:wrap}.result-stat{display:flex;flex-direction:column;align-items:center;gap:.2rem}.result-stat-value{font-size:2rem;font-weight:800;color:var(--indigo-600)}.result-stat-label{font-size:.72rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em}.result-pts{font-size:1.1rem;font-weight:700;color:var(--amber);margin-bottom:1.5rem}.result-btns{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.25rem;border-radius:var(--radius-sm);border:none;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none}.btn-primary{background:var(--indigo-500);color:var(--white);box-shadow:0 2px 10px rgba(79,70,229,.3)}.btn-primary:hover{background:var(--indigo-600)}.btn-ghost{background:var(--gray-100);color:var(--gray-700)}.btn-ghost:hover{background:var(--gray-200)}.leaderboard{margin-top:2rem;background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden}.leaderboard-header{padding:1rem 1.25rem;background:var(--gray-100);font-size:.85rem;font-weight:700;color:var(--indigo-900)}.leaderboard-header,.leaderboard-row{border-bottom:1px solid var(--gray-200)}.leaderboard-row{display:flex;align-items:center;gap:1rem;padding:.75rem 1.25rem;font-size:.875rem}.leaderboard-row:last-child{border-bottom:none}.medal{font-size:1.2rem;width:30px;text-align:center;flex-shrink:0}.leaderboard-name{flex:1 1;font-weight:600;color:var(--gray-700)}.leaderboard-time{color:var(--indigo-600);font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.leaderboard-pts{color:var(--amber);font-weight:700;font-size:.8rem}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem}.page-title{font-size:1.5rem;font-weight:800;color:var(--indigo-900)}.page-subtitle{font-size:.875rem;color:var(--gray-500);margin-top:.2rem}.back-link{font-size:.82rem;color:var(--gray-500);display:inline-flex;align-items:center;gap:.3rem;margin-bottom:.4rem;transition:color .15s}.back-link:hover{color:var(--indigo-600)}@media (max-width:768px){.sidebar{display:none}.main-content{padding:1.25rem}.activity-grid{grid-template-columns:repeat(2,1fr)}.match-grid{gap:.5rem}.word-card{font-size:.8rem;padding:.6rem .75rem;min-height:44px}.welcome-banner{flex-direction:column}}.spelling-game{max-width:560px;margin:0 auto}.spelling-prompt{background:var(--white);border:2px solid var(--indigo-200);border-radius:var(--radius-lg);padding:2.5rem 2rem;text-align:center;margin-bottom:1.25rem;transition:border-color .25s,background .25s;box-shadow:var(--shadow-sm)}.spelling-feedback--correct{border-color:var(--success)!important;background:var(--success-light)!important;animation:correctFlash .35s ease}.spelling-feedback--wrong{border-color:var(--danger)!important;background:var(--danger-light)!important;animation:wrongFlash .35s ease}@keyframes correctFlash{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes wrongFlash{0%,to{transform:translateX(0)}20%{transform:translateX(-8px)}60%{transform:translateX(8px)}}.spelling-prompt-emoji{font-size:3.5rem;margin-bottom:.75rem;line-height:1}.spelling-prompt-italian{font-size:2rem;font-weight:800;color:var(--indigo-900);margin-bottom:.4rem}.spelling-prompt-hint{font-size:.82rem;color:var(--gray-500)}.spelling-correct-reveal{margin-top:1rem;padding:.6rem 1rem;background:var(--danger-light);border-radius:var(--radius-sm);font-size:.9rem;color:#991b1b}.spelling-input-wrap{display:flex;gap:.75rem;align-items:stretch}.spelling-input{flex:1 1;padding:.85rem 1.1rem;font-size:1.15rem;font-weight:600;border:2px solid var(--indigo-200);border-radius:var(--radius-md);outline:none;color:var(--indigo-900);background:var(--white);text-align:center;transition:border-color .15s,box-shadow .15s}.spelling-input:focus{border-color:var(--indigo-500);box-shadow:0 0 0 3px rgba(79,70,229,.15)}.spelling-input:disabled{opacity:.6;cursor:not-allowed}.quiz-board{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-sm)}.quiz-timer{height:8px;background:var(--gray-200);border-radius:99px;overflow:hidden;margin-bottom:1.5rem}.quiz-timer-bar{height:100%;border-radius:99px;transition:width .1s linear,background .5s}.quiz-question{text-align:center;margin-bottom:1.5rem}.quiz-question-label{font-size:.7rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.5rem}.quiz-question-word{font-size:2rem;font-weight:800;color:var(--indigo-900)}.quiz-timeout-msg{margin-top:.75rem;font-size:.9rem;color:var(--danger);font-weight:600}.quiz-options{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem}.quiz-option{min-height:64px;padding:.85rem 1rem;background:var(--indigo-50);border:2px solid var(--indigo-100);border-radius:var(--radius-md);font-size:.95rem;font-weight:600;color:var(--indigo-800);cursor:pointer;transition:all .15s;text-align:center;display:flex;align-items:center;justify-content:center}.quiz-option:hover:not(:disabled){border-color:var(--indigo-400);background:var(--indigo-100);transform:translateY(-2px)}.quiz-option:disabled{cursor:default}.quiz-option--correct{border-color:var(--success)!important;background:var(--success-light)!important;color:#065f46!important}.quiz-option--wrong{border-color:var(--danger)!important;background:var(--danger-light)!important;color:#991b1b!important;animation:shake .3s ease}.flashcard-game{max-width:560px;margin:0 auto}.flashcard-scene{perspective:1200px;height:260px;margin-bottom:1.25rem;cursor:pointer;outline:none}.flashcard{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-lg)}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-back,.flashcard-front{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;box-shadow:var(--shadow-md)}.flashcard-front{background:linear-gradient(135deg,var(--indigo-50) 0,var(--indigo-100) 100%);border:2px solid var(--indigo-200)}.flashcard-back{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #6ee7b7;transform:rotateY(180deg)}.flashcard-side-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-500);position:absolute;top:1rem;left:50%;transform:translateX(-50%)}.flashcard-emoji{font-size:2.5rem;line-height:1}.flashcard-word{font-size:2rem;font-weight:800;color:var(--indigo-900);text-align:center}.flashcard-flip-hint{font-size:.75rem;color:var(--gray-400);position:absolute;bottom:1rem;left:50%;transform:translateX(-50%);white-space:nowrap}.flashcard-nav{justify-content:space-between;margin-bottom:1rem}.flashcard-assess,.flashcard-nav{display:flex;gap:.75rem}.flashcard-assess-btn{flex:1 1;padding:.85rem 1rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:700;cursor:pointer;transition:all .15s;min-height:52px}.flashcard-assess-btn--known{background:var(--success-light);color:#065f46;border:2px solid #6ee7b7}.flashcard-assess-btn--known:hover{background:#a7f3d0;transform:translateY(-2px)}.flashcard-assess-btn--unknown{background:var(--danger-light);color:#991b1b;border:2px solid #fca5a5}.flashcard-assess-btn--unknown:hover{background:#fecaca;transform:translateY(-2px)}.cambridge-featured-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,#1e3a5f,#243f6a);border:1.5px solid #c9a227;border-radius:var(--radius-lg);padding:1.5rem 1.75rem;text-decoration:none;color:#e8eef5;transition:all .2s;box-shadow:0 4px 20px rgba(201,162,39,.15);margin-bottom:.5rem}.cambridge-featured-card:hover{background:linear-gradient(135deg,#243f6a,#2d5080);transform:translateY(-2px);box-shadow:0 8px 28px rgba(201,162,39,.25)}.cambridge-featured-left{display:flex;align-items:center;gap:1.1rem}.cambridge-featured-icon{font-size:2.25rem;flex-shrink:0}.cambridge-featured-title{font-size:1.1rem;font-weight:800;color:#c9a227;margin-bottom:.2rem}.cambridge-featured-desc{font-size:.8rem;color:#8aaed4}.cambridge-featured-right{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem;flex-shrink:0}.cambridge-featured-arrow{font-size:1.3rem;color:#c9a227;font-weight:700}@media (max-width:768px){.cambridge-featured-card{padding:1.1rem 1.25rem}.cambridge-featured-icon{font-size:1.75rem}.cambridge-featured-title{font-size:.95rem}}.cambridge-section{margin-top:2.5rem}.cambridge-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.cambridge-section-note{font-size:.82rem;color:var(--gray-500);margin-bottom:1rem}.cambridge-badge{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:.2em .65em;border-radius:100px;background:#c9a227;color:#1e3a5f;border:1px solid #b8911f}.cambridge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:1rem;gap:1rem}.cambridge-card{background:#1e3a5f;border:1.5px solid #2d5080;border-radius:var(--radius-md);padding:1.5rem 1.25rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;transition:all .2s;color:#e8eef5;position:relative}.cambridge-card--locked{opacity:.8;cursor:not-allowed}.cambridge-card--locked:hover{border-color:#c9a227;opacity:1}.cambridge-card-lock{position:absolute;top:.6rem;right:.75rem;font-size:.85rem;opacity:.5}.cambridge-card-icon{font-size:2rem}.cambridge-card-name{font-size:.9rem;font-weight:700;color:#c9a227}.cambridge-card-desc{font-size:.72rem;color:#8aaed4}.cambridge-card--active{cursor:pointer;text-decoration:none;border-color:#c9a227}.cambridge-card--active:hover{background:#243f6a;transform:translateY(-2px);box-shadow:0 6px 20px rgba(201,162,39,.25)}.cambridge-card-open{font-size:.75rem;color:#c9a227;margin-top:.25rem;font-weight:600}.cambridge-level-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:1rem;gap:1rem}.cambridge-level-card{background:#1e3a5f;border:1.5px solid #2d5080;border-radius:var(--radius-md);padding:1.5rem 1.25rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;transition:all .2s;color:#e8eef5;text-decoration:none}.cambridge-level-card--active{border-color:var(--level-color,#c9a227);cursor:pointer}.cambridge-level-card--active:hover{background:#243f6a;transform:translateY(-2px);box-shadow:0 6px 20px rgba(201,162,39,.2)}.cambridge-level-card--soon{opacity:.55;cursor:default}.cambridge-level-icon{font-size:2rem}.cambridge-level-name{font-size:.95rem;font-weight:700;color:#c9a227}.cambridge-level-year{font-size:.72rem;color:#8aaed4}.cambridge-level-count{font-size:.72rem;color:#5a80a8;margin-top:.1rem}.cambridge-level-tag{margin-top:.35rem;font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:.2em .6em;border-radius:100px}.cambridge-games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:2rem}.cambridge-game-card{background:#1e3a5f;border:1.5px solid var(--level-color,#c9a227);border-radius:var(--radius-md);padding:1.5rem 1.25rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center;transition:all .2s;color:#e8eef5;text-decoration:none}.cambridge-game-card:hover{background:#243f6a;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.2)}.cambridge-game-icon{font-size:2.25rem}.cambridge-game-name{font-size:.95rem;font-weight:700;color:#c9a227}.cambridge-game-desc{font-size:.72rem;color:#8aaed4;line-height:1.4}.cambridge-game-play{margin-top:.35rem;font-size:.78rem;font-weight:700;color:#c9a227}.cambridge-level-info{margin-top:1rem;padding:1rem 1.25rem;background:hsla(0,0%,100%,.03);border:1px solid #2d5080;border-radius:var(--radius-md);font-size:.8rem;color:#5a80a8;text-align:center}.cambridge-resources-page{padding:2rem;max-width:900px;margin:0 auto}.cambridge-resources-header{margin-bottom:2rem}.cambridge-resources-header h1{font-size:1.6rem;font-weight:800;color:#c9a227;margin:.5rem 0 .25rem}.cambridge-resources-header p{color:#8aaed4;font-size:.9rem}.cambridge-back{color:#8aaed4;text-decoration:none;font-size:.85rem;font-weight:600}.cambridge-back:hover{color:#c9a227}.cambridge-resources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1.25rem;gap:1.25rem}.cambridge-resource-card{background:#1e3a5f;border:1.5px solid #2d5080;border-radius:var(--radius-md);overflow:hidden}.cambridge-resource-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid #2d5080;background:rgba(0,0,0,.15)}.cambridge-resource-icon{font-size:1.5rem;flex-shrink:0}.cambridge-resource-name{font-weight:700;font-size:.95rem;color:#e8eef5}.cambridge-resource-year{font-size:.72rem;color:#8aaed4;margin-top:.1rem}.cambridge-resource-badge{margin-left:auto;padding:.2rem .55rem;border-radius:999px;font-size:.7rem;font-weight:800;color:#fff;flex-shrink:0}.cambridge-resource-files{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.4rem}.cambridge-resource-file{display:flex;align-items:center;gap:.5rem;padding:.5rem .6rem;background:hsla(0,0%,100%,.04);border-radius:var(--radius-sm);text-decoration:none;color:#c8d8ec;font-size:.82rem;transition:background .15s}.cambridge-resource-file:hover{background:rgba(201,162,39,.15);color:#c9a227}.cambridge-file-icon{flex-shrink:0}.cambridge-file-name{flex:1 1}.cambridge-file-open{font-size:.72rem;color:#c9a227;font-weight:600;flex-shrink:0}.cambridge-resource-folder{display:block;text-align:center;margin-top:.25rem;font-size:.75rem;color:#5a80a8;text-decoration:none;border-top:1px solid #2d5080;padding:.6rem .35rem .35rem}.cambridge-resource-folder:hover{color:#8aaed4}.cambridge-resources-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #2d5080;font-size:.78rem;color:#5a80a8;text-align:center}.frame-silver{border:3px solid silver;box-shadow:0 0 8px silver}.frame-gold{border:3px solid gold;box-shadow:0 0 12px gold}.frame-rainbow{border:3px solid transparent;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(45deg,red,orange,#ff0,green,blue,violet) border-box}.frame-stars{border:3px solid #fff;box-shadow:0 0 0 2px gold,0 0 16px gold}.frame-fire{border:3px solid #ff4500;box-shadow:0 0 12px #ff4500,0 0 24px #ff8c00}.bg-ocean{background:linear-gradient(135deg,#0f2027,#203a43,#2c5364)!important}.bg-forest{background:linear-gradient(135deg,#134e5e,#71b280)!important}.bg-sunset{background:linear-gradient(135deg,#f093fb,#f5576c,#fd746c)!important}.bg-galaxy{background:linear-gradient(135deg,#0f0c29,#302b63,#24243e)!important}.bg-candy{background:linear-gradient(135deg,#f953c6,#b91d73)!important}.sidebar-avatar-wrap{display:flex;justify-content:center;margin-bottom:.65rem}.sidebar-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;background:hsla(0,0%,100%,.1);border:2px solid hsla(0,0%,100%,.2);line-height:1}.sidebar-student-title{font-size:.7rem;color:var(--amber);font-weight:600;text-align:center;margin-bottom:.15rem;font-style:italic}.sidebar-student-coins{font-size:.75rem;color:#fbbf24;font-weight:600;margin-bottom:.75rem}.shop-page{position:relative}.shop-coin-balance{display:flex;align-items:center;gap:.4rem;background:rgba(251,191,36,.1);border:1.5px solid rgba(251,191,36,.4);border-radius:var(--radius-md);padding:.65rem 1.1rem}.shop-coin-icon{font-size:1.5rem}.shop-coin-amount{font-size:1.75rem;font-weight:800;color:#d97706;line-height:1}.shop-coin-label{font-size:.72rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.07em}.shop-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.shop-tab{padding:.45rem 1rem;border:1.5px solid var(--gray-300);border-radius:100px;background:var(--white);font-size:.82rem;font-weight:600;color:var(--gray-500);cursor:pointer;transition:all .15s}.shop-tab:hover{border-color:var(--indigo-300);color:var(--indigo-600)}.shop-tab--active{background:var(--indigo-500);border-color:var(--indigo-500);color:var(--white)}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));grid-gap:1rem;gap:1rem}.shop-card{background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--radius-md);padding:1.25rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.55rem;text-align:center;transition:all .2s}.shop-card--equipped{border-color:var(--indigo-400);background:var(--indigo-50);box-shadow:0 0 0 2px rgba(79,70,229,.15)}.shop-item-preview{border-radius:var(--radius-md);overflow:hidden}.shop-item-preview--emoji{font-size:2.75rem;border-radius:50%;border:2px solid var(--gray-200)}.shop-item-preview--emoji,.shop-item-preview--frame{width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:var(--gray-100)}.shop-item-preview--frame{border-radius:50%}.shop-item-preview--bg{width:72px;height:72px;border-radius:var(--radius-md);border:1.5px solid var(--gray-200)}.shop-card-name{font-size:.9rem;font-weight:700;color:var(--indigo-900)}.shop-card-desc{font-size:.72rem;color:var(--gray-500);line-height:1.4}.shop-card-price{font-size:.82rem;font-weight:700}.shop-price-free{color:var(--success);background:var(--success-light);padding:.2em .6em;border-radius:100px}.shop-price-cost{color:#d97706}.shop-btn{width:100%;justify-content:center;font-size:.8rem;padding:.5rem .75rem}.shop-btn--equipped{background:var(--indigo-100);color:var(--indigo-700);border:1.5px solid var(--indigo-300);border-radius:var(--radius-sm);font-weight:700;cursor:default}.shop-btn--cant-afford{background:var(--gray-100);color:var(--gray-400);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);cursor:not-allowed}.shop-toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--indigo-900);color:var(--white);padding:.75rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;z-index:9999;box-shadow:var(--shadow-lg);animation:toastIn .2s ease}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}[role=button],a,button{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.empty{text-align:center;padding:3rem;color:var(--gray-500);font-size:.9rem}.cambridge-level-page{max-width:900px;margin:0 auto;padding:1.5rem 2rem 3rem;display:flex;flex-direction:column;gap:2rem}.cambridge-section-block{background:hsla(0,0%,100%,.03);border:1px solid #2d5080;border-radius:var(--radius-lg);padding:1.5rem 1.75rem}.cambridge-section-title{display:flex;align-items:center;gap:.6rem;font-size:1rem;font-weight:800;color:#c9a227;margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}.cambridge-section-note-text{font-size:.8rem;color:#5a80a8;margin-bottom:1.25rem}.cambridge-wordcount-badge{margin-left:auto;font-size:.65rem;background:rgba(201,162,39,.15);border:1px solid rgba(201,162,39,.3);color:#c9a227;padding:.15em .6em;border-radius:100px;font-weight:700;letter-spacing:.06em;text-transform:none}.qplay-wrap{display:flex;flex-direction:column;gap:1rem}.qplay-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.qplay-type-badge{font-size:.72rem;font-weight:700;color:#fff;padding:.25em .75em;border-radius:100px;letter-spacing:.05em;text-transform:uppercase;flex-shrink:0}.qplay-dots{display:flex;gap:.3rem;flex-wrap:wrap}.qplay-dot{width:10px;height:10px;border-radius:50%;background:#2d5080;transition:background .2s,transform .2s}.qplay-dot--active{background:#c9a227;transform:scale(1.35)}.qplay-dot--ok{background:var(--success)}.qplay-dot--bad{background:var(--danger)}.qplay-dot--skip{background:#5a80a8}.qplay-coins-live{margin-left:auto;font-size:.85rem;font-weight:700}.qplay-card{background:#152b48;border:1.5px solid #2d5080;border-radius:var(--radius-lg);overflow:hidden;min-height:280px;display:flex;flex-direction:column}.qplay-face-label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#5a80a8;margin-bottom:.5rem}.qplay-emoji{font-size:2.5rem;line-height:1;margin-bottom:.5rem}.qplay-word{font-size:1.9rem;font-weight:800;color:#e8eef5;text-align:center;line-height:1.2;word-break:break-word}.qplay-hint{font-size:.72rem;color:#5a80a8;margin-top:.5rem}.qplay-feedback{font-size:.9rem;font-weight:700;text-align:center;padding:.65rem 1rem;margin:.75rem 1.5rem 0;border-radius:var(--radius-sm)}.qplay-feedback--ok{background:#064e3b;color:#6ee7b7}.qplay-feedback--bad{background:#7f1d1d;color:#fca5a5}.qplay-flash-wrap{flex:1 1;display:flex;flex-direction:column;padding:1.25rem;gap:1rem}.qplay-flashcard{flex:1 1;min-height:200px;position:relative;transform-style:preserve-3d;transition:transform .45s cubic-bezier(.4,0,.2,1);cursor:pointer;border-radius:var(--radius-md);outline:none}.qplay-flashcard.flipped{transform:rotateY(180deg)}.qplay-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem;border:1.5px solid #2d5080}.qplay-face--front{background:linear-gradient(135deg,#1e3a5f,#243f6a)}.qplay-face--back{background:linear-gradient(135deg,#0a2a0a,#0d3b0d);transform:rotateY(180deg)}.qplay-assess{display:flex;gap:.75rem}.qplay-assess-btn{flex:1 1;padding:.75rem 1rem;border:none;border-radius:var(--radius-md);font-size:.95rem;font-weight:700;cursor:pointer;transition:all .15s}.qplay-assess-btn--miss{background:#7f1d1d;color:#fca5a5}.qplay-assess-btn--miss:hover{background:#991b1b}.qplay-assess-btn--got{background:#064e3b;color:#6ee7b7}.qplay-assess-btn--got:hover{background:#065f46}.qplay-quiz-wrap{flex:1 1;display:flex;flex-direction:column;padding:1.25rem;gap:1rem}.qplay-quiz-prompt{display:flex;flex-direction:column;align-items:center;padding:1rem 0 .5rem}.qplay-quiz-opts{display:grid;grid-template-columns:1fr 1fr;grid-gap:.6rem;gap:.6rem}.qplay-quiz-opt{padding:.85rem 1rem;background:#1e3a5f;border:2px solid #2d5080;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:#e8eef5;cursor:pointer;transition:all .15s;text-align:center}.qplay-quiz-opt:hover:not(:disabled){border-color:#c9a227;background:#243f6a}.qplay-quiz-opt:disabled{cursor:default}.qplay-quiz-opt--correct{border-color:var(--success)!important;background:#064e3b!important;color:#6ee7b7!important}.qplay-quiz-opt--wrong{border-color:var(--danger)!important;background:#7f1d1d!important;color:#fca5a5!important}.qplay-spell-wrap{flex:1 1;display:flex;flex-direction:column;padding:1.25rem;gap:1rem}.qplay-spell-row{display:flex;gap:.6rem;align-items:stretch}.qplay-spell-input{flex:1 1;padding:.75rem 1rem;font-size:1.1rem;font-weight:700;background:#1e3a5f;border:2px solid #2d5080;border-radius:var(--radius-md);color:#e8eef5;outline:none;text-align:center;transition:border-color .15s}.qplay-spell-input:focus{border-color:#c9a227}.qplay-spell-input--ok{border-color:var(--success)!important;background:#064e3b!important}.qplay-spell-input--bad{border-color:var(--danger)!important;background:#7f1d1d!important}.qplay-spell-btn{padding:.75rem 1.1rem!important;flex-shrink:0}.qplay-nav{display:flex;align-items:center;gap:.75rem;justify-content:space-between}.qplay-nav-btn{padding:.45rem 1rem;background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.12);border-radius:var(--radius-sm);color:#8aaed4;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.qplay-nav-btn:hover:not(:disabled){background:hsla(0,0%,100%,.12);color:#e8eef5}.qplay-nav-btn:disabled{opacity:.35;cursor:not-allowed}.qplay-nav-count{font-size:.8rem;color:#5a80a8}.qplay-done{background:#152b48;border:1.5px solid #c9a227;border-radius:var(--radius-lg);padding:2.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.5rem}.qplay-done-icon{font-size:3rem}.qplay-done-title{font-size:1.4rem;font-weight:800;color:#c9a227}.qplay-done-stats{font-size:.9rem;color:#8aaed4}.wordlist-wrap{display:flex;flex-direction:column;gap:1rem}.wordlist-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.wordlist-search{flex:1 1;min-width:160px;padding:.55rem .9rem;background:#152b48;border:1.5px solid #2d5080;border-radius:var(--radius-sm);color:#e8eef5;font-size:.88rem;outline:none;transition:border-color .15s}.wordlist-search:focus{border-color:#c9a227}.wordlist-search::placeholder{color:#5a80a8}.wordlist-sort-btns{display:flex;gap:.35rem}.wordlist-sort-btn{padding:.4rem .85rem;background:hsla(0,0%,100%,.05);border:1px solid #2d5080;border-radius:100px;color:#8aaed4;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s}.wordlist-sort-btn.active,.wordlist-sort-btn:hover{background:rgba(201,162,39,.15);border-color:#c9a227;color:#c9a227}.wordlist-count{font-size:.75rem;color:#5a80a8;white-space:nowrap}.wordlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));grid-gap:.65rem;gap:.65rem}.wordlist-card{background:#152b48;border:1px solid #2d5080;border-radius:var(--radius-md);padding:.85rem 1rem;display:flex;flex-direction:column;gap:.3rem;transition:border-color .15s}.wordlist-card:hover{border-color:#4a6fa0}.wordlist-emoji{font-size:1.4rem;line-height:1}.wordlist-en,.wordlist-it{display:flex;align-items:baseline;gap:.2rem;flex-wrap:wrap}.wordlist-word{font-size:.88rem;font-weight:700;color:#e8eef5}.wordlist-word--it{color:#c9a227}.wordlist-plural{font-size:.72rem;color:#5a80a8;font-style:italic}.wordlist-no-it{font-size:.75rem;color:#2d5080}.shop-item-preview--room{width:72px;height:72px;display:flex;align-items:center;justify-content:center;font-size:2.5rem;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:var(--radius-md);border:2px solid #86efac}@media (max-width:768px){.cambridge-level-page{padding:1rem;gap:1.25rem}.cambridge-section-block{padding:1rem 1.1rem}.qplay-quiz-opts{grid-template-columns:1fr}.wordlist-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.shop-coin-icon{font-size:1.1rem}.exam-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,var(--level-color,var(--indigo-600)) 0,color-mix(in srgb,var(--level-color,var(--indigo-600)) 70%,#000) 100%);border-radius:var(--radius-lg);padding:1.5rem 2rem;color:#fff;text-decoration:none;box-shadow:var(--shadow-md);transition:transform .15s,box-shadow .15s;margin-bottom:.25rem}.exam-banner:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.exam-banner-left{display:flex;align-items:center;gap:1.25rem}.exam-banner-icon{font-size:2.5rem;flex-shrink:0}.exam-banner-badge{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.06em;padding:.2rem .6rem;border-radius:99px;background:hsla(0,0%,100%,.25);color:#fff;margin-bottom:.4rem}.exam-banner-title{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.2rem}.exam-banner-desc{font-size:.85rem;opacity:.85;color:#fff}.exam-banner-cta{font-weight:700;font-size:.95rem;background:hsla(0,0%,100%,.2);border-radius:var(--radius-sm);padding:.5rem 1.1rem;white-space:nowrap;flex-shrink:0}.exam-page{max-width:680px;margin:0 auto;padding-bottom:3rem}.exam-back{display:inline-block;color:var(--gray-500);font-size:.875rem;margin-bottom:1rem}.exam-back:hover{color:var(--gray-900)}.exam-error,.exam-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem;color:var(--gray-500)}.exam-loading-spinner{font-size:3rem;animation:pulse 1.5s infinite}.exam-error-icon{font-size:3rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.exam-intro{background:linear-gradient(135deg,var(--level-color,var(--indigo-600)) 0,color-mix(in srgb,var(--level-color,var(--indigo-600)) 70%,#000) 100%);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;color:#fff;box-shadow:var(--shadow-md)}.exam-intro-icon{font-size:3.5rem;margin-bottom:.75rem}.exam-intro-badge{display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.08em;padding:.25rem .75rem;border-radius:99px;background:hsla(0,0%,100%,.25);margin-bottom:.75rem}.exam-intro-title{font-size:1.75rem;font-weight:800;margin-bottom:.25rem}.exam-intro-subtitle{opacity:.8;margin-bottom:1.5rem}.exam-intro-details{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}.exam-detail-pill{background:hsla(0,0%,100%,.2);border-radius:99px;padding:.3rem .8rem;font-size:.8rem;font-weight:600}.exam-start-btn{font-size:1rem;padding:.8rem 2rem}.exam-progress-bar{height:6px;background:var(--gray-200);border-radius:99px;margin-bottom:1.5rem;overflow:hidden}.exam-progress-fill{height:100%;border-radius:99px;transition:width .4s ease}.exam-phase-label{font-size:.8rem;font-weight:700;color:var(--gray-500);letter-spacing:.05em;text-transform:uppercase;margin-bottom:1rem}.exam-card{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-sm)}.exam-hint{font-size:.875rem;color:var(--gray-500);margin-bottom:.5rem}.exam-sentence{font-size:1.25rem;font-weight:600;color:var(--gray-900);margin-bottom:1.5rem;line-height:1.5}.exam-instruction{font-size:.9rem;color:var(--gray-500);margin-bottom:.75rem}.exam-options{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-bottom:1rem}.exam-option{padding:.75rem 1rem;border-radius:var(--radius-md);border:2px solid var(--gray-200);background:#fff;font-size:.95rem;font-weight:600;color:var(--gray-700);cursor:pointer;transition:border-color .15s,background .15s;text-align:center}.exam-option:hover:not(:disabled){border-color:var(--indigo-400);background:var(--indigo-50)}.exam-option--correct{border-color:var(--success)!important;background:var(--success-light)!important;color:var(--success)!important}.exam-option--wrong{border-color:var(--danger)!important;background:var(--danger-light)!important;color:var(--danger)!important}.exam-next-btn{width:100%;margin-top:.75rem}.exam-built-sentence{min-height:56px;border:2px dashed var(--gray-300);border-radius:var(--radius-md);padding:.75rem;display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-bottom:.75rem}.exam-built-empty{color:var(--gray-400);font-size:.875rem}.exam-word-bank{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;padding:.75rem;background:var(--gray-100);border-radius:var(--radius-md)}.exam-word-chip{padding:.4rem .8rem;border-radius:var(--radius-sm);border:2px solid var(--indigo-200);background:#fff;color:var(--indigo-700);font-weight:600;font-size:.875rem;cursor:pointer;transition:background .15s,transform .1s}.exam-word-chip:hover:not(:disabled){background:var(--indigo-50);transform:scale(1.03)}.exam-word-chip--placed{background:var(--indigo-600);border-color:var(--indigo-600);color:#fff}.exam-result-msg{padding:.75rem 1rem;border-radius:var(--radius-md);font-weight:600;font-size:.9rem;margin-bottom:.75rem}.exam-result-msg--correct{background:var(--success-light);color:var(--success)}.exam-result-msg--wrong{background:var(--danger-light);color:var(--danger)}.exam-reading-text{background:var(--gray-100);border-radius:var(--radius-md);padding:1.25rem;font-size:.95rem;line-height:1.8;color:var(--gray-700);margin-bottom:1.25rem}.exam-highlight{background:#fef08a;color:var(--gray-900);border-radius:3px;padding:0 2px}.exam-reading-question{font-size:1rem;font-weight:600;color:var(--gray-900);margin-bottom:1rem}.exam-summary{background:linear-gradient(135deg,var(--level-color,var(--indigo-600)) 0,color-mix(in srgb,var(--level-color,var(--indigo-600)) 70%,#000) 100%);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;color:#fff;box-shadow:var(--shadow-md)}.exam-summary-icon{font-size:3rem;margin-bottom:.75rem}.exam-summary-title{font-size:1.5rem;font-weight:800;margin-bottom:1.5rem}.exam-summary-stats{display:flex;gap:1.5rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.exam-stat{background:hsla(0,0%,100%,.15);border-radius:var(--radius-md);padding:1rem 1.5rem;min-width:90px}.exam-stat-value{font-size:1.5rem;font-weight:800}.exam-stat-label{font-size:.8rem;opacity:.8;margin-top:.25rem}.exam-stat--stars .exam-stat-value{color:#fde68a}.exam-summary-actions{flex-wrap:wrap}.exam-summary-actions,.room-loading{display:flex;gap:1rem;justify-content:center}.room-loading{flex-direction:column;align-items:center;min-height:300px;color:var(--gray-500)}.room-loading-icon{font-size:3rem}.room-page{max-width:680px;margin:0 auto;padding-bottom:3rem}.room-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.room-tab{padding:.6rem 1.25rem;border-radius:var(--radius-md);border:2px solid var(--gray-200);background:#fff;font-weight:600;font-size:.9rem;cursor:pointer;transition:border-color .15s,background .15s}.room-tab--active{border-color:var(--indigo-500);background:var(--indigo-50);color:var(--indigo-700)}.room-canvas{position:relative;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.5rem;box-shadow:var(--shadow-md)}.room-canvas--room{background:linear-gradient(180deg,#c9d6ea,#c9d6ea 60%,#a89070 0,#a89070);height:280px}.room-canvas--planet{background:radial-gradient(ellipse at center,#0a0a2e 0,#1a1a4e 50%,#0d0d1f 100%);height:280px}.room-slot{position:absolute;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--radius-md);transition:transform .15s,box-shadow .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.room-slot:hover{transform:scale(1.05);box-shadow:0 4px 16px rgba(0,0,0,.2)}.room-slot--empty{border:2px dashed hsla(0,0%,100%,.5);background:hsla(0,0%,100%,.1)}.room-slot--filled{border:2px solid hsla(0,0%,100%,.3)}.room-slot-value{font-size:2.5rem}.room-slot-hint{font-size:.75rem;color:hsla(0,0%,100%,.7);font-weight:600}.room-slot-clear{position:absolute;top:-8px;right:-8px;width:20px;height:20px;border-radius:50%;background:var(--danger);color:#fff;border:none;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px rgba(0,0,0,.2)}.room-slot--wall{top:0;left:0;right:0;height:60%;background:transparent;border-radius:0;border:none}.room-slot--wall.room-slot--filled{font-size:5rem;opacity:.6}.room-slot--floor{bottom:0;left:0;right:0;height:40%;background:transparent;border-radius:0;border:none}.room-slot--floor.room-slot--filled{font-size:3rem;opacity:.5}.room-slot--furniture{width:80px;height:80px;bottom:45%}.room-slot--furniture-1{left:15%}.room-slot--furniture-2{right:15%}.room-slot--planet{width:100px;height:100px}.room-slot--terrain{top:50%;left:50%;transform:translate(-50%,-50%);width:130px;height:130px;border-radius:50%!important}.room-slot--terrain:hover{transform:translate(-50%,-50%) scale(1.05)}.room-slot--planet_deco_1{top:20%;left:20%;width:70px;height:70px}.room-slot--planet_deco_2{top:20%;right:20%;width:70px;height:70px}.room-actions{display:flex;gap:1rem;margin-bottom:1.5rem}.room-picker-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;justify-content:center;z-index:100;padding:1rem}.room-picker{background:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:500px;max-height:60vh;overflow-y:auto;padding:1.5rem}.room-picker-header{display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:1rem;margin-bottom:1rem}.room-picker-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--gray-500)}.room-picker-empty{text-align:center;padding:2rem;color:var(--gray-500);display:flex;flex-direction:column;gap:1rem;align-items:center}.room-picker-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:.75rem;gap:.75rem}.room-picker-item{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem .5rem;border-radius:var(--radius-md);border:2px solid var(--gray-200);background:#fff;cursor:pointer;transition:border-color .15s,background .15s}.room-picker-item:hover{border-color:var(--indigo-400);background:var(--indigo-50)}.room-picker-item-value{font-size:2rem}.room-picker-item-name{font-size:.75rem;font-weight:600;color:var(--gray-600);text-align:center}.shop-item-preview--planet{font-size:2.5rem;display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#1a1a4e,#0a0a2e);margin:0 auto .75rem}