*{margin:0;padding:0;box-sizing:border-box}: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:var(--gray-50);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}.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-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-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-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}@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:1000}.custom-tutor-backdrop{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.custom-tutor-modal{position:relative;background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:480px;max-height:90vh;animation:slideUp .3s ease;display:flex;flex-direction:column}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.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 24px;flex-shrink:0;display:flex;gap:10px}.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}.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-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-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}.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}.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:#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}.pet-upload-area:active{background:#eee}.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:#ddd;color:#999}.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-bottom:0}.tp-card{background:#fff;border-radius:16px;padding:0}.tp-steps{display:flex;align-items:center;justify-content:space-around;margin-bottom:16px;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-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}.incoming-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.incoming-backdrop{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.incoming-card{position:relative;background:#fff;border-radius:24px;padding:32px 24px;width:100%;max-width:340px;text-align:center;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.incoming-close{position:absolute;top:16px;right:16px;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}.incoming-close:active{background:#eee}.incoming-icon{width:80px;height:80px;background:#f5f5f5;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.incoming-title{font-size:20px;font-weight:700;color:#111;margin-bottom:8px}.incoming-desc{font-size:14px;color:#888;margin-bottom:28px}.incoming-buttons{display:flex;flex-direction:column;gap:10px}.incoming-accept{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:16px;background:#111;color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .15s ease}.incoming-accept:active{background:#333;transform:scale(.98)}.incoming-later{width:100%;padding:14px;background:none;border:none;font-size:14px;font-weight:500;color:#888;cursor:pointer}.incoming-later:active{color:#666}.pet-call-banner-wrapper{position:fixed;top:0;left:0;right:0;z-index:9999;padding:8px;padding-top:max(8px,env(safe-area-inset-top));animation:bannerSlideDown .3s ease}@keyframes bannerSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.pet-call-banner{display:flex;align-items:center;gap:16px;background:#fff;border-radius:20px;padding:20px;box-shadow:0 4px 24px #0000002e;max-width:100%;width:100%;margin:0 auto}.pet-call-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0;background:#f5f5f5;display:flex;align-items:center;justify-content:center;font-size:28px}.pet-call-avatar img{width:100%;height:100%;object-fit:cover}.pet-call-info{flex:1;min-width:0}.pet-call-name{display:block;font-size:18px;font-weight:700;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pet-call-subtitle{display:block;font-size:14px;color:#888;margin-top:4px}.pet-call-actions{display:flex;gap:8px;flex-shrink:0}.pet-call-btn{width:52px;height:52px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.pet-call-btn--decline{background:#f5f5f5;color:#666}.pet-call-btn--decline:active{background:#eee;transform:scale(.95)}.pet-call-btn--accept{background:#10b981;color:#fff}.pet-call-btn--accept:active{background:#059669;transform:scale(.95)}.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}.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}.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-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}.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}.generate-textbook-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:16px;padding:16px;background:#111;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;transition:all .2s ease}.generate-textbook-btn:active{background:#333;transform:scale(.98)}.generate-textbook-btn:disabled{background:#ccc;cursor:not-allowed}.generate-textbook-btn svg{color:gold}.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}.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}.preview-overlay{position:fixed;inset:0;background:#0009;z-index:1100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}.preview-modal{background:#fff;border-radius:20px;width:100%;max-width:400px;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f0f0f0}.preview-header h2{font-size:17px;font-weight:600;color:#111}.preview-back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:transparent;transition:background .15s ease}.preview-back-btn:active{background:#f0f0f0}.preview-back-btn svg{color:#666}.preview-content{flex:1;overflow-y:auto;padding:20px}.preview-title-section{text-align:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f0f0f0}.preview-title-ko{font-size:20px;font-weight:700;color:#111;margin-bottom:6px}.preview-title-en{font-size:14px;color:#666}.preview-section{margin-bottom:20px}.preview-section h4{font-size:13px;font-weight:600;color:#8b5cf6;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}.preview-text-ko{font-size:15px;color:#333;line-height:1.6;margin-bottom:6px}.preview-text-en{font-size:14px;color:#666;line-height:1.5;font-style:italic}.preview-roles{display:flex;flex-direction:column;gap:10px}.preview-role{display:flex;align-items:flex-start;gap:10px;background:#f8f8f8;padding:12px;border-radius:10px}.role-label{font-size:12px;font-weight:600;color:#fff;background:#8b5cf6;padding:3px 8px;border-radius:6px;white-space:nowrap}.role-desc{font-size:14px;color:#333;line-height:1.4}.preview-characters{display:flex;flex-direction:column;gap:8px}.preview-character{display:flex;align-items:center;gap:10px;background:#f8f8f8;padding:10px 12px;border-radius:10px}.char-name{font-size:14px;font-weight:600;color:#333}.char-viewpoint{font-size:13px;color:#666}.preview-expressions{display:flex;flex-wrap:wrap;gap:8px}.expression-tag{font-size:13px;color:#5a6ad8;background:#5a6ad81a;padding:6px 12px;border-radius:20px}.preview-starter{font-size:15px;color:#333;line-height:1.6;background:linear-gradient(135deg,#8b5cf614,#6366f114);padding:14px 16px;border-radius:12px;border-left:3px solid #8B5CF6}.preview-footer{display:flex;gap:10px;padding:16px 20px;border-top:1px solid #f0f0f0}.preview-regenerate-btn{flex:1;padding:14px;background:#f0f0f0;color:#333;border-radius:12px;font-size:15px;font-weight:600;transition:all .15s ease}.preview-regenerate-btn:active{background:#e0e0e0}.preview-start-btn{flex:2;padding:14px;background:linear-gradient(90deg,#8b5cf6,#7c3aed,#6366f1);color:#fff;border-radius:12px;font-size:15px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px #8b5cf659;transition:all .15s ease}.preview-start-btn:active{transform:scale(.98)}.group-tab{padding:0 20px 100px;position:relative}.refresh-btn{display:none}.reward-card{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#fff;border:1px solid #e5e5e5;border-radius:14px;margin-bottom:20px}.reward-icon{width:32px;height:32px;background:#f0f9f0;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#10b981}.reward-label{font-size:14px;font-weight:600;color:#333}.reward-progress-bar{flex:1;height:6px;background:#f0f0f0;border-radius:3px;overflow:hidden}.reward-progress-fill{height:100%;background:#10b981;border-radius:3px}.reward-count{font-size:14px;font-weight:700;color:#10b981}.reward-total{font-weight:500;color:#999}.group-sub-tabs{display:flex;gap:0;margin-bottom:20px;border-bottom:1px solid #eee}.group-sub-tab{flex:1;padding:12px 20px;background:transparent;border:none;font-size:14px;font-weight:600;color:#999;cursor:pointer;position:relative}.group-sub-tab.active{color:#111}.group-sub-tab.active:after{content:"";position:absolute;bottom:-1px;left:50%;transform:translate(-50%);width:40px;height:2px;background:#111;border-radius:1px}.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:24px}.challenge-section{display:flex;flex-direction:column}.challenge-card{padding:28px 24px;border-radius:24px;color:#fff;cursor:pointer;margin-bottom:16px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 40px #667eea4d;position:relative;overflow:hidden;min-height:160px}.challenge-card:before{content:"";position:absolute;top:-50%;right:-30%;width:200px;height:200px;background:#ffffff1a;border-radius:50%}.challenge-card:after{content:"";position:absolute;bottom:-30%;left:-20%;width:150px;height:150px;background:#ffffff14;border-radius:50%}.challenge-card:active{transform:scale(.98);opacity:.95}.challenge-category{display:flex;flex-direction:row;align-items:center;gap:8px;font-size:13px;font-weight:600;opacity:.9;margin-bottom:12px;position:relative;z-index:1}.category-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:pulse 2s ease infinite}.challenge-title{font-size:24px;font-weight:800;margin:0 0 8px;position:relative;z-index:1;letter-spacing:-.5px}.challenge-items{font-size:14px;opacity:.85;margin:0;line-height:1.5;position:relative;z-index:1}.my-challenges-list{display:flex;flex-direction:column;gap:12px;margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.2);position:relative;z-index:1}.my-challenge-progress{display:flex;flex-direction:row;align-items:center;gap:14px;background:#ffffff1a;padding:12px 14px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.my-challenge-progress .progress-title{flex:1;font-size:14px;font-weight:600;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-challenge-progress .progress-bar-container{width:80px;height:6px;background:#ffffff40;border-radius:3px;overflow:hidden;flex-shrink:0}.my-challenge-progress .progress-bar-fill{height:100%;background:#fff;border-radius:3px;transition:width .3s ease}.my-challenge-progress .progress-text{font-size:13px;font-weight:700;opacity:1;min-width:50px;text-align:right;white-space:nowrap;flex-shrink:0}.my-challenge-progress.clickable{cursor:pointer;transition:background .2s,transform .1s}.my-challenge-progress.clickable:active{transform:scale(.98);background:#ffffff26}.my-challenge-progress .progress-arrow{color:#fff9;flex-shrink:0;margin-left:4px}.empty-challenges{display:flex;flex-direction:column;align-items:center;padding:32px 20px;background:#fafafa;border-radius:16px;text-align:center;margin-bottom:12px}.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:#00000080;animation:fadeIn .3s ease}.tutor-sheet-overlay.closing .tutor-sheet-backdrop{animation:fadeOut .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.tutor-sheet{position:relative;background:#fff;border-radius:24px 24px 0 0;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s ease;max-width:480px;margin:0 auto;width:100%}.tutor-sheet.closing{animation:slideDown .25s ease-out forwards}@keyframes slideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(30%);opacity:0}}.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}.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}.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}.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:28px 16px 24px;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-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:12px}.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:8px 0}.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:1px solid #e5e5e5;padding:6px 12px;border-radius:8px;font-size:13px;color:#888;cursor:pointer;transition:all .2s}.delete-all-btn:hover{background:#fef2f2;border-color:#fecaca;color:#ef4444}.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}.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}.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:8px;justify-content:center;margin-top:14px}.weekly-card{width:40px;height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:#f8f8f8;border-radius:12px;position:relative;transition:all .15s ease;cursor:pointer;border:2px solid transparent}.weekly-card:active{transform:scale(.95)}.weekly-card.today{background:#5a6ad8;border-color:#5a6ad8}.weekly-card.today .weekly-day,.weekly-card.today .weekly-date{color:#fff}.weekly-card.completed:not(.today){background:#fff;border-color:#5a6ad8}.weekly-card.completed:not(.today) .weekly-day,.weekly-card.completed:not(.today) .weekly-date{color:#5a6ad8}.weekly-card.selected{background:#5a6ad8;border-color:#5a6ad8;box-shadow:0 4px 12px #5a6ad84d}.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;justify-content: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}.onboarding-skip:hover{color:#6b7280}.onboarding-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;max-width:320px}.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-dots{display:flex;gap:8px;margin:32px 0}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:#e5e7eb;cursor:pointer;transition:all .3s ease}.onboarding-dot.active{background:#3b82f6;width:24px;border-radius:4px}.onboarding-buttons{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:320px;margin-bottom:24px}.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.trial{background:linear-gradient(135deg,#6366f1,#8b5cf6);margin-bottom:0}.onboarding-button.trial:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed)}.onboarding-button-text{background:none;border:none;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;padding:8px;transition:color .2s}.onboarding-button-text:hover{color:#3b82f6}.onboarding-button:hover{background:#2563eb;transform:translateY(-1px)}.onboarding-button:active{transform:translateY(0)}@supports (padding-bottom: env(safe-area-inset-bottom)){.onboarding{padding-bottom:calc(24px + env(safe-area-inset-bottom))}}@media(prefers-color-scheme:dark){.onboarding{background:#111827}.onboarding-title{color:#f9fafb}.onboarding-description{color:#9ca3af}.onboarding-dot{background:#374151}.onboarding-dot.active{background:#3b82f6}.onboarding-skip{color:#6b7280}.onboarding-skip:hover{color:#9ca3af}}.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)}}@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}}: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{padding:16px 20px;padding-bottom:calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;align-items:center;gap:16px}.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}
