@import "https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500;700;900&display=swap";.chat-messages{flex-direction:column;flex:1;gap:14px;padding:20px 16px;display:flex;overflow-y:auto}.chat-empty{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:64px 20px;display:flex}.chat-empty-avatar{object-fit:cover;opacity:.7;border-radius:50%;width:72px;height:72px}.chat-empty-text{color:#bbb;font-size:.88rem}.chat-message{align-items:flex-end;gap:8px;width:100%;max-width:720px;margin:0 auto;display:flex}.chat-message--user{flex-direction:row-reverse}.chat-message-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.chat-message-bubble{flex-direction:column;gap:5px;padding:10px 14px;display:flex}.chat-message--assistant .chat-message-bubble{background:#fff;border-radius:18px 18px 18px 4px;max-width:82%;box-shadow:0 1px 4px #00000014}.chat-message--user .chat-message-bubble{background:var(--accent);border-radius:18px 18px 4px;max-width:68%}.chat-correction-row{width:100%;max-width:720px;margin:4px auto 0;display:flex}.chat-correction-row .chat-correction-card{max-width:82%;margin-left:40px}.chat-correction-card{background:#22c55e0f;border:1px solid #22c55e38;border-radius:14px;flex-direction:column;gap:6px;padding:10px 14px;display:flex}.chat-correction-corrected{color:#166534;align-items:flex-start;gap:8px;font-size:.88rem;font-weight:600;line-height:1.5;display:flex}.chat-correction-check{flex-shrink:0;line-height:1.5}.chat-correction-en{word-break:break-word;white-space:pre-wrap;flex:1}.chat-correction-note{color:#475569;white-space:pre-wrap;margin:0;font-size:.78rem;line-height:1.6}.chat-message-text{color:#333;white-space:pre-wrap;word-break:break-word;margin:0;font-size:.9rem;line-height:1.65}.chat-message--user .chat-message-text{color:#fff}.chat-message-time{color:silver;align-self:flex-end;font-size:.65rem;line-height:1}.chat-message--user .chat-message-time{color:#ffffffa6}.chat-message-bubble--loading{color:#aaa;background:#fff;align-items:center;gap:8px;font-size:.85rem;box-shadow:0 1px 4px #00000014;flex-direction:row!important}.chat-spinner{color:#ccc;flex-shrink:0;animation:1s linear infinite chat-spin}@keyframes chat-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-date-separator{align-items:center;gap:10px;width:100%;max-width:720px;margin:6px auto;display:flex}.chat-date-separator:before,.chat-date-separator:after{content:"";background:#00000014;flex:1;height:1px}.chat-date-separator span{color:#bbb;white-space:nowrap;padding:0 4px;font-size:.68rem}.chat-load-more{justify-content:center;padding:8px 0 4px;display:flex}.chat-load-more-spinner{border:2px solid #0000001a;border-top-color:#ccc;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite chat-spin}.chat-input-area{background:#fff;border-top:1px solid #0000000f;flex-shrink:0;padding:12px 16px}.chat-input-wrapper{background:#fff;border:1.5px solid #e0e0e0;border-radius:24px;align-items:flex-end;gap:8px;max-width:720px;margin:0 auto;padding:8px 8px 8px 16px;transition:border-color .15s,box-shadow .15s;display:flex;box-shadow:0 1px 4px #0000000f}.chat-input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent), 0 1px 4px #0000000f}.chat-input{resize:none;color:#333;background:0 0;border:none;outline:none;flex:1;min-height:24px;max-height:120px;padding:6px 0;font-family:inherit;font-size:.9rem;line-height:1.6}.chat-input::placeholder{color:#bbb}.chat-input:disabled{opacity:.5}.chat-send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:opacity .15s,transform .1s;display:flex}.chat-send-btn:disabled{opacity:.35;cursor:not-allowed}.chat-send-btn:not(:disabled):hover{opacity:.85}.chat-send-btn:not(:disabled):active{transform:scale(.93)}@media (width<=768px){.chat-message--assistant .chat-message-bubble{max-width:86%}.chat-message--user .chat-message-bubble{max-width:78%}.chat-correction-row .chat-correction-card{max-width:86%}}:root{--bg-color:#f5f3f0;--surface-color:#fff;--text-primary:#1e1e1e;--text-secondary:#7a7a7a;--text-muted:#a0a0a0;--card-radius:20px;--transition:all .35s cubic-bezier(.25, .8, .25, 1);--gradient-bg:#ff8e9b;--color-text:#1e1e1e;--color-text-secondary:#7a7a7a;--color-text-muted:#a0a0a0;--color-surface:#fff;--color-surface-hover:#f5f3f0;--color-bg:#f5f3f0;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--font-base:"Zen Kaku Gothic New", "Hiragino Sans", sans-serif;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--radius-sm:.375rem;--radius-md:.625rem;--radius-lg:.875rem;--radius-xl:1rem;--radius-2xl:1.25rem;--radius-full:9999px;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000a;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--header-height:56px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Zen Kaku Gothic New,Hiragino Sans,sans-serif;line-height:1.7;overflow-x:hidden}.mesh-bg{z-index:-1;position:fixed;inset:0}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-header{z-index:100;-webkit-backdrop-filter:blur(24px);background:#f5f3f099;padding:1rem 2rem;position:sticky;top:0}.logo{color:var(--text-primary);letter-spacing:.02em;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;display:flex}.logo__icon{object-fit:cover;border-radius:50%;width:28px;height:28px}.app-main{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:2rem 1.5rem 4rem}.app-footer{text-align:center;color:var(--text-muted);padding:2rem;font-size:.75rem}.app-header{justify-content:space-between;align-items:center;display:flex}.account-menu{position:relative}.account-menu__trigger{cursor:pointer;background:0 0;border:none;align-items:center;padding:0;display:flex}.account-menu__avatar{color:#fff;background:#ff8e9b;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 2px 8px #ff8e9b59}.account-menu__trigger:hover .account-menu__avatar{transform:scale(1.08);box-shadow:0 4px 12px #ff8e9b73}.account-menu__dropdown{-webkit-backdrop-filter:blur(16px);z-index:200;background:#fffffff7;border:1px solid #0000000f;border-radius:16px;min-width:232px;animation:.15s ease-out dropdownIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 30px #0000001a}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.account-menu__user-info{flex-direction:column;gap:.2rem;padding:.9rem 1rem .75rem;display:flex}.account-menu__user-name{color:var(--text-primary);font-size:.875rem;font-weight:700}.account-menu__user-email{color:var(--text-secondary);word-break:break-all;font-size:.75rem}.account-menu__divider{background:#0000000f;height:1px;margin:0 .5rem}.account-menu__item{width:100%;color:var(--text-primary);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:.5rem;padding:.7rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:background .15s;display:flex}.account-menu__item:hover{background:#0000000a}.account-menu__item--danger{color:#ef4444}.account-menu__item--danger:hover{background:#ef44440d}.account-menu__plan-upgrade{color:#fff;white-space:nowrap;background:linear-gradient(135deg,#ff8e9b 0%,#c93a4d 100%);border-radius:999px;padding:.22rem .45rem;font-size:.66rem;font-weight:700;line-height:1}.ai-chat-badge{color:#fff;letter-spacing:.15em;vertical-align:middle;background:#ff8e9b;border-radius:14px 14px 14px 3px;flex-shrink:0;padding:.45em 1.1em;font-size:.42em;font-weight:800;display:inline-block}.logo .ai-chat-badge{padding:.3em .75em;font-size:.6rem}.personas-section-label{text-align:center;color:var(--text-secondary);letter-spacing:.04em;margin-bottom:1.5rem;font-size:.85rem;font-weight:600}.personas-grid{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.persona-card{background:var(--surface-color);border-radius:var(--card-radius);cursor:pointer;transition:var(--transition);flex-direction:column;display:flex;overflow:hidden;box-shadow:0 1px 2px #0000000a,0 6px 16px -10px #0000002e}.persona-card:hover{transform:translateY(-6px);box-shadow:0 16px 30px -10px #00000029,0 6px 12px -6px #00000014}.card-header{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 26%, #fff), color-mix(in srgb, var(--accent) 11%, #fff));align-items:center;gap:.6rem;padding:.85rem 1.1rem;display:flex}.card-icon{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px;box-shadow:0 2px 5px #0000001f}.card-emoji{font-size:1.4rem;line-height:1}.card-app-name{letter-spacing:-.01em;color:color-mix(in srgb, var(--accent) 82%, #000);font-size:1.05rem;font-weight:800;line-height:1.3}.card-body{flex-direction:column;flex:1;padding:1.1rem 1.15rem 1.2rem;display:flex;position:relative}.card-bg{z-index:0;background:linear-gradient(to bottom, #ffffff47 0%, #ffffff9e 52%, #ffffffe6 100%), var(--panel) center / cover no-repeat;pointer-events:none;position:absolute;inset:0}.card-body-head{z-index:1;align-items:center;gap:.85rem;margin-bottom:.85rem;display:flex;position:relative}.card-avatar-wrap{flex-shrink:0;width:96px;height:96px;position:relative}.card-avatar{object-fit:cover;object-position:center top;width:100%;height:100%;box-shadow:0 10px 24px -6px #00000047, 0 0 0 4px color-mix(in srgb, var(--accent) 38%, #fff);background:#fff;border:3px solid #fff;border-radius:50%;transition:transform .35s cubic-bezier(.25,.8,.25,1)}.persona-card:hover .card-avatar{transform:scale(1.05)}.card-online-dot{background-color:#4ade80;border:2.5px solid #fff;border-radius:50%;width:16px;height:16px;animation:2s infinite pulse-dot;position:absolute;bottom:5px;right:5px;box-shadow:0 0 0 2px #4ade8040}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 2px #4ade8040}50%{box-shadow:0 0 0 5px #4ade801f}}.card-id{flex-direction:column;gap:.3rem;min-width:0;display:flex}.card-persona-name{color:var(--text-primary);font-size:1.15rem;font-weight:800}.card-scene{color:color-mix(in srgb, var(--accent) 82%, #000);background:color-mix(in srgb, var(--accent) 15%, #fff);white-space:nowrap;border-radius:999px;align-self:flex-start;padding:.2rem .6rem;font-size:.65rem;font-weight:700}.card-concept{z-index:1;color:var(--text-secondary);flex:1;margin-bottom:1.1rem;font-size:.82rem;line-height:1.65;position:relative}.card-cta{z-index:1;border:1.5px solid color-mix(in srgb, var(--accent) 28%, #fff);color:color-mix(in srgb, var(--accent) 80%, #000);cursor:pointer;transition:var(--transition);background:#fff;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:.72rem;font-family:inherit;font-size:.85rem;font-weight:700;display:flex;position:relative}.card-cta svg{flex-shrink:0}.persona-card:hover .card-cta{background:var(--accent);border-color:var(--accent);color:#fff}@media (width<=900px){.personas-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.personas-grid{grid-template-columns:1fr;gap:1rem}.app-main{padding:1.5rem 1rem 3rem}}.login-page{min-height:100dvh;padding:var(--space-4);background:var(--bg-color);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-card{z-index:1;-webkit-backdrop-filter:blur(20px);border-radius:var(--card-radius);width:100%;max-width:440px;padding:var(--space-10) var(--space-8);box-shadow:var(--shadow-xl), 0 0 60px #0000000f;text-align:center;background:#ffffffeb;animation:.5s ease-out cardIn;position:relative}@keyframes cardIn{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.login-card__icon{width:72px;height:72px;margin:0 auto var(--space-5);background:#fff;border-radius:50%;justify-content:center;align-items:center;padding:10px;display:flex;overflow:hidden;box-shadow:0 2px 12px #0000001a}.login-card__icon-img{object-fit:contain;width:100%;height:100%}.login-card__title{font-size:var(--text-2xl);margin-bottom:var(--space-2);color:#ff8e9b;font-weight:700}.login-card__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-8);line-height:1.8}.login-form{gap:var(--space-4);margin-bottom:var(--space-4);text-align:left;flex-direction:column;display:flex}.login-form__field{gap:var(--space-2);flex-direction:column;display:flex}.login-form__label-row{justify-content:space-between;align-items:center;display:flex}.login-form__label{font-size:var(--text-sm);color:var(--color-text);letter-spacing:.01em;font-weight:600}.login-form__forgot-link{font-size:var(--text-xs);color:#ff8e9b;transition:color var(--transition-fast);font-weight:500;text-decoration:none}.login-form__forgot-link:hover{color:#ffa07a;text-decoration:underline}.login-form__input-wrapper{align-items:center;display:flex;position:relative}.login-form__input-icon{left:var(--space-3);color:var(--color-text-muted);pointer-events:none;transition:color var(--transition-fast);z-index:1;position:absolute}.login-form__input-wrapper:focus-within .login-form__input-icon{color:#ff8e9b}.login-form__input{width:100%;padding:var(--space-3) var(--space-4);padding-left:calc(var(--space-3) + 18px + var(--space-3));border:1.5px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-sm);font-family:var(--font-base);color:var(--color-text);background:var(--color-surface);transition:all var(--transition-fast);outline:none}.login-form__input::placeholder{color:var(--color-text-muted)}.login-form__input:focus{border-color:#ff8e9b;box-shadow:0 0 0 3px #ff8e9b1f}.login-form__input:hover:not(:focus){border-color:var(--color-text-muted)}.login-form__toggle-password{right:var(--space-3);color:var(--color-text-muted);padding:var(--space-1);border-radius:var(--radius-sm);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute}.login-form__toggle-password:hover{color:var(--color-text-secondary);background:var(--color-surface-hover)}.login-card__btn{justify-content:center;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-6);border-radius:var(--radius-xl);font-weight:700;font-size:var(--text-sm);font-family:var(--font-base);transition:all var(--transition-fast);cursor:pointer;border:none;text-decoration:none;display:flex}.login-card__btn--primary{color:#fff;background:var(--gradient-bg);box-shadow:0 4px 15px #ff8e9b59}.login-card__btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff8e9b73}.login-card__btn--primary:active{transform:translateY(0)scale(.98)}.login-card__btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.login-divider{align-items:center;gap:var(--space-4);margin:var(--space-4) 0;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.login-divider__text{font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:.05em;font-weight:500}.login-card__google-wrapper{justify-content:center;display:flex}.login-card__inapp-notice{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:#ff8e9b0f;border:1px solid #ff8e9b26;line-height:1.7}.login-card__signup{margin-top:var(--space-6);font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center}.login-card__signup-link{color:#ff8e9b;margin-left:var(--space-1);transition:color var(--transition-fast);white-space:nowrap;font-weight:700;text-decoration:none}.login-card__signup-link:hover{color:#ffa07a;text-decoration:underline}.login-form__consent{margin-top:var(--space-2);align-items:flex-start;display:flex}.login-form__consent-label{align-items:flex-start;gap:var(--space-2);cursor:pointer;font-size:var(--text-xs);color:var(--color-text-secondary);line-height:1.6;display:flex}.login-form__consent-checkbox{accent-color:#ff8e9b;cursor:pointer;flex-shrink:0;width:16px;height:16px;margin-top:2px}.login-form__consent-text{flex:1}.login-form__consent-link{color:#ff8e9b;transition:color var(--transition-fast);font-weight:600;text-decoration:underline}.login-form__consent-link:hover{color:#ffa07a}.login-card__google-consent-note{margin-top:var(--space-3);font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;line-height:1.7}.login-card__google-consent-link{color:#ff8e9b;transition:color var(--transition-fast);font-weight:600;text-decoration:underline}.login-card__google-consent-link:hover{color:#ffa07a}.login-card__legal-links{margin-top:var(--space-4);font-size:var(--text-xs);color:var(--color-text-muted);flex-wrap:wrap;justify-content:center;align-items:center;line-height:1.8;display:flex}.login-card__legal-link{color:var(--color-text-secondary);transition:color var(--transition-fast);white-space:nowrap;text-decoration:none}.login-card__legal-link:hover{color:#ff8e9b;text-decoration:underline}.login-card__legal-sep{margin:0 var(--space-2);color:var(--color-text-muted)}.login-form__success{border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:var(--text-sm);color:#16a34a;text-align:center;background:#22c55e14;border:1px solid #22c55e40}.login-form__error{border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:var(--text-sm);color:#ef4444;text-align:center;background:#ef444414;border:1px solid #ef444440;animation:.3s ease-out shakeIn}@keyframes shakeIn{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.otp-input-group{justify-content:center;gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.otp-input-group__digit{text-align:center;width:48px;height:56px;font-size:var(--text-2xl);font-weight:700;font-family:var(--font-base);color:var(--color-text);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);caret-color:#ff8e9b;outline:none}.otp-input-group__digit:focus{border-color:#ff8e9b;transform:scale(1.05);box-shadow:0 0 0 3px #ff8e9b26}.otp-input-group__digit:hover:not(:focus){border-color:var(--color-text-muted)}.otp-resend{margin-top:var(--space-6);text-align:center}.otp-resend__text{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-2)}.otp-resend__btn{color:#ff8e9b;font-size:var(--text-sm);font-weight:700;font-family:var(--font-base);cursor:pointer;transition:all var(--transition-fast);padding:var(--space-2) var(--space-4);border-radius:var(--radius-lg);background:0 0;border:none}.otp-resend__btn:hover:not(:disabled){color:#ffa07a;background:#ff8e9b14}.otp-resend__btn:disabled{color:var(--color-text-muted);cursor:not-allowed}.profile-form__select-wrapper{align-items:center;gap:var(--space-2);background:var(--bg-color);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:0 var(--space-3);transition:border-color var(--transition-fast);display:flex}.profile-form__select-wrapper:focus-within{border-color:#ff8e9b;box-shadow:0 0 0 3px #ff8e9b1a}.profile-form__select-wrapper--disabled{opacity:.45;pointer-events:none}.profile-form__select-icon{color:var(--color-text-muted);flex-shrink:0}.profile-form__select{padding:var(--space-3) 0;font-size:var(--text-sm);color:var(--color-text);font-family:var(--font-base);cursor:pointer;appearance:none;background:0 0;border:none;outline:none;flex:1}.profile-form__select:disabled{cursor:not-allowed;color:var(--color-text-muted)}.profile-form__chevron{color:var(--color-text-muted);pointer-events:none;flex-shrink:0}.location-modal-overlay{z-index:500;padding:var(--space-4);background:#0000008c;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.location-modal{background:var(--color-surface);border-radius:var(--card-radius);padding:var(--space-6);width:100%;max-width:460px;animation:.25s ease-out slideUp;box-shadow:0 20px 60px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.location-modal__header{margin-bottom:var(--space-5)}.location-modal__emoji{margin-bottom:var(--space-3);font-size:2rem;display:block}.location-modal__title{font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-2);font-weight:800}.location-modal__description{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.7}.location-modal__form{gap:var(--space-4);flex-direction:column;display:flex}.location-modal__submit{margin-top:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--gradient-bg);color:#fff;border-radius:var(--radius-lg);font-size:var(--text-sm);cursor:pointer;transition:opacity var(--transition-fast), transform var(--transition-fast);font-weight:700;font-family:var(--font-base);border:none;width:100%;box-shadow:0 4px 15px #ff8e9b4d}.location-modal__submit:hover{opacity:.9;transform:translateY(-1px)}.location-modal__submit:disabled{opacity:.45;cursor:not-allowed;transform:none}.location-modal__error{border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:#dc2626;background:#ef444414;border:1px solid #ef444433}.profile-loading{padding:var(--space-12) 0;color:var(--color-text-muted);font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}.profile-header__title{font-size:var(--text-base);align-items:center;gap:var(--space-2);color:#ff8e9b;font-weight:700;display:flex}.settings-page{background:var(--bg-color);-webkit-overflow-scrolling:touch;z-index:100;flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.settings-header{padding:var(--space-3) var(--space-4);height:var(--header-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);z-index:10;background:#ffffffeb;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.settings-header__back-btn{border-radius:var(--radius-lg);width:40px;height:40px;color:var(--color-text-secondary);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.settings-header__back-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.settings-header__title{font-size:var(--text-base);align-items:center;gap:var(--space-2);color:#ff8e9b;font-weight:700;display:flex}.settings-content{padding:var(--space-4);padding-bottom:var(--space-12);width:100%;max-width:680px;margin:0 auto;animation:.4s ease-out fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.settings-section{margin-bottom:var(--space-6)}.settings-section__title{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-4);letter-spacing:.02em;font-weight:700}.settings-section__description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);line-height:1.7}.settings-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--card-radius);padding:var(--space-5);box-shadow:var(--shadow-sm)}.settings-info{gap:var(--space-3);flex-direction:column;display:flex}.settings-info__row{padding:var(--space-2) 0;justify-content:space-between;align-items:center;display:flex}.settings-info__row:not(:last-child){border-bottom:1px solid var(--color-border-light);padding-bottom:var(--space-3)}.settings-info__label{font-size:var(--text-sm);color:var(--color-text-secondary)}.settings-info__value{font-size:var(--text-sm);color:var(--color-text);font-weight:600}.settings-form{gap:var(--space-4);flex-direction:column;display:flex}.settings-form__field{gap:var(--space-1);flex-direction:column;display:flex}.settings-form__label{font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:600}.settings-form__hint{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1);line-height:1.5}.settings-form__input-wrapper{align-items:center;gap:var(--space-2);background:var(--bg-color);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:0 var(--space-3);transition:border-color var(--transition-fast);display:flex}.settings-form__input-wrapper:focus-within{border-color:#ff8e9b;box-shadow:0 0 0 3px #ff8e9b1a}.settings-form__input-icon{color:var(--color-text-muted);flex-shrink:0}.settings-form__input{padding:var(--space-3) 0;font-size:var(--text-sm);color:var(--color-text);font-family:var(--font-base);background:0 0;border:none;outline:none;flex:1}.settings-form__input::placeholder{color:var(--color-text-muted)}.settings-form__input[type=date]{position:relative}.settings-form__input[type=date]::-webkit-calendar-picker-indicator{opacity:0;cursor:pointer;width:auto;height:auto;margin:0;position:absolute;inset:0}.settings-form__toggle-password{padding:var(--space-1);color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.settings-form__toggle-password:hover{color:var(--color-text-secondary)}.settings-form__submit{padding:var(--space-3) var(--space-4);background:var(--gradient-bg);color:#fff;border-radius:var(--radius-lg);font-size:var(--text-sm);cursor:pointer;transition:opacity var(--transition-fast), transform var(--transition-fast);font-weight:700;font-family:var(--font-base);border:none;box-shadow:0 4px 15px #ff8e9b4d}.settings-form__submit:hover{opacity:.9;transform:translateY(-1px)}.settings-form__submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.settings-logout-btn{width:100%;padding:var(--space-3) var(--space-4);color:#ef4444;border-radius:var(--radius-lg);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);font-weight:700;font-family:var(--font-base);justify-content:center;align-items:center;gap:var(--space-2);background:0 0;border:1.5px solid #ef44444d;display:flex}.settings-logout-btn:hover{background:#ef44440f;border-color:#ef444480}.settings-success{border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:var(--text-sm);color:#16a34a;background:#22c55e14;border:1px solid #22c55e33}.settings-error{border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:var(--text-sm);color:#dc2626;background:#ef444414;border:1px solid #ef444433}@media (width>=768px){.settings-content{padding:var(--space-8);padding-bottom:var(--space-12)}}.wh-progress-card{border-radius:var(--card-radius);background:#fff;border:none;margin-bottom:1.5rem;padding:1.4rem 1.6rem 1.5rem;position:relative;box-shadow:0 4px 18px -6px #c93a4d1f}.wh-progress-head{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1.1rem;display:flex}.wh-progress-location{color:var(--text-secondary);letter-spacing:.01em;align-items:center;gap:.45rem;min-width:0;font-size:.92rem;display:flex}.wh-progress-location__icon{color:#c93a4d;flex-shrink:0}.wh-progress-location__country{color:var(--text-secondary)}.wh-progress-location__city{color:var(--text-primary);font-weight:700}.wh-progress-edit{color:var(--text-secondary);cursor:pointer;background:#0000000a;border:none;border-radius:999px;flex-shrink:0;align-items:center;gap:.25rem;padding:.3rem .6rem;font-family:inherit;font-size:.72rem;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.wh-progress-edit:hover{color:#c93a4d;background:#c93a4d1a}.wh-progress-stats{justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.45rem;display:flex}.wh-progress-stat{color:var(--text-secondary);align-items:baseline;gap:.25rem;font-size:.78rem;display:flex}.wh-progress-stat__num{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.15rem;font-weight:800;line-height:1}.wh-progress-stat--remaining .wh-progress-stat__num{color:#c93a4d}.wh-progress-bar{background:#ffe4e8;border-radius:999px;height:8px;margin-bottom:.55rem;position:relative;overflow:hidden}.wh-progress-bar__fill{background:#c93a4d;border-radius:999px;height:100%;transition:width .45s}.wh-progress-bar__percent{color:#c93a4d;font-variant-numeric:tabular-nums;font-size:.72rem;font-weight:700;position:absolute;top:-1.45rem;right:0}.wh-progress-period{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:.72rem}.wh-progress-card--before .wh-progress-countdown{text-align:center;padding:.5rem 0 .25rem}.wh-progress-countdown__label{color:var(--text-secondary);margin-bottom:.25rem;font-size:.78rem;display:block}.wh-progress-countdown__num{color:#c93a4d;font-variant-numeric:tabular-nums;font-size:2rem;font-weight:900;line-height:1}.wh-progress-countdown__unit{color:var(--text-secondary);margin-left:.2rem;font-size:.95rem}.wh-progress-card--no-dates .wh-progress-cta{color:#c93a4d;cursor:pointer;background:0 0;border:none;align-items:center;gap:.35rem;padding:0;font-family:inherit;font-size:.8rem;font-weight:600;display:inline-flex}.wh-progress-card--no-dates .wh-progress-cta:hover{text-decoration:underline}.wh-progress-card--open .wh-progress-stats{margin-bottom:.2rem}.wh-progress-card--open .wh-progress-hint{color:var(--text-muted);margin-top:.35rem;font-size:.7rem}@media (width<=600px){.wh-progress-card{margin-bottom:1.1rem;padding:1rem 1.1rem}.wh-progress-stat__num{font-size:1.05rem}.wh-progress-countdown__num{font-size:1.7rem}}.updating-overlay{z-index:20;-webkit-backdrop-filter:blur(2px);background:#ffffffd1;flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:absolute;inset:0}.updating-overlay__spinner{border:3px solid #00000014;border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.9s linear infinite updating-overlay-spin}@keyframes updating-overlay-spin{to{transform:rotate(360deg)}}.updating-overlay__text{color:var(--accent);letter-spacing:.02em;font-size:.85rem;font-weight:600}.kokoro-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.kokoro-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.kokoro-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.kokoro-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.kokoro-back-btn:hover{color:#333;background:#f0f0f0}.kokoro-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.kokoro-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.kokoro-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.kokoro-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.kokoro-summary-btn{display:none}.kokoro-body{flex:1;display:flex;overflow:hidden}.kokoro-chat-col{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.kokoro-summary-panel{width:var(--panel-width,380px);background:#fff;border-left:1px solid #00000012;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.kokoro-summary-resize-handle{cursor:col-resize;z-index:10;background:0 0;width:6px;transition:background .15s;display:none;position:absolute;top:0;bottom:0;left:-3px}.kokoro-summary-resize-handle:hover,.kokoro-summary-resize-handle:active{background:var(--accent);opacity:.4}.kokoro-summary-header{border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 13px;display:flex}.kokoro-summary-title{color:#999;text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:700}.kokoro-summary-close{display:none}.kokoro-summary-body{flex:1;padding:20px 16px;overflow-y:auto}.kokoro-summary-empty{text-align:center;color:#ddd;flex-direction:column;align-items:center;gap:14px;padding:56px 16px;display:flex}.kokoro-summary-empty p{color:silver;margin:0;font-size:.82rem;line-height:1.75}.kokoro-summary-content{color:#444;font-size:.85rem;line-height:1.8}.kokoro-summary-content h2{color:#222;border-bottom:1px solid #00000012;margin:0 0 14px;padding-bottom:8px;font-size:.95rem;font-weight:700}.kokoro-summary-content h3{color:#888;text-transform:uppercase;letter-spacing:.05em;margin:18px 0 6px;font-size:.75rem;font-weight:700}.kokoro-summary-content ul{margin:0 0 10px;padding-left:18px}.kokoro-summary-content li{margin-bottom:5px}.kokoro-summary-content p{margin:0 0 10px}.kokoro-summary-overlay{display:none}@keyframes kokoro-pulse{0%,to{opacity:.35}50%{opacity:1}}.kokoro-updating-dot{vertical-align:middle;background:currentColor;border-radius:50%;width:6px;height:6px;margin-left:4px;animation:1.5s ease-in-out infinite kokoro-pulse;display:inline-block}@media (width>=769px){.kokoro-summary-resize-handle{display:block}.kokoro-chat-col .chat-messages{padding:28px 24px}.kokoro-chat-col .chat-input-area{padding:14px 24px}}@media (width<=768px){.kokoro-summary-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-family:inherit;font-size:.75rem;transition:background .15s,color .15s;display:flex}.kokoro-summary-btn.is-active,.kokoro-summary-btn:hover{background:var(--accent);color:#fff}.kokoro-summary-panel{z-index:300;transition:transform .3s;position:fixed;top:0;bottom:0;right:0;transform:translate(110%);box-shadow:-4px 0 28px #00000024;width:min(85vw,360px)!important}.kokoro-summary-panel.is-open{transform:translate(0)}.kokoro-summary-close{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.kokoro-summary-close:hover{color:#555;background:#f0f0f0}.kokoro-summary-overlay{z-index:299;background:#00000059;display:block;position:fixed;inset:0}}.kokoro-error-banner{color:#dc2626;text-align:center;background:#ef444414;border:1px solid #ef444440;border-radius:10px;flex-shrink:0;margin:8px 12px 0;padding:10px 14px;font-size:.85rem}.kokoro-usage-limit-banner{color:#92400e;background:#f59e0b14;border:1px solid #f59e0b4d;border-radius:10px;flex-shrink:0;align-items:center;gap:8px;margin:8px 12px 0;padding:10px 14px;font-size:.85rem;display:flex}.kokoro-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;display:flex}.kokoro-usage-limit-banner__message{font-size:.85rem;font-weight:600}.kokoro-usage-limit-banner__reset{color:#a16207;font-size:.78rem}.kokoro-usage-limit-banner__link{color:#92400e;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f59e0b80;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:.78rem;transition:background .15s}.kokoro-usage-limit-banner__link:hover{background:#f59e0b1f}.talkmate-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.talkmate-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.talkmate-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.talkmate-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.talkmate-back-btn:hover{color:#333;background:#f0f0f0}.talkmate-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.talkmate-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.talkmate-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.talkmate-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.talkmate-style-btn{cursor:pointer;color:#888;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.talkmate-style-btn:hover{color:#333;background:#f0f0f0}.talkmate-style-btn:disabled{opacity:.4;cursor:default}.talkmate-memo-btn{display:none}.talkmate-body{flex:1;display:flex;overflow:hidden}.talkmate-chat-col{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.talkmate-memo-panel{width:var(--panel-width,380px);background:#fff;border-left:1px solid #00000012;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.talkmate-memo-resize-handle{cursor:col-resize;z-index:10;background:0 0;width:6px;transition:background .15s;display:none;position:absolute;top:0;bottom:0;left:-3px}.talkmate-memo-resize-handle:hover,.talkmate-memo-resize-handle:active{background:var(--accent);opacity:.4}.talkmate-memo-header{border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 13px;display:flex}.talkmate-memo-title{color:#999;text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:700}.talkmate-memo-close{display:none}.talkmate-memo-body{flex:1;padding:20px 16px;overflow-y:auto}.talkmate-memo-empty{text-align:center;color:#ddd;flex-direction:column;align-items:center;gap:14px;padding:56px 16px;display:flex}.talkmate-memo-empty p{color:silver;margin:0;font-size:.82rem;line-height:1.75}.talkmate-memo-content{color:#444;font-size:.85rem;line-height:1.8}.talkmate-memo-content h2{color:#222;border-bottom:1px solid #00000012;margin:0 0 14px;padding-bottom:8px;font-size:.95rem;font-weight:700}.talkmate-memo-content h3{color:#888;text-transform:uppercase;letter-spacing:.05em;margin:18px 0 6px;font-size:.75rem;font-weight:700}.talkmate-memo-content ul{margin:0 0 10px;padding-left:18px}.talkmate-memo-content li{margin-bottom:5px}.talkmate-memo-content p{margin:0 0 10px}.talkmate-memo-overlay{display:none}@keyframes talkmate-pulse{0%,to{opacity:.35}50%{opacity:1}}.talkmate-updating-dot{vertical-align:middle;background:currentColor;border-radius:50%;width:6px;height:6px;margin-left:4px;animation:1.5s ease-in-out infinite talkmate-pulse;display:inline-block}.talkmate-error-banner{color:#dc2626;text-align:center;background:#ef444414;border:1px solid #ef444440;border-radius:10px;flex-shrink:0;margin:8px 12px 0;padding:10px 14px;font-size:.85rem}.talkmate-usage-limit-banner{color:#92400e;background:#f59e0b14;border:1px solid #f59e0b4d;border-radius:10px;flex-shrink:0;align-items:center;gap:8px;margin:8px 12px 0;padding:10px 14px;font-size:.85rem;display:flex}.talkmate-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;display:flex}.talkmate-usage-limit-banner__message{font-size:.85rem;font-weight:600}.talkmate-usage-limit-banner__reset{color:#a16207;font-size:.78rem}.talkmate-usage-limit-banner__link{color:#92400e;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f59e0b80;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:.78rem;transition:background .15s}.talkmate-usage-limit-banner__link:hover{background:#f59e0b1f}.talkmate-style-overlay{z-index:400;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.talkmate-style-modal{background:#fff;border-radius:16px;flex-direction:column;gap:18px;width:100%;max-width:420px;max-height:calc(100dvh - 40px);padding:20px;display:flex;overflow-y:auto}.talkmate-style-head{align-items:flex-start;gap:12px;display:flex}.talkmate-style-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:44px;height:44px}.talkmate-style-head-text{flex:1;min-width:0}.talkmate-style-title{color:#1a1a2e;margin:0 0 4px;font-size:1rem;font-weight:700}.talkmate-style-lead{color:#888;margin:0;font-size:.78rem;line-height:1.6}.talkmate-style-close{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.talkmate-style-close:hover{color:#555;background:#f0f0f0}.talkmate-style-section{flex-direction:column;gap:8px;display:flex}.talkmate-style-section-label{color:#999;letter-spacing:.05em;font-size:.72rem;font-weight:700}.talkmate-style-options{flex-direction:column;gap:8px;display:flex}.talkmate-style-option{text-align:left;cursor:pointer;background:#fff;border:1.5px solid #0000001f;border-radius:10px;flex-direction:column;align-items:flex-start;gap:3px;padding:10px 14px;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.talkmate-style-option:hover:not(:disabled){border-color:var(--accent)}.talkmate-style-option:disabled{cursor:default}.talkmate-style-option.is-selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, #fff)}.talkmate-style-option-label{color:#333;font-size:.88rem;font-weight:600}.talkmate-style-option.is-selected .talkmate-style-option-label{color:var(--accent)}.talkmate-style-option-desc{color:#999;font-size:.75rem}.talkmate-style-error{color:#dc2626;text-align:center;margin:0;font-size:.8rem}.talkmate-style-save{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:12px;font-family:inherit;font-size:.92rem;font-weight:700;transition:opacity .15s}.talkmate-style-save:hover{opacity:.88}.talkmate-style-save:disabled{opacity:.55;cursor:default}@media (width>=769px){.talkmate-memo-resize-handle{display:block}.talkmate-chat-col .chat-messages{padding:28px 24px}.talkmate-chat-col .chat-input-area{padding:14px 24px}}@media (width<=768px){.talkmate-memo-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-family:inherit;font-size:.75rem;transition:background .15s,color .15s;display:flex}.talkmate-memo-btn.is-active,.talkmate-memo-btn:hover{background:var(--accent);color:#fff}.talkmate-memo-panel{z-index:300;transition:transform .3s;position:fixed;top:0;bottom:0;right:0;transform:translate(110%);box-shadow:-4px 0 28px #00000024;width:min(85vw,360px)!important}.talkmate-memo-panel.is-open{transform:translate(0)}.talkmate-memo-close{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.talkmate-memo-close:hover{color:#555;background:#f0f0f0}.talkmate-memo-overlay{z-index:299;background:#00000059;display:block;position:fixed;inset:0}}.resume-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.resume-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.resume-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.resume-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.resume-back-btn:hover{color:#333;background:#f0f0f0}.resume-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.resume-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.resume-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.resume-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.resume-panel-btn{display:none}.resume-body{flex:1;display:flex;overflow:hidden}.resume-chat-col{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.resume-panel{width:var(--panel-width,480px);background:#fff;border-left:1px solid #00000012;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.resume-panel-resize-handle{cursor:col-resize;z-index:10;background:0 0;width:6px;transition:background .15s;display:none;position:absolute;top:0;bottom:0;left:-3px}.resume-panel-resize-handle:hover,.resume-panel-resize-handle:active{background:var(--accent);opacity:.4}.resume-panel-header{border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.resume-panel-title{color:#999;text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:700}.resume-panel-header-actions{align-items:center;gap:6px;display:flex}.resume-report-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;font-family:inherit;font-size:.72rem;font-weight:600;transition:background .15s,color .15s;display:flex}.resume-report-btn:hover{background:var(--accent);color:#fff}.resume-panel-close{display:none}.resume-panel-body{flex:1;padding:4px 0;overflow-y:auto}.resume-section{border-bottom:1px solid #0000000d;padding:14px 16px}.resume-section:last-child{border-bottom:none}.resume-section-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.resume-section-label{color:#999;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:700}.resume-section-actions{align-items:center;gap:2px;display:flex}.resume-section-ai-btn,.resume-section-edit-btn,.resume-section-save-btn,.resume-section-cancel-btn{cursor:pointer;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;width:26px;height:26px;transition:background .15s,color .15s;display:flex}.resume-section-ai-btn{color:var(--accent)}.resume-section-ai-btn:hover{background:#eef3ff}.resume-section-edit-btn{color:#ccc}.resume-section-edit-btn:hover:not(:disabled){color:#555;background:#f0f0f0}.resume-section-edit-btn:disabled{opacity:.3;cursor:not-allowed}.resume-section-save-btn{color:#4ade80}.resume-section-save-btn:hover{background:#f0fdf4}.resume-section-cancel-btn{color:#ccc}.resume-section-cancel-btn:hover{color:#555;background:#f0f0f0}.resume-section-content{color:#444;font-size:.83rem;line-height:1.75}.resume-section-content p{margin:0 0 4px}.resume-section-content ul{margin:0 0 4px;padding-left:16px}.resume-section-content li{margin-bottom:3px}.resume-section-content strong{color:#1a1a2e;font-weight:700}.resume-rich-editor-content .tiptap p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:#aaa;pointer-events:none;float:left;height:0}.resume-report-overlay{z-index:400;background:#00000080;justify-content:center;align-items:flex-start;padding:32px 16px 48px;display:flex;position:fixed;inset:0;overflow-y:auto}.resume-report-inner{background:#fff;border-radius:12px;width:100%;max-width:680px;overflow:hidden;box-shadow:0 20px 60px #0003}.resume-report-toolbar{z-index:1;background:#fafafa;border-bottom:1px solid #00000012;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;position:sticky;top:0}.resume-report-lang-tabs{background:#efefef;border-radius:8px;gap:2px;padding:2px;display:flex}.resume-report-lang-tab{color:#888;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:5px 16px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s,color .15s}.resume-report-lang-tab.is-active{color:var(--accent);background:#fff;box-shadow:0 1px 3px #0000001a}.resume-report-toolbar-actions{align-items:center;gap:8px;display:flex}.resume-report-print-btn{color:#555;cursor:pointer;background:#fff;border:1px solid #0000001f;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s;display:flex}.resume-report-print-btn:hover{background:#f0f0f0}.resume-report-close{color:#555;cursor:pointer;background:#fff;border:1px solid #0000001f;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s;display:flex}.resume-report-close:hover{background:#f0f0f0}.resume-report-body{padding:28px 32px 40px}.resume-report-section{margin-bottom:24px}.resume-report-section:last-child{margin-bottom:0}.resume-report-section-label{color:var(--accent);text-transform:uppercase;letter-spacing:.1em;border-bottom:1.5px solid var(--accent);opacity:.8;margin:0 0 8px;padding-bottom:6px;font-size:.65rem;font-weight:700}.resume-report-section-content{color:#333;font-size:.88rem;line-height:1.85}.resume-report-section-content p{margin:0 0 6px}.resume-report-section-content ul{margin:0 0 6px;padding-left:18px}.resume-report-section-content li{margin-bottom:4px}.resume-report-section-content strong{color:#111;font-weight:700}.resume-updating-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:1.2s ease-in-out infinite resume-pulse;display:inline-block}.resume-translating-dot{vertical-align:middle;background:currentColor;border-radius:50%;width:5px;height:5px;margin-left:4px;animation:1.2s ease-in-out infinite resume-pulse;display:inline-block}@keyframes resume-pulse{0%,to{opacity:1}50%{opacity:.3}}.resume-panel-empty{color:#ccc;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;display:flex}.resume-panel-empty p{color:#bbb;font-size:.82rem;line-height:1.6}.resume-section-placeholder{color:#ccc;pointer-events:none;-webkit-user-select:none;user-select:none}.resume-section-placeholder p,.resume-section-placeholder li,.resume-section-placeholder strong{color:#ccc;font-size:.78rem;font-weight:400}.resume-usage-limit-banner{color:#b45309;background:#fff8f0;border-bottom:1px solid #fde8cc;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;font-size:.82rem;display:flex}.resume-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;display:flex}.resume-usage-limit-banner__message{font-weight:600}.resume-usage-limit-banner__reset{opacity:.8;font-size:.75rem}.resume-usage-limit-banner__link{color:#b45309;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #b45309;border-radius:5px;padding:4px 10px;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .15s}.resume-usage-limit-banner__link:hover{background:#fef3c7}.resume-error-banner{color:#b91c1c;background:#fff0f0;border-bottom:1px solid #fecaca;flex-shrink:0;padding:10px 16px;font-size:.82rem}.resume-report-translating{text-align:center;color:#aaa;padding:40px 0;font-size:.85rem}.resume-report-btn:disabled{opacity:.4;cursor:not-allowed}.resume-panel-overlay{display:none}@media (width>=769px){.resume-panel-resize-handle{display:block}.resume-chat-col .chat-messages{padding:28px 24px}.resume-chat-col .chat-input-area{padding:14px 24px}}@media (width<=768px){.resume-panel-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-family:inherit;font-size:.75rem;transition:background .15s,color .15s;display:flex}.resume-panel-btn.is-active,.resume-panel-btn:hover{background:var(--accent);color:#fff}.resume-panel{z-index:300;transition:transform .3s;position:fixed;top:0;bottom:0;right:0;transform:translate(110%);box-shadow:-4px 0 28px #00000024;width:min(90vw,400px)!important}.resume-panel.is-open{transform:translate(0)}.resume-panel-close{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.resume-panel-close:hover{color:#555;background:#f0f0f0}.resume-panel-overlay{z-index:299;background:#00000059;display:block;position:fixed;inset:0}.resume-report-body{padding:20px 20px 32px}}@media print{body,.resume-page.report-open{background:#fff!important}.resume-page.report-open .resume-header,.resume-page.report-open .resume-body{display:none!important}.resume-page.report-open .resume-report-overlay{background:0 0!important;padding:0!important;display:block!important;position:static!important;overflow:visible!important}.resume-page.report-open .resume-report-inner{width:100%!important;max-width:100%!important;height:auto!important;max-height:none!important;box-shadow:none!important;border-radius:0!important;overflow:visible!important}.resume-page.report-open .resume-report-toolbar{display:none!important}.resume-page.report-open .resume-report-body{max-height:none!important;padding:0!important;overflow:visible!important}}.interview-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.interview-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.interview-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.interview-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.interview-back-btn:hover{color:#333;background:#f0f0f0}.interview-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.interview-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.interview-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.interview-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.interview-panel-btn{display:none}.interview-body{flex:1;display:flex;overflow:hidden}.interview-chat-col{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.interview-panel{width:var(--panel-width,480px);background:#fff;border-left:1px solid #00000012;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.interview-panel-resize-handle{cursor:col-resize;z-index:10;background:0 0;width:6px;transition:background .15s;display:none;position:absolute;top:0;bottom:0;left:-3px}.interview-panel-resize-handle:hover,.interview-panel-resize-handle:active{background:var(--accent);opacity:.4}.interview-panel-header{border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.interview-panel-title{color:#999;text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:700}.interview-panel-header-actions{align-items:center;gap:6px;display:flex}.interview-preview-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;font-family:inherit;font-size:.72rem;font-weight:600;transition:background .15s,color .15s;display:flex}.interview-preview-btn:hover{background:var(--accent);color:#fff}.interview-panel-close{display:none}.interview-panel-body{flex:1;padding:4px 0;overflow-y:auto}.interview-section{border-bottom:1px solid #0000000d;padding:14px 16px}.interview-section:last-child{border-bottom:none}.interview-section-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.interview-section-label{color:#999;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:700}.interview-section-actions{align-items:center;gap:2px;display:flex}.interview-section-edit-btn,.interview-section-save-btn,.interview-section-cancel-btn{cursor:pointer;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;width:26px;height:26px;transition:background .15s,color .15s;display:flex}.interview-section-edit-btn{color:#ccc}.interview-section-edit-btn:hover{color:#555;background:#f0f0f0}.interview-section-save-btn{color:#4ade80}.interview-section-save-btn:hover{background:#f0fdf4}.interview-section-cancel-btn{color:#ccc}.interview-section-cancel-btn:hover{color:#555;background:#f0f0f0}.interview-section-content{color:#444;font-size:.83rem;line-height:1.75}.interview-section-content p{margin:0 0 4px}.interview-section-content ul{margin:0 0 4px;padding-left:16px}.interview-section-content li{margin-bottom:3px}.interview-section-content strong{color:#1a1a2e;font-weight:700}.interview-preview-overlay{z-index:400;background:#00000080;justify-content:center;align-items:flex-start;padding:32px 16px 48px;display:flex;position:fixed;inset:0;overflow-y:auto}.interview-preview-inner{background:#fff;border-radius:12px;width:100%;max-width:680px;overflow:hidden;box-shadow:0 20px 60px #0003}.interview-preview-toolbar{z-index:1;background:#fafafa;border-bottom:1px solid #00000012;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;position:sticky;top:0}.interview-preview-lang-tabs{background:#efefef;border-radius:8px;gap:2px;padding:2px;display:flex}.interview-preview-lang-tab{color:#888;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:5px 16px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s,color .15s}.interview-preview-lang-tab.is-active{color:var(--accent);background:#fff;box-shadow:0 1px 3px #0000001a}.interview-preview-close{color:#555;cursor:pointer;background:#fff;border:1px solid #0000001f;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s;display:flex}.interview-preview-close:hover{background:#f0f0f0}.interview-preview-body{padding:28px 32px 40px}.interview-preview-section{margin-bottom:24px}.interview-preview-section:last-child{margin-bottom:0}.interview-preview-section-label{color:var(--accent);text-transform:uppercase;letter-spacing:.1em;border-bottom:1.5px solid var(--accent);opacity:.8;margin:0 0 8px;padding-bottom:6px;font-size:.65rem;font-weight:700}.interview-preview-section-content{color:#333;font-size:.88rem;line-height:1.85}.interview-preview-section-content p{margin:0 0 6px}.interview-preview-section-content ul{margin:0 0 6px;padding-left:18px}.interview-preview-section-content li{margin-bottom:4px}.interview-preview-section-content strong{color:#111;font-weight:700}.interview-panel-overlay{display:none}.interview-updating-dot,.interview-translating-dot{background:var(--accent);vertical-align:middle;border-radius:50%;width:6px;height:6px;margin-left:4px;animation:1.2s ease-in-out infinite interview-pulse;display:inline-block}@keyframes interview-pulse{0%,to{opacity:1}50%{opacity:.3}}.interview-section-placeholder{opacity:.35;pointer-events:none}.interview-section-placeholder p,.interview-section-placeholder li{color:#666;font-size:.8rem}.interview-error-banner{color:#cf1322;background:#fff1f0;border-bottom:1px solid #ffa39e;flex-shrink:0;padding:10px 16px;font-size:.82rem}.interview-usage-limit-banner{color:#874d00;background:#fff7e6;border-bottom:1px solid #ffd591;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;font-size:.82rem;display:flex}.interview-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;display:flex}.interview-usage-limit-banner__message{font-weight:600}.interview-usage-limit-banner__reset{opacity:.8;font-size:.75rem}.interview-usage-limit-banner__link{color:#fa8c16;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #fa8c16;border-radius:5px;padding:4px 10px;font-family:inherit;font-size:.75rem;transition:background .15s,color .15s}.interview-usage-limit-banner__link:hover{color:#fff;background:#fa8c16}.interview-preview-translating{text-align:center;color:#999;padding:40px;font-size:.88rem}.interview-preview-toolbar-actions{align-items:center;gap:8px;display:flex}.interview-preview-print-btn{color:#555;cursor:pointer;background:#fff;border:1px solid #0000001f;border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-family:inherit;font-size:.78rem;font-weight:600;transition:background .15s;display:flex}.interview-preview-print-btn:hover{background:#f0f0f0}.interview-star-editor{flex-direction:column;gap:8px;display:flex}.interview-star-field{flex-direction:column;gap:3px;display:flex}.interview-star-label{color:var(--accent);letter-spacing:.06em;text-transform:uppercase;font-size:.68rem;font-weight:700}.interview-star-textarea{color:#333;resize:vertical;box-sizing:border-box;border:1.5px solid #0000001f;border-radius:5px;outline:none;width:100%;padding:6px 8px;font-family:inherit;font-size:.81rem;line-height:1.6;transition:border-color .15s}.interview-star-textarea:focus{border-color:var(--accent)}.interview-star-text{color:#222;white-space:pre-wrap;word-break:break-word;margin:0;font-size:.82rem;line-height:1.55}.interview-star-display{gap:10px}.resume-rich-editor{border:1.5px solid var(--accent);background:#fafeff;border-radius:6px;overflow:hidden}.resume-rich-editor-toolbar{background:#f5f5f5;border-bottom:1px solid #00000012;gap:2px;padding:4px 6px;display:flex}.resume-rich-editor-btn{color:#666;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:26px;height:26px;transition:background .15s,color .15s;display:flex}.resume-rich-editor-btn:hover{color:#333;background:#e8e8e8}.resume-rich-editor-btn.is-active{background:var(--accent);color:#fff}.resume-rich-editor-content{color:#333;outline:none;min-height:100px;padding:8px 10px;font-family:inherit;font-size:.82rem;line-height:1.65}.resume-rich-editor-content .tiptap{outline:none;min-height:90px}.resume-rich-editor-content .tiptap p{margin:0 0 4px}.resume-rich-editor-content .tiptap ul{margin:0 0 4px;padding-left:18px}.resume-rich-editor-content .tiptap li{margin-bottom:2px}.resume-rich-editor-content .tiptap strong{color:#111;font-weight:700}@media print{body,.interview-page.preview-open{background:#fff!important}.interview-page.preview-open .interview-header,.interview-page.preview-open .interview-body{display:none!important}.interview-page.preview-open .interview-preview-overlay{background:0 0!important;padding:0!important;display:block!important;position:static!important;overflow:visible!important}.interview-page.preview-open .interview-preview-inner{width:100%!important;max-width:100%!important;height:auto!important;box-shadow:none!important;border-radius:0!important;overflow:visible!important}.interview-page.preview-open .interview-preview-toolbar{display:none!important}.interview-page.preview-open .interview-preview-body{padding:0!important;overflow:visible!important}}@media (width>=769px){.interview-panel-resize-handle{display:block}.interview-chat-col .chat-messages{padding:28px 24px}.interview-chat-col .chat-input-area{padding:14px 24px}}@media (width<=768px){.interview-panel-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-family:inherit;font-size:.75rem;transition:background .15s,color .15s;display:flex}.interview-panel-btn.is-active,.interview-panel-btn:hover{background:var(--accent);color:#fff}.interview-panel{z-index:300;transition:transform .3s;position:fixed;top:0;bottom:0;right:0;transform:translate(110%);box-shadow:-4px 0 28px #00000024;width:min(90vw,400px)!important}.interview-panel.is-open{transform:translate(0)}.interview-panel-close{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.interview-panel-close:hover{color:#555;background:#f0f0f0}.interview-panel-overlay{z-index:299;background:#00000059;display:block;position:fixed;inset:0}.interview-preview-body{padding:20px 20px 32px}}.teacher-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.teacher-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.teacher-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.teacher-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.teacher-back-btn:hover{color:#333;background:#f0f0f0}.teacher-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.teacher-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.teacher-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.teacher-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.teacher-lang-btn{cursor:pointer;color:#888;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.teacher-lang-btn:hover{color:#333;background:#f0f0f0}.teacher-lang-btn:disabled{opacity:.4;cursor:default}.teacher-log-btn{display:none}.teacher-body{flex:1;display:flex;overflow:hidden}.teacher-chat-col{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.teacher-log-panel{width:var(--panel-width,300px);background:#fff;border-left:1px solid #00000012;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.teacher-log-resize-handle{cursor:col-resize;z-index:10;background:0 0;width:6px;transition:background .15s;display:none;position:absolute;top:0;bottom:0;left:-3px}.teacher-log-resize-handle:hover,.teacher-log-resize-handle:active{background:var(--accent);opacity:.4}.teacher-log-header{border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 13px;display:flex}.teacher-log-title{color:#999;text-transform:uppercase;letter-spacing:.07em;font-size:.72rem;font-weight:700}.teacher-log-close{display:none}.teacher-log-body{flex-direction:column;flex:1;gap:20px;padding:20px 16px;display:flex;overflow-y:auto}.teacher-log-streak{background:#fff5ee;border:1px solid #ff8c424d;border-radius:10px;align-items:center;gap:8px;padding:12px 14px;display:flex}.teacher-log-streak-fire{font-size:1.4rem;line-height:1}.teacher-log-streak-count{color:#c05a00;font-size:.88rem;font-weight:700}.teacher-log-stats{background:#f7f8fa;border-radius:10px;align-items:center;padding:14px 0;display:flex}.teacher-log-stat{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.teacher-log-stat-label{color:#aaa;text-transform:uppercase;letter-spacing:.05em;font-size:.68rem;font-weight:600}.teacher-log-stat-value{color:#1a1a2e;font-size:1.9rem;font-weight:800;line-height:1}.teacher-log-stat-value small{color:#aaa;margin-left:2px;font-size:.7rem;font-weight:500}.teacher-log-stat-divider{background:#00000014;flex-shrink:0;width:1px;height:36px}.teacher-log-calendar-section{flex-direction:column;gap:10px;display:flex}.teacher-log-calendar-label{color:#aaa;text-transform:uppercase;letter-spacing:.07em;font-size:.68rem;font-weight:700}.teacher-log-calendar{flex-direction:column;gap:5px;display:flex}.teacher-log-calendar-dow{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:2px;display:grid}.teacher-log-calendar-dow span{color:#ccc;text-align:center;font-size:.6rem;font-weight:600}.teacher-log-calendar-week{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.teacher-log-calendar-dot{aspect-ratio:1;background:#ebebeb;border-radius:50%;display:block}.teacher-log-calendar-dot.is-empty{background:0 0}.teacher-log-calendar-dot.is-studied{background:var(--accent)}.teacher-log-calendar-dot.is-today{outline:2px solid var(--accent);outline-offset:1px}.teacher-log-calendar-dot.is-today.is-studied{outline-color:#b8860b}.teacher-log-note{color:#ccc;text-align:center;margin:0;font-size:.65rem}.teacher-error-banner{color:#dc2626;text-align:center;background:#ef444414;border:1px solid #ef444440;border-radius:10px;flex-shrink:0;margin:8px 12px 0;padding:10px 14px;font-size:.85rem}.teacher-usage-limit-banner{color:#92400e;background:#f59e0b14;border:1px solid #f59e0b4d;border-radius:10px;flex-shrink:0;align-items:center;gap:8px;margin:8px 12px 0;padding:10px 14px;font-size:.85rem;display:flex}.teacher-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;display:flex}.teacher-usage-limit-banner__message{font-size:.85rem;font-weight:600}.teacher-usage-limit-banner__reset{color:#a16207;font-size:.78rem}.teacher-usage-limit-banner__link{color:#92400e;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f59e0b80;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:.78rem;transition:background .15s}.teacher-usage-limit-banner__link:hover{background:#f59e0b1f}.teacher-log-overlay{display:none}.teacher-lang-overlay{z-index:400;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.teacher-lang-modal{background:#fff;border-radius:16px;flex-direction:column;gap:14px;width:100%;max-width:340px;max-height:calc(100dvh - 40px);padding:20px;display:flex;overflow-y:auto}.teacher-lang-head{justify-content:space-between;align-items:center;display:flex}.teacher-lang-title{color:#1a1a2e;margin:0;font-size:1rem;font-weight:700}.teacher-lang-close{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.teacher-lang-close:hover{color:#555;background:#f0f0f0}.teacher-lang-lead{color:#888;margin:0;font-size:.78rem;line-height:1.6}.teacher-lang-options{flex-direction:column;gap:8px;display:flex}.teacher-lang-option{color:#333;text-align:left;cursor:pointer;background:#fff;border:1.5px solid #0000001f;border-radius:10px;justify-content:space-between;align-items:center;padding:11px 14px;font-family:inherit;font-size:.9rem;transition:border-color .15s,background .15s;display:flex}.teacher-lang-option:hover:not(:disabled){border-color:var(--accent)}.teacher-lang-option:disabled{cursor:default}.teacher-lang-option.is-selected{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, #fff);color:var(--accent);font-weight:600}.teacher-lang-error{color:#dc2626;text-align:center;margin:0;font-size:.8rem}@media (width>=769px){.teacher-log-resize-handle{display:block}.teacher-chat-col .chat-messages{padding:28px 24px}.teacher-chat-col .chat-input-area{padding:14px 24px}}@media (width<=768px){.teacher-log-btn{border:1.5px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 12px;font-family:inherit;font-size:.75rem;transition:background .15s,color .15s;display:flex}.teacher-log-btn.is-active,.teacher-log-btn:hover{background:var(--accent);color:#fff}.teacher-log-panel{z-index:300;transition:transform .3s;position:fixed;top:0;bottom:0;right:0;transform:translate(110%);box-shadow:-4px 0 28px #00000024;width:min(85vw,340px)!important}.teacher-log-panel.is-open{transform:translate(0)}.teacher-log-close{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.teacher-log-close:hover{color:#555;background:#f0f0f0}.teacher-log-overlay{z-index:299;background:#00000059;display:block;position:fixed;inset:0}}.translator-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.translator-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.translator-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.translator-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.translator-back-btn:hover{color:#333;background:#f0f0f0}.translator-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.translator-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.translator-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.translator-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.translator-error-banner{color:#dc2626;text-align:center;background:#ef444414;border:1px solid #ef444440;border-radius:10px;flex-shrink:0;margin:8px 12px 0;padding:10px 14px;font-size:.85rem}.translator-usage-limit-banner{color:#92400e;background:#f59e0b14;border:1px solid #f59e0b4d;border-radius:10px;flex-shrink:0;align-items:center;gap:8px;margin:8px 12px 0;padding:10px 14px;font-size:.85rem;display:flex}.translator-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;display:flex}.translator-usage-limit-banner__message{font-size:.85rem;font-weight:600}.translator-usage-limit-banner__reset{color:#a16207;font-size:.78rem}.translator-usage-limit-banner__link{color:#92400e;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f59e0b80;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:.78rem;transition:background .15s}.translator-usage-limit-banner__link:hover{background:#f59e0b1f}.translator-feed{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.translator-initializing{color:#aaa;justify-content:center;align-items:center;gap:8px;padding:24px;font-size:.85rem;display:flex}.translator-date-separator{align-items:center;gap:10px;margin:6px 0;display:flex}.translator-date-separator:before,.translator-date-separator:after{content:"";background:#00000014;flex:1;height:1px}.translator-date-separator span{color:#bbb;white-space:nowrap;padding:0 4px;font-size:.68rem}.translator-load-more-sentinel{color:#aaa;justify-content:center;align-items:center;gap:8px;min-height:32px;padding:16px;font-size:.8rem;display:flex}.translator-empty{text-align:center;color:#ccc;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:64px 20px;display:flex}.translator-empty p{color:#bbb;margin:0;font-size:.88rem;line-height:1.7}.translator-card{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 6px #00000014}.translator-card--loading{color:#aaa;align-items:center;gap:10px;padding:16px 20px;font-size:.88rem;display:flex}.translator-spinner{color:var(--accent);opacity:.7;flex-shrink:0;animation:1s linear infinite translator-spin}@keyframes translator-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.translator-card-head{justify-content:space-between;align-items:center;gap:8px;padding:12px 16px 10px;display:flex}.translator-card-original{color:#999;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.82rem;font-style:italic;overflow:hidden}.translator-card-head-meta{flex-shrink:0;align-items:center;gap:6px;display:flex}.translator-card-lang{color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);border-radius:10px;padding:2px 7px;font-size:.65rem;font-weight:600}.translator-card-time{color:#ccc;font-size:.65rem}.translator-card-image-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.translator-card-image-thumb-mock{color:#bbb;background:#f0f0f0;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.translator-card-divider{background:#0000000d;height:1px}.translator-card-translation{color:#1a1a2e;word-break:break-word;padding:12px 16px 14px;font-size:.95rem;line-height:1.65}.translator-card-translation p{margin:0 0 6px}.translator-card-translation p:last-child{margin-bottom:0}.translator-card-translation ul,.translator-card-translation ol{margin:0;padding-left:18px}.translator-card-translation li{margin-bottom:4px}.translator-card-translation li:last-child{margin-bottom:0}.translator-card-translation strong{color:#1a1a2e;font-weight:700}.translator-card-comment{align-items:center;gap:10px;padding:10px 16px 14px;display:flex}.translator-card-comment-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:32px;height:32px}.translator-card-comment-text{color:#888;word-break:break-word;margin:0;font-size:.82rem;font-style:italic;line-height:1.55}.translator-footer{background:#fff;border-top:1px solid #0000000f;flex-shrink:0;padding:12px 16px 16px}.translator-footer-inner{flex-direction:column;gap:8px;max-width:720px;margin:0 auto;display:flex}.translator-lang-bar{background:#f9f9f9;border:1px solid #ebebeb;border-radius:10px;align-items:center;gap:10px;padding:9px 14px;display:flex}.translator-lang-fixed{color:#555;white-space:nowrap;font-size:.85rem;font-weight:600}.translator-lang-arrow{color:var(--accent);opacity:.7;font-size:1rem}.translator-lang-select-wrapper{flex:1;align-items:center;display:flex;position:relative}.translator-lang-select{appearance:none;color:var(--accent);cursor:pointer;background:0 0;border:none;outline:none;width:100%;padding-right:18px;font-family:inherit;font-size:.85rem;font-weight:600}.translator-lang-chevron{pointer-events:none;color:var(--accent);opacity:.6;position:absolute;right:0}.translator-image-preview{background:#f5f5f5;border:1.5px solid #e8e8e8;border-radius:10px;align-items:center;gap:10px;padding:8px 12px;display:flex}.translator-preview-thumb{object-fit:cover;border-radius:6px;flex-shrink:0;width:40px;height:40px}.translator-preview-name{color:#666;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.8rem;overflow:hidden}.translator-preview-remove{cursor:pointer;color:#aaa;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:background .15s,color .15s;display:flex}.translator-preview-remove:hover{color:#555;background:#eee}.translator-input-box{background:#fff;border:1.5px solid #e0e0e0;border-radius:12px;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.translator-input-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent)}.translator-textarea{resize:none;color:#333;box-sizing:border-box;background:0 0;border:none;outline:none;width:100%;min-height:24px;max-height:120px;font-family:inherit;font-size:.9rem;line-height:1.6;display:block}.translator-textarea::placeholder{color:#bbb}.translator-textarea:disabled{opacity:.5}.translator-actions{justify-content:space-between;align-items:center;display:flex}.translator-image-btn{color:#888;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:.78rem;transition:border-color .15s,color .15s;display:flex}.translator-image-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.translator-image-btn:disabled{opacity:.4;cursor:not-allowed}.translator-submit-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:20px;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:.85rem;font-weight:600;transition:opacity .15s,transform .1s;display:flex}.translator-submit-btn:disabled{opacity:.35;cursor:not-allowed}.translator-submit-btn:not(:disabled):hover{opacity:.85}.translator-submit-btn:not(:disabled):active{transform:scale(.97)}@media (width>=769px){.translator-feed{padding:24px}.translator-card{width:100%;max-width:680px;margin:0 auto}.translator-empty{max-width:400px;margin:0 auto}}@media (width<=768px){.translator-footer{padding-bottom:max(16px, env(safe-area-inset-bottom))}}.travel-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.travel-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.travel-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.travel-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.travel-back-btn:hover{color:#333;background:#f0f0f0}.travel-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.travel-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.travel-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.travel-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.travel-feed{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:16px;min-height:0;padding:16px;display:flex;overflow-y:auto}.travel-empty{text-align:center;color:#ccc;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:64px 20px;display:flex}.travel-empty p{color:#bbb;margin:0;font-size:.88rem;line-height:1.7}.travel-generating{color:#aaa;background:#fff;border-radius:14px;align-items:center;gap:10px;padding:16px 20px;font-size:.88rem;display:flex;box-shadow:0 1px 6px #00000014}.travel-date-separator{align-items:center;gap:10px;margin:6px 0;display:flex}.travel-date-separator:before,.travel-date-separator:after{content:"";background:#00000014;flex:1;height:1px}.travel-date-separator span{color:#bbb;white-space:nowrap;padding:0 4px;font-size:.68rem}.travel-initializing{color:#aaa;justify-content:center;align-items:center;gap:8px;padding:24px;font-size:.85rem;display:flex}.travel-load-more-sentinel{color:#aaa;justify-content:center;align-items:center;gap:8px;min-height:32px;padding:16px;font-size:.8rem;display:flex}.travel-spinner{color:var(--accent);opacity:.7;flex-shrink:0;animation:1s linear infinite travel-spin}@keyframes travel-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.travel-error-banner{color:#dc2626;text-align:center;background:#ef444414;border:1px solid #ef444440;border-radius:10px;flex-shrink:0;margin:8px 12px 0;padding:10px 14px;font-size:.85rem}.travel-usage-limit-banner{color:#92400e;background:#f59e0b14;border:1px solid #f59e0b4d;border-radius:10px;flex-shrink:0;align-items:center;gap:8px;margin:8px 12px 0;padding:10px 14px;font-size:.85rem;display:flex}.travel-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;display:flex}.travel-usage-limit-banner__message{font-size:.85rem;font-weight:600}.travel-usage-limit-banner__reset{color:#a16207;font-size:.78rem}.travel-usage-limit-banner__link{color:#92400e;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #f59e0b80;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:.78rem;transition:background .15s}.travel-usage-limit-banner__link:hover{background:#f59e0b1f}.travel-plan-card{background:#fff;border-radius:16px;flex-shrink:0;overflow:hidden;box-shadow:0 1px 8px #00000014}.travel-card-group{flex-direction:column;gap:6px;display:flex}.travel-user-input{background:color-mix(in srgb, var(--accent) 14%, #fff);border:1px solid color-mix(in srgb, var(--accent) 20%, #fff);border-radius:14px 14px 4px;align-self:flex-end;max-width:80%;padding:8px 12px;box-shadow:0 1px 3px #0000000a}.travel-user-input-meta{color:#888;margin-bottom:3px;font-size:.65rem;line-height:1.4}.travel-user-input-text{color:#333;white-space:pre-wrap;word-break:break-word;font-size:.85rem;line-height:1.5}.travel-plan-head{border-bottom:1px solid #0000000d;padding:16px 18px 14px}.travel-plan-title-row{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px;display:flex}.travel-plan-title{color:#1a1a2e;font-size:.98rem;font-weight:700;line-height:1.3}.travel-plan-time{color:#ccc;flex-shrink:0;padding-top:2px;font-size:.65rem}.travel-plan-summary{color:#777;margin:0 0 8px;font-size:.82rem;line-height:1.55}.travel-plan-total-days{color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);border-radius:20px;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-block}.travel-stops{flex-direction:column;gap:0;padding:16px 18px;display:flex}.travel-stop-wrapper{flex-direction:column;display:flex}.travel-stop-card{border:1px solid #eee;border-left:3px solid var(--accent);background:#fafafa;border-radius:10px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.travel-stop-head-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.travel-stop-location-group{align-items:center;gap:7px;min-width:0;display:flex}.travel-stop-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:9px;height:9px}.travel-stop-location{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;overflow:hidden}.travel-stop-dates{color:#999;white-space:nowrap;flex-shrink:0;font-size:.72rem}.travel-stop-highlights{flex-wrap:wrap;gap:5px;display:flex}.travel-stop-highlight-chip{color:#555;overflow-wrap:anywhere;background:#fff;border:1px solid #e8e8e8;border-radius:20px;max-width:100%;padding:3px 9px;font-size:.75rem}.travel-stop-meta-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.travel-stop-accommodation{color:#888;font-size:.75rem}.travel-stop-cost-per-day{color:#666;font-size:.75rem;font-weight:600}.travel-stop-notes{color:#999;border-top:1px dashed #eee;margin:0;padding-top:2px;font-size:.75rem;line-height:1.55}.travel-connector{flex-direction:column;align-items:center;gap:0;padding:4px 0;display:flex}.travel-connector-line{background:#ddd;width:1.5px;height:10px}.travel-connector-badge{color:#888;white-space:nowrap;background:#f2f2f2;border-radius:20px;align-items:center;gap:5px;padding:4px 12px;font-size:.72rem;display:flex}.travel-budget-summary{border-top:1px solid #0000000d;padding:14px 18px}.travel-budget-title{color:#999;text-transform:uppercase;letter-spacing:.03em;margin-bottom:10px;font-size:.75rem;font-weight:600;display:block}.travel-budget-grid{grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:10px;display:grid}.travel-budget-item{justify-content:space-between;align-items:center;gap:4px;display:flex}.travel-budget-label{color:#aaa;font-size:.78rem}.travel-budget-value{color:#555;font-size:.82rem;font-weight:600}.travel-budget-total-row{border-top:1px solid #eee;justify-content:space-between;align-items:center;padding-top:10px;display:flex}.travel-budget-total-label{color:#555;font-size:.82rem;font-weight:600}.travel-budget-total-value{color:var(--accent);font-size:1rem;font-weight:700}.travel-warnings{background:#fffbf0;border:1px solid #ffe4a0;border-radius:10px;flex-direction:column;gap:6px;margin:0 18px;padding:10px 14px;display:flex}.travel-warning-item{color:#960;align-items:flex-start;gap:7px;font-size:.78rem;line-height:1.5;display:flex}.travel-warning-item svg{color:#e6a020;flex-shrink:0;margin-top:1px}.travel-advice{flex-direction:column;gap:5px;margin:10px 18px 16px;display:flex}.travel-advice-item{color:#666;align-items:flex-start;gap:7px;font-size:.78rem;line-height:1.55;display:flex}.travel-advice-item svg{color:var(--accent);opacity:.7;flex-shrink:0;margin-top:1px}.travel-footer{-webkit-overflow-scrolling:touch;background:#fff;border-top:1px solid #00000012;flex:none;max-height:52vh;overflow-y:auto}.travel-form{border:0;flex-direction:column;gap:9px;min-width:0;max-width:720px;margin:0 auto;padding:10px 16px 14px;display:flex}.travel-form[disabled]{opacity:.6;pointer-events:none}.travel-form-compact-row{align-items:center;gap:8px;display:flex}.travel-date-icon{color:#bbb;flex-shrink:0}.travel-detail-toggle{color:#888;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #e8e8e8;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:6px 11px;font-family:inherit;font-size:.78rem;transition:border-color .15s,color .15s;display:flex}.travel-detail-toggle.is-open{border-color:var(--accent);color:var(--accent)}.travel-form-detail{background:#f9f9f9;border:1px solid #eee;border-radius:10px;flex-direction:column;gap:9px;padding:10px 14px;display:flex}.travel-form-row{align-items:flex-start;gap:10px;display:flex}.travel-form-field{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.travel-form-field--sm{flex:none;min-width:100px}.travel-form-label{color:#999;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;align-items:center;gap:4px;font-size:.7rem;font-weight:600;display:flex}.travel-input{color:#333;box-sizing:border-box;background:#fff;border:1.5px solid #e8e8e8;border-radius:8px;outline:none;width:100%;padding:7px 10px;font-family:inherit;font-size:.85rem;transition:border-color .15s,box-shadow .15s}.travel-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent)}.travel-input::placeholder{color:#ccc}.travel-input--date{padding:7px 8px;font-size:.8rem}.travel-input--tiny{text-align:center;width:52px;padding:4px 6px;font-size:.82rem}.travel-date-range{align-items:center;gap:4px;display:flex}.travel-date-sep{color:#bbb;flex-shrink:0;font-size:.8rem}.travel-date-error{color:#dc2626;margin:6px 0 0;font-size:.78rem}.travel-budget-input-wrap{align-items:center;gap:4px;display:flex}.travel-budget-unit{color:#999;flex-shrink:0;font-size:.8rem}.travel-chips{flex-wrap:wrap;gap:5px;display:flex}.travel-chip{color:#888;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #e8e8e8;border-radius:20px;align-items:center;gap:4px;padding:5px 11px;font-family:inherit;font-size:.78rem;transition:border-color .15s,color .15s,background .15s;display:flex}.travel-chip.is-active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent)}.travel-textarea{color:#333;box-sizing:border-box;resize:none;background:#fff;border:1.5px solid #e8e8e8;border-radius:8px;outline:none;width:100%;padding:8px 10px;font-family:inherit;font-size:.85rem;line-height:1.55;transition:border-color .15s,box-shadow .15s}.travel-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 12%, transparent)}.travel-textarea::placeholder{color:#ccc}.travel-form-actions{justify-content:flex-end;display:flex}.travel-submit-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:20px;align-items:center;gap:6px;padding:9px 20px;font-family:inherit;font-size:.88rem;font-weight:600;transition:opacity .15s,transform .1s;display:flex}.travel-submit-btn:disabled{opacity:.35;cursor:not-allowed}.travel-submit-btn:not(:disabled):hover{opacity:.85}.travel-submit-btn:not(:disabled):active{transform:scale(.97)}@media (width>=769px){.travel-feed{padding:24px}.travel-card-group,.travel-plan-card,.travel-generating{width:100%;max-width:680px;margin:0 auto}.travel-empty{max-width:400px;margin:0 auto}.travel-footer{max-height:50vh}}@media (width<=768px){.travel-footer{padding-bottom:max(0px, env(safe-area-inset-bottom));max-height:42vh}}.sos-page{background:#f7f7f8;flex-direction:column;height:100dvh;display:flex;overflow:hidden}.sos-header{z-index:10;background:#fff;border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex;position:relative}.sos-header:after{content:"";background:var(--accent);opacity:.7;height:2px;position:absolute;bottom:0;left:0;right:0}.sos-back-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,color .15s;display:flex}.sos-back-btn:hover{color:#333;background:#f0f0f0}.sos-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:38px;height:38px}.sos-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sos-header-name{color:#1a1a2e;white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:700;line-height:1.2;overflow:hidden}.sos-header-label{color:#aaa;white-space:nowrap;font-size:.7rem}.sos-disclaimer{color:#8a6d3b;background:#fff7e6;border-bottom:1px solid #f5e6c8;flex-shrink:0;align-items:flex-start;gap:8px;padding:9px 16px 10px;font-size:.72rem;line-height:1.5;display:flex}.sos-disclaimer-icon{color:#c89a3c;flex-shrink:0;margin-top:1px}.sos-error-bar{color:#c0392b;background:#fdecea;border-bottom:1px solid #f5c6c0;flex-shrink:0;align-items:center;gap:8px;padding:9px 16px;font-size:.75rem;line-height:1.4;display:flex}.sos-top-sentinel{flex-shrink:0;height:1px}.sos-loading-more{color:#bbb;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:.78rem;display:flex}.sos-contact-status{align-items:center;gap:5px;padding-left:20px;font-size:.7rem;line-height:1.4;display:flex}.sos-contact-status--searching{color:#888}.sos-contact-status--failed{color:#c0392b}.sos-footer-fieldset{border:none;min-width:0;margin:0;padding:0}.sos-footer-fieldset[disabled]{opacity:.6}.sos-feed{flex-direction:column;flex:1;gap:14px;padding:16px;display:flex;overflow-y:auto}.sos-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:64px 20px;display:flex}.sos-empty-icon{opacity:.4;font-size:3rem;line-height:1}.sos-empty p{color:#bbb;margin:0;font-size:.88rem;line-height:1.7}.sos-card{background:#fff;border-left:4px solid #0000;border-radius:14px;flex-shrink:0;overflow:hidden;box-shadow:0 1px 6px #00000014}.sos-card--high{border-left-color:#e74c3c}.sos-card--medium{border-left-color:#f39c12}.sos-card--low{border-left-color:#27ae60}.sos-card--loading{color:#aaa;border-left:none;align-items:center;gap:10px;padding:16px 20px;font-size:.88rem;display:flex}.sos-spinner{color:var(--accent);opacity:.7;flex-shrink:0;animation:1s linear infinite sos-spin}@keyframes sos-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sos-card-head{justify-content:space-between;align-items:center;gap:8px;padding:12px 14px 6px;display:flex}.sos-card-head-left{align-items:center;gap:6px;display:flex}.sos-card-head-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.sos-severity{letter-spacing:.02em;border-radius:10px;align-items:center;gap:3px;padding:3px 8px;font-size:.65rem;font-weight:700;display:inline-flex}.sos-severity--high{color:#e74c3c;background:#fdecea}.sos-severity--medium{color:#f39c12;background:#fef9ec}.sos-severity--low{color:#27ae60;background:#eafaf1}.sos-card-category{color:#aaa;background:#f5f5f5;border-radius:10px;padding:2px 8px;font-size:.68rem}.sos-card-time{color:#ccc;font-size:.65rem}.sos-card-title{color:#1a1a2e;padding:2px 14px 4px;font-size:1rem;font-weight:700;line-height:1.3}.sos-card-location{color:#bbb;align-items:center;gap:4px;padding:0 14px 10px;font-size:.7rem;display:flex}.sos-card-divider{background:#0000000d;height:1px;margin:0}.sos-section{padding:12px 14px}.sos-section--contacts{padding-bottom:10px}.sos-section-label{color:var(--accent);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px;font-size:.7rem;font-weight:700}.sos-steps{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.sos-step{align-items:flex-start;gap:10px;display:flex}.sos-step-num{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;font-size:.72rem;font-weight:700;display:flex}.sos-step-text{color:#333;flex:1;font-size:.88rem;line-height:1.55}.sos-phrases{flex-direction:column;gap:8px;display:flex}.sos-phrase-row{background:#fafafa;border:1px solid #f0f0f0;border-radius:10px;align-items:center;gap:10px;padding:9px 10px 9px 12px;display:flex}.sos-phrase-texts{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sos-phrase-ja{color:#999;font-size:.75rem}.sos-phrase-en{color:#1a1a2e;font-size:.9rem;font-weight:600;line-height:1.3}.sos-copy-btn{color:#bbb;cursor:pointer;background:#fff;border:1px solid #e8e8e8;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s,border-color .15s;display:flex}.sos-copy-btn:hover{color:#888;background:#f5f5f5}.sos-copy-btn.is-copied{color:#27ae60;background:#eafaf1;border-color:#b2dfdb}.sos-contacts{flex-direction:column;gap:10px;display:flex}.sos-contact-item{flex-direction:column;gap:5px;padding:2px 0;display:flex}.sos-contact-main{align-items:center;gap:8px;display:flex}.sos-contact-icon{color:var(--accent);flex-shrink:0}.sos-contact-label{color:#888;flex:1;min-width:0;font-size:.78rem}.sos-contact-phone{color:#1a1a2e;letter-spacing:.03em;font-size:.88rem;font-weight:700}.sos-contact-actions{flex-wrap:wrap;gap:6px;padding-left:20px;display:flex}.sos-contact-link{color:#666;background:#f6f6f6;border:1px solid #ececec;border-radius:8px;align-items:center;gap:4px;padding:3px 9px;font-size:.7rem;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.sos-contact-link:hover{background:color-mix(in srgb, var(--accent) 8%, transparent);border-color:var(--accent);color:var(--accent)}.sos-card-group{flex-direction:column;gap:6px;display:flex}.sos-user-input{background:color-mix(in srgb, var(--accent) 14%, #fff);border:1px solid color-mix(in srgb, var(--accent) 20%, #fff);border-radius:14px 14px 4px;align-self:flex-end;max-width:80%;padding:8px 12px;box-shadow:0 1px 3px #0000000a}.sos-user-input-meta{color:#888;align-items:center;gap:5px;margin-bottom:3px;font-size:.65rem;display:flex}.sos-user-input-dot{color:#ccc}.sos-user-input-text{color:#333;white-space:pre-wrap;word-break:break-word;font-size:.85rem;line-height:1.5}.sos-card-notes{color:#aaa;border-top:1px solid #0000000a;padding:8px 14px 12px;font-size:.75rem;line-height:1.55}.sos-footer{background:#fff;border-top:1px solid #0000000f;flex-shrink:0;padding:12px 16px 16px}.sos-footer-inner{flex-direction:column;gap:8px;max-width:720px;margin:0 auto;display:flex}.sos-location-bar{background:#f9f9f9;border:1px solid #ebebeb;border-radius:10px;align-items:center;gap:6px;padding:8px 12px;display:flex}.sos-location-icon{color:var(--accent);flex-shrink:0}.sos-location-country{color:#777;white-space:nowrap;flex-shrink:0;font-size:.78rem;font-weight:600}.sos-location-country:after{content:"›";color:#ccc;margin-left:6px;font-weight:400}.sos-location-select-wrapper{flex:1;align-items:center;display:flex;position:relative}.sos-location-select{appearance:none;color:#555;cursor:pointer;background:0 0;border:none;outline:none;width:100%;padding-right:18px;font-family:inherit;font-size:.82rem;font-weight:600}.sos-location-chevron{pointer-events:none;color:#aaa;position:absolute;right:0}.sos-category-chips{scrollbar-width:none;-ms-overflow-style:none;gap:6px;display:flex;overflow-x:auto}.sos-category-chips::-webkit-scrollbar{display:none}.sos-chip{color:#888;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;flex-shrink:0;padding:5px 12px;font-family:inherit;font-size:.75rem;transition:border-color .15s,background .15s,color .15s}.sos-chip:hover{border-color:var(--accent);color:var(--accent)}.sos-chip.is-active{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);color:var(--accent);font-weight:600}.sos-input-box{background:#fff;border:1.5px solid #e0e0e0;border-radius:12px;padding:10px 14px;transition:border-color .15s,box-shadow .15s}.sos-input-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent)}.sos-textarea{resize:none;color:#333;box-sizing:border-box;background:0 0;border:none;outline:none;width:100%;min-height:44px;max-height:120px;font-family:inherit;font-size:.9rem;line-height:1.6;display:block}.sos-textarea::placeholder{color:#bbb}.sos-textarea:disabled{opacity:.5}.sos-form-actions{justify-content:flex-end;display:flex}.sos-submit-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:20px;align-items:center;gap:6px;padding:9px 20px;font-family:inherit;font-size:.85rem;font-weight:600;transition:opacity .15s,transform .1s;display:flex}.sos-submit-btn:disabled{opacity:.35;cursor:not-allowed}.sos-submit-btn:not(:disabled):hover{opacity:.85}.sos-submit-btn:not(:disabled):active{transform:scale(.97)}@media (width>=769px){.sos-feed{padding:24px}.sos-card-group,.sos-card{width:100%;max-width:680px;margin:0 auto}.sos-empty{max-width:400px;margin:0 auto}}@media (width<=768px){.sos-footer{padding-bottom:max(16px, env(safe-area-inset-bottom))}}.reflection-page{background:var(--color-bg);-webkit-overflow-scrolling:touch;z-index:100;flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.reflection-header{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);height:var(--header-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);z-index:10;background:#ffffffeb;flex-shrink:0;display:flex;position:sticky;top:0}.reflection-header:after{content:"";opacity:.75;background:#ff8e9b;height:2px;position:absolute;bottom:-1px;left:0;right:0}.reflection-back-btn{border-radius:var(--radius-lg);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.reflection-back-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.reflection-header-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:36px;height:36px}.reflection-header-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.reflection-header-name{font-size:var(--text-sm);color:var(--color-text);font-weight:700;line-height:1.2}.reflection-header-label{font-size:var(--text-xs);color:var(--color-text-muted)}.reflection-body{padding:var(--space-5) var(--space-4) var(--space-12);gap:var(--space-5);flex-direction:column;width:100%;max-width:720px;margin:0 auto;display:flex}.reflection-intro{padding:var(--space-3) var(--space-1) var(--space-2)}.reflection-intro-eyebrow{font-size:var(--text-xs);color:#c93a4d;letter-spacing:.25em;margin-bottom:var(--space-3);background:0 0;border-top:2px solid #c93a4d;border-bottom:2px solid #c93a4d;border-radius:0;padding:4px 0;font-weight:800;display:inline-block}.reflection-intro-title{font-size:var(--text-2xl);color:var(--color-text);margin:0 0 var(--space-3);letter-spacing:-.005em;font-weight:800;line-height:1.4}.reflection-intro-lead{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;line-height:1.75}.reflection-message{margin:var(--space-2) auto;padding:var(--space-6);background:0 0;border:none;border-radius:0;max-width:520px;position:relative}.reflection-message:before,.reflection-message:after{content:"";width:22px;height:22px;position:absolute}.reflection-message:before{border-top:2px solid #c93a4d;border-left:2px solid #c93a4d;top:0;left:0}.reflection-message:after{border-bottom:2px solid #c93a4d;border-right:2px solid #c93a4d;bottom:0;right:0}.reflection-message-text{font-size:var(--text-sm);color:var(--color-text);letter-spacing:.04em;text-align:center;margin:0;font-weight:500;line-height:1.95}.reflection-message-text strong{color:#c93a4d;font-variant-numeric:tabular-nums;padding:0 2px;font-size:1.1em;font-weight:700}.reflection-message-period{margin-top:var(--space-2);color:#c93a4d;letter-spacing:.06em;font-variant-numeric:tabular-nums;font-size:.92em;font-weight:600;display:inline-block}.reflection-loading{align-items:center;gap:var(--space-3);padding:var(--space-10) var(--space-4);color:var(--color-text-muted);flex-direction:column;display:flex}.reflection-loading-spinner{border:3px solid #c93a4d2e;border-top-color:#c93a4d;border-radius:50%;width:28px;height:28px;animation:.9s linear infinite reflection-spin}@keyframes reflection-spin{to{transform:rotate(360deg)}}.reflection-loading-text{font-size:var(--text-sm);margin:0}.reflection-empty{padding:var(--space-8) var(--space-5);text-align:center;background:#ff8e9b0d;border:1px dashed #c93a4d66;border-radius:4px;max-width:520px;margin:0 auto}.reflection-empty-text{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;line-height:1.9}.reflection-empty-action{margin-top:var(--space-4);font-size:var(--text-sm);color:#fff;cursor:pointer;transition:opacity var(--transition-fast);background:#c93a4d;border:none;border-radius:4px;padding:10px 20px;font-weight:700}.reflection-empty-action:hover{opacity:.85}.reflection-error-banner{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:#c93a4d;background:#c93a4d14;border:1px solid #c93a4d52;border-radius:4px}.reflection-usage-limit-banner{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);color:#c93a4d;background:#c93a4d14;border:1px solid #c93a4d52;border-radius:4px;display:flex}.reflection-usage-limit-banner__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.reflection-usage-limit-banner__message{font-size:var(--text-sm);font-weight:700}.reflection-usage-limit-banner__reset{font-size:var(--text-xs);color:var(--color-text-secondary)}.reflection-usage-limit-banner__link{font-size:var(--text-xs);color:#fff;cursor:pointer;background:#c93a4d;border:none;border-radius:3px;flex-shrink:0;padding:6px 12px;font-weight:700}.reflection-usage-limit-banner__link:hover{opacity:.85}.reflection-analysis-cards{gap:var(--space-4);flex-direction:column;display:flex}.reflection-analysis-card{background:#fff;border:1px solid #c93a4d52;border-radius:2px;grid-template-columns:56px 1fr;display:grid;overflow:hidden}.reflection-analysis-card-tab{color:#fff;align-items:center;gap:var(--space-2);padding:var(--space-5) 0;background:#c93a4d;flex-direction:column;display:flex}.reflection-analysis-card-number{font-size:var(--text-xl);letter-spacing:.04em;font-variant-numeric:tabular-nums;font-family:Georgia,Hiragino Mincho ProN,Yu Mincho,Times New Roman,serif;font-weight:800;line-height:1}.reflection-analysis-card-accent{background:#ffb3bd;width:18px;height:2px;display:block}.reflection-analysis-card-content{padding:var(--space-5);gap:var(--space-4);flex-direction:column;min-width:0;display:flex}.reflection-analysis-card-trait{font-size:var(--text-base);color:var(--color-text);letter-spacing:-.005em;padding-bottom:var(--space-3);border-bottom:2px solid #c93a4d;margin:0;font-weight:800;line-height:1.5}.reflection-analysis-card-section{gap:var(--space-2);flex-direction:column;display:flex}.reflection-analysis-card-section+.reflection-analysis-card-section{padding-top:var(--space-4);border-top:1px dashed #c93a4d40}.reflection-analysis-card-label{font-size:var(--text-xs);color:#c93a4d;letter-spacing:.18em;font-weight:800;display:block}.reflection-analysis-card-text{font-size:var(--text-sm);color:var(--color-text);margin:0;line-height:1.85}@media (width>=769px){.reflection-body{padding:var(--space-8) var(--space-5) var(--space-12);gap:var(--space-6);max-width:880px}.reflection-intro{padding:var(--space-4) 0 var(--space-2)}.reflection-intro-title{font-size:var(--text-3xl)}.reflection-intro-lead{font-size:var(--text-base)}.reflection-message{padding:var(--space-8);max-width:600px}.reflection-message:before,.reflection-message:after{width:28px;height:28px}.reflection-message-text{font-size:var(--text-base)}.reflection-analysis-card{grid-template-columns:80px 1fr}.reflection-analysis-card-tab{padding:var(--space-6) 0}.reflection-analysis-card-number{font-size:var(--text-2xl)}.reflection-analysis-card-accent{width:22px}.reflection-analysis-card-content{padding:var(--space-6);gap:var(--space-5)}.reflection-analysis-card-trait{font-size:var(--text-lg)}.reflection-analysis-card-section+.reflection-analysis-card-section{padding-top:var(--space-5)}}.usage-page{background:var(--color-bg);-webkit-overflow-scrolling:touch;z-index:100;flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.usage-header{padding:var(--space-3) var(--space-4);height:var(--header-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);z-index:10;background:#ffffffeb;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.usage-header__back-btn{border-radius:var(--radius-lg);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.usage-header__back-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.usage-header__center{text-align:center}.usage-header__title{font-size:var(--text-base);justify-content:center;align-items:center;gap:var(--space-2);color:var(--gradient-bg);font-weight:700;display:flex}.usage-content{padding:var(--space-4);padding-bottom:var(--space-12);width:100%;max-width:680px;margin:0 auto;animation:.4s ease-out usageFadeInUp}@keyframes usageFadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.usage-cards{gap:var(--space-4);flex-direction:column;display:flex}.usage-limit-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);overflow:hidden}.usage-limit-card:hover{box-shadow:var(--shadow-md)}.usage-limit-card__header{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-weight:600;font-size:var(--text-sm);color:var(--color-text);border-bottom:1px solid var(--color-border-light);display:flex}.usage-limit-card__body{padding:var(--space-5) var(--space-4)}.usage-limit{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.usage-limit__counts{flex-wrap:wrap;align-items:baseline;gap:.5rem .25rem;display:flex}.usage-limit__current{font-size:var(--text-2xl);color:var(--color-text);font-weight:700;line-height:1.2}.usage-limit__separator,.usage-limit__max{font-size:var(--text-lg);color:var(--color-text-secondary)}.usage-limit__unit{font-size:var(--text-xs);color:var(--color-text-muted);align-self:flex-end;margin-left:.25rem;padding-bottom:.15rem}.usage-limit__bonus{font-size:var(--text-xs);color:#c93a4d;border-radius:var(--radius-full);white-space:nowrap;background:#ff8e9b24;border:1px solid #ff8e9b59;align-self:center;margin-left:auto;padding:.2rem .6rem;font-weight:600}.usage-limit__bar{background:var(--color-bg);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.usage-limit__bar-fill{background:var(--gradient-bg);border-radius:var(--radius-full);height:100%;transition:width .6s cubic-bezier(.34,1.56,.64,1)}.usage-limit__bar-fill--warning{background:#f59e0b}.usage-limit__bar-fill--danger{background:#ef4444}.usage-limit__meta{justify-content:space-between;align-items:center;display:flex}.usage-limit__percent{font-size:var(--text-xs);color:var(--color-text-muted)}.usage-limit__reset{font-size:var(--text-xs);color:var(--color-text-secondary)}.usage-loading{flex-direction:column;align-items:center;padding-top:60px;display:flex}.usage-spinner{color:var(--color-text-muted);animation:1s linear infinite usageSpin}@keyframes usageSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.usage-loading__text{text-align:center;margin-top:var(--space-4);color:var(--color-text-muted);font-size:var(--text-sm)}.usage-error{border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:#dc2626;text-align:center;background:#ef444414;border:1px solid #ef444433}.usage-referral{margin-top:var(--space-5)}.usage-referral__toggle{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);color:#c93a4d;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px dashed #ff8e9b80;font-weight:600;display:flex}.usage-referral__toggle:hover{background:#ff8e9b14;border-style:solid}.usage-referral__toggle-chevron{transition:transform var(--transition-fast)}.usage-referral__toggle-chevron--open{transform:rotate(180deg)}.usage-referral__form{gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);flex-wrap:wrap;animation:.25s ease-out usageFadeInUp;display:flex}.usage-referral__input{min-width:0;font-size:var(--text-sm);border:1px solid var(--color-border-light);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);text-transform:uppercase;transition:border-color var(--transition-fast);flex:200px;padding:.6rem .8rem;font-family:inherit}.usage-referral__input:focus{border-color:#ff8e9b;outline:none}.usage-referral__input:disabled{opacity:.6;cursor:not-allowed}.usage-referral__submit{min-width:88px;font-size:var(--text-sm);color:#fff;background:var(--gradient-bg);border-radius:var(--radius-md);cursor:pointer;transition:opacity var(--transition-fast);border:none;justify-content:center;align-items:center;padding:.6rem 1rem;font-weight:600;display:inline-flex}.usage-referral__submit:hover:not(:disabled){opacity:.9}.usage-referral__submit:disabled{opacity:.5;cursor:not-allowed}.usage-referral__error{font-size:var(--text-xs);color:#dc2626;flex-basis:100%;padding:.2rem 0}@media (width>=768px){.usage-content{padding:var(--space-8);padding-bottom:var(--space-12)}}.sub-page{background:var(--color-bg);-webkit-overflow-scrolling:touch;z-index:100;flex-direction:column;display:flex;position:fixed;inset:0;overflow-y:auto}.sub-header{padding:var(--space-3) var(--space-4);height:var(--header-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border-light);z-index:10;background:#ffffffeb;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.sub-header__back-btn{border-radius:var(--radius-lg);width:40px;height:40px;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.sub-header__back-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.sub-header__title{font-size:var(--text-base);align-items:center;gap:var(--space-2);color:var(--color-text);margin:0;font-weight:700;display:flex}.sub-content{width:100%;max-width:720px;padding:var(--space-5) var(--space-4) var(--space-6);gap:var(--space-5);flex-direction:column;margin:0 auto;display:flex}.sub-error{color:#c93a4d;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);background:#fde8ea;font-weight:600}.sub-current{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--card-radius);padding:var(--space-4);flex-direction:column;gap:6px;display:flex}.sub-current__label{font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:.04em;font-weight:700}.sub-current__name{font-size:var(--text-xl);color:var(--color-text);font-weight:800}.sub-current__meta{font-size:var(--text-sm);color:var(--color-text-secondary);gap:var(--space-2);flex-wrap:wrap;display:flex}.sub-current__warn{color:#c93a4d;font-weight:700}.sub-manage-btn{margin-top:var(--space-2);align-self:flex-start;align-items:center;gap:var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-surface);color:var(--color-text);font-weight:700;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);padding:10px 16px;display:inline-flex}.sub-manage-btn:hover:not(:disabled){background:var(--color-surface-hover)}.sub-manage-btn:disabled{opacity:.6;cursor:default}.sub-cycle{gap:var(--space-3);flex-direction:column;display:flex}.sub-cycle__label{font-size:var(--text-base);color:var(--color-text);align-items:baseline;gap:var(--space-2);font-weight:800;display:flex}.sub-cycle__hint{font-size:var(--text-xs);color:#c93a4d;font-weight:700}.sub-cycle__seg{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.sub-cycle__item{border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);cursor:pointer;transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:4px;padding:14px 8px;display:flex}.sub-cycle__item:hover{border-color:#ffb3bd}.sub-cycle__item--active{background:#fff1f3;border-color:#ff8e9b;box-shadow:0 0 0 3px #ff8e9b2e}.sub-cycle__name{font-size:var(--text-base);color:var(--color-text);font-weight:800}.sub-cycle__save{font-size:var(--text-xs);color:#c93a4d;border-radius:var(--radius-full);background:#ffe1e5;padding:2px 8px;font-weight:800}.sub-cycle__save--muted{color:var(--color-text-muted);background:var(--color-surface-hover)}.sub-cards{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=560px){.sub-cards{grid-template-columns:1fr}}.sub-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--card-radius);padding:var(--space-4);gap:var(--space-3);flex-direction:column;display:flex}.sub-card--current{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent)}.sub-card__top{flex-direction:column;gap:8px;display:flex}.sub-card__nameRow{justify-content:space-between;align-items:center;display:flex}.sub-card__name{font-size:var(--text-lg);color:var(--accent);font-weight:800}.sub-card__badge{font-size:var(--text-xs);color:#fff;background:var(--accent);border-radius:var(--radius-full);padding:3px 10px;font-weight:800}.sub-card__usage{font-size:var(--text-xs);color:var(--color-text-secondary);border-radius:var(--radius-full);background:#fff1f3;align-self:flex-start;padding:4px 10px;font-weight:700;line-height:1.4;display:inline-block}.sub-card__usage strong{color:var(--accent);font-size:var(--text-sm);vertical-align:baseline}.sub-card__price{align-items:baseline;gap:6px;display:flex}.sub-card__amount{color:var(--color-text);font-size:2rem;font-weight:800;line-height:1}.sub-card__cycle{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:700}.sub-card__renew{font-size:var(--text-xs);color:var(--color-text-secondary);align-items:center;gap:6px;font-weight:700;display:inline-flex}.sub-card__permonth{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);display:flex}.sub-card__save{font-size:var(--text-xs);color:#c93a4d;border-radius:var(--radius-full);background:#ffe1e5;padding:2px 8px;font-weight:800}.sub-card__btn{background:var(--accent);color:#fff;font-weight:800;font-size:var(--text-base);border-radius:var(--radius-full);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-2);transition:filter var(--transition-fast);border:none;margin-top:auto;padding:13px;display:flex}.sub-card__btn:hover:not(:disabled){filter:brightness(1.06)}.sub-card__btn:disabled{opacity:.5;cursor:default}.sub-renote{align-items:flex-start;gap:var(--space-2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text);background:#fff1f3;line-height:1.7;display:flex}.sub-renote svg{color:#c93a4d;flex-shrink:0;margin-top:2px}.sub-renote strong{color:#c93a4d}.sub-renote--info{background:var(--color-surface-hover);color:var(--color-text-secondary)}.sub-renote--info svg{color:var(--color-text-muted)}.sub-lp-link{align-self:center;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:#c93a4d;border-radius:var(--radius-full);background:var(--color-surface);transition:all var(--transition-fast);border:1px solid #ffc2ca;padding:10px 18px;font-weight:700;text-decoration:none;display:inline-flex}.sub-lp-link:hover{background:#fff1f3}.sub-note{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;margin:0}.sub-loading{justify-content:center;align-items:center;gap:var(--space-3);color:var(--color-text-secondary);flex-direction:column;flex:1;display:flex}.sub-loading__text{font-size:var(--text-sm)}.sub-spinner{animation:.9s linear infinite sub-spin}@keyframes sub-spin{to{transform:rotate(360deg)}}.sub-complete{text-align:center;justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-4);flex-direction:column;flex:1;max-width:480px;margin:0 auto;display:flex}.sub-complete__icon{color:#ff8e9b}.sub-complete__title{font-size:var(--text-xl);color:var(--color-text);margin:0;font-weight:800}.sub-complete__text{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;line-height:1.8}.sub-complete__btn{margin-top:var(--space-3);align-items:center;gap:var(--space-2);color:#fff;font-weight:800;font-size:var(--text-base);border-radius:var(--radius-full);cursor:pointer;transition:filter var(--transition-fast);background:#ff8e9b;border:none;padding:12px 28px;display:inline-flex}.sub-complete__btn:hover{filter:brightness(1.05)}
