:root{--navy:#0B2A4A;--blue:#1E4D7B;--orange:#FF8A00;--bg:#F4F6F9;--text:#1F2937;--muted:#667085;--success:#16A34A;--error:#DC2626;--line:#d9e2ec;--white:#fff;--shadow:0 18px 45px rgba(11,42,74,.12);--r:8px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}.skip{position:absolute;left:-999px}.skip:focus{left:16px;top:10px;background:#fff;padding:10px;z-index:20}.site-header{position:sticky;top:0;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);z-index:10}.nav-wrap{max-width:1180px;margin:auto;display:flex;align-items:center;justify-content:space-between;padding:14px 20px}.logo{font-weight:800;color:var(--navy);font-size:1.08rem}.logo span{color:var(--orange)}.site-nav{display:flex;gap:20px;align-items:center}.site-nav a{color:var(--navy);font-weight:700;font-size:.95rem}.nav-cta,.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:11px 18px;border-radius:var(--r);background:var(--orange);color:#111;font-weight:800;border:0;cursor:pointer}.btn:hover{text-decoration:none;filter:brightness(.97)}.btn.secondary{background:var(--navy);color:#fff}.btn.ghost{background:#fff;color:var(--navy);border:1px solid var(--line)}.menu-btn{display:none;background:none;border:0}.menu-btn span{display:block;width:24px;height:2px;background:var(--navy);margin:5px}.hero{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:68px 20px 36px}.hero h1{font-size:clamp(2.2rem,5vw,4.8rem);line-height:1.02;margin:0 0 20px;color:var(--navy);letter-spacing:0}.hero p,.page-head p{font-size:1.18rem;color:var(--muted);max-width:720px}.hero picture{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);background:#fff}.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.section{max-width:1180px;margin:auto;padding:44px 20px}.page-head{max-width:1180px;margin:auto;padding:54px 20px 10px}.page-head.compact{padding-bottom:0}.page-head h1,.section h2,.article h1{color:var(--navy);line-height:1.1;margin:0 0 14px}.page-head h1{font-size:clamp(2rem,4vw,3.6rem)}.feature-grid,.cards,.lesson-grid,.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.feature,.card,.lesson-card,.post-card,.dashboard article,.panel,.game-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:0 8px 24px rgba(11,42,74,.06)}.feature h2,.card h3,.lesson-card h3{font-size:1.1rem;color:var(--navy);margin:.3rem 0}.icon-dot{display:block;width:12px;height:12px;border-radius:50%;background:var(--orange)}.split{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start}.level-row{display:flex;gap:10px;flex-wrap:wrap}.level-row a{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:10px 14px;font-weight:800}.six{grid-template-columns:repeat(3,1fr)}.content{background:#fff;border-radius:var(--r);padding:34px;margin-top:20px}.faq details{background:#fff;border:1px solid var(--line);padding:16px 18px;border-radius:var(--r);margin:10px 0}.faq summary{font-weight:800;color:var(--navy);cursor:pointer}.lesson-level{margin-bottom:42px}.lesson-grid{grid-template-columns:repeat(5,1fr)}.lesson-card span,.post-card span,.meta,.crumbs{color:var(--muted);font-size:.92rem}.typing-widget{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow)}.target-text{font-size:1.35rem;line-height:1.9;padding:18px;background:#f8fafc;border-radius:var(--r);min-height:120px}.target-text span{color:#9aa4b2}.target-text .ok{color:var(--success)}.target-text .bad{color:var(--error);background:#fee2e2}.target-text .cur{background:#fff1d6;text-decoration:underline}.typing-input{width:100%;min-height:130px;margin-top:14px;border:2px solid var(--line);border-radius:var(--r);padding:14px;font:inherit;font-size:1.1rem}.typing-input:focus,input:focus,textarea:focus,button:focus-visible,a:focus-visible{outline:3px solid rgba(255,138,0,.35);outline-offset:2px}.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:16px 0}.stats div{background:var(--bg);border-radius:var(--r);padding:12px;text-align:center}.stats b{display:block;color:var(--navy);font-size:1.35rem}.stats span{font-size:.82rem;color:var(--muted);font-weight:700}.meter{height:10px;background:#e5eaf0;border-radius:999px;margin:14px 0;overflow:hidden}.meter span{display:block;height:100%;width:0;background:var(--orange)}.result-card{border:1px solid var(--line);background:#f0fdf4;border-radius:var(--r);padding:16px;margin:12px 0}.test-controls{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.test-controls button{border:1px solid var(--line);background:#fff;border-radius:var(--r);padding:10px 14px;font-weight:800}.test-controls .active{background:var(--navy);color:#fff}.share-box{width:100%;min-height:54px;border:1px solid var(--line);border-radius:var(--r);padding:10px}.game-card{min-height:210px;color:#fff;background:linear-gradient(135deg,var(--navy),var(--blue));position:relative;overflow:hidden}.game-card h2{color:#fff}.game-card span{font-weight:900;color:#fff}.game-stage{position:relative;background:#09192b;border-radius:var(--r);overflow:hidden}.game-stage canvas{width:100%;height:auto;display:block}.game-stage input{position:absolute;left:16px;bottom:16px;width:min(320px,calc(100% - 32px));padding:12px;border-radius:var(--r);border:0}.game-hud{position:absolute;top:12px;left:12px;right:12px;display:flex;gap:10px;flex-wrap:wrap}.game-hud span{background:rgba(255,255,255,.9);border-radius:var(--r);padding:8px 10px;font-weight:800}.post-card{display:grid;grid-template-columns:180px 1fr;gap:18px}.post-card img,.article-img{border-radius:var(--r);background:#dbeafe}.article{max-width:820px;margin:0 auto;padding:44px 20px;background:#fff}.article h2{color:var(--navy);margin-top:32px}.article p{font-size:1.05rem}.auth{max-width:520px;margin:44px auto;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;box-shadow:var(--shadow)}label{display:block;font-weight:800;margin:14px 0 6px}input,textarea{width:100%;border:1px solid var(--line);border-radius:var(--r);padding:12px;font:inherit}.alert{background:#fee2e2;color:#991b1b;padding:10px;border-radius:var(--r)}.success{background:#dcfce7;color:#166534;padding:10px;border-radius:var(--r)}.dashboard{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.dashboard b{font-size:2rem;color:var(--navy)}.dashboard span{display:block;color:var(--muted);font-weight:800}.table-wrap{overflow-x:auto;background:#fff;border-radius:var(--r);border:1px solid var(--line)}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:12px;border-bottom:1px solid var(--line)}.site-footer{background:var(--navy);color:#dce7f3;margin-top:50px}.footer-grid{max-width:1180px;margin:auto;padding:42px 20px;display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:24px}.site-footer a{display:block;color:#fff;margin:7px 0}.site-footer h2{font-size:1rem;color:#fff}.credit{color:#fff;font-weight:900}.copyright{max-width:1180px;margin:auto;padding:16px 20px;border-top:1px solid rgba(255,255,255,.14)}@media(max-width:860px){.menu-btn{display:block}.site-nav{position:absolute;left:0;right:0;top:64px;background:#fff;border-bottom:1px solid var(--line);display:none;flex-direction:column;align-items:flex-start;padding:18px 20px}.site-nav.open{display:flex}.hero,.split{grid-template-columns:1fr}.hero{padding-top:38px}.feature-grid,.cards,.six,.blog-grid,.lesson-grid,.dashboard{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}.post-card{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr}.target-text{font-size:1.12rem}.actions .btn{width:100%}}
/* Typing tutor live guidance */
.typing-widget{overflow:hidden}
.target-text{display:block;width:100%;max-width:100%;white-space:normal;overflow-wrap:anywhere;word-break:break-word}
.target-text .char{display:inline;border-radius:4px}
.target-text .cur{text-decoration-thickness:3px;text-underline-offset:5px}
.typing-hint{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0}
.typing-hint div{background:#fff7ed;border:1px solid #fed7aa;border-radius:var(--r);padding:12px}
.typing-hint span{display:block;color:#9a3412;font-size:.78rem;font-weight:800;text-transform:uppercase}
.typing-hint strong{display:block;color:var(--navy);font-size:1.18rem;margin-top:2px}
.keyboard-guide{background:#f8fafc;border:1px solid var(--line);border-radius:var(--r);padding:12px;margin-bottom:14px;overflow-x:auto}
.key-row{display:flex;gap:7px;margin:6px 0;min-width:max-content}
.key{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;border-radius:7px;background:#fff;border:1px solid #cbd5e1;color:var(--navy);font-weight:800;text-transform:uppercase;box-shadow:0 2px 0 #cbd5e1}
.key-space{width:260px;text-transform:none}
.key.active{background:var(--orange);border-color:var(--orange);color:#111;box-shadow:0 0 0 4px rgba(255,138,0,.22)}
@media(max-width:860px){.typing-hint{grid-template-columns:repeat(2,1fr)}.target-text{padding:14px}.key{min-width:34px;height:34px}}
@media(max-width:520px){.typing-hint{grid-template-columns:1fr}.keyboard-guide{padding:10px}.key{min-width:30px;height:32px;font-size:.85rem}.typing-widget{padding:14px}.target-text{font-size:1rem;line-height:1.8}}

/* Five-minute lesson page layout */
.lesson-shell{max-width:1380px;margin:0 auto;padding:24px 28px 46px;display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,360px);gap:24px;align-items:start}.lesson-main{min-width:0}.lesson-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:28px}.lesson-title-row{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-top:10px}.lesson-title-row h1{font-size:clamp(2rem,4vw,3.4rem);line-height:1.05;margin:0 0 12px;color:var(--navy)}.lesson-title-row p{margin:0;color:var(--muted);font-size:1.08rem}.countdown-card{min-width:132px;background:var(--navy);color:#fff;border-radius:var(--r);padding:14px 16px;text-align:center}.countdown-card span{display:block;font-size:.78rem;font-weight:800;text-transform:uppercase;color:#bfdbfe}.countdown-card strong{display:block;font-size:1.7rem;line-height:1.1;margin-top:4px}.lesson-session{margin-top:24px;box-shadow:none;border-color:#dbe4ef;padding:20px}.lesson-session .target-text{font-size:28px;line-height:1.8;min-height:242px;max-height:242px;overflow:hidden;padding:24px;background:#f8fafc;border:1px solid #edf2f7}.lesson-session .target-text .char{color:#98a3b3}.lesson-session .target-text .ok{color:var(--success)}.lesson-session .target-text .bad{color:var(--error);background:#fee2e2}.lesson-session .target-text .cur{background:#ffedd5;color:var(--navy)}.lesson-session .target-text .faded{color:#c1c9d6}.lesson-session .typing-input{min-height:116px;font-size:1.15rem;margin-top:16px}.lesson-session .stats{grid-template-columns:repeat(5,1fr)}.save-note{margin:10px 0;color:var(--muted);font-weight:700}.lesson-actions{margin-top:10px}.lesson-sidebar{display:grid;gap:16px;position:sticky;top:90px;min-width:300px;max-width:360px}.side-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:0 8px 24px rgba(11,42,74,.06)}.side-card h2{font-size:1.15rem;color:var(--navy);margin:0 0 10px}.side-card ul{margin:0;padding-left:20px;color:var(--muted)}.side-card p{margin:.45rem 0;color:var(--muted)}.affiliate-card{background:#fff;border:1px solid #E5E7EB;border-radius:16px;padding:18px;box-shadow:0 8px 24px rgba(15,23,42,.06)}.affiliate-card img{width:100%;height:150px;object-fit:cover;border-radius:12px;margin-bottom:12px;display:block}.affiliate-card h3{font-size:18px;color:#0B2A4A;margin:0 0 8px;line-height:1.25}.affiliate-card p{font-size:14px;line-height:1.6;color:#4B5563;margin:0}.affiliate-card .affiliate-disclosure{font-size:12px;color:#6B7280;margin-top:10px}.affiliate-card .affiliate-button{display:inline-block;width:100%;text-align:center;background:#FF8A00;color:#0B2A4A;font-weight:700;padding:12px 14px;border-radius:10px;text-decoration:none;margin-top:12px}.affiliate-card .affiliate-button:hover{filter:brightness(.97);text-decoration:none}.ad-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#f8fafc;border:1px dashed #aab7c8;border-radius:var(--r);color:var(--muted);text-align:center}.ad-placeholder span{font-size:.78rem;text-transform:uppercase;font-weight:900;letter-spacing:.04em}.ad-placeholder strong{font-size:.95rem;color:#526071}.ad-300{width:300px;height:250px;margin:0 auto}.ad-below-result{min-height:96px;margin-top:24px}.lesson-modal{position:fixed;inset:0;background:rgba(11,42,74,.58);z-index:50;display:flex;align-items:center;justify-content:center;padding:20px}.lesson-modal[hidden]{display:none}.lesson-modal-panel{width:min(640px,100%);background:#fff;border-radius:var(--r);padding:28px;box-shadow:0 24px 70px rgba(0,0,0,.24)}.lesson-modal-panel h2{margin:0 0 18px;color:var(--navy);font-size:2rem}.modal-results{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.modal-results div{background:var(--bg);border-radius:var(--r);padding:14px}.modal-results span{display:block;color:var(--muted);font-size:.82rem;font-weight:800}.modal-results strong{display:block;color:var(--navy);font-size:1.35rem;margin-top:4px}.modal-actions{margin-top:18px}.modal-actions .btn{flex:1}.typing-widget.test .lesson-modal,.typing-widget.test+.lesson-modal{display:none}
@media(max-width:980px){.lesson-shell{grid-template-columns:1fr}.lesson-sidebar{position:static;grid-row:auto}.ad-300{width:100%;max-width:300px}.lesson-title-row{flex-direction:column}.countdown-card{width:100%;text-align:left}.lesson-session .stats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.lesson-shell{padding:18px 14px 36px}.lesson-card{padding:18px}.lesson-session{padding:14px}.lesson-session .target-text{font-size:20px;line-height:1.8;min-height:178px;max-height:178px;padding:16px}.lesson-session .typing-input{min-height:104px;font-size:1rem}.modal-results{grid-template-columns:repeat(2,1fr)}.modal-actions .btn{width:100%}.typing-hint{grid-template-columns:1fr}.keyboard-guide{max-width:100%}}
.ad-placeholder strong{max-width:260px;white-space:normal;overflow-wrap:anywhere;padding:0 10px}
.lesson-session .typing-hint{margin:14px 0}

/* Readability upgrade for lesson practice */
.lesson-session .target-text,.lesson-session .typing-input,.lesson-session .keyboard-guide{font-family:'Inter','Segoe UI',system-ui,sans-serif}
.lesson-session .target-text{font-size:34px;font-weight:500;letter-spacing:.03em;color:#6b7280;background:#fbfcfe}
.lesson-session .target-text .char{color:#64748b}
.lesson-session .target-text .ok{color:#15803d}
.lesson-session .target-text .bad{color:#b91c1c;background:#fee2e2}
.lesson-session .target-text .cur{background:#ffedd5;color:#0B2A4A}
.lesson-session .typing-input{font-size:22px;line-height:1.7;font-weight:500;letter-spacing:.02em;color:#111827}
.lesson-session .key{font-family:'Inter','Segoe UI',system-ui,sans-serif;font-weight:800;color:#334155}
@media(max-width:640px){.lesson-session .target-text{font-size:24px}.lesson-session .typing-input{font-size:19px}}















/* Keep the highlighted typing cursor visible while JS controls the preview scroll. */
.typing-widget.test .target-text{overflow-x:hidden!important;overflow-y:auto!important;scrollbar-width:none}
.typing-widget.test .target-text::-webkit-scrollbar{display:none}

/* Fast typing preview: show the active word and exact next character clearly. */
.target-text .current-word{background:#fff4e5;color:var(--navy)!important;border-radius:5px}
.target-text .ok.current-word{color:var(--success)!important}
.target-text .bad.current-word{background:#fee2e2!important;color:var(--error)!important}
.target-text .cur{background:#ff8a00!important;color:#0b2a4a!important;border-bottom:3px solid #0b2a4a!important;border-radius:3px;text-decoration:none!important}
.target-text .char.space.cur{border-bottom:none!important}
.target-text .faded{color:#aeb8c7!important;background:transparent!important;box-shadow:none!important}

/* Full-width keyboard layout for the typing test page */
.typing-widget.test .keyboard-guide{width:100%;overflow:hidden;background:#f8fafc;border-color:#d9e2ec}
.typing-widget.test .key-row{display:grid;gap:7px;width:100%;min-width:0;margin:7px 0}
.typing-widget.test .key-row-1{grid-template-columns:repeat(13,minmax(0,1fr)) 1.75fr}
.typing-widget.test .key-row-2{grid-template-columns:1.65fr repeat(13,minmax(0,1fr))}
.typing-widget.test .key-row-3{grid-template-columns:1.9fr repeat(11,minmax(0,1fr)) 1.8fr}
.typing-widget.test .key-row-4{grid-template-columns:2.25fr repeat(10,minmax(0,1fr)) 2.25fr}
.typing-widget.test .key-row-5{grid-template-columns:1fr 1fr 7fr 1fr 1fr}
.typing-widget.test .key{width:100%;min-width:0;height:40px;font-size:14px;text-transform:none}
.typing-widget.test .key span:last-child{text-transform:none}
.typing-widget.test .key-space{width:100%}
@media(max-width:640px){
  .typing-widget.test .keyboard-guide{overflow-x:auto}
  .typing-widget.test .key-row{min-width:720px}
  .typing-widget.test .key{height:38px;font-size:13px}
}
.typing-widget.test .target-text{
  min-height:136px;
  max-height:136px;
  overflow:hidden;
  font-size:18px;
  line-height:1.8;
  white-space:pre-wrap;
}
.typing-widget.test .target-text .char{white-space:pre-wrap}
.typing-widget.test .target-text .space{display:inline}
.typing-widget.test .typing-input{min-height:112px}
@media(max-width:640px){
  .typing-widget.test .target-text{min-height:124px;max-height:124px;font-size:16px;line-height:1.75}
}

.lesson-session .typing-input::placeholder{color:#9aa4b2;font-weight:700}
.lesson-top-stats{margin:16px 0 0}
.lesson-top-stats div{border:1px solid #edf2f7}
@media(min-width:981px){.lesson-top-stats{margin:14px 0 0}.lesson-top-stats div{padding:9px}.lesson-top-stats b{font-size:1.15rem}}
.lesson-inline-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px}
.lesson-inline-cards .side-card{box-shadow:none}
@media(max-width:760px){.lesson-inline-cards{grid-template-columns:1fr}}

/* Balanced lesson columns after removing ad placeholders */
.lesson-shell{align-items:stretch}
.lesson-main,.lesson-sidebar{height:100%}
.lesson-card,.lesson-sidebar{display:flex;flex-direction:column}
.lesson-card{min-height:100%}
.lesson-inline-cards{margin-top:auto;padding-top:16px}
.lesson-sidebar{position:static;max-width:none;min-width:0}
.lesson-sidebar .affiliate-card{flex:1;display:flex;flex-direction:column}
.lesson-sidebar .affiliate-card img{height:clamp(120px,14vw,170px)}
.lesson-sidebar .affiliate-card .affiliate-button{margin-top:auto}
@media(min-width:981px){.lesson-shell{grid-template-columns:minmax(0,1fr) minmax(300px,340px)}}
@media(max-width:980px){.lesson-main,.lesson-sidebar{height:auto}.lesson-card{min-height:0}.lesson-sidebar .affiliate-card{flex:none}}

/* Blog redesign */
.blog-hero{padding-bottom:18px}.blog-hero h1{max-width:820px}.blog-topic-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.blog-topic-strip span,.blog-badge{display:inline-block;background:#FFF4E5;color:#9A4D00;font-size:12px;font-weight:800;padding:5px 9px;border-radius:999px}.blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;align-items:stretch}.blog-card{background:#fff;border:1px solid #E5E7EB;border-radius:18px;overflow:hidden;box-shadow:0 8px 24px rgba(15,23,42,.06);display:flex;flex-direction:column;min-width:0}.blog-card img{width:100%;height:190px;object-fit:cover;display:block;background:#dbeafe}.blog-card-content{padding:18px;display:flex;flex-direction:column;flex:1}.blog-card-meta{font-size:13px;color:#6B7280;margin:0 0 8px}.blog-card h2{font-size:22px;line-height:1.25;color:#0B2A4A;margin:0 0 10px;letter-spacing:0}.blog-card h2 a{color:#0B2A4A}.blog-card p{font-size:15px;line-height:1.6;color:#4B5563;margin:0}.blog-card a.read-more{display:inline-flex;align-items:center;justify-content:center;width:max-content;min-height:40px;margin-top:auto;padding:9px 13px;border-radius:8px;color:#0B2A4A;background:#fff7ed;border:1px solid #fed7aa;font-weight:800;text-decoration:none}.blog-card a.read-more:hover{background:#ffedd5;text-decoration:none}.article-img{width:100%;max-height:430px;object-fit:cover;margin:18px 0 12px}
@media(max-width:1024px){.blog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.blog-grid{grid-template-columns:1fr;gap:18px}.blog-card img{height:180px}.blog-card h2{font-size:20px}}

/* Natural multi-line lesson wrapping */
.lesson-session .target-text{white-space:pre-wrap;overflow-wrap:normal;word-break:normal;text-align:left}
.lesson-session .target-text .char{white-space:pre-wrap}
.lesson-session .target-text .space{display:inline}



/* Complete typing games */
.game-page-head{padding-top:34px}.game-shell{padding-top:22px}.game-stage{border:1px solid rgba(11,42,74,.18);box-shadow:0 20px 55px rgba(11,42,74,.14);min-height:360px}.game-stage canvas{background:#09192b}.game-stage input{left:50%;bottom:18px;transform:translateX(-50%);width:min(520px,calc(100% - 32px));min-height:52px;border:2px solid rgba(255,255,255,.85);box-shadow:0 12px 30px rgba(0,0,0,.18);font-size:1.15rem;font-weight:800;text-align:center;color:var(--navy)}.game-stage input::placeholder{color:#6b7280}.game-hud{top:14px;left:14px;right:auto;max-width:calc(100% - 28px);z-index:2}.game-hud span{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.94);box-shadow:0 8px 18px rgba(0,0,0,.12);font-size:.95rem}.game-hud b{color:var(--navy);font-size:1.1rem}.game-target-panel{position:absolute;right:18px;bottom:18px;z-index:2;display:flex;align-items:center;gap:10px;max-width:calc(50% - 22px);min-height:52px;padding:10px 14px;border-radius:var(--r);background:rgba(255,255,255,.94);box-shadow:0 12px 30px rgba(0,0,0,.16);font-weight:900;color:var(--navy)}.game-target-panel span{font-size:.8rem;text-transform:uppercase;color:#667085}.game-target-panel b{font-size:1.4rem;color:#d63d4a}.game-actions{justify-content:center}.game-card.race{background:linear-gradient(135deg,#0b2a4a,#d97706)}.game-card.sky{background:linear-gradient(135deg,#075985,#38bdf8)}.game-card.space{background:linear-gradient(135deg,#0f172a,#7c3aed)}.game-card.matrix{background:linear-gradient(135deg,#052e16,#16a34a)}.game-card.balloon{background:linear-gradient(135deg,#7c2d12,#ef4444)}.game-card.letters{background:linear-gradient(135deg,#1e3a8a,#ff8a00)}
@media(max-width:760px){.game-page-head{padding-top:24px}.game-stage{min-height:270px;border-radius:8px}.game-stage canvas{min-height:330px;object-fit:cover}.game-hud{top:10px;left:10px;gap:6px}.game-hud span{padding:6px 8px;font-size:.78rem}.game-hud b{font-size:.92rem}.game-stage input{bottom:12px;width:calc(100% - 24px);min-height:50px;font-size:1rem}.game-target-panel{right:12px;bottom:72px;left:12px;max-width:none;justify-content:center;min-height:44px}.game-target-panel b{font-size:1.1rem}.game-actions .btn{width:100%}}

.game-target-panel{position:absolute!important;left:-9999px!important;right:auto!important;bottom:auto!important;width:1px!important;height:1px!important;overflow:hidden!important;padding:0!important;border:0!important;box-shadow:none!important}
@media(max-width:760px){.game-stage{min-height:0}.game-stage canvas{height:auto;min-height:0;object-fit:contain}.game-stage input{bottom:10px}}

@media(max-width:760px){.game-stage{background:#09192b;padding-bottom:12px}.game-stage canvas{height:280px;object-fit:fill}.game-stage input{position:static;transform:none;display:block;margin:10px auto 0;width:calc(100% - 24px)}}

@media(max-width:760px){.game-target-panel{position:static!important;left:auto!important;right:auto!important;bottom:auto!important;display:flex!important;width:calc(100% - 24px)!important;height:auto!important;min-height:50px!important;margin:10px auto 0!important;padding:10px 14px!important;overflow:visible!important;justify-content:center!important;background:rgba(255,255,255,.96)!important;box-shadow:0 10px 24px rgba(0,0,0,.16)!important}.game-target-panel b{font-size:1.2rem}}
.game-options{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.game-options span{font-weight:900;color:var(--navy);margin-right:4px}
.game-options button{border:1px solid var(--line);background:#fff;border-radius:var(--r);padding:10px 13px;font-weight:900;color:var(--navy);cursor:pointer}
.game-options button.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.game-options small{font-weight:800;opacity:.78;margin-left:4px}
.game-result-modal[hidden]{display:none}
.game-result-modal .modal-actions{display:grid;grid-template-columns:1.2fr 1fr .8fr;gap:10px}
.game-result-modal .modal-actions .btn{width:100%;min-width:0}
@media(max-width:640px){.game-result-modal .modal-actions{grid-template-columns:1fr}}

/* Game listing previews */
.game-list{align-items:stretch}
.game-list .game-card{display:flex;flex-direction:column;min-height:0;padding:0;background:#fff;color:var(--text);border:1px solid var(--line);box-shadow:0 12px 32px rgba(11,42,74,.08);transition:transform .18s ease,box-shadow .18s ease}
.game-list .game-card:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(11,42,74,.14);text-decoration:none}
.game-list .game-card img{display:block;width:100%;aspect-ratio:16/7.3;height:auto;object-fit:cover;border-radius:var(--r) var(--r) 0 0;background:#dbeafe}
.game-card-body{display:flex;flex:1;flex-direction:column;gap:10px;padding:18px;color:var(--text)}
.game-card-body strong{font-size:1.2rem;line-height:1.2;color:var(--navy)}
.game-card-body small{font-size:.95rem;line-height:1.55;color:var(--muted)}
.game-card-body em{margin-top:auto;font-style:normal;font-weight:900;color:var(--orange)}

/* Game round controls */
.game-shell > .game-options{margin-bottom:12px}
.game-shell > .game-hud{position:static;display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:10px;max-width:none;margin:0 0 14px;z-index:auto}
.game-shell > .game-hud span{display:flex;align-items:center;justify-content:center;gap:6px;min-height:48px;padding:10px 12px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 18px rgba(11,42,74,.08);border-radius:var(--r);font-size:.95rem;font-weight:900;white-space:nowrap}
.game-shell > .game-hud b{color:var(--navy);font-size:1.08rem;line-height:1}
@media(max-width:760px){.game-shell > .game-options{align-items:flex-start;margin-bottom:10px}.game-shell > .game-options span{flex-basis:100%}.game-shell > .game-hud{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}.game-shell > .game-hud span{min-height:44px;padding:8px 9px;font-size:.78rem}.game-shell > .game-hud b{font-size:.92rem}}

/* Game intro and benefits */
.game-intro{padding-top:0;padding-bottom:0}
.game-intro p{font-size:1.08rem;line-height:1.7;color:var(--muted);max-width:920px}
.game-benefits{padding-top:32px}
.game-benefits h2{text-align:center;margin-bottom:24px}
.benefit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.benefit-item{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;box-shadow:0 8px 24px rgba(11,42,74,.06)}
.benefit-item strong{display:block;font-size:1.05rem;color:var(--navy);margin-bottom:6px}
.benefit-item p{margin:0;font-size:.95rem;color:var(--muted);line-height:1.55}
@media(max-width:860px){.benefit-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.benefit-grid{grid-template-columns:1fr}}

/* Game FAQ accordion */
.game-faq details{background:#fff;border:1px solid var(--line);padding:16px 18px;border-radius:var(--r);margin:10px 0}
.game-faq summary{font-weight:800;color:var(--navy);cursor:pointer;font-size:1.05rem}
.game-faq details p{margin:10px 0 0;color:var(--muted);line-height:1.6}
.game-faq details[open] summary{margin-bottom:4px}

/* How to Play section */
.game-how-to-play{padding-top:28px}
.game-how-to-play h2{margin-bottom:16px}
.how-to-steps{margin:0;padding-left:0;list-style:none;counter-reset:step}
.how-to-steps li{counter-increment:step;display:flex;align-items:flex-start;gap:14px;padding:14px 18px;margin-bottom:10px;background:#fff;border:1px solid var(--line);border-radius:var(--r);font-size:1.02rem;line-height:1.55;color:var(--text)}
.how-to-steps li::before{content:counter(step);flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--orange);color:#111;font-weight:900;font-size:.95rem;border-radius:50%}

/* Skills badges */
.game-skills{padding-top:18px}
.game-skills h2{margin-bottom:14px}
.skill-badges{display:flex;flex-wrap:wrap;gap:10px}
.skill-badge{display:inline-block;background:#fff4e5;color:#9a4d00;font-size:.92rem;font-weight:800;padding:8px 16px;border-radius:999px;border:1px solid #fed7aa}

/* More typing games */
.game-more{padding-top:32px}
.game-more h2{margin-bottom:18px}
.game-more .cards.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.game-more .cards.three{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.game-more .cards.three{grid-template-columns:1fr}}

/* Larger full-width lesson keyboard */
.lesson-session .target-text{font-size:31px;line-height:1.8;min-height:268px;max-height:268px}
.lesson-session .keyboard-guide{padding:18px;width:100%;overflow:hidden;background:#d9dde2;border-color:#c7ccd3;border-radius:22px}
.lesson-session .key-row{display:grid;gap:7px;width:100%;min-width:0;margin:7px 0}
.lesson-session .key-row-1{grid-template-columns:repeat(13,minmax(0,1fr)) 1.75fr}
.lesson-session .key-row-2{grid-template-columns:1.65fr repeat(13,minmax(0,1fr))}
.lesson-session .key-row-3{grid-template-columns:1.9fr repeat(11,minmax(0,1fr)) 1.8fr}
.lesson-session .key-row-4{grid-template-columns:2.25fr repeat(10,minmax(0,1fr)) 2.25fr}
.lesson-session .key-row-5{grid-template-columns:1fr 1fr 7fr 1fr 1fr}
.lesson-session .key{position:relative;width:100%;min-width:0;height:52px;font-size:19px;border-radius:7px;background:#fff;border:1px solid #c8ced6;color:#374151;font-weight:800;text-transform:none;box-shadow:0 3px 0 #b9c0ca;display:flex;align-items:center;justify-content:center;flex-direction:column}
.lesson-session .key span:last-child{text-transform:none}
.lesson-session .key-alt{font-size:13px;line-height:1;color:#4b5563;margin-bottom:2px;font-weight:700}
.lesson-session .key.active{background:#d23f4a;border-color:#d23f4a;color:#fff;box-shadow:0 0 0 5px rgba(210,63,74,.24),0 3px 0 #9f2932}
.lesson-session .key.active .key-alt{color:#fff}
.lesson-session .key-space{font-size:18px}
@media(max-width:640px){.lesson-session .target-text{font-size:22px;line-height:1.8;min-height:198px;max-height:198px}.lesson-session .keyboard-guide{padding:12px;overflow-x:auto;border-radius:16px}.lesson-session .key-row{gap:6px;min-width:760px}.lesson-session .key{height:44px;font-size:16px}.lesson-session .key-alt{font-size:11px}}



/* Final lesson viewport fit: keep the typing area visible at 100% zoom */
@media(min-width:981px){
  .lesson-shell{max-width:1500px;padding:18px 24px 34px;grid-template-columns:minmax(0,1fr) minmax(300px,340px);gap:22px}
  .lesson-card{padding:22px}
  .lesson-title-row{align-items:center;margin-top:8px}
  .lesson-title-row h1{font-size:clamp(2.15rem,3vw,3rem);margin-bottom:8px}
  .lesson-title-row p{font-size:1rem}
  .countdown-card{min-width:118px;padding:10px 14px}
  .countdown-card strong{font-size:1.9rem}
  .lesson-session{margin-top:16px;padding:18px}
  .lesson-session .target-text{font-size:28px;line-height:1.55;min-height:230px;max-height:230px;padding:20px}
  .lesson-session .typing-input{min-height:92px;margin-top:14px;font-size:20px;line-height:1.55}
  .lesson-session .typing-hint{margin:12px 0}
  .lesson-session .keyboard-guide{margin:12px 0 0;padding:14px;border-radius:18px}
  .lesson-session .key-row{gap:6px;margin:6px 0}
  .lesson-session .key{height:44px;font-size:16px}
  .lesson-session .key-alt{font-size:11px}
  .lesson-session .stats{gap:8px;margin:12px 0}
  .lesson-session .stats div{padding:9px}
  .lesson-session .stats b{font-size:1.15rem}
}



/* Absolute final lesson preview sync: scrolls with the current typed index. */
.lesson-session .target-text,
.lesson-session .typing-input{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  font-family:'Inter','Segoe UI',system-ui,sans-serif!important;
  font-size:22px!important;
  line-height:1.65!important;
  font-weight:500!important;
  letter-spacing:.03em!important;
  word-spacing:.1em!important;
  white-space:pre-wrap!important;
  overflow-wrap:normal!important;
  word-break:normal!important;
  text-align:left!important;
}
.lesson-session .target-text{
  min-height:188px!important;
  max-height:188px!important;
  padding:18px!important;
  overflow-x:hidden!important;
  overflow-y:auto!important;
  scrollbar-width:auto!important;
  scroll-behavior:auto!important;
}
.lesson-session .target-text::-webkit-scrollbar{
  display:block!important;
  width:10px;
}
.lesson-session .target-text::-webkit-scrollbar-thumb{
  background:#9aa4b2;
  border-radius:999px;
}
.lesson-session .typing-input{
  min-height:188px!important;
  padding:18px!important;
}
@media(min-width:981px){
  .lesson-session .target-text,
  .lesson-session .typing-input{
    font-size:21px!important;
    line-height:1.6!important;
  }
  .lesson-session .target-text,
  .lesson-session .typing-input{
    min-height:178px!important;
  }
  .lesson-session .target-text{
    max-height:178px!important;
  }
}
@media(max-width:640px){
  .lesson-session .target-text,
  .lesson-session .typing-input{
    font-size:19px!important;
    line-height:1.65!important;
    padding:14px!important;
    min-height:160px!important;
  }
  .lesson-session .target-text{
    max-height:160px!important;
  }
}

/* Absolute final typing feedback colors: keep errors visible above normal char styling. */
.lesson-session .target-text .char.ok{
  color:#15803d!important;
  background:transparent!important;
}
.lesson-session .target-text .char.bad{
  color:#dc2626!important;
  background:#fee2e2!important;
}
.lesson-session .target-text .char.current-word:not(.ok):not(.bad){
  background:#fff4e5!important;
  color:#0b2a4a!important;
}
.lesson-session .target-text .char.cur{
  background:#ff8a00!important;
  color:#0b2a4a!important;
  border-bottom:3px solid #0b2a4a!important;
  border-radius:3px!important;
}

 / *   R T L   S u p p o r t   * / 
 [ d i r = " r t l " ]   {   t e x t - a l i g n :   r i g h t ;   } 
 [ d i r = " r t l " ]   . s i t e - n a v   {   m a r g i n - r i g h t :   a u t o ;   m a r g i n - l e f t :   0 ;   } 
 [ d i r = " r t l " ]   . h e r o   {   t e x t - a l i g n :   r i g h t ;   } 
 [ d i r = " r t l " ]   t h ,   [ d i r = " r t l " ]   t d   {   t e x t - a l i g n :   r i g h t ;   } 
 [ d i r = " r t l " ]   . g a m e - h u d   {   l e f t :   a u t o ;   r i g h t :   1 2 p x ;   } 
 [ d i r = " r t l " ]   . g a m e - t a r g e t - p a n e l   {   r i g h t :   a u t o ;   l e f t :   1 8 p x ;   } 
 
/* Premium Typing Feedback Overrides */
.target-text .char { display: inline-block; white-space: pre-wrap; transition: color 0.1s; }
.target-text .char.ok { color: #1a1a1a !important; background: transparent !important; }
.target-text .char.bad { color: #ba1a1a !important; background: #ffdad6 !important; border-radius: 2px; }
.target-text .char.current-word:not(.ok):not(.bad) { color: #1a1a1a !important; background: transparent !important; }
.target-text .char.cur { background: transparent !important; border-bottom: 2px solid #c48c5d !important; color: #1a1a1a !important; border-radius: 0 !important; box-shadow: none !important; }
.target-text .char.faded { color: #c4c7c7 !important; }