*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w: 340px;--header-h: 0px;--radius: 10px;--shadow: 0 2px 12px rgba(0,0,0,.15);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}html,body,#root{height:100%;overflow:hidden}.app-layout{display:flex;height:100vh;position:relative}.map-container{flex:1;position:relative;overflow:hidden}.map-canvas{width:100%;height:100%}.map-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#fff9;font-size:1rem;color:#333;gap:8px;pointer-events:none}.map-spinner{display:inline-block;width:18px;height:18px;border:3px solid #ccc;border-top-color:#3182ce;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-toast{position:absolute;bottom:70px;left:50%;transform:translate(-50%);padding:8px 16px;border-radius:20px;font-size:.875rem;font-weight:500;white-space:nowrap;pointer-events:none;animation:fadeInUp .2s ease;box-shadow:var(--shadow)}.map-toast--info{background:#2d3748;color:#fff}.map-toast--warn{background:#d69e2e;color:#fff}.map-toast--error{background:#e53e3e;color:#fff}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.map-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#0000008c;color:#fff;padding:6px 14px;border-radius:20px;font-size:.8rem;pointer-events:none}.map-hint--reposition{background:#b47800d9}.map-marker{width:38px;height:38px;border-radius:50%;background:var(--c, #666);border:3px solid #fff;box-shadow:0 2px 8px #00000059;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;cursor:pointer;transition:transform .15s}.map-marker:hover{transform:scale(1.15)}.map-marker__img{width:100%;height:100%;border-radius:50%;object-fit:cover}.map-marker--gold{border-color:#d4af37;box-shadow:0 2px 8px #b48c0073}.map-marker--silver{border-color:#a8b2bb;box-shadow:0 2px 8px #6b7d8d66}.dest-marker{width:52px;height:52px;border-radius:6px;border:3px solid #fff;box-shadow:0 2px 10px #0006;overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s}.dest-marker:hover{transform:scale(1.12);box-shadow:0 4px 16px #00000080}.dest-marker__img{width:100%;height:100%;object-fit:cover;display:block}.dest-card{position:absolute;bottom:80px;left:50%;transform:translate(-50%);width:300px;background:#fff;border-radius:var(--radius);box-shadow:0 4px 24px #00000040;overflow:hidden;z-index:10;animation:fadeInUp .2s ease}.dest-card__photo{width:100%;height:160px;object-fit:cover;display:block}.dest-card__body{padding:12px 14px 14px}.dest-card__title{font-weight:700;font-size:1rem;margin-bottom:6px;color:#1a202c}.dest-card__desc{font-size:.8rem;color:#4a5568;line-height:1.5;margin-bottom:10px}.dest-card__link{display:inline-block;font-size:.8rem;font-weight:600;color:#3182ce;text-decoration:none}.dest-card__link:hover{text-decoration:underline}.dest-card__close{position:absolute;top:8px;right:8px;background:#00000073;border:none;color:#fff;width:24px;height:24px;border-radius:50%;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.dest-card__close:hover{background:#000000b3}.sidebar{width:var(--sidebar-w);flex-shrink:0;display:flex;flex-direction:column;background:#f7fafc;border-left:1px solid #E2E8F0;overflow-y:auto}.sidebar__header{background:linear-gradient(135deg,#2d3748,#1a202c);color:#fff;padding:16px 16px 12px;flex-shrink:0}.sidebar__header-top{display:flex;align-items:center;justify-content:space-between}.sidebar__title{font-size:1.15rem;font-weight:700}.sidebar__edit-btn{background:none;border:1px solid rgba(255,255,255,.4);color:#fff;font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:10px;cursor:pointer;transition:background .15s}.sidebar__edit-btn:hover{background:#ffffff26}.sidebar__sub{font-size:.8rem;opacity:.7;margin-top:2px;margin-bottom:10px}.sidebar__progress{background:#fff3;border-radius:4px;height:6px;overflow:hidden}.sidebar__progress-bar{height:100%;background:#68d391;transition:width .5s ease;border-radius:4px}.sidebar__progress-label{font-size:.72rem;opacity:.6;margin-top:4px}.sidebar__friends{padding:8px;display:flex;flex-direction:column;gap:6px}.user-card{display:flex;align-items:flex-start;gap:10px;background:#fff;border-radius:var(--radius);padding:10px 12px;box-shadow:0 1px 3px #00000014;border:2px solid transparent;transition:border-color .2s}.user-card--me{border-color:#bee3f8}.user-card__avatar{flex-shrink:0;position:relative;width:44px;height:44px;border-radius:50%;border:3px solid;overflow:hidden}.user-card__avatar img{width:100%;height:100%;object-fit:cover}.user-card__avatar span{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#fff;font-weight:700;font-size:14px}.user-card__you-badge{position:absolute;bottom:-2px;right:-2px;background:#3182ce;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:4px}.user-card__info{flex:1;min-width:0}.user-card__name{font-weight:600;font-size:.9rem;margin-bottom:5px}.user-card__pins{display:flex;flex-direction:column;gap:4px}.pin-slot{display:flex;align-items:center;gap:6px;font-size:.78rem;border-radius:6px;padding:4px 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.pin-slot--empty{color:#a0aec0;background:#f7fafc;border:1px dashed #CBD5E0}.pin-slot__dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;opacity:.5}.pin-slot--filled{background:#ebf8ff;border:1px solid #BEE3F8;cursor:pointer;color:#2d3748;border-left:3px solid var(--pin-color, #3182CE)}.pin-slot--filled:hover{background:#bee3f8}.pin-slot__flag{font-size:1rem}.pin-slot__place{flex:1;overflow:hidden;text-overflow:ellipsis;font-weight:500}.pin-slot__remove{flex-shrink:0;color:#e53e3e;font-size:10px;font-weight:700;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fed7d7;cursor:pointer;opacity:.7}.pin-slot__remove:hover{opacity:1}.pin-slot--filled.pin-slot--gold{border:2px solid #D4AF37;border-left:3px solid #9B7A1C;background:#fffef0;box-shadow:0 1px 6px #b48c0033}.pin-slot--filled.pin-slot--gold:hover{background:#fff9d6}.pin-slot--filled.pin-slot--silver{border:2px solid #A8B2BB;border-left:3px solid #6B7D8D;background:#f7f8fa;box-shadow:0 1px 6px #6b7d8d2e}.pin-slot--filled.pin-slot--silver:hover{background:#edf1f4}.pin-slot--empty.pin-slot--gold{border-color:#d4af37}.pin-slot--empty.pin-slot--silver{border-color:#a8b2bb}.tally{margin:4px 8px 12px;background:#fff;border-radius:var(--radius);padding:12px;box-shadow:0 1px 3px #00000014}.tally__title{font-weight:700;font-size:.8rem;color:#4a5568;margin-bottom:8px}.tally__row{display:flex;align-items:center;gap:6px;margin-bottom:5px;font-size:.78rem}.tally__name{width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.tally__bar-wrap{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.tally__bar{height:100%;background:#4299e1;border-radius:3px;transition:width .4s ease}.tally__count{width:16px;text-align:right;color:#718096;font-weight:600}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;border-radius:16px;padding:40px 36px;text-align:center;box-shadow:0 20px 60px #0003;max-width:380px;width:90%}.login-emoji{font-size:4rem;margin-bottom:12px}.login-card h1{font-size:1.6rem;font-weight:800;color:#2d3748;margin-bottom:8px}.login-card p{color:#718096;margin-bottom:6px}.login-sub{font-size:.875rem}.login-btn-wrap{margin-top:24px;display:flex;justify-content:center}.dev-login{margin-top:24px;padding-top:20px;border-top:1px dashed #E2E8F0}.dev-label{font-size:.72rem;color:#a0aec0;margin-bottom:10px}.dev-friend-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.dev-friend-btn{padding:6px 2px;border-radius:6px;border:2px solid;background:none;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .15s}.dev-friend-btn:hover{opacity:.75}.masquerade-panel{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;background:#1a202ceb;color:#fff;padding:6px 10px;border-radius:24px;box-shadow:var(--shadow);z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.masq-label{font-size:.72rem;opacity:.6;white-space:nowrap;margin-right:4px}.masq-friends{display:flex;gap:4px}.masq-btn{padding:4px 10px;border-radius:12px;border:2px solid var(--c, #fff);background:transparent;color:var(--c, #fff);font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s}.masq-btn:hover,.masq-btn.masq-active{background:var(--c, #fff);color:#1a202c}.masq-signout{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:12px;padding:2px 4px}.masq-signout:hover{color:#fff}.admin-drawer{position:absolute;top:0;right:0;bottom:0;z-index:30;width:320px;background:#f7fafc;border-left:1px solid #E2E8F0;display:flex;flex-direction:column;overflow:hidden;box-shadow:-4px 0 20px #00000026}.admin-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:linear-gradient(135deg,#2d3748,#1a202c);color:#fff;flex-shrink:0}.admin-drawer__title{font-weight:700;font-size:1rem}.admin-drawer__header-actions{display:flex;align-items:center;gap:8px}.admin-drawer__add{padding:4px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.4);background:transparent;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:background .15s}.admin-drawer__add:hover{background:#ffffff26}.admin-drawer__close{background:none;border:none;color:#fff9;font-size:14px;cursor:pointer;padding:2px 4px;line-height:1;transition:color .15s}.admin-drawer__close:hover{color:#fff}.admin-drawer__list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.admin-dest-row{display:flex;align-items:center;gap:8px;background:#fff;border-radius:8px;padding:8px;border:2px solid transparent;box-shadow:0 1px 3px #00000012}.admin-dest-row--active{border-color:#bee3f8}.admin-dest-row__thumb{width:40px;height:40px;border-radius:5px;object-fit:cover;flex-shrink:0}.admin-dest-row__title{flex:1;font-size:.8rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-dest-row__actions{display:flex;gap:4px;flex-shrink:0}.admin-dest-row__btn{width:28px;height:28px;border-radius:6px;border:none;background:#edf2f7;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .15s}.admin-dest-row__btn:hover{background:#e2e8f0}.admin-dest-row__btn--del:hover{background:#fed7d7}.admin-form{margin:8px;border-radius:10px;background:#fff;padding:12px;box-shadow:0 1px 4px #0000001a;flex-shrink:0;overflow-y:auto;max-height:70vh;display:flex;flex-direction:column;gap:8px}.admin-form__title{font-weight:700;font-size:.85rem;color:#2d3748;margin-bottom:2px}.admin-form__label{display:flex;flex-direction:column;gap:3px;font-size:.75rem;font-weight:600;color:#4a5568}.admin-form__row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.admin-form__input{padding:6px 8px;border-radius:6px;border:1px solid #CBD5E0;font-size:.8rem;background:#f7fafc;outline:none;transition:border-color .15s}.admin-form__input:focus{border-color:#3182ce;background:#fff}.admin-form__input:disabled{opacity:.5;cursor:not-allowed}.admin-form__textarea{resize:vertical;font-family:inherit}.admin-form__preview{width:100%;height:90px;object-fit:cover;border-radius:6px;border:1px solid #E2E8F0}.admin-form__error{font-size:.75rem;color:#e53e3e;background:#fff5f5;padding:6px 8px;border-radius:6px}.admin-form__actions{display:flex;gap:8px;margin-top:2px}.admin-form__save{flex:1;padding:7px;border-radius:8px;border:none;background:#3182ce;color:#fff;font-weight:700;font-size:.82rem;cursor:pointer;transition:background .15s}.admin-form__save:hover:not(:disabled){background:#2c5282}.admin-form__save:disabled{opacity:.5;cursor:not-allowed}.admin-form__cancel{padding:7px 14px;border-radius:8px;border:1px solid #CBD5E0;background:#fff;font-size:.82rem;cursor:pointer;transition:background .15s}.admin-form__cancel:hover{background:#edf2f7}.admin-form__reposition-btn{width:100%;padding:7px;border-radius:8px;border:1px dashed #CBD5E0;background:#f7fafc;font-size:.78rem;cursor:pointer;color:#4a5568;transition:all .15s;text-align:center}.admin-form__reposition-btn:hover{background:#edf2f7;border-color:#a0aec0}.admin-form__reposition-btn--active{background:#fefcbf;border-color:#d69e2e;border-style:solid;color:#744210;font-weight:600}@media (max-width: 640px){:root{--sidebar-w: 100vw}.app-layout{flex-direction:column}.map-container{height:55vh;flex:none}.sidebar{height:45vh;border-left:none;border-top:1px solid #E2E8F0}}
