:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#101010;background:#d9d9d9}*{box-sizing:border-box}html,body,#root{width:100%;height:100%}body{margin:0;min-width:100vw;min-height:100vh;min-height:100dvh;overflow:hidden;background:#d1d1d1}.phone-shell{width:100vw;height:100vh;height:100dvh;background:#d1d1d1;overflow:hidden;display:flex;flex-direction:column}.header{background:#000;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:10px 12px}.header-title{margin:0;font-size:28px;letter-spacing:2px}.icon-button,.avatar-button,.nav-button{border:none;background:transparent;cursor:pointer}.plus{color:#f8c542;font-size:42px;line-height:1}.header-avatar{width:42px;height:42px;border-radius:50%;border:2px solid #f3f3f3;object-fit:cover}.chat-list{flex:1;overflow-y:auto}.chat-row{min-height:76px;border-bottom:1px solid #4e4e4e;display:flex;align-items:center;gap:12px;padding:8px 12px;cursor:pointer}.chat-row:focus-visible{outline:2px solid #f8c542;outline-offset:-2px}.avatar-wrap{position:relative}.chat-avatar{width:56px;height:56px;border-radius:50%;border:2px dotted #2a2a2a;object-fit:cover}.status-dot{width:14px;height:14px;border-radius:50%;border:2px solid #d1d1d1;position:absolute;right:-1px;bottom:-1px}.status-dot.online{background:#00d43d}.status-dot.offline{background:#ff2323}.chat-name{margin:0;font-size:clamp(24px,7vw,34px);letter-spacing:.3px}.unread-badge{margin-left:auto;min-width:42px;padding:4px 8px;border-radius:20px;background:#f7c847;font-size:20px;text-align:center}.bottom-nav{min-height:80px;background:#000;border-top:2px solid #161616;display:flex;align-items:center;justify-content:space-around;padding-bottom:env(safe-area-inset-bottom)}.nav-button{color:#f8c542;font-size:40px}.nav-button.active{font-size:46px}.chat-room-header{background:#000;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:8px 10px}.back-button{width:42px;height:42px;border:none;border-radius:10px;background:transparent;color:#f8c542;font-size:42px;line-height:1;cursor:pointer}.chat-room-title{margin:0;font-size:34px;font-weight:500;color:#e9e9e9}.chat-room-avatar-wrap{position:relative}.chat-room-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover}.messages-list{flex:1;overflow-y:auto;padding:10px 8px 14px;display:flex;flex-direction:column;gap:16px}.message-row{display:flex}.message-row.them{justify-content:flex-start}.message-row.me{justify-content:flex-end}.message-bubble{max-width:min(76vw,560px);border-radius:12px;padding:10px 12px 6px;border:none;text-align:left;cursor:pointer}.message-bubble.selected{outline:3px solid #f8c542;box-shadow:0 0 0 3px #f8c54240}.their-bubble{background:#99e0d8}.my-bubble{background:#efd79b}.message-text{margin:0;font-size:clamp(18px,3.8vw,36px);line-height:1.15;white-space:pre-wrap}.message-image{display:block;width:100%;max-width:min(68vw,540px);border-radius:10px}.message-meta{margin-top:4px;display:flex;justify-content:flex-end;align-items:center;gap:4px;color:#8b8b8b;font-size:clamp(14px,2.7vw,24px)}.read-mark{letter-spacing:-2px;color:#bdbdbd}.message-input-wrap{margin:8px;margin-bottom:max(8px,env(safe-area-inset-bottom));padding:8px;border-radius:12px;background:#c6c6c6;display:flex;align-items:center;gap:8px;width:calc(100% - 16px);max-width:100%;min-width:0;box-sizing:border-box;align-self:center}.message-input-wrap.delete-mode{justify-content:center}.input-icon-button{border:none;flex-shrink:0;width:44px;height:44px;border-radius:10px;background:#000;color:#fff;font-size:30px;cursor:pointer}.send-button{font-size:27px}.delete-action-button{border:none;width:52px;height:52px;border-radius:12px;background:#000;color:#fff;font-size:30px;cursor:pointer}.message-input{flex:1 1 0;min-width:0;width:0;height:42px;border:none;border-radius:10px;background:#bcbcbc;color:#1f1f1f;font-size:clamp(16px,4.5vw,30px);padding:0 10px}.message-input::placeholder{color:#2f2f2f}.message-input:focus{outline:2px solid #f8c542}.hidden-file-input{display:none}.photo-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:20}.photo-popup{width:min(560px,92vw);background:#efefef;border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:10px}.photo-popup-title{margin:0;font-size:30px}.photo-popup-subtitle{margin:0;color:#555;font-size:20px}.photo-popup-choose-button,.photo-popup-close-button{border:none;border-radius:10px;padding:10px 12px;font-size:18px;cursor:pointer}.photo-popup-choose-button{background:#f8c542}.photo-popup-close-button{background:#d4d4d4}.drop-zone{min-height:130px;border:2px dashed #777;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#fafafa;color:#4f4f4f;font-size:20px}.delete-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:30}.delete-popup{width:min(430px,90vw);background:#f2f2f2;border-radius:14px;padding:16px}.delete-popup-text{margin:0 0 14px;font-size:24px;text-align:center}.delete-popup-actions{display:flex;gap:10px}.delete-popup-button{flex:1;border:none;border-radius:10px;padding:10px;font-size:22px;cursor:pointer}.delete-popup-button.no{background:#dadada}.delete-popup-button.yes{background:#f8c542}.auth-shell{background:#d1d1d1}.auth-form-wrap{flex:1;overflow-y:auto;padding:24px 18px;display:flex;flex-direction:column;gap:18px}.auth-tabs{display:flex;gap:8px;background:silver;border-radius:12px;padding:4px}.auth-tab{flex:1;border:none;background:transparent;padding:10px;border-radius:10px;font-size:18px;cursor:pointer;color:#1f1f1f}.auth-tab.active{background:#f8c542;font-weight:600}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-label{display:flex;flex-direction:column;gap:6px;font-size:16px;color:#2a2a2a}.auth-input{border:none;background:#ededed;border-radius:10px;padding:12px;font-size:18px;color:#1f1f1f}.auth-input:focus{outline:2px solid #f8c542}.auth-error{margin:0;color:#b3261e;background:#fde7e7;border-radius:10px;padding:10px 12px;font-size:16px}.auth-submit{border:none;border-radius:12px;padding:14px;background:#000;color:#f8c542;font-size:20px;font-weight:600;cursor:pointer}.auth-submit:disabled{opacity:.6;cursor:progress}.auth-hint{margin:4px 0 0;font-size:13px;color:#555;line-height:1.4}.auth-submit.secondary{background:#d4d4d4;color:#1f1f1f}.rotate-title{margin:0;font-size:22px}.rotate-actions{display:flex;gap:10px}.rotate-actions .auth-submit{flex:1}.secret-input{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;resize:vertical;word-break:break-all}.auth-divider{display:flex;align-items:center;gap:10px;color:#666;font-size:14px;margin:4px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#b8b8b8}.auth-link{border:none;background:transparent;color:#1f1f1f;text-decoration:underline;cursor:pointer;padding:6px;font-size:14px}.new-dialog-actions .ok.logout{background:#000;color:#f8c542}.settings-body{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:14px;align-items:stretch}.avatar-drop-zone{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 12px;border:2px dashed #888;border-radius:16px;background:#ededed;cursor:pointer;transition:background .15s ease,border-color .15s ease}.avatar-drop-zone:hover{background:#e2e2e2}.avatar-drop-zone.drag-over{background:#fff5d6;border-color:#f8c542}.settings-avatar{width:128px;height:128px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 1px 6px #00000026}.avatar-drop-hint{color:#555;font-size:14px;text-align:center;max-width:320px;line-height:1.35}.settings-saved{margin:0;color:#1f6f3a;background:#e0f5e6;border-radius:10px;padding:8px 12px;font-size:14px;text-align:center}@media (min-width: 790px){.settings-avatar{width:160px;height:160px}}.list-message{padding:18px 14px;font-size:18px;color:#2a2a2a}.connection-banner{background:#c8c8c8;color:#1f1f1f;padding:6px 12px;font-size:14px;text-align:center}.connection-banner.offline{background:#f5cbcb}.new-dialog-popup{width:min(420px,90vw);background:#f2f2f2;border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px}.new-dialog-popup h3{margin:0;font-size:22px}.new-dialog-popup input{border:none;background:#e2e2e2;border-radius:10px;padding:10px;font-size:18px}.new-dialog-actions{display:flex;gap:8px}.new-dialog-actions button{flex:1;border:none;border-radius:10px;padding:10px;font-size:18px;cursor:pointer}.new-dialog-actions .ok{background:#f8c542}.new-dialog-actions .cancel{background:#d4d4d4}.logout-button{border:none;background:transparent;color:#f8c542;font-size:14px;cursor:pointer}@media (min-width: 790px){.header{padding:14px 18px}.header-title{font-size:32px}.plus{font-size:50px}.header-avatar{width:50px;height:50px}.chat-row{min-height:90px;gap:16px;padding:10px 18px}.chat-avatar{width:66px;height:66px}.chat-name{font-size:36px}.unread-badge{min-width:48px;padding:4px 10px;font-size:24px}.bottom-nav{min-height:90px}.nav-button{font-size:46px}.nav-button.active{font-size:52px}.chat-room-header{padding:10px 16px}.back-button{width:48px;height:48px;font-size:48px}.chat-room-avatar{width:50px;height:50px}.chat-room-title{font-size:36px}.messages-list{padding:14px 16px 18px;gap:18px}.message-bubble{max-width:min(62vw,760px);border-radius:14px;padding:12px 14px 8px}.message-text{font-size:38px}.message-image{max-width:min(54vw,720px);border-radius:12px}.message-meta{font-size:24px}.message-input-wrap{margin:12px;padding:10px;border-radius:14px;gap:10px;width:calc(100% - 24px)}.input-icon-button{width:50px;height:50px;font-size:34px}.delete-action-button{width:58px;height:58px;font-size:34px}.message-input{height:48px;font-size:clamp(18px,2.2vw,36px)}}
