*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--yellow:#ffd94a;--orange:#ff8c42;--pink:#ff6b8a;--teal:#3bbfad;--purple:#8b5cf6;--green:#10b981;--jade:#2e9e6b;--navy:#1a2e4a;--cream:#fffbf0;--light:#f9f5ec;--gray:#6b7280;--border:#e9e3d5}html{scroll-behavior:smooth}body{background:var(--cream);color:var(--navy);font-family:Nunito,sans-serif;line-height:1.7}nav{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid var(--yellow);background:#fffbf0f2;justify-content:space-between;align-items:center;padding:.55rem 2.5rem;display:flex;position:sticky;top:0}.nav-logo{color:var(--orange);align-items:center;gap:.4rem;font-size:1.3rem;font-weight:900;text-decoration:none;display:flex}.nav-right{align-items:center;gap:1.5rem;display:flex}.nav-typing-link{color:var(--navy);border:1.5px solid var(--border);white-space:nowrap;border-radius:20px;padding:.3rem .75rem;font-size:.85rem;font-weight:800;text-decoration:none;transition:all .2s}.nav-typing-link:hover{border-color:var(--orange);color:var(--orange)}.nav-search{background:var(--light);border:2px solid var(--border);border-radius:50px;align-items:center;gap:.5rem;padding:.4rem 1rem;display:flex}.nav-search input{color:var(--navy);background:0 0;border:none;outline:none;width:180px;min-width:0;font-family:Nunito,sans-serif;font-size:.9rem}.nav-search input::placeholder{color:var(--gray)}.nav-search-icon{color:var(--gray);font-size:.9rem}.hero{min-height:var(--hero-h,640px);text-align:center;background:linear-gradient(135deg,#fff5c8 0%,#ffe4b5 50%,#ffd6b5 100%);flex-direction:column;justify-content:center;align-items:center;padding:5rem 2.5rem 4rem;display:flex;position:relative;overflow:hidden}.hero--img{background:0 0;min-height:0;padding:0;display:block}.hero-img{width:100%;height:auto;display:block}.hero--img.hero--fixed .hero-img{height:var(--hero-h);object-fit:cover}.hero--img .hero-content{flex-direction:column;justify-content:center;align-items:center;padding:2rem 1.5rem;display:flex;position:absolute;inset:0}.hero-eyebrow{background:var(--orange);color:#fff;letter-spacing:2px;text-transform:uppercase;border-radius:20px;margin-bottom:1.25rem;padding:.3rem 1rem;font-size:.75rem;font-weight:800;display:inline-block}.hero h1{color:var(--navy);margin-bottom:1rem;font-family:Lora,serif;font-size:clamp(2rem,5vw,3.4rem);font-weight:600;line-height:1.2}.hero h1 em{color:var(--orange);font-style:italic}.hero-sub{color:var(--gray);max-width:520px;margin:0 auto 2.5rem;font-size:1.05rem}.hero-stats{flex-wrap:wrap;justify-content:center;gap:3rem;display:flex}.stat-item{text-align:center}.stat-num{color:var(--navy);font-size:2rem;font-weight:900;line-height:1}.stat-label{color:var(--gray);margin-top:.2rem;font-size:.8rem}.featured{background:var(--navy);color:#fff;padding:0;display:grid;position:relative;overflow:hidden}.feat-slide{opacity:0;visibility:hidden;pointer-events:none;grid-area:1/1;grid-template-columns:1fr minmax(240px,38%);align-items:center;gap:2.5rem;padding:3rem 2.5rem;transition:opacity .5s,visibility .5s;display:grid}.feat-slide.active{opacity:1;visibility:visible;pointer-events:auto}.feat-nav{color:#fff;cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:background .2s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.feat-nav:hover{background:#ffffff4d}.feat-nav.prev{left:.75rem}.feat-nav.next{right:.75rem}.feat-dots{z-index:10;gap:.4rem;display:flex;position:absolute;bottom:.75rem;left:50%;transform:translate(-50%)}.feat-dot{cursor:pointer;background:#ffffff59;border:none;border-radius:50%;width:7px;height:7px;padding:0;transition:background .2s}.feat-dot.active{background:var(--yellow);border-radius:4px;width:20px}.featured-label{letter-spacing:2px;text-transform:uppercase;color:var(--yellow);margin-bottom:.75rem;font-size:.75rem;font-weight:800}.featured-title{margin-bottom:.5rem;font-family:Lora,serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:600;line-height:1.2}.featured-title em{color:var(--yellow);font-style:italic}.featured-author{color:#fff9;margin-bottom:1rem;font-size:.9rem}.featured-desc{color:#fffc;max-width:540px;margin-bottom:1.5rem;font-size:.95rem;line-height:1.7}.featured-btn{background:var(--yellow);color:var(--navy);border-radius:50px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9rem;font-weight:900;text-decoration:none;transition:transform .2s,opacity .2s;display:inline-flex}.featured-btn:hover{opacity:.9;transform:translateY(-2px)}.featured-visual{justify-content:center;align-items:flex-end;gap:.7rem;padding-bottom:.5rem;display:flex}.featured-book-mock{background:linear-gradient(145deg, var(--orange), var(--yellow));text-align:center;border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:148px;height:210px;padding:1.25rem 1rem;display:flex;transform:rotate(-3deg);box-shadow:-5px 10px 28px #00000073}.featured-book-mock-icon{margin-bottom:.5rem;font-size:2rem}.featured-book-mock-title{color:var(--navy);font-size:.85rem;font-weight:800;line-height:1.3}.featured-stars{color:var(--navy);margin-top:.5rem;font-size:1.1rem}.featured-cover-img{object-fit:cover;border-radius:10px;flex-shrink:0;width:auto;max-width:210px;height:290px;transform:rotate(-2.5deg);box-shadow:-5px 10px 28px #00000073}.featured-extra-img{object-fit:cover;border-radius:8px;flex-shrink:0;width:auto;max-width:210px;height:290px;transition:transform .25s;box-shadow:0 6px 20px #0006}.featured-extra-img:hover{transform:translateY(-6px)rotate(0)!important}.featured-extra-img:nth-child(2){transform:rotate(3deg)}.featured-extra-img:nth-child(3){transform:rotate(-2deg)}.featured-extra-img:nth-child(4){transform:rotate(2.5deg)}.cat-section{padding:3rem 2.5rem 0}.cat-section-inner{max-width:1100px;margin:0 auto}.type-tabs{border-bottom:2px solid var(--border);flex-wrap:wrap;gap:.6rem;margin-bottom:1.25rem;padding-bottom:1.25rem;display:flex}.type-tab{border:2px solid var(--border);color:var(--gray);cursor:pointer;background:#fff;border-radius:50px;align-items:center;gap:.45rem;padding:.65rem 1.5rem;font-family:Nunito,sans-serif;font-size:.95rem;font-weight:800;transition:all .2s;display:flex}.type-tab:hover{border-color:var(--navy);color:var(--navy)}.type-tab[data-type=all].active{background:var(--navy);border-color:var(--navy);color:#fff}.type-tab[data-type=sach].active{background:var(--orange);border-color:var(--orange);color:#fff}.type-tab[data-type=hoc-lieu].active{background:var(--jade);border-color:var(--jade);color:#fff}.type-tab .count{background:#ffffff40;border-radius:20px;padding:.1rem .55rem;font-size:.75rem;font-weight:900}.type-tab:not(.active) .count{background:var(--light);color:var(--gray)}.cat-tabs{flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem;display:flex}.cat-tab{border:2px solid var(--border);color:var(--gray);cursor:pointer;background:#fff;border-radius:50px;align-items:center;gap:.4rem;padding:.55rem 1.25rem;font-family:Nunito,sans-serif;font-size:.88rem;font-weight:700;transition:all .2s;display:flex}.cat-tab:hover{border-color:var(--orange);color:var(--orange)}.cat-tab.active{background:var(--navy);border-color:var(--navy);color:#fff}.cat-tab .count{color:inherit;background:#fff3;border-radius:20px;padding:.1rem .5rem;font-size:.75rem;font-weight:900}.cat-tab:not(.active) .count{background:var(--light);color:var(--gray)}.cat-section.mode-hoc-lieu .cat-tab.active{background:var(--jade);border-color:var(--jade)}.cat-section.mode-hoc-lieu .cat-tab:hover{border-color:var(--jade);color:var(--jade)}.section-wrap{padding:0 2.5rem 5rem}.section-inner{max-width:1100px;margin:0 auto}.books-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.75rem;display:grid}.no-results{text-align:center;color:var(--gray);padding:4rem 2rem;font-size:1rem}.book-card{background:#fff;border:2px solid #0000;border-radius:20px;flex-direction:column;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;overflow:hidden;box-shadow:0 2px 16px #00000012}.book-card:hover{border-color:var(--yellow);transform:translateY(-6px);box-shadow:0 12px 40px #00000021}.book-cover-wrap{justify-content:center;align-items:center;min-height:200px;padding:2rem 1.5rem 1.5rem;display:flex;position:relative}.book-mock{text-align:center;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;width:130px;height:170px;padding:1.25rem 1rem;display:flex;transform:rotate(-2deg);box-shadow:-5px 5px #0000001f}.book-mock-icon{margin-bottom:.5rem;font-size:2rem}.book-mock-title{color:#fff;font-size:.75rem;font-weight:800;line-height:1.3}.book-cover-img{border-radius:10px;width:130px;height:170px;transition:transform .3s;overflow:hidden;transform:rotate(-2deg);box-shadow:-5px 5px #0000001f}.book-card:hover .book-cover-img{transform:rotate(0)scale(1.04)}.book-cover-img img{object-fit:cover;width:100%;height:100%;display:block}.book-badge{letter-spacing:.5px;text-transform:uppercase;border-radius:20px;padding:.25rem .7rem;font-size:.68rem;font-weight:800;position:absolute;top:1rem;right:1rem}.badge-coming{background:var(--light);color:var(--gray);border:1px solid var(--border)}.badge-new{background:var(--pink);color:#fff}.badge-nen-doc{background:var(--teal);color:#fff}.badge-doc-nhieu{background:var(--orange);color:#fff}.badge-popular{background:var(--yellow);color:var(--navy)}.book-body{flex-direction:column;flex:1;padding:0 1.5rem 1.5rem;display:flex}.book-category{letter-spacing:1px;text-transform:uppercase;margin-top:.6rem;margin-bottom:.35rem;font-size:.72rem;font-weight:800}.book-title{margin-bottom:.25rem;font-family:Lora,serif;font-size:1rem;font-weight:600;line-height:1.35}.book-author{color:var(--gray);margin-bottom:.5rem;font-size:.82rem}.book-stars{color:var(--orange);margin-bottom:.5rem;font-size:.82rem}.book-stars span{color:var(--gray);margin-left:.3rem}.book-desc{color:var(--gray);flex:1;margin-bottom:1rem;font-size:.85rem;line-height:1.6}.book-actions{flex-wrap:wrap;gap:.5rem;margin-top:auto;display:flex}.hl-meta-row{flex-wrap:wrap;gap:.35rem;margin-bottom:.55rem;display:flex}.hl-meta-tag{color:var(--jade);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:20px;align-items:center;gap:.25rem;padding:.2rem .55rem;font-size:.72rem;font-weight:700;display:inline-flex}.btn-hoc-lieu{color:#fff;background:#16a34a;border-radius:50px;align-items:center;padding:.55rem 1.1rem;font-family:Nunito,sans-serif;font-size:.82rem;font-weight:800;text-decoration:none;transition:transform .2s,opacity .2s;display:inline-flex}.btn-hoc-lieu:hover{opacity:.88;transform:translateY(-2px)}.book-btn{border-radius:50px;align-items:center;padding:.55rem 1.1rem;font-family:Nunito,sans-serif;font-size:.82rem;font-weight:800;text-decoration:none;transition:transform .2s,opacity .2s;display:inline-flex}.book-btn:hover{opacity:.88;transform:translateY(-2px)}.btn-read{background:var(--navy);color:#fff}.btn-soon{background:var(--light);color:var(--gray);border:1px solid var(--border);cursor:default}.btn-preview{color:#fff;background:#52b788;border-radius:50px;align-items:center;gap:.3rem;padding:.55rem 1rem;font-family:Nunito,sans-serif;font-size:.82rem;font-weight:800;text-decoration:none;transition:transform .2s,opacity .2s;display:inline-flex}.btn-preview:hover{opacity:.88;transform:translateY(-2px)}.btn-buy{background:var(--orange);color:#fff;border-radius:50px;align-items:center;gap:.3rem;padding:.55rem 1rem;font-family:Nunito,sans-serif;font-size:.82rem;font-weight:800;text-decoration:none;transition:transform .2s,opacity .2s;display:inline-flex}.btn-buy:hover{opacity:.88;transform:translateY(-2px)}footer{background:var(--navy);color:#ffffff80;text-align:center;padding:2.5rem;font-size:.85rem;line-height:1.8}footer strong{color:var(--yellow)}.footer-brand{justify-content:center;align-items:center;gap:.5rem;margin-bottom:.3rem;font-size:1.1rem;font-weight:800;display:flex}.footer-brand-icon{font-size:1.5rem;line-height:1}@media (max-width:680px){nav{flex-wrap:wrap;gap:.6rem;padding:.6rem 1rem}.nav-logo{font-size:1.1rem}.nav-right{flex:auto;justify-content:flex-end;gap:.6rem;min-width:0}.nav-search{flex:auto;min-width:0;padding:.35rem .85rem}.nav-search input{width:100%}.hero:not(.hero--img){min-height:min(var(--hero-h,420px), 440px);padding:3rem 1.25rem 2.5rem}.hero-sub{margin-bottom:1.75rem;font-size:.98rem}.hero-stats{gap:1.5rem 2rem}.stat-num{font-size:1.6rem}.feat-slide{grid-template-columns:1fr;padding:2rem 1.5rem}.featured-visual,.feat-nav{display:none}.cat-section{padding:2rem 1.25rem 0}.section-wrap{padding:0 1.25rem 4rem}.books-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.type-tab{padding:.55rem 1.1rem;font-size:.85rem}.type-tabs,.cat-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;margin-left:-1.25rem;margin-right:-1.25rem;padding-left:1.25rem;padding-right:1.25rem;overflow-x:auto}.type-tabs::-webkit-scrollbar{display:none}.cat-tabs::-webkit-scrollbar{display:none}.type-tab,.cat-tab{white-space:nowrap;flex-shrink:0}}@media (max-width:430px){.nav-logo{font-size:1rem}.nav-typing-link{padding:.3rem .6rem;font-size:.8rem}.hero:not(.hero--img){min-height:min(var(--hero-h,340px), 360px);padding:2.5rem 1.1rem 2.25rem}.hero--img .hero-content{padding:1.25rem 1rem}.hero-eyebrow{margin-bottom:1rem;font-size:.68rem}.hero-stats{gap:1rem 1.5rem}.cat-section{padding:1.5rem 1rem 0}.section-wrap{padding:0 1rem 3rem}.books-grid{grid-template-columns:1fr;gap:1rem}.type-tabs,.cat-tabs{margin-left:-1rem;margin-right:-1rem;padding-left:1rem;padding-right:1rem}}.admin-wrap{max-width:1000px;margin:0 auto;padding:2rem 1.5rem 5rem}.admin-card{border:2px solid var(--border);background:#fff;border-radius:16px;margin-bottom:1.5rem;padding:1.5rem}.admin-table{border-collapse:collapse;width:100%;font-size:.9rem}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:.6rem .5rem}.admin-field{flex-direction:column;gap:.3rem;margin-bottom:1rem;display:flex}.admin-field label{font-size:.85rem;font-weight:700}.admin-field input,.admin-field textarea,.admin-field select{border:2px solid var(--border);background:#fff;border-radius:8px;padding:.5rem .7rem;font-family:Nunito,sans-serif;font-size:.9rem}.admin-btn{cursor:pointer;background:var(--navy);color:#fff;border:none;border-radius:50px;align-items:center;gap:.4rem;padding:.55rem 1.2rem;font-family:Nunito,sans-serif;font-size:.85rem;font-weight:800;text-decoration:none;display:inline-flex}.admin-btn.secondary{color:var(--navy);border:2px solid var(--border);background:#fff}.admin-btn.danger{background:var(--pink)}.admin-grid2{grid-template-columns:1fr 1fr;gap:0 1rem;display:grid}@media (max-width:640px){.admin-grid2{grid-template-columns:1fr}}.ty-page{background:var(--cream);flex-direction:column;min-height:100vh;font-family:Nunito,sans-serif;display:flex}.ty-nav{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:2px solid var(--border);background:#fdf8f2f2;align-items:center;gap:1rem;height:52px;padding:0 1.5rem;display:flex;position:sticky;top:0}.ty-nav-logo{color:var(--orange);font-size:1rem;font-weight:900;text-decoration:none}.ty-nav-title{color:var(--navy);font-size:.95rem;font-weight:800}.ty-nav-back{color:var(--gray);margin-left:auto;font-size:.82rem;font-weight:700;text-decoration:none}.ty-nav-back:hover{color:var(--orange)}.ty-layout{flex:1;display:flex;overflow:hidden}.ty-sidebar{border-right:1px solid var(--border);background:#fff;flex-direction:column;flex-shrink:0;gap:.35rem;width:240px;padding:1rem .75rem;display:flex;overflow-y:auto}.ty-sidebar-head{letter-spacing:2px;text-transform:uppercase;color:var(--gray);margin-bottom:.25rem;padding:0 .5rem;font-size:.7rem;font-weight:800}.ty-lesson-btn{text-align:left;cursor:pointer;background:0 0;border:1.5px solid #0000;border-radius:10px;flex-direction:column;gap:.2rem;width:100%;padding:.6rem .75rem;transition:all .15s;display:flex}.ty-lesson-btn:hover{background:var(--light);border-color:var(--border)}.ty-lesson-btn.active{border-color:var(--orange);background:#fff5eb}.ty-lesson-name{color:var(--navy);font-size:.85rem;font-weight:700;line-height:1.3}.ty-lesson-meta{color:var(--gray);font-size:.72rem}.ty-main{flex-direction:column;flex:1;gap:1.25rem;padding:1.5rem 2rem;display:flex;position:relative;overflow-y:auto}.ty-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.ty-title{color:var(--navy);margin-bottom:.4rem;font-size:1.25rem;font-weight:800}.ty-tags{flex-wrap:wrap;gap:.4rem;display:flex}.ty-tag{background:var(--light);color:var(--gray);border-radius:20px;padding:.2rem .6rem;font-size:.72rem;font-weight:700}.ty-stats{flex-wrap:wrap;gap:1rem;display:flex}.ty-stat{border:1px solid var(--border);text-align:center;background:#fff;border-radius:12px;min-width:80px;padding:.6rem 1rem}.ty-stat-val{color:var(--orange);font-size:1.4rem;font-weight:900;line-height:1;display:block}.ty-stat-label{color:var(--gray);margin-top:.2rem;font-size:.7rem;display:block}.ty-progress-bar{background:var(--border);border-radius:3px;height:6px;overflow:hidden}.ty-progress-fill{background:var(--teal);border-radius:3px;height:100%;transition:width .2s}.ty-desc{color:#1a3a5c;background:#edf6ff;border:1.5px solid #b6d8f7;border-radius:12px;padding:.75rem 1.25rem;font-size:.88rem;line-height:1.7}.ty-desc:before{content:"💡 "}.ty-richref{border:1.5px solid var(--border);color:var(--navy);background:#fffbf5;border-radius:14px;margin-bottom:0;padding:1rem 1.5rem;font-size:1rem;line-height:1.9}.ty-richref b,.ty-richref strong{font-weight:800}.ty-richref i,.ty-richref em{font-style:italic}.ty-richref u{text-decoration:underline}.ty-richref font[size="1"]{font-size:.72em}.ty-richref font[size="2"]{font-size:.875em}.ty-richref font[size="3"]{font-size:1em}.ty-richref font[size="4"]{font-size:1.25em}.ty-richref font[size="5"]{font-size:1.55em;font-weight:700}.ty-richref font[size="6"]{font-size:2em;font-weight:800}.ty-target{border:1px solid var(--border);letter-spacing:.02em;cursor:text;-webkit-user-select:none;user-select:none;background:#fff;border-radius:14px;padding:1.25rem 1.5rem;font-family:Courier New,Courier,monospace;font-size:1.05rem;line-height:1.9}.ty-char{position:relative}.ty-correct{color:var(--teal)}.ty-wrong{color:#fff;background:#e76f51;border-radius:2px}.ty-cursor{border-left:2px solid var(--orange);animation:1s step-end infinite ty-blink}@keyframes ty-blink{50%{opacity:0}}.ty-hidden-input{opacity:0;resize:none;border:none;width:1px;height:1px;padding:0;position:fixed;top:-9999px;left:-9999px;overflow:hidden}.ty-typed-area{border:2px solid var(--border);cursor:text;word-break:break-all;background:#fff;border-radius:14px;width:100%;min-height:52px;padding:.9rem 1.25rem;font-family:Courier New,Courier,monospace;font-size:1rem;line-height:1.7;transition:border-color .2s}.ty-typed-area:hover{border-color:var(--orange-light,#ffc89a)}.ty-typed-area.done{background:#f6fdf7;border-color:#52b788}.ty-typed-hint{color:#aaa;font-family:inherit;font-size:.9rem;font-style:italic}.ty-composing{border-bottom:2.5px solid var(--orange);color:#888}.ty-typed-caret{background:var(--orange);vertical-align:text-bottom;width:2px;height:1.15em;margin-left:1px;animation:1s step-end infinite ty-blink;display:inline-block}.ty-header-btns{flex-wrap:wrap;gap:.5rem;display:flex}.ty-btn-reset,.ty-btn-kbd{border:1.5px solid var(--border);color:var(--gray);cursor:pointer;white-space:nowrap;background:0 0;border-radius:20px;padding:.4rem 1rem;font-size:.8rem;font-weight:700;transition:all .15s}.ty-btn-reset:hover{border-color:var(--orange);color:var(--orange)}.ty-btn-kbd:hover,.ty-btn-kbd.active{border-color:var(--teal);color:var(--teal)}.ty-done{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10;background:#fdf8f2eb;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.ty-done-box{border:2px solid var(--orange);text-align:center;background:#fff;border-radius:20px;padding:2.5rem 3rem;box-shadow:0 8px 40px #0000001f}.ty-done-emoji{margin-bottom:.5rem;font-size:3rem}.ty-done-title{color:var(--navy);margin-bottom:1.25rem;font-size:1.6rem;font-weight:900}.ty-done-stats{color:var(--gray);justify-content:center;gap:2rem;margin-bottom:1.5rem;font-size:1rem;display:flex}.ty-done-stats strong{color:var(--orange);font-size:1.4rem;font-weight:900;display:block}.ty-btn-retry{background:var(--orange);color:#fff;cursor:pointer;border:none;border-radius:30px;padding:.7rem 2rem;font-size:1rem;font-weight:800;transition:opacity .2s}.ty-btn-retry:hover{opacity:.85}.ty-empty{color:var(--gray);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;display:flex}.ty-btn-back{background:var(--orange);color:#fff;border-radius:30px;padding:.6rem 1.5rem;font-size:.9rem;font-weight:800;text-decoration:none}@media (max-width:640px){.ty-layout{flex-direction:column}.ty-sidebar{border-right:none;border-bottom:1px solid var(--border);flex-flow:row;gap:.4rem;width:100%;padding:.5rem;overflow-x:auto}.ty-sidebar-head{display:none}.ty-lesson-btn{flex-shrink:0;min-width:140px}.ty-main{padding:1rem}.ty-target{font-size:.95rem}}.vkb-wrap{border:1px solid var(--border);background:#f7f3ec;border-radius:18px;flex-direction:column;gap:.85rem;padding:1rem 1.25rem 1.25rem;display:flex;overflow-x:auto}.vkb-top-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.vkb-hint-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.vkb-hint-label{color:var(--gray);font-size:.78rem;font-weight:700}.vkb-hint-char{color:var(--navy);text-align:center;min-width:1.5rem;font-size:1.5rem;font-weight:900;line-height:1}.vkb-hint-telex{color:var(--orange);border:2px solid var(--orange);letter-spacing:.15em;background:#fff;border-radius:8px;padding:.15rem .6rem;font-family:Courier New,monospace;font-size:1.05rem;font-weight:900}.vkb-hint-both{color:var(--gray);gap:.75rem;font-family:Courier New,monospace;font-size:.8rem;display:flex}.vkb-hint-both b{color:var(--navy);margin-right:.25rem;font-family:Nunito,sans-serif}.vkb-home-hint{color:var(--gray);font-size:.78rem;font-weight:600}.vkb-method-toggle{border:2px solid var(--border);border-radius:20px;flex-shrink:0;display:flex;overflow:hidden}.vkb-method-btn{color:var(--gray);cursor:pointer;background:0 0;border:none;padding:.3rem .9rem;font-size:.8rem;font-weight:800;transition:all .15s}.vkb-method-btn.active{background:var(--orange);color:#fff}.vkb-keyboard{flex-direction:column;gap:5px;min-width:680px;display:flex}.vkb-row{gap:5px;width:100%;display:flex}.vkb-key{cursor:default;-webkit-user-select:none;user-select:none;white-space:nowrap;border:2px solid #d4ccc0;border-radius:8px;flex:1;justify-content:center;align-items:center;min-width:0;height:44px;font-size:.82rem;font-weight:800;transition:background .12s,border-color .12s,box-shadow .12s,transform .12s;display:flex;position:relative;overflow:hidden;box-shadow:0 3px #c0b8b0}.vkb-key-label{font-size:.78rem;font-weight:800}.vkb-key-special{font-size:.68rem;font-weight:700}.vkb-key-active{animation:.75s ease-in-out infinite vkb-pulse;transform:translateY(2px)!important;box-shadow:0 1px #00000026!important}@keyframes vkb-pulse{0%,to{opacity:1}50%{opacity:.7}}.vkb-home-dot{opacity:.5;background:#999;border-radius:50%;width:5px;height:5px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.vkb-key-order{opacity:.85;font-size:.58rem;font-weight:900;line-height:1;position:absolute;top:2px;right:3px}.vkb-legend{flex-wrap:wrap;gap:.35rem .9rem;display:flex}.vkb-legend-item{align-items:center;gap:.3rem;display:flex}.vkb-legend-dot{border-radius:50%;flex-shrink:0;width:11px;height:11px}.vkb-legend-text{color:var(--gray);font-size:.68rem}
