:root{color:#1b261e;--telegram-bg:#f5f8ee;--telegram-text:#1b261e;font-synthesis:none;text-rendering:optimizelegibility;background:#f5f8ee;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}.telegram-webapp body{color:var(--telegram-text);background:var(--telegram-bg);overscroll-behavior:none}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.auth-shell,.result-shell{background:radial-gradient(circle at 0 0,#fcc45547,#0000 34%),linear-gradient(135deg,#f7fbf0 0%,#e9f7f3 100%);place-items:center;min-height:100vh;padding:28px;display:grid}.auth-panel,.result-card{background:#fff;border:1px solid #dde8d8;border-radius:24px;width:min(460px,100%);padding:30px;box-shadow:0 20px 60px #26433a24}.auth-brand{text-align:center;justify-items:center;display:grid}.brand-mark{object-fit:cover;border:1px solid #d9ead2;border-radius:50%;width:96px;height:96px;margin:0 auto 18px;display:block;box-shadow:0 10px 28px #173f2a24}.auth-brand p{max-width:360px}h1{margin:0;line-height:1.05}p{color:#5f6f65;line-height:1.6}.auth-tabs{background:#edf4e8;border-radius:16px;grid-template-columns:1fr 1fr;gap:8px;margin:22px 0;padding:6px;display:grid}.auth-tabs button{color:#506154;background:0 0;border:0;border-radius:12px;padding:12px 10px;font-weight:800}.auth-tabs button.active{color:#173f2a;background:#fff;box-shadow:0 8px 20px #173f2a1a}.auth-form,.lesson-card{gap:16px;display:grid}label{color:#415348;gap:8px;font-size:13px;font-weight:800;display:grid}input,textarea{color:#1b261e;background:#fbfdf8;border:1px solid #cdddcc;border-radius:14px;outline:none;width:100%;padding:13px 14px}textarea{resize:vertical;min-height:120px;line-height:1.5}input:focus,textarea:focus{border-color:#19a96b;box-shadow:0 0 0 4px #19a96b24}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.primary-btn,.secondary-btn,.icon-btn,.action-btn{border:0;border-radius:16px;justify-content:center;align-items:center;gap:8px;min-height:48px;font-weight:900;display:inline-flex}.primary-btn{color:#fff;background:#19a96b;padding:0 18px;box-shadow:0 5px #0f7e4d}.primary-btn:hover{transform:translateY(-1px)}.primary-btn:disabled{opacity:.45;transform:none}.primary-btn.compact{min-width:150px}.secondary-btn{color:#244333;background:#eef5ea;padding:0 16px}.test-start-btn{color:#0d7548;background:#e4f6eb;border:1px solid #bfe4ce}.icon-btn{color:#244333;background:#fff;border:1px solid #dce8d8;width:48px}.pronounce-btn{color:#0d7548;background:#e4f6eb;border:1px solid #bfe4ce;border-radius:50%;place-items:center;width:52px;min-width:52px;min-height:52px;display:inline-grid;box-shadow:0 5px #b4d9c2}.pronounce-btn:hover:not(:disabled){transform:translateY(-1px)}.pronounce-btn:disabled{opacity:.72}.pronounce-btn.compact{width:42px;min-width:42px;min-height:42px;box-shadow:0 3px #b4d9c2}.pronounce-spinner{border:3px solid;border-top-color:#0000;border-radius:50%;width:20px;height:20px;animation:.75s linear infinite pronounce-spin}.pronounce-btn.compact .pronounce-spinner{border-width:2px;width:16px;height:16px}@keyframes pronounce-spin{to{transform:rotate(360deg)}}.action-btn{color:#244333;background:#fff;border:1px solid #dce8d8;padding:0 14px}.action-btn span{white-space:nowrap}.icon-btn input,.action-btn input{display:none}.error-text{color:#b83232;font-size:14px;font-weight:800}.success-text{color:#108052;font-size:14px;font-weight:800}.announcement-modal{z-index:90;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.announcement-backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#1220157a;position:absolute;inset:0}.announcement-panel{text-align:center;background:linear-gradient(135deg,#fff 0%,#f5fbf0 100%);border:1px solid #dbe8d4;border-radius:24px;gap:18px;width:min(480px,100%);padding:clamp(24px,5vw,34px);display:grid;position:relative;box-shadow:0 26px 80px #12201547}.announcement-close{color:#244333;background:#fff;border:1px solid #dce8d8;border-radius:50%;place-items:center;width:38px;height:38px;display:grid;position:absolute;top:12px;right:12px}.announcement-icon{color:#fff;background:#19a96b;border-radius:22px;justify-self:center;place-items:center;width:70px;height:70px;display:grid;box-shadow:0 8px #0f7e4d}.announcement-greeting{color:#148250;margin:0 0 8px;font-weight:950}.announcement-panel h2{color:#173f2a;margin:0;font-size:clamp(28px,6vw,40px);line-height:1.05}.announcement-panel p{margin:10px 0 0}.announcement-action{justify-self:center;min-width:170px}.report-fab{z-index:30;color:#244333;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff0;border:1px solid #cfe0c8;border-radius:999px;align-items:center;gap:8px;min-height:38px;padding:0 12px;font-size:12px;font-weight:900;display:inline-flex;position:fixed;bottom:16px;left:16px;box-shadow:0 10px 28px #29443629}.report-fab svg{color:#148250;flex:none}.report-modal{z-index:60;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.report-backdrop{background:#12201570;position:absolute;inset:0}.report-panel{background:#fff;border:1px solid #dbe8d4;border-radius:22px;gap:16px;width:min(460px,100%);padding:24px;display:grid;position:relative;box-shadow:0 24px 70px #12201542}.report-panel h2{color:#173f2a;margin:0;font-size:28px;line-height:1.1}.report-panel p{margin:8px 0 0}.report-close{color:#244333;background:#fff;border:1px solid #dce8d8;border-radius:50%;place-items:center;width:36px;height:36px;display:grid;position:absolute;top:12px;right:12px}.report-upload{color:#244333;text-align:center;background:#f8fbf4;border:2px dashed #c9ddc2;border-radius:16px;place-items:center;gap:8px;min-height:92px;padding:14px;display:grid}.report-upload span{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.report-upload input{display:none}.app-shell{min-height:100vh;padding:18px 18px calc(90px + env(safe-area-inset-bottom,0px));background:linear-gradient(#ffffffc7,#f5f8eeeb),#f5f8ee}.topbar,.lesson-topbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffdb;border:1px solid #dfead9;border-radius:22px;justify-content:space-between;align-items:center;gap:16px;max-width:980px;margin:0 auto;padding:12px;display:flex}.profile{align-items:center;gap:12px;min-width:0;display:flex}.profile-button{text-align:left;color:inherit;cursor:pointer;background:0 0;border:0;flex:auto;justify-content:flex-start;padding:0}.top-rating-btn{color:#13784d;background:#eef8f1;border-color:#cfe5d6;flex:none}.profile-button>svg{color:#52705d;flex:none;margin-left:auto}.profile strong,.lesson-topbar strong{display:block}.profile span,.lesson-topbar span,.level-label span{color:#6a7a6f;margin-top:2px;font-size:13px;display:block}.avatar{object-fit:cover;background:#e6f2df;border-radius:18px;width:54px;height:54px}.avatar.initials{color:#13784d;place-items:center;font-weight:950;display:grid}.top-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.account-shell{background:linear-gradient(#ffffffc7,#f5f8eeeb),#f5f8ee;min-height:100vh;padding:18px}.account-panel,.leaderboard-panel{background:#fff;border:1px solid #dbe8d4;border-radius:24px;width:min(820px,100%);margin:18px auto 0;padding:clamp(18px,4vw,30px);box-shadow:0 18px 44px #2944361a}.account-hero{align-items:center;gap:16px;display:flex}.account-hero .avatar{border-radius:22px;width:76px;height:76px}.account-hero h1{font-size:clamp(26px,5vw,42px)}.account-hero p{margin:6px 0 0;font-weight:800}.account-actions{flex-wrap:wrap;gap:10px;margin:22px 0;display:flex}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.stats-grid div{background:#f1f8ec;border-radius:18px;gap:8px;padding:16px;display:grid}.stats-grid span{color:#64786b;font-size:13px;font-weight:800}.stats-grid strong{color:#173f2a;font-size:28px;line-height:1}.panel-title{color:#173f2a;align-items:center;gap:10px;display:flex}.panel-title h2{margin:0;font-size:28px}.rating-tabs{background:#edf4e8;border-radius:16px;grid-template-columns:1fr 1fr;gap:8px;margin-top:16px;padding:6px;display:grid}.rating-tabs button{color:#506154;background:0 0;border:0;border-radius:12px;min-height:42px;font-weight:900}.rating-tabs button.active{color:#173f2a;background:#fff;box-shadow:0 8px 20px #173f2a1a}.leaderboard-list{gap:10px;margin-top:16px;display:grid}.leaderboard-row,.personal-rating-row{border:1px solid #e0eadb;border-radius:18px;grid-template-columns:32px 46px minmax(0,1fr) auto;align-items:center;gap:10px;padding:12px;display:grid}.leaderboard-row>strong{color:#148250;font-size:20px}.personal-rating-list{gap:10px;margin-top:16px;display:grid}.personal-rating-row{grid-template-columns:46px minmax(0,1fr) auto}.level-badge{color:#13784d;background:#e6f2df;border-radius:15px;place-items:center;width:46px;height:46px;font-size:18px;font-weight:950;display:grid}.personal-rating-row strong,.personal-rating-row small{display:block}.personal-rating-row strong{color:#1b261e;font-weight:950}.personal-rating-row small{color:#6a7a6f;margin-top:3px;font-weight:750}.leaderboard-row img,.mini-avatar{object-fit:cover;background:#e6f2df;border-radius:15px;width:46px;height:46px}.mini-avatar{color:#13784d;place-items:center;font-weight:950;display:grid}.leaderboard-row span,.leaderboard-row small{display:block}.leaderboard-row span{color:#1b261e;text-overflow:ellipsis;white-space:nowrap;font-weight:950;overflow:hidden}.leaderboard-row small{color:#6a7a6f}.leaderboard-score{text-align:right;justify-self:end}.leaderboard-score b,.leaderboard-score small{white-space:nowrap;display:block}.leaderboard-score b{color:#173f2a}.leaderboard-score small{color:#4d7a5d;margin-top:3px;font-weight:850}.map-intro{text-align:center;max-width:780px;margin:34px auto 22px}.map-intro h1{font-size:clamp(32px,6vw,58px)}.resume-panel{background:#fff;border:1px solid #cfe4d5;border-radius:20px;justify-content:space-between;align-items:center;gap:14px;width:min(760px,100%);margin:0 auto 18px;padding:16px;display:flex;box-shadow:0 12px 32px #2944361a}.resume-panel span,.resume-panel small{color:#607469;font-size:13px;font-weight:850;display:block}.resume-panel strong{color:#173f2a;margin:4px 0;font-size:clamp(18px,3vw,24px);line-height:1.15;display:block}.resume-actions,.section-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.resume-actions{justify-content:flex-end}.level-map{gap:22px;max-width:520px;margin:0 auto;padding:16px 0;display:grid;position:relative}.level-map:before{content:"";background:repeating-linear-gradient(#bfdab7 0 24px,#a8cf9f 24px 48px);border-radius:999px;width:8px;position:absolute;top:64px;bottom:64px;left:50%;transform:translate(-50%)}.level-row{align-items:center;gap:14px;display:flex;position:relative}.level-row.left{justify-content:flex-start}.level-row.right{justify-content:flex-end}.level-row.right .level-label{text-align:right;order:-1}.level-node{z-index:1;aspect-ratio:1;color:#fff;background:#19a96b;border:0;border-radius:50%;place-items:center;gap:0;width:86px;display:grid;position:relative;box-shadow:0 8px #0f7e4d,0 18px 34px #19a96b3d}.level-node span{font-size:20px;font-weight:950}.level-node.locked{background:#b9c6b7;box-shadow:0 8px #8e9d8b}.level-row.current .level-node{outline:4px solid #fffffff2;box-shadow:0 0 0 8px #19a96b38,0 8px #0f7e4d,0 18px 34px #19a96b3d}.level-node.review-node{color:#173f2a;background:linear-gradient(145deg,#ffffff5c,#0000 42%),#f7c64a;box-shadow:0 8px #c48c1d,0 20px 34px #c48c1d42}.level-node.review-node.locked{color:#fff;background:linear-gradient(145deg,#fff3,#0000 44%),#c3b896;box-shadow:0 8px #9f936f}.level-row.current .level-node.review-node{box-shadow:0 0 0 8px #f7c64a47,0 8px #c48c1d,0 20px 34px #c48c1d42}.level-label{background:#ffffffd1;border:1px solid #dbe8d4;border-radius:18px;min-width:140px;padding:12px 14px}.level-label.review-label{background:#fffaf0;border-color:#efd082;gap:3px;display:grid;box-shadow:0 12px 28px #c48c1d21}.level-label.review-label small{color:#fff;letter-spacing:0;background:#173f2a;border-radius:999px;width:max-content;padding:4px 8px;font-size:11px;font-weight:950;display:inline-flex}.level-row.right .level-label.review-label small{justify-self:end;margin-left:auto}.star-rating{color:#c8d2c3;justify-content:center;align-items:center;gap:6px;display:inline-flex}.star-rating svg{fill:#0000;stroke-width:2.4px}.star-rating svg.filled{color:#f2b832;fill:#f2b832}.star-rating.compact{gap:3px;margin-top:8px}.lesson-shell{min-height:100vh;padding:18px 18px calc(94px + env(safe-area-inset-bottom,0px));background:#f5f8ee}.lesson-topbar{max-width:820px}.step-pill{color:#1a6d49;background:#e7f3df;border-radius:999px;padding:10px 14px;font-weight:900}.lesson-progress{background:#dce8d4;border-radius:999px;max-width:800px;height:12px;margin:18px auto 34px;overflow:hidden}.lesson-progress span{background:#19a96b;height:100%;transition:width .22s;display:block}.lesson-card{background:#fff;border:1px solid #dbe8d4;border-radius:28px;width:min(800px,100%);margin:0 auto;padding:clamp(20px,5vw,42px);box-shadow:0 18px 44px #2944361f}.section-card{text-align:center;place-items:center;min-height:380px}.section-card h1{color:#15251a;font-size:clamp(42px,8vw,82px)}.section-number{color:#148250;background:#e5f5dd;border-radius:999px;place-items:center;min-width:116px;min-height:44px;padding:0 18px;font-weight:950;display:inline-grid}.section-select{gap:20px;width:min(900px,100%);margin:0 auto;display:grid}.section-summary{text-align:center;background:#fff;border:1px solid #dbe8d4;border-radius:28px;padding:clamp(22px,4vw,36px);box-shadow:0 18px 44px #2944361a}.section-summary.review-summary{background:linear-gradient(135deg,#fff8e8 0%,#fff 48%,#edf8ef 100%);border-color:#efd082;position:relative;overflow:hidden;box-shadow:0 20px 48px #c48c1d24}.section-summary.review-summary:before{content:"";pointer-events:none;border-top:6px solid #f7c64a;position:absolute;inset:0}.review-kicker{color:#fff;text-transform:uppercase;background:#173f2a;border-radius:999px;margin-bottom:14px;padding:7px 12px;font-size:12px;font-weight:950;display:inline-flex}.section-summary h1{font-size:clamp(34px,6vw,58px)}.average-box{color:#173f2a;background:#f1f8ec;border-radius:20px;justify-items:center;gap:8px;width:min(320px,100%);margin:20px auto 0;padding:16px;display:grid}.section-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.section-choice{background:#fff;border:1px solid #dbe8d4;border-radius:24px;gap:14px;padding:22px;display:grid;box-shadow:0 12px 30px #29443617}.section-choice.review-choice{background:#fffaf0;border-color:#efd082;box-shadow:0 14px 32px #c48c1d1f}.section-choice.review-choice .section-choice-head span{color:#9a6a0f}.section-choice.review-choice .primary-btn{background:#f0ad23;box-shadow:0 5px #b9780e}.section-choice-head{gap:6px;display:grid}.section-choice-head span{color:#148250;text-transform:uppercase;font-size:13px;font-weight:950}.section-choice-head strong{font-size:30px;line-height:1.05}.section-score{color:#5f6f65;align-content:center;justify-items:start;gap:4px;min-height:54px;font-weight:900;display:grid}.section-score small{color:#148250;font-size:12px;font-weight:950}.section-actions{margin-top:auto}.section-actions .primary-btn,.section-actions .secondary-btn{flex:180px}.step-kicker,.quiz-head{color:#57705c;text-transform:uppercase;font-size:13px;font-weight:950}.study-arabic-wrap{justify-items:center;gap:12px;display:grid}.study-arabic{text-align:center;color:#122015;place-items:center;min-height:112px;font-family:Noto Naskh Arabic,Scheherazade New,serif;line-height:1.5;display:grid}.study-arabic.word{font-size:clamp(54px,12vw,96px)}.study-arabic.sentence{font-size:clamp(30px,6vw,48px)}.study-uzbek{text-align:center;color:#1f3d2b;font-size:clamp(24px,4vw,38px);font-weight:950}.oral-card{gap:20px}.oral-prompt{background:#f5faf0;border:1px solid #dbe8d4;border-radius:22px;justify-items:center;gap:12px;padding:clamp(18px,4vw,30px);display:grid}.oral-arabic{text-align:center;color:#122015;place-items:center;min-height:116px;font-family:Noto Naskh Arabic,Scheherazade New,serif;line-height:1.5;display:grid}.oral-arabic.word{font-size:clamp(54px,12vw,96px)}.oral-arabic.sentence{font-size:clamp(30px,6vw,50px)}.oral-translation{text-align:center;color:#1f3d2b;font-size:clamp(20px,3vw,30px);font-weight:950}.oral-status{color:#57705c;text-align:center;background:#eef6e9;border-radius:18px;align-content:center;gap:4px;min-height:74px;padding:14px 16px;font-weight:950;display:grid}.oral-status small{color:#1d3124;font-family:Noto Naskh Arabic,Scheherazade New,serif;font-size:20px}.oral-status.good{color:#0f7e4d;background:#e2f8e9}.oral-status.bad{color:#b83232;background:#fdeaea}.oral-actions{justify-content:center;place-items:center;gap:12px;display:grid}.oral-actions .secondary-btn,.oral-actions .primary-btn{min-width:150px}.oral-mic-btn{width:82px;min-width:82px;min-height:82px;box-shadow:0 7px #b4d9c2}.study-progress{text-align:center;color:#6b7b70;font-weight:800}.study-controls{justify-content:space-between;gap:12px;display:flex}.quiz-head{justify-content:space-between;display:flex}.quiz-prompt-row{grid-template-columns:1fr;align-items:center;gap:10px;display:grid}.quiz-prompt-row.with-pronunciation{grid-template-columns:minmax(0,1fr) auto}.quiz-prompt-row .pronounce-btn{justify-self:end}.quiz-prompt{text-align:center;color:#17231b;place-items:center;min-height:96px;font-size:clamp(26px,5vw,42px);font-weight:950;line-height:1.35;display:grid}.quiz-prompt.arabic{font-family:Noto Naskh Arabic,Scheherazade New,serif;font-size:clamp(34px,6vw,54px);font-weight:800}.options-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.options-grid button,.token-bank button,.answer-line button{color:#1d3124;background:#fff;border:2px solid #d7e5d0;border-radius:16px;min-height:56px;padding:12px 14px;font-weight:900}.options-grid button{font-size:clamp(16px,2.4vw,24px)}.options-grid button.selected{background:#e9f8ef;border-color:#19a96b}.options-grid button.correct{color:#0d7548;background:#dff8e8;border-color:#19a96b}.options-grid button.wrong{color:#a92f2f;background:#fdeaea;border-color:#d95050}.answer-line,.token-bank{border-radius:18px;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;min-height:88px;padding:14px;display:flex}.answer-line{background:#f8fbf4;border:2px dashed #c9ddc2}.answer-line.rtl-line{direction:rtl;justify-content:center}.answer-line span{color:#809083;font-weight:800}.token-bank{background:#eef6e9}.feedback{border-radius:16px;align-items:center;gap:10px;padding:14px 16px;font-weight:950;display:flex}.feedback span{flex:auto;min-width:0}.feedback .pronounce-btn{flex:none}.feedback.good{color:#0f7e4d;background:#e2f8e9}.feedback.bad{color:#b83232;background:#fdeaea}.quiz-actions{justify-content:flex-end;min-height:48px;margin-bottom:4px;display:flex}.result-card{text-align:center}.result-card svg{color:#f0ad1f}.result-percent{color:#108052;background:#e6f7ed;border-radius:50%;place-items:center;width:138px;height:138px;margin:18px auto;font-size:40px;font-weight:950;display:grid}.result-card .star-rating{margin:4px 0 14px;display:flex}@media (width<=620px){.auth-shell,.result-shell,.lesson-shell,.app-shell{padding:12px 12px calc(86px + env(safe-area-inset-bottom,0px))}.auth-panel,.result-card{border-radius:20px;padding:22px}.form-grid,.options-grid,.section-grid{grid-template-columns:1fr}.topbar,.lesson-topbar{border-radius:18px;align-items:center}.profile strong{white-space:nowrap;text-overflow:ellipsis;max-width:calc(100vw - 150px);overflow:hidden}.level-node{width:76px}.topbar{padding:16px}.top-rating-btn span{display:none}.action-btn{min-height:42px;padding:0 10px;font-size:12px}.level-label{min-width:112px;max-width:150px}.star-rating.compact{gap:1px}.resume-panel,.resume-actions,.section-actions{flex-direction:column;align-items:stretch}.resume-panel{text-align:left}.resume-actions .primary-btn,.resume-actions .secondary-btn,.section-actions .primary-btn,.section-actions .secondary-btn{width:100%}.section-actions .primary-btn,.section-actions .secondary-btn{flex:none;min-height:52px}.study-controls{flex-direction:column}.quiz-prompt-row.with-pronunciation{grid-template-columns:1fr;justify-items:center}.quiz-prompt-row .pronounce-btn{justify-self:center}.feedback{flex-wrap:wrap}.primary-btn.compact,.secondary-btn{width:100%}.account-actions,.study-controls{flex-direction:column}.account-actions .action-btn{width:100%}.stats-grid{grid-template-columns:1fr}.leaderboard-row{grid-template-columns:28px 42px minmax(0,1fr)}.personal-rating-row{grid-template-columns:42px minmax(0,1fr)}.leaderboard-score{text-align:left;grid-column:3;justify-self:start}.personal-rating-row .leaderboard-score{grid-column:2}.leaderboard-score b,.leaderboard-score small{font-size:13px}.report-fab{left:12px;bottom:calc(8px + env(safe-area-inset-bottom,0px));max-width:calc(100vw - 24px)}.report-panel{padding:22px}}
