*{margin:0;padding:0;box-sizing:border-box}html{padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}:root{--primary: #111;--primary-dark: #000;--primary-light: #333;--success: #111;--warning: #666;--danger: #ef4444;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--radius: 12px;--shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#fff;color:var(--gray-900);line-height:1.6;min-height:100vh}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;outline:none;-webkit-tap-highlight-color:transparent;transition:transform .1s ease,opacity .1s ease}button:active{transform:scale(.97);opacity:.9}a{text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}.page-enter{opacity:0;transform:translateY(8px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .2s ease,transform .2s ease}.card-interactive{transition:transform .15s ease,box-shadow .15s ease}.card-interactive:active{transform:scale(.98)}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.fade-in{animation:fadeInUp .25s ease forwards}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}html{scroll-behavior:smooth}@media(hover:none){button:active,.card-interactive:active{opacity:.85}}.time-warning-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.time-warning-modal{background:#fff;border-radius:24px;width:90%;max-width:320px;padding:32px 24px;text-align:center;animation:scaleIn .25s ease;box-shadow:0 20px 40px #0003}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.time-warning-icon{width:80px;height:80px;margin:0 auto 20px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:50%;display:flex;align-items:center;justify-content:center}.time-warning-title{font-size:20px;font-weight:700;color:#111;margin-bottom:12px}.time-warning-text{font-size:15px;color:#666;margin-bottom:8px;line-height:1.5}.time-warning-subtext{font-size:14px;color:#999;margin-bottom:24px}.time-warning-buttons{display:flex;flex-direction:column;gap:10px}.time-warning-btn{width:100%;padding:16px;border-radius:14px;font-size:16px;font-weight:600;transition:all .2s ease}.time-warning-btn.extend{background:#111;color:#fff}.time-warning-btn.extend:active{background:#333}.time-warning-btn.dismiss{background:#f5f5f5;color:#666}.time-warning-btn.dismiss:active{background:#e5e5e5}.settings-page{min-height:100vh;background:#f5f5f5;padding-bottom:100px}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fff;position:sticky;top:0;z-index:100}.settings-header h1{font-size:18px;font-weight:600}.settings-header .back-btn{background:transparent;padding:4px}.settings-header .header-spacer{width:40px}.page-content{padding:20px}.character-card{display:flex;align-items:center;gap:16px;background:#fff;border-radius:20px;padding:20px;margin-bottom:24px;cursor:pointer;transition:transform .2s ease}.character-card:active{transform:scale(.98)}.character-card.has-pet .pet-avatar-area{position:relative}.pet-avatar-ring{width:72px;height:72px;border-radius:50%;background:#fff;padding:4px;box-shadow:0 4px 12px #0000001a;animation:wiggle 3s ease-in-out infinite}.pet-avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover}.pet-avatar-img.loading{opacity:0}.character-shimmer{position:absolute;inset:4px;border-radius:50%;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}.pet-speech-bubble{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#111;color:#fff;font-size:11px;font-weight:600;padding:6px 12px;border-radius:12px;white-space:nowrap;animation:bubbleBounce 2s ease-in-out infinite;box-shadow:0 2px 8px #0003}.pet-speech-bubble:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #111}.character-card.no-pet .no-pet-icon-area{position:relative}.empty-pet-circle{width:72px;height:72px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 4px 12px #0000001a}.empty-pet-cat-img{width:48px;height:48px;object-fit:contain;animation:catWiggle 2.5s ease-in-out infinite}.empty-pet-plus{position:absolute;bottom:0;right:0;width:24px;height:24px;background:#ff6b35;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;border:2px solid #FFF8E7}.pet-info-area{flex:1}.pet-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:#ff6b35;margin-bottom:4px}.pet-badge:before{content:""}.pet-badge.empty{color:#999}.pet-name{font-size:16px;font-weight:600;color:#333;margin-bottom:2px}.pet-desc{font-size:13px;color:#888}.settings-section-label{font-size:13px;font-weight:500;color:#888;padding:0 4px;margin-bottom:12px}.settings-list{background:#fff;border-radius:16px;overflow:hidden;margin-bottom:24px}.settings-item-row{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .2s}.settings-item-row:last-child{border-bottom:none}.settings-item-row:active{background:#f9f9f9}.item-right{display:flex;align-items:center;gap:8px}.item-badge{font-size:14px;color:#666}.credit-row{display:flex;flex-direction:row}.credit-label-wrap{display:flex;flex-direction:column;gap:2px}.credit-sub{font-size:12px;color:#ff6b35}.credit-pill{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#fff8e1,#ffe082);padding:8px 14px;border-radius:20px;position:relative;overflow:hidden}.credit-pill.low{background:linear-gradient(135deg,#ffe5e5,#fcc)}.credit-pill.unlimited{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.credit-coin{font-size:16px;font-weight:700;color:#333}.credit-pill-text{font-size:13px;font-weight:500;color:#666}.credit-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 2s infinite}@keyframes shimmer{to{left:100%}}.profile-row{display:flex;align-items:center;gap:14px;padding:18px 20px;background:#fff;border-radius:16px;margin-bottom:24px;cursor:pointer}.profile-avatar{width:48px;height:48px;background:#f0f0f0;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#999}.profile-info{flex:1}.profile-name{font-size:16px;font-weight:600;color:#333}.profile-email{font-size:13px;color:#888}@keyframes wiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes catWiggle{0%,to{transform:rotate(-5deg) scale(1)}25%{transform:rotate(5deg) scale(1.05)}50%{transform:rotate(-3deg) scale(1)}75%{transform:rotate(3deg) scale(1.02)}}@keyframes bubbleBounce{0%,to{transform:translate(-50%) translateY(0);opacity:1}50%{transform:translate(-50%) translateY(-4px);opacity:.9}}.splash-screen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fafafa;overflow:hidden;z-index:9999}.splash-bg-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:0;animation:splashOrbIn 1.2s ease-out forwards}.splash-bg-orb-1{width:320px;height:320px;background:radial-gradient(circle,rgba(139,92,246,.18) 0%,transparent 70%);top:-60px;right:-80px;animation-delay:.2s}.splash-bg-orb-2{width:260px;height:260px;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);bottom:-40px;left:-60px;animation-delay:.4s}@keyframes splashOrbIn{to{opacity:1}}.splash-content{display:flex;flex-direction:column;align-items:center;gap:20px;z-index:1;opacity:0;transform:translateY(16px);animation:splashContentIn .8s ease-out .3s forwards}@keyframes splashContentIn{to{opacity:1;transform:translateY(0)}}.splash-logo-wrapper{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.splash-logo-icon{width:100px;height:100px;background:linear-gradient(145deg,#f8f8fc,#eeedf5);border-radius:26px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #7c6f9b26,0 2px 8px #0000000f;z-index:1}.splash-logo-icon svg{width:60px;height:60px}.splash-sparkle{animation:splashSparkle 2s ease-in-out infinite;transform-origin:58px 22px}@keyframes splashSparkle{0%,to{opacity:.7;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}.splash-logo-ring{position:absolute;inset:-4px;border-radius:30px;border:2px solid rgba(168,85,247,.15);animation:splashRingPulse 2.4s ease-in-out infinite}@keyframes splashRingPulse{0%,to{transform:scale(1);opacity:.4}50%{transform:scale(1.06);opacity:.15}}.splash-title{font-size:36px;font-weight:800;letter-spacing:-.5px;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;opacity:0;animation:splashTitleIn .7s ease-out .7s forwards}@keyframes splashTitleIn{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.splash-tagline{font-size:14.5px;line-height:1.65;color:#64748b;text-align:center;margin:0;padding:0 20px;opacity:0;animation:splashTagIn .7s ease-out 1.1s forwards}.splash-tagline-line1{display:block;white-space:nowrap}.splash-tagline-highlight{color:#7c3aed;font-weight:700}@keyframes splashTagIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.splash-loader{position:absolute;bottom:60px;width:120px;height:3px;background:#8b5cf61f;border-radius:2px;overflow:hidden;opacity:0;animation:splashTagIn .5s ease-out 1.5s forwards}.splash-loader-bar{width:100%;height:100%;background:linear-gradient(90deg,#8b5cf6,#a855f7);border-radius:2px;transform:scaleX(0);transform-origin:left;animation:splashLoaderFill 2.8s ease-in-out .2s forwards}@keyframes splashLoaderFill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.splash-footer{position:absolute;bottom:20px;display:flex;align-items:center;gap:8px;font-size:12px;opacity:0;animation:splashTagIn .5s ease-out 1.8s forwards}.splash-footer a{color:#94a3b8;text-decoration:none;transition:color .2s}.splash-footer a:hover{color:#7c3aed;text-decoration:underline}.splash-footer-divider{color:#cbd5e1}@media(prefers-color-scheme:dark){.splash-screen{background:#0f0f14}.splash-bg-orb-1{background:radial-gradient(circle,rgba(139,92,246,.12) 0%,transparent 70%)}.splash-bg-orb-2{background:radial-gradient(circle,rgba(99,102,241,.08) 0%,transparent 70%)}.splash-logo-icon{background:linear-gradient(145deg,#1e1e2a,#252535);box-shadow:0 8px 32px #0006,0 2px 8px #0003}.splash-tagline{color:#94a3b8}.splash-loader{background:#8b5cf614}.splash-footer a{color:#64748b}.splash-footer a:hover{color:#a855f7}.splash-footer-divider{color:#475569}}.learning-calendar{background:#fff;border-radius:12px;padding:20px;margin-bottom:12px;box-shadow:0 2px 8px #0000000f}.lc-intro{margin-bottom:16px;padding:12px 14px;background:#f7f7f7;border-radius:10px}.lc-intro-text{font-size:13px;color:#666;margin:0;line-height:1.5}.lc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.lc-nav-btn{width:36px;height:36px;background:none;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#111;cursor:pointer;transition:background .15s ease}.lc-nav-btn:active{background:#f5f5f5}.lc-month{font-size:17px;font-weight:600;color:#111;letter-spacing:-.3px}.lc-sync-btn{width:32px;height:32px;background:#f5f5f5;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#666;cursor:pointer;transition:all .15s ease;margin-left:8px}.lc-sync-btn:active{background:#eee;transform:scale(.95)}.lc-sync-btn.syncing{background:#e3f2fd;color:#1976d2}.lc-sync-btn:disabled{cursor:not-allowed;opacity:.7}.lc-sync-btn .spin{animation:lcSpin 1s linear infinite}@keyframes lcSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.lc-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.lc-weekday{text-align:center;font-size:13px;font-weight:500;color:#999;padding:8px 0}.lc-weekday.sunday,.lc-weekday.saturday{color:#999}.lc-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.lc-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:none;border:none;border-radius:12px;cursor:pointer;transition:background .15s ease;position:relative;padding:4px;gap:2px}.lc-day:active:not(.empty):not(.future){background:#f0f0f0}.lc-day.empty{cursor:default}.lc-day.today{background:#111}.lc-day.today .lc-day-number{color:#fff;font-weight:600}.lc-day.future{opacity:.4}.lc-day-number{font-size:14px;font-weight:400;color:#333;line-height:1}.lc-day-indicators{display:flex;gap:3px;height:6px}.lc-indicator{width:6px;height:6px;border-radius:50%}.lc-indicator.learning{background:#111}.lc-indicator.english{background:#3b82f6}.lc-indicator.schedule{background:#999}.lc-indicator.google{background:#ea4335}.lc-day.today .lc-indicator.learning{background:#fff}.lc-summary{margin-top:16px;padding-top:16px;border-top:1px solid #f0f0f0;text-align:center}.lc-summary-text{font-size:14px;font-weight:500;color:#666}.lc-legend{display:flex;justify-content:center;gap:16px;margin-top:12px;padding-top:12px}.lc-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#888}.lc-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:lcFadeIn .2s ease;padding:20px}@keyframes lcFadeIn{0%{opacity:0}to{opacity:1}}.lc-modal{background:#fff;border-radius:16px;width:100%;max-width:340px;max-height:80vh;overflow-y:auto;animation:lcScaleIn .2s ease}@keyframes lcScaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.lc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid #f0f0f0;position:sticky;top:0;background:#fff;border-radius:16px 16px 0 0}.lc-modal-title{font-size:17px;font-weight:600;color:#111}.lc-modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:none;border-radius:8px;color:#666;cursor:pointer;transition:all .15s ease}.lc-modal-close:active{background:#eee;transform:scale(.95)}.lc-modal-content{padding:16px 20px 20px}.lc-modal-section{margin-bottom:20px}.lc-modal-section:last-child{margin-bottom:0}.lc-modal-section-title{font-size:13px;font-weight:600;color:#888;margin-bottom:10px}.lc-modal-empty-text{font-size:13px;color:#bbb;margin:0}.lc-modal-learning{display:flex;gap:12px}.lc-learning-item{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#f5f5f5;border-radius:8px;font-size:13px;font-weight:500;color:#999}.lc-learning-item.done{background:#f0fdf4;color:#22c55e}.lc-empty-dot{width:8px;height:8px;background:#ddd;border-radius:50%}.lc-modal-schedules{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.lc-schedule-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fafafa;border-radius:10px;transition:all .15s ease}.lc-schedule-item.english{background:#f0f7ff;cursor:pointer}.lc-schedule-item.english:active{background:#e0efff}.lc-schedule-time{font-size:12px;font-weight:600;color:#888;min-width:65px}.lc-schedule-content{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.lc-schedule-title{font-size:14px;font-weight:500;color:#111;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lc-english-badge{font-size:10px;font-weight:600;color:#3b82f6;background:#dbeafe;padding:2px 6px;border-radius:4px;flex-shrink:0}.lc-google-badge{display:flex;align-items:center;gap:3px;font-size:10px;font-weight:600;color:#ea4335;background:#fef2f2;padding:2px 6px;border-radius:4px;flex-shrink:0}.lc-schedule-item.google-event{background:#fff8f7;border-left:3px solid #ea4335;cursor:pointer}.lc-schedule-item.google-event:active{background:#fef2f2}.lc-schedule-delete{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:6px;color:#bbb;cursor:pointer;transition:all .15s ease}.lc-schedule-delete:active{background:#0000000d;color:#888}.lc-add-schedule-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:12px;background:#f5f5f5;border:none;border-radius:10px;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .15s ease}.lc-add-schedule-btn:active{background:#eee}.lc-add-form{background:#f8f8f8;border-radius:10px;padding:14px}.lc-add-row{display:flex;gap:8px;margin-bottom:10px}.lc-time-btn{display:flex;align-items:center;gap:6px;padding:10px 12px;background:#fff;border:1px solid #eee;border-radius:8px;font-size:13px;font-weight:500;color:#111;cursor:pointer;transition:all .15s ease;white-space:nowrap}.lc-time-btn:active{background:#fafafa}.lc-title-input{flex:1;padding:10px 12px;background:#fff;border:1px solid #eee;border-radius:8px;font-size:14px;font-weight:500;color:#111;outline:none;min-width:0}.lc-title-input:focus{border-color:#111}.lc-title-input::placeholder{color:#bbb;font-weight:400}.lc-english-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#fff;border:1px solid #eee;border-radius:8px;margin-bottom:10px;cursor:pointer}.lc-toggle-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#666}.lc-toggle-switch{position:relative;width:40px;height:24px}.lc-toggle-switch input{opacity:0;width:0;height:0}.lc-toggle-switch .toggle-slider{position:absolute;cursor:pointer;inset:0;background:#e5e5e5;transition:.2s ease;border-radius:12px}.lc-toggle-switch .toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:.2s ease;border-radius:50%}.lc-toggle-switch input:checked+.toggle-slider{background:#3b82f6}.lc-toggle-switch input:checked+.toggle-slider:before{transform:translate(16px)}.lc-add-actions{display:flex;gap:8px}.lc-cancel-btn,.lc-save-btn{flex:1;padding:10px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.lc-cancel-btn{background:#fff;color:#666;border:1px solid #eee}.lc-cancel-btn:active{background:#f5f5f5}.lc-save-btn{background:#111;color:#fff}.lc-save-btn:active{opacity:.8}.lc-time-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;animation:lcFadeIn .15s ease;padding:20px}.lc-time-modal{background:#fff;border-radius:16px;width:100%;max-width:280px;padding:20px;animation:lcScaleIn .2s ease}.lc-time-header{text-align:center;font-size:16px;font-weight:600;color:#111;margin-bottom:20px}.lc-time-picker{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px}.lc-time-column{display:flex;flex-direction:column;align-items:center}.lc-time-label{font-size:12px;font-weight:500;color:#999;margin-bottom:8px}.lc-time-scroll{height:132px;width:60px;overflow-y:scroll;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;border-radius:10px;background:#f5f5f5}.lc-time-scroll::-webkit-scrollbar{display:none}.lc-time-item{height:44px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:500;color:#bbb;scroll-snap-align:center;transition:all .15s ease}.lc-time-item.selected{font-size:22px;font-weight:700;color:#111}.lc-time-separator{font-size:24px;font-weight:700;color:#111;padding-top:20px}.lc-time-confirm{width:100%;padding:14px;background:#111;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.lc-time-confirm:active{opacity:.85}.lc-sync-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;background:#111;color:#fff;border-radius:30px;font-size:14px;font-weight:500;box-shadow:0 4px 20px #0003;animation:lcToastFadeIn .3s ease;z-index:2000}.lc-sync-toast svg{color:#22c55e}@keyframes lcToastFadeIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:360px){.learning-calendar{padding:16px}.lc-day-number{font-size:13px}.lc-modal{max-width:100%}}.schedule-manager{background:#fff;border-radius:12px;padding:20px;margin-bottom:12px;box-shadow:0 2px 8px #0000000f}.sm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sm-header-left{display:flex;align-items:center;gap:8px}.sm-header-left h3{font-size:16px;font-weight:600;color:#111;margin:0}.sm-add-btn{width:32px;height:32px;background:#f5f5f5;border:none;border-radius:8px;color:#666;cursor:pointer;transition:all .15s ease}.sm-add-btn:active{background:#eee;transform:scale(.95)}.sm-add-form{background:#fafafa;border-radius:12px;padding:16px;margin-bottom:16px}.sm-input-row{display:flex;gap:8px;margin-bottom:12px}.sm-date-display,.sm-time-display{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #eee;border-radius:10px;padding:12px 14px;cursor:pointer;transition:all .15s ease;flex:1}.sm-date-display:active,.sm-time-display:active{background:#fafafa;border-color:#ddd}.sm-date-display span,.sm-time-display span{flex:1;font-size:14px;font-weight:600;color:#111;text-align:left}.sm-title-input{width:100%;padding:12px 14px;background:#fff;border:1px solid #eee;border-radius:8px;font-size:15px;font-weight:500;color:#111;outline:none;margin-bottom:12px}.sm-title-input:focus{border-color:#111}.sm-title-input::placeholder{color:#bbb;font-weight:400}.sm-english-toggle{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#fff;border:1px solid #eee;border-radius:8px;margin-bottom:12px;cursor:pointer}.sm-toggle-left{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#333}.sm-toggle-switch{position:relative;width:44px;height:26px}.sm-toggle-switch input{opacity:0;width:0;height:0}.sm-toggle-switch .toggle-slider{position:absolute;cursor:pointer;inset:0;background:#e5e5e5;transition:.2s ease;border-radius:13px}.sm-toggle-switch .toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background:#fff;transition:.2s ease;border-radius:50%}.sm-toggle-switch input:checked+.toggle-slider{background:#3b82f6}.sm-toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.sm-english-hint{font-size:12px;color:#3b82f6;background:#f0f7ff;padding:10px 12px;border-radius:8px;margin-bottom:12px}.sm-submit-btn{width:100%;padding:14px;background:#111;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.sm-submit-btn:active{opacity:.8}.sm-section{margin-bottom:16px}.sm-section:last-child{margin-bottom:0}.sm-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:0 2px}.sm-section-title{font-size:13px;font-weight:600;color:#888}.sm-section-count{font-size:12px;font-weight:500;color:#aaa}.sm-events{display:flex;flex-direction:column;gap:8px}.sm-event{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fafafa;border-radius:10px;transition:all .15s ease}.sm-event.english{background:#f0f7ff;border-left:3px solid #3b82f6}.sm-event.clickable{cursor:pointer}.sm-event.clickable:active{transform:scale(.99);opacity:.9}.sm-event.future.urgent{border-left:3px solid #111}.sm-event.future.soon{border-left:3px solid #666}.sm-event.future.normal{border-left:3px solid #ddd}.sm-event-time{font-size:13px;font-weight:600;color:#888;min-width:70px}.sm-event-dday{display:flex;flex-direction:column;align-items:center;min-width:60px;gap:2px}.sm-dday-badge{font-size:12px;font-weight:700;color:#888;padding:2px 6px;background:#f0f0f0;border-radius:4px}.sm-dday-badge.urgent{color:#fff;background:#111}.sm-dday-badge.soon{color:#fff;background:#666}.sm-event-date{font-size:11px;color:#999}.sm-event-content{flex:1;min-width:0}.sm-event-title-row{display:flex;align-items:center;gap:8px}.sm-event-title{font-size:14px;font-weight:500;color:#111;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sm-english-badge{font-size:10px;font-weight:600;color:#3b82f6;background:#dbeafe;padding:2px 6px;border-radius:4px;flex-shrink:0}.sm-event-time-sub{display:block;font-size:12px;color:#888;margin-top:2px}.sm-practice-count{display:inline-block;font-size:11px;color:#666;background:#f0f0f0;padding:2px 6px;border-radius:4px;margin-top:4px}.sm-delete-btn{width:32px;height:32px;background:none;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#bbb;cursor:pointer;transition:all .15s ease}.sm-delete-btn:active{background:#0000000d;color:#888}.sm-empty{text-align:center;padding:24px 16px}.sm-empty p{font-size:14px;color:#888;margin-bottom:16px}.sm-empty-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 20px;background:#111;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.sm-empty-btn:active{background:#333;transform:scale(.98)}.sm-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:smFadeIn .2s ease}@keyframes smFadeIn{0%{opacity:0}to{opacity:1}}.sm-date-modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:400px;padding:20px 20px 34px;animation:smSlideUp .25s ease}@keyframes smSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sm-modal-header{text-align:center;padding-bottom:16px;border-bottom:1px solid #eee;margin-bottom:20px}.sm-modal-header span{font-size:16px;font-weight:600;color:#111}.sm-date-input{width:100%;padding:16px;font-size:18px;font-weight:600;color:#111;text-align:center;border:1px solid #eee;border-radius:12px;margin-bottom:20px;background:#fafafa}.sm-modal-confirm{width:100%;padding:16px;background:#111;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.sm-modal-confirm:active{opacity:.85}.sm-time-modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:400px;padding:20px 20px 34px;animation:smSlideUp .25s ease}.sm-time-picker{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:24px}.sm-time-column{display:flex;flex-direction:column;align-items:center}.sm-time-label{font-size:12px;font-weight:500;color:#999;margin-bottom:8px}.sm-time-scroll{height:132px;width:70px;overflow-y:scroll;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;border-radius:12px;background:#f5f5f5}.sm-time-scroll::-webkit-scrollbar{display:none}.sm-time-item{height:44px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:500;color:#bbb;scroll-snap-align:center;transition:all .15s ease}.sm-time-item.selected{font-size:24px;font-weight:700;color:#111}.sm-time-separator{font-size:28px;font-weight:700;color:#111;padding-top:24px}@media(max-width:360px){.schedule-manager{padding:16px}.sm-input-row{flex-direction:column}.sm-categories{gap:6px}.sm-category{padding:6px 10px;font-size:12px}}.daily-schedule{background:#fff;border-radius:12px;padding:20px;margin-bottom:12px;box-shadow:0 2px 8px #0000000f}.ds-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.ds-header-left{display:flex;align-items:center;gap:8px}.ds-header-left h3{font-size:16px;font-weight:600;color:#111}.ds-date{font-size:13px;font-weight:500;color:#888}.ds-add-btn{width:32px;height:32px;background:none;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#111;cursor:pointer;transition:background .15s ease}.ds-add-btn:active{background:#f5f5f5}.ds-add-form{background:#fafafa;border-radius:12px;padding:16px;margin-bottom:16px}.ds-presets{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.ds-preset{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fff;border:1px solid #eee;border-radius:8px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .15s ease}.ds-preset:active{background:#f5f5f5}.ds-preset.active{background:#111;border-color:#111;color:#fff}.ds-input-row{display:flex;gap:8px;margin-bottom:12px}.ds-time-display{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #eee;border-radius:10px;padding:12px 14px;min-width:130px;cursor:pointer;transition:all .15s ease}.ds-time-display:active{background:#fafafa;border-color:#ddd}.ds-time-display span{flex:1;font-size:15px;font-weight:600;color:#111;text-align:left}.ds-title-input{flex:1;padding:12px 14px;background:#fff;border:1px solid #eee;border-radius:8px;font-size:15px;font-weight:500;color:#111;outline:none}.ds-title-input:focus{border-color:#111}.ds-title-input::placeholder{color:#bbb;font-weight:400}.ds-english-toggle{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#fff;border:1px solid #eee;border-radius:8px;margin-bottom:12px;cursor:pointer}.ds-toggle-left{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#333}.ds-toggle-switch{position:relative;width:44px;height:26px}.ds-toggle-switch input{opacity:0;width:0;height:0}.ds-toggle-switch .toggle-slider{position:absolute;cursor:pointer;inset:0;background:#e5e5e5;transition:.2s ease;border-radius:13px}.ds-toggle-switch .toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background:#fff;transition:.2s ease;border-radius:50%}.ds-toggle-switch input:checked+.toggle-slider{background:#111}.ds-toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.ds-submit-btn{width:100%;padding:14px;background:#111;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.ds-submit-btn:active{opacity:.8}.ds-events{display:flex;flex-direction:column;gap:8px}.ds-event{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fafafa;border-radius:10px}.ds-event.english{background:#f0f7ff}.ds-event-time{font-size:13px;font-weight:600;color:#888;min-width:60px}.ds-event-content{flex:1;display:flex;align-items:center;gap:8px}.ds-event-title{font-size:15px;font-weight:500;color:#111}.ds-english-badge{font-size:11px;font-weight:600;color:#3b82f6;background:#dbeafe;padding:2px 6px;border-radius:4px}.ds-delete-btn{width:32px;height:32px;background:none;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#bbb;cursor:pointer;transition:all .15s ease}.ds-delete-btn:active{background:#0000000d;color:#888}.ds-empty{text-align:center;padding:24px 16px;color:#999}.ds-empty p{font-size:14px;font-weight:500}.ds-time-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.ds-time-modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:400px;padding:20px 20px 34px;animation:slideUp .25s ease}.ds-time-modal-header{text-align:center;padding-bottom:16px;border-bottom:1px solid #eee;margin-bottom:20px}.ds-time-modal-header span{font-size:16px;font-weight:600;color:#111}.ds-time-picker{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:24px}.ds-time-column{display:flex;flex-direction:column;align-items:center}.ds-time-label{font-size:12px;font-weight:500;color:#999;margin-bottom:8px}.ds-time-scroll{height:132px;width:70px;overflow-y:scroll;scroll-snap-type:y mandatory;-webkit-overflow-scrolling:touch;border-radius:12px;background:#f5f5f5}.ds-time-scroll::-webkit-scrollbar{display:none}.ds-time-item{height:44px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:500;color:#bbb;scroll-snap-align:center;transition:all .15s ease}.ds-time-item.selected{font-size:24px;font-weight:700;color:#111}.ds-time-separator{font-size:28px;font-weight:700;color:#111;padding-top:24px}.ds-time-confirm{width:100%;padding:16px;background:#111;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.ds-time-confirm:active{opacity:.85}@media(max-width:360px){.daily-schedule{padding:16px}.ds-input-row{flex-direction:column}.ds-time-display{width:100%}}.addgoal-sheet-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:addgoalOverlayIn .25s ease}.addgoal-sheet-overlay.closing{animation:addgoalOverlayOut .2s ease forwards}@keyframes addgoalOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes addgoalOverlayOut{0%{opacity:1}to{opacity:0}}.addgoal-sheet{width:100%;max-width:480px;max-height:80vh;background:#fff;border-radius:24px 24px 0 0;padding:12px 20px 32px;animation:addgoalSlideUp .3s cubic-bezier(.32,.72,0,1);overflow-y:auto}.addgoal-sheet.closing{animation:addgoalSlideDown .2s ease-out forwards}@keyframes addgoalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes addgoalSlideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(30%);opacity:0}}.addgoal-handle{width:40px;height:4px;background:#ddd;border-radius:2px;margin:0 auto 16px}.addgoal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.addgoal-header h2{font-size:18px;font-weight:700;color:#111}.addgoal-close-btn{background:none;padding:4px;display:flex;align-items:center;justify-content:center}.addgoal-section{margin-bottom:20px}.addgoal-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#333;margin-bottom:10px}.addgoal-label svg{color:#666}.addgoal-optional{font-size:11px;color:#999;font-weight:400;margin-left:auto}.addgoal-input{width:100%;padding:14px 16px;background:#f5f5f5;border:1.5px solid transparent;border-radius:12px;font-family:inherit;font-size:15px;color:#111;transition:all .15s ease}.addgoal-input::placeholder{color:#999}.addgoal-input:focus{outline:none;background:#fff;border-color:#111}.addgoal-input[type=date],.addgoal-input[type=time]{-webkit-appearance:none;appearance:none}.addgoal-input[type=date]::-webkit-calendar-picker-indicator,.addgoal-input[type=time]::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer}.addgoal-categories{display:flex;flex-wrap:wrap;gap:8px}.addgoal-cat-btn{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#f5f5f5;border:1.5px solid transparent;border-radius:20px;font-size:13px;font-weight:500;color:#666;transition:all .15s ease}.addgoal-cat-btn svg{color:#888}.addgoal-cat-btn.selected{background:#fff;border-color:#111;color:#111}.addgoal-cat-btn.selected svg{color:#111}.addgoal-cat-btn:active{transform:scale(.97)}.addgoal-footer{margin-top:24px}.addgoal-save-btn{width:100%;padding:16px;background:#111;color:#fff;border-radius:14px;font-size:16px;font-weight:600;transition:all .15s ease}.addgoal-save-btn:active{background:#333;transform:scale(.99)}.addgoal-save-btn.disabled{background:#ddd;color:#999;pointer-events:none}.english-goals{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:0 2px 8px #0000000f}.eg-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.eg-header-left{display:flex;align-items:center;gap:8px}.eg-header-left h3{font-size:16px;font-weight:700;color:#111;margin:0}.eg-add-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border-radius:8px;transition:all .15s ease}.eg-add-btn svg{color:#666}.eg-add-btn:active{background:#eee;transform:scale(.95)}.eg-list{display:flex;flex-direction:column;gap:10px}.eg-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#fafafa;border-radius:12px;border-left:3px solid #ddd;transition:all .15s ease;cursor:pointer}.eg-card:active{background:#f0f0f0;transform:scale(.99)}.eg-card.urgent{border-left-color:#111;background:#f8f8f8}.eg-card.soon{border-left-color:#666}.eg-card.normal{border-left-color:#ccc}.eg-card-top{display:flex;flex-direction:column;align-items:center;min-width:54px}.eg-dday{font-size:13px;font-weight:700;color:#888;line-height:1.2}.eg-dday.urgent{color:#111}.eg-dday.soon{color:#444}.eg-date{font-size:11px;color:#999;margin-top:2px;white-space:nowrap}.eg-card-content{flex:1;min-width:0}.eg-title{display:block;font-size:14px;font-weight:600;color:#111;line-height:1.3;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.eg-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:#888}.eg-meta svg{color:#999}.eg-practice-count{margin-left:8px;padding:2px 6px;background:#f0f0f0;border-radius:4px;font-size:11px;color:#666}.eg-card-action{display:flex;align-items:center}.eg-empty{text-align:center;padding:24px 16px}.eg-empty p{font-size:14px;color:#888;margin-bottom:16px}.eg-empty-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 20px;background:#111;color:#fff;border-radius:10px;font-size:14px;font-weight:500;transition:all .15s ease}.eg-empty-btn:active{background:#333;transform:scale(.98)}.eg-empty-btn svg{color:#fff}.custom-tutor-overlay{position:fixed;inset:0;display:flex;align-items:flex-end;justify-content:center;z-index:1001}.custom-tutor-overlay.closing{pointer-events:none}.custom-tutor-backdrop{position:absolute;inset:0;background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .3s ease-out,backdrop-filter .3s ease-out;-webkit-tap-highlight-color:transparent}.custom-tutor-overlay.visible .custom-tutor-backdrop{background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.custom-tutor-overlay.closing .custom-tutor-backdrop{background:#0000;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}.custom-tutor-modal{position:relative;background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);will-change:transform}.custom-tutor-modal.visible{transform:translateY(0)}.custom-tutor-modal.closing{transform:translateY(100%)}.custom-tutor-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.custom-tutor-header h2{font-size:18px;font-weight:700;color:#111}.custom-tutor-close{width:32px;height:32px;background:#f5f5f5;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#888;cursor:pointer;transition:all .15s ease}.custom-tutor-close:active{background:#eee}.custom-tutor-content{padding:20px;overflow-y:auto;flex:1}.tutor-upload-area{width:120px;height:120px;background:#f5f5f5;border-radius:50%;margin:0 auto 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;border:2px dashed #ddd;transition:all .15s ease;overflow:hidden}.tutor-upload-area:active{background:#eee}.tutor-upload-area.has-image{border:3px solid #111}.tutor-upload-area p{font-size:12px;color:#888;margin-top:6px}.tutor-preview{width:100%;height:100%;object-fit:cover}.form-group{margin-bottom:20px}.form-group.half{flex:1}.form-row{display:flex;gap:16px}.form-label{display:block;font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.form-input{width:100%;padding:14px 16px;background:#f5f5f5;border:none;border-radius:12px;font-size:15px;color:#111}.form-input::placeholder{color:#999}.form-input:focus{outline:none;background:#f0f0f0}.style-options{display:flex;flex-direction:column;gap:10px}.style-option{position:relative;display:flex;flex-direction:column;align-items:flex-start;padding:14px 16px;background:#fff;border:1.5px solid #eee;border-radius:12px;text-align:left;transition:all .15s ease}.style-option.selected{border-color:#111;background:#fafafa}.style-label{font-size:14px;font-weight:600;color:#111}.style-desc{font-size:12px;color:#888;margin-top:2px}.style-check{position:absolute;top:12px;right:12px;width:20px;height:20px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.chip-options{display:flex;flex-wrap:wrap;gap:8px}.chip-option{padding:10px 16px;background:#fff;border:1.5px solid #eee;border-radius:20px;font-size:13px;font-weight:500;color:#666;transition:all .15s ease}.chip-option.selected{background:#111;border-color:#111;color:#fff}.tag-options{display:flex;flex-wrap:wrap;gap:8px}.tag-option{padding:8px 14px;background:#f5f5f5;border:none;border-radius:16px;font-size:13px;color:#666;transition:all .15s ease}.tag-option.selected{background:#111;color:#fff}.error-message{font-size:13px;color:#e74c3c;text-align:center;margin-top:10px}.custom-tutor-buttons{padding:16px 20px calc(24px + env(safe-area-inset-bottom,0px));flex-shrink:0;display:flex;gap:10px;background:#fff;position:relative;z-index:10}.delete-btn{padding:16px 20px;background:#fff;color:#e74c3c;border:1.5px solid #eee;border-radius:14px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:6px;flex-shrink:0}.delete-btn:disabled{opacity:.5}.delete-btn:active:not(:disabled){background:#fef2f2;border-color:#e74c3c}.save-btn{flex:1;width:100%;padding:16px;background:#111;color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:8px;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.save-btn:disabled{background:#ddd;color:#999}.save-btn:active:not(:disabled){background:#333;transform:scale(.98)}.save-btn .spin{animation:spin 1s linear infinite}.voice-section{background:#fafafa;border-radius:14px;padding:16px;margin-top:8px}.voice-section .form-label{display:flex;align-items:center;gap:4px}.voice-badge{font-size:10px;background:#111;color:#fff;padding:2px 8px;border-radius:10px;margin-left:8px;text-transform:none;letter-spacing:0}.voice-badge.coming-soon{background:linear-gradient(135deg,#667eea,#764ba2)}.voice-desc{font-size:12px;color:#888;margin-bottom:12px}.voice-sample{background:#fff;border-radius:10px;padding:12px;margin-bottom:12px}.voice-sample .sample-label{font-size:11px;color:#999;display:block;margin-bottom:4px}.voice-sample .sample-text{font-size:13px;color:#333;font-style:italic;line-height:1.4}.voice-controls{display:flex;align-items:center;gap:10px}.voice-record-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;background:#111;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.voice-record-btn.recording{background:#e74c3c;animation:pulse 1.5s infinite}.voice-record-btn:disabled{background:#27ae60;cursor:default}.voice-record-btn.coming-soon-btn{background:#ddd;color:#888}.voice-recorded{flex:1;display:flex;align-items:center;gap:10px;background:#fff;border-radius:12px;padding:10px 14px;border:1px solid #eee}.voice-play-btn,.voice-reset-btn{width:36px;height:36px;background:#f5f5f5;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#666;cursor:pointer;transition:all .15s ease}.voice-play-btn:active,.voice-reset-btn:active{background:#eee}.voice-time{flex:1;font-size:14px;font-weight:500;color:#111;text-align:center}.sample-sentence-box{background:#f8f9fa;border-radius:10px;padding:12px 14px;margin-bottom:12px}.sample-sentence-box .sample-label{display:block;font-size:11px;color:#888;margin-bottom:6px}.sample-sentence-box .sample-text{font-size:13px;color:#333;font-style:italic;line-height:1.5;margin:0}.recorded-controls{flex:1;display:flex;align-items:center;gap:10px;background:#f5f5f5;border-radius:12px;padding:10px 14px}.playback-btn{width:36px;height:36px;background:#111;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;transition:all .15s ease}.recorded-time{flex:1;font-size:14px;font-weight:600;color:#333}.reset-btn{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:12px;color:#666;cursor:pointer}.reset-btn:active{background:#f0f0f0}.clone-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;margin-top:12px;transition:all .15s ease}.clone-btn:active{transform:scale(.98)}.clone-btn:disabled{opacity:.7;cursor:default}.voice-success{display:flex;align-items:center;gap:8px;padding:12px 14px;background:#e8f5e9;border-radius:10px;margin-top:12px;color:#2e7d32;font-size:13px;font-weight:500}.voice-success .reset-voice-btn{margin-left:auto;background:none;border:none;color:#666;font-size:12px;text-decoration:underline;cursor:pointer}.voice-badge.active{background:#e8f5e9;color:#2e7d32}.voice-clone-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;margin-top:10px;transition:all .15s ease}.voice-clone-btn:disabled{opacity:.7;cursor:default}.voice-clone-btn .spin{animation:spin 1s linear infinite}.voice-reset-link{display:block;width:100%;text-align:center;font-size:12px;color:#888;background:none;border:none;padding:10px 0 0;cursor:pointer;text-decoration:underline}.custom-tutor-toast{position:absolute;bottom:100px;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;padding:12px 24px;border-radius:24px;font-size:14px;font-weight:500;white-space:nowrap;z-index:100;animation:toastFadeIn .2s ease,toastFadeOut .2s ease 1.8s}@keyframes toastFadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastFadeOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}.pet-modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.pet-modal-backdrop{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pet-modal{position:relative;background:#fff;border-radius:20px;width:100%;max-width:360px;animation:slideUp .3s ease;overflow:hidden}.pet-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #f0f0f0}.pet-modal-header h2{font-size:18px;font-weight:700;color:#111}.pet-modal-close{width:32px;height:32px;background:#f5f5f5;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#888;cursor:pointer;transition:all .15s ease}.pet-modal-close:active{background:#eee}.pet-modal-content{padding:24px 20px}.pet-upload-area{width:160px;height:160px;background:#f8f8f8;border-radius:50%;margin:0 auto 20px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;border:1.5px solid #e5e5e5;transition:all .15s ease;overflow:hidden}.pet-upload-area:active{background:#f0f0f0;border-color:#ddd}.pet-upload-area.has-image{border:none}.pet-upload-area p{font-size:13px;color:#888;margin-top:8px}.pet-preview{width:100%;height:100%;object-fit:cover}.pet-name-input{width:100%;padding:14px 16px;background:#f5f5f5;border:none;border-radius:12px;font-size:15px;color:#111;text-align:center;margin-bottom:12px}.pet-name-input::placeholder{color:#999}.pet-name-input:focus{outline:none;background:#f0f0f0}.pet-modal-hint{font-size:13px;color:#888;text-align:center}.pet-modal-error{font-size:13px;color:#e74c3c;text-align:center;margin-top:8px}.pet-modal-buttons{display:flex;gap:10px;padding:16px 20px 20px}.pet-remove-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 16px;background:#f5f5f5;border:none;border-radius:12px;font-size:14px;font-weight:500;color:#888;cursor:pointer;transition:all .15s ease}.pet-remove-btn:active{background:#eee}.pet-save-btn{flex:1;padding:14px;background:#111;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease}.pet-save-btn:disabled{background:#e5e5e5;color:#aaa;cursor:not-allowed}.pet-save-btn:active:not(:disabled){background:#333;transform:scale(.98)}.pet-save-btn{display:flex;align-items:center;justify-content:center;gap:8px}.pet-save-btn .spin{animation:spin 1s linear infinite}.voice-recording-section{margin-bottom:28px;padding:0 20px}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.voice-recording-section .section-title{font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin:0;padding:0}.ai-badge{display:flex;align-items:center;gap:4px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:10px;font-weight:700;padding:4px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.voice-recording-section .section-desc{font-size:13px;color:#888;margin-bottom:16px;padding:0}.voice-content{background:#fff;border-radius:16px;padding:20px;border:1px solid #eee}.tutor-connection{display:flex;align-items:center;gap:12px;padding:12px 14px;background:linear-gradient(135deg,#667eea14,#764ba214);border-radius:12px;margin-bottom:16px;border:1px solid rgba(102,126,234,.15)}.tutor-avatar-small{width:36px;height:36px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.tutor-avatar-small img{width:100%;height:100%;object-fit:cover}.tutor-connection-info{display:flex;flex-direction:column;gap:2px}.tutor-connection-name{font-size:14px;font-weight:600;color:#111}.tutor-connection-status{display:flex;align-items:center;gap:4px;font-size:12px;color:#667eea;font-weight:500}.voice-guide{font-size:12px;color:#888;text-align:center;margin-top:12px;line-height:1.5}.voice-guide strong{color:#667eea;font-weight:600}.gender-selector{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#fafafa;border-radius:12px;margin-bottom:12px}.gender-label{font-size:13px;color:#666;font-weight:500}.gender-options{display:flex;gap:8px}.gender-btn{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:20px;font-size:13px;color:#666;cursor:pointer;transition:all .15s ease}.gender-btn.active{background:#111;border-color:#111;color:#fff}.gender-btn:active{transform:scale(.96)}.sample-sentence{background:#fafafa;border-radius:12px;padding:14px 16px;margin-bottom:16px}.sample-label{font-size:11px;color:#999;display:block;margin-bottom:8px}.sample-text{font-size:14px;color:#333;line-height:1.6;font-style:italic}.voice-controls{display:flex;justify-content:center;margin-bottom:16px}.record-btn{display:flex;align-items:center;gap:10px;padding:14px 28px;background:#111;color:#fff;border:none;border-radius:30px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease}.record-btn:active{transform:scale(.96)}.record-btn.recording{background:#e74c3c;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.recorded-controls{display:flex;align-items:center;gap:12px}.playback-btn{width:44px;height:44px;background:#111;color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.playback-btn:active{transform:scale(.95)}.recorded-time{font-size:15px;font-weight:600;color:#111;min-width:40px}.reset-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#f0f0f0;border:none;border-radius:20px;font-size:13px;color:#666;cursor:pointer;transition:all .15s ease}.reset-btn:active{background:#e0e0e0}.clone-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease}.clone-btn:disabled{background:#ddd;color:#999}.clone-btn:active:not(:disabled){transform:scale(.98)}.clone-btn .spin{animation:spin 1s linear infinite}.voice-success{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:#e8f5e9;border-radius:12px;color:#2e7d32;font-size:14px;font-weight:500}.reset-voice-btn{margin-left:12px;padding:6px 12px;background:#fff;border:1px solid #2e7d32;border-radius:16px;font-size:12px;color:#2e7d32;cursor:pointer}.reset-voice-btn:active{background:#f0f0f0}.voice-recording-section .error-message{font-size:13px;color:#e74c3c;text-align:center;margin-top:12px}.google-calendar-section{margin-bottom:28px;padding:16px 20px;background:linear-gradient(135deg,#f3e8ff,#ede9fe);border-radius:16px;margin-left:20px;margin-right:20px}.google-calendar-section .section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.google-calendar-section .section-title{font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin:0;padding:0}.connected-badge{display:flex;align-items:center;gap:4px;background:#e8f5e9;color:#2e7d32;font-size:11px;font-weight:600;padding:4px 10px;border-radius:12px}.google-calendar-section .section-desc{font-size:13px;color:#888;margin-bottom:16px;padding:0}.calendar-content{background:transparent;border-radius:16px;padding:0;border:none}.calendar-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px;color:#888;font-size:14px}.calendar-loading .spin,.connect-btn .spin{animation:spin 1s linear infinite}.calendar-not-configured{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;color:#999;text-align:center}.calendar-not-configured p{font-size:14px;margin:0}.config-hint{font-size:12px;color:#bbb}.connect-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;background:#fff;border:1px solid #e0e0e0;border-radius:12px;font-size:15px;font-weight:600;color:#111;cursor:pointer;transition:all .15s ease}.connect-btn:hover{border-color:#ddd;background:#fafafa}.connect-btn:active{transform:scale(.98)}.connect-btn:disabled{opacity:.7;cursor:not-allowed}.calendar-connected{display:flex;flex-direction:column;gap:16px;padding:20px;background:#fafafa;border-radius:14px}.calendar-connected-top{display:flex;align-items:center;gap:14px}.google-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f}.google-icon svg{width:20px;height:20px}.connection-info{flex:1;display:flex;flex-direction:column;gap:2px}.connection-status{font-size:13px;font-weight:600;color:#111}.connection-hint{font-size:12px;color:#888;line-height:1.4}.disconnect-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:12px 16px;background:#fff;border:1px solid #e5e5e5;border-radius:10px;font-size:13px;font-weight:500;color:#666;cursor:pointer;transition:all .15s ease}.disconnect-btn:active{background:#f5f5f5}.calendar-success,.calendar-error{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:10px;font-size:13px;margin-top:12px}.calendar-success{background:#e8f5e9;color:#2e7d32}.calendar-error{background:#ffebee;color:#c62828}.calendar-features{margin-top:20px;padding:16px;background:#f8f9fa;border-radius:12px}.calendar-features h4{font-size:11px;font-weight:600;color:#999;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.calendar-features ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.calendar-features li{font-size:13px;color:#555;line-height:1.4}.expired-badge{display:flex;align-items:center;gap:4px;background:#fff3e0;color:#e65100;font-size:11px;font-weight:600;padding:4px 10px;border-radius:12px}.calendar-expired{display:flex;flex-direction:column;gap:16px;padding:20px;background:#fffbf5;border-radius:14px;border:1px solid #ffe0b2}.calendar-expired-top{display:flex;align-items:center;gap:14px}.google-icon.faded{opacity:.5}.connection-status.expired{color:#e65100}.reconnect-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 16px;background:#111;border:none;border-radius:12px;font-size:14px;font-weight:600;color:#fff;cursor:pointer;transition:all .15s ease}.reconnect-btn:hover{background:#333}.reconnect-btn:active{transform:scale(.98)}.reconnect-btn:disabled{opacity:.7;cursor:not-allowed}.reconnect-btn .spin{animation:spin 1s linear infinite}.today-progress{margin-top:0;margin-bottom:0}.tp-header{display:flex;justify-content:space-between;align-items:center;padding:0 4px;margin-bottom:12px}.tp-header-label{font-size:15px;font-weight:600;color:#1f2937}.tp-header-count{font-size:14px;font-weight:600;color:#3b82f6}.tp-card{background:#fff;border-radius:16px;padding:8px 0}.tp-steps{display:flex;align-items:center;justify-content:space-around;margin-bottom:8px;margin-top:8px}.tp-step-wrapper{display:flex;align-items:center}.tp-step{display:flex;flex-direction:column;align-items:center;gap:8px;background:none;border:none;padding:8px 24px;cursor:pointer;transition:opacity .15s ease}.tp-step:active{opacity:.7}.tp-step-circle{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#888;background:#f5f5f5;transition:all .2s ease}.tp-step-circle.completed.step-1{background:#b8c4f8;color:#fff}.tp-step-circle.completed.step-2{background:#8b9bf0;color:#fff}.tp-step-circle.completed.step-3{background:#5a6ad8;color:#fff}.tp-step-circle.available{background:#f5f5f5;color:#888}.tp-step-label{font-size:13px;font-weight:400;color:#888}.tp-step.completed .tp-step-label{color:#111;font-weight:400}.tp-step.selected .tp-step-label{color:#5a6ad8;font-weight:600}.tp-step-circle.selected{box-shadow:0 0 0 3px #5a6ad840}.tp-step-circle.available.selected{background:#5a6ad8;color:#fff}.tp-connector{display:none}.tp-progress-bar{height:4px;background:#f0f0f0;border-radius:2px;overflow:hidden}.tp-progress-fill{height:100%;background:linear-gradient(90deg,#b8c4f8,#8b9bf0,#5a6ad8);border-radius:2px;transition:width .3s ease}.precall-sheet-overlay{position:fixed;inset:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:overlayFadeIn .25s ease}.precall-sheet-overlay.closing{animation:overlayFadeOut .2s ease forwards}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes overlayFadeOut{0%{opacity:1}to{opacity:0}}.precall-sheet{width:100%;max-width:480px;max-height:85vh;background:#fff;border-radius:24px 24px 0 0;padding:16px 24px 36px;animation:sheetSlideUp .3s cubic-bezier(.32,.72,0,1);overflow-y:auto}.precall-sheet.closing{animation:sheetSlideDown .2s ease-out forwards}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheetSlideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(30%);opacity:0}}.sheet-handle{width:40px;height:4px;background:#ddd;border-radius:2px;margin:0 auto 16px}.sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.sheet-header h2{font-size:18px;font-weight:700;color:#111}.sheet-close-btn{background:none;padding:4px;display:flex;align-items:center;justify-content:center}.sheet-section{margin-bottom:28px}.section-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#333;margin-bottom:14px}.section-label svg{color:#666}.section-hint{font-size:12px;color:#888;margin-top:8px}.duration-options{display:flex;gap:12px}.duration-btn{flex:1;padding:16px;background:#f5f5f5;border:none;border-radius:14px;font-size:15px;font-weight:600;color:#666;transition:all .15s ease}.duration-btn.selected{background:#fff;color:#111;box-shadow:0 2px 12px #0000001f}.duration-btn:active{transform:scale(.98)}.focus-options{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.focus-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 6px;background:#f8f8f8;border:none;border-radius:14px;transition:all .15s ease}.focus-btn.selected{background:#fff;box-shadow:0 2px 12px #0000001f}.focus-btn:active{transform:scale(.97)}.focus-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#eee;border-radius:12px;transition:all .15s ease}.focus-btn.selected .focus-icon{background:color-mix(in srgb,var(--focus-color, #111) 15%,white)}.focus-label{font-size:11px;font-weight:500;color:#666}.focus-btn.selected .focus-label{color:#111;font-weight:600}.focus-btn.disabled{opacity:.5;cursor:not-allowed;position:relative}.focus-btn.disabled:active{transform:none}.focus-area-options{display:flex;gap:8px}.focus-area-btn{flex:1;padding:12px 8px;background:#f7f8fa;border:1.5px solid transparent;border-radius:12px;transition:all .15s ease;position:relative}.focus-area-btn.selected{background:#fff;border-color:#3182f6;box-shadow:0 2px 8px #3182f626}.focus-area-btn:active{transform:scale(.97)}.focus-area-label{font-size:13px;font-weight:600;color:#4e5968}.focus-area-btn.selected .focus-area-label{color:#3182f6}.focus-area-btn.disabled{opacity:.5;cursor:not-allowed;position:relative}.focus-area-btn.disabled:active{transform:none}.coming-soon-badge{position:absolute;top:-6px;right:-4px;font-size:9px;font-weight:600;color:#fff;background:#8b95a1;padding:2px 5px;border-radius:6px;text-transform:uppercase;letter-spacing:.3px}.focus-btn.disabled .focus-icon{background:#f5f5f5}.coming-soon-badge{position:absolute;top:4px;right:4px;font-size:8px;font-weight:600;color:#999;background:#f0f0f0;padding:2px 4px;border-radius:4px}.sheet-section:last-of-type{margin-top:8px;padding-top:20px;border-top:1px solid #f0f0f0}.section-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.section-label-row .section-label{margin-bottom:0}.toggle-switch{width:48px;height:28px;background:#ddd;border-radius:14px;position:relative;transition:all .2s ease}.toggle-switch.active{background:#111}.toggle-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:all .2s ease;box-shadow:0 1px 3px #0003}.toggle-switch.active .toggle-thumb{left:23px}.structure-options{display:flex;flex-direction:column;gap:10px;margin-top:12px}.structure-btn{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:16px 18px;background:#f5f5f5;border:none;border-radius:14px;text-align:left;transition:all .15s ease}.structure-btn.selected{background:#fff;box-shadow:0 2px 12px #0000001f}.structure-btn:active{transform:scale(.99)}.structure-label{font-size:14px;font-weight:600;color:#111}.structure-steps{font-size:12px;color:#888}.structure-btn.selected .structure-steps{color:#666}.exam-mode-options{display:flex;gap:12px}.exam-mode-btn{flex:1;padding:16px 14px;background:#f5f5f5;border:2px solid transparent;border-radius:14px;text-align:center;transition:all .15s ease}.exam-mode-btn.selected{background:#fff;border-color:var(--exam-color, #6366f1);box-shadow:0 2px 12px #0000001a}.exam-mode-btn:active{transform:scale(.98)}.exam-label{display:block;font-size:15px;font-weight:700;color:#333}.exam-mode-btn.selected .exam-label{color:var(--exam-color, #6366f1)}.exam-desc{display:block;font-size:11px;color:#888;margin-top:4px}.question-type-section{margin-top:16px;padding:16px;background:#fafafa;border-radius:14px}.question-type-label{font-size:12px;font-weight:600;color:#666;margin-bottom:12px}.question-type-options{display:flex;flex-wrap:wrap;gap:8px}.question-type-btn{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#fff;border:1px solid #e5e5e5;border-radius:20px;font-size:13px;color:#555;transition:all .15s ease}.question-type-btn.selected{background:#111;border-color:#111;color:#fff}.question-type-btn:active{transform:scale(.97)}.qt-label{font-weight:500}.qt-time{display:flex;align-items:center;gap:3px;font-size:11px;opacity:.7}.exam-tip{font-size:12px;color:#666;margin-top:14px;padding:12px;background:#fff;border-radius:10px;line-height:1.5}.start-exam-btn{width:100%;margin-top:16px;padding:16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;transition:all .2s ease;box-shadow:0 4px 12px #6366f14d}.start-exam-btn:active{transform:scale(.98);box-shadow:0 2px 8px #6366f14d}.start-exam-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed}.custom-message-section{margin-top:8px;padding-top:20px;border-top:1px solid #f0f0f0}.optional-badge{font-size:11px;color:#888;font-weight:400;margin-left:auto}.custom-message-input{width:100%;padding:16px;background:#f8f8f8;border:none;border-radius:14px;font-family:inherit;font-size:14px;line-height:1.6;color:#333;resize:none;transition:all .15s ease}.custom-message-input::placeholder{color:#aaa}.custom-message-input:focus{outline:none;background:#fff;box-shadow:0 2px 12px #0000001a}.sheet-footer{margin-top:16px}.start-call-btn{width:100%;padding:18px;background:linear-gradient(90deg,#8b5cf6,#6366f1 40%,#38bdf8);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;transition:all .15s ease;box-shadow:0 4px 16px #8b5cf659}.start-call-btn:active{background:linear-gradient(90deg,#7c3aed,#5558e3 40%,#2eaee8);transform:scale(.99)}.textbook-section{margin-top:8px;padding-top:20px;border-top:1px solid #f0f0f0}.situation-cards-wrapper{margin:12px -20px 16px;padding:0 20px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.situation-cards-wrapper::-webkit-scrollbar{display:none}.situation-cards{display:flex;gap:10px;padding:4px 0}.situation-card{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px;width:80px;padding:14px 10px;background:#f8f8f8;border:2px solid transparent;border-radius:14px;cursor:pointer;transition:all .15s ease}.situation-card:hover{background:#f0f0f0}.situation-card.selected{background:#f0f4ff;border-color:#5a6ad8}.situation-card:active{transform:scale(.96)}.situation-category{font-size:10px;font-weight:600;color:#999;text-transform:uppercase}.situation-card.selected .situation-category{color:#5a6ad8}.situation-label{font-size:13px;font-weight:600;color:#333;text-align:center;word-break:keep-all}.textbook-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px;background:#f8f8f8;border:2px dashed #ddd;border-radius:14px;cursor:pointer;transition:all .15s ease}.textbook-upload-area:active{background:#f0f0f0;border-color:#bbb}.textbook-upload-area span{font-size:13px;color:#888;font-weight:500}.textbook-upload-area .upload-main-text{font-size:14px;font-weight:600;color:#555}.textbook-upload-area .upload-sub-text{font-size:12px;font-weight:400;color:#999}.textbook-help{display:flex;align-items:flex-start;gap:8px;padding:12px 14px;background:linear-gradient(135deg,#f0f4ff,#f8f0ff);border-radius:10px;margin-top:10px}.textbook-help svg{color:#7c3aed;flex-shrink:0;margin-top:1px}.textbook-help span{font-size:12px;line-height:1.5;color:#666}.textbook-uploaded{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#f0f4ff;border:1px solid #d4dcff;border-radius:12px}.textbook-file-info{display:flex;align-items:center;gap:10px}.textbook-filename{font-size:13px;font-weight:500;color:#333;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.textbook-remove-btn{background:#00000014;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.textbook-remove-btn:active{background:#00000026}.textbook-remove-btn svg{color:#666}.textbook-options{margin-top:16px}.study-mode-list{display:flex;flex-direction:column;gap:10px}.study-mode-btn{display:flex;align-items:flex-start;gap:14px;padding:16px;background:#f8f8f8;border:2px solid transparent;border-radius:14px;text-align:left;transition:all .15s ease}.study-mode-btn.selected{background:#fff;border-color:#5a6ad8;box-shadow:0 2px 12px #5a6ad81f}.study-mode-btn:active{transform:scale(.99)}.study-mode-btn svg{margin-top:2px;flex-shrink:0}.study-mode-text{display:flex;flex-direction:column;gap:4px}.study-mode-label{font-size:14px;font-weight:600;color:#333}.study-mode-desc{font-size:12px;color:#888}.study-mode-btn.selected .study-mode-label{color:#5a6ad8}.study-mode-btn.disabled{opacity:.5;cursor:not-allowed;position:relative}.study-mode-btn.disabled:active{transform:none}.coming-soon-tag{position:absolute;top:8px;right:8px;font-size:10px;font-weight:600;color:#999;background:#f0f0f0;padding:3px 6px;border-radius:4px}.roleplay-type-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding:14px;background:#fafafa;border-radius:12px}.roleplay-type-btn{padding:10px 16px;background:#fff;border:1px solid #e5e5e5;border-radius:20px;font-size:13px;font-weight:500;color:#555;transition:all .15s ease}.roleplay-type-btn.selected{background:#5a6ad8;border-color:#5a6ad8;color:#fff}.roleplay-type-btn:active{transform:scale(.97)}.level-options{display:flex;gap:10px;margin-top:16px}.level-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 10px;background:#f8f8f8;border:2px solid transparent;border-radius:12px;transition:all .15s ease}.level-btn.selected{background:#fff;border-color:#111}.level-btn:active{transform:scale(.98)}.level-label{font-size:15px;font-weight:700;color:#333}.level-desc{font-size:11px;color:#888}.level-btn.selected .level-label{color:#111}.level-btn.selected .level-desc{color:#666}.level-options-v2{display:flex;flex-direction:column;gap:10px;margin-top:16px}.level-btn-v2{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 16px;background:#f8f8f8;border:2px solid transparent;border-radius:14px;transition:all .15s ease;text-align:left}.level-btn-v2.selected{background:#f0f0ff;border-color:#5a6ad8}.level-btn-v2:active{transform:scale(.98)}.level-btn-v2 .level-header{display:flex;align-items:center;gap:8px;width:100%}.level-btn-v2 .level-label{font-size:15px;font-weight:700;color:#333}.level-btn-v2 .level-cefr{font-size:11px;font-weight:600;color:#888;background:#e8e8e8;padding:2px 6px;border-radius:4px}.level-btn-v2 .level-desc{font-size:13px;color:#555;margin-top:2px}.level-btn-v2 .level-detail{font-size:11px;color:#999;margin-top:4px}.level-btn-v2.selected .level-label{color:#5a6ad8}.level-btn-v2.selected .level-cefr{background:#5a6ad8;color:#fff}.level-btn-v2.selected .level-desc{color:#333}.level-btn-v2.selected .level-detail{color:#666}.generate-textbook-area{margin-top:16px}.credit-display{display:flex;justify-content:flex-end;margin-bottom:8px;font-size:13px}.credit-loading{color:#999}.credit-unlimited{color:#5a6ad8;font-weight:600}.credit-balance{color:#666}.credit-balance.insufficient{color:#e53e3e;font-weight:600}.login-required-notice{display:flex;justify-content:center;align-items:center;padding:10px 14px;margin-bottom:8px;background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;font-size:13px;color:#c53030}.generate-textbook-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 20px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;border-radius:14px;font-size:15px;font-weight:600;transition:all .2s ease;box-shadow:0 4px 14px #8b5cf659}.generate-textbook-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #8b5cf673}.generate-textbook-btn:active{transform:scale(.98) translateY(0);box-shadow:0 2px 10px #8b5cf64d}.generate-textbook-btn:disabled{background:linear-gradient(135deg,#d1d5db,#9ca3af);box-shadow:none;cursor:not-allowed;transform:none}.generate-textbook-btn.generating{background:linear-gradient(135deg,#a78bfa,#818cf8);cursor:wait}.generate-textbook-btn svg{color:#fff;flex-shrink:0}.generate-textbook-btn svg.spin{animation:spin 1s linear infinite}.section-divider-text{display:flex;align-items:center;text-align:center;font-size:12px;color:#aaa;margin:20px 0 0}.section-divider-text:before,.section-divider-text:after{content:"";flex:1;height:1px;background:#e5e5e5}.section-divider-text:before{margin-right:12px}.section-divider-text:after{margin-left:12px}.daily-accordion-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;margin-top:16px;background:#f8f8f8;border:1px solid #e8e8e8;border-radius:12px;font-size:14px;font-weight:500;color:#555;cursor:pointer;transition:all .15s ease}.daily-accordion-trigger:hover{background:#f0f0f0}.daily-accordion-trigger.expanded{background:#5a6ad8;border-color:#5a6ad8;color:#fff;border-radius:12px 12px 0 0}.accordion-icon{transition:transform .2s ease}.accordion-icon.rotated{transform:rotate(180deg)}.daily-accordion-content{padding:16px;background:#fafafa;border:1px solid #e8e8e8;border-top:none;border-radius:0 0 12px 12px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.textbook-options.dimmed{opacity:.5;pointer-events:none}.textbook-options.dimmed .study-mode-btn{cursor:default}.textbook-section.dragging{background:#f0f4ff;border-radius:16px}.textbook-section.dragging .textbook-upload-area{border-color:#5a6ad8;background:#e8edff}.custom-topic-input{width:100%;padding:14px 16px;background:#f8f8f8;border:none;border-radius:12px;font-family:inherit;font-size:14px;line-height:1.5;color:#333;resize:none;transition:all .15s ease;margin-top:4px}.custom-topic-input::placeholder{color:#aaa}.custom-topic-input:focus{outline:none;background:#fff;box-shadow:0 2px 12px #0000001a}.daily-templates{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.template-chip{padding:8px 14px;background:#f5f5f5;border:1px solid #e8e8e8;border-radius:20px;font-size:13px;font-weight:500;color:#555;cursor:pointer;transition:all .15s ease}.template-chip:hover{background:#eee;border-color:#ddd}.template-chip.selected{background:#5a6ad8;border-color:#5a6ad8;color:#fff}.template-chip:active{transform:scale(.97)}.preview-overlay{position:fixed;inset:0;background:#0006;z-index:1100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.preview-modal{background:#fff;border-radius:24px 24px 0 0;width:100%;max-width:100%;max-height:92vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid #f3f4f6}.preview-header h2{font-size:18px;font-weight:700;color:#191f28}.preview-back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:transparent;transition:background .15s ease}.preview-back-btn:active{background:#f3f4f6}.preview-back-btn svg{color:#191f28}.preview-content{flex:1;overflow-y:auto;padding:20px 20px 0}.preview-title-section{margin-bottom:24px}.preview-title-ko{font-size:24px;font-weight:700;color:#191f28;margin-bottom:6px;line-height:1.3}.preview-title-en{font-size:15px;color:#8b95a1;font-weight:400}.preview-section{margin-bottom:28px}.preview-section h4{font-size:13px;font-weight:600;color:#8b95a1;margin-bottom:12px}.preview-section h4:before{display:none}.preview-text-ko{font-size:15px;color:#333d4b;line-height:1.7;margin-bottom:8px}.preview-text-en{font-size:14px;color:#8b95a1;line-height:1.6;padding-left:0;border-left:none}.preview-roles{display:flex;gap:10px}.preview-role{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;background:#f9fafb;padding:16px 12px;border-radius:16px;border:none;box-shadow:none;transition:background .15s ease}.preview-role:active{background:#f3f4f6}.role-label{font-size:12px;font-weight:600;color:#6b7280;background:transparent;padding:0;border-radius:0;box-shadow:none}.preview-role:first-child .role-label{color:#3182f6;background:transparent;box-shadow:none}.preview-role:last-child .role-label{color:#8b5cf6}.role-desc{font-size:15px;font-weight:600;color:#191f28;text-align:center}.preview-characters{display:flex;flex-direction:column;gap:8px}.preview-character{display:flex;align-items:center;gap:10px;background:#f9fafb;padding:12px 14px;border-radius:12px}.char-name{font-size:14px;font-weight:600;color:#191f28}.char-viewpoint{font-size:13px;color:#8b95a1}.preview-expressions{display:flex;flex-wrap:wrap;gap:8px}.expression-tag{font-size:13px;color:#3182f6;background:#f0f7ff;padding:6px 12px;border-radius:8px;font-weight:500}.preview-starter{font-size:15px;color:#191f28;line-height:1.6;background:#f9fafb;padding:14px 16px;border-radius:12px;border:none}.preview-footer{display:flex;gap:10px;padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));background:#fff;border-top:1px solid #f3f4f6}.preview-regenerate-btn{flex:1;padding:16px;background:#f9fafb;color:#4b5563;border:none;border-radius:12px;font-size:15px;font-weight:600;transition:background .15s ease}.preview-regenerate-btn:active{background:#f3f4f6}.preview-start-btn{flex:2;padding:16px 24px;background:#3182f6;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s ease}.preview-start-btn:active{background:#1b64da}.preview-expressions-list{display:flex;flex-direction:column;gap:8px}.expression-item{background:#f9fafb;padding:14px 16px;border-radius:12px;border:none;transition:background .15s ease}.expression-item:active{background:#f3f4f6}.expression-en{display:block;font-size:15px;font-weight:600;color:#191f28;margin-bottom:4px}.expression-ko{display:block;font-size:13px;color:#8b95a1}.preview-hint-section{background:#f9fafb;padding:16px;border-radius:12px;border:none}.preview-hint-section h4{color:#8b95a1;margin-bottom:10px;font-size:13px;font-weight:600}.preview-hint-en{font-size:15px;font-weight:500;color:#191f28;margin-bottom:4px;line-height:1.5}.preview-hint-ko{font-size:13px;color:#8b95a1;font-style:normal}.starter-options{display:flex;gap:10px}.starter-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;background:#f9fafb;border:none;border-radius:16px;transition:all .15s ease}.starter-btn.selected{background:#3182f6}.starter-btn:active{transform:scale(.98)}.starter-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;font-size:22px;transition:all .15s ease}.starter-btn.selected .starter-icon{background:#fff3}.starter-label{font-size:15px;font-weight:600;color:#191f28;transition:color .15s ease}.starter-btn.selected .starter-label{color:#fff}.starter-desc{font-size:12px;color:#8b95a1;text-align:center;line-height:1.4}.starter-btn.selected .starter-desc{color:#fffc}.sheet-tabs{display:flex;gap:6px;padding:6px;background:#f5f5f5;border-radius:14px;margin-bottom:20px}.sheet-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 10px;background:transparent;border:none;border-radius:10px;font-size:13px;font-weight:500;color:#888;transition:all .2s ease}.sheet-tab.active{background:#fff;color:#111;font-weight:600;box-shadow:0 2px 8px #00000014}.sheet-tab svg{color:inherit}.sheet-content{flex:1;overflow-y:auto}.tab-panel{display:flex;flex-direction:column;min-height:300px}.panel-section{margin-bottom:24px}.panel-footer{margin-top:auto;padding-top:16px}.panel-footer .start-call-btn{display:flex;align-items:center;justify-content:center;gap:8px}.panel-footer .start-call-btn:disabled{background:linear-gradient(90deg,#d1d5db,#9ca3af);box-shadow:none;cursor:not-allowed}.panel-footer .credit-info{text-align:center;font-size:13px;color:#888;margin-bottom:10px}.panel-footer .credit-deduct-hint{text-align:center;font-size:12px;color:#8b95a1;margin-top:10px;margin-bottom:0}.topic-options{display:flex;gap:10px}.topic-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 10px;background:#fff;border:1.5px solid #f0f0f0;border-radius:16px;transition:all .15s ease;box-shadow:0 1px 3px #0000000a}.topic-btn:hover{border-color:#e0e0e0}.topic-btn.selected{background:#f8faff;border-color:#5a6ad8;box-shadow:0 2px 8px #5a6ad826}.topic-btn:active{transform:scale(.97)}.topic-icon-wrap{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:14px;transition:transform .15s ease}.topic-btn:active .topic-icon-wrap{transform:scale(.95)}.topic-btn span:not(.topic-emoji){font-size:12px;font-weight:500;color:#555}.topic-btn.selected span:not(.topic-emoji){color:#5a6ad8;font-weight:600}.situation-category{margin-bottom:16px}.situation-category .category-label{font-size:12px;font-weight:600;color:#888;margin-bottom:10px}.situation-grid{display:flex;flex-wrap:wrap;gap:8px}.situation-btn{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border:1.5px solid #f0f0f0;border-radius:14px;font-size:14px;font-weight:600;color:#333;transition:all .15s ease;box-shadow:0 1px 3px #0000000a}.situation-btn:hover{border-color:#e0e0e0}.situation-icon-wrap{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px;flex-shrink:0;transition:transform .15s ease}.situation-btn:active .situation-icon-wrap{transform:scale(.92)}.situation-btn.selected{background:#f8faff;border-color:#5a6ad8;color:#5a6ad8;box-shadow:0 2px 8px #5a6ad826}.situation-btn:active{transform:scale(.97)}.selected-situation{background:#f9fafb;padding:14px 16px;border-radius:12px}.selected-situation .selected-label{font-size:11px;font-weight:600;color:#5a6ad8;margin-bottom:6px}.selected-situation .selected-desc{font-size:14px;color:#333;line-height:1.5}.exam-options{display:flex;gap:12px}.exam-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:20px 14px;background:#f8f8f8;border:2px solid transparent;border-radius:14px;transition:all .15s ease}.exam-btn.selected{background:#fff;border-color:var(--exam-color, #6366f1);box-shadow:0 2px 12px #00000014}.exam-btn:active{transform:scale(.98)}.exam-btn .exam-name{font-size:16px;font-weight:700;color:#333}.exam-btn.selected .exam-name{color:var(--exam-color, #6366f1)}.exam-btn .exam-name-ko{font-size:12px;color:#888}.question-type-grid{display:flex;flex-wrap:wrap;gap:8px}.start-call-btn.exam-start{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 4px 16px #6366f159}.chat-topic-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.chat-topic-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 8px;background:#fff;border:1.5px solid #f0f0f0;border-radius:14px;transition:all .15s ease;box-shadow:0 1px 3px #0000000a;position:relative}.chat-topic-btn:hover{border-color:#e0e0e0}.chat-topic-btn.selected{background:#f8faff;border-color:#5a6ad8;box-shadow:0 2px 8px #5a6ad826}.chat-topic-btn:active{transform:scale(.96)}.chat-topic-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:transform .15s ease}.chat-topic-btn:active .chat-topic-icon{transform:scale(.92)}.chat-topic-label{font-size:12px;font-weight:600;color:#333;text-align:center;word-break:keep-all}.chat-topic-btn.selected .chat-topic-label{color:#5a6ad8}.chat-topic-badge{position:absolute;top:4px;right:4px;font-size:9px;font-weight:600;color:#fff;background:#5a6ad8;padding:2px 5px;border-radius:4px}.file-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 20px;background:#fafafa;border:2px dashed #ddd;border-radius:16px;cursor:pointer;transition:all .15s ease}.file-upload-area:hover{background:#f5f5f5;border-color:#ccc}.file-upload-area:active{background:#f0f0f0;border-color:#5a6ad8}.file-upload-title{font-size:15px;font-weight:600;color:#333;margin:0}.file-upload-desc{font-size:13px;color:#666;margin:0}.file-upload-formats{font-size:11px;color:#999;margin:0}.file-uploaded{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#f0f4ff;border:1.5px solid #d4dcff;border-radius:14px}.file-info{display:flex;align-items:center;gap:12px}.file-details{display:flex;flex-direction:column;gap:2px}.file-name{font-size:14px;font-weight:600;color:#333;margin:0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:12px;color:#888;margin:0}.file-remove-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#0000000d;border:none;border-radius:10px;cursor:pointer;transition:all .15s ease}.file-remove-btn:hover{background:#0000001a}.file-remove-btn:active{transform:scale(.95)}.file-study-modes{display:flex;flex-direction:column;gap:10px}.file-study-btn{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#fff;border:1.5px solid #f0f0f0;border-radius:14px;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 3px #0000000a}.file-study-btn:hover{border-color:#e0e0e0}.file-study-btn.selected{background:#f8faff;border-color:#5a6ad8;box-shadow:0 2px 8px #5a6ad826}.file-study-btn:active{transform:scale(.99)}.file-study-btn svg{color:#888;flex-shrink:0}.file-study-btn.selected svg{color:#5a6ad8}.file-study-text{display:flex;flex-direction:column;gap:2px}.file-study-label{font-size:14px;font-weight:600;color:#333}.file-study-btn.selected .file-study-label{color:#5a6ad8}.file-study-desc{font-size:12px;color:#888}.exam-tip{font-size:13px;color:#666;margin-top:14px;padding:12px 14px;background:#fafafa;border-radius:10px;line-height:1.5}.empty-library{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.empty-library svg{margin-bottom:16px}.empty-title{font-size:17px;font-weight:700;color:#333;margin:0 0 8px}.empty-desc{font-size:14px;color:#888;margin:0 0 24px;line-height:1.5}.add-first-btn{display:flex;align-items:center;gap:8px;padding:14px 24px;background:linear-gradient(135deg,#5a6ad8,#7c3aed);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 4px 14px #5a6ad859}.add-first-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #5a6ad873}.add-first-btn:active{transform:scale(.98)}.file-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;border:2px dashed #d0d5dd;border-radius:16px;background:#fafbfc;cursor:pointer;transition:all .2s ease}.file-upload-zone:hover{border-color:#5a6ad8;background:#f5f7ff}.file-upload-zone:active{transform:scale(.99)}.file-upload-zone .upload-title{font-size:16px;font-weight:600;color:#333;margin:12px 0 4px}.file-upload-zone .upload-desc{font-size:13px;color:#888;margin:0 0 16px}.file-upload-zone .upload-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,#5a6ad8,#7c3aed);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #5a6ad84d}.material-count{font-size:11px;font-weight:600;color:#fff;background:#5a6ad8;padding:2px 7px;border-radius:10px;margin-left:auto}.material-library{display:flex;gap:10px;overflow-x:auto;margin:0 -4px;padding:4px 4px 8px;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.material-library::-webkit-scrollbar{display:none}.material-card{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:8px;width:80px;padding:14px 10px 12px;background:#fff;border:1.5px solid #f0f0f0;border-radius:14px;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 3px #0000000a;position:relative}.material-card:hover{border-color:#e0e0e0}.material-card.selected{background:#f0f4ff;border-color:#5a6ad8;box-shadow:0 2px 10px #5a6ad833}.material-card:active{transform:scale(.96)}.material-check{position:absolute;top:6px;left:6px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:#5a6ad8;border-radius:50%}.material-delete{position:absolute;top:4px;right:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#00000014;border:none;border-radius:50%;cursor:pointer;transition:all .15s ease;opacity:0}.material-card:hover .material-delete{opacity:1}.material-delete:hover{background:#ef444426}.material-delete svg{color:#666}.material-delete:hover svg{color:#ef4444}.material-name{font-size:11px;font-weight:600;color:#333;text-align:center;word-break:break-all;line-height:1.3;margin:0}.material-card.selected .material-name{color:#5a6ad8}.material-study-count{font-size:10px;font-weight:500;color:#888;background:#f5f5f5;padding:2px 6px;border-radius:8px}.material-card.selected .material-study-count{background:#e0e5ff;color:#5a6ad8}.material-card.add-new{background:#fafafa;border-style:dashed;border-color:#ddd}.material-card.add-new:hover{background:#f5f5f5;border-color:#ccc}.material-card.add-new.active{background:#f0f4ff;border-color:#5a6ad8;border-style:solid}.material-card.add-new .material-name{color:#888}.material-card.add-new.active .material-name{color:#5a6ad8}.file-upload-area.compact{padding:24px 20px}.file-upload-area.compact .file-upload-title{font-size:14px}.file-upload-area.compact .file-upload-desc{display:none}.script-preview-section .section-label{display:flex;align-items:center;gap:6px}.regenerate-btn{display:flex;align-items:center;gap:4px;margin-left:auto;padding:6px 12px;background:#f7f8fa;border:none;border-radius:8px;font-size:13px;font-weight:500;color:#6b7684;cursor:pointer;transition:all .15s ease}.regenerate-btn:hover{background:#f0f1f3;color:#4e5968}.regenerate-btn:active{transform:scale(.97);background:#e8e9eb}.script-preview{background:#fff;border-radius:20px;padding:24px 20px;display:flex;flex-direction:column;gap:20px;box-shadow:0 2px 12px #0000000f}.script-title h3{margin:0;font-size:20px;font-weight:700;color:#191f28;line-height:1.4;letter-spacing:-.02em}.script-title-en{margin:6px 0 0;font-size:14px;color:#8b95a1;font-weight:400}.script-situation{padding:16px;background:#f7f8fa;border-radius:14px;border:none}.script-situation p{margin:0;font-size:15px;color:#4e5968;line-height:1.7}.script-roles{display:flex;gap:12px}.role-item{flex:1;padding:16px 14px;background:#f7f8fa;border-radius:14px;text-align:center}.role-label{display:block;font-size:12px;font-weight:600;color:#8b95a1;text-transform:uppercase;letter-spacing:.02em;margin-bottom:6px}.role-value{font-size:15px;font-weight:600;color:#191f28}.script-expressions{padding:0;background:transparent;border-radius:0}.expressions-label{display:flex;align-items:center;gap:6px;margin:0 0 12px;font-size:13px;font-weight:600;color:#8b95a1;text-transform:uppercase;letter-spacing:.02em}.expressions-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}.expressions-list li{display:flex;flex-direction:column;gap:4px;padding:14px 16px;background:#f7f8fa;border-radius:12px;border:none}.expr-en{font-size:15px;font-weight:600;color:#191f28}.expr-ko{font-size:13px;color:#8b95a1}.script-hint{padding:16px;background:#f7f8fa;border-radius:14px;border:none}.hint-label{margin:0 0 8px;font-size:13px;font-weight:600;color:#8b95a1;text-transform:uppercase;letter-spacing:.02em}.hint-text{margin:0;font-size:15px;font-weight:500;color:#5a6ad8!important;font-style:normal;line-height:1.6}.generate-script-btn{background:#3182f6!important;box-shadow:none!important}.generate-script-btn:hover{background:#1b6de8!important}.generate-script-btn:active{background:#1560d4!important;transform:scale(.98)}.script-characters{padding:0;background:transparent;border-radius:0}.characters-label{margin:0 0 12px;font-size:13px;font-weight:600;color:#8b95a1;text-transform:uppercase;letter-spacing:.02em}.character-item{display:flex;flex-direction:column;gap:4px;padding:14px 16px;background:#f7f8fa;border-radius:12px;border:none;margin-bottom:10px}.character-item:last-child{margin-bottom:0}.char-name{font-size:15px;font-weight:600;color:#191f28}.char-desc{font-size:13px;color:#6b7684}.script-raw{padding:16px;background:#f7f8fa;border-radius:14px}.raw-label{margin:0 0 10px;font-size:13px;font-weight:600;color:#8b95a1;text-transform:uppercase;letter-spacing:.02em}.raw-content{margin:0;font-size:14px;color:#4e5968;line-height:1.7;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.loading-overlay{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-radius:20px;overflow:hidden;min-height:280px}.loading-overlay:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,#3182f6 20%,#8b5cf6 50%,#3182f6 80%,transparent 100%);animation:scanLine 2s ease-in-out infinite;box-shadow:0 0 20px #3182f680}@keyframes scanLine{0%{top:0;opacity:1}50%{opacity:.8}to{top:calc(100% - 3px);opacity:1}}.loading-icon-wrap{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.loading-icon-wrap:before,.loading-icon-wrap:after{content:"";position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid #3182f6;animation:pulseRing 2s ease-out infinite}.loading-icon-wrap:after{animation-delay:1s}@keyframes pulseRing{0%{transform:scale(.8);opacity:.8}to{transform:scale(1.8);opacity:0}}.loading-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3182f6,#8b5cf6);border-radius:16px;color:#fff;animation:iconFloat 2s ease-in-out infinite;box-shadow:0 8px 24px #3182f64d}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.loading-title{font-size:18px;font-weight:700;color:#191f28;margin:0 0 8px;text-align:center}.loading-desc{font-size:14px;color:#8b95a1;margin:0 0 24px;text-align:center}.extracting-lines{display:flex;flex-direction:column;gap:8px;width:100%;max-width:280px}.extracting-line{height:12px;background:linear-gradient(90deg,#e2e8f0,#f1f5f9,#e2e8f0);background-size:200% 100%;border-radius:6px;animation:shimmer 1.5s infinite}.extracting-line:nth-child(1){width:100%;animation-delay:0s}.extracting-line:nth-child(2){width:85%;animation-delay:.1s}.extracting-line:nth-child(3){width:92%;animation-delay:.2s}.extracting-line:nth-child(4){width:70%;animation-delay:.3s}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.generating-content{width:100%;max-width:300px}.generating-section{margin-bottom:16px}.generating-label{display:flex;align-items:center;gap:8px;margin-bottom:8px}.generating-label-dot{width:8px;height:8px;background:#3182f6;border-radius:50%;animation:dotPulse 1s infinite}.generating-label span{font-size:12px;font-weight:600;color:#8b95a1;text-transform:uppercase;letter-spacing:.05em}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.generating-skeleton{height:16px;background:linear-gradient(90deg,#e2e8f0,#f8fafc,#e2e8f0);background-size:200% 100%;border-radius:8px;animation:shimmer 1.2s infinite}.generating-skeleton.title{height:24px;width:80%;margin-bottom:8px}.generating-skeleton.subtitle{height:14px;width:60%}.generating-skeleton.text{height:14px;margin-bottom:6px}.generating-skeleton.text:last-child{width:75%}.loading-progress{width:100%;max-width:200px;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden;margin-top:8px}.loading-progress-bar{height:100%;background:linear-gradient(90deg,#3182f6,#8b5cf6);border-radius:2px;animation:progressIndeterminate 1.5s ease-in-out infinite}@keyframes progressIndeterminate{0%{width:0%;margin-left:0%}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}.loading-steps{display:flex;gap:8px;margin-top:16px}.loading-step{width:8px;height:8px;background:#e2e8f0;border-radius:50%;transition:all .3s ease}.loading-step.active{background:#3182f6;box-shadow:0 0 8px #3182f680}.loading-step.done{background:#10b981}.precall-embedded{background:#fff;border-radius:0;padding:0;margin-top:16px;box-shadow:none;border:none;border-top:1px solid #f0f0f0;overflow:hidden}.sheet-tabs.embedded{margin-bottom:0;border-radius:0;background:#f8f9fa;padding:8px}.sheet-content.embedded{padding:0;max-height:none;overflow:visible}.sheet-content.embedded .tab-panel{padding:16px}.panel-footer.embedded{padding:8px 16px 16px;background:transparent;position:relative}.panel-footer.embedded .start-call-btn{margin-bottom:0}.credit-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:24px;animation:fadeIn .2s ease}.credit-modal{background:#fff;border-radius:24px;padding:32px 24px 24px;width:100%;max-width:340px;text-align:center;animation:modalBounce .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px #0003}@keyframes modalBounce{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.credit-modal-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:50%;margin-bottom:20px}.credit-modal-title{font-size:20px;font-weight:700;color:#1f2937;margin:0 0 12px}.credit-modal-desc{font-size:14px;color:#6b7280;line-height:1.6;margin:0 0 24px}.credit-modal-buttons{display:flex;flex-direction:column;gap:10px}.credit-modal-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border:none;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease}.credit-modal-btn--trial{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;box-shadow:0 4px 14px #f59e0b66}.credit-modal-btn--trial:hover{transform:translateY(-1px);box-shadow:0 6px 20px #f59e0b80}.credit-modal-btn--trial:active{transform:scale(.98)}.credit-modal-btn--primary{background:linear-gradient(135deg,#5a6ad8,#7c3aed);color:#fff;box-shadow:0 4px 14px #5a6ad866}.credit-modal-btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #5a6ad880}.credit-modal-btn--primary:active{transform:scale(.98)}.credit-modal-btn--secondary{background:#f3f4f6;color:#6b7280}.credit-modal-btn--secondary:hover{background:#e5e7eb}.credit-modal-btn--secondary:active{transform:scale(.98)}.group-tab{padding:0 16px 100px;position:relative}.refresh-btn{display:none}.streak-card{background:#f1f2ff;border-radius:20px;padding:16px 20px;margin-bottom:16px;text-align:center}.streak-card-header{display:flex;align-items:center;justify-content:center;gap:4px;font-size:13px;font-weight:500;color:#888;margin-bottom:8px}.streak-main{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}.streak-days{font-size:48px;font-weight:800;color:#111;line-height:1}.streak-card .streak-unit{font-size:20px;font-weight:600;color:#111;align-self:flex-end;margin-bottom:8px}.streak-stats{display:flex;align-items:center;justify-content:center;background:#fff;border-radius:10px;padding:10px 16px}.streak-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.streak-stat-value{font-size:18px;font-weight:700;color:#111}.streak-stat-label{font-size:11px;font-weight:500;color:#888}.streak-stat-divider{width:1px;height:28px;background:#e5e5e5}.reward-card{display:none}.group-sub-tabs{display:flex;gap:0;margin:0 0 16px;padding:3px;background:#f0f0f0;border-radius:12px}.group-sub-tab{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:10px;font-size:14px;font-weight:600;color:#666;cursor:pointer;transition:all .25s ease}.group-sub-tab:active{transform:scale(.98)}.group-sub-tab.active{background:#fff;color:#111;box-shadow:0 2px 8px #00000014}.group-sub-tab.active:after{display:none}.section-label{font-size:13px;font-weight:600;color:#888;margin:0 0 12px}.friends-content{display:flex;flex-direction:column;gap:20px}.invite-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:#111;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer}.invite-btn:active{background:#333}.ranking-section{background:#fff;border-radius:16px;padding:16px;border:1px solid #f0f0f0}.ranking-list{display:flex;flex-direction:column;gap:8px}.ranking-item{display:flex;flex-direction:row;align-items:center;gap:12px;padding:12px;background:#fafafa;border-radius:12px}.ranking-item:first-child{background:#fffbeb}.ranking-item.is-me{background:#f0f7ff}.ranking-rank{width:24px;min-width:24px;text-align:center;font-size:14px;font-weight:700;color:#666}.ranking-avatar{width:36px;height:36px;min-width:36px;background:#ddd;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600}.ranking-item:first-child .ranking-avatar{background:#f59e0b}.ranking-item:nth-child(2) .ranking-avatar{background:#a78bfa}.ranking-item:nth-child(3) .ranking-avatar{background:#a78bfa}.ranking-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.ranking-name{flex:1;min-width:0;font-size:14px;font-weight:600;color:#333;display:flex;flex-direction:row;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.me-badge{font-size:10px;font-weight:600;color:#3b82f6;background:#eff6ff;padding:2px 6px;border-radius:4px;flex-shrink:0}.ranking-streak{display:flex;flex-direction:row;align-items:center;gap:3px;font-size:13px;font-weight:600;color:#f97316;white-space:nowrap;flex-shrink:0}.studying-section{background:#fff;border-radius:16px;padding:16px;border:1px solid #f0f0f0}.studying-empty{display:flex;flex-direction:column;align-items:center;padding:32px 20px;text-align:center}.studying-empty p{font-size:14px;font-weight:600;color:#333;margin:12px 0 4px}.studying-empty span{font-size:12px;color:#999}.studying-friends-list{display:flex;flex-direction:column;gap:8px}.studying-friend-item{display:flex;flex-direction:row;align-items:center;gap:12px;padding:12px;background:#f0fdf4;border-radius:12px}.studying-friend-item .friend-avatar{width:36px;height:36px;min-width:36px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600}.studying-friend-item span{flex:1;font-size:14px;font-weight:600;color:#111}.studying-indicator{width:8px;height:8px;background:#10b981;border-radius:50%;animation:pulse 2s ease infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.challenge-content{display:flex;flex-direction:column;gap:0}.challenge-wrapper-card{background:#fff;border:1px solid #e8e8e8;border-radius:20px;overflow:hidden}.my-challenge-section{padding:20px 16px}.my-challenge-header{font-size:16px;font-weight:700;color:#111;margin:0 0 16px}.my-challenge-box{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:14px;padding:14px}.my-challenge-box.empty{background:#f1f2fe}.my-challenge-item{display:flex;align-items:center;gap:14px;cursor:pointer}.my-challenge-icon-wrap{width:44px;height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.my-challenge-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.my-challenge-name{font-size:15px;font-weight:600;color:#333}.my-challenge-progress-bar{width:100%;height:8px;background:#0000001a;border-radius:4px;overflow:hidden}.my-challenge-progress-fill{height:100%;background:linear-gradient(90deg,#a8e6cf,#88d8b0);border-radius:4px;transition:width .3s ease}.my-challenge-count{font-size:16px;font-weight:700;color:#667eea;white-space:nowrap}.challenge-divider{height:1px;background:#f0f0f0;margin:0}.challenge-list{padding:0}.challenge-list-item{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #f0f0f0}.challenge-list-item:last-child{border-bottom:none}.challenge-list-info{flex:1;min-width:0}.challenge-list-title{display:block;font-size:15px;font-weight:600;color:#111;margin-bottom:4px}.challenge-list-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:#888}.difficulty-tag{font-size:11px;font-weight:600;padding:2px 6px;border-radius:4px}.difficulty-tag.easy{background:#ecfdf5;color:#059669}.difficulty-tag.medium{background:#fef3c7;color:#d97706}.difficulty-tag.hard{background:#fef2f2;color:#dc2626}.challenge-list-btn{padding:8px 16px;background:#111;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0}.challenge-list-btn:active{background:#333}.challenge-list-btn.joined{background:#f0f0f0;color:#999;cursor:default}.challenge-list-btn:disabled{opacity:.6;cursor:not-allowed}.challenge-wrapper-card .create-challenge-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:calc(100% - 32px);margin:16px 16px 20px;padding:14px;background:#fafafa;border:1.5px dashed #d0d0d0;border-radius:12px;font-size:14px;font-weight:600;color:#666;cursor:pointer}.challenge-wrapper-card .create-challenge-btn:active{background:#fafafa}.challenge-section,.challenge-card{display:none}.my-challenges-list{display:flex;flex-direction:column;gap:10px}.my-challenge-card{display:flex;flex-direction:row;align-items:center;gap:12px;padding:14px 16px;background:#f5f5f5;border-radius:14px;cursor:pointer;transition:background .2s,transform .1s}.my-challenge-card:active{background:#ebebeb;transform:scale(.98)}.my-challenge-icon{width:40px;height:40px;min-width:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.my-challenge-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.my-challenge-title{font-size:14px;font-weight:600;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-challenge-bar{width:100%;height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.my-challenge-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;transition:width .3s ease}.my-challenge-count{font-size:14px;font-weight:700;color:#667eea;white-space:nowrap;flex-shrink:0}.empty-challenges{display:flex;flex-direction:column;align-items:center;padding:32px 20px;background:#fafafa;border-radius:16px;text-align:center}.empty-challenges p{font-size:14px;font-weight:600;color:#333;margin:12px 0 4px}.empty-challenges span{font-size:12px;color:#999}.completed-link{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:4px;background:none;border:none;font-size:13px;font-weight:600;color:#10b981;cursor:pointer;padding:6px 0}.available-challenges{display:flex;flex-direction:column;gap:10px}.available-challenge-card{display:flex;flex-direction:row;align-items:center;gap:12px;padding:14px;background:#fff;border-radius:14px;border:1px solid #f0f0f0}.available-challenge-card.clickable{cursor:pointer;transition:background .2s,transform .1s,box-shadow .2s}.available-challenge-card.clickable:active{transform:scale(.98);background:#fafafa}.challenge-icon-box{width:44px;height:44px;min-width:44px;border-radius:12px;display:flex;align-items:center;justify-content:center}.challenge-info{flex:1;min-width:0}.challenge-info h4{font-size:14px;font-weight:600;color:#111;margin:0 0 3px}.challenge-info p{font-size:12px;color:#888;margin:0 0 6px}.challenge-meta{display:flex;flex-direction:row;align-items:center;gap:8px;flex-wrap:wrap}.challenge-meta span{display:flex;flex-direction:row;align-items:center;gap:3px;font-size:11px;color:#999}.difficulty{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px}.difficulty.easy{background:#ecfdf5;color:#059669}.difficulty.medium{background:#fef3c7;color:#d97706}.difficulty.hard{background:#fef2f2;color:#dc2626}.join-btn{padding:8px 14px;background:#111;color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;flex-shrink:0}.join-btn:active{background:#333}.join-btn:disabled{background:#ddd;cursor:not-allowed}.create-challenge-btn{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;width:100%;padding:14px;background:#fff;border:1px dashed #ddd;border-radius:12px;font-size:14px;font-weight:600;color:#888;cursor:pointer}.create-challenge-btn:active{background:#fafafa}.group-tab.loading-state,.group-tab.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px}.group-tab.loading-state p,.group-tab.error-state p{font-size:13px;color:#666;margin:0}.group-tab.error-state button{padding:10px 20px;background:#111;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;padding:24px 20px;text-align:center}.empty-state p{font-size:13px;color:#666;margin:10px 0 0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:420px;padding:24px 20px calc(40px + env(safe-area-inset-bottom,0px));position:relative;animation:slideUp .25s ease;max-height:85vh;overflow-y:auto}.modal-content:before{content:"";position:absolute;top:10px;left:50%;transform:translate(-50%);width:36px;height:4px;background:#ddd;border-radius:2px}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;background:#f5f5f5;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#666}.modal-close:active{background:#eee}.modal-header{display:flex;flex-direction:row;align-items:center;gap:10px;margin-bottom:16px;padding-top:8px}.modal-header h3{font-size:18px;font-weight:700;color:#111;margin:0}.modal-desc{font-size:14px;color:#666;margin:0 0 20px}.invite-code-box{display:flex;align-items:center;justify-content:center;padding:24px;background:#f8f8f8;border-radius:12px;margin-bottom:16px;min-height:60px}.invite-code{font-size:28px;font-weight:700;letter-spacing:4px;color:#111;font-family:monospace}.invite-actions{display:flex;flex-direction:row;gap:10px;margin-bottom:16px}.copy-btn,.share-btn{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;padding:14px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;border:none}.copy-btn{background:#111;color:#fff}.copy-btn:disabled,.share-btn:disabled{opacity:.5;cursor:not-allowed}.share-btn{background:#f0f0f0;color:#111}.copy-btn:active{background:#333}.share-btn:active{background:#e0e0e0}.invite-note{font-size:12px;color:#999;text-align:center;margin:0}.completed-list{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto}.completed-item{display:flex;flex-direction:row;align-items:center;gap:12px;padding:14px;background:#f8f8f8;border-radius:12px}.completed-icon{width:40px;height:40px;background:#ecfdf5;border-radius:10px;display:flex;align-items:center;justify-content:center}.completed-info{flex:1;min-width:0}.completed-info h4{font-size:14px;font-weight:600;color:#111;margin:0 0 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.completed-info p{font-size:12px;color:#888;margin:0}.completed-badge{width:28px;height:28px;background:#fffbeb;border-radius:50%;display:flex;align-items:center;justify-content:center}.empty-completed{display:flex;flex-direction:column;align-items:center;padding:40px 20px;text-align:center}.empty-completed p{font-size:15px;font-weight:600;color:#333;margin:16px 0 4px}.empty-completed span{font-size:13px;color:#999}.create-form{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:#666}.form-group input,.form-group select{padding:12px 14px;border:1px solid #e5e5e5;border-radius:10px;font-size:14px;color:#111;background:#fff;outline:none}.form-group input:focus,.form-group select:focus{border-color:#111}.form-row{display:flex;flex-direction:row;gap:12px}.form-row .form-group{flex:1}.target-input{display:flex;flex-direction:row;gap:8px}.target-input input{flex:1;min-width:0}.target-input select{width:80px;flex-shrink:0}.create-submit-btn{width:100%;padding:16px;background:#111;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.create-submit-btn:disabled{background:#ddd;cursor:not-allowed}.create-submit-btn:active:not(:disabled){background:#333}.custom-dropdown{position:relative}.dropdown-trigger{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:6px;padding:12px 14px;background:#fff;border:1px solid #e5e5e5;border-radius:10px;font-size:14px;font-weight:500;color:#111;cursor:pointer;width:100%;min-width:80px;transition:border-color .2s,box-shadow .2s}.dropdown-trigger:hover{border-color:#ccc}.dropdown-trigger:focus{border-color:#111;outline:none;box-shadow:0 0 0 2px #0000000d}.dropdown-trigger svg{color:#888;transition:transform .2s;flex-shrink:0}.dropdown-trigger svg.rotate{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e5e5e5;border-radius:10px;box-shadow:0 4px 12px #0000001a;z-index:100;overflow:hidden;animation:dropdownFade .15s ease}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:12px 14px;background:transparent;border:none;font-size:14px;font-weight:500;color:#333;cursor:pointer;text-align:left;transition:background .15s}.dropdown-item:hover{background:#f8f8f8}.dropdown-item:active{background:#f0f0f0}.dropdown-item.selected{background:#f5f5f5;color:#111;font-weight:600}.dropdown-item svg{color:#10b981;flex-shrink:0}.dropdown-item+.dropdown-item{border-top:1px solid #f0f0f0}.difficulty-dropdown .dropdown-trigger{min-width:100px}.difficulty-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600}.target-input .custom-dropdown{flex-shrink:0}.target-input .dropdown-trigger{min-width:70px;width:auto}.target-input .dropdown-menu{min-width:90px}.friend-feed-section{margin-bottom:24px}.friend-feed-section .section-label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#666;margin-bottom:12px}.friend-feed-section .section-label svg{color:#667eea}.friend-feed-list{display:flex;flex-direction:column;gap:0;background:#fff;border:1px solid #e5e5e5;border-radius:14px;overflow:hidden}.friend-feed-item{display:flex;flex-direction:row;gap:12px;padding:14px 16px;border-bottom:1px solid #f0f0f0}.friend-feed-item:last-child{border-bottom:none}.feed-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.feed-avatar img{width:100%;height:100%;object-fit:cover}.feed-avatar span{font-size:16px;font-weight:700;color:#fff}.feed-content{flex:1;min-width:0}.feed-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.feed-nickname{font-size:14px;font-weight:600;color:#111}.feed-time{font-size:12px;color:#999}.feed-summary{font-size:13px;color:#444;margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-style:italic}.feed-meta{display:flex;flex-direction:row;gap:12px}.feed-duration,.feed-tutor{display:flex;align-items:center;gap:4px;font-size:12px;color:#888}.feed-duration svg{color:#667eea}.feed-tutor svg{color:#10b981}.tutor-sheet-overlay{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;justify-content:flex-end}.tutor-sheet-overlay.closing{pointer-events:none}.tutor-sheet-backdrop{position:absolute;inset:0;background:#0000;transition:background-color .3s ease-out;-webkit-tap-highlight-color:transparent}.tutor-sheet-overlay.visible .tutor-sheet-backdrop{background:#00000080}.tutor-sheet-overlay.closing .tutor-sheet-backdrop{background:#0000}.tutor-sheet{position:relative;background:#fff;border-radius:24px 24px 0 0;max-height:85vh;display:flex;flex-direction:column;max-width:480px;margin:0 auto;width:100%;transform:translateY(100%);transition:transform .3s cubic-bezier(.32,.72,0,1);will-change:transform}.tutor-sheet.visible{transform:translateY(0)}.tutor-sheet.closing{transform:translateY(100%)}.tutor-sheet-handle{display:flex;justify-content:center;padding:12px 0 8px}.handle-bar{width:36px;height:4px;background:#ddd;border-radius:2px}.tutor-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px 16px;border-bottom:1px solid #f0f0f0}.tutor-sheet-header h2{font-size:16px;font-weight:600;color:#111}.tutor-sheet-close{display:flex;align-items:center;justify-content:center;color:#999;background:transparent;padding:4px}.tutor-sheet-content{flex:1;overflow-y:auto;padding:20px 0}.sheet-section-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px 16px}.sheet-section-main-title{font-size:18px;font-weight:700;color:#111}.sheet-section-actions{display:flex;align-items:center;gap:8px}.sheet-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;color:#999;background:transparent;transition:all .15s ease}.sheet-action-btn.active{background:#111;color:#fff}.sheet-subsection{padding:0 20px 20px}.sheet-subsection-title{font-size:13px;font-weight:500;color:#888;margin-bottom:12px}.sheet-filter-chips{display:flex;gap:8px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}.sheet-filter-chips::-webkit-scrollbar{display:none}.sheet-filter-chip{padding:10px 18px;background:#fff;border:1.5px solid #eee;border-radius:24px;font-size:14px;font-weight:500;color:#666;white-space:nowrap;transition:all .15s ease}.sheet-filter-chip.active{background:#111;border-color:#111;color:#fff}.sheet-tutor-carousel{display:flex;gap:12px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:8px}.sheet-tutor-carousel::-webkit-scrollbar{display:none}.sheet-tutor-card{flex-shrink:0;width:140px;display:flex;flex-direction:column;align-items:center;padding:20px 12px;background:#fff;border:2px solid #eee;border-radius:16px;cursor:pointer;transition:all .15s ease;position:relative}.sheet-tutor-card.selected{border-color:#111}.sheet-tutor-card.create-card{border-style:dashed;border-color:#ddd;background:#fafafa}.sheet-tutor-avatar{width:64px;height:64px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:10px}.sheet-tutor-avatar img{width:100%;height:100%;object-fit:cover}.sheet-tutor-avatar span{font-size:24px;font-weight:600;color:#fff}.sheet-tutor-avatar.create-avatar{background:#f0f0f0;border:2px dashed #ccc}.sheet-tutor-meta{font-size:11px;color:#999;margin-bottom:2px}.sheet-tutor-name{font-size:15px;font-weight:700;color:#111;margin-bottom:8px;text-align:center}.sheet-tutor-tags{display:flex;gap:4px;flex-wrap:wrap;justify-content:center}.sheet-tutor-tag{font-size:11px;color:#888;background:#f5f5f5;padding:4px 8px;border-radius:6px}.sheet-custom-badge{position:absolute;top:8px;left:8px;background:#111;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px}.sheet-carousel-dots{display:flex;justify-content:center;gap:6px;margin-top:16px}.sheet-dot{width:6px;height:6px;border-radius:50%;background:#ddd;cursor:pointer;transition:all .2s ease}.sheet-dot.active{background:#111;width:18px;border-radius:3px}.sheet-difficulty-cards{display:flex;flex-direction:column;gap:10px}.sheet-difficulty-card{background:#fff;border:1.5px solid #eee;border-radius:14px;padding:16px;text-align:left;transition:all .15s ease}.sheet-difficulty-card.selected{border-color:#111}.sheet-difficulty-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.sheet-difficulty-label{font-size:15px;font-weight:600;color:#111}.sheet-difficulty-check{width:24px;height:24px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.sheet-difficulty-desc{font-size:13px;color:#666;margin-bottom:4px}.sheet-difficulty-detail{font-size:12px;color:#999}.sheet-option-row{display:flex;gap:8px;flex-wrap:wrap}.sheet-option-btn{flex:1;min-width:0;padding:14px 12px;background:#f5f5f5;border-radius:12px;font-size:14px;font-weight:500;color:#666;text-align:center;transition:all .15s ease;white-space:nowrap}.sheet-option-btn.selected{background:#111;color:#fff}.tutor-sheet-footer{padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));border-top:1px solid #f0f0f0;background:#fff}.sheet-save-btn{width:100%;padding:16px;background:#111;color:#fff;border-radius:14px;font-size:16px;font-weight:600;transition:all .15s ease}.sheet-save-btn:active{background:#333;transform:scale(.98)}.sheet-save-toast{position:absolute;bottom:100px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 24px;background:#111;color:#fff;border-radius:50px;font-size:14px;font-weight:600;box-shadow:0 4px 20px #0003;animation:toastPop .3s ease;z-index:10}@keyframes toastPop{0%{opacity:0;transform:translate(-50%) scale(.8)}to{opacity:1;transform:translate(-50%) scale(1)}}.sheet-coming-soon-toast{position:absolute;bottom:100px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 24px;background:#7c3aed;color:#fff;border-radius:50px;font-size:14px;font-weight:600;box-shadow:0 4px 20px #7c3aed4d;animation:toastPop .3s ease;z-index:10}.feedback-banner{background:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:var(--radius-xl, 16px);padding:20px 16px;margin-top:8px;animation:feedbackSlideIn .3s ease-out}@keyframes feedbackSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.feedback-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md, 16px)}.feedback-question{display:flex;align-items:center;gap:6px;font-size:var(--font-base, 14px);font-weight:var(--font-semibold, 600);color:var(--text-secondary, #6b7280)}.question-icon{color:var(--color-gray-400, #9ca3af)}.feedback-ratings{display:flex;gap:var(--spacing-md, 12px);justify-content:center}.rating-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 20px;background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:var(--radius-lg, 12px);cursor:pointer;transition:all var(--transition-normal, .2s ease);min-width:85px}.rating-btn:active{transform:scale(.96)}.rating-btn.selected{background:var(--color-primary-light, #ede9fe);border-color:transparent}.rating-icon{color:var(--color-gray-400, #9ca3af);transition:color var(--transition-fast, .15s ease)}.rating-btn.selected .rating-icon{color:var(--color-primary, #5046e4)}.rating-label{font-size:var(--font-xs, 12px);font-weight:var(--font-medium, 500);color:var(--text-secondary, #6b7280)}.rating-btn.selected .rating-label{color:var(--color-primary, #5046e4);font-weight:var(--font-semibold, 600)}.feedback-category-section{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.feedback-header{display:flex;align-items:center;gap:var(--spacing-sm, 8px)}.back-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:var(--radius-md, 8px);color:var(--text-secondary, #6b7280);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.back-btn:active{background:var(--bg-tertiary, #f3f4f6)}.category-prompt{font-size:var(--font-base, 14px);font-weight:var(--font-semibold, 600);color:var(--text-primary, #1f2937);margin:0;flex:1}.category-hint{font-size:var(--font-xs, 12px);color:var(--text-muted, #9ca3af);margin:0;text-align:center}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm, 8px)}.category-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:var(--radius-lg, 12px);cursor:pointer;transition:all var(--transition-normal, .2s ease)}.category-btn:active{transform:scale(.96)}.category-btn.selected{background:var(--color-primary-light, #ede9fe);border-color:transparent}.category-icon{color:var(--color-gray-400, #9ca3af);transition:color var(--transition-fast, .15s ease)}.category-btn.selected .category-icon{color:var(--color-primary, #5046e4)}.category-label{font-size:11px;font-weight:var(--font-medium, 500);color:var(--text-secondary, #6b7280)}.category-btn.selected .category-label{color:var(--color-primary, #5046e4);font-weight:var(--font-semibold, 600)}.category-next-btn{width:100%;padding:12px;background:var(--color-primary, #5046e4);border:none;border-radius:var(--radius-lg, 12px);font-size:var(--font-base, 14px);font-weight:var(--font-semibold, 600);color:#fff;cursor:pointer;transition:all var(--transition-fast, .15s ease);margin-top:var(--spacing-xs, 4px)}.category-next-btn:active{background:var(--color-primary-dark, #4338ca)}.feedback-comment-section{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.comment-prompt{font-size:var(--font-base, 14px);font-weight:var(--font-semibold, 600);color:var(--text-primary, #1f2937);margin:0;text-align:center}.selected-categories{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.selected-category-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--color-primary-light, #ede9fe);border-radius:var(--radius-full, 9999px);font-size:var(--font-xs, 12px);color:var(--color-primary, #5046e4);font-weight:var(--font-medium, 500)}.comment-input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.feedback-comment-input{width:100%;padding:12px 14px;background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:var(--radius-lg, 12px);font-size:var(--font-base, 14px);color:var(--text-primary, #374151);resize:none;outline:none;font-family:inherit;transition:border-color var(--transition-fast, .15s ease)}.feedback-comment-input::placeholder{color:var(--text-muted, #9ca3af)}.feedback-comment-input:focus{border-color:var(--color-primary, #5046e4)}.comment-actions{display:flex;gap:var(--spacing-sm, 8px);justify-content:flex-end}.skip-btn{padding:10px 16px;background:transparent;border:none;border-radius:var(--radius-lg, 12px);font-size:var(--font-sm, 13px);font-weight:var(--font-medium, 500);color:var(--text-muted, #9ca3af);cursor:pointer;transition:all var(--transition-fast, .15s ease)}.skip-btn:active{background:var(--bg-tertiary, #f3f4f6)}.skip-btn:disabled{opacity:.5}.submit-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--color-primary, #5046e4);border:none;border-radius:var(--radius-lg, 12px);font-size:var(--font-sm, 13px);font-weight:var(--font-semibold, 600);color:#fff;cursor:pointer;transition:all var(--transition-fast, .15s ease)}.submit-btn:active{background:var(--color-primary-dark, #4338ca)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.feedback-banner.submitted{background:#f0fdf4;border-color:#bbf7d0}.feedback-thank-you{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm, 8px);padding:var(--spacing-sm, 8px) 0}.thank-you-icon{color:var(--color-success, #22c55e);animation:heartPop .4s ease}@keyframes heartPop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.feedback-thank-you p{font-size:var(--font-md, 15px);font-weight:var(--font-semibold, 600);color:var(--color-success, #22c55e);margin:0}.app-footer{padding:24px 20px 32px;text-align:center;background:#f5f5f5;margin-top:40px}.footer-en-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:20px;font-size:13px;font-weight:500;color:#555;cursor:pointer;margin-bottom:16px;transition:all .2s ease}.footer-en-btn:hover{background:#f8f8f8;border-color:#2d5a47;color:#2d5a47}.footer-links{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}.footer-links button,.footer-links a{background:none;border:none;font-size:13px;color:#666;cursor:pointer;text-decoration:none;padding:4px 8px;border-radius:4px;transition:all .15s ease}.footer-links button:hover,.footer-links a:hover{color:#333;background:#0000000d}.footer-links .dot{color:#ccc;font-size:12px}.footer-copyright{font-size:12px;color:#999;margin:0}.knock-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:knockFadeIn .3s ease;padding:20px}.knock-modal{background:#fff;border-radius:24px;padding:32px 24px 24px;width:100%;max-width:340px;position:relative;text-align:center;box-shadow:0 24px 80px #00000040;animation:knockSlideUp .4s cubic-bezier(.16,1,.3,1)}.knock-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;padding:6px;color:#94a3b8;border-radius:8px;transition:background .2s}.knock-close:hover{background:#f1f5f9;color:#475569}.knock-icon{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,#60a5fa,#3b82f6);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#fff;box-shadow:0 8px 24px #3b82f64d}.knock-title{margin:0 0 6px;font-size:18px;font-weight:700;color:#1e293b;line-height:1.4}.knock-body{margin:0 0 16px;font-size:14px;color:#64748b;line-height:1.5}.knock-countdown{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:20px;padding:8px 16px;background:#fef3c7;border-radius:10px;color:#92400e;font-size:14px;font-weight:600}.knock-actions{display:flex;flex-direction:column;gap:10px}.knock-btn{width:100%;padding:14px 20px;border-radius:14px;border:none;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:transform .15s,opacity .15s}.knock-btn:active{transform:scale(.97)}.knock-btn.accept{background:#3b82f6;color:#fff;box-shadow:0 4px 16px #3b82f64d}.knock-btn.accept:hover{opacity:.9}.knock-btn.reject{background:#f1f5f9;color:#475569}.knock-btn.reject:hover{background:#e2e8f0}.knock-hint{margin:14px 0 0;font-size:12px;color:#94a3b8}@keyframes knockFadeIn{0%{opacity:0}to{opacity:1}}@keyframes knockSlideUp{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.home-tab-content,.call-tab-content,.schedule-section{animation:tabFadeIn .2s ease}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ringle-home{min-height:100vh;background:#fafafa;padding-bottom:env(safe-area-inset-bottom,20px)}.ringle-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 16px;padding-top:calc(20px + env(safe-area-inset-top,0px));padding-left:calc(20px + env(safe-area-inset-left,0px));padding-right:calc(20px + env(safe-area-inset-right,0px));background:#fafafa}.ringle-header h1{font-size:22px;font-weight:700;color:#111;letter-spacing:-.5px}.header-left{display:flex;align-items:center;gap:8px}.beta-badge{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;font-size:10px;font-weight:700;padding:4px 8px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 6px #f9731659}.header-icons{display:flex;align-items:center;gap:10px}.streak-badge{display:flex;align-items:center;gap:5px;background:linear-gradient(135deg,#312e81,#4338ca);padding:8px 14px;border-radius:24px;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;box-shadow:0 2px 8px #6366f14d}.streak-badge:active{opacity:.85;transform:scale(.98)}.streak-count{font-size:13px;font-weight:600;color:#fffffff2;letter-spacing:.3px}.streak-icon{filter:drop-shadow(0 0 4px rgba(165,180,252,.6));animation:starGlow 2s ease-in-out infinite}@keyframes starGlow{0%,to{filter:drop-shadow(0 0 4px rgba(165,180,252,.6));opacity:1}50%{filter:drop-shadow(0 0 6px rgba(165,180,252,.9));opacity:.95}}.profile-wrapper{position:relative}.contact-btn{width:36px;height:36px;border-radius:50%;background:#f0f0f0;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.contact-btn:hover{background:#e0e0e0}.profile-btn{width:36px;height:36px;border-radius:50%;background:#f0f0f0;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden}.profile-img{width:100%;height:100%;object-fit:cover}.profile-backdrop{position:fixed;inset:0;z-index:99}.profile-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:14px;box-shadow:0 4px 20px #0000001f;min-width:200px;z-index:100;overflow:hidden;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.profile-info{padding:14px 16px;border-bottom:1px solid #f0f0f0}.profile-email{font-size:13px;color:#666;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-menu-btn{width:100%;display:flex;align-items:center;gap:10px;padding:14px 16px;background:none;border:none;font-size:14px;color:#666;cursor:pointer;transition:all .15s ease}.logout-menu-btn:active{background:#f5f5f5}.tabs{display:flex;background:#fff;margin:0 16px;padding:4px;border-radius:12px;gap:4px}.tab{flex:1;padding:10px 0;font-size:14px;font-weight:500;color:#888;background:none;border:none;border-radius:10px;transition:all .2s ease}.tab.active{color:#111;background:#f0f0f0;font-weight:600}.main-content{padding:16px}.tutor-card{position:relative;background:#fff;border-radius:16px;padding:24px 16px 20px;text-align:center;cursor:pointer;transition:all .15s ease}.tutor-card:active{transform:scale(.98);background:#fafafa}.tutor-avatar-wrapper{position:relative;display:inline-block;margin-bottom:12px}.tutor-edit-icon{position:absolute;bottom:-4px;right:-4px;width:26px;height:26px;background:#fff;border:1px solid #e0e0e0;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#666;box-shadow:0 1px 3px #0000001a}.tutor-avatar{width:70px;height:70px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;border:2px solid #eee;box-shadow:0 2px 8px #0000001a}.tutor-avatar span{font-size:28px;font-weight:600;color:#fff}.tutor-avatar-img{width:100%;height:100%;object-fit:cover}.tutor-tags{display:flex;justify-content:center;gap:5px;margin-bottom:8px}.personality-tag{padding:4px 10px;background:#f5f5f5;border-radius:5px;font-size:12px;color:#666}.tutor-name{font-size:20px;font-weight:700;color:#111;margin-bottom:4px;letter-spacing:-.5px}.tutor-info-tags{display:flex;justify-content:center;gap:10px}.info-tag{font-size:12px;color:#999}.tutor-greeting{margin-top:12px;font-size:13px;color:#666;font-style:italic;text-align:center;line-height:1.4}.tutor-expand-hint{margin-top:16px;font-size:13px;color:#999;padding:8px 16px;background:#f5f5f5;border-radius:20px;display:inline-block}.tutor-card.expanded{border:2px solid #111}.tutor-card.expanded .tutor-expand-hint{background:#111;color:#fff}.tutor-options{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.tutor-option-btn{display:flex;align-items:center;gap:12px;width:100%;padding:16px 20px;background:#fff;border:1.5px solid #e5e5e5;border-radius:14px;font-size:15px;font-weight:500;color:#333;text-align:left;cursor:pointer;transition:all .15s ease}.tutor-option-btn:hover{background:#fafafa}.tutor-option-btn:active{background:#f0f0f0;transform:scale(.98)}.tutor-option-btn svg{color:#666;flex-shrink:0}.topic-setting-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background:#fff;border:1.5px solid #e5e5e5;border-radius:14px;font-size:15px;font-weight:600;color:#333;margin-bottom:12px;cursor:pointer;transition:all .15s ease}.topic-setting-btn:active{background:#f5f5f5;transform:scale(.98)}.topic-setting-btn svg{color:#7c3aed}.call-btn-wrapper{display:flex;justify-content:center;margin-top:8px}.call-btn{width:100%;padding:16px 24px;background:linear-gradient(90deg,#8b5cf6,#7c3aed,#6366f1);color:#fff;border:none;border-radius:50px;font-size:15px;font-weight:600;box-shadow:0 4px 20px #8b5cf666;display:flex;align-items:center;justify-content:center}.call-btn-icon{width:44px;height:44px;background:#ffffff40;border-radius:50%;display:flex;align-items:center;justify-content:center}.call-btn:active{transform:scale(.98);box-shadow:0 2px 12px #6366f166}.call-tab-content{display:flex;flex-direction:column;gap:16px}.minimal-cards-row{display:flex;flex-direction:column;gap:8px}.minimal-card{display:flex;align-items:center;gap:14px;padding:16px;background:#fff;border-radius:14px;cursor:pointer;transition:all .15s ease}.minimal-card:active{background:#f8f8f8;transform:scale(.98)}.minimal-card-icon{width:44px;height:44px;background:#f5f5f5;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#111}.minimal-card-text{flex:1;display:flex;flex-direction:column;gap:2px}.minimal-card-label{font-size:15px;font-weight:600;color:#111}.minimal-card-desc{font-size:12px;color:#888}.call-history-section{background:#fff;border-radius:16px;padding:16px;margin-top:8px}.call-history-section .month-navigator{position:sticky;top:0;background:#fff;padding-bottom:8px;z-index:5}.history-scroll-area{max-height:300px;overflow-y:auto;-webkit-overflow-scrolling:touch}.empty-history-small{text-align:center;padding:24px;color:#999;font-size:13px}.custom-tutor-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;background:linear-gradient(135deg,#f8f8f8,#f0f0f0);border:1.5px solid #e0e0e0;border-radius:12px;font-size:14px;font-weight:600;color:#333;margin-top:12px;transition:all .15s ease}.custom-tutor-btn:active{background:linear-gradient(135deg,#f0f0f0,#e8e8e8);transform:scale(.98)}.custom-tutor-btn-img{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid #111}.custom-scenario-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:linear-gradient(135deg,#f3e8ff,#e0e7ff);border:1.5px solid #c4b5fd;border-radius:12px;font-size:14px;font-weight:600;color:#6d28d9;margin-top:12px;transition:all .15s ease}.custom-scenario-btn:active{background:linear-gradient(135deg,#ede9fe,#ddd6fe);transform:scale(.98)}.custom-scenario-btn svg{color:#7c3aed}.test-call-btn{width:100%;padding:14px;background:transparent;color:#999;border:1px dashed #ddd;border-radius:12px;font-size:14px;font-weight:500;margin-top:12px;transition:all .15s ease}.test-call-btn:active{background:#f5f5f5;color:#666}.history-section{display:flex;flex-direction:column;gap:16px}.weekly-progress-card{background:#fff;border-radius:16px;padding:20px;margin-bottom:12px}.weekly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.weekly-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#111}.weekly-count{font-size:14px;font-weight:700;color:#111}.progress-bar-wrapper{height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden;margin-bottom:10px}.progress-bar-fill{height:100%;background:#111;border-radius:4px;transition:width .3s ease}.weekly-message{font-size:13px;color:#888}.weekly-message .achieved{color:#111;font-weight:600}.summary-card{background:#fff;border-radius:16px;padding:20px;display:flex;align-items:center}.summary-divider-line{display:none}.summary-item{flex:1;text-align:center}.summary-value{display:block;font-size:18px;font-weight:700;color:#111;margin-bottom:4px}.summary-label{font-size:11px;color:#999}.summary-divider{width:1px;height:36px;background:#eee}.notice-banner{background:#fff;border-radius:14px;padding:16px;display:flex;gap:12px;align-items:flex-start}.notice-icon{font-size:18px}.notice-text{flex:1}.notice-title{font-size:14px;font-weight:600;color:#111;margin-bottom:2px}.notice-desc{font-size:13px;color:#888}.month-navigator{display:flex;align-items:center;justify-content:space-between;padding:4px 0 12px}.month-title{font-size:18px;font-weight:700;color:#111}.month-arrows{display:flex;gap:4px}.month-arrows button{background:none;border:none;padding:4px;color:#888}.month-nav-left{display:flex;align-items:center;gap:8px}.clear-filter-btn{background:#5a6ad8;color:#fff;font-size:12px;font-weight:500;padding:6px 12px;border-radius:16px;border:none;cursor:pointer;transition:all .15s ease}.clear-filter-btn:active{opacity:.8;transform:scale(.95)}.delete-all-btn{display:flex;align-items:center;gap:6px;background:none;border:none;padding:6px 0;font-size:13px;color:#999;cursor:pointer;transition:all .2s}.delete-all-btn:active{color:#666}.filter-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 0}.checkbox{width:20px;height:20px;border:2px solid #ddd;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.checkbox.checked{background:#111;border-color:#111;color:#fff}.filter-checkbox span{font-size:14px;color:#666}.session-list-item{display:flex;align-items:center;justify-content:space-between;padding:18px 0;background:transparent;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:all .15s ease}.session-list-item:last-child{border-bottom:none}.session-list-item:active{background:#fafafa}.session-list-date{flex:1;font-size:14px;font-weight:500;color:#333;white-space:nowrap}.session-list-words{font-size:13px;font-weight:500;color:#999;white-space:nowrap}.session-list-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.session-list-delete{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:8px;color:#ccc;cursor:pointer;transition:all .15s ease}.session-list-delete:active{background:#eee;color:#999}.call-card-v2{background:#f5f5f5;border-radius:14px;padding:14px;margin-bottom:8px}.call-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.call-card-info{flex:1;min-width:0}.call-date-v2{font-size:13px;font-weight:600;color:#111;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis}.call-stats{display:flex;gap:6px}.call-stat{font-size:11px;color:#666}.quick-review-btn{display:flex;align-items:center;gap:5px;padding:8px 12px;background:#111;color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;transition:all .15s ease;flex-shrink:0}.quick-review-btn:active{background:#333}.call-card-btns{display:flex;align-items:center;gap:6px}.delete-session-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:8px;color:#bbb;cursor:pointer;transition:all .2s;flex-shrink:0}.delete-session-btn:active{background:#eee;color:#999}.call-card-actions{display:flex;gap:6px}.call-action-chip{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#fff;border:none;border-radius:8px;font-size:12px;font-weight:500;color:#555;transition:all .15s ease}.call-action-chip:active{background:#eee}.call-card{background:#fff;border-radius:16px;padding:18px;margin-bottom:10px}.call-type-tag{display:inline-block;padding:4px 10px;background:#f5f5f5;border-radius:6px;font-size:12px;font-weight:500;color:#888;margin-bottom:10px}.call-date{font-size:15px;font-weight:600;color:#111;margin-bottom:4px}.call-words{font-size:13px;color:#888;margin-bottom:16px}.word-count-ok{color:#111;font-weight:500}.word-count-low{color:#bbb}.word-threshold{color:#ccc}.call-buttons{display:flex;flex-direction:column;gap:8px}.call-btn-item{width:100%;padding:14px;background:#fafafa;border:none;border-radius:12px;font-size:14px;font-weight:500;color:#333;text-align:center;transition:all .15s ease}.call-btn-item:active{background:#f0f0f0}.empty-history{text-align:center;padding:60px 20px;background:#fff;border-radius:16px}.empty-icon{width:72px;height:72px;background:#f5f5f5;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.empty-history p{font-size:15px;color:#333;margin-bottom:4px}.empty-history .sub{font-size:13px;color:#999}.loading-sessions{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px 20px;background:#fff;border-radius:16px;color:#888;font-size:14px}.schedule-section{display:flex;flex-direction:column;gap:12px}.selected-date-card{background:#fff;border-radius:16px;padding:20px}.selected-date-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.selected-date-title{font-size:16px;font-weight:600;color:#111}.selected-date-close{background:none;border:none;font-size:14px;font-weight:500;color:#888;cursor:pointer}.selected-date-items{display:flex;flex-direction:column;gap:8px}.selected-date-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fafafa;border-radius:10px}.selected-date-item.done{background:#f0f0f0}.item-label{font-size:15px;font-weight:500;color:#333}.item-status{font-size:14px;font-weight:500;color:#999}.selected-date-item.done .item-status{color:#111}.selected-date-empty{text-align:center;padding:24px;font-size:14px;color:#999}.schedule-settings{background:#fff;border-radius:16px;padding:20px;margin-bottom:12px}.schedule-settings-title{font-size:16px;font-weight:600;color:#111;margin-bottom:16px}.schedule-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #f5f5f5}.schedule-item:last-child{border-bottom:none;padding-bottom:0}.schedule-item:first-of-type{padding-top:0}.schedule-item-left{display:flex;align-items:center;gap:12px}.schedule-item-title{font-size:15px;font-weight:500;color:#111}.schedule-time{background:#f5f5f5;border:none;border-radius:6px;padding:6px 10px;font-size:14px;font-weight:500;color:#111;outline:none;-webkit-appearance:none}.schedule-time::-webkit-calendar-picker-indicator{display:none}.schedule-toggle{position:relative;width:44px;height:26px;flex-shrink:0}.schedule-toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:#e5e5e5;transition:.2s ease;border-radius:13px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background:#fff;transition:.2s ease;border-radius:50%}.schedule-toggle input:checked+.toggle-slider{background:#111}.schedule-toggle input:checked+.toggle-slider:before{transform:translate(18px)}.schedule-call-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;background:linear-gradient(135deg,#7c3aed,#6d28d9);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;margin-bottom:16px;cursor:pointer;transition:all .15s ease;box-shadow:0 4px 12px #7c3aed4d}.schedule-call-btn:active{transform:scale(.98)}.schedule-shortcuts{display:flex;gap:8px}.shortcut-btn{flex:1;padding:14px;background:#fafafa;border:none;border-radius:12px;font-size:14px;font-weight:600;color:#111;cursor:pointer;transition:background .15s ease}.shortcut-btn:active{background:#f0f0f0}.google-events-section{background:#fff;border-radius:16px;padding:16px;margin-bottom:16px}.google-events-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.google-events-header h3{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;color:#111}.event-count{font-size:13px;color:#888}.google-events-list{display:flex;flex-direction:column;gap:8px}.google-event-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f8f8;border-radius:10px}.google-event-item.past{opacity:.5}.event-time{font-size:14px;font-weight:600;color:#7c3aed;min-width:50px}.event-title{font-size:14px;color:#333;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.google-loading,.google-empty{text-align:center;font-size:14px;color:#888;padding:20px 0}.google-connect-hint{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 16px;background:#fff;border-radius:16px;margin-bottom:16px;text-align:center}.google-connect-hint p{font-size:14px;color:#666;line-height:1.5}.google-connect-hint button{padding:10px 24px;background:#111;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer}.google-connect-hint button:active{background:#333}.english-events-banner{background:linear-gradient(135deg,#eff6ff,#f0f9ff);border:1px solid #dbeafe;border-radius:16px;padding:16px;margin:0 20px 16px}.english-banner-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.english-banner-header span{font-size:14px;font-weight:600;color:#1d4ed8}.english-events-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.english-event-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000d}.english-event-item svg{color:#64748b;flex-shrink:0}.english-event-item.past{opacity:.5}.english-event-item.upcoming{background:#fff;border:1px solid #3b82f6}.english-event-item.upcoming svg{color:#3b82f6}.english-event-time{font-size:13px;font-weight:600;color:#3b82f6;min-width:65px}.english-event-title{flex:1;font-size:14px;font-weight:500;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upcoming-badge{font-size:11px;font-weight:600;color:#fff;background:#3b82f6;padding:3px 8px;border-radius:10px;flex-shrink:0}.english-banner-hint{font-size:13px;color:#64748b;text-align:center;margin:0}.home-tab-content{display:flex;flex-direction:column;gap:12px;padding-bottom:90px}.greeting-section{padding:8px 4px 12px}.greeting-text{font-size:24px;font-weight:600;color:#111;line-height:1.4;letter-spacing:-.5px}.greeting-name{color:#4b5fd8;font-weight:700}.home-section-card{background:#fff;border-radius:16px;padding:16px;margin-top:12px}.home-section-card.collapsible{padding:0}.home-section-card.collapsible .home-section-header-toggle{padding:16px}.home-section-card.collapsible .section-content{padding:0 16px 16px;margin-top:0}.home-section-card.collapsible .section-content.collapsed{padding:0 16px}.home-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.home-section-header-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;min-height:28px;-webkit-tap-highlight-color:transparent;transition:opacity .15s ease}.home-section-header-toggle:active{opacity:.7}.home-section-header-left{display:flex;align-items:center;gap:8px}.section-toggle-icon{color:#888;transition:transform .25s ease}.section-toggle-icon.collapsed{transform:rotate(-90deg)}.section-content{overflow:hidden;max-height:500px;opacity:1;margin-top:16px;transition:max-height .3s ease,opacity .25s ease,margin-top .25s ease}.section-content.collapsed{max-height:0;opacity:0;margin-top:0}.home-section-title{font-size:16px;font-weight:600;color:#111;margin:0}.home-section-count{font-size:14px;font-weight:600;color:#888}.home-section-count .count-done{color:#555}.home-quiz-list{display:flex;flex-direction:column;gap:8px}.home-quiz-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#fff;border-radius:12px;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 8px #0000000f}.home-quiz-item:active{background:#ebebeb}.home-quiz-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:12px;color:#6366f1}.home-quiz-icon.business{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.home-quiz-text{flex:1;font-size:14px;font-weight:500;color:#333}.weekly-cards{display:flex;gap:6px;justify-content:center;margin-top:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f0f0f0}.weekly-card{width:40px;height:56px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:transparent;border-radius:12px;position:relative;transition:all .15s ease;cursor:pointer}.weekly-card:active{transform:scale(.95)}.weekly-card.today{background:#111}.weekly-card.today .weekly-day,.weekly-card.today .weekly-date{color:#fff}.weekly-card.completed:not(.today){background:#f0f0f0}.weekly-card.completed:not(.today) .weekly-day,.weekly-card.completed:not(.today) .weekly-date{color:#111;font-weight:600}.weekly-card.selected{background:#111}.weekly-card.selected .weekly-day,.weekly-card.selected .weekly-date{color:#fff}.weekly-day{font-size:11px;font-weight:500;color:#999}.weekly-date{font-size:16px;font-weight:700;color:#333}.weekly-check{display:none}.weekly-sessions-list{margin-top:16px;background:#fff;padding:16px;border-radius:16px;box-shadow:0 2px 8px #0000000f}.weekly-sessions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.weekly-sessions-title{font-size:13px;font-weight:600;color:#111}.weekly-sessions-count{font-size:12px;color:#888}.weekly-session-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;border-radius:12px;margin-bottom:10px;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 8px #0000000f}.weekly-session-item:last-child{margin-bottom:0}.weekly-session-item:active{transform:scale(.98);background:#f8f8f8}.weekly-session-info{display:flex;align-items:center;gap:12px}.weekly-session-time{font-size:14px;font-weight:500;color:#333}.weekly-session-words{font-size:12px;color:#888}.recent-session-card{display:flex;align-items:center;justify-content:space-between;padding:14px;background:#f5f5f5;border-radius:12px;margin-bottom:8px;cursor:pointer;transition:all .15s ease}.home-section-title+.recent-session-card{margin-top:14px}.recent-session-card:last-child{margin-bottom:0}.recent-session-card:active{background:#eee}.recent-session-info{display:flex;flex-direction:column;gap:2px}.recent-session-date{font-size:13px;font-weight:600;color:#111}.recent-session-words{font-size:11px;color:#888}.floating-call-btn-circle{position:fixed;bottom:calc(28px + env(safe-area-inset-bottom,0px));right:20px;width:76px;height:76px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#5046e4,#8b5cf6);color:#fff;border:none;border-radius:50%;cursor:pointer;box-shadow:0 6px 20px #667eea66;transition:all .2s ease;z-index:50}.floating-call-btn-circle:active{transform:scale(.9);background:linear-gradient(135deg,#4338ca,#7c3aed)}.floating-call-btn-circle svg{animation:pulse 2s infinite}.onboarding-link-btn{width:100%;padding:14px 20px;background:#f5f5f5;border:1.5px dashed #ddd;border-radius:12px;font-size:14px;font-weight:500;color:#888;text-align:center;cursor:pointer;transition:all .15s ease;margin-top:8px}.onboarding-link-btn:active{background:#eee;border-color:#ccc;color:#666}.home-toast{position:fixed;bottom:120px;left:50%;transform:translate(-50%);background:#000000d9;color:#fff;padding:14px 24px;border-radius:12px;font-size:14px;font-weight:500;z-index:2000;animation:toastFadeInUp .3s ease;box-shadow:0 4px 12px #0003}@keyframes toastFadeInUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.onboarding{display:flex;flex-direction:column;align-items:center;min-height:100vh;min-height:100dvh;background:#fff;padding:24px;position:relative}.onboarding-skip{position:absolute;top:16px;right:16px;background:none;border:none;color:#9ca3af;font-size:14px;font-weight:500;padding:8px 12px;cursor:pointer;transition:color .2s;z-index:2}.onboarding-skip:hover{color:#6b7280}.onboarding-back{position:absolute;top:16px;left:16px;background:none;border:none;color:#9ca3af;padding:8px;cursor:pointer;transition:color .2s;display:flex;align-items:center;z-index:2}.onboarding-back:hover{color:#111827}.onboarding-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;max-width:340px;width:100%;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.onboarding-icon{margin-bottom:40px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.onboarding-title{font-size:24px;font-weight:700;color:#111827;margin:0 0 12px;line-height:1.3}.onboarding-description{font-size:16px;color:#6b7280;margin:0;line-height:1.5}.onboarding-content.features-mode{text-align:left;align-items:center}.onboarding-content.features-mode .onboarding-title{text-align:center;font-size:22px}.onboarding-features{list-style:none;padding:0;margin:4px 0 0;display:flex;flex-direction:column;gap:12px;width:100%}.onboarding-feature-item{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:#4b5563;line-height:1.5}.onboarding-feature-bullet{flex-shrink:0;font-size:14px;line-height:1.5;color:#9ca3af}.onboarding-feature-item strong{color:#111827;font-weight:600}.cal-motion{display:grid;grid-template-columns:1fr auto 1fr;gap:6px 4px;width:100%;max-width:320px;margin:16px auto 0;align-items:center}.cal-motion-step{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;transform:translateY(16px)}.cal-motion-step.step-1{animation:calStepIn .5s ease .3s forwards}.cal-motion-step.step-2{animation:calStepIn .5s ease .8s forwards}.cal-motion-step.step-3{animation:calStepIn .5s ease 1.3s forwards}.cal-motion-step.step-4{animation:calStepIn .5s ease 1.8s forwards}.cal-motion-arrow-cell{display:flex;align-items:center;justify-content:center;padding-bottom:20px;opacity:0}.cal-motion-arrow-cell.step-a1{animation:calArrowIn .3s ease .7s forwards}.cal-motion-arrow-cell.step-a2{animation:calArrowIn .3s ease 1.7s forwards}.cal-motion-arrow-cell .cal-motion-arrow{font-size:18px;color:#d1d5db;font-weight:700}@keyframes calStepIn{to{opacity:1;transform:translateY(0)}}.cal-motion-phone{width:120px;height:150px;background:#fff;border:2px solid #E5E7EB;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.cal-motion-screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px;gap:6px}.cal-motion-app-bar{width:100%;text-align:center;margin-bottom:4px}.cal-motion-logo{font-size:11px;font-weight:800;color:#5a6ad8;letter-spacing:-.3px}.cal-motion-connect-btn{display:flex;align-items:center;gap:4px;background:#3b82f6;color:#fff;font-size:8px;font-weight:600;padding:6px 8px;border-radius:8px;white-space:nowrap;animation:calBtnPulse 2s ease-in-out 2.5s infinite}@keyframes calBtnPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05);box-shadow:0 0 8px #3b82f666}}.cal-motion-screen.google-auth{background:#f9fafb;gap:6px}.cal-motion-google{width:32px;height:32px}.cal-motion-google-text{font-size:9px;font-weight:600;color:#374151}.cal-motion-spinner{width:16px;height:16px;border:2px solid #E5E7EB;border-top-color:#3b82f6;border-radius:50%;animation:calSpin .8s linear infinite;opacity:0;animation:calSpin .8s linear infinite,calSpinnerShow .3s ease 1.2s forwards}@keyframes calSpin{to{transform:rotate(360deg)}}@keyframes calSpinnerShow{to{opacity:1}}.cal-motion-screen.calendar-view{padding:8px;gap:0;justify-content:flex-start}.cal-motion-cal-header{font-size:10px;font-weight:700;color:#111827;width:100%;text-align:center;padding:5px 0 4px;border-bottom:1px solid #f0f0f0;margin-bottom:4px}.cal-motion-timeline{width:100%;display:flex;flex-direction:column;gap:4px}.cal-motion-event{display:flex;align-items:center;gap:4px;height:20px}.cal-motion-time{font-size:8px;color:#9ca3af;width:26px;flex-shrink:0}.cal-motion-bar{flex:1;height:14px;border-radius:4px;background:#e5e7eb}.cal-motion-event.free .cal-motion-bar.free-bar{background:transparent;border:1.5px dashed #22C55E;height:14px;animation:calFreePulse 1.5s ease-in-out 2s infinite}.cal-motion-free-badge{font-size:7px;font-weight:700;color:#22c55e;white-space:nowrap;opacity:0;animation:calBadgeIn .3s ease 2.2s forwards}@keyframes calFreePulse{0%,to{border-color:#22c55e}50%{border-color:#86efac;box-shadow:0 0 6px #22c55e40}}@keyframes calBadgeIn{to{opacity:1}}.cal-motion-screen.incoming-call{background:linear-gradient(180deg,#312e81,#4338ca);gap:4px;position:relative}.cal-motion-call-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;border-radius:50%;background:#ffffff14;animation:calCallPulse 1.5s ease-out 2.2s infinite}@keyframes calCallPulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:.6}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.cal-motion-call-icon{z-index:1;animation:calPhoneShake .5s ease-in-out 2.5s infinite}@keyframes calPhoneShake{0%,to{transform:rotate(0)}20%{transform:rotate(-12deg)}40%{transform:rotate(12deg)}60%{transform:rotate(-8deg)}80%{transform:rotate(8deg)}}.cal-motion-call-text{font-size:9px;font-weight:700;color:#fff;z-index:1}.cal-motion-call-btns{z-index:1}.cal-motion-accept{font-size:8px;font-weight:700;color:#fff;background:#22c55e;padding:4px 14px;border-radius:8px}.cal-motion-label{font-size:11px;font-weight:600;color:#6b7280;text-align:center;margin:0;white-space:nowrap}@keyframes calArrowIn{to{opacity:1}}.phone-motion{display:grid;grid-template-columns:1fr auto 1fr;gap:6px 4px;width:100%;max-width:320px;margin:16px auto 0;align-items:center}.phone-motion-step{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;transform:translateY(16px)}.phone-motion-step.pm-step-1{animation:calStepIn .5s ease .3s forwards}.phone-motion-step.pm-step-2{animation:calStepIn .5s ease .8s forwards}.phone-motion-step.pm-step-3{animation:calStepIn .5s ease 1.3s forwards}.phone-motion-step.pm-step-4{animation:calStepIn .5s ease 1.8s forwards}.phone-motion-arrow-cell{display:flex;align-items:center;justify-content:center;padding-bottom:20px;opacity:0}.phone-motion-arrow-cell.pm-arrow-1{animation:calArrowIn .3s ease .7s forwards}.phone-motion-arrow-cell.pm-arrow-2{animation:calArrowIn .3s ease 1.7s forwards}.phone-motion-arrow-cell .phone-motion-arrow{font-size:18px;color:#d1d5db;font-weight:700}.phone-motion-phone{width:120px;height:150px;background:#fff;border:2px solid #E5E7EB;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.phone-motion-screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px;gap:4px}.phone-motion-app-bar{width:100%;display:flex;align-items:center;gap:2px;margin-bottom:2px}.phone-motion-logo{font-size:10px;font-weight:800;color:#5a6ad8;letter-spacing:-.3px}.phone-motion-beta{font-size:5px;font-weight:700;color:#fff;background:#5a6ad8;padding:1px 4px;border-radius:3px;line-height:1}.phone-motion-tutor{display:flex;flex-direction:column;align-items:center;gap:3px;margin:4px 0}.phone-motion-avatar{width:32px;height:32px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;border:1.5px solid #eee}.phone-motion-tutor-name{font-size:10px;font-weight:700;color:#111}.phone-motion-call-btn{display:flex;align-items:center;justify-content:center;gap:3px;width:100%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:8px;font-weight:700;padding:6px 4px;border-radius:8px;white-space:nowrap;animation:pmBtnPulse 2s ease-in-out 2.5s infinite}@keyframes pmBtnPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05);box-shadow:0 0 8px #6366f166}}.phone-motion-screen.setting-sheet{background:#fafafa;padding:12px 8px 8px;gap:6px;justify-content:flex-start}.phone-motion-sheet-title{font-size:10px;font-weight:700;color:#111;width:100%;text-align:center;margin-bottom:2px}.phone-motion-setting-row{width:100%;display:flex;flex-direction:column;gap:3px}.phone-motion-setting-label{font-size:7px;font-weight:600;color:#888}.phone-motion-setting-chips{display:flex;gap:4px}.phone-motion-chip{font-size:7px;font-weight:600;color:#666;background:#fff;border:1px solid #e0e0e0;padding:3px 8px;border-radius:5px}.phone-motion-chip.active{color:#fff;background:#6366f1;border-color:#6366f1}.phone-motion-start-btn{width:100%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:8px;font-weight:700;padding:6px 0;border-radius:6px;text-align:center;margin-top:4px}.phone-motion-screen.textbook-sheet{background:#fafafa;padding:12px 8px 8px;gap:5px;justify-content:flex-start}.textbook-topic-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;width:100%}.textbook-topic-chip{font-size:7px;font-weight:600;color:#666;background:#fff;border:1px solid #e5e7eb;padding:4px 0;border-radius:6px;text-align:center;transition:all .2s}.textbook-topic-chip.active{color:#b45309;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fbbf24;box-shadow:0 1px 4px #fbbf2433}.textbook-preview-card{width:100%;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:6px 8px;display:flex;align-items:center;gap:6px;position:relative;animation:textbookPulse 2s ease-in-out infinite}.textbook-preview-icon{font-size:14px;flex-shrink:0}.textbook-preview-lines{flex:1;display:flex;flex-direction:column;gap:3px}.textbook-line{height:3px;background:linear-gradient(90deg,#e5e7eb,#d1d5db,#e5e7eb);background-size:200% 100%;border-radius:2px;width:100%;animation:lineShimmer 1.8s ease-in-out infinite}.textbook-line.short{width:60%}.textbook-ai-badge{font-size:6px;font-weight:800;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);padding:2px 5px;border-radius:4px;flex-shrink:0;letter-spacing:.5px}.phone-motion-start-btn.textbook-btn{background:linear-gradient(135deg,#f59e0b,#d97706)}@keyframes textbookPulse{0%,to{box-shadow:0 0 #fbbf2400}50%{box-shadow:0 0 0 3px #fbbf2426}}@keyframes lineShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.phone-motion-screen.call-active{background:linear-gradient(180deg,#312e81,#4338ca);gap:4px;position:relative;overflow:hidden}.phone-motion-wave-bg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;border-radius:50%;background:#ffffff0d;animation:pmWaveBg 2s ease-in-out 2s infinite}@keyframes pmWaveBg{0%{transform:translate(-50%,-50%) scale(.8);opacity:.5}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.phone-motion-call-avatar{width:34px;height:34px;background:#ffffff26;border:1.5px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;z-index:1}.phone-motion-calling-text{font-size:9px;font-weight:600;color:#ffffffe6;z-index:1}.phone-motion-waveform{display:flex;align-items:center;gap:3px;height:22px;z-index:1}.phone-motion-wave-bar{width:4px;background:#fff9;border-radius:2px;animation:pmWaveBar 1.2s ease-in-out infinite}.phone-motion-wave-bar.wb1{height:8px;animation-delay:0s}.phone-motion-wave-bar.wb2{height:14px;animation-delay:.1s}.phone-motion-wave-bar.wb3{height:20px;animation-delay:.2s}.phone-motion-wave-bar.wb4{height:11px;animation-delay:.3s}.phone-motion-wave-bar.wb5{height:17px;animation-delay:.15s}.phone-motion-wave-bar.wb6{height:8px;animation-delay:.25s}.phone-motion-wave-bar.wb7{height:14px;animation-delay:.05s}@keyframes pmWaveBar{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}.phone-motion-screen.feedback-view{background:#fff;padding:8px;gap:4px;justify-content:center}.phone-motion-chat-bubble{width:100%;padding:5px 7px;border-radius:6px;font-size:7px;line-height:1.4}.phone-motion-chat-bubble.user-bubble{background:#f3f4f6;align-self:flex-end;border-bottom-right-radius:2px}.phone-motion-bubble-text{color:#374151;font-weight:500;text-decoration:line-through;text-decoration-color:#ef4444;opacity:0;animation:pmBubbleIn .4s ease 2s forwards}.phone-motion-chat-bubble.ai-bubble{background:#eef2ff;border-bottom-left-radius:2px}.phone-motion-correction{font-size:7px;font-weight:600;color:#4338ca;opacity:0;animation:pmBubbleIn .4s ease 2.4s forwards}.phone-motion-correction em{font-style:normal;color:#22c55e;font-weight:700;text-decoration:underline}.phone-motion-chat-bubble.tip{background:#f0fdf4;border:1px solid #BBF7D0}.phone-motion-tip-text{font-size:6.5px;font-weight:600;color:#16a34a;opacity:0;animation:pmBubbleIn .4s ease 2.8s forwards}@keyframes pmBubbleIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.phone-motion-label{font-size:11px;font-weight:600;color:#6b7280;text-align:center;margin:0;white-space:nowrap}.anl-motion{display:grid;grid-template-columns:1fr auto 1fr;gap:6px 4px;width:100%;max-width:320px;margin:16px auto 0;align-items:center}.anl-motion-step{display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0;transform:translateY(16px)}.anl-motion-step.anl-step-1{animation:calStepIn .5s ease .3s forwards}.anl-motion-step.anl-step-2{animation:calStepIn .5s ease .8s forwards}.anl-motion-step.anl-step-3{animation:calStepIn .5s ease 1.3s forwards}.anl-motion-step.anl-step-4{animation:calStepIn .5s ease 1.8s forwards}.anl-motion-arrow-cell{display:flex;align-items:center;justify-content:center;padding-bottom:20px;opacity:0}.anl-motion-arrow-cell.anl-arrow-1{animation:calArrowIn .3s ease .7s forwards}.anl-motion-arrow-cell.anl-arrow-2{animation:calArrowIn .3s ease 1.7s forwards}.anl-motion-arrow-cell .anl-motion-arrow{font-size:18px;color:#d1d5db;font-weight:700}.anl-motion-phone{width:120px;height:150px;background:#fff;border:2px solid #E5E7EB;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.anl-motion-screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px;gap:4px}.anl-motion-screen.call-done{background:linear-gradient(180deg,#312e81,#4338ca);gap:4px}.anl-motion-done-circle{width:38px;height:38px;background:#22c55e;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:anlDonePopIn .5s ease .6s both}@keyframes anlDonePopIn{0%{transform:scale(0);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.anl-motion-done-text{font-size:10px;font-weight:700;color:#fff}.anl-motion-done-sub{font-size:8px;color:#fff9}.anl-motion-screen.analyzing{background:#fafafa;gap:4px;position:relative;overflow:hidden}.anl-motion-brain-pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;border-radius:50%;background:#6366f114;animation:anlBrainPulse 1.5s ease-out 1.2s infinite}@keyframes anlBrainPulse{0%{transform:translate(-50%,-50%) scale(.6);opacity:.6}to{transform:translate(-50%,-50%) scale(2);opacity:0}}.anl-motion-brain{z-index:1;animation:anlBrainBounce 1s ease-in-out 1.2s infinite}@keyframes anlBrainBounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.anl-motion-analyzing-text{font-size:9px;font-weight:700;color:#6366f1;z-index:1}.anl-motion-progress{width:80%;height:5px;background:#e5e7eb;border-radius:2px;overflow:hidden;z-index:1}.anl-motion-progress-bar{width:0;height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:2px;animation:anlProgressFill 2s ease 1s forwards}@keyframes anlProgressFill{0%{width:0}to{width:100%}}.anl-motion-scan-lines{position:absolute;inset:0;overflow:hidden;pointer-events:none}.anl-scan-line{position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.15),transparent);animation:anlScanMove 2s linear infinite}.anl-scan-line.sl1{top:20%;animation-delay:0s}.anl-scan-line.sl2{top:50%;animation-delay:.7s}.anl-scan-line.sl3{top:80%;animation-delay:1.4s}@keyframes anlScanMove{0%{opacity:0;transform:translateY(-10px)}50%{opacity:1}to{opacity:0;transform:translateY(10px)}}.anl-motion-screen.cafp-report{background:#fff;padding:10px 8px 8px;gap:0;justify-content:flex-start}.anl-motion-report-title{font-size:10px;font-weight:700;color:#111;width:100%;text-align:center;margin-bottom:6px}.anl-motion-scores{width:100%;display:flex;flex-direction:column;gap:6px}.anl-motion-score-row{display:flex;align-items:center;gap:4px}.anl-score-label{font-size:7px;font-weight:600;color:#6b7280;width:24px;flex-shrink:0}.anl-score-bar{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.anl-score-fill{display:block;height:100%;border-radius:3px;width:0}.anl-score-fill.sf-c{background:#6366f1;animation:anlBarFill .6s ease 1.8s forwards}.anl-score-fill.sf-a{background:#8b5cf6;animation:anlBarFillA .6s ease 2s forwards}.anl-score-fill.sf-f{background:#3b82f6;animation:anlBarFillF .6s ease 2.2s forwards}.anl-score-fill.sf-p{background:#22c55e;animation:anlBarFillP .6s ease 2.4s forwards}@keyframes anlBarFill{to{width:67%}}@keyframes anlBarFillA{to{width:56%}}@keyframes anlBarFillF{to{width:78%}}@keyframes anlBarFillP{to{width:44%}}.anl-score-val{font-size:7px;font-weight:700;color:#374151;width:22px;text-align:right;flex-shrink:0;opacity:0}.anl-motion-score-row:nth-child(1) .anl-score-val{animation:calArrowIn .3s ease 2s forwards}.anl-motion-score-row:nth-child(2) .anl-score-val{animation:calArrowIn .3s ease 2.2s forwards}.anl-motion-score-row:nth-child(3) .anl-score-val{animation:calArrowIn .3s ease 2.4s forwards}.anl-motion-score-row:nth-child(4) .anl-score-val{animation:calArrowIn .3s ease 2.6s forwards}.anl-motion-screen.detail-feedback{background:#fff;padding:10px 8px 8px;gap:4px;justify-content:flex-start}.anl-motion-fb-title{font-size:9px;font-weight:700;color:#111;width:100%;text-align:center;margin-bottom:3px}.anl-motion-fb-card{width:100%;padding:5px 6px;border-radius:5px;display:flex;align-items:center;gap:3px;opacity:0}.anl-motion-fb-card.error-card{background:#fef2f2;border:.5px solid #FECACA;animation:pmBubbleIn .4s ease 2.2s forwards}.anl-fb-wrong{font-size:7px;color:#ef4444;text-decoration:line-through;font-weight:500}.anl-fb-arrow{font-size:7px;color:#9ca3af}.anl-fb-correct{font-size:7px;color:#22c55e;font-weight:700}.anl-motion-fb-card.vocab-card{background:#eef2ff;border:.5px solid #C7D2FE;flex-direction:column;align-items:flex-start;gap:1px;animation:pmBubbleIn .4s ease 2.5s forwards}.anl-fb-vocab-label{font-size:6px;font-weight:600;color:#6366f1}.anl-fb-vocab{font-size:7px;font-weight:600;color:#4338ca}.anl-motion-fb-card.strength-card{background:#f0fdf4;border:.5px solid #BBF7D0;animation:pmBubbleIn .4s ease 2.8s forwards}.anl-fb-strength{font-size:7px;font-weight:600;color:#16a34a}.anl-motion-label{font-size:11px;font-weight:600;color:#6b7280;text-align:center;margin:0;white-space:nowrap}.onboarding-content.survey-mode{justify-content:flex-start;align-items:flex-start;text-align:left;padding-top:56px;max-width:100%}.onboarding-trial-teaser{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;background:linear-gradient(135deg,#eff6ff,#f0f7ff);border:1px solid #DBEAFE;border-radius:14px;margin-bottom:24px}.onboarding-trial-teaser-icon{flex-shrink:0;width:44px;height:44px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #3b82f61a}.onboarding-trial-teaser-body{flex:1;min-width:0}.onboarding-trial-teaser-text{font-size:13px;font-weight:500;color:#374151;margin:0 0 6px;line-height:1.45}.onboarding-trial-teaser-text strong{color:#3b82f6;font-weight:700}.onboarding-trial-teaser-tags{display:flex;gap:6px;flex-wrap:wrap}.onboarding-trial-teaser-tags span{font-size:11px;font-weight:500;color:#3b82f6;background:#3b82f614;padding:2px 8px;border-radius:100px;white-space:nowrap}.onboarding-survey-header{margin-bottom:28px}.onboarding-survey-title{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px;line-height:1.4}.onboarding-survey-desc{font-size:15px;color:#9ca3af;margin:0}.onboarding-chips{display:flex;flex-wrap:wrap;gap:10px;width:100%}.onboarding-chip{padding:10px 18px;background:#fff;border:1.5px solid #E5E7EB;border-radius:100px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease;white-space:nowrap}.onboarding-chip:hover{border-color:#93c5fd;background:#f0f7ff}.onboarding-chip:active{transform:scale(.97)}.onboarding-chip.selected{background:#3b82f6;border-color:#3b82f6;color:#fff}.onboarding-chip.selected:hover{background:#2563eb;border-color:#2563eb}.onboarding-other-input{width:100%;margin-top:12px;padding:12px 16px;border:1.5px solid #3B82F6;border-radius:12px;font-size:15px;font-family:inherit;color:#111827;outline:none;transition:border-color .2s ease;box-sizing:border-box;animation:slideIn .2s ease}.onboarding-other-input::placeholder{color:#c4c4c4}.onboarding-textarea-wrap{position:relative;width:100%}.onboarding-textarea{width:100%;padding:16px;border:1.5px solid #E5E7EB;border-radius:12px;font-size:15px;font-family:inherit;color:#111827;resize:none;outline:none;transition:border-color .2s ease;line-height:1.6;box-sizing:border-box}.onboarding-textarea::placeholder{color:#c4c4c4}.onboarding-textarea:focus{border-color:#3b82f6}.onboarding-textarea-count{position:absolute;bottom:12px;right:16px;font-size:12px;color:#c4c4c4}.onboarding-content.reward-mode{justify-content:center;padding-top:0}.onboarding-reward-icon{margin-bottom:24px;animation:rewardBounce .6s ease}@keyframes rewardBounce{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}.onboarding-reward-title{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px;line-height:1.4;animation:slideIn .4s ease .2s both}.onboarding-reward-subtitle{font-size:15px;color:#9ca3af;margin:0 0 32px;animation:slideIn .4s ease .3s both}.onboarding-reward-card{width:100%;max-width:320px;background:#f8faff;border:1.5px solid #DBEAFE;border-radius:16px;padding:24px;animation:slideIn .4s ease .4s both}.onboarding-reward-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.onboarding-reward-badge{background:#3b82f6;color:#fff;font-size:12px;font-weight:700;padding:4px 12px;border-radius:100px;letter-spacing:.5px}.onboarding-reward-period{font-size:14px;font-weight:600;color:#3b82f6}.onboarding-reward-benefits{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}.onboarding-reward-benefits li{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:500;color:#374151}.onboarding-reward-benefits li svg{flex-shrink:0}.onboarding-reward-expiry{margin-top:20px;padding-top:16px;border-top:1px solid #E5E7EB;font-size:13px;color:#9ca3af;text-align:center}.onboarding-dots{display:flex;gap:8px;margin:32px 0}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:#e5e7eb;transition:all .3s ease}.onboarding-dot.active{background:#3b82f6;width:24px;border-radius:4px}.onboarding-button{width:100%;max-width:320px;padding:16px 24px;background:#3b82f6;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:24px}.onboarding-button:hover{background:#2563eb;transform:translateY(-1px)}.onboarding-button:active{transform:translateY(0)}.onboarding-button.disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed;transform:none}.onboarding-button.disabled:hover{background:#e5e7eb;transform:none}@supports (padding-bottom: env(safe-area-inset-bottom)){.onboarding{padding-bottom:calc(24px + env(safe-area-inset-bottom))}}.onboarding-skip-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.onboarding-skip-modal{background:#fff;border-radius:20px;padding:32px 24px;max-width:320px;width:100%;text-align:center;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.onboarding-skip-modal-icon{margin-bottom:16px}.onboarding-skip-modal-title{font-size:22px;font-weight:700;color:#111827;margin:0 0 12px}.onboarding-skip-modal-desc{font-size:15px;color:#6b7280;line-height:1.6;margin:0 0 24px}.onboarding-skip-modal-desc strong{color:#3b82f6;font-weight:600}.onboarding-skip-modal-buttons{display:flex;flex-direction:column;gap:10px}.onboarding-skip-modal-btn{width:100%;padding:14px 20px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.onboarding-skip-modal-btn.primary{background:#3b82f6;color:#fff}.onboarding-skip-modal-btn.primary:hover{background:#2563eb}.onboarding-skip-modal-btn.secondary{background:#f3f4f6;color:#6b7280}.onboarding-skip-modal-btn.secondary:hover{background:#e5e7eb}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:#fafafa;position:relative;overflow:hidden;animation:loginPageFadeIn .5s ease forwards}@keyframes loginPageFadeIn{0%{opacity:0}to{opacity:1}}.login-bg-orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}.login-bg-orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.15) 0%,transparent 70%);top:-100px;right:-100px}.login-bg-orb-2{width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);bottom:-50px;left:-80px}.login-container{width:100%;max-width:380px;z-index:1}.login-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 4px 24px #0000000f;animation:loginCardIn .5s ease .3s both}@keyframes loginCardIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card .social-buttons{margin-bottom:0}.login-card .auth-divider{margin:16px 0}.login-card .auth-form{gap:14px}.login-card .form-group{gap:6px}.login-card .form-group input{padding:12px 14px}.login-card .btn-primary{padding:13px 20px;margin-top:4px}.login-card .login-links{margin-top:14px}.login-card .login-links:first-of-type{margin-top:16px}.login-branding{text-align:center;margin-bottom:24px;animation:loginBrandingIn .6s ease .1s both}@keyframes loginBrandingIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-app-icon{width:72px;height:72px;margin:0 auto 12px}.login-app-icon img{width:100%;height:100%;border-radius:16px;box-shadow:0 8px 32px #8b5cf640;object-fit:cover}.login-title{font-size:28px;font-weight:800;letter-spacing:-.5px;color:#1d1b4b;margin:0 0 8px}.login-tagline{font-size:13px;line-height:1.5;color:#64748b;margin:0}.login-tagline-highlight{color:#7c3aed;font-weight:600}.login-links{text-align:center;margin-top:16px}.login-links:first-of-type{margin-top:20px}.login-links a{font-size:13px;color:#64748b;text-decoration:none}.login-links a:hover{color:#7c3aed}.login-links strong{color:#7c3aed;font-weight:600}.login-footer{margin-top:80px;text-align:center;font-size:11px;animation:loginFooterIn .4s ease .5s both}@keyframes loginFooterIn{0%{opacity:0}to{opacity:1}}.login-footer a{color:#94a3b8;text-decoration:none}.login-footer a:hover{color:#7c3aed;text-decoration:underline}.login-footer-divider{color:#cbd5e1}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:#fafafa}.auth-container{width:100%;max-width:380px;background:#fff;border-radius:20px;padding:36px 28px}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{font-size:24px;font-weight:700;color:#111;margin:0 0 8px;letter-spacing:-.5px}.auth-header p{font-size:14px;color:#888;margin:0;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:#333}.form-group input{padding:14px 16px;border:1.5px solid #eee;border-radius:12px;font-size:15px;transition:all .15s ease;background:#fff}.form-group input:focus{outline:none;border-color:#111}.form-group input::placeholder{color:#bbb}.btn-primary{padding:15px 24px;background:#111;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-primary:hover{background:#222}.btn-primary:active{background:#333;transform:scale(.98)}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.auth-divider{display:flex;align-items:center;margin:24px 0;gap:16px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#eee}.auth-divider span{font-size:12px;color:#bbb}.social-buttons{display:flex;flex-direction:column;gap:10px}.btn-social{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 24px;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-social:active{transform:scale(.98)}.btn-google{background:#fff;border:1.5px solid #eee;color:#333}.btn-google:hover{background:#fafafa}.btn-apple{background:#111;border:1.5px solid #111;color:#fff}.btn-apple:hover{background:#222}.auth-links{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:28px}.auth-links a,.btn-link{font-size:13px;color:#888;text-decoration:none;background:none;border:none;cursor:pointer;padding:0}.auth-links a:hover,.btn-link:hover{color:#111}.auth-links strong{font-weight:600;color:#111}.auth-error{background:#fef2f2;color:#b91c1c;padding:12px 16px;border-radius:10px;font-size:13px;margin-bottom:20px;text-align:center}.auth-success{background:#f0fdf4;color:#166534;padding:12px 16px;border-radius:10px;font-size:13px;margin-bottom:20px;text-align:center}.auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:16px}.auth-loading p{font-size:14px;color:#888}.loading-spinner{width:36px;height:36px;border:3px solid #eee;border-top-color:#111;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-back-button{position:absolute;top:16px;left:16px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-radius:12px;box-shadow:0 2px 8px #00000014;cursor:pointer;color:#333;transition:all .2s ease}.auth-back-button:hover{background:#f5f5f5;transform:scale(1.05)}.auth-back-button:active{transform:scale(.95)}.auth-container{position:relative}@media(max-width:480px){.auth-page{padding:60px 16px 16px;align-items:flex-start}.auth-container{padding:28px 24px}.auth-header h1{font-size:22px}.auth-back-button{top:12px;left:12px;width:40px;height:40px}}:root{--color-primary: #5046e4;--color-primary-dark: #4338ca;--color-primary-light: #ede9fe;--color-purple: #8b5cf6;--color-purple-light: #ddd6fe;--color-success: #22c55e;--color-error: #ef4444;--color-warning: #f59e0b;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--border-color: #e5e7eb;--border-color-light: #f3f4f6;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--font-xs: 12px;--font-sm: 13px;--font-base: 14px;--font-md: 15px;--font-lg: 16px;--font-xl: 18px;--font-2xl: 20px;--font-3xl: 24px;--font-4xl: 28px;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-modal: 1000;--z-toast: 2000}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid var(--gray-200);padding:16px 24px;position:sticky;top:0;z-index:100}.header-content{max-width:480px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:8px;font-weight:700;font-size:18px;color:var(--primary)}.page{flex:1;padding:24px;max-width:480px;margin:0 auto;width:100%}.page-title{font-size:24px;font-weight:700;margin-bottom:8px;color:var(--gray-900)}.page-subtitle{font-size:14px;color:var(--gray-500);margin-bottom:24px}.card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:16px}.card-title{font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:var(--radius);font-size:16px;font-weight:600;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-full{width:100%}.btn-lg{padding:18px 32px;font-size:18px}.call-btn{background:linear-gradient(90deg,#8b5cf6,#7c3aed,#6366f1);color:#fff;padding:18px;border-radius:50px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:16px;font-weight:600;width:100%;margin-top:12px;box-shadow:0 4px 20px #8b5cf666}.call-btn:hover{background:linear-gradient(90deg,#8b5cf6,#7c3aed,#6366f1)}.call-btn:hover{background:#333}.call-btn .icon{width:32px;height:32px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.option-group{margin-bottom:24px}.option-label{font-size:14px;font-weight:600;color:var(--gray-600);margin-bottom:12px;display:block}.option-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.option-grid.cols-3{grid-template-columns:repeat(3,1fr)}.option-item{padding:14px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);text-align:center;cursor:pointer;transition:all .2s;background:#fff}.option-item:hover{border-color:#888}.option-item.selected{border-color:#111;background:#fafafa}.option-item .icon{font-size:24px;margin-bottom:4px}.option-item .label{font-size:14px;font-weight:500;color:var(--gray-700)}.option-item .sublabel{font-size:12px;color:var(--gray-400)}.settings-tutor-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--gray-50);border-radius:var(--radius)}.settings-tutor-avatar{width:64px;height:64px;border-radius:50%;background:#111;color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px}.tutor-info h3{font-size:18px;font-weight:600;margin-bottom:4px}.tutor-info p{font-size:14px;color:var(--gray-500)}.tutor-badges{display:flex;gap:8px;margin-top:8px}.badge{font-size:12px;padding:4px 10px;border-radius:20px;background:var(--gray-200);color:var(--gray-600)}.badge.primary{background:#f0f0f0;color:#111}.call-screen{min-height:100vh;background:#111;display:flex;flex-direction:column;color:#fff}.call-header{padding:24px;text-align:center}.call-status{font-size:14px;color:var(--success);display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px}.call-status .dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.call-timer{font-size:32px;font-weight:700;font-variant-numeric:tabular-nums}.call-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.call-tutor-avatar{width:120px;height:120px;border-radius:50%;background:#fff;color:#111;display:flex;align-items:center;justify-content:center;font-size:48px;margin-bottom:24px}.call-tutor-name{font-size:24px;font-weight:600;margin-bottom:8px}.call-tutor-accent{font-size:14px;color:var(--gray-400)}.message-bubble{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:20px 24px;margin-top:32px;max-width:90%}.message-en{font-size:18px;font-weight:500;margin-bottom:8px}.message-ko{font-size:14px;color:var(--gray-400)}.voice-wave{display:flex;align-items:center;justify-content:center;gap:4px;height:40px;margin-top:24px}.voice-wave .bar{width:4px;background:var(--primary-light);border-radius:2px;animation:wave 1s infinite ease-in-out}.voice-wave .bar:nth-child(1){animation-delay:0s;height:20px}.voice-wave .bar:nth-child(2){animation-delay:.1s;height:30px}.voice-wave .bar:nth-child(3){animation-delay:.2s;height:40px}.voice-wave .bar:nth-child(4){animation-delay:.3s;height:30px}.voice-wave .bar:nth-child(5){animation-delay:.4s;height:20px}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.voice-indicator{display:flex;align-items:center;gap:8px;color:var(--gray-400);font-size:14px;margin-top:16px}.call-bottom-area{position:relative;padding:20px;padding-bottom:calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column;align-items:center;gap:16px;background:linear-gradient(to top,#111,#111111fa,#111111f2)}.call-bottom-area:before{content:"";position:absolute;top:-24px;left:0;right:0;height:24px;background:linear-gradient(to top,rgba(17,17,17,.9),transparent);pointer-events:none}.mode-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#6366f133;border-radius:12px;font-size:13px;color:#ffffffe6}.mode-indicator.text-mode{background:#6366f140}.listening-indicator{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 20px;background:#ffffff14;border-radius:16px;width:100%;max-width:340px}.listening-waves{display:flex;align-items:center;gap:3px;height:20px}.listening-waves span{width:3px;height:8px;background:#fff9;border-radius:2px;animation:wave 1s ease-in-out infinite}.listening-waves span:nth-child(1){animation-delay:0s}.listening-waves span:nth-child(2){animation-delay:.1s}.listening-waves span:nth-child(3){animation-delay:.2s}.listening-waves span:nth-child(4){animation-delay:.3s}@keyframes wave{0%,to{height:8px}50%{height:18px}}.loading-dots{display:flex;align-items:center;gap:6px;height:24px}.loading-dots span{width:8px;height:8px;background:#fff9;border-radius:50%;animation:loadingDot 1.4s ease-in-out infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes loadingDot{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.speaking-waves{display:flex;align-items:center;gap:4px;height:24px}.speaking-waves span{width:4px;height:12px;background:linear-gradient(180deg,#6366f1,#8b5cf6);border-radius:2px;animation:speak .8s ease-in-out infinite}.speaking-waves span:nth-child(1){animation-delay:0s}.speaking-waves span:nth-child(2){animation-delay:.15s}.speaking-waves span:nth-child(3){animation-delay:.3s}.speaking-waves span:nth-child(4){animation-delay:.45s}@keyframes speak{0%,to{height:8px}50%{height:20px}}.mic-ready{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;color:#fff;animation:pulseReady 2s ease-in-out infinite}@keyframes pulseReady{0%,to{transform:scale(1);box-shadow:0 0 #6366f166}50%{transform:scale(1.05);box-shadow:0 0 0 10px #6366f100}}.listening-text{font-size:15px;color:#ffffffe6;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-status-area{display:flex;flex-direction:column;align-items:center;gap:12px}.listening-waves-center{display:flex;align-items:center;justify-content:center;gap:4px;height:32px}.listening-waves-center span{width:3px;height:12px;background:#fff6;border-radius:2px;animation:waveCenter 1.2s ease-in-out infinite}.listening-waves-center span:nth-child(1){animation-delay:0s}.listening-waves-center span:nth-child(2){animation-delay:.1s}.listening-waves-center span:nth-child(3){animation-delay:.2s}.listening-waves-center span:nth-child(4){animation-delay:.3s}.listening-waves-center span:nth-child(5){animation-delay:.4s}@keyframes waveCenter{0%,to{height:12px;opacity:.4}50%{height:28px;opacity:.8}}.send-arrow-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#ffffff1f;border:1px solid rgba(255,255,255,.15);border-radius:50%;color:#fffc;cursor:pointer;transition:all .2s}.send-arrow-btn:hover{background:#fff3;transform:scale(1.05)}.send-arrow-btn:active{transform:scale(.95)}.send-arrow-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.input-row{width:100%;max-width:340px}.input-wrapper{display:flex;align-items:center;gap:8px;padding:6px 6px 6px 16px;background:#ffffff1a;border-radius:24px;border:1px solid rgba(255,255,255,.1);transition:all .2s}.input-wrapper:focus-within{background:#ffffff1f;border-color:#fff3}.input-wrapper.text-mode{border-color:#6366f166}.chat-input{flex:1;background:transparent;border:none;color:#fff;font-size:16px;outline:none;min-width:0;padding:8px 0}.chat-input::placeholder{color:#fff6}.input-action-btn{width:40px;height:40px;border-radius:50%;background:#ffffff26;color:#fff;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.input-action-btn:active{transform:scale(.95)}.input-action-btn.send{background:var(--primary)}.input-action-btn.listening{background:var(--primary);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.end-call-btn-new{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#ef4444;color:#fff;border-radius:24px;font-size:15px;font-weight:500;transition:all .2s}.end-call-btn-new:active{transform:scale(.98);background:#dc2626}.call-settings-overlay{position:fixed;inset:0;background:#00000080;z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.call-settings-sheet{background:#1c1c1e;border-radius:20px 20px 0 0;width:100%;max-width:500px;padding-bottom:env(safe-area-inset-bottom,20px);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:36px;height:5px;background:#ffffff4d;border-radius:3px;margin:12px auto 20px}.sheet-content{padding:0 20px 20px}.sheet-item{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.08)}.sheet-item:last-child{border-bottom:none}.sheet-item-info{display:flex;align-items:center;gap:14px}.sheet-icon{color:#fff9}.sheet-item-text{display:flex;flex-direction:column;gap:2px}.sheet-item-title{font-size:16px;font-weight:500;color:#fff}.sheet-item-desc{font-size:13px;color:#ffffff80}.ios-toggle{width:51px;height:31px;border-radius:16px;background:#78788052;padding:2px;transition:background .2s ease;flex-shrink:0}.ios-toggle.on{background:#34c759}.toggle-knob{width:27px;height:27px;border-radius:50%;background:#fff;box-shadow:0 3px 8px #00000026,0 3px 1px #0000000f;transition:transform .2s ease}.ios-toggle.on .toggle-knob{transform:translate(20px)}.result-header{display:flex;justify-content:flex-end;padding:16px 20px;background:#fafafa}.result-icon{font-size:64px;margin-bottom:16px}.result-title{font-size:24px;font-weight:700;margin-bottom:8px}.result-subtitle{font-size:14px;opacity:.8}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.stat-item{text-align:center;padding:16px;background:var(--gray-50);border-radius:var(--radius)}.stat-value{font-size:24px;font-weight:700;color:#111}.stat-label{font-size:12px;color:var(--gray-500);margin-top:4px}.transcript{max-height:300px;overflow-y:auto}.transcript-item{display:flex;gap:12px;margin-bottom:16px}.transcript-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.transcript-avatar.ai{background:#111;color:#fff}.transcript-avatar.user{background:var(--gray-200);color:var(--gray-600)}.transcript-content{flex:1}.transcript-text{font-size:14px;line-height:1.6;color:var(--gray-700)}.transcript-time{font-size:12px;color:var(--gray-400);margin-top:4px}.schedule-days{display:flex;gap:8px;margin-bottom:16px}.day-btn{width:44px;height:44px;border-radius:50%;border:2px solid var(--gray-200);background:#fff;font-size:14px;font-weight:500;color:var(--gray-600);transition:all .2s}.day-btn.selected{border-color:#111;background:#111;color:#fff}.time-picker{display:flex;align-items:center;gap:12px}.time-input{flex:1;padding:14px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:16px;text-align:center}.time-input:focus{border-color:var(--primary);outline:none}.history-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius);cursor:pointer;transition:background .2s}.history-item:hover{background:var(--gray-50)}.history-icon{width:40px;height:40px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;color:var(--gray-500)}.history-info{flex:1}.history-date{font-size:14px;font-weight:500}.history-duration{font-size:12px;color:var(--gray-500)}.history-arrow{color:var(--gray-400)}.empty-state{text-align:center;padding:40px 20px;color:var(--gray-400)}.empty-state .icon{font-size:48px;margin-bottom:16px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--gray-200);padding:12px 24px;padding-bottom:max(12px,env(safe-area-inset-bottom))}.nav-content{max-width:480px;margin:0 auto;display:flex;justify-content:space-around}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;border-radius:12px;color:var(--gray-400);background:transparent;transition:all .2s}.nav-item:hover{color:var(--gray-600)}.nav-item.active{color:#111;background:#f0f0f0}.nav-item .label{font-size:12px;font-weight:500}
