*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{color:#1f2937;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;background:#f3f4f6;font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:16px}body{overscroll-behavior-y:none;margin:0}#root{width:100%}button{cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;font-family:inherit}input{touch-action:manipulation;font-family:inherit}.pin{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.pin__card{background:#fff;border-radius:24px;flex-direction:column;align-items:center;width:100%;max-width:340px;padding:40px 32px 36px;display:flex;box-shadow:0 20px 60px #0003}.pin__logo{object-fit:cover;border-radius:20px;width:80px;height:80px;margin-bottom:16px}.pin__title{color:#111827;letter-spacing:-.3px;margin-bottom:6px;font-size:26px;font-weight:700}.pin__subtitle{color:#6b7280;text-align:center;margin-bottom:24px;font-size:15px}.pin__users{flex-direction:column;gap:10px;width:100%;display:flex}.pin__user-btn{cursor:pointer;color:#111827;-webkit-tap-highlight-color:transparent;background:#fff;border:2px solid #e5e7eb;border-radius:14px;align-items:center;gap:14px;width:100%;padding:14px 18px;font-size:16px;font-weight:500;transition:border-color .15s,background .15s,transform .1s;display:flex}.pin__user-btn:hover{border-color:var(--user-color);background:#fafafa}.pin__user-btn:active{border-color:var(--user-color);transform:scale(.97)}.pin__user-emoji{background:#f3f4f6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:26px;display:flex}.pin__user-name{font-size:17px;font-weight:600}.pin__input-wrap{border:2px solid #e5e7eb;border-radius:14px;width:100%;margin-bottom:12px;transition:border-color .15s;overflow:hidden}.pin__input-wrap:focus-within{border-color:#667eea}.pin__input-wrap--error{border-color:#ef4444;animation:.4s pin-shake}@keyframes pin-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.pin__input{letter-spacing:6px;text-align:center;color:#111827;background:#f9fafb;border:none;outline:none;width:100%;padding:14px 18px;font-size:22px}.pin__input::placeholder{letter-spacing:4px;color:#d1d5db}.pin__input:disabled{opacity:.6}.pin__error{color:#ef4444;text-align:center;margin-bottom:8px;font-size:13px}.pin__btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:14px;width:100%;margin-top:4px;padding:14px;font-size:16px;font-weight:600;transition:opacity .15s,transform .1s}.pin__btn:active:not(:disabled){opacity:.85;transform:scale(.98)}.pin__btn:disabled{opacity:.4;cursor:not-allowed}.pin__back{color:#9ca3af;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;margin-top:14px;padding:4px 8px;font-size:14px}.pin__back:hover{color:#6b7280}.chat{background:#f3f4f6;flex-direction:column;height:100dvh;display:flex;position:fixed;top:0;left:0;right:0}.chat__header{padding-top:env(safe-area-inset-top);background:#fff;flex-shrink:0;box-shadow:0 1px 4px #00000014}.chat__header-inner{justify-content:space-between;align-items:center;height:64px;padding:0 16px;display:flex}.chat__header-left{align-items:center;gap:10px;display:flex}.chat__avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;display:flex}.chat__user-name{color:#111827;margin-bottom:3px;font-size:16px;font-weight:600;line-height:1}.chat__status{color:#10b981;font-size:12px}.chat__header-actions{align-items:center;gap:8px;display:flex}.chat__clear-btn{color:#ef4444;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:1px solid #fee2e2;border-radius:8px;justify-content:center;align-items:center;min-width:38px;min-height:38px;padding:7px 10px;font-size:16px;transition:background .15s;display:flex}@media (hover:hover){.chat__clear-btn:hover:not(:disabled){background:#fef2f2}}.chat__clear-btn:active:not(:disabled){background:#fef2f2}.chat__clear-btn:disabled{opacity:.5;cursor:not-allowed}.chat__icon-btn{color:#6b7280;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:1px solid #e5e7eb;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:background .15s,color .15s;display:flex}@media (hover:hover){.chat__icon-btn:hover{color:#374151;background:#f9fafb}}.chat__icon-btn:active{color:#374151;background:#f3f4f6}.chat__modal-overlay{z-index:500;background:#00000073;justify-content:center;align-items:center;padding:24px;animation:.15s lightbox-in;display:flex;position:fixed;inset:0}.chat__modal{background:#fff;border-radius:20px;flex-direction:column;gap:12px;width:100%;max-width:320px;padding:28px 24px 24px;display:flex;box-shadow:0 12px 40px #0000002e}.chat__modal-title{color:#111827;margin:0;font-size:18px;font-weight:700}.chat__modal-sub{color:#6b7280;margin:-4px 0 2px;font-size:14px}.chat__modal-input{letter-spacing:5px;text-align:center;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;outline:none;width:100%;padding:11px 14px;font-size:18px;transition:border-color .15s}.chat__modal-input:focus{background:#fff;border-color:#667eea}.chat__modal-error{color:#ef4444;text-align:center;margin:-4px 0;font-size:13px}.chat__modal-actions{gap:8px;margin-top:4px;display:flex}.chat__modal-cancel{color:#6b7280;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;flex:1;padding:11px;font-size:15px;font-weight:500;transition:background .15s}.chat__modal-cancel:active{background:#f3f4f6}.chat__modal-save{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:10px;flex:1;padding:11px;font-size:15px;font-weight:600;transition:opacity .15s}.chat__modal-save:disabled{opacity:.5;cursor:not-allowed}.chat__messages{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:10px;padding:16px 12px;display:flex;overflow-y:auto}.chat__loading-more{color:#9ca3af;justify-content:center;padding:8px 0 4px;display:flex}.chat__empty{text-align:center;color:#9ca3af;margin:auto;font-size:15px}.chat__empty-icon{margin-bottom:12px;font-size:48px;display:block}.msg{align-items:flex-end;gap:6px;display:flex}.msg--own{flex-direction:row-reverse}.msg__avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;display:flex}.msg__content{flex-direction:column;gap:3px;max-width:78%;display:flex}.msg--own .msg__content{align-items:flex-end}.msg__sender{padding-left:4px;font-size:11px;font-weight:600}.msg__bubble{color:#1f2937;word-break:break-word;white-space:pre-wrap;background:#fff;border-radius:18px;padding:9px 13px;font-size:15px;line-height:1.45;box-shadow:0 1px 2px #00000012}.msg--own .msg__bubble{color:#fff;border-bottom-right-radius:4px}.msg--other .msg__bubble{border-bottom-left-radius:4px}.msg__time{color:#9ca3af;padding:0 4px;font-size:11px}.msg__bubble--image{padding:4px;overflow:hidden}.msg__image{cursor:pointer;object-fit:cover;border-radius:14px;width:100%;max-width:min(260px,65vw);max-height:300px;transition:opacity .15s;display:block}@media (hover:hover){.msg__image:hover{opacity:.9}}.msg__image:active{opacity:.85}.msg__image-caption{padding:6px 10px 4px;font-size:15px;line-height:1.4;display:block}.chat__input-area{padding:10px 12px;padding-bottom:max(10px, env(safe-area-inset-bottom));background:#fff;border-top:1px solid #e5e7eb;flex-shrink:0;align-items:center;gap:8px;display:flex}.chat__input{color:#1f2937;background:#f9fafb;border:1px solid #e5e7eb;border-radius:22px;outline:none;flex:1;padding:10px 16px;font-size:16px;transition:border-color .15s,background .15s}.chat__input:focus{background:#fff;border-color:#d1d5db}.chat__input::placeholder{color:#9ca3af}.chat__send-btn{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:opacity .15s,transform .1s;display:flex}@media (hover:hover){.chat__send-btn:hover:not(:disabled){opacity:.88;transform:scale(1.06)}}.chat__send-btn:active:not(:disabled){opacity:.8;transform:scale(.95)}.chat__send-btn:disabled{opacity:.35;cursor:not-allowed}.chat__image-btn{color:#9ca3af;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:color .15s,background .15s;display:flex}@media (hover:hover){.chat__image-btn:hover:not(:disabled){color:#6b7280;background:#f3f4f6}}.chat__image-btn:active:not(:disabled){color:#6b7280;background:#f3f4f6}.chat__image-btn:disabled{opacity:.4;cursor:not-allowed}.lightbox{z-index:1000;padding:max(60px, env(safe-area-inset-top)) 16px max(20px, env(safe-area-inset-bottom));background:#000000eb;justify-content:center;align-items:center;animation:.18s lightbox-in;display:flex;position:fixed;inset:0}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.lightbox__img{object-fit:contain;-webkit-user-select:none;user-select:none;border-radius:8px;max-width:100%;max-height:100%}.lightbox__close{top:max(12px, env(safe-area-inset-top));color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);-webkit-tap-highlight-color:transparent;background:#ffffff2e;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;transition:background .15s;display:flex;position:absolute;right:16px}.lightbox__close:hover{background:#ffffff47}.lightbox__close:active{background:#ffffff61}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.7s linear infinite spin}
