:root{--c-bg:#FDF6E3;--c-bg-2:#FFF1E1;--c-surface:#ffffff;--c-ink:#1B1530;--c-ink-2:#3A3155;--c-muted:#7A6F8E;--c-line:rgba(27,21,48,.08);--c-line-strong:rgba(27,21,48,.14);--c-purple:#6D28D9;--c-purple-d:#4C1D95;--c-pink:#EC4899;--c-coral:#F97316;--c-amber:#F5B82A;--c-mint:#10B981;--c-sky:#0EA5E9;--c-violet:#8B5CF6;--c-rose:#FB7185;--grad-brand:linear-gradient(135deg,#FF6B6B 0%,#F97316 18%,#F5B82A 35%,#10B981 55%,#0EA5E9 75%,#8B5CF6 100%);--grad-soft:linear-gradient(135deg,#FFE4D6 0%,#FFE7F1 35%,#E8DCFF 70%,#D6E9FF 100%);--grad-warm:linear-gradient(135deg,#FFB37A 0%,#FF7BAF 50%,#9F70F2 100%);--grad-cta:linear-gradient(135deg,#A3E635 0%,#22C55E 55%,#16A34A 100%);--grad-card:linear-gradient(180deg,#ffffff 0%,#FDF6E3 100%);--r-xs:8px;--r-sm:12px;--r-md:18px;--r-lg:24px;--r-xl:32px;--r-2xl:42px;--shadow-sm:0 2px 6px rgba(27,21,48,.06),0 1px 2px rgba(27,21,48,.04);--shadow-md:0 12px 32px -12px rgba(27,21,48,.18),0 4px 12px -6px rgba(27,21,48,.08);--shadow-lg:0 30px 60px -20px rgba(27,21,48,.25),0 10px 24px -10px rgba(27,21,48,.12);--shadow-glow:0 20px 60px -10px rgba(141,87,235,.35);--shadow-glow-green:0 20px 60px -10px rgba(34,197,94,.40);--t-fast:160ms cubic-bezier(.4,.1,.2,1);--t-base:280ms cubic-bezier(.34,.07,.16,1);--t-slow:520ms cubic-bezier(.22,.08,.18,1);--font-display:'Fraunces','Times New Roman',serif;--font-body:'Inter','Segoe UI',system-ui,sans-serif;--font-mono:'JetBrains Mono',ui-monospace,monospace}*,::after,::before{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--c-ink);background:var(--c-bg);background-image:radial-gradient(1100px 600px at 12% -10%,rgba(236,72,153,.1),transparent 60%),radial-gradient(900px 500px at 110% 5%,rgba(109,40,217,.1),transparent 55%),radial-gradient(800px 600px at 50% 110%,rgba(245,184,42,.08),transparent 60%);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}img{max-width:100%;display:block}button{font:inherit;color:inherit;cursor:pointer;border:none;background:0 0}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--c-purple);outline-offset:3px;border-radius:6px}input,select,textarea{font:inherit;color:inherit}a{color:var(--c-purple);text-decoration:none}a:hover{text-decoration:underline}::selection{background:rgba(236,72,153,.25);color:var(--c-purple-d)}.container{width:100%;max-width:1180px;margin:0 auto;padding:0 24px}.h-display{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.05}.h-body{font-family:var(--font-body)}.muted{color:var(--c-muted)}.es{font-style:italic;color:var(--c-purple-d)}.topbar{position:sticky;top:0;z-index:80;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);background:rgba(255,248,240,.78);border-bottom:1px solid var(--c-line);transition:box-shadow var(--t-base)}.topbar.scrolled{box-shadow:0 6px 18px -10px rgba(27,21,48,.12)}.topbar-inner{display:flex;align-items:center;gap:18px;height:68px}.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:-.01em;white-space:nowrap;flex-shrink:0}.brand img{width:42px;height:42px;border-radius:50%;box-shadow:var(--shadow-sm);flex-shrink:0}.brand .b-tag{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);font-family:var(--font-body);margin-left:2px}@media(max-width:480px){.brand{font-size:18px;gap:8px}.brand img{width:36px;height:36px}.brand .b-tag{display:none}.nav-progress{padding:4px 10px;font-size:12px}.nav-progress .ring{width:26px;height:26px}.nav-progress>div:last-child{display:none}}.nav-spacer{flex:1}.nav-links{gap:6px}.nav-links a{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;color:var(--c-ink-2);font-weight:500;font-size:14px;transition:background var(--t-fast),color var(--t-fast)}.nav-links a:hover{background:rgba(109,40,217,.08);color:var(--c-purple-d);text-decoration:none}.nav-links a.current{background:rgba(109,40,217,.1);color:var(--c-purple-d);font-weight:600}.nav-progress{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 14px;background:rgba(255,255,255,.7);border:1px solid var(--c-line);border-radius:999px;font-size:13px;font-weight:600}.nav-progress .ring{width:30px;height:30px;border-radius:50%;background:conic-gradient(var(--c-purple) 0,var(--c-line) 0);position:relative;display:grid;place-items:center}.nav-progress .ring::after{content:"";position:absolute;inset:4px;background:#fffcef;border-radius:50%}.nav-progress .ring span{position:relative;z-index:1;font-size:10px;font-weight:700;color:var(--c-purple-d)}.nav-progress .lbl{color:var(--c-muted);font-weight:500}.menu-btn{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;background:#fffcef;border:1px solid var(--c-line);color:var(--c-ink)}.nav-links{display:none}.hero{position:relative;padding:96px 0 72px;isolation:isolate;overflow:hidden}.hero::before{content:"";position:absolute;inset:-10% -10% auto -10%;height:120%;background:radial-gradient(closest-side at 80% 20%,rgba(255,123,175,.3),transparent 70%),radial-gradient(closest-side at 15% 75%,rgba(141,112,242,.25),transparent 70%),radial-gradient(closest-side at 60% 90%,rgba(245,184,42,.22),transparent 70%);z-index:-1;filter:blur(2px)}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}@media(max-width:880px){.hero-grid{grid-template-columns:1fr;gap:32px}.hero{padding:56px 0 48px}}.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 14px 7px 8px;border-radius:999px;background:rgba(255,255,255,.75);border:1px solid var(--c-line);font-size:13px;font-weight:600;color:var(--c-purple-d);box-shadow:var(--shadow-sm)}.hero-eyebrow .dot{width:22px;height:22px;border-radius:50%;background:var(--grad-brand);box-shadow:0 0 0 4px rgba(255,255,255,.7) inset}.hero h1{font-family:var(--font-display);font-size:clamp(40px,7vw,80px);font-weight:800;line-height:1;margin:18px 0;letter-spacing:-.025em}.hero h1 .accent{font-style:italic;font-weight:700;color:var(--c-ink)}.hero p.lead{font-size:19px;line-height:1.55;color:var(--c-ink-2);max-width:560px;margin:0 0 28px}.hero-cta{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border-radius:999px;font-weight:600;font-size:15px;transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);cursor:pointer;will-change:transform}.btn-primary{background:var(--grad-cta);color:#fff;box-shadow:var(--shadow-glow-green);font-weight:700}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow-green);text-decoration:none}.btn-secondary{background:#fffcef;color:var(--c-ink);border:1px solid var(--c-line-strong)}.btn-secondary:hover{background:#fffcef;border-color:var(--c-purple);color:var(--c-purple-d);text-decoration:none}.btn-gradient{background:var(--grad-cta);color:#fff;box-shadow:var(--shadow-glow-green);font-weight:700;position:relative;overflow:hidden}.btn-gradient::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.3) 50%,transparent 70%);background-size:200% 100%;background-position:200% 0;transition:background-position .8s;pointer-events:none}.btn-gradient:hover::after{background-position:-200% 0}.btn-gradient:hover{transform:translateY(-2px);text-decoration:none}.btn-xl{padding:26px 52px;font-size:22px;gap:14px;border-radius:999px;font-weight:800;letter-spacing:-.005em}.btn-xl i{font-size:18px}.btn-large{padding:20px 36px;font-size:18px;gap:12px;font-weight:700}@keyframes btn-attention{0%,100%,70%{transform:translateY(0) rotate(0);box-shadow:var(--shadow-glow-green)}74%{transform:translateY(-4px) rotate(-2deg);box-shadow:0 30px 80px -10px rgba(34,197,94,.55)}78%{transform:translateY(-3px) rotate(2deg)}82%{transform:translateY(-2px) rotate(-2deg)}86%{transform:translateY(-1px) rotate(1deg)}90%{transform:translateY(0) rotate(0)}}.btn-attention{animation:4s ease-in-out infinite btn-attention}.btn-attention:hover{animation-play-state:paused}.hero-stats{display:flex;gap:28px;margin-top:34px;flex-wrap:wrap}.hero-stat .num{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--c-purple-d);line-height:1}.hero-stat .lbl{font-size:13px;color:var(--c-muted);margin-top:4px;font-weight:500}.hero-art{position:relative;display:grid;place-items:center;aspect-ratio:1/1;max-width:480px;justify-self:center;width:100%}.hero-art .ring-bg{position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 220deg,#ff6b6b,#f97316,#f5b82a,#10b981,#0ea5e9,#8b5cf6,#ec4899,#ff6b6b);filter:blur(40px) saturate(110%);opacity:.55;animation:18s linear infinite spin}.hero-art .logo-card{position:relative;width:62%;aspect-ratio:1/1;background:#fffcef;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-lg);animation:6s ease-in-out infinite float}.hero-art .logo-card img{width:80%;height:80%;object-fit:contain}.hero-art .float-chip{position:absolute;background:#fffcef;padding:10px 16px;border-radius:999px;box-shadow:var(--shadow-md);font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;animation:5s ease-in-out infinite float}.hero-art .float-chip i{color:var(--c-pink)}.hero-art .chip-1{top:8%;left:0;animation-delay:.2s}.hero-art .chip-2{top:32%;right:-2%;animation-delay:1.1s}.hero-art .chip-3{bottom:14%;left:-4%;animation-delay:.6s}.hero-art .chip-4{bottom:0;right:6%;animation-delay:1.7s}@keyframes spin{to{transform:rotate(360deg)}}@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:0 50%}100%{background-position:200% 50%}}@keyframes pop{0%{transform:scale(.94);opacity:0}100%{transform:scale(1);opacity:1}}@keyframes pulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(236,72,153,.45)}50%{transform:scale(1.04);box-shadow:0 0 0 14px rgba(236,72,153,0)}}.section{padding:88px 0;position:relative}@media(max-width:880px){.section{padding:44px 0}}.section-narrow{max-width:880px;margin:0 auto}.section-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-purple-d)}.section-eyebrow::before{content:"";width:24px;height:2px;background:var(--c-purple);border-radius:2px}.section h2{font-family:var(--font-display);font-size:clamp(30px,4.5vw,52px);font-weight:700;letter-spacing:-.02em;line-height:1.05;margin:14px 0 16px}.section h2 em{font-style:italic;color:var(--c-ink);font-weight:700}.section .sub{font-size:18px;color:var(--c-ink-2);max-width:640px;margin:0 0 40px}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.mod-card{position:relative;background:var(--grad-card);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:24px;transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);display:flex;flex-direction:column;gap:14px;overflow:hidden;cursor:pointer}.mod-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--grad,var(--grad-brand));opacity:.85}.mod-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--c-line-strong)}.mod-card .mod-num{font-family:var(--font-display);font-size:42px;font-weight:700;font-style:italic;background:linear-gradient(135deg,#8b5cf6,#6d28d9);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;display:inline-block;padding-right:.12em}.mod-card h3{font-family:var(--font-display);font-size:22px;font-weight:600;margin:0;line-height:1.2}.mod-card p{margin:0;color:var(--c-muted);font-size:14px;line-height:1.5}.mod-card .mod-meta{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:10px;border-top:1px dashed var(--c-line)}.mod-card .mod-meta .tag{font-size:12px;font-weight:600;color:var(--c-purple-d)}.mod-card .mod-status{font-size:12px;color:var(--c-muted);display:flex;align-items:center;gap:6px}.mod-card .mod-status i{color:var(--c-mint)}.mod-card.is-done{border-color:rgba(16,185,129,.4)}.mod-card.is-done::after{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;top:14px;right:14px;width:28px;height:28px;background:var(--c-mint);color:#fff;border-radius:50%;display:grid;place-items:center;font-size:13px}.module{scroll-margin-top:96px;padding-top:64px;padding-bottom:64px;position:relative}.module+.module{border-top:1px dashed var(--c-line)}.module-header{display:flex;flex-wrap:wrap;align-items:flex-end;gap:24px;margin-bottom:36px}.module-header .m-num{font-family:var(--font-display);font-style:italic;font-weight:800;font-size:120px;line-height:.85;background:linear-gradient(135deg,#8b5cf6,#6d28d9);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;padding:.05em .18em .08em 0;overflow:visible}.module-header .m-title{flex:1;min-width:260px}.module-header h2{margin:0 0 8px;font-family:var(--font-display);font-size:clamp(28px,4vw,44px);font-weight:700;letter-spacing:-.02em;line-height:1.05}.module-header h2 .es-sub{display:block;font-style:italic;font-weight:500;color:var(--c-purple-d);font-size:.55em;margin-top:6px}.module-header p{margin:0;color:var(--c-ink-2);max-width:620px}.lesson-block{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:28px;margin:18px 0;box-shadow:var(--shadow-sm)}.lesson-block .lb-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}.lesson-block .lb-head .icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(109,40,217,.08);color:var(--c-purple-d);font-size:18px}.lesson-block .lb-head h3{font-family:var(--font-display);font-size:22px;font-weight:600;margin:0;letter-spacing:-.01em}.lesson-block .lb-head .badge{margin-left:auto;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--c-muted);background:var(--c-bg-2);padding:4px 10px;border-radius:999px}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}@media(max-width:560px){.container{padding:0 16px}.lesson-block{padding:18px}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.flip-card{aspect-ratio:5/3.8}.flip-card .face{padding:42px 10px 10px!important}.flip-card .face .es{font-size:21px!important;line-height:1.2}.flip-card .face .hint{display:none}.flip-card .face.back .ru{font-size:19px!important;line-height:1.2}.flip-card .face.back .es{font-size:14px!important;margin-top:4px;line-height:1.2}.speak-btn{width:26px;height:26px;font-size:11px;top:5px;right:5px}}.flip-card{perspective:1000px;aspect-ratio:5/3;cursor:pointer;position:relative}.flip-card .face-wrap{position:relative;width:100%;height:100%;transition:transform var(--t-slow);transform-style:preserve-3d}.flip-card.is-flipped .face-wrap{transform:rotateY(180deg)}.flip-card .face{position:absolute;inset:0;border-radius:var(--r-md);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 14px 14px;text-align:center;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:1px solid var(--c-line);background:#fffcef;transition:border-color var(--t-fast),box-shadow var(--t-fast)}.flip-card:hover .face{border-color:var(--c-purple);box-shadow:var(--shadow-md)}.flip-card .face .es{font-family:var(--font-display);font-style:italic;font-weight:600;font-size:clamp(24px,3.4vw,30px);color:var(--c-purple-d);line-height:1.2;word-break:break-word}.flip-card .face .ru{font-size:17px;font-weight:500;color:var(--c-ink-2);line-height:1.3;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word;word-break:normal}.flip-card .face .hint{margin-top:8px;font-size:11px;color:var(--c-muted);letter-spacing:.05em;text-transform:uppercase}.flip-card .face.back{transform:rotateY(180deg);background:linear-gradient(135deg,#ffe7f1 0,#e8dcff 100%)}.flip-card .face.back .ru{font-family:var(--font-display);font-size:clamp(22px,3.1vw,28px);font-weight:600;color:var(--c-ink);line-height:1.2;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word;word-break:normal}.flip-card .face.back .es{margin-top:6px;font-size:16px;color:var(--c-purple-d);font-weight:500;line-height:1.2}.cards-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;font-size:13px;color:var(--c-muted)}.cards-toolbar .actions{display:flex;gap:8px}.btn-mini{padding:8px 14px;border-radius:999px;background:var(--c-bg-2);font-size:13px;font-weight:600;color:var(--c-ink-2);border:1px solid var(--c-line)}.btn-mini:hover{background:#fffcef;color:var(--c-purple-d);border-color:var(--c-purple)}.btn-mini i{margin-right:6px}.vocab-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:0;border-top:1px dashed var(--c-line)}.vocab-list .row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:14px 4px;border-bottom:1px dashed var(--c-line)}.vocab-list .row .es{font-family:var(--font-display);font-style:italic;font-weight:600;font-size:21px;color:var(--c-purple-d)}.vocab-list .row .ru{font-size:19px;color:var(--c-ink-2);text-align:right}.dialogue{background:linear-gradient(180deg,#fff,#fff6fa);border:1px solid var(--c-line);border-radius:var(--r-md);padding:18px 20px;display:grid;gap:10px}.bubble{display:flex;gap:10px;align-items:flex-start;animation:pop var(--t-base) both}.bubble .av{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-weight:700;font-size:14px;color:#fff}.bubble.a .av{background:var(--c-purple)}.bubble.b .av{background:var(--c-pink)}.bubble .msg{background:#fffcef;border:1px solid var(--c-line);padding:10px 14px;border-radius:14px 14px 14px 4px;font-size:17px}.bubble.b{flex-direction:row-reverse}.bubble.b .msg{border-radius:14px 14px 4px;background:linear-gradient(135deg,#ffe0ef,#fff)}.bubble .msg .es{font-family:var(--font-display);font-style:italic;font-weight:600;color:var(--c-purple-d)}.bubble .msg .ru{display:block;font-size:15px;color:var(--c-muted);margin-top:2px}.quiz{background:linear-gradient(135deg,#fff6fa 0,#f4eeff 100%);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:24px}.quiz-q{font-family:var(--font-display);font-size:22px;font-weight:600;margin:0 0 4px}.quiz-q .es{font-style:italic;color:var(--c-purple-d)}.quiz-hint{font-size:13px;color:var(--c-muted);margin-bottom:14px}.quiz-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.quiz-options button{padding:14px 18px;border-radius:14px;background:#fffcef;border:1.5px solid var(--c-line-strong);font-weight:600;font-size:18px;text-align:left;transition:all var(--t-fast);position:relative;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:break-word;word-break:normal}.quiz-options button:hover:not(:disabled){border-color:var(--c-purple);transform:translateY(-1px)}.quiz-options button.correct{background:rgba(16,185,129,.12);border-color:var(--c-mint);color:#065f46}.quiz-options button.wrong{background:rgba(251,113,133,.12);border-color:var(--c-rose);color:#9f1239}.quiz-options button.correct::after{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--c-mint)}.quiz-options button.wrong::after{content:"\f00d";font-family:"Font Awesome 6 Free";font-weight:900;position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--c-rose)}.quiz-options button:disabled{cursor:default;opacity:.85}.quiz-feedback{margin-top:14px;padding:12px 14px;border-radius:14px;font-size:14px;display:none}.quiz-feedback.show{display:block;animation:pop var(--t-base)}.quiz-feedback.ok{background:rgba(16,185,129,.1);color:#065f46}.quiz-feedback.err{background:rgba(251,113,133,.1);color:#9f1239}.quiz-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;font-size:13px;font-weight:600;color:var(--c-purple-d)}.match{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:22px}.match-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}.match-col{display:flex;flex-direction:column;gap:8px}.match-col h4{margin:0 0 4px;font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--c-muted);text-transform:uppercase;letter-spacing:.1em}.match-item{padding:14px 16px;border-radius:12px;background:#fdf6e3;border:1.5px solid var(--c-line);font-weight:500;font-size:19px;cursor:pointer;text-align:left;transition:all var(--t-fast);display:flex;align-items:center;gap:8px}.match-item:hover{border-color:var(--c-purple)}.match-item.selected{background:rgba(109,40,217,.1);border-color:var(--c-purple);transform:translateX(4px)}.match-item.matched{background:rgba(16,185,129,.1);border-color:var(--c-mint);color:#065f46;cursor:default;pointer-events:none}.match-item.shake{animation:.35s shake}@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}.match-item .es{font-family:var(--font-display);font-style:italic;color:var(--c-purple-d);font-weight:600;font-size:21px}.match-status{margin-top:14px;font-size:13px;color:var(--c-muted)}.fill{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:22px}.fill-q{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:17px;line-height:2;font-family:var(--font-display);font-style:italic;color:var(--c-ink)}.fill-q strong{color:var(--c-purple-d)}.fill-q input{padding:6px 12px;border:none;border-bottom:2px solid var(--c-purple);background:rgba(109,40,217,.05);min-width:120px;font-family:var(--font-display);font-style:italic;font-weight:600;color:var(--c-purple-d);font-size:17px;border-radius:6px 6px 0 0;text-align:center}.fill-q input.ok{border-color:var(--c-mint);background:rgba(16,185,129,.1);color:#065f46}.fill-q input.bad{border-color:var(--c-rose);background:rgba(251,113,133,.1);color:#9f1239}.fill-actions{display:flex;gap:10px;margin-top:16px;align-items:center;flex-wrap:wrap}.fill-hint{font-size:13px;color:var(--c-muted)}.cat{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:22px}.cat-pool{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 18px;padding:14px;background:#fff6fa;border-radius:14px;border:1px dashed var(--c-line-strong);min-height:60px}.cat-chip{padding:10px 16px;border-radius:999px;background:#fffcef;border:1.5px solid var(--c-line-strong);font-weight:600;font-size:17px;cursor:grab;user-select:none;font-family:var(--font-display);font-style:italic;color:var(--c-purple-d);transition:all var(--t-fast)}.cat-chip:hover{border-color:var(--c-purple);transform:translateY(-1px)}.cat-chip.placed{background:rgba(16,185,129,.1);border-color:var(--c-mint);cursor:default}.cat-chip.placed.wrong{background:rgba(251,113,133,.1);border-color:var(--c-rose);animation:.35s shake}.cat-buckets{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.cat-bucket{background:linear-gradient(180deg,#fff,#fdf6e3);border:1.5px dashed var(--c-line-strong);border-radius:14px;padding:14px;min-height:130px;transition:all var(--t-fast)}.cat-bucket.dragover{border-color:var(--c-purple);background:rgba(109,40,217,.05)}.cat-bucket h4{margin:0 0 10px;font-family:var(--font-display);font-size:16px;color:var(--c-ink-2);display:flex;align-items:center;gap:8px}.cat-bucket h4 i{color:var(--c-purple)}.cat-bucket .items{display:flex;flex-wrap:wrap;gap:6px;min-height:30px}.type{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:22px;text-align:center}.type .ru{font-family:var(--font-display);font-size:30px;font-weight:700;margin:6px 0 4px}.type .hint{font-size:13px;color:var(--c-muted);margin-bottom:18px}.type input{display:block;width:100%;max-width:380px;margin:0 auto 12px;padding:14px 16px;border-radius:14px;border:2px solid var(--c-line-strong);text-align:center;font-family:var(--font-display);font-style:italic;font-size:22px;font-weight:600;color:var(--c-purple-d);background:#fdf6e3;transition:border-color var(--t-fast)}.type input:focus{outline:0;border-color:var(--c-purple)}.type input.ok{border-color:var(--c-mint);background:rgba(16,185,129,.08)}.type input.bad{border-color:var(--c-rose);background:rgba(251,113,133,.08);animation:.35s shake}.type-controls{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.type-counter{margin-top:12px;font-size:13px;color:var(--c-muted)}.info{background:linear-gradient(135deg,rgba(245,184,42,.12) 0,rgba(249,115,22,.1) 100%);border:1px solid rgba(245,184,42,.4);border-radius:var(--r-md);padding:18px 20px;display:flex;gap:14px;align-items:flex-start}.info i{font-size:20px;color:var(--c-coral);margin-top:2px}.info .body{font-size:17px;line-height:1.55}.info strong{color:var(--c-purple-d)}.tip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:8px}.tip{background:#fdf6e3;border:1px solid var(--c-line);border-radius:var(--r-md);padding:14px 16px;display:flex;gap:12px;align-items:flex-start}.tip i{color:var(--c-pink);font-size:18px;margin-top:2px}.tip strong{display:block;font-family:var(--font-display);font-weight:600;font-size:15px;margin-bottom:2px}.tip .ru{font-size:13px;color:var(--c-muted)}.final{background:linear-gradient(135deg,#1b1530 0,#3b1f5c 60%,#6d28d9 100%);color:#fff;border-radius:var(--r-2xl);padding:48px;position:relative;overflow:hidden}.final::before{content:"";position:absolute;inset:-30%;background:radial-gradient(closest-side at 80% 20%,rgba(245,184,42,.4),transparent 60%),radial-gradient(closest-side at 15% 85%,rgba(236,72,153,.4),transparent 60%);filter:blur(20px);pointer-events:none}.final>*{position:relative;z-index:1}.final h2{color:#fff;margin-top:0}.final h2 em{background:linear-gradient(90deg,#ffd7a8,#ffc0da);-webkit-background-clip:text;background-clip:text;color:transparent}.final p{color:rgba(255,255,255,.82);max-width:560px}.final .quiz{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);backdrop-filter:blur(10px)}.final .quiz-q{color:#fff}.final .quiz-progress{color:rgba(255,255,255,.78)}.final .quiz-progress .es{color:#ffd7a8!important}.final .quiz-hint{color:rgba(255,255,255,.7)}.final .quiz-feedback{color:#fff}.final .quiz-options button{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.18);color:#fff}.final .quiz-options button:hover:not(:disabled){background:rgba(255,255,255,.18);border-color:#fff;color:#fff}.final .quiz-options button.correct{background:rgba(16,185,129,.25);border-color:#10b981;color:#fff}.final .quiz-options button.wrong{background:rgba(251,113,133,.25);border-color:#fb7185;color:#fff}.final-bar{height:8px;background:rgba(255,255,255,.14);border-radius:999px;overflow:hidden;margin:6px 0 20px}.final-bar>div{height:100%;background:linear-gradient(90deg,#ffd7a8,#ffc0da,#a78bfa);border-radius:999px;transition:width var(--t-base)}.cert{display:none;margin-top:24px;background:#fffcef;color:var(--c-ink);border-radius:var(--r-lg);padding:36px;text-align:center;position:relative;overflow:hidden;border:6px double var(--c-purple)}.cert.show{display:block;animation:pop var(--t-slow)}.cert::before{content:"";position:absolute;inset:-30%;background:radial-gradient(closest-side,rgba(245,184,42,.18),transparent 65%);pointer-events:none}.cert>*{position:relative}.cert .crest{font-family:var(--font-display);font-style:italic;font-weight:800;font-size:24px;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.02em}.cert h3{font-family:var(--font-display);font-size:32px;font-weight:700;margin:8px 0 6px;letter-spacing:-.02em}.cert .who{font-family:var(--font-display);font-size:42px;font-weight:600;font-style:italic;color:var(--c-purple-d);margin:18px 0 14px;border-bottom:1px solid var(--c-line);padding-bottom:14px}.cert input.who-input{font-family:var(--font-display);font-size:34px;font-weight:600;font-style:italic;text-align:center;border:none;border-bottom:1.5px dashed var(--c-line-strong);background:0 0;width:80%;max-width:480px;color:var(--c-purple-d);padding:6px 0}.cert input.who-input:focus{outline:0;border-bottom-color:var(--c-purple)}.cert .meta{display:flex;justify-content:space-around;flex-wrap:wrap;gap:18px;margin-top:14px;font-size:14px;color:var(--c-muted)}.cert .meta .v{font-family:var(--font-display);font-weight:600;color:var(--c-ink);font-size:18px;display:block;margin-top:2px}.final .cert p{color:var(--c-ink)}.final .cert .muted{color:var(--c-muted)}.final .cert strong{color:var(--c-ink)}@media (max-width:720px){.cert{padding:24px 16px}.cert h3{font-size:24px}.cert .who{font-size:28px}.cert input.who-input{font-size:22px;width:90%}.cert .crest{font-size:18px}}footer{margin-top:64px;background:linear-gradient(180deg,transparent,rgba(141,87,235,.1) 30%,rgba(141,87,235,.18) 100%);padding:64px 0 36px;border-top:1px solid var(--c-line)}footer .f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px}footer h3{font-family:var(--font-display);font-size:18px;margin:0 0 12px;font-weight:600;letter-spacing:-.005em}footer ul{list-style:none;padding:0;margin:0;display:grid;gap:8px;font-size:14px;color:var(--c-ink-2)}footer .copy{margin-top:36px;padding-top:18px;border-top:1px solid var(--c-line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:var(--c-muted)}.fab-up{position:fixed;right:24px;bottom:24px;width:48px;height:48px;border-radius:50%;background:#fffcef;border:1px solid var(--c-line);box-shadow:var(--shadow-md);display:grid;place-items:center;color:var(--c-purple-d);font-size:16px;opacity:0;pointer-events:none;transition:opacity var(--t-base),transform var(--t-base);z-index:60}.fab-up.show{opacity:1;pointer-events:auto}.fab-up:hover{transform:translateY(-3px);background:var(--c-purple);color:#fff;border-color:transparent}.drawer{position:fixed;inset:0;z-index:90;display:none}.drawer.open{display:block}.drawer .scrim{position:absolute;inset:0;background:rgba(27,21,48,.45);animation:pop var(--t-fast)}.drawer .panel{position:absolute;top:0;right:0;bottom:0;width:min(86%,360px);max-width:calc(100vw - 30px);background:#fffcef;padding:64px 22px 24px;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-lg);animation:slide var(--t-base);box-sizing:border-box}@keyframes slide{from{transform:translateX(100%)}to{transform:translateX(0)}}.drawer h3{margin:0 0 14px;font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.005em}.drawer ul{list-style:none;padding:0;margin:0;display:grid;gap:6px}.drawer ul a{display:block;padding:10px 12px;border-radius:10px;color:var(--c-ink-2);font-weight:500;font-size:15px;display:flex;align-items:center;gap:10px;text-decoration:none}.drawer ul a:hover{background:rgba(109,40,217,.08);color:var(--c-purple-d);text-decoration:none}.drawer ul a.done::after{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;color:var(--c-mint);float:right}.drawer .close-btn{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:10px;background:var(--c-bg-2);display:grid;place-items:center;color:var(--c-ink)}.drawer.drawer-left .panel{right:auto;left:0;animation:slide-in-left var(--t-base)}@keyframes slide-in-left{from{transform:translateX(-100%)}to{transform:translateX(0)}}.drawer.drawer-left .close-btn{right:auto;left:14px}.drawer ul a i{color:var(--c-purple-d);width:18px;text-align:center}.drawer ul li.divider{height:1px;background:var(--c-line);margin:8px 4px;list-style:none}.drawer .drawer-section-title{display:block;padding:4px 12px 2px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-muted)}.drawer .drawer-sublist{margin:0 0 6px;padding-left:6px;gap:2px}.drawer .drawer-sublist a{padding:8px 12px;font-size:14px;font-weight:500;color:var(--c-ink-2)}.drawer .drawer-logout{width:100%;display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:10px;border:1.5px solid var(--c-line-strong);background:0 0;color:var(--c-muted);font-weight:600;font-size:14px;cursor:pointer;font-family:inherit;text-align:left}.drawer .drawer-logout[hidden]{display:none}.drawer .drawer-logout:hover{border-color:var(--c-purple);color:var(--c-purple-d);background:rgba(109,40,217,.05)}.drawer .drawer-logout i{color:inherit}.toast-wrap{position:fixed;left:50%;top:24px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{background:#1b1530;color:#fff;padding:12px 18px;border-radius:999px;font-size:14px;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;animation:pop var(--t-base)}.toast i{color:var(--c-amber)}.toast.ok i{color:#5eead4}.confetti{position:fixed;inset:0;pointer-events:none;z-index:300;overflow:hidden}.confetti i{position:absolute;top:-20px;width:10px;height:18px;border-radius:2px;animation:2.6s ease-in forwards fall}@keyframes fall{0%{transform:translateY(0) rotate(0)}100%{transform:translateY(110vh) rotate(720deg)}}.speak-btn{position:absolute;top:8px;right:8px;z-index:5;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--c-purple-d);display:grid;place-items:center;font-size:11px;border:1px solid var(--c-line);transition:all var(--t-fast);box-shadow:var(--shadow-sm)}.speak-btn:hover{background:var(--c-purple);color:#fff;transform:scale(1.1);border-color:var(--c-purple)}.speak-btn.is-playing{background:var(--c-pink);color:#fff;border-color:var(--c-pink);animation:1.4s infinite pulse}.audio-toggle{width:38px;height:38px;border-radius:50%;background:#fffcef;border:1px solid var(--c-line);display:grid;place-items:center;color:var(--c-purple-d);font-size:14px;transition:all var(--t-fast);position:relative}.audio-toggle:hover{border-color:var(--c-purple)}.audio-toggle.off{color:var(--c-muted);background:var(--c-bg-2)}.speed{background:linear-gradient(135deg,#fff6fa 0,#f4eeff 100%);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:28px;text-align:center}.speed-progress{font-size:13px;color:var(--c-muted);margin-bottom:8px}.speed-bar{height:6px;background:rgba(27,21,48,.06);border-radius:999px;overflow:hidden;margin:0 auto 16px;max-width:480px}.speed-bar>div{height:100%;background:var(--grad-warm);border-radius:999px;transition:width var(--t-base)}.speed-card{position:relative;background:#fffcef;border-radius:var(--r-md);padding:38px 24px 28px;margin:0 auto 18px;max-width:520px;box-shadow:var(--shadow-md)}.speed-card .es{font-family:var(--font-display);font-style:italic;font-weight:700;font-size:clamp(28px,5vw,40px);color:var(--c-purple-d);line-height:1.1;word-break:break-word}.speed-card .ru{font-size:18px;color:var(--c-ink-2);margin-top:14px;display:none}.speed-card.revealed .ru{display:block;animation:pop var(--t-base)}.speed-card.revealed .es{opacity:.65}.speed-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.btn-success{background:var(--c-mint);color:#fff;box-shadow:var(--shadow-sm)}.btn-success:hover{background:#0d9668;text-decoration:none;transform:translateY(-2px)}.btn-warn{background:var(--c-amber);color:#1b1530;box-shadow:var(--shadow-sm)}.btn-warn:hover{background:#e0a41f;text-decoration:none;transform:translateY(-2px)}.btn-danger{background:#fffcef;color:var(--c-rose);border:1.5px solid var(--c-rose)}.btn-danger:hover{background:var(--c-rose);color:#fff;text-decoration:none}.dict{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:28px 24px;text-align:center}.dict .speaker{width:74px;height:74px;border-radius:50%;background:var(--grad-warm);color:#fff;font-size:24px;display:grid;place-items:center;margin:0 auto 14px;box-shadow:var(--shadow-glow);cursor:pointer;border:none;transition:transform var(--t-fast)}.dict .speaker:hover{transform:scale(1.06)}.dict .speaker.is-playing{animation:1.4s infinite pulse}.dict .hint-ru{font-size:15px;color:var(--c-muted);margin-bottom:10px}.dict .hint-ru strong{color:var(--c-purple-d);font-weight:600}.dict input{display:block;width:100%;max-width:380px;margin:6px auto 12px;padding:14px 16px;border-radius:14px;border:2px solid var(--c-line-strong);text-align:center;font-family:var(--font-display);font-style:italic;font-size:22px;font-weight:600;color:var(--c-purple-d);background:#fdf6e3}.dict input:focus{outline:0;border-color:var(--c-purple)}.dict input.ok{border-color:var(--c-mint);background:rgba(16,185,129,.08)}.dict input.bad{border-color:var(--c-rose);background:rgba(251,113,133,.08);animation:.35s shake}.dict .reveal{font-family:var(--font-display);font-style:italic;font-weight:600;color:var(--c-purple-d);font-size:22px;margin:10px 0;display:none}.dict .reveal.show{display:block;animation:pop var(--t-base)}.dict-counter{margin-top:12px;font-size:13px;color:var(--c-muted)}.articles{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:28px;text-align:center}.articles .ru-hint{font-size:14px;color:var(--c-muted);margin-bottom:10px}.articles .word{font-family:var(--font-display);font-style:italic;font-weight:700;font-size:clamp(26px,4vw,38px);color:var(--c-ink);margin:8px 0 18px}.articles .word em{color:var(--c-purple-d);font-style:italic;background:rgba(109,40,217,.08);padding:2px 12px;border-radius:8px}.articles-options{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.articles-options button{min-width:84px;padding:14px 22px;border-radius:14px;background:#fffcef;border:2px solid var(--c-line-strong);font-family:var(--font-display);font-style:italic;font-size:20px;font-weight:600;color:var(--c-purple-d)}.articles-options button:hover:not(:disabled){border-color:var(--c-purple);transform:translateY(-1px)}.articles-options button.correct{background:rgba(16,185,129,.12);border-color:var(--c-mint);color:#065f46}.articles-options button.wrong{background:rgba(251,113,133,.12);border-color:var(--c-rose);color:#9f1239;animation:.35s shake}.art-slot{display:inline-block;min-width:1.5em;font-family:var(--font-display);font-weight:700;letter-spacing:.02em;transition:color .25s,transform .25s}.art-slot.art-correct{color:#10b981;transform:scale(1.08)}.art-slot.art-wrong{color:#ef4444}.articles-counter{margin-top:14px;font-size:13px;color:var(--c-muted)}.listen{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:24px}.listen-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}.listen-head .speaker{width:54px;height:54px;border-radius:50%;background:var(--grad-warm);color:#fff;font-size:18px;display:grid;place-items:center;cursor:pointer;flex-shrink:0;box-shadow:var(--shadow-md);border:none}.listen-head .speaker:hover{transform:scale(1.05)}.listen-head .speaker.is-playing{animation:1.4s infinite pulse}.listen-head .label{font-size:14px;color:var(--c-muted);font-weight:500}.listen-head .meta{font-size:13px;color:var(--c-muted)}.listen-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.listen-options button{padding:14px 16px;border-radius:14px;background:#fffcef;border:1.5px solid var(--c-line-strong);font-weight:600;text-align:left;transition:all var(--t-fast)}.listen-options button:hover:not(:disabled){border-color:var(--c-purple);transform:translateY(-1px)}.listen-options button.correct{background:rgba(16,185,129,.12);border-color:var(--c-mint);color:#065f46}.listen-options button.wrong{background:rgba(251,113,133,.12);border-color:var(--c-rose);color:#9f1239}.conj{background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-lg);padding:24px;text-align:center}.conj .prompt{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--c-ink);margin:6px 0 16px}.conj .prompt em{color:var(--c-purple-d);font-style:italic;font-weight:700;background:rgba(109,40,217,.1);padding:3px 14px;border-radius:8px}.conj input{display:block;width:100%;max-width:300px;margin:0 auto 10px;padding:14px 16px;border-radius:14px;border:2px solid var(--c-line-strong);text-align:center;font-family:var(--font-display);font-style:italic;font-size:22px;font-weight:600;color:var(--c-purple-d);background:#fdf6e3}.conj input:focus{outline:0;border-color:var(--c-purple)}.conj input.ok{border-color:var(--c-mint);background:rgba(16,185,129,.08)}.conj input.bad{border-color:var(--c-rose);background:rgba(251,113,133,.08);animation:.35s shake}.conj-controls{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:6px}.conj-counter{margin-top:12px;font-size:13px;color:var(--c-muted)}.trainer{background:linear-gradient(135deg,#fff6fa 0,#f4eeff 100%);border:1px solid var(--c-line);border-radius:var(--r-lg);padding:24px;position:relative;scroll-margin-top:84px;overscroll-behavior:contain}.trainer-block{scroll-margin-top:84px}.trainer-head{display:flex;align-items:center;gap:14px;padding-bottom:14px;border-bottom:1px dashed var(--c-line);margin-bottom:18px;flex-wrap:wrap}.trainer-stat{display:flex;align-items:baseline;gap:8px}.trainer-stat-num{font-family:var(--font-display);font-size:18px;color:var(--c-ink-2)}.trainer-stat-num strong{font-size:26px;color:var(--c-purple-d);font-weight:700}.trainer-stat-lbl{font-size:11px;color:var(--c-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.trainer-bar{flex:1;min-width:140px;height:8px;background:rgba(27,21,48,.06);border-radius:999px;overflow:hidden}.trainer-bar>div{height:100%;background:var(--grad-warm);border-radius:999px;transition:width var(--t-base)}.mode-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:6px;margin-bottom:18px;background:rgba(255,255,255,.6);padding:5px;border-radius:14px;border:1px solid var(--c-line)}.mode-tab{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:10px;background:0 0;border:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--c-muted);transition:all var(--t-fast)}.mode-tab:hover:not(.active){color:var(--c-purple-d);background:rgba(109,40,217,.06)}.mode-tab.active{background:#fffcef;color:var(--c-purple-d);box-shadow:var(--shadow-sm)}.mode-tab.mode-done{background:#dcfce7;color:#15803d;border:1px solid #86efac}.mode-tab.mode-done.active{background:#bbf7d0;box-shadow:0 4px 12px -2px rgba(34,197,94,.35)}.mode-tab.mode-done .mode-done-check{margin-left:4px;color:#16a34a;font-size:13px}.mode-tab i{font-size:14px}@media(max-width:580px){.mode-tabs{grid-template-columns:repeat(4,1fr)}.mode-tab span{display:none}.mode-tab i{font-size:18px}.mode-tab{padding:14px}}.trainer-stage{animation:pop var(--t-base)}.mode-label{font-size:13px;color:var(--c-muted);font-weight:600;letter-spacing:.05em;margin-bottom:14px;display:flex;align-items:center;gap:8px;text-transform:uppercase}.mode-label i{color:var(--c-purple-d)}.trainer-prompt{text-align:center;padding:26px 16px;background:#fffcef;border:1px solid var(--c-line);border-radius:var(--r-md);margin-bottom:18px;position:relative;min-height:90px;display:flex;align-items:center;justify-content:center}.trainer-prompt:has(.speak-btn-large){padding-top:54px;padding-right:54px}.prompt-es{font-family:var(--font-display);font-style:italic;font-weight:700;font-size:clamp(28px,5vw,42px);color:var(--c-purple-d);line-height:1.15;word-break:normal;overflow-wrap:normal;hyphens:none;text-wrap:balance}.prompt-ru{font-family:var(--font-display);font-weight:600;font-size:clamp(24px,4vw,34px);color:var(--c-ink);line-height:1.2;word-break:normal;overflow-wrap:normal;hyphens:none;text-wrap:balance}.prompt-ru.big{font-size:clamp(28px,5vw,38px)}@media(max-width:520px){.lesson-block{padding:18px 12px}.trainer-prompt{padding:22px 12px}.trainer-prompt:has(.speak-btn-large){padding-top:50px;padding-right:50px;padding-left:12px}}.speak-btn-large{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(109,40,217,.1);color:var(--c-purple-d);display:grid;place-items:center;font-size:14px;border:1px solid transparent;transition:all var(--t-fast);cursor:pointer}.speak-btn-large:hover{background:var(--c-purple);color:#fff;transform:scale(1.08)}.speak-btn-large.is-playing{background:var(--c-pink);color:#fff;animation:1.4s infinite pulse}.trainer-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.trainer-options.vertical{grid-template-columns:1fr}.trainer-options button{padding:16px 18px;border-radius:14px;background:#fffcef;border:1.5px solid var(--c-line-strong);font-weight:600;font-size:19px;text-align:left;min-height:58px;display:flex;align-items:center;justify-content:space-between;gap:10px;transition:all var(--t-fast);cursor:pointer}.trainer-options.vertical button{font-family:var(--font-display);font-style:italic;font-size:20px;color:var(--c-purple-d)}.trainer-options.ru-text button{font-family:var(--font-body, inherit);font-style:normal;font-size:17px;color:var(--c-ink);font-weight:600}.trainer-options button:hover:not(:disabled){border-color:var(--c-purple);transform:translateY(-1px)}.trainer-options button.correct{background:rgba(16,185,129,.12);border-color:var(--c-mint);color:#065f46}.trainer-options button.wrong{background:rgba(251,113,133,.12);border-color:var(--c-rose);color:#9f1239;animation:.35s shake}.trainer-options .mini-spk{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:11px;background:rgba(109,40,217,.1);color:var(--c-purple-d);border:none;flex-shrink:0;cursor:pointer;transition:all var(--t-fast)}.trainer-options .mini-spk:hover{background:var(--c-purple);color:#fff;transform:scale(1.1)}.trainer-options .mini-spk.is-playing{background:var(--c-pink);color:#fff;animation:1.4s infinite pulse}.speaker-xl{width:84px;height:84px;border-radius:50%;background:var(--grad-warm);color:#fff;font-size:30px;display:grid;place-items:center;margin:6px auto 16px;box-shadow:var(--shadow-glow);border:none;cursor:pointer;transition:transform var(--t-fast)}.speaker-xl:hover{transform:scale(1.06)}.speaker-xl.is-playing{animation:1.4s infinite pulse}.trainer-stage .ru-hint{font-size:14px;color:var(--c-muted);text-align:center;margin-bottom:10px}.trainer-stage .ru-hint strong{color:var(--c-purple-d);font-weight:600}.trainer-stage input{display:block;width:100%;max-width:420px;margin:0 auto 14px;padding:14px 16px;border-radius:14px;border:2px solid var(--c-line-strong);text-align:center;font-family:var(--font-display);font-style:italic;font-size:22px;font-weight:600;color:var(--c-purple-d);background:#fdf6e3}.trainer-stage input:focus{outline:0;border-color:var(--c-purple)}.trainer-stage input.ok{border-color:var(--c-mint);background:rgba(16,185,129,.08)}.trainer-stage input.bad{border-color:var(--c-rose);background:rgba(251,113,133,.08);animation:.35s shake}.trainer-controls{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}@media (max-width:768px){.trainer-stage .trainer-controls{position:sticky;bottom:8px;z-index:30;background:rgba(253,246,227,.92);backdrop-filter:blur(6px);padding:8px;border-radius:14px;margin:0 -4px 8px}}.trainer-meta{font-size:12px;color:var(--c-muted);text-align:center;margin-top:14px;letter-spacing:.05em}.trainer-meta .pip{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--c-line-strong);margin:0 2px;vertical-align:-1px;transition:background var(--t-fast)}.trainer-meta .pip.on{background:var(--c-mint)}.trainer-done{text-align:center;padding:24px}.trainer-done .big-emoji{font-size:64px;margin-bottom:10px;animation:pop var(--t-slow)}.trainer-done .trainer-done-title{font-family:var(--font-display);font-size:30px;font-weight:700;margin:0 0 8px;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.02em}.trainer-done p{margin:6px 0 18px}.btn-mini.danger{color:var(--c-rose);background:rgba(251,113,133,.06);border-color:rgba(251,113,133,.3)}.btn-mini.danger:hover{background:var(--c-rose);color:#fff;border-color:var(--c-rose)}.mod-card .mod-mastery{font-size:12px;color:var(--c-muted);font-weight:600;display:flex;align-items:center;gap:6px;margin-top:4px}.mod-card .mod-mastery .b{flex:1;height:4px;background:rgba(27,21,48,.06);border-radius:999px;overflow:hidden}.mod-card .mod-mastery .b>div{height:100%;background:var(--grad-warm);transition:width var(--t-base)}.section-trainer{background:linear-gradient(135deg,#fff6fa 20%,#f4eeff 100%);border-radius:var(--r-2xl);padding:48px;position:relative;overflow:hidden;border:1px solid var(--c-line);margin:0 24px}@media(max-width:760px){footer .f-grid{grid-template-columns:1fr}.section-trainer{padding:32px 22px}}.section-trainer::before{content:"";position:absolute;inset:-30%;background:radial-gradient(closest-side at 20% 20%,rgba(245,184,42,.16),transparent 60%),radial-gradient(closest-side at 85% 85%,rgba(141,87,235,.16),transparent 60%);pointer-events:none}.section-trainer>*{position:relative}.section-trainer h2{margin-top:14px}.trainer-locked{text-align:center;padding:44px 24px 38px;background:linear-gradient(135deg,rgba(245,184,42,.1) 0,rgba(141,87,235,.1) 100%);border-radius:var(--r-md);border:1px dashed var(--c-line-strong);position:relative;overflow:hidden}.trainer-locked::before{content:"";position:absolute;inset:-30%;background:radial-gradient(closest-side at 25% 30%,rgba(245,184,42,.18),transparent 65%),radial-gradient(closest-side at 80% 75%,rgba(141,87,235,.18),transparent 65%);pointer-events:none}.trainer-locked>*{position:relative}.locked-icon{width:78px;height:78px;border-radius:50%;background:var(--grad-warm);color:#fff;font-size:30px;display:grid;place-items:center;margin:0 auto 16px;box-shadow:var(--shadow-glow)}.trainer-locked .locked-title{font-family:var(--font-display);font-size:26px;font-weight:700;margin:0 0 10px;letter-spacing:-.01em}.trainer-locked p{color:var(--c-ink-2);max-width:520px;margin:0 auto 20px;font-size:15px;line-height:1.55}.trainer-locked p strong{color:var(--c-purple-d)}.trainer-locked .features{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:24px;max-width:520px;margin-left:auto;margin-right:auto}.trainer-locked .features span{background:rgba(255,255,255,.85);padding:7px 14px;border-radius:999px;font-size:13px;font-weight:500;color:var(--c-ink-2);border:1px solid var(--c-line);display:inline-flex;align-items:center;gap:6px}.trainer-locked .features span i{color:var(--c-mint);font-size:11px}.modal{position:fixed;inset:0;z-index:300;display:none}.modal.open{display:grid;place-items:center;padding:20px}.modal-scrim{position:absolute;inset:0;background:rgba(27,21,48,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:pop var(--t-fast)}.modal-panel{position:relative;background:#fffcef;border-radius:var(--r-2xl);padding:40px 32px 32px;max-width:460px;width:100%;box-shadow:var(--shadow-lg);text-align:center;animation:pop var(--t-base)}.modal-icon{width:78px;height:78px;border-radius:50%;background:var(--grad-warm);color:#fff;font-size:30px;display:grid;place-items:center;margin:0 auto 14px;box-shadow:var(--shadow-glow)}.modal h3{font-family:var(--font-display);font-size:26px;font-weight:700;margin:0 0 8px;letter-spacing:-.01em}.modal .modal-sub{color:var(--c-muted);font-size:15px;margin:0 0 14px}.modal-input{display:block;width:100%;padding:14px 16px;border-radius:14px;border:2px solid var(--c-line-strong);text-align:center;font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--c-ink);margin:14px 0 6px;letter-spacing:.08em;background:#fdf6e3}.modal-input:focus{outline:0;border-color:var(--c-purple)}.modal-input.bad{border-color:var(--c-rose);background:rgba(251,113,133,.06);animation:.35s shake}.modal-input.ok{border-color:var(--c-mint);background:rgba(16,185,129,.06)}.modal-feedback{font-size:13px;color:var(--c-rose);min-height:18px;margin-bottom:14px;font-weight:500}.modal-feedback.ok{color:#065f46}.modal-actions{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.modal-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:10px;background:var(--c-bg-2);display:grid;place-items:center;border:none;cursor:pointer;color:var(--c-ink);font-size:14px}.modal-close:hover{background:var(--c-line-strong);color:#fff}.premium-chip{display:none;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;background:linear-gradient(135deg,#ffd7a8,#ffc0da);color:#6d28d9;font-size:12px;font-weight:700;border:1px solid rgba(255,255,255,.6);box-shadow:var(--shadow-sm)}.premium-chip.show{display:inline-flex}.premium-chip i{font-size:13px}.premium-chip span{display:none}@media(max-width:880px){.audio-toggle,.nav-progress{display:none}}@media(prefers-reduced-motion:reduce){*{animation-duration:NaNs!important;transition-duration:NaNs!important}}.center{text-align:center}.gap-12{display:flex;gap:12px;flex-wrap:wrap}.mt-24{margin-top:24px}.mb-12{margin-bottom:12px}hr.soft{border:none;border-top:1px dashed var(--c-line);margin:36px 0}.cta-active{position:relative;animation:1.6s ease-in-out infinite cta-pulse}@keyframes cta-pulse{0%,100%{box-shadow:0 0 0 0 rgba(236,72,153,.55),var(--shadow-md);transform:scale(1)}50%{box-shadow:0 0 0 14px rgba(236,72,153,0),var(--shadow-md);transform:scale(1.06)}}.cta-active::after{content:"Нажми, чтобы услышать";position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%);white-space:nowrap;background:var(--c-ink);color:#fff;padding:8px 14px;border-radius:10px;font-family:var(--font-body);font-style:normal;font-size:12px;font-weight:600;letter-spacing:.02em;pointer-events:none;opacity:0;animation:.35s .35s forwards cta-tooltip-in;z-index:10;box-shadow:0 6px 18px -4px rgba(0,0,0,.18)}.cta-active::before{content:"";position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%);width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:9px solid var(--c-ink);pointer-events:none;opacity:0;animation:.35s .35s forwards cta-tooltip-in;z-index:11}@keyframes cta-tooltip-in{to{opacity:1}}.cta-active.is-playing::after,.cta-active.is-playing::before{display:none}.cta-active.is-playing{animation:1.4s infinite pulse}