@import "https://cdn.jsdelivr.net/gh/webfontworld/gmarket/GmarketSans.css";@import "https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700;800&display=swap";.navbar{border-bottom:1px solid var(--gray-200);z-index:100;background:#fff;position:sticky;top:0;box-shadow:0 1px 4px #0000000f}.navbar-inner{align-items:center;gap:40px;max-width:1200px;height:56px;margin:0 auto;padding:0 24px;display:flex}.navbar-logo{color:var(--purple-primary);align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.navbar-logo-img{width:28px;height:28px}.navbar-links{flex:1;align-items:center;gap:4px;display:flex}.navbar-item{position:relative}.navbar-link{color:var(--gray-600);border-radius:8px;padding:8px 16px;font-size:15px;font-weight:500;transition:color .2s,background .2s;display:block}.navbar-link:hover,.navbar-link.active{color:var(--purple-primary);background:var(--purple-bg)}.navbar-link.active{font-weight:700}.navbar-dropdown{border:1px solid var(--gray-200);background:#fff;border-radius:12px;gap:20px;min-width:220px;padding:16px;display:flex;position:absolute;top:100%;left:0;box-shadow:0 8px 24px #0000001f}.dropdown-group{flex-direction:column;gap:4px;display:flex}.dropdown-group-title{color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;padding:0 8px;font-size:11px;font-weight:600}.dropdown-item{color:var(--gray-600);white-space:nowrap;border-radius:6px;padding:6px 8px;font-size:14px;transition:background .15s,color .15s}.dropdown-item:hover{background:var(--purple-bg);color:var(--purple-primary)}.navbar-right{align-items:center;gap:12px;margin-left:auto;display:flex}.navbar-icon-btn{background:0 0;border-radius:8px;padding:6px;font-size:18px;transition:background .2s}.navbar-icon-btn:hover{background:var(--gray-100)}.navbar-user{background:var(--purple-bg);color:var(--purple-dark);border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:14px;font-weight:600;transition:background .2s;display:flex}.navbar-user:hover{background:var(--purple-lighter)}.navbar-avatar{object-fit:contain;width:28px;height:28px}.auth-page{background:#f9fafb;justify-content:center;align-items:flex-start;min-height:100vh;padding:70px 24px 40px;font-family:GmarketSans,Noto Sans KR,sans-serif;display:flex}.auth-box{flex-direction:column;align-items:center;width:100%;max-width:400px;display:flex}.auth-logo{object-fit:contain;width:56px;height:56px;margin-bottom:24px}.auth-headline{letter-spacing:-1.5px;color:#111827;text-align:center;word-break:keep-all;margin-bottom:32px;font-size:48px;font-weight:800;line-height:1.1}.auth-form{flex-direction:column;gap:16px;width:100%;margin-bottom:24px;display:flex}.auth-field{flex-direction:column;gap:6px;display:flex}.auth-label{color:#111827;letter-spacing:.01em;font-size:13px;font-weight:700}.auth-input{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:6px;outline:none;width:100%;padding:14px 16px;font-family:inherit;font-size:15px;transition:border-color .15s}.auth-input::placeholder{color:#9ca3af}.auth-input:focus{border-color:#8758ff}.auth-input-wrap{align-items:center;display:flex;position:relative}.auth-input-wrap .auth-input{padding-right:44px}.auth-eye-btn{cursor:pointer;opacity:.6;background:0 0;border:none;padding:4px;font-size:16px;line-height:1;transition:opacity .15s;position:absolute;right:12px}.auth-eye-btn:hover{opacity:1}.auth-error{color:#ef4444;text-align:center;margin:-4px 0;font-size:13px}.auth-btn-primary{color:#fff;cursor:pointer;background:#8758ff;border:none;border-radius:999px;width:100%;margin-top:4px;padding:16px;font-family:inherit;font-size:15px;font-weight:700;transition:transform .1s,background .15s}.auth-btn-primary:hover{background:#7248ee;transform:scale(1.02)}.auth-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-divider{color:#6b7280;align-items:center;gap:12px;width:100%;margin-bottom:16px;font-size:13px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#e5e7eb;flex:1;height:1px}.auth-social{flex-direction:column;gap:10px;width:100%;margin-bottom:28px;display:flex}.auth-social-btn{color:#111827;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:999px;justify-content:center;align-items:center;gap:12px;width:100%;padding:13px 20px;font-family:inherit;font-size:14px;font-weight:700;transition:border-color .15s,background .15s;display:flex;position:relative}.auth-social-btn:hover{background:#f9fafb;border-color:#111827}.auth-social-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:900;display:flex;position:absolute;left:20px}.naver-icon{color:#fff;background:#03c75a}.kakao-icon{color:#3a1d1d;background:#fee500}.auth-progress{background:#e5e7eb;border-radius:99px;width:100%;height:3px;margin-bottom:24px;overflow:hidden}.auth-progress-fill{background:#8758ff;border-radius:99px;height:100%;transition:width .3s}.auth-step-header{align-items:flex-start;gap:12px;width:100%;margin-bottom:24px;display:flex}.auth-back-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;flex-shrink:0;margin-top:2px;padding:2px 4px;font-size:20px;line-height:1;transition:color .15s}.auth-back-btn:hover:not(:disabled){color:#111827}.auth-back-btn:disabled{opacity:.3;cursor:default}.auth-step-label{color:#6b7280;margin-bottom:4px;font-size:13px;font-weight:500}.auth-step-title{color:#111827;white-space:pre-line;font-size:24px;font-weight:800;line-height:1.2}.auth-pw-rules{flex-direction:column;gap:6px;margin:8px 0 0;padding:0;list-style:none;display:flex}.auth-pw-rules li{color:#9ca3af;align-items:center;gap:8px;font-size:13px;transition:color .2s;display:flex}.auth-pw-rules li:before{content:"○";flex-shrink:0;font-size:10px}.auth-pw-rules li.rule-ok{color:#8758ff}.auth-pw-rules li.rule-ok:before{content:"●"}.auth-switch{color:#6b7280;text-align:center;font-size:14px}.auth-link{color:#111827;font-weight:700;text-decoration:underline;transition:color .15s}.auth-link:hover{color:#8758ff}.typing-text--ko .char-pending,.typing-text--ko .char-correct,.typing-text--ko .char-wrong,.typing-text--ko .char-composing,.typing-text--ko .char-cursor{line-height:1}.typing-text--ko .char-cursor{border-left:none;margin-left:0;position:relative}.typing-text--ko .char-cursor:before{content:"";background:var(--purple-primary,#8758ff);width:2px;height:100%;animation:.9s step-end infinite blink-ko;position:absolute;top:0;left:0}@keyframes blink-ko{0%,to{opacity:1}50%{opacity:0}}.char-pending{color:#d1d5db}.char-correct{color:var(--purple-primary,#8758ff)}.char-wrong{color:#ef4444;background:#fee2e2;border-radius:3px}.char-composing{color:var(--purple-primary,#8758ff);border-bottom:2px solid var(--purple-primary,#8758ff);opacity:.6}.char-cursor{color:#d1d5db;border-left:2.5px solid var(--purple-primary,#8758ff);animation:.9s step-end infinite blink}@keyframes blink{0%,to{border-color:var(--purple-primary,#8758ff)}50%{border-color:#0000}}.typing-text--dark .char-pending,.typing-text--dark .char-cursor{color:#3f3f46}.typing-text--dark .char-wrong{background:#ef444426}.lt-page{background:#f9fafb;justify-content:center;align-items:center;min-height:100vh;padding:24px;font-family:GmarketSans,Noto Sans KR,sans-serif;display:flex}.lt-card{text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:20px;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:480px;padding:48px 40px;display:flex;box-shadow:0 4px 24px #0000000f}.lt-card--wide{text-align:left;max-width:640px}.lt-intro-icon{margin-bottom:4px;font-size:52px}.lt-title{color:#111827;margin:0;font-size:26px;font-weight:700}.lt-desc{color:#6b7280;margin:0;font-size:15px;line-height:1.75}.lt-sub{color:#9ca3af;margin:0;font-size:13px}.lt-btn-primary{color:#fff;cursor:pointer;background:#8758ff;border:none;border-radius:10px;margin-top:8px;padding:14px 44px;font-family:inherit;font-size:16px;font-weight:600;transition:opacity .2s,transform .15s}.lt-btn-primary:hover{opacity:.9;transform:translateY(-1px)}.lt-step-label{color:#9ca3af;letter-spacing:.02em;font-size:13px;font-weight:500}.lt-progress{background:#e5e7eb;border-radius:3px;width:100%;height:5px;overflow:hidden}.lt-progress-fill{background:#8758ff;border-radius:3px;height:100%;transition:width .35s cubic-bezier(.4,0,.2,1)}.lt-keyboard-desc{color:#9ca3af;margin:8px 0 0;font-size:14px}.lt-jamo{color:#111827;-webkit-user-select:none;user-select:none;margin:20px 0;font-size:100px;font-weight:700;line-height:1;transition:color .15s,transform .15s cubic-bezier(.4,0,.2,1)}.lt-jamo--correct{color:#6de701;transform:scale(1.12)}.lt-jamo--wrong{color:#ef4444;transform:scale(.92)rotate(-3deg)}.lt-hint{color:#9ca3af;margin:0;font-size:13px}.lt-slow-hint{color:#f59e0b;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;margin:0;padding:8px 14px;font-size:13px}.lt-badge{border-radius:50px;padding:6px 18px;font-size:14px;font-weight:600;display:inline-block}.lt-badge--pass{color:#4ade80;background:#6de7011a}.lt-badge--fail{color:#ef4444;background:#ef444414}.lt-speed-header{justify-content:space-between;align-items:center;width:100%;margin-bottom:12px;display:flex}.lt-char-wrap{justify-content:center;margin-bottom:8px;display:flex}.lt-character{object-fit:contain;width:72px;height:72px}.lt-timer{color:#111827;letter-spacing:-2px;font-size:44px;font-weight:700;line-height:1}.lt-timer span{color:#9ca3af;letter-spacing:0;margin-left:4px;font-size:16px;font-weight:500}.lt-live-cpm{color:#8758ff;font-size:22px;font-weight:700}.lt-live-cpm span{color:#9ca3af;margin-left:3px;font-size:13px;font-weight:500}.lt-speed-text{word-break:break-all;background:#f9fafb;border-radius:12px;width:100%;padding:20px;font-size:22px;line-height:2}.lt-result-emoji{margin-bottom:4px;font-size:60px}.lt-level-badge{border:2px solid;border-radius:50px;padding:7px 28px;font-size:20px;font-weight:700;display:inline-block}.lt-level-desc{color:#6b7280;margin:0;font-size:15px}.lt-stats-row{background:#f9fafb;border-radius:14px;justify-content:center;align-items:center;gap:28px;width:100%;margin:4px 0;padding:20px 36px;display:flex}.lt-stat{text-align:center}.lt-stat-value{color:#111827;font-size:34px;font-weight:700;line-height:1}.lt-stat-label{color:#9ca3af;margin-top:6px;font-size:12px}.lt-stat-sep{background:#e5e7eb;flex-shrink:0;width:1px;height:44px}.lt-group-analysis{flex-direction:column;gap:10px;width:100%;display:flex}.lt-group-item{align-items:center;gap:12px;display:flex}.lt-group-label{color:#6b7280;flex-shrink:0;width:80px;font-size:13px;font-weight:600}.lt-group-bar{background:#e5e7eb;border-radius:99px;flex:1;height:6px;overflow:hidden}.lt-group-fill{border-radius:99px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.lt-group-pct{color:#111827;text-align:right;width:36px;font-size:13px;font-weight:700}.lt-guide-box{color:#6b7280;text-align:left;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;align-items:center;gap:10px;width:100%;padding:13px 18px;font-size:14px;display:flex}.lt-guide-arrow{color:#8758ff;flex-shrink:0;font-weight:700}.ranking-page{background:var(--gray-100);min-height:calc(100vh - 56px);padding:32px 24px}.ranking-container{max-width:700px;margin:0 auto}.ranking-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.ranking-subtitle{color:var(--gray-600);font-size:14px}.ranking-date{color:var(--gray-400);font-size:13px}.podium{justify-content:center;align-items:flex-end;gap:12px;margin-bottom:40px;display:flex}.podium-item{flex-direction:column;align-items:center;gap:6px;display:flex}.podium-crown{margin-bottom:4px}.podium-crown-img{object-fit:contain;filter:drop-shadow(0 2px 6px #0003);width:48px;height:48px}.podium-avatar{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;display:flex;box-shadow:0 4px 16px #8758ff33}.podium-avatar-large{width:88px;height:88px}.podium-emoji{object-fit:contain;width:36px;height:36px}.podium-avatar-large .podium-emoji{width:48px;height:48px}.podium-name{color:var(--gray-700,#374151);font-size:13px;font-weight:600}.podium-block{border-radius:8px 8px 0 0;justify-content:center;align-items:center;width:80px;display:flex}.podium-block-1st{background:linear-gradient(180deg, var(--purple-primary) 0%, var(--purple-dark) 100%);height:80px}.podium-block-2nd{background:linear-gradient(180deg, var(--purple-light) 0%, var(--purple-primary) 100%);height:60px}.podium-block-3rd{background:linear-gradient(180deg, var(--purple-lighter) 0%, var(--purple-light) 100%);height:44px}.podium-rank-num{color:#ffffffe6;font-size:22px;font-weight:800}.rank-list-section{background:#fff;border-radius:20px;padding:24px;box-shadow:0 4px 20px #0000000f}.rank-tabs{gap:8px;margin-bottom:20px;display:flex}.rank-tab{background:var(--gray-100);color:var(--gray-600);border-radius:20px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.rank-tab.active{background:var(--purple-primary);color:#fff}.rank-tab:hover:not(.active){background:var(--purple-bg);color:var(--purple-primary)}.rank-list{flex-direction:column;gap:2px;display:flex}.rank-row{border-radius:10px;align-items:center;gap:12px;padding:12px 8px;transition:background .15s;display:flex}.rank-row:hover{background:var(--gray-100)}.rank-num{width:28px;color:var(--purple-primary);text-align:center;font-size:15px;font-weight:700}.rank-avatar-small{object-fit:contain;background:var(--purple-bg);border-radius:50%;width:36px;height:36px;font-size:18px}.rank-username{color:var(--gray-800);flex:1;font-size:14px;font-weight:600}.rank-score{align-items:center;gap:4px;display:flex}.rank-wpm-icon{font-size:14px}.rank-wpm{color:var(--gray-600);font-size:13px}.rank-up-btn{background:var(--purple-bg);color:var(--purple-primary);border-radius:50%;width:28px;height:28px;font-size:14px;font-weight:700;transition:background .15s}.rank-up-btn:hover{background:var(--purple-lighter)}.rank-tabs-top{justify-content:center;margin-bottom:28px}.podium-cpm{color:#ffffffd9;margin-top:2px;font-size:11px;font-weight:600;display:block}.rank-row-me{background:#ede9fe;border-color:#c4b5fd}.rank-me-badge{background:var(--purple-primary,#8758ff);color:#fff;vertical-align:middle;border-radius:10px;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.rank-session-count{color:#9ca3af;margin-left:8px;font-size:12px}.rank-avatar-small{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.rank-avatar-img{opacity:.9;width:20px;height:20px}.ranking-loading{text-align:center;color:#9ca3af;padding:60px;font-size:15px}.ranking-empty{text-align:center;color:#6b7280;padding:60px 20px}.ranking-empty-sub{color:#9ca3af;margin-top:8px;font-size:13px}.profile-page{background:var(--gray-100);min-height:calc(100vh - 56px);padding:32px 24px}.profile-container{flex-direction:column;gap:20px;max-width:860px;margin:0 auto;display:flex}.profile-header-card{background:#fff;border-radius:20px;align-items:center;gap:24px;padding:28px;display:flex;box-shadow:0 4px 20px #0000000f}.profile-mascot-wrap{flex-shrink:0;width:80px;height:80px;position:relative}.profile-mascot-bg{background:var(--purple-bg);border-radius:50%;position:absolute;inset:0}.profile-mascot{z-index:1;object-fit:contain;width:56px;height:56px;display:block;position:relative}.profile-info{flex:1}.profile-username{color:var(--gray-800);margin-bottom:12px;font-size:20px;font-weight:700}.profile-level-row{align-items:center;gap:10px;margin-bottom:8px;display:flex}.profile-level-label{color:var(--gray-600);white-space:nowrap;font-size:13px}.profile-xp-bar{background:var(--gray-200);border-radius:5px;flex:1;max-width:220px;height:10px;overflow:hidden}.profile-xp-fill{background:linear-gradient(90deg, var(--purple-primary), var(--green-primary));border-radius:5px;height:100%;transition:width .4s}.profile-xp-text{color:var(--purple-primary);font-size:13px;font-weight:600}.profile-xp-max{color:var(--gray-400);font-size:13px}.profile-attendance{color:var(--gray-600);font-size:13px}.grape-grid{flex-shrink:0;grid-template-columns:repeat(6,1fr);gap:6px;display:grid}.grape-item{object-fit:contain;width:28px;height:28px}.chart-card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 4px 20px #0000000f}.chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.chart-title{color:var(--gray-800);font-size:15px;font-weight:600}.chart-ranges{gap:6px;display:flex}.range-btn{background:var(--gray-100);color:var(--gray-600);border-radius:12px;padding:4px 10px;font-size:12px;font-weight:500;transition:all .15s}.range-btn.active{background:var(--purple-primary);color:#fff}.range-btn:hover:not(.active){background:var(--purple-bg);color:var(--purple-primary)}.monthly-chart-wrap{align-items:flex-end;gap:16px;display:flex}.monthly-mascot{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.monthly-mascot-emoji{object-fit:contain;width:60px;height:60px}.monthly-speech-bubble{background:var(--purple-primary);color:#fff;text-align:center;border-radius:12px;max-width:120px;padding:8px 12px;font-size:12px;line-height:1.5;position:relative}.monthly-speech-bubble:before{content:"";border:4px solid #0000;border-bottom-color:var(--purple-primary);position:absolute;top:-8px;left:50%;transform:translate(-50%)}.profile-level-badge{margin-bottom:8px;font-size:15px;font-weight:700}.profile-stat-row{gap:20px;margin-top:12px;display:flex}.profile-mini-stat{flex-direction:column;align-items:center;gap:2px;display:flex}.profile-mini-value{color:var(--gray-800);font-size:22px;font-weight:800;line-height:1}.profile-mini-label{color:#9ca3af;white-space:nowrap;font-size:11px;font-weight:500}.chart-range-tabs{gap:6px;display:flex}.profile-loading,.chart-empty{text-align:center;color:#9ca3af;padding:40px;font-size:14px}.profile-logout-btn{color:#9ca3af;cursor:pointer;background:0 0;border:1.5px solid #e5e7eb;border-radius:8px;align-self:flex-start;margin-top:16px;padding:8px 20px;font-size:13px;font-weight:500;transition:border-color .15s,color .15s}.profile-logout-btn:hover{color:#ef4444;border-color:#ef4444}.custom-page{background:var(--gray-50,#f9fafb);min-height:100vh;padding:40px 0 80px}.custom-container{max-width:860px;margin:0 auto;padding:0 20px}.custom-header-row{justify-content:space-between;align-items:flex-end;margin-bottom:32px;display:flex}.custom-page-title{color:var(--gray-800,#1f2937);margin:0 0 4px;font-size:28px;font-weight:800}.custom-page-sub{color:#9ca3af;margin:0;font-size:14px}.custom-create-btn{background:var(--purple-primary,#8758ff);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s cubic-bezier(.4,0,.2,1)}.custom-create-btn:hover{background:#6e58ff}.custom-login-prompt{flex-direction:column;align-items:center;gap:16px;padding:80px 20px;display:flex}.custom-login-logo{opacity:.4;width:72px}.custom-login-text{color:#6b7280;margin:0;font-size:16px}.custom-login-btn{background:var(--purple-primary,#8758ff);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600}.custom-login-btn:hover{background:#6e58ff}.custom-loading{text-align:center;color:#9ca3af;padding:60px;font-size:14px}.custom-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;display:flex}.custom-empty-title{color:var(--gray-800,#1f2937);margin:0;font-size:18px;font-weight:700}.custom-empty-sub{color:#9ca3af;max-width:360px;margin:0;font-size:14px;line-height:1.6}.custom-dict-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.dict-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;gap:16px;padding:20px;transition:box-shadow .2s cubic-bezier(.4,0,.2,1);display:flex}.dict-card:hover{box-shadow:0 4px 16px #8758ff1f}.dict-card-body{flex-direction:column;flex:1;gap:6px;display:flex}.dict-card-name{color:var(--gray-800,#1f2937);margin:0;font-size:17px;font-weight:700}.dict-card-meta{color:var(--purple-primary,#8758ff);margin:0;font-size:13px;font-weight:600}.dict-card-preview{color:#9ca3af;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.dict-card-actions{gap:8px;display:flex}.dict-action-btn{cursor:pointer;border:none;border-radius:6px;flex:1;padding:8px 0;font-size:13px;font-weight:600;transition:opacity .15s}.dict-action-btn:disabled{opacity:.5;cursor:not-allowed}.dict-action-btn.practice{background:var(--purple-primary,#8758ff);color:#fff}.dict-action-btn.practice:hover:not(:disabled){background:#6e58ff}.dict-action-btn.edit{color:#374151;background:#f3f4f6}.dict-action-btn.edit:hover{background:#e5e7eb}.dict-action-btn.delete{color:#ef4444;background:#fef2f2}.dict-action-btn.delete:hover:not(:disabled){background:#fee2e2}.dict-modal-backdrop{z-index:1000;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dict-modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.dict-modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.dict-modal-title{color:var(--gray-800,#1f2937);margin:0;font-size:18px;font-weight:700}.dict-modal-close{color:#9ca3af;cursor:pointer;background:0 0;border:none;padding:4px;font-size:18px;line-height:1}.dict-modal-close:hover{color:#374151}.dict-modal-form{flex-direction:column;gap:6px;padding:20px 24px 24px;display:flex}.dict-field-label{color:#374151;justify-content:space-between;align-items:center;margin-top:10px;font-size:13px;font-weight:600;display:flex}.dict-word-count{color:#9ca3af;font-size:12px;font-weight:400}.dict-field-input{color:#1f2937;border:1.5px solid #e5e7eb;border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.dict-field-input:focus{border-color:var(--purple-primary,#8758ff)}.dict-field-textarea{color:#1f2937;resize:vertical;border:1.5px solid #e5e7eb;border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:14px;line-height:1.6;transition:border-color .15s}.dict-field-textarea:focus{border-color:var(--purple-primary,#8758ff)}.dict-modal-error{color:#ef4444;margin:4px 0 0;font-size:13px}.dict-modal-actions{justify-content:flex-end;gap:10px;margin-top:12px;display:flex}.dict-btn-cancel{color:#374151;cursor:pointer;background:#f3f4f6;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600}.dict-btn-cancel:hover{background:#e5e7eb}.dict-btn-save{background:var(--purple-primary,#8758ff);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .15s}.dict-btn-save:hover:not(:disabled){background:#6e58ff}.dict-btn-save:disabled{opacity:.6;cursor:not-allowed}.typing-page{background:var(--gray-100);min-height:calc(100vh - 56px)}.typing-header{background:var(--purple-primary);height:72px;position:relative}.typing-header-wave{height:48px;position:absolute;bottom:0;left:0;right:0}.typing-wave-svg{width:100%;height:100%}.typing-container{flex-direction:column;gap:24px;max-width:900px;margin:0 auto;padding:24px 24px 48px;display:flex}.mode-card,.practice-card,.activity-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 20px #0000000f}.mode-card{padding:28px 32px}.mode-options{flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;display:flex}.mode-bracket{color:var(--purple-primary);flex-shrink:0;padding:0 4px;font-size:44px;font-weight:700;line-height:1}.mode-btn{background:var(--gray-100);border:2px solid #0000;border-radius:14px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:2px;min-width:88px;height:72px;transition:background .15s,border-color .15s,box-shadow .15s;display:flex}.mode-btn:hover{background:var(--purple-bg);border-color:var(--purple-lighter)}.mode-btn.active{background:var(--purple-bg);border-color:var(--purple-primary);box-shadow:0 4px 12px #8758ff2e}.mode-btn-line{color:#6b7280;font-size:13px;font-weight:600;line-height:1.4}.mode-btn.active .mode-btn-line{color:var(--purple-dark)}.practice-card{align-items:stretch;min-height:280px;display:flex}.practice-idle{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;padding:48px 32px;display:flex}.idle-desc{color:#6b7280;font-size:16px;font-weight:500}.idle-controls{flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;display:flex}.practice-countdown{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:48px;display:flex}.practice-playing{flex-direction:column;flex:1;gap:20px;padding:28px 32px;display:flex}.practice-result{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:32px;padding:48px 32px;display:flex}.practice-lang-toggle{background:var(--gray-100);border-radius:10px;gap:2px;padding:3px;display:flex}.practice-lang-btn{color:#6b7280;background:0 0;border-radius:8px;padding:7px 20px;font-size:13px;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.practice-lang-btn.active{color:var(--purple-primary);background:#fff;box-shadow:0 2px 8px #8758ff26}.practice-lang-btn:not(.active):hover{color:var(--purple-primary)}.practice-duration-row{gap:6px;display:flex}.practice-duration-btn{color:#6b7280;background:var(--gray-100);border:2px solid #0000;border-radius:10px;padding:8px 22px;font-size:14px;font-weight:700;transition:background .15s,color .15s,border-color .15s}.practice-duration-btn.active{color:var(--purple-primary);background:var(--purple-bg);border-color:var(--purple-primary)}.practice-duration-btn:not(.active):hover{color:var(--purple-primary);background:var(--purple-bg)}.practice-start-btn{color:#fff;background:var(--purple-primary);border-radius:12px;padding:14px 48px;font-size:16px;font-weight:700;transition:background .15s,transform .15s,box-shadow .15s;box-shadow:0 4px 16px #8758ff4d}.practice-start-btn:hover{background:var(--purple-light);transform:translateY(-2px);box-shadow:0 6px 20px #8758ff66}.practice-start-btn:active{transform:translateY(0)}@keyframes countPop{0%{opacity:0;transform:scale(1.5)}to{opacity:1;transform:scale(1)}}.playing-topbar{justify-content:space-between;align-items:center;display:flex}.playing-stat{flex-direction:column;align-items:center;gap:4px;min-width:72px;display:flex}.playing-stat-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.playing-stat-value{color:var(--gray-800);font-size:32px;font-weight:800;line-height:1}.playing-timer-wrap{align-items:center;display:flex}.playing-timer-svg{width:72px;height:72px}.playing-character{justify-content:center;display:flex}.playing-character-img{object-fit:contain;width:100px;height:100px}.arena-text{background:var(--gray-100);letter-spacing:.04em;cursor:text;-webkit-user-select:none;user-select:none;word-break:break-all;overflow-wrap:break-word;white-space:pre-wrap;border-radius:16px;padding:24px 28px;font-size:20px;line-height:2.2}.result-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.1em;font-size:12px;font-weight:700}.result-stats-row{align-items:center;gap:28px;display:flex}.result-stat{flex-direction:column;align-items:center;gap:6px;display:flex}.result-stat-value{color:var(--gray-800);font-size:52px;font-weight:800;line-height:1}.result-stat-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:12px;font-weight:600}.result-stat-divider{background:var(--gray-200);width:1px;height:52px}.result-errors{flex-direction:column;align-items:center;gap:12px;display:flex}.result-errors-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.result-errors-row{gap:10px;display:flex}.result-error-chip{background:#fef2f2;border:1.5px solid #fecaca;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:12px 20px;display:flex}.result-error-jamo{color:#ef4444;font-size:26px;font-weight:800}.result-error-count{color:#f87171;font-size:12px;font-weight:600}.activity-card{padding:24px 28px}.activity-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.activity-title{color:var(--gray-800);font-size:15px;font-weight:700}.activity-login-hint{color:#9ca3af;font-size:12px}.activity-login-link{color:var(--purple-primary);background:0 0;font-weight:600;text-decoration:underline}.activity-content{align-items:flex-end;gap:20px;display:flex}.activity-bars{flex:1;align-items:flex-end;gap:10px;height:140px;display:flex;position:relative}.activity-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:6px;height:100%;display:flex}.activity-bar{background:linear-gradient(180deg, var(--purple-primary) 0%, var(--purple-lighter) 100%);border-radius:4px 4px 0 0;width:100%;min-height:4px;transition:height .4s}.activity-bar-label{color:#9ca3af;white-space:nowrap;font-size:10px}.activity-empty{color:#9ca3af;justify-content:center;align-items:center;font-size:13px;font-weight:500;display:flex;position:absolute;inset:0}.activity-mascot{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.mascot-img{object-fit:contain;width:56px;height:56px}.mascot-bubble{background:var(--purple-primary);color:#fff;text-align:center;white-space:pre-line;border-radius:12px;max-width:110px;padding:8px 12px;font-size:12px;line-height:1.5;position:relative}.mascot-bubble:before{content:"";border:4px solid #0000;border-bottom-color:var(--purple-primary);position:absolute;top:-7px;left:50%;transform:translate(-50%)}.custom-dict-banner{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;margin-bottom:8px;display:flex}.custom-dict-badge{color:var(--purple-primary,#8758ff);background:#ede9fe;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:700}.custom-dict-name{color:var(--gray-800,#1f2937);font-size:20px;font-weight:800}.custom-dict-count{color:#9ca3af;font-size:13px}.battle-page{background:linear-gradient(160deg,#f5f3ff 0%,#ede9fe 40%,#e0d9fb 100%);min-height:calc(100vh - 56px)}.school-select{justify-content:center;align-items:flex-start;min-height:calc(100vh - 56px);padding:40px 24px;display:flex}.school-select-layout{grid-template-columns:1fr 1fr;align-items:start;gap:32px;width:100%;max-width:1100px;display:grid}.school-select-form{flex-direction:column;align-items:center;gap:20px;display:flex}.school-ranking-panel{background:#fff;border-radius:24px;padding:28px;position:sticky;top:80px;box-shadow:0 4px 20px #0000000f}.ranking-panel-title{color:var(--gray-800);margin-bottom:20px;font-size:17px;font-weight:700}.ranking-panel-empty{color:var(--gray-400);text-align:center;padding:24px 0;font-size:14px}.ranking-panel-list{flex-direction:column;gap:8px;display:flex}.ranking-panel-row{background:var(--gray-100);border:2px solid #0000;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s;display:flex}.ranking-panel-row.mine{background:var(--purple-bg);border-width:2px}.ranking-panel-pos{flex-shrink:0;justify-content:center;align-items:center;width:32px;display:flex}.ranking-panel-crown{object-fit:contain;filter:drop-shadow(0 1px 3px #00000026);width:26px;height:26px}.ranking-panel-rank-num{color:var(--gray-500,#6b7280);font-size:14px;font-weight:700}.ranking-panel-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.ranking-panel-school{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.ranking-panel-nick{color:var(--gray-400);font-size:11px}.ranking-panel-score{color:var(--gray-800);text-align:right;flex-shrink:0;width:72px;font-size:13px;font-weight:700}.ranking-panel-score small{color:var(--gray-400);font-size:10px;font-weight:400}.ranking-panel-count{color:var(--gray-400);text-align:right;flex-shrink:0;width:28px;font-size:11px}.battle-logo{text-align:center;flex-direction:column;align-items:center;display:flex}.battle-logo-emoji{object-fit:contain;filter:drop-shadow(0 4px 16px #7c3aed4d);width:80px;height:80px;margin-bottom:8px;display:block}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.battle-logo-title{color:var(--purple-primary);margin-bottom:6px;font-size:32px;font-weight:800}.battle-logo-sub{color:var(--gray-600);font-size:14px}.school-type-tabs{background:#fff;border-radius:14px;gap:6px;width:100%;padding:4px;display:flex;box-shadow:0 2px 10px #0000000f}.school-type-tab{color:var(--gray-600);background:0 0;border-radius:10px;flex:1;padding:9px 0;font-size:13px;font-weight:600;transition:all .18s}.school-type-tab.active{background:var(--purple-primary);color:#fff;box-shadow:0 3px 10px #7c3aed4d}.school-type-tab:hover:not(.active){background:var(--purple-bg);color:var(--purple-primary)}.school-search-wrap{position:relative}.school-search-input-row{align-items:center;display:flex;position:relative}.school-search-input{border:2px solid var(--gray-200);background:#fff;border-radius:14px;width:100%;padding:13px 42px 13px 18px;font-size:15px;transition:border-color .2s}.school-search-input:focus{border-color:var(--purple-light);outline:none}.school-search-spinner{border:2px solid var(--purple-lighter);border-top-color:var(--purple-primary);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;position:absolute;right:14px}@keyframes spin{to{transform:rotate(360deg)}}.school-dropdown{border:1.5px solid var(--gray-200);z-index:50;background:#fff;border-radius:14px;max-height:240px;padding:6px;list-style:none;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001a}.school-dropdown-item{cursor:pointer;border-radius:9px;padding:10px 12px;transition:background .12s}.school-dropdown-item:hover{background:var(--purple-bg)}.school-dropdown-name{color:var(--gray-800);font-size:14px;font-weight:600}.school-dropdown-meta{color:var(--gray-400);margin-top:2px;font-size:12px}.school-dropdown-empty{text-align:center;color:var(--gray-400);padding:16px;font-size:14px}.selected-school-badge{color:#fff;border-radius:24px;align-items:center;gap:10px;padding:8px 18px;font-size:14px;font-weight:700;display:inline-flex;box-shadow:0 4px 12px #00000026}.selected-school-type{opacity:.8;background:#fff3;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500}.username-section{width:100%}.username-input{border:2px solid var(--gray-200);text-align:center;background:#fff;border-radius:14px;width:100%;padding:14px 20px;font-size:16px;font-weight:600;transition:border-color .2s}.username-input:focus{border-color:var(--purple-light);outline:none}.school-section-label{color:var(--gray-600);align-self:flex-start;font-size:14px;font-weight:600}.school-grid{grid-template-columns:repeat(4,1fr);gap:10px;width:100%;display:grid}.school-card{background:#fff;border:2px solid #0000;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000000d}.school-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a}.school-card.selected{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.school-emoji{font-size:20px}.school-short{color:var(--gray-700,#374151);font-size:12px;font-weight:600}.start-btn{background:linear-gradient(135deg, var(--purple-primary), var(--purple-dark));color:#fff;letter-spacing:.03em;border-radius:16px;width:100%;padding:16px;font-size:18px;font-weight:700;transition:all .2s;box-shadow:0 6px 20px #7c3aed59}.start-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 28px #7c3aed66}.start-btn:disabled{opacity:.4;cursor:not-allowed}.arena-countdown-overlay{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:calc(100vh - 56px);display:flex}.arena-logo{object-fit:contain;width:80px;height:80px;animation:2s ease-in-out infinite float}.countdown-number{color:var(--purple-primary);font-size:120px;font-weight:900;line-height:1;animation:.4s countPop}.countdown-sub{color:var(--gray-600);font-size:16px;font-weight:500}.arena{flex-direction:column;gap:28px;max-width:860px;margin:0 auto;padding:40px 24px;display:flex}.arena-topbar{background:#fff;border-radius:20px;justify-content:space-between;align-items:center;padding:20px 36px;display:flex;box-shadow:0 4px 20px #0000000f}.arena-stat{flex-direction:column;align-items:center;gap:4px;min-width:80px;display:flex}.arena-stat-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600}.arena-stat-value{color:var(--gray-800);font-size:36px;font-weight:800;line-height:1}.arena-timer-wrap{justify-content:center;align-items:center;display:flex}.arena-timer-svg{width:100px;height:100px}.arena-character{justify-content:center;margin-bottom:8px;display:flex}.arena-character-img{object-fit:contain;image-rendering:auto;width:120px;height:120px}.arena-text{letter-spacing:.05em;cursor:text;-webkit-user-select:none;user-select:none;word-break:break-all;overflow-wrap:break-word;white-space:pre-wrap;background:#fff;border-radius:20px;padding:32px;font-size:22px;line-height:2.2;box-shadow:0 4px 20px #0000000f}.phase-badge{border-radius:20px;align-self:flex-start;align-items:center;gap:6px;padding:6px 16px;font-size:13px;font-weight:700;display:inline-flex}.phase-badge.korean{color:#7c3aed;background:#ede9fe}.phase-badge.english{color:#059669;background:#dcfce7}.phase-remain{opacity:.7;font-weight:400}.arena-transition{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:60px 0;display:flex}.transition-label{color:var(--gray-600);font-size:18px;font-weight:600}.transition-count{color:#f59e0b;font-size:100px;font-weight:900;line-height:1;animation:.4s countPop}.transition-sub{color:var(--gray-400);font-size:15px}.arena-input-preview{letter-spacing:.04em;color:var(--gray-400);word-break:break-all;min-height:1.5em;font-size:22px;line-height:2}.arena-input-hidden{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.arena-hint{text-align:center;color:var(--gray-400);font-size:13px}.result-page{min-height:calc(100vh - 56px);padding:40px 24px}.result-container{flex-direction:column;gap:20px;max-width:720px;margin:0 auto;display:flex}.result-score-card{text-align:center;background:#fff;border-radius:24px;flex-direction:column;align-items:center;gap:12px;padding:40px;display:flex;box-shadow:0 8px 32px #7c3aed1f}.result-mascot{object-fit:contain;width:80px;height:80px;animation:3s ease-in-out infinite float}.result-username{color:var(--gray-800);font-size:22px;font-weight:700}.result-school-badge{color:#fff;border-radius:20px;padding:4px 16px;font-size:13px;font-weight:700;display:inline-block}.result-main-score{align-items:baseline;gap:8px;margin:4px 0;display:flex}.result-score-num{color:var(--purple-primary);font-size:64px;font-weight:900;line-height:1}.result-score-unit{color:var(--gray-400);font-size:20px;font-weight:600}.result-comment{color:var(--purple-light);font-size:18px;font-weight:700}.result-sub-stats{gap:32px;margin-top:8px;display:flex}.result-sub-stat{flex-direction:column;align-items:center;gap:4px;display:flex}.result-sub-label{color:var(--gray-400);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.result-sub-value{color:var(--gray-800);font-size:20px;font-weight:700}.school-ranking-card{background:#fff;border-radius:24px;padding:28px;box-shadow:0 4px 20px #0000000f}.school-ranking-title{color:var(--gray-800);align-items:center;gap:10px;margin-bottom:20px;font-size:16px;font-weight:700;display:flex}.school-ranking-mode{background:var(--purple-bg);color:var(--purple-primary);border-radius:10px;padding:2px 10px;font-size:12px}.school-ranking-list{flex-direction:column;gap:10px;display:flex}.school-rank-row{background:var(--gray-100);border:2px solid #0000;border-radius:12px;align-items:center;gap:10px;padding:10px 14px;transition:background .15s;display:flex}.school-rank-row.mine{background:var(--purple-bg);border-width:2px}.school-rank-pos{text-align:center;justify-content:center;align-items:center;width:32px;font-size:15px;display:flex}.rank-crown-img{object-fit:contain;filter:drop-shadow(0 1px 4px #00000026);width:28px;height:28px}.school-rank-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.school-rank-school{color:var(--gray-800);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.school-rank-nick{color:var(--gray-400);font-size:11px}.school-rank-score{color:var(--gray-800);text-align:right;flex-shrink:0;width:80px;font-size:14px;font-weight:700}.school-rank-score small{color:var(--gray-400);font-size:11px;font-weight:400}.school-rank-count{color:var(--gray-400);text-align:right;flex-shrink:0;width:32px;font-size:12px}.result-actions{gap:12px;display:flex}.result-retry-btn{background:linear-gradient(135deg, var(--purple-primary), var(--purple-dark));color:#fff;border-radius:16px;flex:1;padding:16px;font-size:16px;font-weight:700;transition:all .2s;box-shadow:0 6px 20px #7c3aed4d}.result-retry-btn:hover{transform:translateY(-2px);box-shadow:0 10px 28px #7c3aed66}.result-change-btn{color:var(--purple-primary);border:2px solid var(--purple-lighter);background:#fff;border-radius:16px;padding:16px 28px;font-size:15px;font-weight:600;transition:all .2s}.result-change-btn:hover{background:var(--purple-bg)}.real-battle-page{background:var(--gray-50,#f9fafb);min-height:calc(100vh - 60px);padding:32px 16px}.rb-btn-primary{background:var(--purple-primary,#8758ff);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:700;transition:background .2s cubic-bezier(.4,0,.2,1),transform .15s cubic-bezier(.4,0,.2,1)}.rb-btn-primary:hover{background:#6e58ff}.rb-btn-primary:active{transform:scale(.97)}.rb-btn-primary:disabled{opacity:.4;cursor:default}.rb-btn-ghost{color:var(--gray-600,#4b5563);border:1.5px solid var(--gray-300,#d1d5db);cursor:pointer;background:0 0;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:500;transition:border-color .2s,color .2s}.rb-btn-ghost:hover{border-color:var(--purple-primary,#8758ff);color:var(--purple-primary)}.rb-lobby{max-width:720px;margin:0 auto}.rb-lobby-header{text-align:center;margin-bottom:40px}.rb-lobby-title{color:var(--gray-900,#111827);margin:0 0 8px;font-size:32px;font-weight:800}.rb-lobby-sub{color:var(--gray-500,#6b7280);margin:0;font-size:15px}.rb-mode-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;display:grid}@media (width<=540px){.rb-mode-grid{grid-template-columns:1fr}}.rb-mode-card{text-align:left;cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:32px 24px;transition:border-color .2s,box-shadow .2s,transform .15s;position:relative}.rb-mode-card:hover{border-color:var(--purple-primary,#8758ff);transform:translateY(-2px);box-shadow:0 4px 20px #8758ff26}.rb-mode-icon{margin-bottom:12px;font-size:36px}.rb-mode-name{color:var(--gray-900);margin:0 0 8px;font-size:20px;font-weight:800}.rb-mode-desc{color:var(--gray-500,#6b7280);margin:0;font-size:13px;line-height:1.6}.rb-mode-badge{border-radius:4px;padding:3px 10px;font-size:11px;font-weight:700;position:absolute;top:16px;right:16px}.rb-badge-ranked{color:#7c3aed;background:#ede9fe}.rb-badge-custom{color:#92400e;background:#fef9c3}.rb-custom-box{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:24px}.rb-custom-label{color:var(--gray-700);margin:0 0 12px;font-size:14px;font-weight:600}.rb-custom-row{gap:8px;margin-bottom:12px;display:flex}.rb-custom-input{letter-spacing:.05em;border:1.5px solid #d1d5db;border-radius:8px;outline:none;flex:1;padding:10px 14px;font-size:15px;font-weight:600;transition:border-color .2s}.rb-custom-input:focus{border-color:var(--purple-primary)}.rb-lobby-card{text-align:center;padding:60px 24px}.rb-login-hint{color:var(--gray-500);margin-bottom:24px;font-size:16px}.rb-matching{justify-content:center;align-items:center;min-height:60vh;display:flex}.rb-matching-card{text-align:center;background:#fff;border-radius:16px;min-width:320px;padding:48px 40px;box-shadow:0 4px 24px #00000014}.rb-spinner{border:5px solid #e5e7eb;border-top-color:var(--purple-primary,#8758ff);border-radius:50%;width:56px;height:56px;margin:0 auto 20px;animation:.8s linear infinite rb-spin}@keyframes rb-spin{to{transform:rotate(360deg)}}.rb-matching-title{color:var(--gray-900);margin:0 0 8px;font-size:22px;font-weight:800}.rb-matching-elapsed{color:var(--purple-primary,#8758ff);font-variant-numeric:tabular-nums;margin:0 0 8px;font-size:28px;font-weight:800}.rb-matching-hint{color:var(--gray-500);margin:0 0 24px;font-size:13px}.rb-matching-dots{justify-content:center;gap:8px;margin-bottom:28px;display:flex}.rb-matching-dots span{background:var(--purple-primary,#8758ff);border-radius:50%;width:10px;height:10px;animation:1.2s ease-in-out infinite rb-bounce}.rb-matching-dots span:nth-child(2){animation-delay:.2s}.rb-matching-dots span:nth-child(3){animation-delay:.4s}@keyframes rb-bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.rb-cancel-btn{margin-top:4px}.rb-arena{max-width:800px;margin:0 auto;position:relative}.rb-countdown-overlay{z-index:100;color:#fff;background:#000000bf;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.rb-countdown-vs{align-items:center;gap:32px;margin-bottom:24px;font-size:22px;font-weight:700;display:flex}.rb-vs{color:#9ca3af;font-size:16px;font-weight:500}.rb-countdown-num{color:var(--purple-primary,#8758ff);font-size:96px;font-weight:900;line-height:1;animation:.5s cubic-bezier(.4,0,.2,1) rb-pop}@keyframes rb-pop{0%{opacity:0;transform:scale(.5)}60%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.rb-topbar{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:16px 24px;display:flex;box-shadow:0 1px 6px #0000000f}.rb-player-stat{flex-direction:column;gap:4px;display:flex}.rb-player-stat.rb-opp{text-align:right;align-items:flex-end}.rb-player-name{color:var(--gray-500);font-size:13px;font-weight:600}.rb-cpm{font-size:22px;font-weight:800}.rb-acc{color:var(--gray-500);font-size:13px}.rb-finished-tag{color:#16a34a;background:#dcfce7;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:700}.rb-progress-wrap{background:#fff;border-radius:12px;flex-direction:column;gap:12px;margin-bottom:16px;padding:16px 24px;display:flex;box-shadow:0 1px 6px #0000000f}.rb-progress-row{align-items:center;gap:10px;display:flex}.rb-progress-label{width:28px;color:var(--gray-500);flex-shrink:0;font-size:12px;font-weight:600}.rb-progress-track{background:#f3f4f6;border-radius:5px;flex:1;height:10px;overflow:hidden}.rb-progress-fill{border-radius:5px;height:100%;transition:width .3s cubic-bezier(.4,0,.2,1)}.rb-fill-me{background:var(--purple-primary,#8758ff)}.rb-fill-opp{background:#f59e0b}.rb-progress-pct{text-align:right;width:36px;color:var(--gray-600);flex-shrink:0;font-size:12px;font-weight:700}.rb-text{cursor:text;background:#fff;border-radius:12px;min-height:100px;padding:24px;font-size:20px;line-height:1.8;box-shadow:0 1px 6px #0000000f}.rb-my-done{text-align:center;background:#f0fdf4;border:2px solid #86efac;border-radius:12px;padding:32px}.rb-my-done p{color:#15803d;margin:0 0 8px;font-size:16px;font-weight:600}.rb-my-done-cpm{color:var(--purple-primary);font-size:36px;font-weight:900}.rb-result{text-align:center;max-width:480px;margin:0 auto}.rb-verdict{margin-bottom:32px;font-size:52px;font-weight:900;line-height:1;animation:.5s cubic-bezier(.4,0,.2,1) rb-pop}.rb-cpm-compare{background:#fff;border-radius:12px;justify-content:center;align-items:flex-end;gap:12px;margin-bottom:28px;padding:24px;display:flex;box-shadow:0 1px 8px #0000000f}.rb-cpm-col{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.rb-cpm-bar-wrap{background:#f3f4f6;border-radius:6px 6px 0 0;align-items:flex-end;width:60px;height:120px;display:flex;overflow:hidden}.rb-cpm-bar{border-radius:6px 6px 0 0;width:100%;transition:height .6s cubic-bezier(.4,0,.2,1)}.rb-cpm-name{color:var(--gray-500);font-size:12px;font-weight:600}.rb-cpm-val{color:var(--gray-900);font-size:24px;font-weight:800}.rb-acc-val{color:var(--gray-500);font-size:12px}.rb-cpm-vs-label{color:var(--gray-400);align-self:center;padding-bottom:8px;font-size:11px;font-weight:700}.rb-mmr-delta{background:#fff;border-radius:12px;justify-content:center;align-items:center;gap:12px;margin-bottom:28px;padding:16px;display:flex;box-shadow:0 1px 8px #0000000f}.rb-mmr-label{color:var(--gray-600);font-size:14px;font-weight:600}.rb-mmr-value{font-size:28px;font-weight:900}.rb-result-btns{justify-content:center;gap:12px;display:flex}.btn-primary{background:var(--purple-primary);color:#fff;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;transition:background .15s}.btn-primary:hover{background:#5b21b6}.btn-primary.full-width{text-align:center;width:100%}.btn-ghost{color:#4b5563;background:0 0;border:1.5px solid #e5e7eb;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;transition:border-color .15s,color .15s}.btn-ghost:hover{border-color:var(--purple-primary);color:var(--purple-primary)}.btn-text{color:var(--purple-primary);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:0;font-size:13px;font-weight:600;text-decoration:underline}.home{background:#fff;min-height:calc(100vh - 56px)}.home-hero{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:flex-end;gap:32px;max-width:960px;margin:0 auto;padding:80px 24px 64px;display:flex}.home-eyebrow{color:var(--purple-primary);letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;font-size:13px;font-weight:500}.home-title{color:#1f2937;letter-spacing:-.02em;font-size:44px;font-weight:800;line-height:1.2}.home-hero-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.home-modes{border-bottom:1px solid #f3f4f6}.home-section-inner{max-width:960px;margin:0 auto;padding:0 24px}.home-section-label{color:#9ca3af;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;padding-top:32px;font-size:11px;font-weight:600}.mode-tabs{gap:4px;padding-bottom:0;display:flex}.mode-tab{cursor:pointer;background:0 0;border-bottom:2px solid #0000;border-radius:8px 8px 0 0;flex-direction:column;align-items:flex-start;gap:2px;padding:12px 20px;transition:background .15s,border-color .15s;display:flex}.mode-tab:hover{background:#f9fafb}.mode-tab.active{border-bottom-color:var(--purple-primary);background:#f9fafb}.mode-tab-label{color:#1f2937;font-size:14px;font-weight:600}.mode-tab.active .mode-tab-label{color:var(--purple-primary)}.mode-tab-sub{color:#9ca3af;font-size:11px}.home-content{background:#f9fafb;padding:40px 0 80px}.home-grid{grid-template-columns:1fr 340px;align-items:start;gap:20px;padding-top:0;display:grid}.home-card{background:#fff;border:1px solid #f3f4f6;border-radius:12px;padding:28px}.home-card-head{align-items:baseline;gap:10px;margin-bottom:24px;display:flex}.home-card-title{color:#1f2937;font-size:16px;font-weight:700}.home-card-meta{color:#9ca3af;font-size:12px}.home-empty{color:#9ca3af;flex-direction:column;justify-content:center;align-items:center;gap:12px;height:180px;font-size:14px;display:flex}.home-action-card{flex-direction:column;gap:20px;display:flex}.home-action-desc{color:#4b5563;font-size:14px;line-height:1.7}.home-action-stats{border-top:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6;align-items:center;gap:0;padding:16px 0;display:flex}.home-stat{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.home-stat-num{color:var(--purple-primary);font-size:28px;font-weight:800;line-height:1}.home-stat-unit{color:var(--purple-primary);font-size:13px;font-weight:600}.home-stat-label{color:#9ca3af;margin-top:4px;font-size:11px}.home-stat-divider{background:#f3f4f6;width:1px;height:36px}.home-left,.home-right,.home-goal-card{flex-direction:column;gap:20px;display:flex}.goal-progress-wrap{flex-direction:column;gap:8px;display:flex}.goal-progress-labels{color:#9ca3af;justify-content:space-between;font-size:12px;font-weight:500;display:flex}.goal-progress-track{background:#f3f4f6;border-radius:99px;height:8px;overflow:hidden}.goal-progress-fill{background:var(--purple-primary);border-radius:99px;height:100%;transition:width .6s}.goal-progress-meta{color:#6b7280;justify-content:space-between;font-size:12px;display:flex}.goal-today{background:#f9fafb;border-radius:12px;flex-direction:column;gap:6px;padding:20px;display:flex}.goal-today-label{color:#9ca3af;letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:700}.goal-today-minutes{color:var(--purple-primary);letter-spacing:-1px;font-size:48px;font-weight:800;line-height:1}.goal-today-minutes span{color:#6b7280;margin-left:4px;font-size:20px;font-weight:600}.goal-today-sub{color:#6b7280;margin-bottom:4px;font-size:13px}.goal-warning{color:#f59e0b;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;padding:6px 10px;font-size:12px}.goal-start-btn{margin-top:8px}.goal-achieved{color:#374151;background:#6de70114;border:1px solid #6de7014d;border-radius:10px;padding:14px 16px;font-size:14px}.home-goal-empty{background:linear-gradient(135deg,#8758ff0a,#8758ff14);border-color:#8758ff33;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;display:flex}.home-goal-empty-title{color:#1f2937;margin:0 0 4px;font-size:15px;font-weight:700}.home-goal-empty-sub{color:#6b7280;margin:0;font-size:13px;line-height:1.5}.landing{--lbg:#fff;--lcard:#f9fafb;--lborder:#e5e7eb;--ltext:#111827;--lsub:#6b7280;--lprimary:#8758ff;--lhover:#7248ee;--ease:cubic-bezier(.4, 0, .2, 1);background:var(--lbg);color:var(--ltext);scrollbar-width:thin;scrollbar-color:var(--lborder) transparent;min-height:100vh;font-family:GmarketSans,Noto Sans KR,sans-serif;overflow-x:hidden}.landing::-webkit-scrollbar{width:3px}.landing::-webkit-scrollbar-thumb{background:var(--lborder);border-radius:99px}@keyframes l-blink{0%,to{opacity:1}50%{opacity:0}}.intro-overlay{z-index:1000;background:var(--lbg);transition:background .18s var(--ease);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.intro-overlay.intro-flash{background:var(--lprimary)}.intro-text{letter-spacing:-2px;color:var(--ltext);font-size:72px;font-weight:700}.intro-overlay.intro-flash .intro-text{color:#fff}.intro-cursor{color:var(--lprimary);animation:.9s step-end infinite l-blink}.intro-overlay.intro-flash .intro-cursor{color:#ffffffb3}.l-nav{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);opacity:0;height:64px;transition:opacity .5s var(--ease) .15s, transform .5s var(--ease) .15s;pointer-events:none;background:#ffffffeb;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:0 48px;display:flex;position:fixed;top:0;left:0;right:0;transform:translateY(-16px);box-shadow:0 1px #0000000f}.l-nav.l-nav-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.l-nav-logo{letter-spacing:-.5px;color:var(--ltext);font-size:20px;font-weight:700}.l-nav-accent{color:var(--lprimary)}.l-nav-links{gap:28px;font-size:13px;font-weight:500;display:flex}.l-nav-link{color:var(--lsub);transition:color .15s var(--ease);text-decoration:none}.l-nav-link:hover{color:var(--ltext)}.l-nav-cta{background:var(--lprimary);color:#fff;cursor:pointer;transition:background .15s var(--ease);border:none;border-radius:8px;padding:9px 20px;font-family:inherit;font-size:13px;font-weight:700}.l-nav-cta:hover{background:var(--lhover)}.l-hero{justify-content:center;align-items:center;min-height:100vh;padding:80px 48px 60px;display:flex;position:relative;overflow:hidden}.l-hero-dotgrid{pointer-events:none;background-image:radial-gradient(circle,#00000012 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 70% at 50% 40%,#000 20%,#0000 100%);mask-image:radial-gradient(80% 70% at 50% 40%,#000 20%,#0000 100%)}.l-hero-inner{z-index:1;opacity:0;width:100%;max-width:1160px;transition:opacity .65s var(--ease), transform .65s var(--ease);grid-template-columns:5fr 6fr;align-items:center;gap:80px;display:grid;position:relative;transform:translateY(32px)}.l-hero-inner.l-hero-inner-visible{opacity:1;transform:translateY(0)}.l-hero-left{flex-direction:column;align-items:flex-start;display:flex}.l-hero-right{opacity:0;transition:opacity .7s var(--ease) .3s, transform .7s var(--ease) .3s;justify-content:center;align-items:center;display:flex;transform:translate(24px)}.l-hero-right.l-hero-right-visible{opacity:1;transform:translate(0)}.l-hero-h1{letter-spacing:-2px;color:var(--ltext);text-align:left;margin-bottom:24px;font-size:64px;font-weight:700;line-height:1.1}.l-hero-sub{color:var(--lsub);text-align:left;max-width:440px;margin-bottom:36px;font-size:15px;font-weight:300;line-height:1.9}.l-hero-cta-row{flex-wrap:wrap;justify-content:flex-start;gap:12px;display:flex}.l-btn-primary{background:var(--lprimary);color:#fff;cursor:pointer;transition:background .15s var(--ease), transform .15s var(--ease);border:none;border-radius:8px;padding:15px 36px;font-family:inherit;font-size:15px;font-weight:700}.l-btn-primary:hover{background:var(--lhover);transform:translateY(-2px)}.l-btn-ghost{color:var(--lsub);border:1px solid var(--lborder);cursor:pointer;transition:color .15s var(--ease), border-color .15s var(--ease);background:0 0;border-radius:8px;padding:15px 36px;font-family:inherit;font-size:15px;font-weight:500}.l-btn-ghost:hover{color:var(--ltext);border-color:#fff3}.l-btn-hero{border-radius:10px;width:100%;max-width:320px;padding:17px 32px;font-size:16px}.l-hero-trust{flex-wrap:wrap;gap:20px;margin-top:16px;display:flex}.l-trust-item{color:var(--lsub);font-size:12px;font-weight:500}.hero-mockup{border:1px solid var(--lborder);background:#fff;border-radius:14px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 8px 40px #0000001a,0 1px 3px #0000000f}.hero-mockup-bar{background:var(--lcard);border-bottom:1px solid var(--lborder);align-items:center;gap:6px;padding:10px 16px;display:flex}.hero-mockup-dot{background:var(--lborder);border-radius:50%;width:10px;height:10px}.hero-mockup-body{flex-direction:column;gap:14px;padding:24px;display:flex}.hero-mockup-label{letter-spacing:2px;text-transform:uppercase;color:var(--lsub);font-size:11px;font-weight:700}.hero-mockup-row{justify-content:space-between;align-items:center;font-size:14px;display:flex}.hero-mockup-key{color:var(--lsub);font-weight:400}.hero-mockup-val{color:var(--ltext);font-weight:600}.hero-mockup-divider{background:var(--lborder);height:1px}.hero-mockup-result{background:var(--lprimary);border-radius:10px;padding:16px 20px}.hero-mockup-result-num{color:#fff;letter-spacing:-.5px;font-size:24px;font-weight:700}.hero-mockup-result-sub{color:#ffffffbf;margin-top:4px;font-size:13px}.hero-mockup-progress-wrap{flex-direction:column;gap:8px;display:flex}.hero-mockup-progress-label{color:var(--lsub);justify-content:space-between;font-size:12px;display:flex}.hero-mockup-progress-track{background:var(--lborder);border-radius:99px;height:6px;overflow:hidden}.hero-mockup-progress-fill{background:var(--lprimary);border-radius:99px;height:100%}.hero-mockup-stats{border:1px solid var(--lborder);border-radius:10px;gap:0;display:flex;overflow:hidden}.hero-mockup-stat{text-align:center;border-right:1px solid var(--lborder);flex:1;padding:12px}.hero-mockup-stat:last-child{border-right:none}.hero-mockup-stat-num{color:var(--ltext);letter-spacing:-.5px;font-size:18px;font-weight:700}.hero-mockup-stat-label{color:var(--lsub);margin-top:2px;font-size:11px}.demo-wrap{flex-direction:column;align-items:center;gap:16px;display:flex}.demo-text{letter-spacing:-.3px;background:var(--lcard);border:1px solid var(--lborder);text-align:left;-webkit-user-select:none;user-select:none;border-radius:10px;align-items:center;min-width:340px;padding:14px 24px;font-size:20px;font-weight:500;display:flex}.demo-typed{color:var(--ltext)}.demo-cursor{color:var(--lprimary);font-weight:300;animation:.9s step-end infinite l-blink}.demo-remaining{color:var(--lborder);opacity:.8}.kb-wrap{flex-direction:column;align-items:center;gap:5px;display:flex}.kb-row{gap:4px;display:flex}.kb-key{background:var(--lcard);border:1px solid var(--lborder);width:38px;height:38px;color:var(--lsub);transition:background .1s var(--ease), border-color .1s var(--ease), color .1s var(--ease);-webkit-user-select:none;user-select:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex;position:relative}.kb-key.kb-key-lit{background:var(--lprimary);border-color:var(--lprimary);color:#fff}.kb-shift{opacity:.4;font-size:8px;font-weight:700;position:absolute;top:3px;left:4px}.kb-key.kb-key-lit .kb-shift{opacity:.6}.kb-space{background:var(--lcard);border:1px solid var(--lborder);width:200px;height:30px;transition:background .1s var(--ease), border-color .1s var(--ease);border-radius:6px;margin-top:1px}.kb-space.kb-key-lit{background:var(--lprimary);border-color:var(--lprimary)}.l-stats{border-top:1px solid var(--lborder);opacity:0;max-width:1080px;transition:opacity .5s var(--ease), transform .5s var(--ease);flex-wrap:wrap;gap:16px;margin:0 auto;padding:72px 48px;display:flex;transform:translateY(20px)}.l-stats.l-stats-visible{opacity:1;transform:translateY(0)}.stat-card{background:var(--lcard);border:1px solid var(--lborder);min-width:180px;transition:transform .2s var(--ease);border-radius:12px;flex:1;padding:28px 32px}.stat-card:hover{transform:translateY(-3px)}.stat-number{letter-spacing:-2px;color:var(--ltext);font-size:48px;font-weight:700;line-height:1}.stat-label{color:var(--lsub);margin-top:8px;font-size:13px;font-weight:300}.l-features{width:100%;max-width:1080px;margin:0 auto;padding:72px 48px}.l-section-eyebrow{color:var(--lsub);letter-spacing:3px;text-transform:uppercase;margin-bottom:14px;font-size:11px;font-weight:700}.l-features-header{margin-bottom:48px}.l-features-title{letter-spacing:-1.5px;color:var(--ltext);font-size:40px;font-weight:700;line-height:1.1}.l-feat-grid{flex-wrap:wrap;gap:16px;display:flex}.feat-card{background:var(--lcard);border:1px solid var(--lborder);opacity:0;min-width:240px;transition:opacity .5s var(--ease), transform .5s var(--ease);cursor:default;border-radius:12px;flex:1;padding:32px 28px;transform:translateY(28px)}.feat-card.feat-card-in{opacity:1;transform:translateY(0)}.feat-card:hover,.feat-card.feat-card-in:hover{transform:translateY(-3px)}.feat-num{color:var(--lsub);letter-spacing:2px;margin-bottom:20px;font-size:11px;font-weight:700}.feat-title{color:var(--ltext);letter-spacing:-.3px;margin-bottom:10px;font-size:18px;font-weight:700}.feat-desc{color:var(--lsub);font-size:14px;font-weight:300;line-height:1.75}.l-hero-eyebrow{letter-spacing:3px;text-transform:uppercase;color:var(--lprimary);margin-bottom:20px;font-size:11px;font-weight:700}.hero-td{border:1px solid var(--lborder);cursor:text;background:#fff;border-radius:14px;flex-direction:column;gap:16px;width:100%;max-width:420px;padding:28px;display:flex;box-shadow:0 8px 40px #0000001a,0 1px 3px #0000000f}.hero-td-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.hero-td-header{justify-content:space-between;align-items:center;display:flex}.hero-td-label{color:var(--lprimary);letter-spacing:.02em;font-size:13px;font-weight:700}.hero-td-stats{align-items:center;gap:2px;display:flex}.hero-td-cpm{color:var(--lprimary);letter-spacing:-.5px;font-size:20px;font-weight:700}.hero-td-cpm-unit,.hero-td-acc{color:var(--lsub);font-size:12px}.hero-td-text{letter-spacing:-.3px;background:var(--lcard);border:2px solid var(--lborder);transition:border-color .15s var(--ease);white-space:nowrap;border-radius:10px;padding:16px 20px;font-size:18px;font-weight:600;line-height:1.6;overflow:hidden}.hero-td-text.hero-td-focused{border-color:var(--lprimary)}.hero-td-pending{color:var(--lborder)}.hero-td-correct{color:var(--ltext)}.hero-td-wrong{color:#ef4444;background:#fef2f2;border-radius:2px}.hero-td-preview-top{align-items:center;gap:10px;margin-bottom:4px;display:flex}.hero-td-preview-char{object-fit:contain;flex-shrink:0;width:36px;height:36px}.try-char-row{align-items:center;gap:16px;margin-bottom:16px;display:flex}.try-char-img{object-fit:contain;flex-shrink:0;width:72px;height:72px}.hero-td-cursor{color:#d1d5db;border-left:2.5px solid var(--lprimary);animation:.9s step-end infinite blink}.hero-td-preview{cursor:pointer;animation:2.5s ease-in-out infinite hero-td-pulse}.hero-td-preview:hover{border-color:var(--lprimary);animation:none;box-shadow:0 8px 40px #8758ff2e,0 1px 3px #0000000f}@keyframes hero-td-pulse{0%,to{border-color:var(--lborder);box-shadow:0 8px 40px #0000001a}50%{border-color:var(--lprimary);box-shadow:0 8px 40px #8758ff26}}.hero-td-scroll{color:var(--lprimary);cursor:pointer;text-align:left;transition:opacity .15s var(--ease);background:0 0;border:none;padding:0;font-family:inherit;font-size:13px;font-weight:600}.hero-td-scroll:hover{opacity:.7}.l-try{border-top:1px solid var(--lborder);background:var(--lcard);padding:80px 48px}.l-try-inner{max-width:720px;margin:0 auto}.l-try-title{letter-spacing:-1px;color:var(--ltext);margin-bottom:32px;font-size:32px;font-weight:700}.try-box{border:1px solid var(--lborder);cursor:text;background:#fff;border-radius:16px;padding:32px;box-shadow:0 2px 12px #0000000f}.try-progress-bar{background:var(--lborder);border-radius:99px;height:3px;margin-bottom:28px;overflow:hidden}.try-progress-fill{background:var(--lprimary);height:100%;transition:width .4s var(--ease);border-radius:99px}.try-sentence{letter-spacing:-.3px;min-height:56px;margin-bottom:20px;font-size:22px;font-weight:600;line-height:1.6}.try-stats{align-items:center;gap:16px;min-height:28px;display:flex}.try-stat{color:var(--ltext);letter-spacing:-.5px;font-size:18px;font-weight:700}.try-stat small{color:var(--lsub);margin-left:2px;font-size:12px;font-weight:400}.try-stat-muted{color:var(--lsub);font-size:13px;font-weight:500}.try-hint{color:var(--lsub);font-size:13px;font-style:italic}.try-idx{color:var(--lsub);margin-bottom:16px;font-size:12px;font-weight:600}.try-done{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:20px 0;display:flex}.try-done-cpm{color:var(--lprimary);letter-spacing:-2px;font-size:52px;font-weight:700}.try-done-sub{color:var(--lsub);font-size:15px}.l-plan{border-top:1px solid var(--lborder);opacity:0;transition:opacity .6s var(--ease), transform .6s var(--ease);padding:80px 48px;transform:translateY(24px)}.l-plan.l-plan-visible{opacity:1;transform:translateY(0)}.l-plan-inner{max-width:860px;margin:0 auto}.l-plan-title{letter-spacing:-1.2px;color:var(--ltext);margin-bottom:12px;font-size:36px;font-weight:700;line-height:1.2}.l-plan-sub{color:var(--lsub);margin-bottom:40px;font-size:14px;line-height:1.8}.plan-calc{background:var(--lcard);border:1px solid var(--lborder);border-radius:16px;padding:36px 40px}.plan-row{flex-wrap:wrap;gap:40px;margin-bottom:28px;display:flex}.plan-field{flex-direction:column;flex:1;gap:12px;min-width:200px;display:flex}.plan-label{letter-spacing:2px;text-transform:uppercase;color:var(--lsub);font-size:11px;font-weight:700}.plan-slider-wrap{align-items:center;gap:16px;display:flex}.plan-slider{-webkit-appearance:none;background:var(--lborder);cursor:pointer;border-radius:99px;outline:none;flex:1;height:3px}.plan-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--lprimary);cursor:pointer;width:18px;height:18px;transition:transform .15s var(--ease);border-radius:50%}.plan-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.plan-slider-val{color:var(--ltext);text-align:right;letter-spacing:-.5px;min-width:72px;font-size:22px;font-weight:700}.plan-slider-val small{color:var(--lsub);margin-left:2px;font-size:13px;font-weight:400}.plan-presets{flex-wrap:wrap;gap:8px;display:flex}.plan-preset{border:1px solid var(--lborder);color:var(--lsub);cursor:pointer;transition:all .15s var(--ease);background:0 0;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:600;display:flex}.plan-preset:hover{border-color:var(--lprimary);color:var(--ltext)}.plan-preset.plan-preset-active{background:var(--lprimary);border-color:var(--lprimary);color:#fff}.plan-preset-cpm{opacity:.75;font-size:11px;font-weight:400}.plan-custom-input{background:var(--lbg);border:1px solid var(--lborder);color:var(--ltext);width:160px;transition:border-color .15s var(--ease);border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:15px;font-weight:600}.plan-custom-input:focus{border-color:var(--lprimary)}.plan-weeks{gap:8px;display:flex}.plan-week-btn{border:1px solid var(--lborder);color:var(--lsub);cursor:pointer;transition:all .15s var(--ease);background:0 0;border-radius:8px;padding:10px 20px;font-family:inherit;font-size:15px;font-weight:600}.plan-week-btn:hover{border-color:var(--lprimary);color:var(--ltext)}.plan-week-btn.plan-week-active{background:var(--lprimary);border-color:var(--lprimary);color:#fff}.plan-result{background:var(--lborder);border:1px solid var(--lborder);transition:border-color .2s var(--ease);border-radius:10px;align-items:center;gap:12px;padding:18px 24px;display:flex}.plan-result.plan-result-ok{border-color:#6de701}.plan-result.plan-result-hard{border-color:#ef4444}.plan-result-icon{color:var(--lprimary);font-size:18px;font-weight:700}.plan-result-ok .plan-result-icon{color:#6de701}.plan-result-text{color:var(--lsub);font-size:15px;font-weight:500}.plan-result-text strong{color:var(--ltext);font-weight:700}.plan-result-note{color:#ef4444;margin-left:4px;font-size:13px}.plan-cta{border-top:1px solid var(--lborder);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:20px;padding-top:20px;display:flex}.plan-cta-sub{color:var(--lsub);margin:0;font-size:14px}.plan-cta-btn{white-space:nowrap;padding:12px 28px}.l-cta{opacity:0;width:100%;max-width:1080px;transition:opacity .6s var(--ease), transform .6s var(--ease);margin:0 auto 80px;padding:0 48px;transform:translateY(24px)}.l-cta.l-cta-visible{opacity:1;transform:translateY(0)}.l-cta-card{background:var(--lcard);border:1px solid var(--lborder);border-radius:16px;flex-wrap:wrap;align-items:center;gap:80px;padding:56px 60px;display:flex}.l-cta-copy{flex:1;min-width:260px}.l-cta-title{letter-spacing:-1px;color:var(--ltext);margin-top:20px;margin-bottom:20px;font-size:32px;font-weight:700;line-height:1.3}.l-cta-body{color:var(--lsub);margin-bottom:32px;font-size:14px;font-weight:300;line-height:1.9}.l-phil{width:100%;max-width:1080px;margin:0 auto 80px;padding:0 48px}.l-phil-card{background:var(--lcard);border:1px solid var(--lborder);border-radius:16px;flex-wrap:wrap;align-items:center;gap:80px;padding:56px 60px;display:flex}.l-phil-copy{flex:1;min-width:260px}.l-phil-title{letter-spacing:-1px;color:var(--ltext);margin-top:20px;margin-bottom:20px;font-size:36px;font-weight:700;line-height:1.25}.l-phil-body{color:var(--lsub);margin-bottom:32px;font-size:14px;font-weight:300;line-height:1.9}.l-phil-bars{flex-direction:column;flex:1;gap:20px;min-width:260px;display:flex}.l-bar-row{flex-direction:column;gap:8px;display:flex}.l-bar-meta{color:var(--lsub);justify-content:space-between;font-size:12px;font-weight:500;display:flex}.l-bar-to{color:var(--lprimary)}.l-bar-track{background:var(--lborder);border-radius:99px;height:3px;overflow:hidden}.l-bar-fill{background:var(--lprimary);border-radius:99px;height:100%}.l-footer{border-top:1px solid var(--lborder);color:var(--lsub);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:36px 48px;font-size:12px;font-weight:300;display:flex}.l-footer-logo{color:var(--ltext);font-size:17px;font-weight:700}.l-footer-copy{color:var(--lsub)}.l-footer-links{gap:20px;display:flex}.l-footer-link{color:var(--lsub);transition:color .15s var(--ease);text-decoration:none}.l-footer-link:hover{color:var(--ltext)}.gs-page{background:#f9fafb;justify-content:center;align-items:center;min-height:100vh;padding:40px 24px;font-family:GmarketSans,Noto Sans KR,sans-serif;display:flex}.gs-card{background:#fff;border:1px solid #e5e7eb;border-radius:20px;flex-direction:column;gap:28px;width:100%;max-width:480px;padding:48px 40px;display:flex;box-shadow:0 4px 24px #0000000f}.gs-header{flex-direction:column;gap:8px;display:flex}.gs-title{color:#111827;letter-spacing:-.5px;margin:0;font-size:28px;font-weight:800}.gs-desc{color:#6b7280;margin:0;font-size:14px;line-height:1.6}.gs-section{flex-direction:column;gap:12px;display:flex}.gs-section-label{color:#374151;letter-spacing:.01em;font-size:13px;font-weight:700}.gs-presets{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.gs-preset{cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.gs-preset:hover{border-color:#8758ff}.gs-preset--active{background:#8758ff0f;border-color:#8758ff}.gs-preset-name{color:#111827;font-size:13px;font-weight:700}.gs-preset-cpm{color:#6b7280;font-size:12px}.gs-deadline-presets{flex-wrap:wrap;gap:8px;display:flex}.gs-deadline-btn{color:#374151;cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:600;transition:border-color .15s,background .15s}.gs-deadline-btn:hover{border-color:#8758ff}.gs-deadline-btn--active{color:#8758ff;background:#8758ff0f;border-color:#8758ff}.gs-input{color:#111827;box-sizing:border-box;background:#fff;border:1px solid #d1d5db;border-radius:8px;outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .15s}.gs-input:focus{border-color:#8758ff}.gs-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;align-items:flex-start;gap:10px;padding:16px 18px;transition:border-color .2s;display:flex}.gs-preview--warn{background:#fffbeb;border-color:#f59e0b}.gs-preview-icon{color:#8758ff;flex-shrink:0;font-weight:700}.gs-preview-text{color:#374151;font-size:14px;line-height:1.5}.gs-preview-text strong{color:#111827}.gs-preview-warning{color:#f59e0b;margin-top:4px;font-size:12px}.gs-error{color:#ef4444;text-align:center;margin:0;font-size:13px}.gs-actions{flex-direction:column;gap:10px;display:flex}.gs-btn-primary{color:#fff;cursor:pointer;background:#8758ff;border:none;border-radius:999px;width:100%;padding:16px;font-family:inherit;font-size:16px;font-weight:700;transition:background .15s,transform .1s}.gs-btn-primary:hover:not(:disabled){background:#7248ee;transform:scale(1.02)}.gs-btn-primary:disabled{opacity:.5;cursor:not-allowed}.gs-btn-skip{color:#9ca3af;cursor:pointer;background:0 0;border:none;width:100%;padding:4px;font-family:inherit;font-size:13px;transition:color .15s}.gs-btn-skip:hover{color:#6b7280}*{box-sizing:border-box;margin:0;padding:0}:root{--purple-primary:#8758ff;--purple-light:#6e58ff;--purple-lighter:#c4b5fd;--purple-bg:#f0ebff;--purple-dark:#6e58ff;--purple-deep:#5b37bf;--green-primary:#6de701;--green-dark:#03cf5d;--white:#fff;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-400:#9ca3af;--gray-600:#4b5563;--gray-800:#1f2937;--yellow:#fbbf24;--green:#03cf5d}body{background-color:var(--gray-100);color:var(--gray-800);min-height:100vh;font-family:GmarketSans,Noto Sans KR,sans-serif}button{cursor:pointer;border:none;outline:none;font-family:inherit}input{outline:none;font-family:inherit}a{color:inherit;text-decoration:none}
