@import "https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.css";:root{--color-base-white:#fff;--color-base-black:#000;--color-neutral-50:#fafafa;--color-neutral-75:#f5f5f5;--color-neutral-100:#f0f0f0;--color-neutral-200:#e5e5e5;--color-neutral-300:#cecece;--color-neutral-400:#a3a3a3;--color-neutral-500:#737373;--color-neutral-600:#525252;--color-neutral-700:#424242;--color-neutral-800:#292929;--color-neutral-900:#141414;--color-pine-50:#f2f6f5;--color-pine-100:#e0ebe8;--color-pine-200:#b8ccc5;--color-pine-300:#8fada3;--color-pine-400:#5f8a7d;--color-pine-500:#1e3a33;--color-pine-600:#1a322c;--color-pine-700:#152925;--color-pine-800:#0f1e1b;--color-pine-900:#0a1412;--chat-bubble-own-color:#3b82f6;--chat-theme-surface:color-mix(in srgb, var(--chat-bubble-own-color) 10%, white);--chat-theme-surface-strong:color-mix(in srgb, var(--chat-bubble-own-color) 18%, white);--chat-theme-border:color-mix(in srgb, var(--chat-bubble-own-color) 30%, white);--chat-theme-border-strong:color-mix(in srgb, var(--chat-bubble-own-color) 45%, white);--chat-theme-focus-ring:color-mix(in srgb, var(--chat-bubble-own-color) 32%, transparent);--color-red-50:#fef6f4;--color-red-100:#fce6e0;--color-red-500:#c54600;--color-green-50:#f2fbf1;--color-green-500:#007d00;--color-orange-50:#fff8ee;--color-orange-400:#fb9600;--color-opacity-black-4:#0000000a;--color-opacity-black-8:#00000014;--color-opacity-black-12:#0000001f;--color-opacity-black-16:#00000029;--color-opacity-black-24:#0000003d;--surface-default:var(--color-base-white);--surface-subtle:var(--color-neutral-50);--surface-muted:var(--color-neutral-75);--surface-brand:var(--color-pine-500);--surface-brand-subtle:var(--color-pine-50);--background-default:var(--color-base-white);--background-subtle:var(--color-neutral-50);--background-muted:var(--color-neutral-75);--background-brand:var(--color-pine-500);--background-info:var(--color-pine-50);--action-primary:var(--color-pine-500);--action-primary-hover:var(--color-pine-600);--action-primary-pressed:var(--color-pine-700);--action-accent:var(--chat-bubble-own-color);--action-accent-hover:color-mix(in srgb, var(--chat-bubble-own-color) 85%, white);--action-accent-pressed:color-mix(in srgb, var(--chat-bubble-own-color) 85%, black);--action-secondary:var(--color-neutral-100);--action-secondary-hover:var(--color-neutral-200);--action-secondary-pressed:var(--color-neutral-300);--action-tertiary:transparent;--action-tertiary-hover:var(--color-opacity-black-4);--action-tertiary-pressed:var(--color-opacity-black-8);--border-default:var(--color-opacity-black-8);--border-subtle:var(--color-neutral-100);--border-strong:var(--color-neutral-300);--border-brand:var(--chat-theme-border);--border-focus:var(--chat-bubble-own-color);--label-strong:var(--color-neutral-900);--label-default:var(--color-neutral-800);--label-neutral:var(--color-neutral-600);--label-subtle:var(--color-neutral-500);--label-disabled:var(--color-neutral-400);--label-inverse:var(--color-base-white);--label-on-color:var(--color-base-white);--label-link:var(--color-pine-600);--label-brand:var(--color-pine-500);--label-accent:var(--chat-bubble-own-color);--status-info:var(--color-pine-500);--status-success:var(--color-green-500);--status-warning:var(--color-orange-400);--status-critical:var(--color-red-500);--status-critical-bg:var(--color-red-50);--status-info-bg:var(--color-pine-50);--status-success-bg:var(--color-green-50);--shadow-1:0 1px 2px #0000000f, 0 1px 3px #0000000a;--shadow-2:0 2px 4px #0000000f, 0 4px 8px #0000000f;--shadow-3:0 4px 8px #00000014, 0 12px 20px #00000014;--shadow-4:0 8px 16px #0000001a, 0 24px 48px #0000001f;--shadow-overlay:0 16px 48px #0000002e;--shadow-focus:0 0 0 3px var(--chat-theme-focus-ring);--radius-xs:2px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-pill:999px;--space-0:0px;--space-1:2px;--space-2:4px;--space-3:8px;--space-4:12px;--space-5:16px;--space-6:20px;--space-7:24px;--space-8:32px;--space-9:40px;--space-10:48px;--space-11:64px;--space-12:80px;--font-family-sans:"Pretendard Variable", "Pretendard", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Noto Sans KR", "Helvetica Neue", Arial, sans-serif;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--text-heading-lg-size:24px;--text-heading-lg-line:32px;--text-heading-md-size:20px;--text-heading-md-line:28px;--text-heading-sm-size:18px;--text-heading-sm-line:26px;--text-body-md-size:16px;--text-body-md-line:26px;--text-body-sm-size:14px;--text-body-sm-line:22px;--text-body-xs-size:13px;--text-body-xs-line:20px;--text-caption-size:12px;--text-caption-line:18px;--motion-duration-fast:.12s;--motion-duration-base:.2s;--motion-duration-slow:.32s;--motion-ease-standard:cubic-bezier(.2, 0, 0, 1);--motion-ease-emphasized:cubic-bezier(.3, 0, 0, 1);--color-brand-pine:var(--color-pine-500);--color-brand-gold:var(--chat-bubble-own-color)}.hk-btn{justify-content:center;align-items:center;gap:var(--space-3);height:44px;padding:0 var(--space-5);border-radius:var(--radius-md);font-family:inherit;font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);letter-spacing:-.01em;cursor:pointer;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard), color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);border:none;line-height:1;display:inline-flex}.hk-btn--lg{height:52px;padding:0 var(--space-6);font-size:15px;font-weight:var(--font-weight-bold)}.hk-btn--sm{height:36px;padding:0 var(--space-4);font-size:var(--text-caption-size)}.hk-btn--full{width:100%}.hk-btn--primary{background:var(--action-primary);color:var(--label-on-color)}.hk-btn--primary:hover:not(:disabled){background:var(--action-primary-hover)}.hk-btn--primary:active:not(:disabled){background:var(--action-primary-pressed)}.hk-btn--accent{background:var(--action-accent);color:var(--color-pine-500)}.hk-btn--accent:hover:not(:disabled){background:var(--action-accent-hover)}.hk-btn--accent:active:not(:disabled){background:var(--action-accent-pressed)}.hk-btn--secondary{background:var(--surface-default);color:var(--label-default);border:1px solid var(--color-neutral-200)}.hk-btn--secondary:hover:not(:disabled){background:var(--color-neutral-50);border-color:var(--color-neutral-300)}.hk-btn--ghost{background:var(--action-tertiary);color:var(--label-neutral);border:1px solid var(--color-neutral-200)}.hk-btn--ghost:hover:not(:disabled){background:var(--action-tertiary-hover);color:var(--label-strong);border-color:var(--color-neutral-300)}.hk-btn:disabled{background:var(--color-neutral-200);color:var(--label-disabled);border-color:var(--color-neutral-200);cursor:not-allowed}.hk-input{width:100%;height:44px;padding:0 var(--space-4);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);background:var(--surface-default);font-family:inherit;font-size:var(--text-body-sm-size);color:var(--label-strong);letter-spacing:-.01em;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);outline:none}.hk-input::placeholder{color:var(--label-disabled)}.hk-input:hover:not(:disabled){border-color:var(--color-neutral-300)}.hk-input:focus{border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.hk-input:disabled{background:var(--color-neutral-75);color:var(--label-disabled);cursor:not-allowed}.hk-field{flex-direction:column;gap:6px;display:flex}.hk-field__label{font-size:var(--text-body-xs-size);font-weight:var(--font-weight-medium);color:var(--label-default);letter-spacing:-.01em}.hk-card{background:var(--surface-default);border:1px solid var(--color-neutral-100);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-1)}.hk-modal-overlay{z-index:100;padding:var(--space-7);background:#0000007a;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.hk-modal{width:100%;max-width:400px;padding:var(--space-8) var(--space-7);border:1px solid var(--color-neutral-100);border-radius:var(--radius-xl);background:var(--surface-default);box-shadow:var(--shadow-overlay)}.hk-modal__title{margin:0 0 var(--space-2);font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-strong);text-align:center;letter-spacing:-.02em}.hk-modal__subtitle{margin:0 0 var(--space-7);font-size:var(--text-body-sm-size);color:var(--label-subtle);text-align:center;letter-spacing:-.01em}.hk-modal__form{gap:var(--space-4);flex-direction:column;display:flex}.hk-modal__actions{gap:var(--space-3);margin-top:var(--space-2);display:flex}.hk-modal__actions .hk-btn{flex:1}.hk-alert{padding:var(--space-4);border-radius:var(--radius-md);font-size:var(--text-body-sm-size);line-height:var(--text-body-sm-line);letter-spacing:-.01em;text-align:center;margin:0}.hk-alert--info{color:var(--chat-bubble-own-color);background:var(--chat-theme-surface);border:1px solid var(--chat-theme-border)}.hk-alert--error{color:var(--status-critical);background:var(--status-critical-bg);border:1px solid var(--color-red-100)}.hk-page{min-height:100vh;padding:var(--space-7);background:var(--background-muted);justify-content:center;align-items:center;display:flex}.hk-page__title{margin:0 0 var(--space-2);font-size:28px;font-weight:var(--font-weight-bold);color:var(--label-brand);text-align:center;letter-spacing:-.02em}.hk-page__subtitle{margin:0 0 var(--space-8);font-size:var(--text-body-sm-size);color:var(--label-subtle);text-align:center;letter-spacing:-.01em;line-height:1.6}.hk-loading{justify-content:center;align-items:center;gap:var(--space-5);background:var(--background-muted);min-height:100vh;color:var(--label-subtle);font-size:var(--text-body-sm-size);letter-spacing:-.01em;flex-direction:column;display:flex}.hk-loading__spinner{border:3px solid var(--color-neutral-200);border-top-color:var(--color-pine-500);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite hk-spin}.hk-loading__text{color:var(--label-subtle)}@keyframes hk-spin{to{transform:rotate(360deg)}}.fluent-emoji-img{object-fit:contain;vertical-align:middle;-webkit-user-select:none;user-select:none;display:inline-block}.fluent-emoji--fallback{line-height:1}.fluent-emoji-message{flex-wrap:wrap;align-items:center;gap:6px;display:flex}img.emoji{object-fit:contain;vertical-align:-.15em;-webkit-user-select:none;user-select:none;display:inline-block}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-family-sans);font-size:var(--text-body-sm-size);color:var(--label-strong);background:var(--background-default);letter-spacing:-.01em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-synthesis:none;width:100%;max-width:100%;height:100%;line-height:1.6;overflow:hidden}body{min-width:320px}#root,.app-container{width:100%;max-width:100%;height:100dvh;overflow:hidden}@supports (-webkit-touch-callout:none){#root,.app-container{height:-webkit-fill-available;min-height:-webkit-fill-available}}button{cursor:pointer;letter-spacing:inherit;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}.emoji-picker{bottom:100%;left:var(--space-7);z-index:25;width:min(320px,100vw - 48px);max-height:360px;margin-bottom:var(--space-2);padding:var(--space-3);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);gap:var(--space-2);flex-direction:column;display:flex;position:absolute}.emoji-picker__section-title{margin:0 0 var(--space-2);font-size:11px;font-weight:var(--font-weight-semibold);color:var(--label-subtle);letter-spacing:-.01em}.emoji-picker__tabs{flex-wrap:wrap;gap:4px;display:flex}.emoji-picker__tab{font-family:inherit;font-size:11px;font-weight:var(--font-weight-medium);color:var(--label-subtle);border-radius:var(--radius-pill);cursor:pointer;background:0 0;border:1px solid #0000;padding:4px 8px}.emoji-picker__tab--active{color:var(--chat-bubble-own-color);background:var(--chat-theme-surface);border-color:var(--chat-theme-border)}.emoji-picker__grid{grid-template-columns:repeat(5,minmax(56px,1fr));gap:6px;display:grid}.emoji-picker__grid--scroll{max-height:220px;overflow-y:auto}.emoji-picker__item{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:100%;min-height:56px;padding:0;line-height:1;display:flex}.emoji-picker__item:hover{background:var(--chat-theme-surface)}.gif-search{padding:var(--space-3) var(--space-7) 0}.gif-search__form{gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.gif-search__input{min-width:0;padding:var(--space-2) var(--space-3);font-size:var(--text-body-sm-size);color:var(--label-default);background:var(--background-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);letter-spacing:-.01em;flex:1}.gif-search__input:focus{border-color:var(--chat-bubble-own-color,#1e3a33);outline:none}.gif-search__submit{padding:var(--space-2) var(--space-4);font-size:var(--text-body-sm-size);color:var(--label-on-accent);background:var(--chat-bubble-own-color,#1e3a33);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:opacity var(--motion-duration-fast) var(--motion-ease-standard);border:none;flex-shrink:0;font-weight:500}.gif-search__submit:hover:not(:disabled){opacity:.9}.gif-search__submit:disabled{opacity:.5;cursor:not-allowed}.gif-search__loading{align-items:center;gap:var(--space-2);padding:var(--space-2) 0;display:flex}.gif-search__spinner{border:2px solid var(--color-neutral-200);border-top-color:var(--color-pine-500);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite gif-search-spin}@keyframes gif-search-spin{to{transform:rotate(360deg)}}.gif-search__status{font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em;margin:0}.gif-search__scroll{scrollbar-width:thin;scrollbar-color:var(--color-neutral-300) transparent;max-height:min(320px,40vh);overflow-y:auto}.gif-search__scroll::-webkit-scrollbar{width:4px}.gif-search__scroll::-webkit-scrollbar-track{background:0 0}.gif-search__scroll::-webkit-scrollbar-thumb{background:var(--color-neutral-300);border-radius:2px}.gif-search__grid{gap:var(--space-2);grid-template-columns:repeat(2,1fr);display:grid}@media (width>=640px){.gif-search__grid{grid-template-columns:repeat(3,1fr)}}.gif-search__item{aspect-ratio:1;background:var(--color-neutral-100);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), transform var(--motion-duration-fast) var(--motion-ease-standard);padding:0;position:relative;overflow:hidden}.gif-search__item:hover{border-color:var(--chat-bubble-own-color,#1e3a33);transform:scale(1.04)}.gif-search__thumb{object-fit:cover;width:100%;height:100%;transition:transform var(--motion-duration-fast) var(--motion-ease-standard);display:block}.gif-search__item:hover .gif-search__thumb{transform:scale(1.05)}.gif-search__more-wrap{padding:var(--space-3) 0 var(--space-1);justify-content:center;display:flex}.gif-search__more{padding:var(--space-2) var(--space-5);font-size:var(--text-caption-size);color:var(--label-default);background:var(--color-neutral-100);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), background var(--motion-duration-fast) var(--motion-ease-standard);font-weight:500}.gif-search__more:hover:not(:disabled){background:var(--color-neutral-200);border-color:var(--color-neutral-300)}.gif-search__more:disabled{cursor:wait;opacity:.7}.gif-search__attribution{margin:var(--space-2) 0 0;color:var(--label-disabled);text-align:right;letter-spacing:-.01em;font-size:10px}.slash-help{padding:var(--space-4) var(--space-7);border-bottom:1px solid var(--color-neutral-100);background:var(--color-neutral-50);margin:0}.slash-help__header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.slash-help__title{font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-default);letter-spacing:-.01em;margin:0}.slash-help__close{width:28px;height:28px;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:14px;display:flex}.slash-help__close:hover{color:var(--label-default);background:var(--color-neutral-100)}.slash-help__list{gap:var(--space-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.slash-help__item{align-items:baseline;gap:var(--space-3);display:flex}.slash-help__command{min-width:56px;font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-brand);letter-spacing:-.01em;flex-shrink:0}.slash-help__desc{font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em}.modal-overlay{z-index:9999;background:#0000007a;position:fixed;inset:0}.modal{box-sizing:border-box;width:calc(100vw - 48px);max-width:360px;padding:var(--space-8) var(--space-7);border-radius:var(--radius-xl);background:var(--surface-default);border:1px solid var(--color-neutral-100);box-shadow:var(--shadow-overlay);margin:0;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.modal__title{margin:0 0 var(--space-2);font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-strong);text-align:center;letter-spacing:-.02em}.modal__subtitle{margin:0 0 var(--space-7);font-size:var(--text-body-sm-size);color:var(--label-subtle);text-align:center;letter-spacing:-.01em}.modal__form{gap:var(--space-4);flex-direction:column;min-width:0;display:flex}.modal__label{font-size:var(--text-body-xs-size);font-weight:var(--font-weight-medium);color:var(--label-default);letter-spacing:-.01em}.modal__input{box-sizing:border-box;width:100%;min-width:0;height:44px;padding:0 var(--space-4);font-size:var(--text-body-sm-size);color:var(--label-strong);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);letter-spacing:-.01em;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);outline:none}.modal__input::placeholder{color:var(--label-disabled)}.modal__input:hover{border-color:var(--color-neutral-300)}.modal__input:focus{border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.modal__error{font-size:var(--text-caption-size);color:var(--status-critical);letter-spacing:-.01em;margin:0}.modal__actions{gap:var(--space-3);margin-top:var(--space-2);min-width:0;display:flex}.modal__button{min-width:0;height:44px;padding:0 var(--space-5);font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard);border:none;flex:1}.modal__button--cancel{color:var(--label-default);background:var(--surface-default);border:1px solid var(--color-neutral-200)}.modal__button--cancel:hover:not(:disabled){background:var(--color-neutral-50);border-color:var(--color-neutral-300)}.modal__button--confirm{color:var(--label-on-color);background:var(--action-primary)}.modal__button--confirm:hover:not(:disabled){background:var(--action-primary-hover)}.modal__button--destroy{color:var(--label-on-color);background:var(--status-critical)}.modal__button--destroy:hover:not(:disabled){background:var(--color-red-600,#a93a00)}.modal__subtitle strong{color:var(--label-strong);font-weight:var(--font-weight-semibold)}.modal__button:disabled{opacity:.6;cursor:not-allowed}.create-family-modal{max-width:400px}.create-family__room-types{gap:var(--space-3);flex-direction:column;display:flex}.create-family__room-type-grid{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.create-family__room-type{gap:var(--space-2);padding:var(--space-4);text-align:left;background:var(--surface-default);border:2px solid var(--color-neutral-200);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);flex-direction:column;display:flex}.create-family__room-type:hover{border-color:var(--color-pine-300)}.create-family__room-type--selected{border-color:var(--action-primary);box-shadow:0 0 0 2px var(--shadow-focus)}.create-family__room-type-label{font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-strong);letter-spacing:-.01em}.create-family__room-type-desc{font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em;line-height:1.45}@media (width<=420px){.create-family__room-type-grid{grid-template-columns:1fr}}.chat-settings-modal{max-width:520px;max-height:min(90vh,720px);overflow-y:auto}.chat-settings__section+.chat-settings__section{margin-top:var(--space-7)}.chat-settings__heading{margin:0 0 var(--space-4);font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-strong);letter-spacing:-.01em}.chat-settings__hint{margin:calc(var(--space-2) * -1) 0 var(--space-4);font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em}.chat-settings__lang-toggle{gap:var(--space-2);display:flex}.chat-settings__lang-btn{padding:var(--space-3) var(--space-4);font-family:inherit;font-size:var(--text-body-sm-size);font-weight:var(--font-weight-medium);color:var(--label-default);background:var(--color-neutral-100);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), background var(--motion-duration-fast) var(--motion-ease-standard), color var(--motion-duration-fast) var(--motion-ease-standard);flex:1}.chat-settings__lang-btn:hover{background:var(--color-neutral-200)}.chat-settings__lang-btn--active{color:var(--label-on-accent);background:var(--chat-bubble-own-color,#1e3a33);border-color:var(--chat-bubble-own-color,#1e3a33)}.chat-settings__lang-btn--active:hover{opacity:.92;background:var(--chat-bubble-own-color,#1e3a33)}.chat-settings__theme-grid{gap:var(--space-3);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.chat-settings__theme{gap:var(--space-2);padding:var(--space-3);text-align:left;background:var(--surface-default);border:2px solid var(--color-neutral-200);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);flex-direction:column;display:flex}.chat-settings__theme:hover{border-color:var(--color-pine-300)}.chat-settings__theme--selected{border-color:var(--chat-bubble-own-color);box-shadow:0 0 0 2px var(--chat-theme-focus-ring)}.chat-settings__theme-name{font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:var(--label-default);letter-spacing:-.01em}.theme-preview{gap:var(--space-2);min-height:72px;padding:var(--space-3);border-radius:var(--radius-md);border:1px solid #0000000f;flex-direction:column;display:flex}.theme-preview__bubble{max-width:72%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);letter-spacing:-.01em;font-size:10px;line-height:1.3}.theme-preview__bubble--other{color:var(--label-default);border:1px solid var(--color-neutral-100);background:#fff;align-self:flex-start}.theme-preview__bubble--own{color:#fff;align-self:flex-end}.chat-settings__sound-list{gap:var(--space-2);flex-direction:column;display:flex}.chat-settings__sound{justify-content:space-between;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-4);text-align:left;background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), background var(--motion-duration-fast) var(--motion-ease-standard);display:flex}.chat-settings__sound:hover{background:var(--color-pine-50);border-color:var(--color-pine-200)}.chat-settings__sound--selected{border-color:var(--chat-bubble-own-color);background:var(--chat-theme-surface)}.chat-settings__sound-label{font-size:var(--text-body-sm-size);font-weight:var(--font-weight-medium);color:var(--label-default);letter-spacing:-.01em}.chat-settings__sound-preview{font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--label-accent);letter-spacing:-.01em;flex-shrink:0}.chat-settings__language-row{align-items:center;gap:var(--space-3);display:flex}.chat-settings__language-select{cursor:pointer;flex:1}.chat-settings__language-saved{font-size:var(--text-body-sm-size);flex-shrink:0;line-height:1}.chat-settings__notice{width:100%;min-width:0;min-height:88px;padding:var(--space-3) var(--space-4);font-family:inherit;font-size:var(--text-body-sm-size);color:var(--label-strong);resize:vertical;line-height:1.5}.chat-settings__notice-actions{align-items:center;gap:var(--space-3);margin-top:var(--space-3);display:flex}.chat-settings__notice-save{width:auto;min-width:120px}.chat-settings__notice-saved{font-size:var(--text-body-sm-size);color:var(--status-success);letter-spacing:-.01em}.chat-settings__actions{margin-top:var(--space-7)}@media (width<=520px){.chat-settings__theme-grid{grid-template-columns:1fr}}.invite-modal{width:min(340px,90vw);max-width:90vw;padding:var(--space-7) var(--space-6) var(--space-6);position:relative}.invite-modal__close{top:var(--space-4);right:var(--space-4);width:32px;height:32px;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:color var(--motion-duration-fast) var(--motion-ease-standard), background var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;display:flex;position:absolute}.invite-modal__close:hover{color:var(--label-default);background:var(--color-neutral-100)}.invite-modal__title{margin:0 var(--space-8) var(--space-2) 0;font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-strong);letter-spacing:-.02em}.invite-modal__hint{margin:0 0 var(--space-5);font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em;line-height:1.5}.invite-modal__form{gap:var(--space-3);flex-direction:column;display:flex}.invite-modal__row{gap:var(--space-3);align-items:stretch;display:flex}.invite-modal__input{flex:1;min-width:0}.invite-modal__add{flex-shrink:0;width:auto;min-width:72px}.invite-modal__success{margin:var(--space-3) 0 0;font-size:var(--text-caption-size);color:var(--status-success);letter-spacing:-.01em}.invite-modal__member-list{margin:var(--space-5) 0 0;gap:var(--space-2);flex-direction:column;padding:0;list-style:none;display:flex}.invite-modal__member-item{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);display:flex}.invite-modal__member-email{min-width:0;font-size:var(--text-body-sm-size);color:var(--label-default);word-break:break-all;letter-spacing:-.01em}.invite-modal__member-remove{width:28px;height:28px;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:14px;line-height:1}.invite-modal__member-remove:hover:not(:disabled){color:var(--status-critical);background:var(--status-critical-bg)}.invite-modal__member-empty{font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em}.invite-modal__link-box{padding:var(--space-4);background:var(--color-neutral-50);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md)}.invite-modal__link{font-size:var(--text-caption-size);color:var(--label-default);word-break:break-all;line-height:1.5;display:block}.invite-modal__link-actions{gap:var(--space-3);margin-top:var(--space-4);flex-wrap:wrap;display:flex}.invite-modal__link-actions .modal__button{flex:1;min-width:120px}.invite-modal__restricted{font-size:var(--text-body-sm-size);color:var(--label-subtle);letter-spacing:-.01em;margin:0}.avatar{background:hsl(var(--avatar-hue,210) 65% 45%);color:#fff;font-weight:var(--font-weight-bold);letter-spacing:-.02em;-webkit-user-select:none;user-select:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;position:relative;overflow:hidden}.avatar--sm{width:28px;height:28px;font-size:12px}.avatar--md{width:36px;height:36px;font-size:14px}.avatar--lg{width:80px;height:80px;font-size:32px}.avatar--interactive{cursor:pointer;border:none;padding:0}.avatar--interactive:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.avatar__initial{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.avatar__image{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.avatar--image .avatar__initial{position:absolute;inset:0}.avatar--image .avatar__image{z-index:1;position:relative}.avatar--uploading:after{content:"";z-index:2;background:#00000059;position:absolute;inset:0}.avatar__spinner{z-index:3;border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite avatar-spin;position:absolute}.avatar--lg .avatar__spinner{border-width:3px;width:28px;height:28px}@keyframes avatar-spin{to{transform:rotate(360deg)}}.members-modal{width:320px;max-width:90vw;max-height:min(70vh,480px);padding:var(--space-6) var(--space-5) var(--space-5);flex-direction:column;display:flex}.members-modal__title{margin:0 0 var(--space-4);font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-strong);text-align:center;letter-spacing:-.02em}.members-modal__list{gap:var(--space-2);flex-direction:column;min-height:0;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.members-modal__item{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);display:flex}.members-modal__avatar{flex-shrink:0}.members-modal__info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.members-modal__name-row{align-items:center;gap:var(--space-2);min-width:0;display:flex}.members-modal__name{min-width:0;font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-default);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;overflow:hidden}.members-modal__self{font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--label-subtle);flex-shrink:0}.members-modal__owner{flex-shrink:0;font-size:14px;line-height:1}.members-modal__email{font-size:var(--text-caption-size);color:var(--label-subtle);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;overflow:hidden}.members-modal__remove{width:28px;height:28px;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:14px;line-height:1}.members-modal__remove:hover:not(:disabled){color:var(--status-critical);background:var(--status-critical-bg)}.members-modal__remove:disabled{opacity:.5;cursor:not-allowed}.members-modal__actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.members-modal__transfer{font-family:inherit;font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--label-brand);background:var(--color-pine-50);border:1px solid var(--color-pine-200);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;flex-shrink:0;padding:6px 10px}.members-modal__transfer:hover:not(:disabled){background:var(--color-pine-100)}.members-modal__transfer:disabled{opacity:.5;cursor:not-allowed}.members-modal__confirm{z-index:10000;width:min(320px,90vw);padding:var(--space-6) var(--space-5);position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.members-modal__confirm-title{margin:0 0 var(--space-5);font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-strong);text-align:center;letter-spacing:-.01em;line-height:1.5}.members-modal__confirm-actions{gap:var(--space-3);display:flex}.members-modal__confirm-actions .modal__button{flex:1}.members-modal__status,.members-modal__empty{padding:var(--space-4) 0;font-size:var(--text-caption-size);color:var(--label-subtle);text-align:center;letter-spacing:-.01em;margin:0}.members-modal__error{margin:var(--space-3) 0 0;font-size:var(--text-caption-size);color:var(--status-critical);text-align:center;letter-spacing:-.01em}.image-lightbox{z-index:200;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.image-lightbox__toolbar{top:var(--space-5);right:var(--space-5);z-index:1;align-items:center;gap:var(--space-2);display:flex;position:fixed}.image-lightbox__download,.image-lightbox__close{border-radius:var(--radius-pill);color:#fff;cursor:pointer;width:44px;height:44px;transition:background var(--motion-duration-fast) var(--motion-ease-standard);background:#ffffff1f;border:none;justify-content:center;align-items:center;padding:0;font-size:20px;line-height:1;display:flex}.image-lightbox__close{font-size:28px}.image-lightbox__download:hover,.image-lightbox__close:hover{background:#ffffff38}.image-lightbox__content{justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;max-width:90vw;max-height:90vh;display:flex}.image-lightbox__image{object-fit:contain;border-radius:var(--radius-md);width:auto;max-width:90vw;height:auto;max-height:90vh;box-shadow:var(--shadow-4);-webkit-user-select:none;user-select:none;cursor:default;display:block}.image-lightbox__counter{font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:#ffffffbf;letter-spacing:-.01em;margin:0}.image-lightbox__nav{z-index:1;border-radius:var(--radius-pill);color:#fff;cursor:pointer;width:44px;height:44px;transition:background var(--motion-duration-fast) var(--motion-ease-standard);background:#ffffff1f;border:none;justify-content:center;align-items:center;padding:0;font-size:28px;line-height:1;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.image-lightbox__nav:hover{background:#ffffff38}.image-lightbox__nav--prev{left:var(--space-5)}.image-lightbox__nav--next{right:var(--space-5)}@media (width<=640px){.image-lightbox__toolbar{top:var(--space-3);right:var(--space-3)}.image-lightbox__nav--prev{left:var(--space-3)}.image-lightbox__nav--next{right:var(--space-3)}}.photo-album-modal{max-width:640px;max-height:min(88vh,760px);padding:var(--space-5) var(--space-6);flex-direction:column;display:flex}.photo-album__header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.photo-album__header .modal__title{text-align:left;margin:0}.photo-album__close{width:32px;height:32px;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;display:flex}.photo-album__close:hover{color:var(--label-default);background:var(--color-neutral-100)}.photo-album__content{gap:var(--space-5);flex-direction:column;flex:1;display:flex;overflow-y:auto}.photo-album__status,.photo-album__empty,.photo-album__error{margin:var(--space-6) 0;font-size:var(--text-body-sm-size);text-align:center;letter-spacing:-.01em}.photo-album__status,.photo-album__empty{color:var(--label-subtle)}.photo-album__error{color:var(--status-critical)}.photo-album__section{gap:var(--space-3);flex-direction:column;display:flex}.photo-album__date{font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:var(--label-subtle);letter-spacing:-.01em;margin:0}.photo-album__grid{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.photo-album__item{aspect-ratio:1;background:var(--color-neutral-100);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), transform var(--motion-duration-fast) var(--motion-ease-standard);padding:0;overflow:hidden}.photo-album__item:hover:not(:disabled){border-color:var(--chat-bubble-own-color);transform:scale(1.02)}.photo-album__item:disabled{cursor:wait}.photo-album__thumb{object-fit:cover;width:100%;height:100%;display:block}.photo-album__placeholder{background:linear-gradient(110deg, var(--color-neutral-100) 8%, var(--color-neutral-75) 18%, var(--color-neutral-100) 33%);background-size:200% 100%;width:100%;height:100%;animation:1.2s linear infinite photo-album-shimmer;display:block}@keyframes photo-album-shimmer{to{background-position-x:-200%}}@media (width>=520px){.photo-album__grid{grid-template-columns:repeat(4,1fr)}}.family-sidebar{background:var(--surface-default);border-right:1px solid var(--color-neutral-100);flex-direction:column;width:100%;height:100%;display:flex}.family-sidebar__header{padding:var(--space-5) var(--space-5) var(--space-4);border-bottom:1px solid var(--color-neutral-100)}.family-sidebar__title{margin:0 0 var(--space-4);font-size:var(--text-body-md-size);font-weight:var(--font-weight-bold);color:var(--label-brand);letter-spacing:-.015em}.family-sidebar__create{width:100%;height:40px;padding:0 var(--space-4);font-size:var(--text-body-xs-size);font-weight:var(--font-weight-semibold);color:var(--label-on-color);background:var(--action-primary);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard);border:none}.family-sidebar__create:hover{background:var(--action-primary-hover)}.family-sidebar__list{padding:var(--space-3) var(--space-2);gap:var(--space-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.family-sidebar__status{padding:var(--space-5) var(--space-4);font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em;margin:0;line-height:1.5}.family-sidebar__row{border-radius:var(--radius-md);border-left:3px solid #0000;align-items:stretch;display:flex;position:relative}.family-sidebar__row:hover{background:var(--color-neutral-50)}.family-sidebar__row--active{background:var(--color-pine-50);border-left-color:var(--chat-bubble-own-color)}.family-sidebar__item{min-width:0;padding:var(--space-4) var(--space-2) var(--space-4) var(--space-4);font-size:var(--text-body-sm-size);font-weight:var(--font-weight-medium);text-align:left;color:var(--label-default);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;background:0 0;border:none;flex:1}.family-sidebar__item-label{align-items:center;gap:.35em;min-width:0;max-width:100%;display:inline-flex}.family-sidebar__room-type,.family-sidebar__owner-badge{flex-shrink:0;font-size:.8em;line-height:1}.family-sidebar__room-name{text-overflow:ellipsis;white-space:nowrap;word-break:normal;min-width:0;overflow:hidden}.family-sidebar__item--active{color:var(--label-brand);font-weight:var(--font-weight-semibold)}.family-sidebar__menu-wrap{padding-right:var(--space-2);flex-shrink:0;align-items:center;display:flex;position:relative}.family-sidebar__menu-trigger{width:28px;height:28px;font-size:14px;font-weight:var(--font-weight-bold);letter-spacing:.1em;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--motion-duration-fast) var(--motion-ease-standard), color var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.family-sidebar__menu-trigger:hover,.family-sidebar__menu-trigger[aria-expanded=true]{color:var(--label-default);background:var(--color-neutral-100)}.family-sidebar__menu{z-index:20;min-width:140px;margin-top:var(--space-1);padding:var(--space-2);background:var(--surface-default);border:1px solid var(--color-neutral-100);border-radius:var(--radius-md);box-shadow:var(--shadow-3);position:absolute;top:100%;right:0}.family-sidebar__menu-item{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-body-xs-size);font-weight:var(--font-weight-medium);text-align:left;color:var(--label-default);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;display:block}.family-sidebar__menu-item:hover{background:var(--color-neutral-50)}.family-sidebar__menu-item--danger{color:var(--status-critical)}.family-sidebar__menu-item--danger:hover{background:var(--status-critical-bg)}.date-divider{align-items:center;gap:var(--space-4);width:100%;padding:var(--space-2) 0;display:flex}.date-divider__line{background:var(--color-neutral-200);flex:1;height:1px}.date-divider__label{font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--label-subtle);letter-spacing:-.01em;white-space:nowrap;flex-shrink:0}.image-context-menu{z-index:300;min-width:160px;padding:var(--space-2);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-3);position:fixed}.image-context-menu__item{width:100%;padding:var(--space-3) var(--space-4);font-family:inherit;font-size:var(--text-body-sm-size);font-weight:var(--font-weight-medium);color:var(--label-default);text-align:left;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;display:block}.image-context-menu__item:hover{background:var(--color-pine-50)}.message-gallery{gap:var(--space-2);width:100%;max-width:560px;display:grid}.message-gallery--cols-1{grid-template-columns:1fr}.message-gallery--cols-2{grid-template-columns:repeat(2,1fr)}.message-gallery--cols-3{grid-template-columns:repeat(3,1fr)}.message-gallery__cell{position:relative}.message-gallery__menu{top:var(--space-2);right:var(--space-2);z-index:2;border-radius:var(--radius-pill);color:#fff;cursor:pointer;opacity:0;width:28px;height:28px;transition:opacity var(--motion-duration-fast) var(--motion-ease-standard);background:#00000073;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;display:flex;position:absolute}.message-gallery__cell:hover .message-gallery__menu,.message-gallery__cell:focus-within .message-gallery__menu{opacity:1}.message-gallery__menu:hover{background:#0000009e}.message-gallery__item{cursor:zoom-in;border-radius:var(--radius-lg);background:0 0;border:none;width:100%;margin:0;padding:0;line-height:0;display:block;position:relative;overflow:hidden}.message-gallery__item:disabled{cursor:default}.message-gallery__frame{border-radius:var(--radius-lg);background:var(--color-neutral-100);width:100%;height:100%;display:block;overflow:hidden}.message-gallery--cols-1 .message-gallery__item{aspect-ratio:4/3;max-width:560px;max-height:420px}.message-gallery--cols-2 .message-gallery__item,.message-gallery--cols-3 .message-gallery__item{aspect-ratio:1}.message-gallery__image{object-fit:contain;border-radius:var(--radius-lg);width:100%;height:100%;transition:filter var(--motion-duration-fast) var(--motion-ease-standard);display:block}.message-gallery--cols-2 .message-gallery__image,.message-gallery--cols-3 .message-gallery__image{object-fit:cover}.message-gallery__placeholder{background:var(--color-neutral-100);width:100%;height:100%;animation:1.2s ease-in-out infinite gallery-pulse;display:block}@keyframes gallery-pulse{0%,to{opacity:.55}50%{opacity:1}}.message-gallery__item:hover:not(:disabled) .message-gallery__image,.message-gallery__item:focus-visible:not(:disabled) .message-gallery__image{filter:brightness(1.08)}.message-gallery__item:focus-visible{outline:2px solid var(--chat-bubble-own-color);outline-offset:2px}.message__menu{top:var(--space-2);right:calc(var(--space-2) + 52px);z-index:2;position:absolute}.message__menu-btn{width:28px;height:24px;font-family:inherit;font-size:14px;font-weight:var(--font-weight-medium);letter-spacing:.08em;color:var(--label-subtle);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-sm);cursor:pointer;opacity:0;box-shadow:var(--shadow-1);justify-content:center;align-items:center;padding:0;line-height:1;transition:opacity .15s;display:flex}.message:hover .message__menu-btn,.message:focus-within .message__menu-btn,.message__menu-btn:focus-visible,.message__menu-btn[aria-expanded=true]{opacity:1}.message__menu-btn:hover{color:var(--chat-bubble-own-color);border-color:var(--chat-bubble-own-color)}.message__menu-dropdown{z-index:4;background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-sm);min-width:88px;box-shadow:var(--shadow-2);padding:4px;position:absolute;top:calc(100% + 4px);right:0}.message__menu-item{width:100%;font-family:inherit;font-size:13px;font-weight:var(--font-weight-medium);color:var(--label-default);text-align:left;border-radius:var(--radius-xs,4px);cursor:pointer;background:0 0;border:none;padding:8px 12px;display:block}.message__menu-item:hover{background:var(--color-neutral-50)}.message__menu-item--danger{color:var(--color-danger,#e53935)}.message__menu-item--danger:hover{background:#e5393514}.read-status{flex-shrink:0;align-items:center;line-height:0;display:inline-flex}.read-status__icon{display:block}.read-status--sent{color:var(--label-disabled)}.read-status--read{color:var(--chat-bubble-own-color,#3b82f6)}.message__reactions{flex-wrap:wrap;gap:4px;margin-top:2px;display:flex}.message--own .message__reactions{align-self:flex-end}.message--other .message__reactions{align-self:flex-start}.message__reaction-chip{font-size:14px;font-weight:var(--font-weight-medium,500);color:var(--label-default);background:var(--surface-default);border:1px solid var(--color-neutral-100);box-shadow:var(--shadow-1);cursor:pointer;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), background var(--motion-duration-fast) var(--motion-ease-standard);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;line-height:1;display:inline-flex}.message__reaction-chip:hover{border-color:var(--chat-theme-border-strong)}.message__reaction-chip--own{color:var(--chat-bubble-own-color);background:var(--chat-theme-surface);border-color:var(--chat-bubble-own-color)}.message__reaction-emoji{flex-shrink:0;line-height:1}.message__reaction-count{letter-spacing:-.02em;font-size:14px}.message__bubble{width:100%;position:relative}.message__bubble--reactable{cursor:default}.message__reply-btn{top:var(--space-2);left:var(--space-2);z-index:2;font-family:inherit;font-size:11px;font-weight:var(--font-weight-medium);color:var(--label-subtle);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-sm);cursor:pointer;opacity:0;box-shadow:var(--shadow-1);align-items:center;gap:4px;padding:4px 8px;transition:opacity .15s;display:flex;position:absolute}.message--own .message__reply-btn{left:auto;right:var(--space-2)}.message:hover .message__reply-btn,.message:focus-within .message__reply-btn,.message__reply-btn:focus-visible{opacity:1}.message__reply-btn:hover{color:var(--chat-bubble-own-color);border-color:var(--chat-bubble-own-color)}.message__emoji-pop{z-index:3;pointer-events:none;animation:message-emoji-pop .85s var(--motion-ease-emphasized,ease) forwards;font-size:40px;line-height:1;position:absolute;top:40%;left:50%}@keyframes message-emoji-pop{0%{opacity:0;transform:translate(-50%,8px)scale(.4)}18%{opacity:1;transform:translate(-50%,-6px)scale(1.15)}to{opacity:0;transform:translate(-50%,-42px)scale(1)}}.message-reply-quote{gap:var(--space-2);margin-bottom:var(--space-2);padding:var(--space-2) var(--space-3);background:color-mix(in srgb, var(--chat-bubble-own-color) 8%, var(--surface-default));border-radius:var(--radius-md);text-align:left;cursor:pointer;border:none;width:100%;font-family:inherit;transition:opacity .15s;display:flex}.message-reply-quote:hover{opacity:.88}.message--own .message-reply-quote{background:#ffffff1f}.message-reply-quote__bar{background:var(--chat-bubble-own-color);border-radius:999px;flex-shrink:0;width:3px}.message-reply-quote__content{flex-direction:column;gap:2px;min-width:0;display:flex}.message-reply-quote__sender{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--chat-bubble-own-color);letter-spacing:-.01em}.message--other .message-reply-quote__sender{color:var(--chat-bubble-own-color)}.message-reply-quote__text{font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;line-height:1.4;overflow:hidden}.message--own .message-reply-quote__text{color:#ffffffd1}.reaction-picker{z-index:5;background:var(--surface-default);border:1px solid var(--color-neutral-200);max-width:min(480px,92vw);box-shadow:var(--shadow-3);border-radius:20px;flex-wrap:wrap;justify-content:center;gap:10px;padding:12px 14px;display:flex;position:absolute;top:-8px;left:50%;transform:translate(-50%,-100%)}.message--own .reaction-picker{left:auto;right:0;transform:translateY(-100%)}.message--other .reaction-picker{left:0;right:auto;transform:translateY(-100%)}.reaction-picker__item{cursor:pointer;width:56px;height:56px;transition:transform var(--motion-duration-fast) var(--motion-ease-standard), background var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;border-radius:999px;justify-content:center;align-items:center;padding:0;line-height:1;display:flex}.reaction-picker__item:hover{background:var(--chat-theme-surface);transform:scale(1.12)}.message-bomb{align-items:flex-start;gap:var(--space-1);width:100%;padding:var(--space-4) var(--space-5);text-align:left;background:var(--surface-default);border:1px dashed var(--chat-bubble-own-color);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard);flex-direction:column;display:flex}.message-bomb:hover{background:var(--chat-theme-surface);border-color:var(--chat-bubble-own-color)}.message-bomb__title{font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-strong);letter-spacing:-.01em}.message-bomb__hint{font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em}.message-bomb__own{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.message-bomb__own--image{max-width:min(100%,560px)}.message-bomb__revealed{gap:var(--space-2);flex-direction:column;width:100%;max-width:min(100%,560px);display:flex}.message-bomb__countdown{padding:0 var(--space-1);font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--chat-bubble-own-color);letter-spacing:-.01em;margin:0}.message-bomb__reading{font-weight:var(--font-weight-semibold)}.message__body--bomb-own .message-bomb__countdown{padding:var(--space-2) var(--space-5) 0}.message-bomb__countdown--done{color:var(--label-subtle)}.message__body--bomb-own .message-bomb__own-label{margin:0 0 var(--space-1);padding:0 var(--space-5);font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:var(--chat-bubble-own-color);letter-spacing:-.01em}.message__edit{gap:var(--space-2);flex-direction:column;width:100%;display:flex}.message__edit-input{width:100%;min-width:200px;max-width:100%;padding:var(--space-2) var(--space-3);color:inherit;background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-sm);resize:vertical;font-family:inherit;font-size:14px;line-height:1.5}.message__edit-input:focus{outline:2px solid var(--chat-bubble-own-color);outline-offset:1px}.message__edit-actions{justify-content:flex-end;gap:var(--space-2);display:flex}.message__edit-btn{font-family:inherit;font-size:12px;font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--color-neutral-200);background:var(--surface-default);color:var(--label-default);padding:6px 12px}.message__edit-btn--confirm{color:var(--surface-default);background:var(--chat-bubble-own-color);border-color:var(--chat-bubble-own-color)}.message__edit-btn:disabled{opacity:.5;cursor:not-allowed}.message__edit-error{color:var(--color-danger,#e53935);margin:0;font-size:12px}.message__embeds{gap:var(--space-3);width:100%;min-width:0;margin-top:var(--space-2);flex-direction:column;display:flex}.youtube-card{box-sizing:border-box;background:var(--surface-default);border:1px solid var(--color-neutral-100);border-radius:var(--radius-lg);width:100%;max-width:100%;box-shadow:var(--shadow-1);overflow:hidden}.youtube-card__media{aspect-ratio:16/9;background:#000;width:100%;position:relative}.youtube-card__thumb{cursor:pointer;background:#000;border:none;width:100%;height:100%;padding:0;display:block;position:absolute;inset:0}.youtube-card__thumb-image{object-fit:cover;width:100%;height:100%;display:block}.youtube-card__thumb:after{content:"";pointer-events:none;background:#0000001f;transition:background-color .2s;position:absolute;inset:0}.youtube-card__thumb:hover:after,.youtube-card__thumb:focus-visible:after{background:#00000047}.youtube-card__play{z-index:1;filter:drop-shadow(0 4px 16px #00000073);pointer-events:none;transition:transform .2s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.youtube-card__thumb:hover .youtube-card__play,.youtube-card__thumb:focus-visible .youtube-card__play{transform:translate(-50%,-50%)scale(1.06)}.youtube-card__play-bg{fill:#ff0000eb}.youtube-card__play-triangle{fill:#fff}.youtube-card__frame{border:0;width:100%;height:100%;position:absolute;inset:0}.youtube-card__info{gap:var(--space-2);min-height:4.5rem;padding:var(--space-3) var(--space-4) var(--space-4);box-sizing:border-box;flex-direction:column;display:flex}.youtube-card__title--placeholder{visibility:hidden;pointer-events:none}.youtube-card__title{font-size:var(--text-body-sm-size);color:var(--label-default);letter-spacing:-.01em;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-weight:600;line-height:1.45;text-decoration:none;display:-webkit-box;overflow:hidden}.youtube-card__title:hover{color:var(--chat-bubble-own-color,#1e3a33)}.youtube-card__source{align-items:center;gap:var(--space-2);width:fit-content;font-size:var(--text-caption-size,.75rem);color:var(--label-secondary);font-weight:500;text-decoration:none;display:inline-flex}.youtube-card__source:hover{color:var(--label-default)}.youtube-card__brand-icon{flex-shrink:0}.vimeo-card__play-bg{fill:#1ab7eaeb}.vimeo-card__placeholder{background:linear-gradient(135deg,#1ab7ea 0%,#162221 100%);width:100%;height:100%;display:block}.message-translation__reserve{min-height:4.5em;margin-top:var(--space-2);box-sizing:border-box}.message-translation__reserve--loading{border-radius:var(--radius-sm);background:linear-gradient(90deg,#0000000a 0%,#00000014 50%,#0000000a 100%) 0 0/200% 100%;animation:1.2s ease-in-out infinite message-translation-shimmer}.message--own .message-translation__reserve--loading{background:linear-gradient(90deg,#ffffff14 0%,#ffffff29 50%,#ffffff14 100%) 0 0/200% 100%}@keyframes message-translation-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.message-translation__loading{padding:var(--space-2) var(--space-5) 0;font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em;margin:0}.message-translation__divider{margin:var(--space-2) var(--space-5) 0;border:none;border-top:1px solid var(--color-neutral-200);opacity:.6}.message--own .message-translation__divider{border-top-color:#ffffff59}.message-translation__translated{padding-bottom:calc(var(--space-4) + 4px);position:relative}.message-translation__translated .message__content{font-size:calc(var(--text-body-sm-size) * .9);opacity:.75;padding-top:var(--space-2);padding-bottom:var(--space-2);font-style:italic;box-shadow:none!important;background:0 0!important;border:none!important}.message-translation__footer{padding:0 var(--space-5) var(--space-2);justify-content:flex-end;display:flex}.message-translation__toggle{margin-top:var(--space-1);padding:2px var(--space-2);font-size:11px;font-weight:var(--font-weight-medium);color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;transition:color var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none}.message-translation__translated .message-translation__toggle{right:var(--space-3);bottom:var(--space-2);margin-top:0;position:absolute}.message-translation__toggle:hover{color:var(--label-default)}.message--own .message-translation__toggle{color:#ffffffb3}.message--own .message-translation__toggle:hover{color:#fff}.file-card{align-items:center;gap:var(--space-3);width:100%;min-width:0;padding:var(--space-3) var(--space-4);border:1px solid var(--color-neutral-100);background:#ffffffb8;border-radius:12px;display:flex}.message--own .file-card{background:#ffffff2e;border-color:#ffffff47}.file-card__icon{flex-shrink:0;font-size:1.75rem;line-height:1}.file-card__info{flex:1;min-width:0}.file-card__name{font-size:var(--text-body-sm-size);color:var(--label-default);letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;margin:0;font-weight:600;overflow:hidden}.message--own .file-card__name,.message--own .file-card__size{color:inherit}.file-card__size{font-size:var(--text-caption-size);color:var(--label-secondary);margin:.125rem 0 0}.file-card__download{font-family:inherit;font-size:var(--text-caption-size);color:var(--label-brand);background:var(--surface-default);border:1px solid var(--color-neutral-200);cursor:pointer;border-radius:999px;flex-shrink:0;padding:.45rem .75rem;font-weight:600;transition:background .2s}.message--own .file-card__download{color:inherit;background:#ffffffeb;border-color:#ffffff80}.file-card__download:hover:not(:disabled){background:var(--color-neutral-50)}.file-card__download:disabled{opacity:.6;cursor:not-allowed}.message--system{padding:var(--space-2) var(--space-5);justify-content:center;display:flex}.message__system{font-size:var(--text-caption-size);color:var(--label-subtle);text-align:center;letter-spacing:-.01em;margin:0;line-height:1.4}.unread-divider{align-items:center;gap:var(--space-4);width:100%;padding:var(--space-2) 0;display:flex}.unread-divider__line{background:#c4b5fd;flex:1;height:1px}.unread-divider__label{font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:#7c3aed;letter-spacing:-.01em;white-space:nowrap;flex-shrink:0}.unread-divider--pending{visibility:hidden}.profile-menu{top:calc(100% + 8px);left:var(--space-5);right:var(--space-5);z-index:30;padding:var(--space-3);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-3);flex-direction:column;gap:2px;display:flex;position:absolute}.profile-menu__header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);padding:0 var(--space-2) var(--space-2);border-bottom:1px solid var(--color-neutral-100);display:flex}.profile-menu__greeting{color:var(--label-subtle);margin:0;font-size:13px}.profile-menu__file-input{display:none}.profile-menu__item{width:100%;font-family:inherit;font-size:14px;font-weight:var(--font-weight-medium);color:var(--label-default);text-align:left;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;padding:10px 12px}.profile-menu__item:hover{background:var(--color-neutral-50)}.profile-menu__divider{height:1px;margin:var(--space-2) 0 var(--space-1);background:var(--color-neutral-100)}.profile-menu__item--logout{color:#dc2626}.profile-menu__item--logout:hover{background:#fef2f2}.qr-login-modal{max-width:360px}.qr-login-modal__guide{margin:0 0 var(--space-4);color:var(--label-subtle);text-align:center;letter-spacing:-.01em;font-size:14px;line-height:1.55}.qr-login-modal__code-wrap{min-height:280px;margin:0 0 var(--space-4);padding:var(--space-3);background:var(--color-neutral-50);border:1px solid var(--color-neutral-100);border-radius:var(--radius-lg);justify-content:center;align-items:center;display:flex}.qr-login-modal__code{border-radius:var(--radius-md);transition:opacity .2s;display:block}.qr-login-modal__code--expired{opacity:.45}.qr-login-modal__status{color:var(--label-subtle);margin:0;font-size:14px}.qr-login-modal__timer{margin:0 0 var(--space-2);font-size:14px;font-weight:var(--font-weight-semibold);color:var(--label-default);text-align:center;letter-spacing:-.01em}.qr-login-modal__timer--urgent{color:#dc2626}.qr-login-modal__timer--expired{color:#dc2626;font-weight:var(--font-weight-bold)}.qr-login-modal__warning{margin:0 0 var(--space-4);color:#c2410c;text-align:center;letter-spacing:-.01em;font-size:12px;line-height:1.5}.qr-login-modal__regenerate{width:100%;margin:0 0 var(--space-4);font-family:inherit;font-size:14px;font-weight:var(--font-weight-semibold);color:var(--label-on-color);background:var(--action-primary);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;border:none;padding:.75rem 1rem;display:block}.qr-login-modal__regenerate:hover:not(:disabled){background:var(--action-primary-hover)}.qr-login-modal__regenerate:disabled{opacity:.6;cursor:not-allowed}.chat-layout{background:var(--background-subtle);width:100%;max-width:100%;height:100dvh;max-height:100dvh;color:var(--label-default);grid-template-columns:220px minmax(0,1fr);display:grid;overflow:hidden}@supports (-webkit-touch-callout:none){.chat-layout{height:-webkit-fill-available;max-height:-webkit-fill-available}}.chat-layout__sidebar{grid-column:1;min-width:0;height:100%;overflow:hidden}.chat-layout__main{background:var(--surface-default);flex-direction:column;grid-column:2;min-width:0;height:100%;display:flex;overflow:hidden}.chat-layout__overlay,.chat__menu-button,.chat__mobile-bar{display:none}.chat__header-leading{align-items:center;gap:var(--space-3);min-width:0;display:flex}.chat__header-leading .chat__title{align-items:center;gap:var(--space-2);min-width:0;margin-bottom:0;display:flex}.chat__title-text{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.chat__member-count{font-family:inherit;font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--label-subtle);letter-spacing:-.01em;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;flex-shrink:0;padding:0}.chat__member-count:hover{color:var(--label-brand)}.chat__mobile-bar-heading{align-items:center;gap:var(--space-2);min-width:0;font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-brand);letter-spacing:-.015em;display:flex}.chat__mobile-bar-heading .chat__title-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.chat__mobile-bar-heading .chat__member-count{font-size:var(--text-caption-size)}.chat__mobile-bar{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-neutral-100);background:var(--surface-default);flex-shrink:0}.chat__mobile-bar-title{font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-brand);letter-spacing:-.015em}.chat__menu-button{width:40px;height:40px;color:var(--label-default);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard);flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:22px;line-height:1}.chat__menu-button:hover{background:var(--chat-theme-surface);border-color:var(--chat-bubble-own-color)}.chat__header-profile{display:none}.chat__profile-wrap--desktop{display:block}@media (width<=768px){.chat-layout{transform-origin:0 0;flex-direction:column;grid-template-columns:none;width:100%;max-width:100%;height:100dvh;max-height:100dvh;display:flex;position:relative;overflow:hidden}@supports (-webkit-touch-callout:none){.chat-layout{height:-webkit-fill-available;max-height:-webkit-fill-available}}.chat-layout__sidebar{z-index:210;width:min(280px, calc(100vw - env(safe-area-inset-left,0px)));visibility:hidden;pointer-events:none;max-width:280px;transition:transform .28s var(--motion-ease-emphasized,ease);box-shadow:var(--shadow-4);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.chat-layout--sidebar-open .chat-layout__sidebar{visibility:visible;pointer-events:auto;transform:translate(0)}.chat-layout__overlay{z-index:200;opacity:0;pointer-events:none;transition:opacity .28s var(--motion-ease-standard,ease);cursor:pointer;background:#00000073;border:none;padding:0;display:block;position:fixed;inset:0}.chat-layout--sidebar-open .chat-layout__overlay{opacity:1;pointer-events:auto}.chat-layout__main{flex-direction:column;flex:1;width:100%;max-width:100%;min-height:0;display:flex;overflow:hidden}.chat__room{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.chat__header{flex-shrink:0}.chat__main{-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;min-height:0;scroll-padding-bottom:var(--chat-input-height,0px);flex:1;overflow-y:auto}.chat__main::-webkit-scrollbar{display:none}.chat-input-wrap{background:var(--surface-default);flex-shrink:0;min-height:0;position:relative}.chat__menu-button,.chat__mobile-bar{display:flex}.chat__panel-empty{flex-direction:column;justify-content:flex-start;align-items:stretch;padding:0}.chat__panel-empty .chat__status{padding:var(--space-8) var(--space-5);flex:1;justify-content:center;align-items:center;margin:0;display:flex}.chat__header{padding-top:max(var(--space-3), env(safe-area-inset-top,0px));padding-right:max(var(--space-4), env(safe-area-inset-right,0px));padding-bottom:var(--space-3);padding-left:max(var(--space-4), env(safe-area-inset-left,0px))}.chat__header-top{gap:var(--space-2);min-height:44px}.chat__header-leading{gap:var(--space-2);flex:1;min-width:0}.chat__header-actions{gap:var(--space-1);flex-shrink:0}.chat__title{font-size:var(--text-heading-sm-size);margin:0;line-height:1.2}.chat__menu-button{width:44px;min-width:44px;height:44px;min-height:44px}.chat__album-button,.chat__settings-button{width:44px;min-width:44px;height:44px;min-height:44px;font-size:20px}.chat__invite-button{height:44px;min-height:44px;padding:0 var(--space-3);white-space:nowrap;font-size:12px}.chat__header-profile{flex-shrink:0;display:block;position:relative}.chat__profile-button{cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;min-height:44px;padding:0;display:flex}.chat__profile-button .avatar{width:36px;height:36px}.chat__header-profile .profile-menu{min-width:180px;top:calc(100% + 6px);left:auto;right:0}.chat__profile-wrap--desktop{display:none}.chat__main{padding:var(--space-4);padding-left:max(var(--space-4), env(safe-area-inset-left,0px));padding-right:max(var(--space-4), env(safe-area-inset-right,0px))}.message--text{max-width:85%}.message--image-only,.message--embed,.message--embed-only{width:85%;max-width:85%}.chat-input{box-sizing:border-box;gap:var(--space-2);width:100%;padding:var(--space-3) max(var(--space-4), env(safe-area-inset-right,0px)) max(var(--space-3), env(safe-area-inset-bottom,0px)) max(var(--space-4), env(safe-area-inset-left,0px));min-height:56px}.chat-input__emoji,.chat-input__bomb{width:44px;min-width:44px;height:44px;min-height:44px}.chat-input__attach{min-width:44px;height:44px;min-height:44px;padding:0 var(--space-3);font-size:12px}.chat-input__field{box-sizing:border-box;width:100%;min-width:0;min-height:44px;max-height:120px;padding:10px var(--space-3);flex:1;font-size:16px;line-height:1.5}.chat-input__button{min-width:52px;height:44px;min-height:44px;padding:0 var(--space-4);flex-shrink:0;align-self:flex-end}.chat-input__reply-banner,.chat-input__bomb-notice,.chat-input__error{padding-left:var(--space-4);padding-right:var(--space-4)}.chat-input__commands{left:var(--space-4);right:var(--space-4)}.chat__background-clear{display:none}.chat__action-message{padding-left:var(--space-4);padding-right:var(--space-4)}}.chat__action-message{padding:var(--space-3) var(--space-7);font-size:var(--text-caption-size);color:var(--chat-bubble-own-color);background:var(--chat-theme-surface);border-bottom:1px solid var(--chat-theme-border);letter-spacing:-.01em;text-align:center;flex-shrink:0;margin:0}.chat__panel-empty{padding:var(--space-8) var(--space-7);color:var(--label-subtle);font-size:var(--text-body-sm-size);letter-spacing:-.01em;flex:1;justify-content:center;align-items:center;display:flex}.chat__room{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.chat__header{padding:var(--space-5) var(--space-7) var(--space-4);border-bottom:1px solid var(--color-neutral-100);background:var(--surface-default);flex-shrink:0}.chat__notice-banner{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--chat-theme-surface,var(--color-pine-50));border-bottom:1px solid var(--chat-theme-border,var(--color-pine-100));flex-shrink:0;display:flex}.chat__notice-icon{flex-shrink:0;font-size:16px;line-height:1.4}.chat__notice-text{min-width:0;font-size:var(--text-body-sm-size);color:var(--label-default);white-space:pre-wrap;word-break:break-word;letter-spacing:-.01em;flex:1;margin:0;line-height:1.5}.chat__notice-dismiss{width:28px;height:28px;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:14px;line-height:1;display:flex}.chat__notice-dismiss:hover{color:var(--label-default);background:var(--color-neutral-100)}.chat__header-top{justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.chat__header-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.chat__background-clear{height:36px;padding:0 var(--space-4);font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:var(--label-subtle);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-pill);cursor:pointer;letter-spacing:-.01em;transition:color var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard)}.chat__background-clear:hover{color:var(--chat-bubble-own-color,#3b82f6);border-color:var(--chat-bubble-own-color,#3b82f6)}.chat__album-button,.chat__settings-button{background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-pill);cursor:pointer;width:36px;height:36px;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard);justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;display:flex}.chat__album-button:hover,.chat__settings-button:hover{background:color-mix(in srgb, var(--chat-bubble-own-color,#3b82f6) 12%, transparent);border-color:var(--chat-bubble-own-color,#3b82f6)}.chat__invite-button{height:36px;padding:0 var(--space-4);font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:#fff;background:var(--chat-bubble-own-color,#3b82f6);border-radius:var(--radius-pill);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard);border:none}.chat__invite-button:hover{background:color-mix(in srgb, var(--chat-bubble-own-color,#3b82f6) 85%, #000)}.chat__invite-message{margin:var(--space-3) 0 0;font-size:var(--text-caption-size);color:var(--label-accent);letter-spacing:-.01em}.chat__title{margin:0 0 var(--space-1);font-size:var(--text-heading-md-size);font-weight:var(--font-weight-bold);color:var(--label-brand);letter-spacing:-.015em}.chat__profile-wrap{position:relative}.chat__profile{align-items:center;gap:var(--space-3);padding:var(--space-1) 0;font-family:inherit;font-size:var(--text-body-sm-size);color:var(--label-subtle);cursor:pointer;letter-spacing:-.01em;transition:color var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;margin:0;display:inline-flex}.chat__profile:hover{color:var(--label-default)}.chat__profile-greeting strong{color:var(--label-brand);font-weight:var(--font-weight-semibold)}.chat__profile-edit{font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--label-subtle);text-underline-offset:2px;text-decoration:underline}.chat__profile:hover .chat__profile-edit{color:var(--label-brand)}.chat__main{overflow-anchor:none;scroll-behavior:auto;min-height:0;padding:var(--space-5) var(--space-7);background-color:var(--chat-theme-color,var(--background-subtle));contain:layout;flex:1;position:relative;overflow:hidden auto}.chat__main--room-loading{overflow-y:hidden}.chat__main--has-bg{background-color:var(--chat-theme-color,var(--background-subtle));background-image:var(--chat-bg-image);background-position:50%;background-repeat:no-repeat;background-size:cover}.chat__main--has-bg:before{content:"";z-index:0;pointer-events:none;background:#ffffffd6;position:absolute;inset:0}.chat__main--has-bg>*{z-index:1;position:relative}.chat__main--dragging{outline:2px dashed var(--chat-bubble-own-color);outline-offset:-8px}.chat__drop-overlay{z-index:10;justify-content:center;align-items:center;gap:var(--space-3);pointer-events:none;background:#ffffffe0;flex-direction:column;display:flex;position:absolute;inset:0}.chat__drop-overlay-text{font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-brand);letter-spacing:-.01em;margin:0}.chat__drop-overlay-hint{font-size:var(--text-body-sm-size);color:var(--label-subtle);letter-spacing:-.01em;margin:0}.chat__drop-message{margin:0 0 var(--space-5);padding:var(--space-4);font-size:var(--text-body-sm-size);color:var(--status-critical);background:var(--status-critical-bg);border:1px solid var(--color-red-100);border-radius:var(--radius-md);text-align:center;letter-spacing:-.01em}.chat__drop-status{margin:0 0 var(--space-5);padding:var(--space-4);font-size:var(--text-body-sm-size);color:var(--chat-bubble-own-color);background:var(--chat-theme-surface);border:1px solid var(--chat-theme-border);border-radius:var(--radius-md);text-align:center;letter-spacing:-.01em}.chat__status,.chat__empty{padding:var(--space-8) var(--space-7);font-size:var(--text-body-sm-size);color:var(--label-subtle);text-align:center;letter-spacing:-.01em;margin:0}.chat__error{margin:0 0 var(--space-5);padding:var(--space-4);font-size:var(--text-body-sm-size);color:var(--status-critical);background:var(--status-critical-bg);border:1px solid var(--color-red-100);border-radius:var(--radius-md);letter-spacing:-.01em}.message-list{align-items:stretch;gap:var(--space-4);overflow-anchor:none;contain:layout;flex-direction:column;width:100%;max-width:100%;display:flex}.message-list--loading{flex:1;min-height:100%}.message-list--settling .message,.message-list--mount-settled .message,.chat__main--room-loading .message{animation:none}.message{gap:var(--space-1);flex-direction:column;max-width:100%;display:flex}.message--highlight{animation:1.5s ease-out highlightFlash}@keyframes highlightFlash{0%{background-color:#6366f133}to{background-color:#0000}}@media (prefers-reduced-motion:no-preference){.message{animation:message-enter .32s var(--motion-ease-emphasized) both}}@keyframes message-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message--text{max-width:75%}.message--emoji-only{max-width:none}.message--emoji-only .message__bubble{padding:0;box-shadow:none!important;background:0 0!important;border:none!important}.message--emoji-only .message__bubble--emoji-only{width:auto}.message--image-only,.message--embed,.message--embed-only{align-items:stretch;width:min(100%,560px);max-width:560px}.message--own{align-self:flex-end;align-items:flex-end}.message--other{align-self:flex-start;align-items:flex-start}.message--own.message--embed,.message--own.message--embed-only,.message--other.message--embed,.message--other.message--embed-only,.message--own.message--image-only,.message--other.message--image-only{align-items:stretch}.message--embed .message__embeds,.message--embed-only .message__embeds{align-self:stretch;width:100%;min-width:0}.message--compact-time{gap:var(--space-1)}.message--compact-time.message--own+.message--compact-time.message--own,.message--compact-time.message--other+.message--compact-time.message--other{margin-top:calc(var(--space-1) * -1)}.message__row{align-items:flex-end;gap:var(--space-2);max-width:100%;display:flex}.message__avatar{align-self:flex-end;margin-bottom:2px}.message__avatar--spacer{flex-shrink:0;width:28px;height:28px;display:block}.message--own .message__row{justify-content:flex-end}.message--other .message__row{justify-content:flex-start}.message__content-area{min-width:0;max-width:100%}.message__media{margin-bottom:var(--space-2)}.message__body{border-radius:var(--radius-lg);flex-direction:column;display:flex;position:relative;overflow:hidden}.message__body--copyable .message__content{padding-top:calc(var(--space-4) + 4px);padding-right:calc(var(--space-5) + 28px)}.message__copy-btn{top:var(--space-2);right:var(--space-2);z-index:1;border-radius:var(--radius-sm);cursor:pointer;opacity:0;border:none;justify-content:center;align-items:center;width:28px;height:28px;padding:0;transition:opacity .15s,background-color .15s;display:flex;position:absolute}.message:hover .message__copy-btn,.message:focus-within .message__copy-btn,.message__copy-btn:focus-visible{opacity:1}.message--own .message__copy-btn{color:#fff;background:#fff3}.message--own .message__copy-btn:hover{background:#ffffff52}.message--other .message__copy-btn{color:var(--label-default);background:#0000000f}.message--other .message__copy-btn:hover{background:#0000001a}.message__content{padding:var(--space-4) var(--space-5);font-size:var(--text-body-sm-size);border-radius:var(--radius-lg);word-break:break-word;letter-spacing:-.01em;margin:0;line-height:1.5}.message--own .message__body{border-bottom-right-radius:var(--radius-sm)}.message--other .message__body{border-bottom-left-radius:var(--radius-sm)}.message--own .message__content{background:var(--chat-bubble-own-color,#3b82f6);color:#fff}.message--other .message__content{background:var(--surface-default);color:var(--label-default);border:1px solid var(--color-neutral-100);box-shadow:var(--shadow-1)}.message__link{color:inherit;text-underline-offset:2px;word-break:break-all;text-decoration:underline}.message__link:hover{opacity:.85}.message--own .message__link{color:#fff}.message--other .message__link{color:var(--chat-bubble-own-color,#3b82f6)}.message__markdown{gap:var(--space-1);flex-direction:column;display:flex}.message__md-line{margin:0}.message__md-spacer{height:.5em}.message__heading{font-weight:var(--font-weight-bold);letter-spacing:-.02em;margin:0;line-height:1.35}.message__heading--h1{font-size:28px}.message__heading--h2{font-size:22px}.message__heading--h3{font-size:18px}.message__md-bold{font-weight:var(--font-weight-bold)}.message__md-italic{font-style:italic}.message__md-strike{text-decoration:line-through}.message__md-red{color:var(--status-critical)}.message--own .message__md-red,.message--own .message__md-red .message__link{color:#fecaca}.message__code{border-radius:var(--radius-sm);background:#00000014;padding:.1em .35em;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.9em}.message--own .message__code{background:#fff3}.message__table-wrap{max-width:100%;margin:var(--space-2) 0;border-radius:var(--radius-md);overflow-x:auto}.message__table{border-collapse:collapse;width:100%;min-width:240px;font-size:var(--text-caption-size);line-height:1.45}.message__table th,.message__table td{border:1px solid var(--color-neutral-200);padding:var(--space-2) var(--space-3);text-align:left;vertical-align:top}.message__table th{font-weight:var(--font-weight-semibold);background:#0000000a}.message--own .message__table th,.message--own .message__table td{border-color:#ffffff59}.message--own .message__table th{background:#ffffff26}.message__sender{margin-bottom:var(--space-1);padding:0 var(--space-1);font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:var(--label-subtle);letter-spacing:-.01em;display:block}.message__meta{align-items:center;gap:var(--space-2);padding:0 var(--space-1);margin-top:var(--space-1);display:flex}.message--own .message__meta{flex-direction:row-reverse}.message__time{font-size:11px;font-weight:var(--font-weight-medium);color:var(--label-subtle);letter-spacing:-.01em;white-space:nowrap}.message__time--compact{color:var(--label-disabled);font-size:10px}.message__time--side{padding-bottom:var(--space-1);flex-shrink:0;align-self:flex-end}.message__meta--status-only{padding-top:0}.message--deleted{opacity:.85}.message__bubble--deleted{padding:var(--space-2) var(--space-3);background:var(--color-neutral-100);border-radius:var(--radius-md)}.message__deleted-text{color:var(--label-subtle);font-size:13px;font-style:italic}.message__edited{padding:0 var(--space-1);color:var(--label-disabled);margin-top:2px;font-size:10px;display:block}.message--own .message__edited{text-align:right}.message--other .message__edited{text-align:left}.chat-input-wrap{border-top:1px solid var(--color-neutral-100);background:var(--surface-default);flex-shrink:0;min-height:0;position:relative}.chat-input__reply-banner{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-7);background:var(--chat-theme-surface);border-bottom:1px solid var(--chat-theme-border);display:flex}.chat-input__reply-info{flex-direction:column;gap:2px;min-width:0;display:flex}.chat-input__reply-label{font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:var(--chat-bubble-own-color);letter-spacing:-.01em}.chat-input__reply-preview{color:var(--label-subtle);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;font-size:11px;overflow:hidden}.chat-input__reply-cancel{width:28px;height:28px;color:var(--label-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:14px;display:flex}.chat-input__reply-cancel:hover{color:var(--label-default);background:var(--color-neutral-100)}.chat-input__emoji{background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;width:44px;height:44px;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard);flex-shrink:0;padding:0;font-size:22px;line-height:1}.chat-input__emoji:hover:not(:disabled){background:var(--chat-theme-surface);border-color:var(--chat-bubble-own-color)}.chat-input__emoji:disabled{opacity:.6;cursor:not-allowed}.chat-input__commands{bottom:100%;left:var(--space-7);right:var(--space-7);z-index:20;gap:var(--space-1);margin-bottom:var(--space-2);padding:var(--space-2);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);box-shadow:var(--shadow-3);flex-direction:column;display:flex;position:absolute}.chat-input__command{align-items:baseline;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);text-align:left;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--motion-duration-fast) var(--motion-ease-standard);background:0 0;border:none;font-family:inherit;display:flex}.chat-input__command:hover{background:var(--color-neutral-50)}.chat-input__command-label{font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-brand);letter-spacing:-.01em;flex-shrink:0}.chat-input__command-desc{font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em}.chat-input--bomb{background:var(--chat-theme-surface);border-radius:var(--radius-md)}.chat-input__bomb-notice{padding:var(--space-3) var(--space-7) 0;font-size:var(--text-caption-size);font-weight:var(--font-weight-medium);color:var(--chat-bubble-own-color);letter-spacing:-.01em;margin:0}.chat-input{align-items:flex-end;gap:var(--space-3);box-sizing:border-box;width:100%;padding:var(--space-5) var(--space-7);flex-shrink:0;display:flex}.chat-input__bomb{background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;width:44px;height:44px;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);flex-shrink:0;padding:0;font-size:20px;line-height:1}.chat-input__bomb:hover:not(:disabled){background:var(--chat-theme-surface);border-color:var(--chat-theme-border-strong)}.chat-input__bomb--active{background:var(--chat-theme-surface-strong);border-color:var(--chat-bubble-own-color);box-shadow:0 0 0 2px var(--chat-theme-focus-ring)}.chat-input__bomb:disabled{opacity:.6;cursor:not-allowed}.chat-input__error{padding:0 var(--space-7) var(--space-4);font-size:var(--text-caption-size);color:var(--status-critical);letter-spacing:-.01em;margin:0}.chat-input__attach{height:44px;padding:0 var(--space-4);font-size:var(--text-caption-size);font-weight:var(--font-weight-semibold);color:var(--label-brand);background:var(--color-pine-50);border:1px solid var(--color-pine-200);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard), border-color var(--motion-duration-fast) var(--motion-ease-standard);flex-shrink:0}.chat-input__attach:hover:not(:disabled){background:var(--color-pine-100);border-color:var(--color-pine-300)}.chat-input__attach:disabled{opacity:.6;cursor:not-allowed}.chat-input__attach--file{min-width:44px;padding:0 var(--space-3);font-size:1.125rem;line-height:1}.chat-input__status{padding:0 var(--space-7) var(--space-2);font-size:var(--text-caption-size);color:var(--label-secondary);letter-spacing:-.01em;margin:0}.chat-input__field{box-sizing:border-box;width:100%;min-width:0;min-height:44px;max-height:120px;padding:10px var(--space-4);color:var(--label-strong);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);letter-spacing:-.01em;resize:none;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);outline:none;flex:1;font-family:inherit;font-size:16px;line-height:1.5;overflow-y:hidden}.chat-input__field::placeholder{color:var(--label-disabled)}.chat-input__field:hover{border-color:var(--color-neutral-300)}.chat-input__field--bomb{border-color:var(--chat-theme-border-strong);background:var(--surface-default)}.chat-input__field--bomb:focus{border-color:var(--chat-bubble-own-color);box-shadow:0 0 0 3px var(--chat-theme-focus-ring)}.chat-input__field:focus{border-color:var(--chat-bubble-own-color,#3b82f6);box-shadow:0 0 0 3px color-mix(in srgb, var(--chat-bubble-own-color,#3b82f6) 32%, transparent)}.chat-input__button{height:44px;padding:0 var(--space-5);font-size:var(--text-body-sm-size);font-weight:var(--font-weight-semibold);color:var(--label-on-color);background:var(--action-primary);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard);border:none;flex-shrink:0;align-self:flex-end}.chat-input__button:hover:not(:disabled){background:var(--action-primary-hover)}.chat-input__button:disabled{background:var(--color-neutral-200);color:var(--label-disabled);cursor:not-allowed}.join{min-height:100vh;padding:var(--space-7);background:var(--background-muted);justify-content:center;align-items:center;display:flex}.join__card{width:100%;max-width:400px;padding:var(--space-8) var(--space-7);border-radius:var(--radius-xl);background:var(--surface-default);border:1px solid var(--color-neutral-100);box-shadow:var(--shadow-2);text-align:center}.join__brand{margin:0 0 var(--space-2);font-size:28px;font-weight:var(--font-weight-bold);color:var(--label-brand);letter-spacing:-.02em}.join__title{margin:0 0 var(--space-5);font-size:var(--text-heading-sm-size);font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-brand);letter-spacing:-.02em}.join__status{font-size:var(--text-body-sm-size);color:var(--label-neutral);letter-spacing:-.01em;margin:0;line-height:1.6}.join__error{font-size:var(--text-body-sm-size);color:var(--status-critical);letter-spacing:-.01em;margin:0;line-height:1.6}.login{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;color:#111827;background:#fff;min-height:100dvh;overflow:hidden auto}:is(html:has(.login-page),body:has(.login-page)){scroll-behavior:smooth;height:auto;min-height:100%;overflow:hidden auto}#root:has(.login-page){height:auto;min-height:100%;overflow:visible}.app-container:has(.login-page){height:auto;min-height:100%;overflow:visible}.login--loading{justify-content:center;align-items:center;display:flex}.login__section{opacity:0;animation:.7s forwards login-fade-in;transform:translateY(16px)}.login__header{animation-delay:0s}.login__hero{animation-delay:50ms}.login__features{animation-delay:.15s}.login__footer{animation-delay:.25s}@keyframes login-fade-in{to{opacity:1;transform:translateY(0)}}.login__header{justify-content:space-between;align-items:center;gap:1rem;max-width:1100px;margin:0 auto;padding:1rem 48px 0;display:flex}.login__header-brand{color:#6366f1;letter-spacing:-.02em;font-size:1.125rem;font-weight:800}.login__lang-toggle{background:#f3f4f6;border-radius:8px;align-items:center;gap:.25rem;padding:.2rem;display:inline-flex}.login__lang-btn{color:#6b7280;cursor:pointer;letter-spacing:-.01em;background:0 0;border:none;border-radius:6px;padding:.35rem .65rem;font-family:inherit;font-size:.75rem;font-weight:600;transition:background .2s,color .2s}.login__lang-btn:hover{color:#374151}.login__lang-btn--active{color:#6366f1;background:#fff;box-shadow:0 1px 2px #1118270f}.login__hero{background:linear-gradient(#f8f8ff 0%,#fff 100%);align-items:center;min-height:min(100vh,100dvh);padding:60px 48px;display:flex}.login__hero-grid{grid-template-columns:1fr 400px;align-items:center;gap:60px;width:100%;max-width:1100px;margin:0 auto;display:grid}.login__brand{text-align:left;padding-left:24px}.login__logo{color:#6366f1;letter-spacing:-.02em;margin-bottom:1rem;font-size:3.75rem;font-weight:800;line-height:1;display:block}.login__hero-title{letter-spacing:-.04em;color:#111827;flex-direction:column;gap:.25rem;margin:0 0 1rem;font-size:clamp(2rem,4vw,2.75rem);font-weight:800;line-height:1.15;display:flex}.login__hero-subtitle{color:#6b7280;letter-spacing:-.01em;white-space:pre-line;max-width:480px;margin:0 0 2rem;font-size:1.125rem;line-height:1.65}.login__points{flex-direction:column;gap:.875rem;margin:0;padding:0;list-style:none;display:flex}.login__point{color:#374151;letter-spacing:-.01em;align-items:center;gap:.75rem;font-size:1.0625rem;font-weight:500;display:flex}.login__point-icon{flex-shrink:0;font-size:1.5rem;line-height:1}.login__card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;width:100%;padding:32px;box-shadow:0 4px 6px #1118270a,0 12px 32px #1118271a,0 24px 48px #6366f114}.login__hero-grid>.login__card{margin-right:24px}.login__card-title{color:#111827;text-align:center;letter-spacing:-.03em;margin:0 0 .375rem;font-size:1.375rem;font-weight:800}.login__card-subtitle{color:#6b7280;text-align:center;letter-spacing:-.01em;margin:0 0 1.5rem;font-size:.9375rem;line-height:1.5}.login__form{flex-direction:column;gap:.75rem;display:flex}.login__label{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.login__input{color:#111827;letter-spacing:-.01em;background:#fff;border:1px solid #d1d5db;border-radius:8px;outline:none;width:100%;height:48px;padding:0 1rem;font-size:16px;transition:border-color .2s,box-shadow .2s}.login__input::placeholder{color:#9ca3af}.login__input:hover{border-color:#9ca3af}.login__input:focus{border-color:#6366f1;box-shadow:0 0 0 4px #6366f126}.login__button{color:#fff;cursor:pointer;letter-spacing:-.02em;background:#6366f1;border:none;border-radius:8px;width:100%;height:48px;padding:0 1.5rem;font-size:1.0625rem;font-weight:700;transition:background .2s}.login__button:hover:not(:disabled){background:#4f46e5}.login__button:disabled{color:#9ca3af;cursor:not-allowed;background:#d1d5db}.login__message{color:#4338ca;text-align:center;background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;margin:1rem 0 0;padding:.875rem 1rem;font-size:.9375rem;line-height:1.5}.login__error{color:#b91c1c;text-align:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin:1rem 0 0;padding:.875rem 1rem;font-size:.9375rem;line-height:1.5}.login__divider{color:#9ca3af;align-items:center;gap:1rem;margin:1.25rem 0;font-size:.8125rem;font-weight:500;display:flex}.login__divider:before,.login__divider:after{content:"";background:#e5e7eb;flex:1;height:1px}.login__social-buttons{flex-direction:column;gap:.625rem;display:flex}.login__social{cursor:pointer;letter-spacing:-.01em;border-radius:8px;justify-content:center;align-items:center;gap:.625rem;width:100%;min-height:48px;padding:0 1rem;font-family:inherit;font-size:.9375rem;font-weight:600;transition:background .2s,border-color .2s;display:flex}.login__social-icon{flex-shrink:0}.login__social--google{color:#111827;background:#fff;border:1px solid #e5e7eb}.login__social--google:hover{background:#f9fafb}.login__social--facebook{color:#fff;background:#1877f2;border:1px solid #1877f2}.login__social--facebook:hover{background:#166fe5;border-color:#166fe5}.login__qr-link{color:#6366f1;text-align:center;cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;width:100%;margin-top:.625rem;padding:.75rem;font-family:inherit;font-size:.9375rem;font-weight:600;transition:background .2s;display:block}.login__qr-link:hover{background:#f3f4f6}.login__terms{color:#9ca3af;text-align:center;letter-spacing:-.01em;margin:1.25rem 0 0;font-size:.75rem;line-height:1.5}.login__status{color:#6b7280;font-size:1rem}.login__features{padding:0 24px 4rem}.login__features-grid{grid-template-columns:1fr;gap:1rem;max-width:1100px;margin:0 auto;display:grid}@media (width>=768px){.login__features-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem}}.login__feature-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1.5rem;transition:border-color .2s,box-shadow .2s,transform .2s}.login__feature-card:hover{border-color:#c7d2fe;transform:translateY(-2px);box-shadow:0 8px 24px #6366f114}.login__feature-icon{margin-bottom:.875rem;font-size:2rem;line-height:1;display:block}.login__feature-title{color:#111827;letter-spacing:-.02em;margin:0 0 .5rem;font-size:1.0625rem;font-weight:700}.login__feature-desc{color:#6b7280;letter-spacing:-.01em;margin:0;font-size:.9375rem;line-height:1.6}.login__footer{text-align:center;padding:0 24px 2.5rem}.login__footer p{color:#9ca3af;letter-spacing:-.01em;margin:0;font-size:.8125rem}@media (width<=767px){.login__header{padding:.75rem 1.25rem 0}.login__hero{align-items:flex-start;min-height:auto;padding:1.5rem 0 2rem}.login__hero-grid{flex-direction:column;gap:0;width:100%;max-width:none;display:flex}.login__brand{text-align:center;order:1;padding:0 1.25rem 1.5rem}.login__card{border-radius:20px;order:2;margin:0 16px;padding:28px 24px}.login__hero-grid>.login__card{margin-right:16px}.login__logo{color:#6366f1;margin-bottom:.75rem;font-size:3rem}.login__hero-title{margin-bottom:.75rem;font-size:clamp(1.625rem,6vw,2rem)}.login__hero-subtitle{max-width:none;margin:0 auto;font-size:.9375rem}.login__points{display:none}.login__features{padding:0 1.25rem 3rem}.login__footer{padding:0 1.25rem 2rem}}.qr-scan{z-index:0;min-height:100dvh;padding:max(var(--space-6), env(safe-area-inset-top)) max(var(--space-4), env(safe-area-inset-right)) max(var(--space-6), env(safe-area-inset-bottom)) max(var(--space-4), env(safe-area-inset-left));background:var(--background-muted,#f4f4f5);color:var(--label-strong,#111);justify-content:center;align-items:flex-start;display:flex;position:relative;overflow-x:hidden}.qr-scan__card{z-index:2;width:min(100%,420px);margin-top:var(--space-4);padding:var(--space-6);background:var(--surface-default,#fff);border:1px solid var(--color-neutral-100,#eee);border-radius:var(--radius-xl,16px);box-shadow:var(--shadow-2);position:relative}.qr-scan__title{margin:0 0 var(--space-2);font-size:24px;font-weight:var(--font-weight-bold);color:var(--label-strong,#111);letter-spacing:-.02em}.qr-scan__subtitle{margin:0 0 var(--space-4);color:var(--label-subtle,#666);font-size:14px;line-height:1.5}.qr-scan__notice{margin:0 0 var(--space-4);padding:var(--space-3);color:var(--label-default,#333);background:var(--color-neutral-50,#fafafa);border-radius:var(--radius-md);font-size:13px;line-height:1.5}.qr-scan__notice-link{font-family:inherit;font-size:inherit;font-weight:var(--font-weight-medium);color:var(--chat-bubble-own-color,#3b82f6);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:0;text-decoration:underline}.qr-scan__viewport{isolation:isolate;width:100%;height:min(72vw,300px);max-height:300px;margin-bottom:var(--space-4);border-radius:var(--radius-lg);background:#111;position:relative;overflow:hidden}.qr-scan__viewport-placeholder{background:linear-gradient(135deg,#ffffff14,#ffffff05);position:absolute;inset:0}.qr-scan__video{object-fit:cover;border-radius:var(--radius-lg);width:100%;height:100%;display:block}.qr-scan__canvas{display:none}.qr-scan__start,.qr-scan__retry{width:100%;margin-bottom:var(--space-3);font-family:inherit;font-size:14px;font-weight:var(--font-weight-medium);color:#fff;background:var(--chat-bubble-own-color,#3b82f6);border-radius:var(--radius-md);cursor:pointer;border:none;padding:12px;display:block}.qr-scan__retry{color:var(--chat-bubble-own-color,#3b82f6);border:1px solid var(--color-neutral-200,#ddd);background:0 0}.qr-scan__status{margin:0 0 var(--space-2);color:var(--label-subtle,#666);text-align:center;font-size:14px}.qr-scan__error{margin:0 0 var(--space-3);color:var(--color-danger,#e53935);text-align:center;font-size:14px;line-height:1.5}.qr-scan__error-detail{color:var(--label-subtle,#666);text-align:center;word-break:break-word;margin:0;font-size:12px;line-height:1.5}.qr-scan__link{width:100%;margin-top:var(--space-4);font-family:inherit;font-size:14px;font-weight:var(--font-weight-medium);color:var(--chat-bubble-own-color,#3b82f6);border:1px solid var(--color-neutral-200,#ddd);border-radius:var(--radius-md);cursor:pointer;background:0 0;padding:12px;display:block}.qr-scan__link:hover{background:var(--color-neutral-50,#fafafa)}.set-nickname{min-height:100vh;padding:var(--space-7);background:var(--background-muted);justify-content:center;align-items:center;display:flex}.set-nickname__card{width:100%;max-width:400px;padding:var(--space-8) var(--space-7);border-radius:var(--radius-xl);background:var(--surface-default);border:1px solid var(--color-neutral-100);box-shadow:var(--shadow-2)}.set-nickname__brand{margin:0 0 var(--space-2);font-size:28px;font-weight:var(--font-weight-bold);color:var(--label-brand);text-align:center;letter-spacing:-.02em}.set-nickname__title{margin:0 0 var(--space-2);font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-default);text-align:center;letter-spacing:-.02em}.set-nickname__subtitle{margin:0 0 var(--space-8);font-size:var(--text-body-sm-size);color:var(--label-subtle);text-align:center;letter-spacing:-.01em;line-height:1.6}.set-nickname__form{gap:var(--space-2);flex-direction:column;display:flex}.set-nickname__label{font-size:var(--text-body-xs-size);font-weight:var(--font-weight-medium);color:var(--label-default);letter-spacing:-.01em}.set-nickname__input{width:100%;height:44px;padding:0 var(--space-4);font-size:var(--text-body-sm-size);color:var(--label-strong);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);letter-spacing:-.01em;transition:border-color var(--motion-duration-fast) var(--motion-ease-standard), box-shadow var(--motion-duration-fast) var(--motion-ease-standard);outline:none}.set-nickname__input::placeholder{color:var(--label-disabled)}.set-nickname__input:hover{border-color:var(--color-neutral-300)}.set-nickname__input:focus{border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.set-nickname__hint{margin:0 0 var(--space-4);font-size:var(--text-caption-size);color:var(--label-subtle);letter-spacing:-.01em}.set-nickname__button{width:100%;height:52px;padding:0 var(--space-6);font-size:15px;font-weight:var(--font-weight-bold);color:var(--label-on-color);background:var(--action-primary);border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;transition:background var(--motion-duration-fast) var(--motion-ease-standard);border:none}.set-nickname__button:hover:not(:disabled){background:var(--action-primary-hover)}.set-nickname__button:disabled{background:var(--color-neutral-200);color:var(--label-disabled);cursor:not-allowed}.set-nickname__error{margin:var(--space-5) 0 0;padding:var(--space-4);font-size:var(--text-body-sm-size);color:var(--status-critical);text-align:center;background:var(--status-critical-bg);border:1px solid var(--color-red-100);border-radius:var(--radius-md);letter-spacing:-.01em;line-height:1.5}.profile-page{min-height:100vh;padding:var(--space-5);background:var(--background-muted)}.profile-page__header{align-items:center;gap:var(--space-3);max-width:480px;margin:0 auto var(--space-6);display:flex}.profile-page__back{width:40px;height:40px;color:var(--label-default);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;justify-content:center;align-items:center;font-size:20px;display:flex}.profile-page__title{font-size:var(--text-heading-sm-size);font-weight:var(--font-weight-bold);color:var(--label-default);margin:0}.profile-page__card{width:100%;max-width:480px;padding:var(--space-8) var(--space-7);background:var(--surface-default);border:1px solid var(--color-neutral-100);border-radius:var(--radius-xl);box-shadow:var(--shadow-2);margin:0 auto}.profile-page__photo-section{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);flex-direction:column;display:flex}.profile-page__photo-hint{font-size:var(--text-body-sm-size);color:var(--label-subtle);margin:0}.profile-page__photo-button{padding:0 var(--space-4);height:36px;font-family:inherit;font-size:var(--text-body-sm-size);font-weight:var(--font-weight-medium);color:var(--label-default);background:var(--color-neutral-50);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer}.profile-page__photo-button:hover:not(:disabled){background:var(--color-neutral-100)}.profile-page__photo-button:disabled{opacity:.6;cursor:not-allowed}.profile-page__file-input{display:none}.profile-page__form{gap:var(--space-2);flex-direction:column;display:flex}.profile-page__label{margin-top:var(--space-3);font-size:var(--text-body-xs-size);font-weight:var(--font-weight-medium);color:var(--label-default)}.profile-page__nickname-row{align-items:center;gap:var(--space-2);min-height:44px;padding:0 var(--space-4);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);display:flex}.profile-page__nickname-value{font-size:var(--text-body-sm-size);color:var(--label-strong);flex:1}.profile-page__nickname-input{height:42px;box-shadow:none;border:none;flex:1;padding:0}.profile-page__nickname-input:focus{box-shadow:none}.profile-page__nickname-edit{border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.profile-page__nickname-edit:hover{background:var(--color-neutral-50)}.profile-page__input{width:100%;height:44px;padding:0 var(--space-4);font-size:var(--text-body-sm-size);color:var(--label-strong);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);outline:none}.profile-page__input:focus{border-color:var(--border-focus);box-shadow:var(--shadow-focus)}.profile-page__select{appearance:none}.profile-page__email{padding:var(--space-3) var(--space-4);font-size:var(--text-body-sm-size);color:var(--label-subtle);background:var(--color-neutral-50);border-radius:var(--radius-md);margin:0}.profile-page__lang-toggle{gap:var(--space-2);display:flex}.profile-page__lang-btn{height:40px;font-family:inherit;font-size:var(--text-body-sm-size);font-weight:var(--font-weight-medium);color:var(--label-default);background:var(--surface-default);border:1px solid var(--color-neutral-200);border-radius:var(--radius-md);cursor:pointer;flex:1}.profile-page__lang-btn--active{color:var(--label-on-color);background:var(--action-primary);border-color:var(--action-primary)}.profile-page__save{margin-top:var(--space-6);width:100%;height:48px;font-size:15px;font-weight:var(--font-weight-bold);color:var(--label-on-color);background:var(--action-primary);border-radius:var(--radius-md);cursor:pointer;border:none}.profile-page__save:hover:not(:disabled){background:var(--action-primary-hover)}.profile-page__save:disabled{background:var(--color-neutral-200);color:var(--label-disabled);cursor:not-allowed}.profile-page__error{margin:var(--space-4) 0 0;font-size:var(--text-body-sm-size);color:var(--status-critical)}.profile-page__saved{margin:var(--space-3) 0 0;font-size:var(--text-body-sm-size);color:var(--status-success,#16a34a);text-align:center}
