:root{--sf:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue",sans-serif;--bg:#0A0A0A;--bg2:#111111;--bg3:#181818;--border:#222222;--border2:#2a2a2a;--accent:#E85D3A;--accent2:#ff7a5c;--text:#EFEFEF;--muted:#666;--muted2:#444;--white:#ffffff}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--sf);overflow-x:hidden}#falling-canvas{width:100%;height:100%;pointer-events:none;z-index:0;opacity:.06}#falling-canvas,nav{position:fixed;top:0;left:0}nav{right:0;z-index:100;padding:20px 48px;display:flex;align-items:center;justify-content:space-between;background:linear-gradient(180deg,rgba(10,10,10,.95),transparent)}.nav-logo{font-size:22px;font-weight:800;letter-spacing:-1px;color:var(--text)}.nav-logo span{color:var(--accent)}.nav-cta{background:var(--accent);color:white;border:none;padding:10px 24px;border-radius:100px;font-family:var(--sf);font-weight:700;font-size:14px;cursor:pointer;transition:background .2s,transform .15s;text-decoration:none}.nav-cta:hover{background:var(--accent2);transform:translateY(-1px)}.hero{position:relative;min-height:100vh;display:flex;justify-content:center;padding:120px 48px 80px;z-index:1}.hero,.hero-inner{align-items:center}.hero-inner{max-width:1200px;width:100%;display:grid;grid-template-columns:1fr 420px;grid-gap:80px;gap:80px}.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(232,93,58,.12);border:1px solid rgba(232,93,58,.3);border-radius:100px;padding:6px 14px;font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.5px;text-transform:uppercase;margin-bottom:32px;opacity:0;animation:fadeUp .6s ease .2s forwards}.hero-title{font-size:clamp(52px,6vw,88px);font-weight:800;line-height:.95;letter-spacing:-3px;color:var(--text);margin-bottom:28px;opacity:0;animation:fadeUp .7s ease .35s forwards}.hero-title .jp{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;color:var(--accent);display:block;font-size:.75em;letter-spacing:-2px}.hero-sub{font-size:18px;line-height:1.65;color:var(--muted);max-width:480px;margin-bottom:44px;font-weight:400;opacity:0;animation:fadeUp .7s ease .5s forwards}.hero-sub strong{color:var(--text);font-weight:600}.hero-actions{display:flex;align-items:center;gap:20px;opacity:0;animation:fadeUp .7s ease .65s forwards}.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:white;padding:16px 32px;border-radius:100px;font-family:var(--sf);font-weight:700;font-size:16px;text-decoration:none;transition:all .2s;cursor:pointer;border:none}.btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 12px 40px rgba(232,93,58,.35)}.btn-secondary{color:var(--muted);font-size:14px;font-weight:600;text-decoration:none;transition:color .2s}.btn-secondary:hover{color:var(--text)}.phone-wrap{position:relative;display:flex;justify-content:center;opacity:0;animation:fadeUp .9s ease .4s forwards}.phone-glow{position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(232,93,58,.3) 0,transparent 70%);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);filter:blur(40px);animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}.phone{width:320px;height:660px;background:#111;border-radius:48px;border:1.5px solid #2a2a2a;position:relative;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.04),0 40px 80px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.06)}.phone-notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:100px;height:28px;background:#0A0A0A;border-radius:20px;z-index:10}.phone-screen{position:absolute;inset:0;padding:60px 20px 20px;display:flex;flex-direction:column;gap:16px;overflow:hidden}.phone-topbar{display:flex;justify-content:space-between;align-items:flex-start;padding-top:8px}.phone-logo{font-size:20px;font-weight:800;color:#EFEFEF;letter-spacing:-.5px}.phone-logo span{color:#E85D3A}.phone-greeting{color:#666;font-size:11px;margin-top:3px}.phone-streak{color:#E85D3A;font-size:10px;margin-top:2px}.phone-avatar{width:36px;height:36px;border-radius:18px;background:#1A1A1A;border:1px solid #333;display:flex;align-items:center;justify-content:center;color:#E85D3A;font-size:14px;font-weight:700}.phone-stats{background:#0F0F0F;border:1px solid #222;border-radius:14px;padding:14px;display:flex;justify-content:space-around}.phone-stat{text-align:center}.phone-stat-val{font-size:18px;font-weight:700;color:#EFEFEF}.phone-stat-label{font-size:9px;color:#555;margin-top:2px;letter-spacing:.3px}.phone-stat-div{width:1px;background:#222}.phone-card-primary{background:#E85D3A;border-radius:18px;padding:22px}.phone-card-icon{font-size:22px}.phone-card-title{font-size:20px;font-weight:800;color:white;letter-spacing:-.5px;margin-top:4px}.phone-card-sub{font-size:11px;color:rgba(255,255,255,.65);margin-top:2px}.phone-card-secondary{background:#111;border:1px solid #222;border-radius:18px;padding:18px 22px}.phone-card-secondary .phone-card-icon{color:#E85D3A;font-family:var(--font-noto-sans-jp),"Noto Sans JP",sans-serif;font-size:22px}.phone-card-secondary .phone-card-title{font-size:18px;font-weight:800;color:#EFEFEF;letter-spacing:-.5px;margin-top:2px}.phone-card-secondary .phone-card-sub{font-size:11px;color:#444;margin-top:2px}.phone-screen-2{position:absolute;inset:0;background:#0A0A0A;padding:60px 20px 20px;display:flex;flex-direction:column;opacity:0;transition:opacity 1s ease}.phone-screen-2.visible{opacity:1}.sentence-display{flex:1 1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;text-align:center}.sentence-jp{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;font-size:26px;color:#EFEFEF;line-height:1.6;letter-spacing:2px}.sentence-en{font-size:13px;color:#555;font-style:italic}.typing-bar{background:#111;border:1px solid #333;border-radius:12px;padding:14px 16px;font-family:var(--font-noto-sans-jp),"Noto Sans JP",sans-serif;font-size:16px;color:#EFEFEF;position:relative;overflow:hidden}.typing-text{display:inline}.typing-cursor{display:inline-block;width:2px;height:18px;background:#E85D3A;margin-left:2px;vertical-align:middle;animation:blink 1s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.grade-badge{position:absolute;top:-60px;left:50%;transform:translateX(-50%);font-size:48px;transition:top .5s cubic-bezier(.34,1.56,.64,1)}.grade-badge.show{top:10px}section{position:relative;z-index:1}.section-inner{max-width:1200px;margin:0 auto;padding:120px 48px}.section-tag{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:20px}.section-title{font-size:clamp(36px,4vw,56px);font-weight:800;letter-spacing:-2px;line-height:1.05;color:var(--text);margin-bottom:20px}.section-sub{font-size:17px;color:var(--muted);line-height:1.65;max-width:520px}.marquee-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:24px 0;overflow:hidden;position:relative;z-index:1}.marquee-track{display:flex;gap:0;animation:marquee 20s linear infinite;width:max-content}.marquee-item{display:flex;align-items:center;gap:20px;padding:0 32px;white-space:nowrap}.marquee-jp{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;font-size:22px;color:var(--accent)}.marquee-en{font-size:13px;color:var(--muted2);font-weight:600;letter-spacing:.5px}.marquee-dot{color:var(--border2);font-size:8px}@keyframes marquee{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.diff-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:2px;gap:2px;margin-top:64px;border:1px solid var(--border);border-radius:24px;overflow:hidden}.diff-card{background:var(--bg2);padding:40px;transition:background .3s}.diff-card:hover{background:var(--bg3)}.diff-card.accent-card{background:rgba(232,93,58,.08);border:1px solid rgba(232,93,58,.15);border-radius:0}.diff-card.accent-card:hover{background:rgba(232,93,58,.12)}.diff-num{font-size:48px;font-weight:800;color:var(--accent);letter-spacing:-2px;line-height:1;margin-bottom:16px;font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif}.diff-title{font-size:20px;font-weight:700;color:var(--text);margin-bottom:10px;letter-spacing:-.5px}.diff-desc{font-size:14px;color:var(--muted);line-height:1.6}.features-section{background:var(--bg)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:2px;gap:2px;margin-top:64px}.feature-card{background:var(--bg2);padding:36px;border-radius:0;transition:background .3s;position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(232,93,58,.4),transparent);opacity:0;transition:opacity .3s}.feature-card:hover{background:var(--bg3)}.feature-card:hover:before{opacity:1}.feature-icon{font-size:32px;margin-bottom:20px;display:block}.feature-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:10px;letter-spacing:-.3px}.feature-desc{font-size:14px;color:var(--muted);line-height:1.65}.compare-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:64px;border:1px solid var(--border);border-radius:20px;overflow:hidden}.compare-table th{padding:20px 24px;text-align:left;font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:var(--bg2);color:var(--muted);border-bottom:1px solid var(--border)}.compare-table th.highlight{background:rgba(232,93,58,.1);color:var(--accent)}.compare-table td{padding:18px 24px;font-size:14px;color:var(--text);border-bottom:1px solid var(--border);background:var(--bg)}.compare-table td.highlight{background:rgba(232,93,58,.05);font-weight:600;color:var(--text)}.compare-table tr:last-child td{border-bottom:none}.check{color:#4ade80}.check,.cross{font-size:18px}.cross{color:var(--muted2)}.partial{color:#facc15;font-size:14px}.mastery-demo{display:flex;gap:16px;margin-top:48px;flex-wrap:wrap}.mastery-card{flex:1 1;min-width:180px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:28px 24px;text-align:center;transition:transform .2s,border-color .2s}.mastery-card:hover{transform:translateY(-4px)}.mastery-card.perfect{border-color:rgba(96,165,250,.4)}.mastery-card.good{border-color:rgba(74,222,128,.4)}.mastery-card.wrong{border-color:rgba(232,93,58,.4)}.mastery-symbol{font-size:40px;font-family:var(--font-noto-sans-jp),"Noto Sans JP",sans-serif;display:block;margin-bottom:12px}.mastery-card.perfect .mastery-symbol{color:#60a5fa}.mastery-card.good .mastery-symbol{color:#4ade80}.mastery-card.wrong .mastery-symbol{color:#E85D3A}.mastery-label{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}.mastery-desc{font-size:13px;color:var(--muted)}.mastery-score{font-size:11px;color:var(--muted2);margin-top:8px;font-weight:600}.jlpt-section{background:var(--bg)}.jlpt-grid{display:flex;gap:12px;margin-top:48px;align-items:flex-end}.jlpt-bar-wrap{flex:1 1;align-items:center;gap:12px}.jlpt-bar-outer,.jlpt-bar-wrap{display:flex;flex-direction:column}.jlpt-bar-outer{width:100%;height:200px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;justify-content:flex-end}.jlpt-bar-fill{background:linear-gradient(to top,var(--accent),var(--accent2));border-radius:0 0 12px 12px;transition:height 1.5s cubic-bezier(.34,1.1,.64,1);width:100%}.jlpt-label{font-size:13px;font-weight:700;color:var(--muted);letter-spacing:.5px}.ime-flow{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;grid-gap:0;gap:0;align-items:center;margin-top:48px;margin-bottom:32px}.ime-step{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px 24px}.ime-step-num{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:14px}.ime-step-content{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;font-size:32px;margin-bottom:10px;line-height:1.2}.ime-step-content .romaji{font-family:var(--sf);font-size:24px;font-style:italic;color:var(--muted);letter-spacing:-.5px}.ime-step-content .kana{color:#60a5fa}.ime-step-content .kanji{color:var(--accent)}.ime-step-desc{font-size:13px;color:var(--muted);line-height:1.6}.ime-arrow{font-size:22px;color:var(--muted2);padding:0 18px;text-align:center;flex-shrink:0}.ime-callout{background:rgba(232,93,58,.07);border:1px solid rgba(232,93,58,.18);border-radius:16px;padding:24px 32px;font-size:15px;color:var(--muted);line-height:1.75}.ime-callout strong{color:var(--text);font-weight:600}.cta-section{background:var(--bg);text-align:center}.cta-inner{max-width:700px;margin:0 auto;padding:120px 48px}.cta-jp{font-family:var(--font-noto-serif-jp),"Noto Serif JP",serif;font-size:64px;color:var(--accent);opacity:.15;display:block;margin-bottom:-20px;letter-spacing:8px}.cta-title{font-size:clamp(40px,5vw,64px);font-weight:800;letter-spacing:-2px;color:var(--text);line-height:1;margin-bottom:20px}.cta-sub{font-size:18px;color:var(--muted);line-height:1.6;margin-bottom:44px}.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.store-btn{display:inline-flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid var(--border2);color:var(--text);padding:14px 28px;border-radius:14px;text-decoration:none;transition:all .2s;font-size:14px;font-weight:600}.store-btn:hover{background:var(--bg3);border-color:var(--accent);transform:translateY(-2px)}.store-btn svg{opacity:.7}footer{border-top:1px solid var(--border);padding:40px 48px;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}.footer-logo{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.5px}.footer-logo span{color:var(--accent)}.footer-text{font-size:13px;color:var(--muted2)}@keyframes fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.divider{width:100%;height:1px;background:var(--border);position:relative;z-index:1}@media (max-width:900px){nav{padding:16px 24px}.hero-inner{grid-template-columns:1fr;text-align:center;gap:60px}.hero-sub{margin:0 auto 44px}.hero-actions{justify-content:center}.hero-tag{margin-left:auto;margin-right:auto}.section-inner{padding:80px 24px}.diff-grid,.features-grid{grid-template-columns:1fr}.phone{width:280px;height:580px}footer{flex-direction:column;gap:12px;text-align:center}}