:root{--font:'Inter','Noto Sans JP',sans-serif;--primary:#0f172a;--primary-light:#1e3a8a;--accent:#2563eb;--cta:#dc2626;--cta-hover:#b91c1c;--text:#1f2937;--text-sub:#6b7280;--bg:#fff;--bg-sub:#f8fafc;--border:#e5e7eb;--success:#10b981;--error:#ef4444;--shadow:0 4px 12px rgba(0,0,0,.08);--radius:12px}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-size:20px;line-height:1.8;color:var(--text);background:var(--bg)}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section-sub{background:var(--bg-sub)}
.section-dark{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff}
.section-header{text-align:center;margin-bottom:48px}
.section-label{font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.section-dark .section-label{color:rgba(255,255,255,.6)}
.section-title{font-size:clamp(32px,5vw,48px);font-weight:700;color:var(--primary)}
.section-dark .section-title{color:#fff}
.section-subtitle{font-size:18px;color:var(--text-sub);margin-top:8px}
.section-dark .section-subtitle{color:rgba(255,255,255,.8)}
.reveal{opacity:0;transform:translateY(20px);transition:all .6s}.reveal.visible{opacity:1;transform:none}
.hero{min-height:100vh;display:flex;align-items:center;padding:80px 0;color:#fff;background:var(--primary);position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg-img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.5s}
.hero-bg-img.active{opacity:.3}
.hero-bg-img:nth-child(1){background-image:url('https://images.unsplash.com/photo-1493976040374-85c8e12f0c0e?w=1600')}
.hero-bg-img:nth-child(2){background-image:url('https://images.unsplash.com/photo-1528164344705-47542687000d?w=1600')}
.hero-bg-img:nth-child(3){background-image:url('https://images.unsplash.com/photo-1545569341-9eb8b30979d9?w=1600')}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,23,42,.88),rgba(30,58,138,.78));z-index:1}
.hero .container{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1fr 480px;gap:60px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;margin-bottom:20px}
.hero-badge-dot{width:6px;height:6px;background:#10b981;border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-title{font-size:clamp(40px,6vw,64px);font-weight:700;line-height:1.3;margin-bottom:24px}
.hero-title span{color:#fbbf24}
.hero-lead{font-size:20px;color:rgba(255,255,255,.85);margin-bottom:32px;line-height:1.9}
.hero-meta{display:flex;gap:32px;padding:20px 0;border-top:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:28px}
.hero-meta-item{display:flex;flex-direction:column;gap:2px}
.hero-meta-label{font-size:12px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1px}
.hero-meta-value{font-size:22px;font-weight:700}
.hero-meta-value.hl{color:#fbbf24}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:16px 32px;font-size:17px;font-weight:600;text-decoration:none;border-radius:8px;transition:all .2s}
.btn-primary{background:linear-gradient(90deg,#dc2626,#ef4444,#dc2626);background-size:200%;animation:gradientBtn 3s ease infinite;color:#fff;box-shadow:0 4px 14px rgba(220,38,38,.3)}
@keyframes gradientBtn{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(220,38,38,.4)}
.btn-secondary{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff}
.btn-secondary:hover{background:rgba(255,255,255,.15)}
.hero-phone-area{position:relative;display:flex;justify-content:center;align-items:center;min-height:580px}
.phone-frame{width:280px;height:540px;background:#111;border-radius:36px;padding:8px;box-shadow:0 25px 50px rgba(0,0,0,.4);position:relative;z-index:10}
.phone-screen{width:100%;height:100%;background:linear-gradient(180deg,#1e40af,#3b82f6);border-radius:28px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.phone-notch{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:70px;height:20px;background:#111;border-radius:10px;z-index:5}
.phone-header{padding:36px 14px 8px;text-align:center}
.phone-logo{height:32px}
.phone-tagline{font-size:9px;color:rgba(255,255,255,.6);margin-top:2px}
.phone-view-label{font-size:9px;color:rgba(255,255,255,.4);background:rgba(0,0,0,.2);padding:2px 8px;border-radius:8px;margin-top:6px;display:inline-block}
.chat-box{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:8px;padding:8px 10px}
.chat-msg{max-width:88%;padding:10px 12px;border-radius:14px;font-size:11px;line-height:1.5;position:relative;opacity:0;transform:translateY(10px);transition:all .4s}
.chat-msg.show{opacity:1;transform:translateY(0)}
.chat-msg.user{background:rgba(255,255,255,.15);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-msg.system{background:#fff;color:#1e3a8a;align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg .flag{font-size:10px;margin-right:3px}
.chat-msg .translate-badge{font-size:8px;background:rgba(251,191,36,.3);color:#fbbf24;padding:1px 5px;border-radius:4px;margin-left:4px}
.chat-msg .original{font-size:9px;color:rgba(30,64,175,.5);display:block;margin-top:4px;padding-top:4px;border-top:1px dashed rgba(30,64,175,.2)}
.chat-msg-img{max-width:90px;border-radius:6px;margin-top:6px;display:block}
.chat-avatar{position:absolute;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 2px 4px rgba(0,0,0,.2);overflow:hidden}
.chat-msg.user .chat-avatar{right:-6px;bottom:-6px;background:linear-gradient(135deg,#60a5fa,#3b82f6)}
.chat-msg.system .chat-avatar{left:-6px;bottom:-6px;background:#fff;padding:2px}
.chat-msg.system .chat-avatar.responder{background:linear-gradient(135deg,#fbbf24,#f59e0b);padding:0;font-size:12px}
.chat-msg.system .chat-avatar img{width:100%;height:100%;object-fit:contain}
.chat-typing{display:flex;gap:3px;padding:10px 12px;align-self:flex-start}
.chat-typing span{width:6px;height:6px;background:rgba(255,255,255,.5);border-radius:50%;animation:typing 1.4s infinite}
.chat-typing span:nth-child(2){animation-delay:.2s}
.chat-typing span:nth-child(3){animation-delay:.4s}
@keyframes typing{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-4px)}}
.chat-input-area{display:flex;gap:6px;padding:6px 8px;background:rgba(0,0,0,.2);border-radius:16px;margin:6px 8px 8px}
.chat-input{flex:1;background:rgba(255,255,255,.15);border-radius:12px;padding:8px 10px;font-size:10px;color:#fff;min-height:14px}
.chat-send{width:26px;height:26px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:#1e3a8a;font-weight:700}
.flying-bubble{position:absolute;background:#fff;border-radius:14px;padding:12px 16px;box-shadow:0 8px 24px rgba(0,0,0,.15);font-size:12px;color:#333;max-width:200px;opacity:0;z-index:5;pointer-events:none}
.flying-bubble .flag{font-size:11px;margin-right:4px}
.flying-bubble .text{line-height:1.5}
.flying-bubble .sub{display:block;font-size:10px;color:#888;margin-top:4px}
.flying-bubble::after{content:'';position:absolute;border:8px solid transparent}
.flying-bubble.left{right:calc(50% + 160px);top:20%}.flying-bubble.left::after{border-left-color:#fff;right:-14px;top:16px}
.flying-bubble.right{left:calc(50% + 160px);top:50%}.flying-bubble.right::after{border-right-color:#fff;left:-14px;top:16px}
.flying-bubble.bottom{left:calc(50% + 140px);bottom:15%}.flying-bubble.bottom::after{border-right-color:#fff;left:-14px;top:16px}
.flying-bubble.float{animation:floatBubble 3s ease-in-out infinite}
@keyframes floatBubble{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.flying-bubble.fly-in{animation:flyIn .8s ease forwards}
@keyframes flyIn{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(.3) translateX(var(--fly-x)) translateY(var(--fly-y))}}
.flying-bubble.fly-out{animation:flyOut .8s ease forwards}
@keyframes flyOut{0%{opacity:0;transform:scale(.3)}100%{opacity:1;transform:scale(1)}}
.translate-effect{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:24px;opacity:0;z-index:20;pointer-events:none}
.translate-effect.show{animation:translatePop .6s ease}
@keyframes translatePop{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}100%{opacity:0;transform:translate(-50%,-50%) scale(1)}}
.nav{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.nav-inner{display:flex;justify-content:center;gap:4px;padding:10px 0}
.nav-link{color:var(--text-sub);font-size:15px;font-weight:500;padding:10px 16px;border-radius:6px;text-decoration:none;transition:all .2s}
.nav-link:hover,.nav-link.active{color:var(--accent);background:rgba(37,99,235,.08)}
.nav-cta{background:var(--cta);color:#fff !important}
.nav-cta:hover{background:var(--cta-hover)}
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;z-index:100;background:#fff;border-bottom:1px solid var(--border);padding:8px 0;overflow-x:auto}
.mobile-nav .nav-inner{justify-content:flex-start;padding:0 12px;gap:6px}
.mobile-nav .nav-link{font-size:14px;padding:8px 12px;white-space:nowrap}
.whatis-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:900px;margin:0 auto}
.whatis-text h2{font-size:clamp(24px,3vw,32px);font-weight:700;color:var(--primary);margin-bottom:16px}
.whatis-text p{color:var(--text-sub);margin-bottom:12px;font-size:17px}
.whatis-visual{display:flex;gap:12px;justify-content:center}
.whatis-phone{width:130px;height:260px;background:#111;border-radius:18px;padding:4px;box-shadow:var(--shadow);overflow:hidden}
.whatis-phone img{width:100%;height:100%;object-fit:cover;border-radius:14px}
.whatis-features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;max-width:800px;margin-left:auto;margin-right:auto}
.feature{text-align:center;padding:20px}
.feature-icon{width:52px;height:52px;background:linear-gradient(135deg,var(--accent),#60a5fa);border-radius:10px;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:22px}
.feature-title{font-size:17px;font-weight:600;color:var(--primary);margin-bottom:4px}
.feature-desc{font-size:15px;color:var(--text-sub)}
.whynow-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:900px;margin:0 auto}
.whynow-card{text-align:center;padding:32px 24px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);transition:all .25s}
.whynow-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.whynow-num{font-size:48px;font-weight:700;color:var(--accent);line-height:1}
.whynow-unit{font-size:18px;color:var(--accent)}
.whynow-label{font-size:15px;color:var(--text-sub);margin-top:10px;line-height:1.5}
.whynow-source{font-size:12px;color:#aaa;margin-top:6px}
.whynow-footer{text-align:center;margin-top:40px;padding:32px 40px;background:linear-gradient(135deg,var(--primary),var(--primary-light));border-radius:var(--radius);max-width:900px;margin-left:auto;margin-right:auto;font-size:18px;font-weight:500;color:#fff;line-height:1.8;box-shadow:0 8px 24px rgba(15,23,42,.2)}
.whynow-footer strong{color:#fbbf24;font-weight:700;font-size:20px}
.questions-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.q-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .25s}
.q-card:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-3px)}
.q-text{font-size:16px;color:var(--text);line-height:1.6;min-height:60px}
.q-tag{display:inline-flex;align-items:center;gap:4px;margin-top:10px;background:var(--bg-sub);padding:6px 12px;border-radius:10px;font-size:13px;color:var(--text-sub)}
.q-tag-dot{width:5px;height:5px;background:var(--accent);border-radius:50%}
.ba-grid{display:grid;grid-template-columns:1fr 40px 1fr;gap:20px;max-width:900px;margin:0 auto;align-items:stretch}
.ba-card{background:#fff;border-radius:var(--radius);padding:32px 28px}
.ba-card.before{border:1px solid #fecaca}
.ba-card.after{border:1px solid #bbf7d0;box-shadow:var(--shadow)}
.ba-label{font-size:13px;font-weight:700;letter-spacing:1px;margin-bottom:14px;display:flex;align-items:center;gap:6px}
.ba-card.before .ba-label{color:#dc2626}
.ba-card.after .ba-label{color:#059669}
.ba-title{font-size:18px;font-weight:600;color:var(--primary);margin-bottom:14px}
.ba-list{list-style:none}
.ba-list li{padding:10px 0;font-size:15px;display:flex;align-items:flex-start;gap:8px;color:var(--text-sub);line-height:1.5;border-bottom:1px solid var(--border)}
.ba-list li:last-child{border-bottom:none}
.ba-icon{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;margin-top:2px}
.ba-card.before .ba-icon{background:#fef2f2;color:#dc2626}
.ba-card.after .ba-icon{background:#ecfdf5;color:#059669}
.ba-arrow{display:flex;align-items:center;justify-content:center}
.ba-arrow-icon{width:40px;height:40px;background:var(--accent);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px}
.benefits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:900px;margin:0 auto}
.benefit-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:all .25s}
.benefit-card:hover{border-color:var(--accent);box-shadow:var(--shadow);transform:translateY(-3px)}
.benefit-num{width:32px;height:32px;background:var(--bg-sub);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--accent);margin-bottom:12px}
.benefit-title{font-size:18px;font-weight:600;color:var(--primary);margin-bottom:6px}
.benefit-desc{font-size:16px;color:var(--text-sub);line-height:1.6}
.taiwan-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.stat-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:28px;position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:240px}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#fbbf24,#f59e0b)}
.stat-num{font-size:48px;font-weight:700;color:#fbbf24;line-height:1}
.stat-suffix{font-size:22px}
.stat-label{font-size:16px;color:rgba(255,255,255,.9);margin-top:8px}
.stat-note{font-size:12px;color:rgba(255,255,255,.5);margin-top:6px}
.stat-chart{width:80px;height:80px;margin:12px auto 0;position:relative}
.stat-chart svg{transform:rotate(-90deg)}
.stat-chart circle{fill:none;stroke-width:6}
.stat-chart .bg{stroke:rgba(255,255,255,.1)}
.stat-chart .prog{stroke:#fbbf24;stroke-linecap:round;stroke-dasharray:0 999;transition:stroke-dasharray 1.5s}
.stat-chart.animated .prog{stroke-dasharray:var(--val) 999}
.stat-chart-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:13px;color:rgba(255,255,255,.8)}
.stat-categories{margin-top:14px;text-align:left;font-size:14px;color:rgba(255,255,255,.7)}
.stat-cat-item{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.stat-cat-item:last-child{margin-bottom:0}
.stat-cat-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.taiwan-cta{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;padding:14px 28px;border-radius:6px;font-size:16px;font-weight:600;text-decoration:none;transition:all .2s}
.taiwan-cta:hover{background:rgba(255,255,255,.15)}
.partners-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:900px;margin:0 auto}
.partner-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:32px;text-align:center;transition:all .25s;display:flex;flex-direction:column}
.partner-card:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.partner-card:hover .partner-logo{filter:grayscale(0);opacity:1}
.partner-logo-wrap{height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.partner-logo{height:50px;width:auto;filter:grayscale(100%);opacity:.6;transition:all .3s}
.partner-name{font-size:17px;font-weight:600;color:var(--primary)}
.partner-name-en{font-size:13px;color:var(--text-sub);margin-bottom:12px}
.partner-desc{font-size:15px;color:var(--text-sub);line-height:1.7;text-align:left;margin-bottom:16px;flex:1}
.partner-hl{background:var(--bg-sub);padding:12px 16px;border-radius:6px;font-size:14px;font-weight:600;color:var(--accent);margin-top:auto}
.program-tl{max-width:700px;margin:0 auto;position:relative;padding-left:32px}
.program-tl::before{content:'';position:absolute;left:10px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--accent),#60a5fa)}
.program-item{position:relative;padding:20px 0 20px 24px}
.program-item::before{content:'';position:absolute;left:-26px;top:24px;width:12px;height:12px;background:#fff;border:3px solid var(--accent);border-radius:50%;transition:all .3s}
.program-item:hover::before{transform:scale(1.3);background:var(--accent)}
.program-time{font-size:14px;font-weight:700;color:var(--accent);background:rgba(37,99,235,.08);padding:6px 12px;border-radius:10px;display:inline-block;margin-bottom:8px}
.program-box{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:all .3s}
.program-item:hover .program-box{border-color:var(--accent);box-shadow:var(--shadow)}
.program-title{font-size:17px;font-weight:600;color:var(--primary);margin-bottom:4px}
.program-desc{font-size:15px;color:var(--text-sub)}
.program-speaker{margin-top:6px;font-size:13px;color:var(--text-sub);background:var(--bg-sub);padding:6px 10px;border-radius:8px;display:inline-block}
.exclusive-section{padding:80px 0;background:linear-gradient(135deg,#fefce8,#fef3c7)}
.exclusive-badge{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fbbf24;padding:10px 16px;border-radius:16px;font-size:13px;font-weight:700;margin-bottom:16px}
.exclusive-title{font-size:clamp(24px,3vw,32px);font-weight:700;color:var(--primary);margin-bottom:8px}
.exclusive-subtitle{font-size:16px;color:var(--text-sub);margin-bottom:32px}
.exclusive-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:640px;margin:0 auto;text-align:left}
.exc-card{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);transition:transform .3s}
.exc-card:hover{transform:translateY(-4px)}
.exc-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--accent),#60a5fa);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:20px}
.exc-title{font-size:17px;font-weight:600;color:var(--primary);margin-bottom:4px}
.exc-desc{font-size:15px;color:var(--text-sub);line-height:1.5}
.target-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:720px;margin:0 auto}
.target-item{background:#fff;border:1px solid var(--border);padding:18px;border-radius:8px;display:flex;align-items:center;gap:12px;transition:all .25s}
.target-item:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.target-check{width:28px;height:28px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.target-text{font-size:16px;font-weight:500;color:var(--text)}
.faq-list{max-width:700px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;background:none;border:none;padding:20px 0;text-align:left;font-size:17px;font-weight:600;color:var(--primary);cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:'+';font-size:20px;color:var(--accent);transition:transform .2s}
details[open] .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 0 20px;font-size:16px;color:var(--text-sub);line-height:1.7}
.cta-section{background:var(--primary);color:#fff;padding:80px 0;text-align:center}
.cta-title{font-size:clamp(24px,3vw,32px);font-weight:700;margin-bottom:10px}
.cta-subtitle{font-size:16px;color:rgba(255,255,255,.8);margin-bottom:24px}
.cta-meta{display:inline-flex;gap:32px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);padding:18px 32px;border-radius:8px;margin-bottom:20px}
.cta-meta-item{text-align:left}
.cta-meta-label{font-size:12px;color:rgba(255,255,255,.5);letter-spacing:1px}
.cta-meta-value{font-size:18px;font-weight:700}
.footer{background:var(--primary);color:#fff;padding:40px 0;text-align:center;border-top:1px solid rgba(255,255,255,.1)}
.footer p{font-size:14px;color:rgba(255,255,255,.6);margin:4px 0}
.footer a{color:rgba(255,255,255,.8)}
.mobile-cta{position:fixed;bottom:0;left:0;right:0;background:#fff;padding:12px 16px;box-shadow:0 -4px 12px rgba(0,0,0,.1);z-index:99;display:none;transition:transform .3s}
.mobile-cta.hidden{transform:translateY(100%)}
.mobile-cta .btn{width:100%;justify-content:center}
/* アスクー - 크기 2배, 위치 위로 조정 */
.askuu-float{position:fixed;bottom:160px;right:20px;z-index:90;width:140px;cursor:pointer;animation:floatBubble 3s ease-in-out infinite}
.askuu-float img{width:100%;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2))}
.askuu-float:hover{transform:scale(1.1)}
.askuu-tip{position:absolute;right:150px;top:50%;transform:translateY(-50%);background:#fff;padding:10px 14px;border-radius:10px;font-size:14px;color:var(--text);box-shadow:var(--shadow);opacity:0;transition:opacity .3s;white-space:nowrap}
.askuu-float:hover .askuu-tip{opacity:1}
.askuu-tip::after{content:'';position:absolute;right:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-left-color:#fff}
[id]{scroll-margin-top:70px}
.modal{position:fixed;inset:0;z-index:200;display:none}
.modal[aria-hidden="false"]{display:flex;align-items:center;justify-content:center}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}
.modal-panel{position:relative;width:min(520px,94vw);max-height:90vh;background:#fff;border-radius:var(--radius);box-shadow:0 12px 32px rgba(0,0,0,.15);overflow:hidden;display:flex;flex-direction:column}
.modal-header{padding:24px;border-bottom:1px solid var(--border)}
.modal-title{font-size:20px;font-weight:700;color:var(--primary)}
.modal-subtitle{font-size:14px;color:var(--text-sub);margin-top:2px}
.modal-body{padding:24px;overflow-y:auto}
.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;background:var(--bg-sub);border:none;border-radius:50%;cursor:pointer;font-size:18px;color:var(--text-sub)}
.modal-close:hover{background:var(--border)}
.form{display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}
.form-label{font-size:14px;font-weight:600;color:var(--text)}
.form-label .req{color:var(--cta)}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:6px;font-size:15px;font-family:var(--font);color:var(--text);transition:all .2s}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.form-error{font-size:13px;color:var(--error);display:none}
.form-group.has-error .form-error{display:block}
.form-group.has-error .form-input{border-color:var(--error)}
.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%236b7280' d='M5 7L0 2h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.form-textarea{min-height:80px;resize:vertical}
.form-checkbox-group{display:flex;align-items:flex-start;gap:10px}
.form-checkbox{width:18px;height:18px;accent-color:var(--accent)}
.form-checkbox-label{font-size:14px;color:var(--text-sub);line-height:1.5}
.form-checkbox-label a{color:var(--accent)}
.form-submit{width:100%;padding:14px;font-size:16px;font-weight:700;color:#fff;background:var(--cta);border:none;border-radius:6px;cursor:pointer;transition:all .2s;position:relative}
.form-submit:hover{background:var(--cta-hover)}
.form-submit:disabled{opacity:.6;cursor:not-allowed}
.form-submit.loading{color:transparent}
.form-submit.loading::after{content:'';position:absolute;width:20px;height:20px;top:50%;left:50%;margin:-10px 0 0 -10px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.form-note{font-size:13px;color:var(--text-sub);text-align:center}
.form-success,.form-error-state{text-align:center;padding:36px 20px;display:none}
.form-success.show,.form-error-state.show{display:block}
.form-success-icon{width:56px;height:56px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:24px;color:#fff}
.form-error-icon{width:56px;height:56px;background:var(--error);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:24px;color:#fff}
.form-success-title,.form-error-title{font-size:18px;font-weight:700;color:var(--primary);margin-bottom:6px}
.form-success-text,.form-error-text{font-size:15px;color:var(--text-sub)}
.form-retry{margin-top:16px;padding:12px 24px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer}
@media(max-width:1024px){.hero-grid{grid-template-columns:1fr;text-align:center;gap:40px}.hero-meta{justify-content:center}.hero-cta{justify-content:center}.hero-phone-area{min-height:500px}.flying-bubble{display:none}.ba-grid{grid-template-columns:1fr;gap:12px}.ba-arrow{padding:8px 0}.ba-arrow-icon{transform:rotate(90deg)}.whatis-grid{grid-template-columns:1fr;gap:32px}.program-tl{padding-left:24px}.program-tl::before{left:6px}.program-item::before{left:-22px}}
@media(max-width:768px){.hero{min-height:auto;padding:70px 0 50px}.nav{display:none}.mobile-nav,.mobile-cta{display:block}.section{padding:56px 0}.whynow-grid,.taiwan-stats{grid-template-columns:1fr;gap:14px}.questions-grid{grid-template-columns:1fr 1fr;gap:10px}.benefits-grid,.partners-grid,.exclusive-cards,.target-grid{grid-template-columns:1fr}.phone-frame{width:220px;height:420px}.form-row{grid-template-columns:1fr}.hero-meta{flex-direction:column;gap:12px}.askuu-float{width:100px;bottom:100px;right:12px}.askuu-tip{right:110px;font-size:12px}.whatis-visual{flex-direction:row}.whatis-phone{width:100px;height:200px}}
@media(max-width:480px){.questions-grid{grid-template-columns:1fr}}
.phone-caption{position:absolute;bottom:-60px;left:50%;transform:translateX(-50%);text-align:center;white-space:nowrap}
.phone-caption-title{font-size:14px;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:4px}
.phone-caption-desc{font-size:12px;color:rgba(255,255,255,.6)}
/* =========================
   CF7 PATCH (apply-modal 전용) - 최종본
   ========================= */

/* CF7 기본 p 태그 여백 제거 */
#apply-modal .wpcf7 form p {
  margin: 0;
}

/* CF7 wrap */
#apply-modal .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* 에러 문구 */
#apply-modal .wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.4;
  color: var(--error);
}

/* invalid input 테두리 */
#apply-modal .wpcf7-form-control.wpcf7-not-valid {
  border-color: var(--error) !important;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, .12);
}

/* response output */
#apply-modal .wpcf7-response-output {
  margin: 14px 0 0;
  font-size: 14px;
}

/* form-row 간격 */
#apply-modal .form-row {
  margin-bottom: 16px;
}

/* form-group */
#apply-modal .form-group {
  margin-bottom: 4px;
}

#apply-modal .form-group.full {
  margin-bottom: 16px;
}

/* ★ 프라이버시 체크박스 - 강제 한 줄 ★ */
#apply-modal .privacy-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px;
}

#apply-modal .privacy-row .wpcf7-form-control-wrap,
#apply-modal .privacy-row .wpcf7-acceptance,
#apply-modal .privacy-row .wpcf7-list-item,
#apply-modal .privacy-row .wpcf7-list-item label {
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding: 0 !important;
}

#apply-modal .privacy-row input[type="checkbox"] {
  display: inline-block !important;
  width: 18px !important;
  height: 18px !important;
  margin: 0 8px 0 0 !important;
  vertical-align: middle;
  accent-color: var(--accent);
}

#apply-modal .privacy-row a {
  color: var(--accent);
}

#apply-modal .privacy-row .req {
  color: var(--cta);
}

#apply-modal .privacy-row br {
  display: none !important;
}
/* =========================
   他のセミナー セクション - 우선순위 강화
   ========================= */
section.other-seminars-section {
  padding: 60px 0 !important;
  background: #f8fafc !important;
}

section.other-seminars-section .other-seminars-header {
  text-align: center;
  margin-bottom: 32px;
}

section.other-seminars-section .other-seminars-label {
  display: block;
  font-size: 11px !important;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #2563eb;
  margin-bottom: 8px;
}

section.other-seminars-section .other-seminars-title {
  font-size: 28px !important;
  font-weight: 700;
  color: #0f172a;
  margin: 0;
}

section.other-seminars-section .other-seminars-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 20px;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 24px;
}

section.other-seminars-section .other-seminar-card {
  display: flex !important;
  align-items: stretch;
  background: #fff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 12px !important;
  padding: 20px !important;
  text-decoration: none !important;
  color: #1f2937 !important;
  transition: all 0.25s;
  position: relative;
}

section.other-seminars-section .other-seminar-card:hover {
  border-color: #2563eb !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
  transform: translateY(-3px);
}

section.other-seminars-section .other-seminar-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  background: #10b981 !important;
  color: #fff !important;
  font-size: 10px !important;
  font-weight: 700;
  padding: 4px 8px;
  border-radius: 4px;
}

section.other-seminars-section .other-seminar-date {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 56px;
  padding-right: 16px;
  margin-right: 16px;
  border-right: 1px solid #e5e7eb;
}

section.other-seminars-section .other-seminar-month {
  font-size: 11px !important;
  color: #2563eb !important;
  font-weight: 600;
}

section.other-seminars-section .other-seminar-day {
  font-size: 28px !important;
  font-weight: 700;
  color: #0f172a !important;
  line-height: 1;
}

section.other-seminars-section .other-seminar-content {
  flex: 1;
  min-width: 0;
}

section.other-seminars-section .other-seminar-title {
  font-size: 15px !important;
  font-weight: 600;
  color: #0f172a !important;
  margin-bottom: 8px;
  line-height: 1.4;
  padding-right: 50px;
}

section.other-seminars-section .other-seminar-meta {
  display: flex !important;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 11px !important;
  color: #6b7280 !important;
  margin-bottom: 8px;
}

section.other-seminars-section .other-seminar-tags {
  display: flex !important;
  gap: 6px;
}

section.other-seminars-section .other-seminar-tag {
  font-size: 10px !important;
  padding: 2px 8px;
  border-radius: 4px;
  background: #f0f7ff !important;
  color: #1d4ed8 !important;
  border: 1px solid #dbeafe;
}

section.other-seminars-section .other-seminar-arrow {
  display: flex !important;
  align-items: center;
  font-size: 18px !important;
  color: #e5e7eb;
  margin-left: 12px;
  transition: all 0.2s;
}

section.other-seminars-section .other-seminar-card:hover .other-seminar-arrow {
  color: #2563eb;
  transform: translateX(4px);
}

section.other-seminars-section .other-seminars-more {
  text-align: center;
  margin-top: 24px;
}

section.other-seminars-section .other-seminars-more-link {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  color: #2563eb !important;
  font-size: 14px !important;
  font-weight: 600;
  text-decoration: none !important;
  padding: 10px 20px;
  border: 1px solid #2563eb !important;
  border-radius: 6px;
  transition: all 0.2s;
  background: transparent !important;
}

section.other-seminars-section .other-seminars-more-link:hover {
  background: #2563eb !important;
  color: #fff !important;
}

@media (max-width: 768px) {
  section.other-seminars-section .other-seminars-grid {
    grid-template-columns: 1fr !important;
    gap: 14px;
    padding: 0 16px;
  }
  
  section.other-seminars-section .other-seminar-card {
    padding: 16px !important;
  }
  
  section.other-seminars-section .other-seminar-date {
    min-width: 48px;
    padding-right: 12px;
    margin-right: 12px;
  }
  
  section.other-seminars-section .other-seminar-day {
    font-size: 24px !important;
  }
  
  section.other-seminars-section .other-seminar-title {
    font-size: 14px !important;
    padding-right: 40px;
  }
  
  section.other-seminars-section .other-seminar-arrow {
    display: none !important;
  }
}