.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#f5f5f5}.chanju{width:150px;height:150px;margin-bottom:20px}.login-box{background:#fff;padding:50px;border-radius:20px;box-shadow:0 4px 12px #0000001a;text-align:center}.login-box h2{margin-bottom:20px;font-size:1.2rem}.login-buttons{display:flex;flex-direction:column;gap:15px}.login-btn{border:none;background:none;cursor:pointer;padding:0}.login-btn img{width:220px;height:auto;display:block}:root{--bg: #dfeef7;--device: #ffffff;--panel: #08245f;--panel-border: #2d66ff;--text: #eef5ff;--radius: 28px;--radius-lg: 36px;--shadow: 0 14px 40px rgba(8, 36, 95, .18)}html,body{height:100%;overflow:hidden}.board{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg);box-sizing:border-box}.board__view{position:relative;width:360px;max-width:100%;background:var(--device);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:12px 12px 100px;overflow:hidden;display:flex;flex-direction:column;scrollbar-width:none;-ms-overflow-style:none}.board__content::-webkit-scrollbar{display:none}.shared-map-container{position:absolute;top:70px;left:12px;right:12px;bottom:100px;z-index:5;transition:opacity .2s ease-in-out}.shared-map-container.visible{opacity:1;pointer-events:auto}.shared-map-container.hidden{opacity:0;pointer-events:none}.board__content{position:relative;width:auto;height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.board__content>*{position:relative;z-index:10}@media (max-width: 420px){.board{padding:16px}.board__view{width:100%}}.swipe-wrap{height:100%;display:grid;grid-template-rows:auto 1fr;background:transparent;padding:0;box-sizing:border-box}.swipe-header{position:sticky;top:0;z-index:3;background:var(--device);border-bottom:1px solid rgba(0,0,0,.04)}.swipe-header h1{margin:10px 14px;font-size:18px;font-weight:800;color:#0a1f4d}.swipe-main{display:grid;place-items:center;padding:8px 6px;overflow:hidden}.deck{position:relative;width:100%;max-width:520px;height:100%;contain:layout paint size;-webkit-tap-highlight-color:transparent;perspective:1000px}.card{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;transition:transform .16s ease;will-change:transform,opacity;touch-action:pan-y;-webkit-user-select:none;user-select:none;backface-visibility:hidden;pointer-events:none}.top{cursor:grab;pointer-events:auto}.top:active{cursor:grabbing}.stacked{filter:saturate(.9) brightness(.96)}.profile{width:100%;height:100%;background:var(--panel);color:var(--text);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 16px;display:grid;grid-template-rows:auto 1fr}.circle{width:100%;aspect-ratio:1 / 1;border-radius:999px;background:radial-gradient(120% 120% at 50% 35%,#1a3d84 0%,var(--panel) 60%);display:grid;place-items:center;overflow:hidden;margin-bottom:12px}.circle img{width:78%;height:78%;object-fit:cover;border-radius:999px}.info{padding:8px 8px 2px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:6px;height:100%}.nm{display:block;font-size:clamp(16px,2.2vw,18px);font-weight:800;margin-bottom:6px}.meta{font-size:14px;opacity:.9;margin-bottom:4px}.intro{font-size:14px;line-height:1.4}.profile .chatting{width:100%;display:flex;justify-content:center;align-items:center;margin-top:10px}.profile .stat-chatting{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(135deg,#2d66ff,#5a8bff);color:#fff;border:none;border-radius:999px;font-size:15px;font-weight:700;padding:12px 28px;cursor:pointer;transition:all .2s ease;box-shadow:0 6px 14px #08245f40}.profile .stat-chatting:hover{transform:translateY(-2px);box-shadow:0 10px 20px #08245f4d;filter:brightness(1.05)}.profile .stat-chatting:active{transform:translateY(0);box-shadow:0 4px 10px #08245f33;filter:brightness(.97)}.profile .stat-chatting:focus-visible{outline:2px solid rgba(45,102,255,.6);outline-offset:2px}@media (max-width: 400px){.profile .stat-chatting{width:100%;max-width:280px}}.loading{margin-top:8px;color:#2a3655}.end-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#2a3655;background:#ffffff80;border-radius:var(--radius);padding:12px;text-align:center}@media (prefers-reduced-motion: reduce){.card,.profile .stat-chatting{transition:none!important}}.profile-container{padding:20px;max-width:1200px;margin:0 auto}.profile-container h1{font-size:28px;font-weight:700;margin-bottom:10px;color:#333}.user-info-section{margin-bottom:40px;background:#fff;border-radius:16px;padding:30px;box-shadow:0 2px 8px #0000001a}.profile-header{display:flex;gap:30px;align-items:flex-start}.profile-image{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid #f0f0f0}.user-details{flex:1}.profile-text{font-size:16px;color:#666;margin:10px 0;line-height:1.5}.user-meta{display:flex;gap:20px;margin-top:15px;font-size:14px;color:#888}.user-meta span{padding:5px 12px;background:#f5f5f5;border-radius:12px}.records-section{margin-top:30px}.records-section h2{font-size:24px;font-weight:600;margin-bottom:20px;color:#333}.records-list{display:flex;flex-direction:column;gap:20px;max-height:calc(100vh - 250px);overflow-y:auto;padding-right:10px}.records-list::-webkit-scrollbar{width:8px}.records-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.records-list::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.records-list::-webkit-scrollbar-thumb:hover{background:#555}.loading,.error-message,.no-records{text-align:center;padding:40px;font-size:16px;color:#666}.error-message{color:#d32f2f;background-color:#ffebee;border-radius:8px}.no-records{background-color:#f5f5f5;border-radius:8px}@media (max-width: 600px){.profile-container{padding:15px}.profile-container h1{font-size:24px;margin-bottom:10px}.user-info-section{padding:20px}.profile-header{flex-direction:column;align-items:center;gap:20px}.profile-image{width:100px;height:100px}.user-details{text-align:center}.user-meta{justify-content:center;flex-wrap:wrap;gap:10px}.records-section h2{font-size:20px;margin-bottom:15px}.records-list{gap:15px;max-height:calc(100vh - 350px)}}.record-card{width:100%;margin-bottom:20px}.record-card-container{width:100%;max-width:521px;background:#fff;box-shadow:0 4px 9px 1px #00000040;border-radius:20px;display:flex;position:relative;padding:16px;box-sizing:border-box;overflow:hidden}.map-preview{width:120px;height:120px;flex-shrink:0;margin-right:16px}.map-preview img{width:100%;height:100%;object-fit:cover;border-radius:8px}.map-placeholder{width:100%;height:100%;background:#d9d9d9;display:flex;align-items:center;justify-content:center;border-radius:8px}.map-placeholder span{color:#000;font-size:10px;font-family:Inter,sans-serif;font-weight:400;text-align:center;padding:8px;line-height:1.2}.record-info{flex:1;display:flex;flex-direction:column;min-width:0}.record-date{color:#000;font-size:16px;font-family:Inter,sans-serif;font-weight:500;margin-bottom:12px;line-height:1.2}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:12px 10px;flex:1}.metric-item{display:flex;flex-direction:column;gap:4px;min-width:0}.metric-label{color:#666;font-size:11px;font-family:Inter,sans-serif;font-weight:400;line-height:1.2;word-break:keep-all}.metric-value{color:#000;font-size:16px;font-family:Inter,sans-serif;font-weight:700;line-height:1.3;word-break:keep-all;overflow-wrap:normal}@media (max-width: 480px){.record-card-container{padding:12px}.map-preview{width:100px;height:100px;margin-right:12px}.record-date{font-size:14px;margin-bottom:10px}.metrics-grid{gap:10px 8px}.metric-label{font-size:10px}.metric-value{font-size:14px}.map-placeholder span{font-size:9px;padding:6px}}@media (max-width: 360px){.record-card-container{padding:10px}.map-preview{width:85px;height:85px;margin-right:10px}.record-date{font-size:13px;margin-bottom:8px}.metrics-grid{gap:8px 6px}.metric-label{font-size:9px}.metric-value{font-size:12px}.map-placeholder span{font-size:8px;padding:5px}}.board__nav{position:absolute;left:12px;right:12px;bottom:12px;display:flex;justify-content:space-between;gap:8px;background:#fff;border:1px solid #e6eef9;border-radius:20px;padding:10px 12px;box-shadow:0 10px 24px #08245f1f;z-index:2}.board__nav>button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;width:60px;height:44px;border-radius:12px;font:inherit;color:#0b265f;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .06s,color .15s}.board__nav>button:hover{background:#f2f6ff}.board__nav>button.is-active{background:#eaf1ff;color:#1e4dff;transform:translateY(-2px)}.mate-search{width:100%;height:100%;display:flex;flex-direction:column;background-color:transparent;padding:0;overflow:hidden;pointer-events:none}.mate-search>*{pointer-events:auto}.mate-search h1{margin:0;padding:1rem;font-size:1.5rem;text-align:center;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;flex-shrink:0;position:relative;z-index:1}.create-post-button{position:absolute;bottom:20px;left:50%;transform:translate(-50%);padding:12px 30px;font-size:1rem;font-weight:700;color:#fff;background-color:#007bff;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;z-index:1;white-space:nowrap}.create-post-button:hover{background-color:#0056b3;box-shadow:0 6px 8px #00000026}.create-post-button:active{transform:translate(-50%) scale(.95)}.post-form-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.post-form{background-color:#fff;border-radius:15px;padding:2rem;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 25px #0003;animation:slideUp .3s ease}.post-form h2{margin:0 0 1.5rem;font-size:1.5rem;color:#212529;text-align:center}.form-group{margin-bottom:1.2rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#495057;font-size:.95rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#007bff}.form-group textarea{resize:vertical;min-height:80px}.form-buttons{display:flex;gap:1rem;margin-top:1.5rem}.form-buttons button{flex:1;padding:.85rem;font-size:1rem;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.cancel-button{background-color:#6c757d;color:#fff}.cancel-button:hover{background-color:#5a6268}.submit-button{background-color:#007bff;color:#fff}.submit-button:hover{background-color:#0056b3}.cancel-button:active,.submit-button:active{transform:scale(.98)}.view-toggle-button{position:absolute;bottom:30px;right:20px;width:50px;height:50px;border:none;border-radius:50%;cursor:pointer;z-index:100;box-shadow:0 4px 6px #0003;transition:all .3s ease}.view-toggle-button.map-mode{background-color:#007bff}.view-toggle-button.map-mode:hover{background-color:#0056b3;box-shadow:0 6px 8px #00000040;transform:scale(1.05)}.view-toggle-button.list-mode{background-color:#dc3545}.view-toggle-button.list-mode:hover{background-color:#c82333;box-shadow:0 6px 8px #00000040;transform:scale(1.05)}.view-toggle-button:active{transform:scale(.95)}.mate-search.list-view{background-color:#fff}.filter-bar{display:flex;gap:.75rem;padding:1rem;background-color:#fff;border-bottom:1px solid #dee2e6;flex-shrink:0;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;-webkit-user-select:none;user-select:none}.filter-bar::-webkit-scrollbar{display:none}.filter-bar.grabbing{cursor:grabbing}.filter-button{padding:.5rem .75rem;border:1px solid #ced4da;border-radius:6px;font-size:.9rem;background-color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0;width:auto;min-width:fit-content;white-space:nowrap;font-family:inherit}.filter-button:hover{background-color:#f8f9fa;border-color:#adb5bd}.filter-button.active{background-color:#007bff;color:#fff;border-color:#007bff}.filter-button:active{transform:scale(.98)}.active-filters{display:flex;gap:.5rem;padding:.75rem 1rem;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;flex-wrap:wrap;flex-shrink:0;min-height:50px}.filter-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background-color:#007bff;color:#fff;border-radius:20px;font-size:.85rem;font-weight:500}.filter-tag button{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.filter-tag button:hover{background-color:#fff3}.party-list{flex:1;overflow-y:auto;padding:1rem;background-color:#f8f9fa;position:relative;z-index:10;height:100%}.no-parties{text-align:center;padding:3rem 1rem;color:#6c757d;font-size:1rem}.party-item{background-color:#fff;border-radius:10px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}.party-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.party-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e9ecef}.party-header h3{margin:0;font-size:1.1rem;color:#212529}.party-header .distance{background-color:#28a745;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.party-info{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.75rem}.party-info p{margin:0;font-size:.9rem;color:#495057}.party-goal{margin:.75rem 0 0;padding-top:.75rem;border-top:1px solid #e9ecef;color:#6c757d;font-size:.9rem;line-height:1.5}.create-post-button-list{position:fixed;bottom:65px;left:50%;transform:translate(-50%);padding:12px 30px;font-size:1rem;font-weight:700;color:#fff;background-color:#007bff;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;z-index:50}.create-post-button-list:hover{background-color:#0056b3;box-shadow:0 6px 8px #00000026}.create-post-button-list:active{transform:translate(-50%) scale(.95)}.time-inputs{display:flex;align-items:center;gap:.5rem}.time-inputs input{width:70px;padding:.5rem;text-align:center}.time-inputs span{font-size:.95rem;color:#495057}.filter-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.filter-modal{background-color:#fff;border-radius:15px;padding:2rem;max-width:400px;width:90%;max-height:70vh;overflow-y:auto;box-shadow:0 10px 25px #0003;animation:slideUp .3s ease}.filter-modal h3{margin:0 0 1.5rem;font-size:1.3rem;color:#212529;text-align:center}.filter-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.filter-option-button{padding:.85rem 1rem;border:1px solid #ced4da;border-radius:8px;font-size:1rem;background-color:#fff;color:#495057;cursor:pointer;transition:all .2s ease;text-align:left;font-family:inherit}.filter-option-button:hover{background-color:#f8f9fa;border-color:#adb5bd}.filter-option-button.selected{background-color:#007bff;color:#fff;border-color:#007bff;font-weight:600}.filter-option-button:active{transform:scale(.98)}.filter-modal-close{width:100%;padding:.85rem;font-size:1rem;font-weight:700;background-color:#6c757d;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.filter-modal-close:hover{background-color:#5a6268}.filter-modal-close:active{transform:scale(.98)}.location-input-group{display:flex;gap:8px;align-items:center}.location-input-group input{flex:1;width:auto}.location-picker-btn{flex-shrink:0;width:45px;height:45px;padding:0;background-color:#28a745;border:1px solid #28a745;border-radius:8px;font-size:1.3rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.location-picker-btn:hover{background-color:#218838;border-color:#1e7e34;transform:scale(1.05)}.location-picker-btn:active{transform:scale(.95)}.location-picker-btn:focus{outline:none;box-shadow:0 0 0 3px #28a74540}.map-display-wrapper{width:100%;height:100%;position:relative}.map-display{width:100%;height:100%;position:relative;transition:opacity .3s ease-in-out}.map-display.map-loading{opacity:0}.map-loading-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#e0e0e0,#f5f5f5,#e0e0e0);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.skeleton-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,#fff0,#ffffff80,#fff0);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.loading-text{font-size:14px;color:#666;margin-top:20px;z-index:1001;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.location-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .2s ease-in-out}.location-picker-modal{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.location-picker-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.location-picker-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#333}.close-btn{background:none;border:none;font-size:2rem;color:#888;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s,color .2s}.close-btn:hover{background-color:#f0f0f0;color:#333}.search-container{display:flex;gap:8px;padding:15px 20px;border-bottom:1px solid #e0e0e0}.search-container input{flex:1;padding:10px 15px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}.search-container input:focus{border-color:#4a90e2}.search-container button{padding:10px 20px;background-color:#4a90e2;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.search-container button:hover{background-color:#357abd}.search-results{max-height:200px;overflow-y:auto;border-bottom:1px solid #e0e0e0;background-color:#fafafa}.search-result-item{padding:12px 20px;border-bottom:1px solid #e8e8e8;cursor:pointer;transition:background-color .2s}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background-color:#e3f2fd}.place-name{font-size:.95rem;font-weight:600;color:#333;margin-bottom:4px}.place-address{font-size:.85rem;color:#666}.map-container{width:100%;height:400px;border-bottom:1px solid #e0e0e0}.picker-info{padding:10px 20px;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;font-size:.85rem;color:#666;text-align:center}.selected-address{padding:12px 20px;background-color:#e8f5e9;border-bottom:1px solid #c8e6c9;font-size:.9rem;color:#2e7d32}.selected-address strong{font-weight:600;margin-right:8px}.location-picker-footer{display:flex;gap:10px;padding:20px}.location-picker-footer button{flex:1;padding:12px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn{background-color:#f5f5f5;color:#666}.cancel-btn:hover{background-color:#e0e0e0;color:#333}.confirm-btn{background-color:#4caf50;color:#fff}.confirm-btn:hover{background-color:#45a049}.confirm-btn:disabled{background-color:#ccc;color:#888;cursor:not-allowed}@media (max-width: 768px){.location-picker-modal{width:95%;max-height:95vh}.location-picker-header h2{font-size:1.2rem}.map-container{height:300px}.search-container input{font-size:.9rem}.search-container button{padding:10px 15px;font-size:.9rem}}.search-results::-webkit-scrollbar{width:6px}.search-results::-webkit-scrollbar-track{background:#f1f1f1}.search-results::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.search-results::-webkit-scrollbar-thumb:hover{background:#555}.run-recorder{width:100%;height:100%;display:flex;flex-direction:column;background-color:transparent;padding:0;overflow:hidden;pointer-events:none}.run-recorder>*{pointer-events:auto}.run-recorder h1{margin:0;padding:1rem;font-size:1.5rem;text-align:center;background-color:#f8f9fa;border-bottom:1px solid #dee2e6;flex-shrink:0;position:relative;z-index:1}.location-error{background-color:#fff3cd;color:#856404;padding:.75rem 1rem;text-align:center;font-size:.9rem;border-bottom:1px solid #ffeaa7;flex-shrink:0;position:relative;z-index:1}.accuracy-info{background-color:#f8d7da;color:#721c24;padding:.5rem 1rem;text-align:center;font-size:.85rem;border-bottom:1px solid #f5c6cb;flex-shrink:0;overflow:hidden;animation:slideDown .5s ease-out;position:relative;z-index:1}@keyframes slideDown{0%{max-height:0;opacity:0;padding-top:0;padding-bottom:0}to{max-height:100px;opacity:1;padding-top:.5rem;padding-bottom:.5rem}}.map-full{flex:1;width:100%;position:relative}.map-small{width:100%;flex:1;min-height:0;position:relative}.start-button{position:absolute;bottom:20px;left:50%;transform:translate(-50%);padding:12px 40px;font-size:1.1rem;font-weight:700;color:#fff;background-color:#28a745;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;z-index:1}.start-button:hover{background-color:#218838;box-shadow:0 6px 8px #00000026}.start-button:active{transform:translate(-50%) scale(.95)}.recording-button{position:absolute;bottom:20px;left:50%;transform:translate(-50%);padding:12px 40px;font-size:1.1rem;font-weight:700;color:#fff;background-color:#ff6b6b;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;z-index:1;animation:pulse 1.5s ease-in-out infinite}.recording-button:hover{background-color:#ff5252;box-shadow:0 6px 8px #00000026}.recording-button:active{transform:translate(-50%) scale(.95)}@keyframes pulse{0%,to{box-shadow:0 4px 6px #0000001a,0 0 #ff6b6bb3}50%{box-shadow:0 4px 6px #0000001a,0 0 0 10px #ff6b6b00}}.recording-info{flex:none;background-color:#fff;padding:.5rem 1rem 1rem;display:flex;flex-direction:column;justify-content:flex-start;-webkit-user-select:none;user-select:none;cursor:grab;box-shadow:0 -2px 10px #0000001a;z-index:20}.recording-info:active{cursor:grabbing}.swipe-indicator{width:50px;height:4px;background-color:#dee2e6;border-radius:2px;margin:.5rem auto .8rem;flex-shrink:0}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}.info-item{text-align:center;padding:.8rem 0;border-bottom:1px solid #e9ecef;border-right:1px solid #e9ecef}.info-item:nth-child(2),.info-item:nth-child(4){border-right:none}.info-item:nth-child(3),.info-item:nth-child(4){border-bottom:none}.info-label{font-size:.85rem;color:#6c757d;margin-bottom:.3rem;font-weight:500}.info-value{font-size:1.8rem;font-weight:700;color:#212529}.button-group{display:flex;gap:.8rem;margin-top:.8rem;justify-content:center;align-items:center;flex-shrink:0}.pause-button,.resume-button,.stop-button{padding:12px 30px;font-size:1rem;font-weight:700;color:#fff;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;flex-shrink:0;min-width:100px}.pause-button{background-color:#ffc107}.pause-button:hover{background-color:#e0a800;box-shadow:0 6px 8px #00000026}.resume-button{background-color:#28a745}.resume-button:hover{background-color:#218838;box-shadow:0 6px 8px #00000026}.stop-button{background-color:#dc3545}.stop-button:hover{background-color:#c82333;box-shadow:0 6px 8px #00000026}.pause-button:active,.resume-button:active,.stop-button:active{transform:scale(.95)}.refresh-location-button{position:absolute;bottom:90px;right:20px;width:50px;height:50px;background-color:#ff8c42;border:none;border-radius:50%;cursor:pointer;box-shadow:0 4px 6px #0003;transition:all .3s ease;z-index:1}.refresh-location-button:hover{background-color:#ff7426;box-shadow:0 6px 8px #00000040;transform:scale(1.05)}.refresh-location-button:active{transform:scale(.95)}.refresh-location-button.refreshing{animation:spin 1s linear infinite;opacity:.7}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.summary-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.summary-modal{background-color:#fff;border-radius:12px;padding:1.5rem;width:90%;max-width:400px;box-shadow:0 4px 20px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.summary-modal h2{margin:0 0 1rem;font-size:1.3rem;text-align:center;color:#212529;font-weight:700}.warning-message{text-align:center;font-size:.85rem;color:#555;margin-top:1rem;margin-bottom:.5rem;line-height:1.4}.modal-button-group{display:flex;gap:.8rem;margin-top:1rem;justify-content:center;align-items:center}.save-button,.cancel-button{padding:12px 30px;font-size:1rem;font-weight:700;color:#fff;border:none;border-radius:50px;cursor:pointer;box-shadow:0 4px 6px #0000001a;transition:all .3s ease;flex:1;min-width:100px}.save-button{background-color:#28a745}.save-button:hover{background-color:#218838;box-shadow:0 6px 8px #00000026}.cancel-button{background-color:#6c757d}.cancel-button:hover{background-color:#5a6268;box-shadow:0 6px 8px #00000026}.save-button:active,.cancel-button:active{transform:scale(.95)}*{box-sizing:border-box}:root{--bg: #f7f8fb;--panel: #ffffff;--text-strong: #1f2937;--text: #4b5563;--muted: #9ca3af;--line: #e5e7eb;--primary: #2d66ff;--radius: 14px;--shadow: 0 10px 30px rgba(8, 36, 95, .08)}.chat-wrap{display:flex;min-height:100dvh}.chat-sidebar{width:320px;max-width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column}.chat-title{margin:0 0 10px;font-size:1.35rem;font-weight:700;color:var(--text-strong);padding-bottom:.7rem}.chat-status,.chat-error,.chat-empty{text-align:center;padding:16px 8px;font-size:.92rem;color:var(--muted);border:1px dashed var(--line);border-radius:10px;margin-top:8px}.chat-error{color:#ef4444;border-color:#fecaca}.room-list{list-style:none;margin:8px 0 0;padding:0;flex:1 1 auto;min-height:0;overflow-y:auto;border-top:1px solid var(--line)}.room-list{scrollbar-width:none;-ms-overflow-style:none}.room-list::-webkit-scrollbar{display:none}.room-item{display:flex;align-items:center;gap:12px;padding:14px 10px;border-bottom:1px solid var(--line);cursor:pointer;transition:background .15s ease,transform .04s ease}.room-item:hover{background:#f7faff}.room-item:active{transform:translateY(1px)}.room-avatar{flex-shrink:0}.avatar-circle{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;box-shadow:0 2px 8px #667eea4d}.room-content{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:4px}.room-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.room-title{flex:1 1 auto;font-size:.95rem;font-weight:600;color:var(--text-strong);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-time{flex-shrink:0;font-size:.75rem;color:var(--muted);white-space:nowrap}.room-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.room-preview{flex:1 1 auto;font-size:.85rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{flex-shrink:0;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#ef4444;color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #ef44444d}.room-item.is-active{background:#eff4ff;border-left:3px solid var(--primary);padding-left:9px}@media (max-width: 640px){.chat-wrap{padding:12px}.chat-sidebar{width:100%;border-radius:12px}}.chat-detail{--tone-panel: var(--panel);--tone-text: var(--text);--left-bg: #ffffff;--left-fg: #122046;--left-bd: rgba(12, 22, 54, .08);--right-bg: var(--panel-border);--right-fg: #ffffff;--right-bd: rgba(255, 255, 255, .22);--muted: rgba(255, 255, 255, .7);--separator: rgba(255, 255, 255, .12)}.chat-detail{height:100%;width:100%;display:flex;flex-direction:column;overflow:hidden;overscroll-behavior:contain}.message-frame{flex:1;display:grid;grid-template-rows:auto 1fr auto;background:var(--tone-panel);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow, 0 8px 28px rgba(0,0,0,.14));min-height:0}.frame-title{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:14px 16px;color:var(--tone-text);background:linear-gradient(180deg,rgba(255,255,255,.07),transparent);border-bottom:1px solid var(--separator)}.back-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:inherit;font-size:18px;padding:6px 10px;border-radius:10px;cursor:pointer;transition:background-color .18s ease,transform .08s ease}.back-btn:hover{background:#ffffff14}.back-btn:active{transform:translateY(1px)}.room-header{margin:0;font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-list{position:relative;min-height:0;overflow-y:auto;padding:14px 12px 18px;margin:0;list-style:none;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent;overscroll-behavior:contain;touch-action:pan-y}.message-list::-webkit-scrollbar{width:6px}.message-list::-webkit-scrollbar-thumb{background:#ffffff40;border-radius:999px}.loading-older,.empty-msg{text-align:center;color:#ffffffd9;font-size:12px;padding:8px 0 12px}.message-item{display:grid;grid-template-columns:minmax(0,1fr);justify-items:start;gap:6px;margin:12px 0;max-width:min(78%,560px)}.message-item.mine{margin-left:auto;justify-items:end}.message-item.theirs+.message-item.theirs{margin-top:6px}.message-item.mine+.message-item.mine{margin-top:6px}.msg-top{width:100%;display:flex;align-items:center;gap:8px;padding:0 4px;opacity:.92}.message-item.mine .msg-top{justify-content:flex-end}.msg-user{font-weight:700;font-size:12px;color:var(--tone-text);letter-spacing:.1px}.msg-time{font-size:11px;color:var(--muted)}.msg-text{position:relative;padding:11px 14px;border-radius:16px;word-break:break-word;line-height:1.5;background:var(--left-bg);color:var(--left-fg);border:1px solid var(--left-bd);box-shadow:0 1px #0000000a;transition:transform .08s ease,box-shadow .15s ease}.message-item.mine .msg-text{background:var(--right-bg);color:var(--right-fg);border-color:var(--right-bd);box-shadow:0 1px #0000000f,0 8px 18px #0000001f}.msg-text:active{transform:translateY(1px)}.msg-text a{color:inherit;text-decoration:underline;text-underline-offset:2px;word-break:break-all}.frame-composer{display:grid;grid-template-columns:1fr auto;gap:8px;padding:10px;background:linear-gradient(0deg,rgba(255,255,255,.07),transparent);border-top:1px solid var(--separator);padding-bottom:calc(18px + env(safe-area-inset-bottom,0px))}.chat-input{resize:none;width:100%;min-height:42px;max-height:140px;padding:10px 12px;background:#f6f8ff;color:#0e1d4a;border:1px solid rgba(13,63,255,.25);border-radius:14px;outline:none;line-height:1.5;transition:border-color .15s ease,box-shadow .15s ease,background-color .2s ease}.chat-input::placeholder{color:#7b8cb6}.chat-input:focus{border-color:var(--panel-border);box-shadow:0 0 0 3px #2d66ff2e}.send-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;padding:0 16px;border-radius:14px;background:var(--panel-border);color:#fff;font-weight:700;cursor:pointer;min-width:74px;transition:filter .15s ease,transform .08s ease}.send-btn:hover{filter:brightness(1.05)}.send-btn:active{transform:translateY(1px)}.send-btn:disabled{opacity:.55;cursor:not-allowed}@media (max-width: 420px){.frame-title{padding:12px}.room-header{font-size:15px}.message-list{padding:10px 10px 14px}.msg-text{font-size:14px}.chat-input{min-height:38px}}.back-btn:focus-visible,.chat-input:focus-visible,.send-btn:focus-visible{outline:2px solid rgba(255,255,255,.65);outline-offset:2px;border-radius:12px}@media (prefers-contrast: more){.msg-text,.chat-input{border-width:1.25px}.send-btn{outline:2px solid transparent}.send-btn:focus-visible{outline-color:#ffffffd9}}html,body,#root{height:100%}.ei-container{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg, #dbeaf4);box-sizing:border-box}.ei-card{width:360px;max-width:100%;background:var(--device, #fff);border-radius:var(--radius-lg, 22px);box-shadow:var(--shadow, 0 20px 40px rgba(0,0,0,.08));padding:12px 12px 100px;display:flex;flex-direction:column;max-height:calc(100dvh - 48px);overflow-y:auto}.ei-card{display:flex;flex-direction:column}@supports (padding: max(0px)){.ei-card{padding-bottom:max(100px,env(safe-area-inset-bottom))}}.title-container{align-items:center;justify-content:center;gap:8px;text-align:center;padding:30px 0}.ei-avatar{width:140px;height:140px;border-radius:16px;background:#e6f1fb;color:#6b7682;margin:16px auto 50px;display:grid;place-items:center;text-align:center;cursor:pointer;border:1.5px dashed #c9d7e3;transition:transform .08s ease;-webkit-user-select:none;user-select:none}.ei-avatar:hover{transform:translateY(-1px)}.ei-avatar img{width:100%;height:100%;object-fit:cover;border-radius:12px}.ei-row{display:grid;grid-template-columns:90px 1fr;align-items:start;gap:12px;margin-bottom:12px}.ei-label{line-height:40px;color:#333d4b;font-size:14px}.ei-input,.ei-textarea{max-width:260px;border:1.2px solid #d8e3ee;border-radius:10px;background:#eaf4ff;padding:10px 12px;font-size:14px;outline:none}.ei-input:focus,.ei-textarea:focus{border-color:#8bb6ff;background:#f5faff}.ei-textarea-wrap{position:relative}.ei-textarea{resize:vertical;min-height:110px}.ei-counter{position:absolute;right:10px;bottom:8px;font-size:12px;color:#8a94a6}.ei-help{margin:4px 0 10px 90px;font-size:12px;color:#6b7682}.ei-help-error{color:#e54848}.ei-error{border-color:#e54848!important;background:#fff5f5!important}.ei-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.ei-btn{height:40px;padding:0 16px;border-radius:10px;border:1px solid #dbe6f1;background:#f7fbff;cursor:pointer;font-size:14px}.ei-btn:hover{filter:brightness(.98)}.ei-btn.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.ei-btn.ghost{background:#fff}@media (max-width: 420px){.ei-card{width:100%;padding:12px 12px 80px;border-radius:18px}.ei-row{grid-template-columns:1fr;gap:8px}.ei-help,.ei-help-error{margin-left:0}.ei-avatar{width:120px;height:120px}}@media (min-width: 1024px){.ei-card{width:390px}}@media (prefers-reduced-motion: reduce){.ei-avatar{transition:none}}
