*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#1f2937;line-height:1.6;padding-bottom:80px}.header{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 20px;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;gap:16px}.back-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center}.icon{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.page-title{font-size:18px;font-weight:700;color:#1f2937}.intro-section{padding:24px 20px;background:#fff;border-bottom:1px solid #e5e7eb}.intro-title{font-size:16px;font-weight:700;color:#1f2937;margin-bottom:8px}.intro-text{font-size:14px;color:#6b7280;line-height:1.6}.avatars-container{padding:20px}.section-title{font-size:14px;font-weight:700;color:#1f2937;margin-bottom:16px}.avatar-grid{display:flex;flex-direction:column;gap:12px}.avatar-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;cursor:pointer;transition:all .2s}.avatar-card:hover{border-color:#1f2937;box-shadow:0 4px 12px #0000000d}.avatar-card:active{transform:scale(.98)}.avatar-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.avatar-image{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:20px;flex-shrink:0;overflow:hidden;background-size:cover;background-position:center}.avatar-image img{width:100%;height:100%;object-fit:cover}.avatar-image.business{background:linear-gradient(135deg,#667eea,#764ba2)}.avatar-image.casual{background:linear-gradient(135deg,#f093fb,#f5576c)}.avatar-image.exam{background:linear-gradient(135deg,#4facfe,#00f2fe)}.avatar-image.instant_translation{background:linear-gradient(135deg,#43e97b,#38f9d7)}.avatar-image.travel{background:linear-gradient(135deg,#fa709a,#fee140)}.avatar-image.pronunciation{background:linear-gradient(135deg,#a18cd1,#fbc2eb)}.avatar-info{flex:1}.avatar-name{font-size:16px;font-weight:700;color:#1f2937;margin-bottom:2px}.avatar-tags{display:flex;gap:6px;flex-wrap:wrap}.avatar-tag{font-size:11px;padding:2px 8px;border-radius:4px;background:#f3f4f6;color:#6b7280}.avatar-tag.accent{background:#dbeafe;color:#1e40af}.avatar-description{font-size:13px;color:#6b7280;line-height:1.5;margin-bottom:12px}.avatar-footer{display:flex;justify-content:space-between;align-items:center}.start-button{background:#1f2937;color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.start-button:hover{background:#111827}.avatar-specialty{font-size:12px;color:#9ca3af;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;margin-right:8px;max-width:50%}.footer-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;padding:8px 0;padding-bottom:env(safe-area-inset-bottom,8px);z-index:40;display:flex;justify-content:space-around;align-items:center}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;cursor:pointer;transition:all .2s;text-decoration:none;color:#9ca3af}.nav-item.active,.nav-item:hover{color:#1f2937}.nav-icon{width:24px;height:24px;margin-bottom:4px}.nav-label{font-size:11px;font-weight:500}.loading{text-align:center;padding:40px 20px;color:#9ca3af}.spinner{border:3px solid #f3f4f6;border-top:3px solid #1f2937;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 12px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.conversation-container{display:flex;flex-direction:column;height:100vh;background:#f5f5f5;padding-top:76px;padding-top:calc(76px + env(safe-area-inset-top,0px));box-sizing:border-box}.chat-messages{flex:1;overflow-y:auto;padding:16px 16px 100px}.message{max-width:80%;margin-bottom:12px;padding:12px 16px;border-radius:16px;animation:fadeIn .3s ease-out}.message.ai{background:#fff;border:1px solid #e5e7eb;margin-right:auto;border-bottom-left-radius:4px}.message.user{background:#f3f4f6;color:#1f2937;border:1px solid #e5e7eb;margin-left:auto;border-bottom-right-radius:4px}.message-content{font-size:14px;line-height:1.6}.conversation-footer{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;padding:12px 20px;padding-bottom:env(safe-area-inset-bottom,12px);display:flex;justify-content:center;align-items:center;gap:24px}.mic-button{width:64px;height:64px;border-radius:50%;background:#1f2937;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.mic-button:hover{background:#111827;transform:scale(1.05)}.mic-button.active{background:#ef4444;animation:pulse 1.5s infinite}.mic-button svg{width:28px;height:28px;stroke:#fff;fill:none;stroke-width:2}@keyframes pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 12px #ef444400}}.end-button{background:#f3f4f6;border:none;padding:12px 24px;border-radius:24px;font-size:14px;font-weight:600;color:#1f2937;cursor:pointer;transition:all .2s}.end-button:hover{background:#e5e7eb}.status-bar{background:#fff;padding:12px 20px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.status-indicator{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280}.status-dot{width:8px;height:8px;border-radius:50%;background:#d1d5db}.status-dot.connected{background:#10b981}.status-dot.speaking{background:#3b82f6;animation:pulse 1s infinite}.timer{font-size:14px;color:#6b7280;font-variant-numeric:tabular-nums}.history-list{padding:16px}.history-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s}.history-item:hover{border-color:#1f2937}.history-title{font-size:15px;font-weight:600;color:#1f2937;margin-bottom:4px}.history-meta{font-size:13px;color:#6b7280}.history-header-left,.history-header-right{display:flex;align-items:center;gap:8px}.new-conversation-button svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.token-badge{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:#4b5563;background:#f3f4f6;padding:6px 12px;border-radius:9999px;cursor:pointer;transition:all .2s;border:none}.token-badge:hover{background:#e5e7eb}.stats-section{background:#fff;border-bottom:1px solid #e5e7eb;padding:20px}.stats-grid{display:flex;align-items:center;justify-content:space-between;gap:16px}.stat-item{flex:1;text-align:center}.stat-value{font-size:24px;font-weight:700;color:#1f2937}.stat-label{font-size:12px;color:#9ca3af;margin-top:4px}.stat-divider{width:1px;height:40px;background:#e5e7eb}.period-filter-section{background:#fff;padding:12px 20px;border-bottom:1px solid #e5e7eb}.period-filter-tabs{display:flex;background:#f3f4f6;border-radius:10px;padding:4px;gap:2px}.period-tab{flex:1;padding:10px 8px;border:none;background:transparent;border-radius:8px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-width:0}.period-tab:hover{color:#374151}.period-tab.active{background:#fff;color:#1f2937;box-shadow:0 1px 3px #0000001a}.date-picker-panel{margin-top:12px;padding:16px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.date-picker-row{display:flex;align-items:flex-end;gap:12px;justify-content:center}.date-input-group{display:flex;flex-direction:column;gap:4px}.date-input-group label{font-size:12px;color:#6b7280;font-weight:500}.date-input-group input[type=date]{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#1f2937;background:#fff;min-width:130px}.date-input-group input[type=date]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.date-separator{color:#6b7280;font-size:14px;padding-bottom:10px}.date-picker-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.date-picker-btn{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.date-picker-btn.cancel{background:transparent;border:1px solid #d1d5db;color:#6b7280}.date-picker-btn.cancel:hover{background:#f3f4f6}.date-picker-btn.apply{background:#3b82f6;border:none;color:#fff}.date-picker-btn.apply:hover{background:#2563eb}.date-picker-btn.apply:disabled{background:#9ca3af;cursor:not-allowed}.date-group{margin-bottom:16px}.date-label{font-size:12px;font-weight:500;color:#9ca3af;margin-bottom:12px;letter-spacing:.5px}.history-card{background:#fff;border-radius:16px;border:1px solid #e5e7eb;overflow:hidden;margin-bottom:12px}.history-card-content{padding:16px;cursor:pointer;transition:all .2s ease}.clickable-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.clickable-card:active{transform:translateY(0);box-shadow:0 2px 6px #0000000a}.history-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.avatar-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:16px;flex-shrink:0;overflow:hidden}.avatar-icon.small{width:40px;height:40px;font-size:14px}.history-card-info{flex:1;min-width:0}.history-title{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:4px}.history-date{font-size:12px;color:#9ca3af}.history-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.action-button{width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.action-button svg{width:16px;height:16px}.action-button.resume{background:#f3e8ff;color:#9333ea}.action-button.resume:hover{background:#e9d5ff}.action-button.play{background:#dbeafe;color:#2563eb}.action-button.play:hover{background:#bfdbfe}.duration-badge{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:#4b5563;background:#f3f4f6;padding:4px 8px;border-radius:9999px}.history-meta-row{display:flex;align-items:center;gap:12px;font-size:12px;color:#6b7280;margin-bottom:12px}.meta-item{display:flex;align-items:center;gap:4px}.meta-icon{width:14px;height:14px;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.meta-icon.star{color:#f59e0b}.history-preview{font-size:12px;color:#6b7280;line-height:1.6;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.history-card-border{height:4px;background:linear-gradient(to right,#f3f4f6,#fff)}.empty-state{text-align:center;padding:48px 20px;color:#9ca3af}.empty-state svg{width:64px;height:64px;stroke:currentColor;fill:none;stroke-width:1.5;margin-bottom:16px}.detail-container{padding:20px}.feedback-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:20px;margin-bottom:16px}.feedback-score{font-size:48px;font-weight:700;color:#1f2937;text-align:center;margin-bottom:8px}.feedback-label{font-size:14px;color:#6b7280;text-align:center}.feedback-text{font-size:14px;color:#4b5563;line-height:1.8;margin-top:16px}.key-phrases{margin-top:16px}.key-phrase{background:#f3f4f6;padding:12px;border-radius:8px;margin-bottom:8px}.key-phrase-text{font-size:14px;font-weight:600;color:#1f2937}.key-phrase-translation{font-size:13px;color:#6b7280;margin-top:4px}.purchase-container{padding:20px}.balance-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:24px;text-align:center;margin-bottom:20px}.balance-label{font-size:12px;color:#9ca3af;margin-bottom:8px}.balance-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:4px}.balance-value{font-size:40px;font-weight:700;color:#1f2937}.balance-star{width:24px;height:24px;color:#f59e0b}.balance-minutes{font-size:14px;color:#6b7280;margin-bottom:16px}.usage-section{background:#f3f4f6;border-radius:12px;padding:16px}.usage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.usage-label{font-size:12px;color:#6b7280}.usage-value{font-size:12px;font-weight:600;color:#1f2937}.usage-bar-container{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.usage-bar{height:100%;background:#1f2937;transition:width .3s ease}.usage-remaining{font-size:12px;color:#9ca3af;margin-top:8px}.package-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;margin-bottom:12px;cursor:pointer;transition:all .2s ease;position:relative}.package-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.package-card:active{transform:translateY(0);box-shadow:0 2px 6px #0000000a}.package-card.popular{border:2px solid #1f2937;background:#f9fafb}.popular-badge{position:absolute;top:-8px;right:-8px;background:#1f2937;color:#fff;font-size:11px;font-weight:700;padding:4px 8px;border-radius:9999px}.package-content{display:flex;align-items:center;justify-content:space-between}.package-left{flex:1}.package-title-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:4px}.package-star{width:20px;height:20px;color:#f59e0b;flex-shrink:0;margin-top:2px}.package-credits{font-size:16px;font-weight:700;color:#1f2937}.package-bonus{font-size:12px;font-weight:600;color:#ea580c}.package-estimate{font-size:12px;color:#6b7280}.package-rate{font-size:11px;color:#9ca3af;margin-top:2px}.package-right{text-align:right}.package-price{font-size:20px;font-weight:700;color:#1f2937}.package-tax{font-size:11px;color:#9ca3af}.purchase-history-list{display:flex;flex-direction:column;gap:8px}.purchase-history-empty{text-align:center;padding:16px;font-size:12px;color:#9ca3af}.purchase-history-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px;display:flex;align-items:center;justify-content:space-between}.purchase-history-left{flex:1}.purchase-history-amount{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:2px}.purchase-history-date{font-size:12px;color:#9ca3af}.purchase-history-right{text-align:right}.purchase-history-price{font-size:14px;font-weight:700;color:#1f2937}.purchase-history-status{font-size:12px}.purchase-history-status.status-completed{color:#16a34a}.purchase-history-status.status-failed{color:#dc2626}.purchase-history-status.status-pending{color:#ca8a04}.purchase-history-status.status-refunded{color:#6b7280}.notes-section{background:#f3f4f6;border-radius:12px;padding:16px;margin-top:20px}.notes-header{display:flex;align-items:flex-start;gap:8px}.notes-icon{width:20px;height:20px;color:#9ca3af;flex-shrink:0;margin-top:2px}.notes-content{flex:1}.notes-title{font-size:12px;font-weight:700;color:#4b5563;margin-bottom:8px}.notes-list{font-size:12px;color:#6b7280;line-height:1.6;padding-left:16px;margin:0}.notes-list li{margin-bottom:4px}.token-balance{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;padding:24px;text-align:center;margin-bottom:24px}.balance-unit{font-size:14px;opacity:.9}.plan-card{background:#fff;border:2px solid #e5e7eb;border-radius:16px;padding:20px;margin-bottom:12px;cursor:pointer;transition:all .2s}.plan-card:hover{border-color:#1f2937}.plan-card.popular{border-color:#3b82f6}.plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.plan-name{font-size:16px;font-weight:700;color:#1f2937}.plan-badge{background:#dbeafe;color:#1e40af;font-size:11px;padding:2px 8px;border-radius:4px;font-weight:600}.plan-price{font-size:24px;font-weight:700;color:#1f2937}.plan-description{font-size:13px;color:#6b7280;margin-top:4px}.empty-state{text-align:center;padding:60px 20px;color:#9ca3af}.empty-state svg{width:64px;height:64px;margin-bottom:16px;stroke:currentColor;fill:none;stroke-width:1.5}.empty-state-text{font-size:14px;margin-bottom:16px}.footer-nav-conversation{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;padding-top:8px;padding-bottom:env(safe-area-inset-bottom,8px);z-index:50;display:grid;grid-template-columns:repeat(3,1fr);align-items:center;gap:0}.nav-item-small{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;cursor:pointer;transition:all .2s;text-decoration:none;color:#9ca3af;border:none;background:transparent}.nav-item-small:active{transform:scale(.95)}.nav-item-small .nav-icon{width:20px;height:20px;margin-bottom:4px}.nav-item-small .nav-label{font-size:10px;font-weight:500}.mic-button-large{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px;cursor:pointer;border:none;background:transparent}.mic-button-large .mic-circle{width:56px;height:56px;background:#1f2937;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-bottom:4px}.mic-button-large:active .mic-circle{transform:scale(.95);background:#000}.mic-button-large .mic-circle.active{background:#ef4444;animation:pulse 1.5s infinite}.mic-button-large .mic-circle.connecting{background:#6b7280;animation:blink 1s ease-in-out infinite}.mic-button-large .mic-icon{width:28px;height:28px;color:#fff}.mic-button-large .nav-label{font-size:10px;font-weight:500;color:#9ca3af}.conversation-header{position:fixed;top:0;left:0;right:0;z-index:40;background:#fff;border-bottom:1px solid #e5e7eb;padding-top:env(safe-area-inset-top,0px);height:76px;box-sizing:content-box}.conversation-header-content{height:76px;display:flex;align-items:center;justify-content:space-between;padding:8px 20px;box-sizing:border-box}.conversation-header-left{display:flex;align-items:center;gap:12px}.conversation-header-right{display:flex;align-items:center;gap:8px}.avatar-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;flex-shrink:0;overflow:hidden}.avatar-icon img{width:100%;height:100%;object-fit:cover}.avatar-icon.small{width:32px;height:32px;font-size:14px}.avatar-gradient-business{background:linear-gradient(135deg,#667eea,#764ba2)}.avatar-gradient-casual{background:linear-gradient(135deg,#f093fb,#f5576c)}.avatar-gradient-exam{background:linear-gradient(135deg,#4facfe,#00f2fe)}.avatar-gradient-instant_translation{background:linear-gradient(135deg,#43e97b,#38f9d7)}.avatar-gradient-travel{background:linear-gradient(135deg,#fa709a,#fee140)}.avatar-gradient-pronunciation{background:linear-gradient(135deg,#a18cd1,#fbc2eb)}.token-badge{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:#4b5563;background:#f9fafb;padding:6px 12px;border-radius:20px;border:none;cursor:pointer;transition:all .2s}.token-badge:hover{background:#f3f4f6}.token-badge:active{transform:scale(.95)}.token-badge svg{width:16px;height:16px;color:#f59e0b}.nav-item{border:none;background:transparent}.logout-button{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;transition:background .2s}.logout-button:hover{background:#f3f4f6}.logout-button:active{transform:scale(.95)}.logout-button svg{width:16px;height:16px;color:#9ca3af}.status-bar-bottom{position:fixed;bottom:100px;left:0;right:0;height:48px;background:#fff;border-top:1px solid #f3f4f6;display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:45}.status-bar-center{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center}.status-indicator-container{display:flex;align-items:center;gap:8px}.status-dot-container{position:relative;display:flex;height:12px;width:12px}.status-dot-ping{position:absolute;display:inline-flex;height:100%;width:100%;border-radius:50%;background:#9ca3af;opacity:.4;animation:ping 1s cubic-bezier(0,0,.2,1) infinite}.status-dot-inner{position:relative;display:inline-flex;border-radius:50%;height:12px;width:12px;background:#9ca3af}.status-dot-inner.listening{background:#10b981}.status-dot-inner.speaking{background:#3b82f6}.status-dot-inner.thinking{background:#f59e0b}.status-dot-inner.connecting{background:#6b7280}@keyframes ping{75%,to{transform:scale(2);opacity:0}}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}.status-text{font-size:14px;font-weight:500;color:#374151}.session-timer{display:flex;align-items:center;gap:6px;color:#6b7280}.session-timer svg{width:16px;height:16px}.session-timer span{font-family:ui-monospace,monospace;font-size:14px;font-weight:500}.message-row{display:flex;align-items:flex-end;gap:12px;margin-bottom:16px}.message-row.ai{flex-direction:row}.message-row.user{flex-direction:row-reverse}.message-bubble{max-width:85%;padding:12px 20px;border-radius:16px;font-size:15px;line-height:1.6;white-space:pre-wrap}.message-bubble.ai{background:#fff;color:#1f2937;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.message-bubble.user{background:#f3f4f6;color:#1f2937;border:1px solid #e5e7eb;border-bottom-right-radius:4px}.message-time{font-size:10px;color:#9ca3af;margin-top:4px;margin-left:44px}.message-row.user .message-time{margin-left:0;margin-right:44px;text-align:right}.messages-area{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px 20px 160px;background:#fff}.resume-message{display:flex;justify-content:center;align-items:center;gap:8px;margin-bottom:16px;padding:8px 16px;background:#f5f3ff;color:#7c3aed;border-radius:9999px;font-size:14px;width:fit-content;margin-left:auto;margin-right:auto}.resume-message svg{width:16px;height:16px;flex-shrink:0}.timeout-warning{position:fixed;top:70px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-radius:12px;font-size:14px;font-weight:500;box-shadow:0 4px 12px #f59e0b4d;z-index:1000;animation:pulse-warning 1s ease-in-out infinite}.timeout-warning svg{width:20px;height:20px;flex-shrink:0;stroke:#f59e0b}@keyframes pulse-warning{0%,to{opacity:1;transform:translate(-50%) scale(1)}50%{opacity:.9;transform:translate(-50%) scale(1.02)}}.low-balance-warning{padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500;white-space:nowrap;animation:fade-in .3s ease-in-out}.low-balance-warning.warning-medium{background:#fef3c7;color:#92400e}.low-balance-warning.warning-high{background:#fed7aa;color:#9a3412;animation:pulse-warning-medium 1s ease-in-out infinite}.low-balance-warning.warning-critical{background:#fecaca;color:#991b1b;font-weight:600;animation:pulse-warning-critical .8s ease-in-out infinite}@keyframes pulse-warning-medium{0%,to{opacity:1}50%{opacity:.85}}@keyframes pulse-warning-critical{0%,to{opacity:1}50%{opacity:.7}}@keyframes slide-down{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.practice-mode-container{margin-bottom:20px}.practice-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#f0fdf4;color:#16a34a;border-radius:9999px;font-size:14px;width:fit-content;margin-left:auto;margin-right:auto;margin-bottom:12px}.practice-banner svg{width:16px;height:16px;flex-shrink:0}.practice-sentences-list{background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:16px;margin:0 0 20px}.practice-list-header{font-size:13px;font-weight:600;color:#92400e;margin-bottom:12px}.practice-sentences{display:flex;flex-direction:column;gap:8px}.practice-sentence-item{background:#fff;border:1px solid #fcd34d;border-radius:8px;padding:10px 12px}.practice-sentence-item.active{border-color:#f59e0b;background:#fef3c7}.practice-sentence-index{font-size:11px;color:#92400e;font-weight:600;margin-bottom:4px}.practice-sentence-text{font-size:14px;color:#78350f;line-height:1.5}.practice-hint{margin-top:12px;font-size:12px;color:#92400e;font-style:italic}.token-warning-banner{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:12px 20px;display:flex;align-items:center;justify-content:space-between}.token-warning-content{display:flex;align-items:center;gap:8px;flex:1}.token-warning-text{font-size:14px;font-weight:500}.token-warning-button{background:#fff3;border:none;color:#fff;padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.token-warning-button:hover{background:#ffffff4d}.history-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:40}.history-header-left{display:flex;align-items:center;gap:12px}.history-header-right{display:flex;align-items:center;gap:8px}.new-conversation-button{width:36px;height:36px;border-radius:50%;background:#1f2937;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.new-conversation-button:hover{background:#111827}.new-conversation-button:active{transform:scale(.95)}.new-conversation-button svg{width:20px;height:20px;color:#fff}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:4px 0}.collapsible-header:hover{opacity:.8}.collapsible-icon{transition:transform .2s}.collapsible-icon.expanded{transform:rotate(180deg)}.collapsible-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out;padding-top:0}.collapsible-content.expanded{max-height:2000px;padding-top:12px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease-out}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding-bottom:0}.login-container{width:100%;max-width:400px;margin:0 auto;padding:40px 20px}.login-header{text-align:center;margin-bottom:40px;background:transparent;border:none;padding:0;position:static}.logo-icon{width:64px;height:64px;background:#1e293b;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.logo-icon svg{width:32px;height:32px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.app-title{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:4px}.app-version{font-size:14px;color:#6b7280}.login-form{background:#fff;border-radius:16px;padding:24px;box-shadow:0 1px 3px #0000001a}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.form-input{width:100%;padding:12px 16px;border:1px solid #e5e7eb;border-radius:12px;font-size:16px;color:#1f2937;background:#fafafa;transition:border-color .2s,background .2s}.form-input::placeholder{color:#9ca3af}.form-input:focus{outline:none;border-color:#1e293b;background:#fff}.form-input::-ms-reveal,.form-input::-ms-clear{display:none}.form-hint{font-size:12px;color:#6b7280;margin-top:8px}.error-message{display:none;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;font-size:14px;color:#dc2626;margin-bottom:20px}.error-message.show{display:block}.login-btn{width:100%;padding:14px;background:#1e293b;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.login-btn:hover{background:#0f172a}.login-btn:active{transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.dev-section{margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.dev-label{font-size:12px;color:#9ca3af;text-align:center;margin-bottom:12px}.quick-login-btn{width:100%;padding:12px;background:#f3f4f6;color:#4b5563;border:none;border-radius:12px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.quick-login-btn:hover{background:#e5e7eb}.login-footer{text-align:center;margin-top:32px;font-size:12px;color:#9ca3af}.login-footer p{margin-bottom:4px}.purchase-success-container{padding:24px 20px;max-width:480px;margin:0 auto}.purchase-success-loading{text-align:center;padding:48px 0}.purchase-success-loading .spinner{width:48px;height:48px;border:3px solid #e5e7eb;border-top-color:#1e293b;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.purchase-success-loading .loading-text{font-size:14px;color:#6b7280}.purchase-success-content{text-align:center}.purchase-success-content .success-icon{width:64px;height:64px;background:#dcfce7;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.purchase-success-content .success-icon svg{width:32px;height:32px;stroke:#16a34a}.purchase-success-content .success-title{font-size:20px;font-weight:700;color:#1f2937;margin-bottom:8px}.purchase-success-content .success-subtitle{font-size:14px;color:#6b7280;margin-bottom:24px}.purchase-success-content .details-card{background:#fff;border-radius:16px;padding:20px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;text-align:left}.purchase-success-content .details-title{font-size:14px;font-weight:700;color:#1f2937;margin-bottom:16px}.purchase-success-content .detail-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f3f4f6}.purchase-success-content .detail-row:last-child{border-bottom:none}.purchase-success-content .detail-label{font-size:13px;color:#6b7280}.purchase-success-content .detail-value{font-size:14px;font-weight:600;color:#1f2937}.purchase-success-content .detail-value.highlight{font-size:18px;font-weight:700;color:#1e293b}.purchase-success-content .button-group{display:flex;flex-direction:column;gap:12px}.purchase-success-content .btn{display:block;width:100%;padding:14px;border-radius:12px;font-size:15px;font-weight:600;text-align:center;cursor:pointer;transition:background .2s,transform .1s;border:none}.purchase-success-content .btn:active{transform:scale(.98)}.purchase-success-content .btn-primary{background:#1e293b;color:#fff}.purchase-success-content .btn-primary:hover{background:#0f172a}.purchase-success-content .btn-secondary{background:#fff;color:#1f2937;border:1px solid #e5e7eb}.purchase-success-content .btn-secondary:hover{background:#f9fafb}.purchase-success-error{text-align:center;padding:48px 0}.purchase-success-error .error-icon{width:64px;height:64px;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.purchase-success-error .error-icon svg{width:32px;height:32px;stroke:#dc2626}.purchase-success-error .error-title{font-size:20px;font-weight:700;color:#1f2937;margin-bottom:8px}.purchase-success-error .error-message{font-size:14px;color:#6b7280;margin-bottom:24px;display:block;background:transparent;border:none;padding:0}.purchase-success-error .btn{display:inline-block;padding:14px 32px;border-radius:12px;font-size:15px;font-weight:600;text-align:center;cursor:pointer;transition:background .2s,transform .1s;border:none;background:#1e293b;color:#fff}.purchase-success-error .btn:hover{background:#0f172a}.purchase-success-error .btn:active{transform:scale(.98)}
