@import url(https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700&display=swap);header .header-bar{align-items:center!important;background:#fff!important;border-bottom:1px solid #e0e0e0!important;display:flex!important;height:56px!important;justify-content:center!important;left:0!important;margin:0!important;overflow:visible!important;padding:0!important;position:fixed!important;right:0!important;top:0!important;width:100vw!important;z-index:1100!important}header .header-bar .header-content{align-items:center!important;box-sizing:border-box!important;display:flex!important;justify-content:space-between!important;margin:0 auto!important;max-width:768px!important;padding:0 16px!important;width:calc(100vw - 32px)!important}.header-logo{color:#222;cursor:pointer;flex-shrink:0;font-size:1.5rem;font-weight:700;letter-spacing:1px;white-space:nowrap}.header-icons{align-items:center;display:flex;gap:10px}.header-icon-btn{background:none;border:none;border-radius:50%;color:#444;cursor:pointer;font-size:1.3rem;padding:6px;transition:background .2s}.header-icon-btn:hover{background:#f5f5f5}.header-icon{color:#444;font-size:1.3rem}.header-btn{align-items:center;background:#7581f0;border:none;border-radius:8px;box-shadow:0 2px 8px 0 #7581f014;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-family:Montserrat,Arial,sans-serif;font-size:14px;font-weight:600;gap:4px;height:40px;margin-right:12px;padding:8px 16px;transition:background .2s;white-space:nowrap}.header-btn:hover{background:#5a67d8}.btn-icon{font-weight:700}.btn-text{display:inline}@media (max-width:768px){header .header-bar .header-content{padding:0 12px!important}.header-logo{font-size:1.3rem}.header-btn{font-size:13px;gap:3px;height:36px;margin-right:8px;padding:8px 12px}.btn-icon{font-size:14px}}@media (max-width:480px){header .header-bar .header-content{padding:0 8px!important}.header-logo{font-size:1.2rem}.header-btn{font-size:12px;gap:2px;height:32px;margin-right:6px;padding:8px 10px}.btn-icon{font-size:13px}.admin-btn,.new-trip-btn{padding:8px}.admin-btn{font-size:11px}}.navbar{align-items:center;background:#fff;bottom:0;box-shadow:0 -1px 8px #0000000a;display:flex;height:56px;justify-content:center;left:0;position:fixed;right:0;width:100%;z-index:1200}.navbar-container{box-sizing:border-box;display:flex;justify-content:space-between;margin:0 auto;max-width:800px;padding:0 16px;width:100%}.navbar-logo{color:#222;cursor:pointer;font-size:24px;font-weight:700}.navbar-items{display:flex;gap:20px;height:100%}.navbar-item{align-items:center;background:none;border:none;border-radius:8px;color:#bbb;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:16px;gap:4px;padding:8px 12px;text-align:center;transition:all .2s ease}.navbar-item.selected,.navbar-item:hover{background:#f3f4fd;color:#7581f0}.navbar-icon{font-size:22px}.navbar-label{color:inherit;font-size:12px}.featured-city-filter{margin:0 0 12px;padding:8px 0}.city-filter-container{-ms-overflow-style:none;display:flex;gap:2px;overflow-x:auto;padding:0;scroll-behavior:smooth;scrollbar-width:none}.city-filter-container::-webkit-scrollbar{display:none}.featured-city-filter .city-item{align-items:center;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;gap:8px;margin:0 8px;min-width:100px;padding:8px;transition:all .3s ease}.featured-city-filter .city-item:hover{transform:translateY(-2px)}.city-circle{background:none;border:none;border-radius:50%;height:100px;overflow:hidden;padding:0;position:relative;transition:all .3s ease;width:100px}.city-circle img{border-radius:50%;height:100%;object-fit:cover;position:relative;width:100%;z-index:2}.city-circle.all-cities{align-items:center;background:#f8f9fa;display:flex;justify-content:center}.all-cities-icon{font-size:90px;position:relative;z-index:2}.city-name{color:#333;display:block;font-size:14px;font-weight:500;margin:0 auto;max-width:100px;overflow:hidden;padding:0;text-align:center;text-overflow:ellipsis;transition:color .3s ease;white-space:nowrap;width:100px}.featured-city-filter .city-item.selected{gap:12px}.featured-city-filter .city-item.selected .city-circle{box-shadow:0 4px 12px #00000026;transform:scale(1.1)}.featured-city-filter .city-item.selected .city-name{color:#7581f0;font-weight:600}.loading-circle{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(45deg,#e0e0e0,#f0f0f0 50%,#e0e0e0);background-size:200% 200%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (max-width:768px){.featured-city-filter{margin-bottom:10px;padding:8px 0}.city-filter-container{gap:2px;padding:0}.featured-city-filter .city-item{gap:6px;margin:0 6px;min-width:75px;padding:6px}.featured-city-filter .city-item.selected{gap:8px}.city-circle{height:75px;width:75px}.all-cities-icon{font-size:68px}.city-name{font-size:12px;max-width:75px;width:75px}}@media (max-width:480px){.featured-city-filter{padding:8px 0}.city-filter-container{gap:2px}.featured-city-filter .city-item{gap:5px;margin:0 4px;min-width:70px;padding:6px}.featured-city-filter .city-item.selected{gap:7px}.city-circle{height:70px;width:70px}.all-cities-icon{font-size:63px}.city-name{font-size:11px;max-width:70px;width:70px}}.trip-sort-section{margin-bottom:20px}.sort-header{align-items:center;display:flex;flex-wrap:nowrap;gap:12px;justify-content:space-between;padding:0 4px}.section-title{color:#111827;flex-shrink:0;font-family:Montserrat,Arial,sans-serif;font-size:22px;font-weight:700;margin:0;white-space:nowrap}.sort-dropdown-container{position:relative}.sort-dropdown-button{align-items:center;background:#f8f9fa;border:1px solid #e5e7eb;border-radius:20px;cursor:pointer;display:flex;gap:6px;justify-content:space-between;min-width:140px;padding:10px 14px;transition:all .2s ease}.sort-dropdown-button:hover{background:#f3f4f6;border-color:#7581f0}.sort-dropdown-text{color:#7581f0;font-family:Montserrat,Arial,sans-serif;font-size:14px;font-weight:600}.sort-dropdown-icon{color:#7581f0;flex-shrink:0;transition:transform .2s ease}.sort-dropdown-icon.open{transform:rotate(180deg)}.sort-dropdown-menu{animation:dropdownFadeIn .15s ease;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 20px #0000001f;min-width:160px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:100}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sort-dropdown-item{align-items:center;background:none;border:none;color:#374151;cursor:pointer;display:flex;font-family:Montserrat,Arial,sans-serif;font-size:14px;font-weight:500;justify-content:space-between;padding:12px 16px;text-align:left;transition:background .15s ease;width:100%}.sort-dropdown-item:hover{background:#f3f4f6}.sort-dropdown-item.selected{background:#f0f3ff;color:#7581f0}.sort-dropdown-item svg{color:#7581f0}@media (max-width:768px){.sort-header{padding:0}.section-title{font-size:20px}.sort-dropdown-button{min-width:130px;padding:8px 12px}.sort-dropdown-text{font-size:13px}.sort-dropdown-menu{min-width:150px}.sort-dropdown-item{font-size:13px;padding:10px 14px}}@media (max-width:480px){.section-title{font-size:18px}.sort-dropdown-button{min-width:auto;padding:6px 10px}.sort-dropdown-text{font-size:12px}.sort-dropdown-icon{height:14px;width:14px}.sort-dropdown-menu{min-width:140px}.sort-dropdown-item{font-size:12px;padding:10px 12px}}.trip-card{background:#fff;border:1px solid #eee;border-radius:12px;box-shadow:0 4px 6px #00000014;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:transform .2s ease,box-shadow .2s}.trip-card:hover{box-shadow:0 8px 16px #0000001f;transform:translateY(-5px)}.trip-image{background:#f3f3f3;height:240px;overflow:hidden;position:relative;width:100%}.trip-card-img,.trip-image img{display:block;height:100%;object-fit:cover;width:100%}.save-button{background:#fffffff2;border-radius:20px;box-shadow:0 2px 6px #0000000f;color:#333;font-size:14px;font-weight:600;padding:8px 16px;position:absolute;right:10px;top:10px;transition:all .2s ease;z-index:2}.save-button:hover{background:#f5f5f5;transform:scale(1.05)}.save-button.saved{background:#7581f0;color:#fff}.trip-info{background:#fff;padding:16px 16px 12px}.trip-title-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.trip-title-row .stat-item{flex-shrink:0;margin-left:12px;padding:8px}.trip-info h3{-webkit-line-clamp:1;color:#222;flex:1 1;font-size:18px;font-weight:700;margin:0;text-overflow:ellipsis}.trip-description,.trip-info h3{-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.trip-description{-webkit-line-clamp:2;color:#666;font-size:14px;height:42px;line-height:1.5;margin:0 0 12px}.trip-styles{display:flex;flex-wrap:wrap;gap:6px;height:24px;margin-bottom:6px;overflow:hidden}.style-tag{background:#f0f0f0;border-radius:8px;color:#333;display:inline-block;font-size:12px;font-weight:500;margin-bottom:2px;margin-right:4px;padding:2px 10px}.trip-days{color:#666;font-size:14px;margin-bottom:8px}.trip-stats{align-items:center;display:flex;gap:16px;margin-bottom:8px}.stat-item{border-radius:6px;font-size:14px;font-weight:500;gap:4px;padding:4px 8px}.stat-item,.stat-item svg{color:#888;transition:all .2s ease}.stat-item svg{flex-shrink:0}.stat-item:hover{background:#7581f01a;color:#7581f0}.stat-item:hover svg{color:#7581f0;transform:scale(1.1)}.stat-item[style*="cursor: pointer"]:active{transform:scale(.95)}.trip-places{height:60px;margin-top:4px;overflow:hidden}.trip-place{color:#444;font-size:13px;gap:4px;margin-bottom:2px}.trip-card.loading,.trip-place{align-items:center;display:flex}.trip-card.loading{background:#f5f5f5;color:#666;justify-content:center;min-height:220px}.heart-icon{cursor:pointer;position:absolute;right:10px;top:10px;transition:all .2s ease;z-index:10}.heart-icon:hover{transform:scale(1.1)}.heart-icon.liked,.heart-icon.saved{color:#7581f0}@media (max-width:768px){.trip-card{border-radius:10px}.trip-image{height:220px}.trip-info{padding:14px 12px 10px}.trip-title-row{margin-bottom:6px}.trip-title-row .stat-item{margin-left:8px;padding:8px}.trip-info h3{font-size:16px}.trip-stats{gap:12px;margin-bottom:6px}.stat-item{font-size:13px;gap:3px}.stat-item svg{height:14px;width:14px}.trip-days{font-size:13px;margin-bottom:6px}.trip-styles{gap:4px;margin-bottom:4px}.style-tag{font-size:11px;padding:1px 8px}.trip-place{font-size:12px}.heart-icon,.save-button{right:8px;top:8px}.save-button{font-size:12px;padding:6px 12px}}@media (max-width:480px){.trip-image{height:200px}.trip-info{padding:12px 10px 8px}.trip-info h3{font-size:15px}.trip-stats{gap:10px}.stat-item{font-size:12px}.stat-item svg{height:13px;width:13px}.trip-days{font-size:12px}.style-tag{font-size:10px;padding:1px 6px}.trip-place{font-size:11px}}:root{--orion-primary:#7581f0;--orion-bg:#fff;--orion-text:#222}body{margin:0;padding:0}.home-container{align-items:center;display:flex;flex-direction:column;overflow:hidden;padding:0;position:relative}.home-container,.home-content{box-sizing:border-box;width:100%}.home-content{margin:0 auto;max-width:800px;padding:24px 16px}.header{margin-bottom:24px;margin-left:auto;margin-right:auto}.header h1{color:#222;font-size:24px;font-weight:700;margin:0}.create-trip-btn{align-items:center;background:#2ecc40;border:none;border-radius:20px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;gap:4px;margin-right:8px;padding:8px 16px}.trips-grid{grid-column-gap:20px;grid-row-gap:16px;column-gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:20px;row-gap:16px}.error,.loading{align-items:center;background:#fff;bottom:0;display:flex;justify-content:center;left:0;min-height:100vh;padding:40px;position:fixed;right:0;text-align:center;top:0;z-index:1000}.error{color:#f44}.welcome-banner{background:linear-gradient(135deg,#94c2fd,#a09cff 50%,#d097f3);border-radius:16px;box-shadow:0 8px 30px #0000001a;color:#fff;margin:24px 0;padding:32px;text-align:center}.welcome-banner h2{color:#fff;font-size:24px;font-weight:700;margin-bottom:16px}.welcome-banner p{color:#fff;font-size:16px;line-height:1.6;margin-bottom:24px;opacity:.95}.search-container{display:flex;justify-content:center;margin-bottom:24px;margin-left:auto;margin-right:auto;max-width:600px;width:100%}.destination-input{border:none;border-radius:30px 0 0 30px;box-shadow:0 2px 10px #0000001a;flex:1 1;font-size:16px;outline:none;padding:14px 20px}.search-button{align-items:center;background:#7581f0;border-radius:0 30px 30px 0;display:flex;font-weight:600;gap:8px;padding:14px 24px}.search-button:hover{background:#636bd9;transform:translateY(-2px)}.banner-buttons{display:flex;gap:16px;justify-content:center}.banner-button{border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .2s ease}.banner-button.primary{background:#fff;border:none;color:#7581f0}.banner-button.primary:hover{background:#f3f3fa;transform:translateY(-2px)}.banner-button.secondary{background:#0000;border:2px solid #fff;color:#fff}.banner-button.secondary:hover{background:#ffffff1a;transform:translateY(-2px)}.explore-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;margin:24px 0;padding:20px;text-align:center}.explore-header h2{color:#fff;font-size:20px;font-weight:600;margin:0 0 8px}.explore-header p{color:#fffc;font-size:14px;margin:0}@media (max-width:768px){.header{margin-bottom:16px;padding:0 8px}.header h1{font-size:20px;margin-left:16px}.create-trip-btn{font-size:12px;margin-right:4px;padding:6px 12px}.home-content{padding:16px 12px}}@media (max-width:480px){.header{margin-bottom:12px;padding:0 4px}.header h1{font-size:18px;margin-left:8px}.create-trip-btn{font-size:11px;margin-right:2px;padding:4px 8px}.home-content{padding:12px 8px}}.discover-places{background-color:#f8f9fa;display:flex;flex-direction:column;height:calc(100vh - 60px)}.discover-header{align-items:center;background-color:#fff;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;padding:20px}.discover-header h1{color:#333;font-size:28px;font-weight:700;margin:0}.view-toggle{align-items:center;background-color:#fff;border:2px solid #7581f0;border-radius:8px;color:#7581f0;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .2s}.view-toggle:hover{background-color:#7581f0;color:#fff}.view-toggle svg{height:20px;width:20px}.city-filters{background-color:#fff;border-bottom:1px solid #e5e5e5;padding:16px 0}.city-scroll{display:flex;gap:16px;overflow-x:auto;padding:0 20px;scrollbar-width:none}.city-scroll::-webkit-scrollbar{display:none}.city-filter-item{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:8px;min-width:80px;transition:transform .2s}.city-filter-item:hover{transform:scale(1.05)}.city-icon-container{align-items:center;background-color:#f0f0f0;border:3px solid #0000;border-radius:50%;display:flex;height:64px;justify-content:center;overflow:hidden;transition:border-color .2s;width:64px}.city-filter-item.active .city-icon-container{background-color:#fff;border-color:#7581f0}.city-icon-emoji{font-size:32px}.city-icon-image{height:100%;object-fit:cover;width:100%}.city-icon-placeholder{color:#666;font-size:24px;font-weight:700}.city-label{color:#666;font-size:12px;font-weight:600;max-width:80px;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.city-filter-item.active .city-label{color:#7581f0}.discover-content{flex:1 1;overflow:hidden;position:relative}.discover-map{height:100%;width:100%}.empty-state,.error-container,.loading-container{align-items:center;display:flex;height:100%;justify-content:center;padding:40px}.error,.loading{color:#666;font-size:16px}.empty-state{flex-direction:column}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{color:#333;font-size:20px;font-weight:700}.empty-state p{color:#666;font-size:16px;line-height:1.5;margin:0}.places-list-view{height:100%;overflow-y:auto}.limit-notice{background-color:#fff8e1;border-left:4px solid #ffb300;border-radius:8px;color:#856404;font-size:14px;font-weight:500;margin:20px 20px 0;padding:12px 20px;text-align:center}.places-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));padding:20px}.place-card{background-color:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;transition:transform .2s,box-shadow .2s}.place-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-4px)}.place-image{background-color:#f0f0f0;background-position:50%;background-size:cover;height:200px;width:100%}.place-placeholder{align-items:center;background:linear-gradient(135deg,#7581f0,#9d9dfc);display:flex;flex-direction:column;height:200px;justify-content:center;padding:20px;width:100%}.place-icon{font-size:48px;margin-bottom:12px}.place-placeholder-text{color:#fff;font-size:16px;font-weight:600;text-align:center}.place-info{padding:16px}.place-name{color:#333;font-size:18px;font-weight:700;margin:0 0 8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-meta{align-items:center;gap:6px;margin-bottom:6px}.place-meta svg{flex-shrink:0}.place-address{color:#888;margin-bottom:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.place-footer{align-items:center;display:flex;gap:8px;justify-content:space-between}.place-type{background-color:#f0f0f0;border-radius:12px;color:#666;font-size:12px;font-weight:600;padding:4px 12px}.place-duration{color:#888;font-size:13px}@media (max-width:768px){.discover-header h1{font-size:24px}.view-toggle span{display:none}.places-grid{gap:12px;grid-template-columns:1fr;padding:12px}.city-icon-container{height:56px;width:56px}.city-icon-emoji{font-size:28px}.city-label{font-size:11px}}@media (min-width:769px) and (max-width:1024px){.places-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (min-width:1440px){.places-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}.login-container{align-items:center;background:#fff;background:var(--sphereloop-bg);display:flex;justify-content:center;min-height:100vh;padding:16px}.login-card{background:#fff;border-radius:16px;box-shadow:0 4px 16px #7581f01a;box-sizing:border-box;margin:32px auto;max-width:480px;padding:48px 40px;width:100%}.login-title{color:#7581f0;color:var(--sphereloop-primary);font-size:2rem;font-weight:700;margin-bottom:24px;text-align:center}.login-form{width:100%}.login-form label{color:#7581f0;color:var(--sphereloop-primary);display:block;font-size:1rem;font-weight:600;margin-bottom:8px}.login-input{border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:1rem;margin-bottom:0;padding:12px;transition:border .2s,box-shadow .2s;width:100%}.login-input:focus{border-color:#7581f0;border-color:var(--sphereloop-primary);box-shadow:0 0 0 2px #7581f01f;outline:none}.login-button{align-items:center;background:#7581f0;background:var(--sphereloop-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;justify-content:center;margin-top:8px;min-height:48px;padding:12px 0;transition:background .2s;width:100%}.login-button:hover:not(:disabled){background:#5a67d8}.login-button:disabled{cursor:not-allowed;opacity:.7}.link-button{color:#7581f0;color:var(--sphereloop-primary);font-size:1rem;font-weight:600;letter-spacing:.01em;margin-top:16px;text-decoration:underline}.login-footer{margin-top:24px;text-align:center}.error-message{margin-bottom:16px}.notification{font-size:.95rem}.success-message{padding:20px 0}.success-icon{align-items:center;background:#48bb78;border-radius:50%;color:#fff;display:flex;font-size:24px;font-weight:700;height:60px;justify-content:center;margin:0 auto 20px;width:60px}.success-message h3{color:#7581f0;color:var(--sphereloop-primary);font-size:1.5rem;font-weight:600;margin:0 0 16px}.success-message p{color:#666;line-height:1.5;margin:12px 0}.action-buttons{flex-direction:column;gap:10px;margin-top:20px}.retry-button{background-color:#7581f0}.secondary-button{background-color:initial;border:1px solid #7581f0;color:#7581f0}.secondary-button:hover{background-color:#7581f01a}@media (max-width:768px){.login-container{align-items:flex-start;padding:40px 12px 12px}.login-card{border-radius:12px;box-shadow:0 2px 12px #7581f014;margin:0;padding:32px 24px}.login-title{font-size:1.75rem;margin-bottom:20px}.login-input{font-size:16px;padding:14px 12px}.login-button{font-size:1rem;min-height:50px;padding:14px 0}.link-button{font-size:.95rem;min-height:48px;padding:12px 8px}.success-icon{font-size:20px;height:50px;width:50px}.success-message h3{font-size:1.25rem}.notification{font-size:.9rem;padding:10px 12px}}@media (max-width:480px){.login-container{padding:20px 8px 8px}.login-card{border-radius:8px;padding:24px 20px}.login-title{font-size:1.5rem}.form-group,.login-title{margin-bottom:16px}.login-input{padding:12px 10px}.login-button{min-height:48px;padding:12px 0}}.register-wrapper{background-color:#fff;background-color:var(--sphereloop-bg);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:16px}.register-container{background:#fff;border-radius:16px;box-shadow:0 4px 16px #7581f01a;box-sizing:border-box;margin:0 auto;max-width:480px;padding:40px;width:100%}.register-header{margin-bottom:30px;text-align:center}.register-title{color:#7581f0;color:var(--sphereloop-primary);font-size:2rem;font-weight:700;margin:0}.register-form{display:flex;flex-direction:column}.form-group label{color:#222;color:var(--sphereloop-text);font-size:1rem}.form-control{border:1.5px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px;transition:border .2s,box-shadow .2s;width:100%}.form-control:focus{border-color:#7581f0;border-color:var(--sphereloop-primary);box-shadow:0 0 0 2px #7581f01f;outline:none}.register-button{align-items:center;background:#7581f0;background:var(--sphereloop-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;justify-content:center;margin-top:10px;min-height:48px;padding:14px 0;transition:background .2s;width:100%}.register-button:hover:not(:disabled){background:#5a67d8}.register-button:disabled{background:#a8b0f0;cursor:not-allowed;opacity:.7}.auth-links{display:flex;justify-content:center;margin-top:20px}.link-button{background:none;border:none;cursor:pointer;min-height:44px;padding:8px}.sign-in-link{color:#7581f0;font-size:1.05rem;font-weight:600;letter-spacing:.01em;text-decoration:underline;-webkit-text-decoration-color:#7581f0;text-decoration-color:#7581f0}.error-message{background:#fff5f5;padding:10px 16px}.error-message,.notification{border-radius:8px;font-size:1rem;line-height:1.4;margin-bottom:20px;text-align:center}.notification{padding:12px 16px}.notification.success{background-color:#f0fff4;border:1px solid #9ae6b4;color:#22543d}.notification.error{background-color:#fff5f5;border:1px solid #feb2b2;color:#742a2a}.loading-spinner{border:2px solid #ffffff40;border-top-color:#fff;height:20px;width:20px}.password-requirements{color:#666;font-size:.85rem;line-height:1.3;margin-bottom:0;margin-top:5px}.recaptcha-wrapper{display:flex;justify-content:center;margin:20px 0}.recaptcha-container{align-items:center;display:flex;justify-content:center;min-height:78px;width:100%}.recaptcha-loading{background-color:#f5f5f5;border-radius:4px;color:#666;font-size:.9rem;padding:10px}.terms-container{display:flex;justify-content:center;margin:20px 0;width:100%}.terms-checkbox-container{display:flex;justify-content:flex-start;margin:0;max-width:380px;width:100%}.terms-checkbox-label{align-items:flex-start;cursor:pointer;display:flex;font-size:.95rem;line-height:1.4;max-width:100%}.terms-checkbox-label input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.custom-checkbox{height:20px;margin-right:10px;margin-top:2px;min-width:20px;position:relative;width:20px}.checkmark{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;height:20px;left:0;position:absolute;top:0;transition:all .2s ease;width:20px}.terms-checkbox-label:hover input~.checkmark{background-color:#eee;border-color:#ccc}.terms-checkbox-label input:checked~.checkmark{background-color:#7581f0;background-color:var(--sphereloop-primary);border-color:#7581f0;border-color:var(--sphereloop-primary)}.checkmark:after{content:"";display:none;position:absolute}.terms-checkbox-label input:checked~.checkmark:after{display:block}.terms-checkbox-label .checkmark:after{border:solid #fff;border-width:0 2px 2px 0;height:10px;left:7px;top:3px;transform:rotate(45deg);width:5px}.terms-checkbox-label input:disabled~.checkmark{cursor:not-allowed;opacity:.6}.terms-text{line-height:1.4}.terms-link{background:none;border:none;color:#7581f0;color:var(--sphereloop-primary);cursor:pointer;font-size:.95rem;font-weight:600;padding:0;text-decoration:underline}.terms-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.terms-modal{background-color:#fff;border-radius:10px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:100%}.terms-modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:15px 20px}.terms-modal-header h3{color:#7581f0;color:var(--sphereloop-primary);font-size:1.25rem;font-weight:600;margin:0}.close-button{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:1.5rem;justify-content:center;min-height:32px;min-width:32px;padding:4px}.terms-modal-content{flex-grow:1;overflow-y:auto;padding:20px}.terms-modal-content h4{color:#444;font-weight:600;margin:15px 0 8px}.terms-modal-content h4:first-child{margin-top:0}.terms-modal-content p{color:#555;font-size:.95rem;line-height:1.5;margin:8px 0 15px;white-space:pre-line}.terms-modal-footer{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.accept-button{background-color:#7581f0;background-color:var(--sphereloop-primary);border:none;border-radius:6px;color:#fff}.accept-button,.decline-button{cursor:pointer;font-weight:600;min-height:40px;padding:10px 16px}.decline-button{background-color:initial;border:1px solid #ddd;border-radius:6px;color:#666}.optional-label{color:#888;font-size:.8rem;font-weight:400;margin-left:4px}@media (max-width:768px){.register-wrapper{justify-content:flex-start;padding:40px 12px 12px}.register-container{border-radius:12px;box-shadow:0 2px 12px #7581f014;padding:32px 24px}.register-title{font-size:1.75rem;margin-bottom:24px}.form-control{font-size:16px;padding:14px 12px}.register-button{font-size:1rem;min-height:50px;padding:14px 0}.link-button{font-size:.95rem;min-height:48px;padding:12px 8px}.terms-checkbox-label{font-size:.9rem}.terms-modal{margin:10px;max-height:85vh}.terms-modal-header{padding:12px 16px}.terms-modal-header h3{font-size:1.1rem}.terms-modal-content{padding:16px}.terms-modal-footer{flex-direction:column;gap:8px;padding:12px 16px}.accept-button,.decline-button{min-height:44px;width:100%}.error-message,.notification{font-size:.9rem;padding:10px 12px}}@media (max-width:480px){.register-wrapper{padding:20px 8px 8px}.register-container{border-radius:8px;padding:24px 20px}.register-title{font-size:1.5rem;margin-bottom:20px}.form-group{margin-bottom:16px}.form-control{padding:12px 10px}.register-button{min-height:48px;padding:12px 0}.terms-checkbox-label{font-size:.85rem}.custom-checkbox{margin-right:8px;min-width:18px}.checkmark,.custom-checkbox{height:18px;width:18px}.terms-checkbox-label .checkmark:after{height:8px;left:6px;top:2px;width:4px}.terms-modal{border-radius:0;height:100vh;margin:0;max-height:100vh}.password-requirements{font-size:.8rem}}.create-trip-container{padding:20px}.create-trip-container,.create-trip-form{margin:0 auto;max-width:800px}.header{margin-bottom:30px}.back-button{border-radius:50%;color:#7581f0;color:var(--sphereloop-primary);transition:background-color .3s}.back-button:hover{background-color:#7581f014}.create-trip-container h1{color:#7581f0;color:var(--sphereloop-primary);flex:1 1;margin:0 auto;text-align:center}.trip-info-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;padding:20px}.form-group{margin-bottom:20px}.form-group label{color:#7581f0;color:var(--sphereloop-primary);margin-bottom:8px}.form-group input,.form-group select{border:1.5px solid #e0e0e0;border-radius:4px;font-size:1rem;padding:10px;width:100%}.form-group input:focus,.form-group select:focus{border-color:var(--sphereloop-primary);box-shadow:0 0 0 2px #7581f01f}.create-trip-container .dark-section{background:#181818;border-radius:8px;color:#fff;margin-top:20px;padding:24px}.create-trip-container .dark-section h2{color:#fff;font-size:22px;font-weight:700;margin-bottom:24px}.create-trip-container .dark-section label{color:#fff;font-weight:600}.create-trip-container .dark-section input,.create-trip-container .dark-section select{background:#222;border:none;color:#fff}.create-trip-container .dark-section input:focus,.create-trip-container .dark-section select:focus{border-color:#2ecc40;box-shadow:0 0 0 2px #2ecc401a}.style-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.style-tag{align-items:center;background:#fff;border:1.5px solid #e0e0e0;border-radius:20px;color:#7581f0;color:var(--sphereloop-primary);cursor:pointer;display:flex;font-size:14px;gap:6px;padding:8px 12px;transition:all .2s ease}.style-tag:hover{background:#7581f014;border-color:#bfc6f7}.style-tag.selected{background:#7581f0;background:var(--sphereloop-primary);border-color:#7581f0;border-color:var(--sphereloop-primary);color:#fff}.style-tag .style-icon{font-size:16px}.style-tag .style-label{font-weight:500}.white-card{background:#fff;border-radius:16px;box-shadow:0 4px 16px #3c3c3c14;box-sizing:border-box;margin:32px auto;max-width:900px;padding:5vw 4vw;width:100%}@media (max-width:600px){.white-card{margin:16px auto;max-width:98vw;padding:6vw 2vw}}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#7581f0;background:var(--sphereloop-primary);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;cursor:pointer;height:20px;width:20px}input[type=range]::-moz-range-thumb{background:#7581f0;background:var(--sphereloop-primary);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;cursor:pointer;height:20px;width:20px}input[type=range]:focus{outline:none}input[type=range]::-webkit-slider-runnable-track{background:#e3e7fd;border-radius:4px;height:8px}input[type=range]::-moz-range-track{background:#e3e7fd;border-radius:4px;height:8px}.image-gallery{background-color:#f0f0f0;border-radius:8px;overflow:hidden;position:relative;width:100%}.image-gallery__container,.image-gallery__slide{height:100%;position:relative;width:100%}.image-gallery__slide{align-items:center;cursor:pointer;display:flex;justify-content:center;left:0;top:0}.image-gallery__img{background-color:#f0f0f0;height:100%;object-fit:contain;transition:transform .3s ease,opacity .2s ease;width:100%}.image-gallery__img:hover{transform:scale(1.02)}.image-gallery__caption{background-color:#0009;bottom:0;color:#fff;font-size:14px;left:0;padding:12px 16px;position:absolute;width:100%}.image-gallery__arrow{align-items:center;background-color:#ffffffb3;border:none;border-radius:50%;box-shadow:0 2px 5px #0003;cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;line-height:1;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s ease;width:40px;z-index:2}.image-gallery__arrow:hover{background-color:#ffffffe6;box-shadow:0 3px 8px #0000004d}.image-gallery__arrow--prev{left:10px}.image-gallery__arrow--next{right:10px}.image-gallery__indicators{bottom:16px;display:flex;gap:8px;justify-content:center;left:0;position:absolute;width:100%;z-index:2}.image-gallery__indicator{background-color:#ffffff80;border:none;border-radius:50%;cursor:pointer;height:10px;padding:0;transition:all .2s ease;width:10px}.image-gallery__indicator--active{background-color:#fff;box-shadow:0 0 4px #0006;transform:scale(1.2)}@media (max-width:768px){.image-gallery__arrow{font-size:18px;height:30px;width:30px}.image-gallery__indicator{height:8px;width:8px}}.slide-fade-enter{opacity:0;transform:translateX(10%)}.slide-fade-enter-active{transition:opacity .3s,transform .3s}.slide-fade-enter-active,.slide-fade-exit{opacity:1;transform:translateX(0)}.slide-fade-exit-active{opacity:0;transform:translateX(-10%);transition:opacity .3s,transform .3s}.image-viewer{align-items:center;display:flex;height:100%;justify-content:center;left:0;opacity:0;pointer-events:none;position:fixed;top:0;transition:opacity .3s ease;width:100%;z-index:9999}.image-viewer--visible{opacity:1;pointer-events:auto}.image-viewer__overlay{background-color:#000000d9;height:100%;left:0;position:absolute;top:0;width:100%}.image-viewer__content{animation:zoom-in .3s ease forwards;max-width:800px;position:relative;width:90%;z-index:1}.image-viewer__close-btn{align-items:center;background-color:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s ease;width:40px;z-index:2}.image-viewer__close-btn:hover{background-color:#000c;transform:scale(1.1)}@keyframes zoom-in{0%{transform:scale(.95)}to{transform:scale(1)}}.trip-image-manager-v2{background-color:#fff;border-radius:12px;display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.tim-header{align-items:center;background:#fff;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;padding:16px 20px}.tim-title{color:#333;font-size:18px;font-weight:600;margin:0}.tim-add-button{align-items:center;background:#007aff;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:10px 16px;transition:all .2s ease}.tim-add-button:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.tim-add-button:disabled{background:#ccc;cursor:not-allowed}.tim-icon{font-size:18px;font-weight:700}.tim-instructions{background:#f8f9fa;border-bottom:1px solid #e5e5e5;padding:14px 20px}.tim-instructions p{color:#666;font-size:14px;line-height:1.5;margin:0}.tim-instructions strong{color:#333;display:block;margin-bottom:4px}.tim-error{background:#ffebee;border-bottom:1px solid #ffcdd2;color:#d32f2f;font-size:14px;padding:12px 20px}.tim-grid{grid-gap:16px;align-content:start;display:grid;flex:1 1;gap:16px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));overflow-y:auto;padding:16px}.tim-empty{align-items:center;color:#999;display:flex;flex-direction:column;grid-column:1/-1;justify-content:center;padding:60px 20px}.tim-empty-icon{font-size:48px;margin-bottom:12px;opacity:.6}.tim-empty p{color:#666;font-size:16px;margin:0 0 4px}.tim-empty-hint{color:#999;font-size:14px}.tim-image-card{background:#fff;border:1px solid #e5e5e5;border-radius:12px;overflow:hidden;transition:all .2s ease}.tim-image-card:hover{border-color:#007aff;box-shadow:0 4px 12px #0000001a}.tim-image-wrapper{aspect-ratio:4/3;background:#f5f5f5;position:relative;width:100%}.tim-image{height:100%;object-fit:cover;width:100%}.tim-badge{background:#000000b3;border-radius:12px;color:#fff;font-size:12px;font-weight:600;left:8px;padding:5px 10px;position:absolute;top:8px}.tim-badge-cover{background:#007afff2}.tim-actions{align-items:center;background:#fff;border-top:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:10px 12px}.tim-reorder{display:flex;gap:6px}.tim-reorder-btn{background:#f5f5f5;border:none;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s ease}.tim-reorder-btn:hover:not(:disabled):not(.disabled){background:#e5e5e5}.tim-reorder-btn.disabled,.tim-reorder-btn:disabled{cursor:not-allowed;opacity:.4}.tim-remove-btn{background:#ffebee;border:none;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s ease}.tim-remove-btn:hover:not(:disabled){background:#ffcdd2}.tim-progress{align-items:center;border-top:1px solid #e5e5e5;display:flex;gap:12px;padding:12px 20px}.tim-progress-bar{background:#e5e5e5;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.tim-progress-fill{background:#007aff;border-radius:3px;height:100%;transition:width .3s ease}.tim-progress-text{color:#007aff;font-size:13px;font-weight:500;min-width:100px}.tim-footer{background:#fff;border-top:1px solid #e5e5e5;display:flex;flex-direction:column;gap:12px;padding:16px 20px}.tim-footer-label{color:#666;font-size:14px;text-align:center}.tim-update-btn{align-items:center;background:#007aff;border:none;border-radius:12px;box-shadow:0 2px 8px #007aff4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:16px 24px;transition:all .2s ease}.tim-update-btn:hover:not(:disabled):not(.disabled){background:#0056b3;box-shadow:0 4px 12px #007aff66;transform:translateY(-1px)}.tim-update-btn.disabled,.tim-update-btn:disabled{background:#e5e5e5;box-shadow:none;color:#999;cursor:not-allowed}.tim-saved{align-items:center;color:#34c759;display:flex;font-weight:600;gap:8px;justify-content:center;padding:12px}.tim-saved-icon{font-size:18px}@media (max-width:768px){.tim-grid{gap:12px;grid-template-columns:repeat(2,1fr);padding:12px}.tim-header{padding:12px 16px}.tim-title{font-size:16px}.tim-add-button{font-size:13px;padding:8px 12px}.tim-instructions{padding:12px 16px}.tim-instructions p{font-size:13px}.tim-footer{padding:12px 16px}.tim-update-btn{font-size:15px;padding:14px 20px}}@media (max-width:480px){.tim-grid{gap:10px;grid-template-columns:repeat(2,1fr);padding:10px}.tim-image-wrapper{aspect-ratio:1/1}.tim-badge{font-size:10px;padding:4px 8px}.tim-actions{padding:8px 10px}.tim-remove-btn,.tim-reorder-btn{font-size:12px;padding:6px 10px}}.modal-overlay{align-items:center;background-color:#00000080;box-sizing:border-box;display:flex;height:100%;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;top:0;width:100%;z-index:1000}.modal{animation:modalFadeIn .3s ease;background-color:#fff;border-radius:10px;box-shadow:0 5px 20px #0003;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;position:relative}.modal--small{max-width:400px;width:90%}.modal--medium{max-width:600px;width:90%}.modal--large{max-width:800px;width:90%}.modal--auto{max-width:90%;width:auto}.modal__header{align-items:center;border-bottom:1px solid #eaeaea;display:flex;justify-content:space-between;padding:16px 20px}.modal__title{color:#333;font-size:18px;font-weight:600;margin:0}.modal__close-button{align-items:center;background:none;border:none;border-radius:4px;color:#888;cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:5px;transition:all .2s}.modal__close-button:hover{background-color:#f0f0f0;color:#333}.modal__content{flex-grow:1;overflow-y:auto;padding:20px}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.modal-overlay{padding:10px}.modal--large,.modal--medium,.modal--small{width:95%}.modal__header{padding:12px 16px}.modal__title{font-size:16px}.modal__content{padding:16px}}.place-image-manager{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;width:100%}.image-manager-title{color:#333;font-size:1.4rem;font-weight:600;margin-bottom:1.5rem}.image-error-message{background-color:#fff0f0;border-left:3px solid #ff5252;border-radius:4px;margin-bottom:1.2rem;padding:.8rem 1rem}.image-error-message p{color:#c40000;font-size:14px;margin:0}.image-upload-zone{background-color:#f9f9f9;border:2px dashed #ccc;border-radius:8px;cursor:pointer;margin-bottom:1.5rem;padding:2rem;text-align:center;transition:all .2s ease}.image-upload-zone:hover{background-color:#f5f6fa;border-color:#7581f0}.image-upload-zone.uploading{opacity:.8;pointer-events:none}.upload-icon{font-size:2.5rem;margin-bottom:.5rem}.upload-progress{background-color:#e0e0e0;border-radius:4px;height:8px;margin:1rem 0;overflow:hidden;position:relative;width:100%}.progress-bar{background-color:#7581f0;border-radius:4px;height:100%;transition:width .3s ease}.image-gallery{margin-top:1.5rem}.image-gallery h4{color:#333;font-size:1rem;margin-bottom:1rem}.image-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.image-item{border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;position:relative;transition:transform .2s ease,box-shadow .2s ease}.image-item:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.image-item img{display:block;height:150px;object-fit:cover;width:100%}.image-item-main{border:3px solid #7581f0}.image-actions{background:#0009;bottom:0;display:flex;flex-direction:column;gap:.5rem;left:0;opacity:0;padding:.5rem;position:absolute;right:0;transition:opacity .2s ease}.image-item:hover .image-actions{opacity:1}.delete-btn,.set-main-btn{border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;padding:.3rem .6rem;transition:background-color .2s ease}.set-main-btn{background-color:#7581f0;color:#fff}.set-main-btn:hover{background-color:#5a64d6}.delete-btn{background-color:#ff5252;color:#fff}.delete-btn:hover{background-color:#e04444}.main-badge{background-color:#7581f0;border-radius:4px;color:#fff;display:inline-block;font-size:12px;font-weight:500;padding:.3rem .6rem;text-align:center}@media (max-width:768px){.image-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.image-item img{height:120px}}.place-detail{margin:0 auto;max-width:800px;padding:20px}.place-detail-error,.place-detail-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.loading-spinner{border:4px solid #f3f3f3}.place-header{padding:20px 0;position:relative}.back-button{background:none;border:none;color:#333;cursor:pointer;font-size:24px;left:0;padding:8px;position:absolute;top:50%;transform:translateY(-50%)}.header-content{align-items:center;display:flex;justify-content:space-between;margin-left:40px}.title-section h1{font-size:28px;margin:0 0 8px}.place-meta{color:#666;display:flex;font-size:14px;gap:16px}.action-buttons{display:flex;gap:12px}.like-button,.share-button{align-items:center;background:#fff;border:1px solid #7581f0;border-radius:20px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.like-button{color:#7581f0}.share-button{background-color:#7581f0;border-color:#7581f0;color:#fff}.like-button:hover,.share-button:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.like-button:hover{background:#f0f2ff}.share-button:hover{background:#6670d1}.place-main-image{align-items:center;aspect-ratio:16/9;border-radius:12px 12px 0 0;box-shadow:0 4px 12px #0000001a;display:flex;justify-content:center;max-height:none;overflow:hidden;position:relative;width:100%}.place-main-image img{background-color:#f0f0f0;object-fit:contain}.place-main-image img,.place-main-image>div{height:100%;width:100%}.place-main-image .image-gallery-slide img{background-color:#f0f0f0;height:100%;max-height:100%;object-fit:contain;width:100%}.place-image-container{border-radius:12px;box-shadow:0 4px 12px #0000001a;margin:20px 0;overflow:hidden}.place-meta-container{background-color:#f9f9f9;border-radius:0 0 12px 12px;border-top:1px solid #eee;padding:16px}.place-meta-content{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between}@media (max-width:768px){.place-meta-content{align-items:flex-start;flex-direction:column;gap:16px}.action-buttons{justify-content:flex-end;width:100%}.map-container{border-radius:12px!important;margin:12px 0!important}.place-tabs{gap:12px;overflow-x:auto;padding-bottom:8px}.tab{flex-shrink:0;font-size:14px;padding:10px 16px;white-space:nowrap}.info-section{margin-bottom:24px}.info-section h2{font-size:18px;margin-bottom:12px}}@media (max-width:480px){.place-detail{padding:12px}.place-header{padding:12px 0}.header-content{margin-left:32px}.title-section h1{font-size:22px}.place-meta{flex-wrap:wrap;gap:8px}.place-meta .place-duration,.place-meta .place-rating,.place-meta .place-type{font-size:12px;padding:3px 8px}.map-container{border-radius:8px!important;margin:8px 0!important}.photos-grid{gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.photo-item--main{grid-column:span 1;grid-row:span 1}}.place-meta .place-duration,.place-meta .place-rating,.place-meta .place-type{align-items:center;background-color:#f0f2ff;border-radius:16px;color:#5561c7;display:inline-flex;font-weight:500;padding:4px 12px}.place-meta .place-rating{background-color:#fff9e6;color:#f0a500}.place-tabs{border-bottom:1px solid #eee;display:flex;gap:20px;margin:20px 0}.tab{background:none;border:none;color:#666;cursor:pointer;font-size:16px;padding:12px 24px;position:relative}.tab.active{color:#7581f0;font-weight:500}.tab.active:after{background:#7581f0;bottom:-1px;content:"";height:2px;left:0;position:absolute;width:100%}.place-content{padding:20px 0}.info-section{margin-bottom:40px}.info-section h2{font-size:20px;margin-bottom:16px}.address{color:#666;margin-bottom:16px}.map-container{border-radius:12px;margin:16px 0;overflow:hidden}.hours-grid{grid-gap:8px;display:grid;gap:8px}.hours-row{border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:8px 0}.day{font-weight:500}.reviews-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.write-review-button{background:#7581f0;border:none;border-radius:20px;color:#fff;cursor:pointer;padding:8px 16px}.review-card{border:1px solid #eee;border-radius:12px;margin-bottom:16px;padding:16px}.review-header{display:flex;justify-content:space-between;margin-bottom:12px}.reviewer-info{display:flex;flex-direction:column}.reviewer-name{font-weight:500}.review-date{color:#666;font-size:14px}.review-rating{color:gold}.photos-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:20px}.photo-item{aspect-ratio:1;border-radius:12px;box-shadow:0 4px 8px #0000001a;cursor:pointer;overflow:hidden;position:relative;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.photo-item:hover{box-shadow:0 8px 16px #00000026;transform:translateY(-5px)}.photo-item img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.photo-item:hover img{transform:scale(1.05)}.photo-item--main{grid-column:span 2;grid-row:span 2}.photo-caption{background:#0009;bottom:0;color:#fff;font-size:14px;left:0;opacity:0;padding:8px 12px;position:absolute;right:0;transition:opacity .3s ease}.photo-item:hover .photo-caption{opacity:1}.saved-trips-container{margin:0 auto;max-width:800px;padding:20px}.saved-trips-container h1{color:#222;color:var(--sphereloop-text);font-size:28px;margin-bottom:30px;text-align:center}.saved-trips-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:20px 0}.no-trips,.no-trips-message{background:#fff;background:var(--sphereloop-bg);border-radius:12px;line-height:1.6;text-align:center}.loading,.no-trips,.no-trips-message{color:#222;color:var(--sphereloop-text);font-size:16px;padding:40px}.error{border-radius:12px;color:#dc3545;font-size:16px;padding:40px}.profile-container{margin:0 auto;max-width:900px;padding:32px 16px}.profile-info-box{align-items:center;background:#f7f8fa;border-radius:12px;box-shadow:0 1px 4px #0000000a;display:flex;gap:24px;margin-bottom:32px;padding:24px 32px}.profile-avatar{align-items:center;background:#7581f0;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:32px;font-weight:700;height:64px;justify-content:center;width:64px}.profile-info{flex:1 1;min-width:0}.profile-name{color:#222;font-size:22px;font-weight:700}.profile-email,.profile-name{margin-bottom:2px;word-break:break-word}.profile-email{color:#666;font-size:15px}.profile-joined{color:#aaa;font-size:14px}.profile-details{background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000a;margin-bottom:32px;padding:24px}.section-title{color:#666;font-size:16px;margin-bottom:8px;margin-top:0}.section-content{color:#333;font-size:15px;line-height:1.5;margin-bottom:16px;margin-top:0}.profile-section:last-child .section-content{margin-bottom:0}.no-info{color:#888;font-size:15px;padding:16px;text-align:center}.travel-stats{display:flex;gap:32px;margin-bottom:32px}.stat-card{background:#f3f4fa;border-radius:10px;flex:1 1;min-width:160px;padding:18px 32px;text-align:center}.stat-label{color:#888;font-size:15px;margin-bottom:4px}.stat-value{color:#7581f0;font-size:28px;font-weight:700}.trips-list{list-style:none;margin:0;padding:0}.trips-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin:0;padding:0}.trip-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:16px;padding:12px 0;transition:background-color .2s}.trip-item:hover{background-color:#f9fafb;border-radius:8px;margin:0 -16px;padding:12px 16px}.trip-item:last-child{border-bottom:none}.trip-title{color:#222;cursor:pointer;flex:1 1;font-weight:600;min-width:0;transition:color .2s;word-break:break-word}.trip-title:hover{color:#7581f0}.trip-meta{align-items:center;display:flex;flex-shrink:0;gap:16px}.trip-days,.trip-likes,.trip-views{color:#888;font-size:14px;white-space:nowrap}.trip-date{color:#bbb;font-size:13px;white-space:nowrap}.empty-state{color:#aaa;font-style:italic;padding:24px 16px}.profile-box{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:32px;padding:2rem;position:relative}.profile-box:last-child{margin-bottom:0}.profile-box h2{color:#333;font-size:1.5rem;margin-top:0}.form-group,.profile-box h2{margin-bottom:1.5rem}.form-group label{color:#666;font-size:.95rem;margin-bottom:.5rem}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#7581f0;outline:none}.profile-buttons{border-top:1px solid #eee;display:flex;gap:16px;justify-content:flex-end;margin-top:32px;padding-top:24px}.save-button{background:#7581f0;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;min-width:140px;padding:.75rem 2rem;transition:all .2s}.save-button:hover{background:#5a67d8;transform:translateY(-1px)}.save-button:disabled{background:#a0aec0;cursor:not-allowed;transform:none}.cancel-button{background:#fff;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:1rem;min-width:140px;padding:.75rem 2rem;transition:all .2s}.cancel-button:hover{background:#f8f9fa;border-color:#ccc;color:#333}.cancel-button:disabled{background:#f8f9fa;color:#a0aec0;cursor:not-allowed}.success-message{background:#f0fff4;border-radius:6px;color:#48bb78}.error,.success-message{margin:1rem 0;padding:1rem}.error{background:#fff5f5;border:1px solid #feb2b2;border-radius:6px;color:#e53e3e}.error,.loading{text-align:center}.loading{color:#718096;padding:2rem}.edit-profile-button{background:#7581f0;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;min-height:40px;padding:8px 16px;transition:all .2s;white-space:nowrap}.edit-profile-button:hover{background:#5a67d8;transform:translateY(-1px)}.profile-section{margin-bottom:1.5rem}.profile-section:last-child{margin-bottom:0}@media (max-width:768px){.profile-container{padding:16px 12px}.profile-info-box{flex-direction:column;gap:16px;padding:20px 16px;text-align:center}.profile-avatar{font-size:28px;height:56px;width:56px}.profile-info{text-align:center}.profile-name{font-size:20px}.profile-email{font-size:14px}.profile-joined{font-size:13px}.edit-profile-button{font-size:15px;max-width:200px;min-height:44px;padding:12px 16px;width:100%}.profile-details{margin-bottom:24px;padding:16px}.section-title{font-size:15px}.no-info,.section-content{font-size:14px}.no-info{padding:20px 12px}.travel-stats{flex-direction:column;gap:16px;margin-bottom:24px}.stat-card{min-width:auto;padding:16px 20px}.stat-label{font-size:14px}.stat-value{font-size:24px}.profile-box{margin-bottom:24px;padding:16px}.profile-box h2{font-size:1.25rem;margin-bottom:1rem}.trip-item{align-items:flex-start;flex-direction:column;gap:8px;padding:16px 0}.trip-item:hover{margin:0 -12px;padding:16px 12px}.trip-title{font-size:16px;line-height:1.4}.trip-meta{flex-wrap:wrap;gap:8px;justify-content:space-between;width:100%}.trip-days,.trip-likes,.trip-views{font-size:13px}.trip-date{font-size:12px;margin-top:4px;text-align:left;width:100%}.empty-state{font-size:14px;padding:32px 12px}.trips-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.profile-buttons{flex-direction:column-reverse;gap:12px}.cancel-button,.save-button{min-height:44px;min-width:auto;padding:.75rem 1rem;width:100%}}@media (max-width:480px){.profile-container{padding:12px 8px}.profile-info-box{margin-bottom:20px;padding:16px 12px}.profile-avatar{font-size:24px;height:48px;width:48px}.profile-name{font-size:18px}.profile-email{font-size:13px}.profile-joined{font-size:12px}.edit-profile-button{font-size:14px;padding:10px 16px}.profile-details{padding:12px}.travel-stats{gap:12px;margin-bottom:20px}.stat-card{padding:12px 16px}.stat-value{font-size:20px}.profile-box{margin-bottom:20px;padding:12px}.profile-box h2{font-size:1.1rem}.trip-item{padding:12px 0}.trip-item:hover{margin:0 -8px;padding:12px 8px}.trip-title{font-size:15px}.trip-meta{gap:6px}.trip-days,.trip-likes,.trip-views{font-size:12px}.trip-date{font-size:11px}.empty-state{font-size:13px;padding:24px 8px}.trips-grid{gap:12px;grid-template-columns:1fr}}.edit-profile-container{margin:0 auto;max-width:900px;padding:30px 20px}.edit-profile-box{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:30px;position:relative}.edit-profile-title{color:#333;font-size:24px;font-weight:600;margin-bottom:25px;margin-top:0}.edit-profile-form{display:flex;flex-direction:column}.edit-profile-field{margin-bottom:20px}.edit-profile-field label{color:#555;display:block;font-size:16px;font-weight:500;margin-bottom:8px}.edit-profile-field input,.edit-profile-field textarea{border:1px solid #ddd;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:16px;padding:12px 15px;transition:border-color .2s;width:100%}.edit-profile-field input:focus,.edit-profile-field textarea:focus{border-color:#7581f0;box-shadow:0 0 0 1px #7581f033;outline:none}.edit-profile-field textarea{min-height:100px;resize:vertical}.edit-profile-actions{border-top:1px solid #eee;display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:25px}.save-btn{background-color:#7581f0;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 25px;transition:all .2s}.save-btn:hover{background-color:#6271e0;transform:translateY(-1px)}.save-btn:disabled{background-color:#b0b7e0;cursor:not-allowed;transform:none}.cancel-btn{background-color:#fff;border:1px solid #ddd;border-radius:8px;color:#666;cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 25px;transition:all .2s}.cancel-btn:hover{background-color:#f5f5f5;border-color:#ccc}.cancel-btn:disabled{cursor:not-allowed;opacity:.7}.error-message,.loading-message{border-radius:8px;padding:20px;text-align:center}.loading-message{color:#666}.error-message{background-color:#fff5f5;border:1px solid #feb2b2;color:#e53e3e}.success-message{background-color:#f0fff4;border:1px solid #c6f6d5;border-radius:8px;color:#38a169;line-height:1.5;margin:10px 0;padding:20px;text-align:center}@media (max-width:768px){.edit-profile-container{padding:16px 12px}.edit-profile-box{padding:20px 16px}.edit-profile-title{font-size:20px;margin-bottom:20px}.edit-profile-field{margin-bottom:18px}.edit-profile-field label{font-size:15px;margin-bottom:6px}.edit-profile-field input,.edit-profile-field textarea{border-radius:10px;font-size:16px;min-height:44px;padding:14px 12px}.edit-profile-field textarea{min-height:120px}.edit-profile-actions{flex-direction:column-reverse;gap:12px;margin-top:24px;padding-top:20px}.cancel-btn,.save-btn{font-size:16px;min-height:48px;min-width:auto;padding:14px 16px;width:100%}.error-message,.loading-message,.success-message{font-size:15px;padding:16px 12px}}@media (max-width:480px){.edit-profile-container{padding:12px 8px}.edit-profile-box{border-radius:12px;padding:16px 12px}.edit-profile-title{font-size:18px;margin-bottom:16px}.edit-profile-field{margin-bottom:16px}.edit-profile-field label{font-size:14px}.edit-profile-field input,.edit-profile-field textarea{border-radius:8px;font-size:16px;padding:12px 10px}.edit-profile-field textarea{min-height:100px}.edit-profile-actions{gap:10px;margin-top:20px;padding-top:16px}.cancel-btn,.save-btn{font-size:15px;min-height:44px;padding:12px 14px}.error-message,.loading-message,.success-message{font-size:14px;padding:14px 10px}}.admin-dashboard{background:#f7f8fa;display:flex;font-family:Montserrat,Arial,sans-serif;min-height:100vh}.admin-sidebar{background:#fff;border-right:1px solid #e5e7eb;box-shadow:2px 0 12px #0000000a;height:100vh;left:0;overflow-y:auto;padding:24px 0;position:fixed;top:0;width:260px;z-index:100}.sidebar-header{border-bottom:1px solid #e5e7eb;margin-bottom:16px;padding:0 24px 24px}.sidebar-header h1{align-items:center;color:#222;display:flex;font-size:20px;font-weight:700;gap:10px;margin:0 0 4px}.sidebar-header h1:before{content:"⚙️";font-size:24px}.sidebar-header p{color:#666;font-size:13px;margin:0}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:0 12px}.nav-button{align-items:center;background:#0000;border:none;border-radius:10px;color:#4b5563;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:14px 16px;text-align:left;transition:all .2s ease;width:100%}.nav-button:hover{background:#f3f4f6;color:#7581f0}.nav-button.active{background:linear-gradient(135deg,#7581f0,#6366f1);box-shadow:0 4px 12px #7581f04d;color:#fff}.nav-button .nav-icon{font-size:18px;text-align:center;width:24px}.nav-button .nav-label{flex:1 1}.admin-main{flex:1 1;margin-left:260px;max-width:1200px;padding:32px}.page-header{margin-bottom:24px}.page-header h2{color:#111827;font-size:28px;font-weight:700;margin:0 0 8px}.page-header p{color:#6b7280;font-size:15px;margin:0}.alert{align-items:center;border-radius:12px;display:flex;gap:12px;margin-bottom:24px;padding:16px 20px;position:relative}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.alert-icon{font-size:18px}.alert-close{background:none;border:none;color:inherit;cursor:pointer;font-size:20px;opacity:.7;position:absolute;right:16px}.alert-close:hover{opacity:1}.loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e3e7fd;border-radius:50%;border-top-color:#7581f0;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 1px 3px #0000000d,0 1px 2px #00000008;margin-bottom:24px;overflow:hidden}.card-header{align-items:center;background:#fafbfc;border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:20px 24px}.card-header h2{color:#111827;font-size:18px;font-weight:700;margin:0}.card-header p{color:#6b7280;font-size:13px;margin:4px 0 0}.search-container{min-width:280px;position:relative}.search-input{background:#fff;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;padding:12px 16px 12px 44px;transition:all .2s ease;width:100%}.search-input:focus{border-color:#7581f0;box-shadow:0 0 0 3px #7581f01a;outline:none}.search-icon{color:#9ca3af;font-size:16px;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.city-form{padding:24px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.form-help{color:#6b7280;font-size:12px;font-style:italic;margin:4px 0 8px}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 14px;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#7581f0;box-shadow:0 0 0 3px #7581f01a;outline:none}.form-group small{color:#6b7280;font-size:12px}.coordinate-inputs{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;text-decoration:none;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:linear-gradient(135deg,#7581f0,#6366f1);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#6366f1,#5558e8);box-shadow:0 4px 12px #7581f04d;transform:translateY(-1px)}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover:not(:disabled){background:#d97706}.btn-sm{font-size:13px;padding:8px 14px}.btn-xs{font-size:12px;padding:6px 10px}.btn-icon{font-size:16px}.cities-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));padding:24px}.city-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s ease}.city-card:hover{border-color:#7581f0;box-shadow:0 4px 12px #7581f01f;transform:translateY(-2px)}.city-info h3{color:#111827;font-size:18px;font-weight:700;margin:0 0 8px}.city-details{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.city-value{background:#f3f4f6;border-radius:4px;color:#374151;font-family:Monaco,Menlo,monospace;font-size:12px;padding:2px 6px}.city-country{color:#6b7280;font-size:14px}.city-coordinates{color:#6b7280;font-size:12px;margin:8px 0 0}.city-actions{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-top:16px}.status-badge{border-radius:6px;font-size:12px;font-weight:600;padding:4px 10px;text-transform:uppercase}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.inactive{background:#fef2f2;color:#dc2626}.connections-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.connections-panel,.trips-panel{margin-bottom:0}.trips-list{max-height:600px;overflow-y:auto;padding:16px}.trip-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;margin-bottom:12px;padding:16px;position:relative;transition:all .2s ease}.trip-item:hover{background:#fafbfc;border-color:#7581f0}.trip-item.selected{background:#eef2ff;border-color:#7581f0;box-shadow:0 2px 8px #7581f026}.trip-info h4{color:#111827;font-size:16px;font-weight:600;margin:0 0 4px}.trip-info p{color:#6b7280;font-size:14px;margin:0 0 8px}.trip-meta{color:#9ca3af;font-size:12px}.selected-indicator{color:#7581f0;font-size:18px;font-weight:700;position:absolute;right:16px;top:16px}.add-city-form{border-bottom:1px solid #e5e7eb;padding:24px}.add-city-controls{align-items:end;display:flex;gap:12px}.city-select{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:14px;padding:12px 16px}.city-select:focus{border-color:#7581f0;outline:none}.city-assignment{display:flex;flex-direction:column;gap:12px}.city-assignment .city-select{width:100%}.city-info{color:#6b7280;font-size:13px;margin:0}.city-info strong{color:#111827;font-weight:600}.connected-cities{padding:24px}.connected-city{align-items:center;background:#fafbfc;border:1px solid #e5e7eb;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:12px;padding:16px}.connected-city .city-info{align-items:center;display:flex;gap:16px}.city-order{align-items:center;background:linear-gradient(135deg,#7581f0,#6366f1);border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;width:32px}.connected-city h4{color:#111827;font-size:16px;font-weight:600;margin:0}.connected-city p{color:#6b7280;font-size:14px;margin:0}.primary-badge{background:#10b981;border-radius:6px;color:#fff;font-size:12px;font-weight:600;margin-left:12px;padding:4px 8px}.connected-city .city-actions{display:flex;gap:8px;margin:0}.empty-state{color:#6b7280;padding:48px 24px;text-align:center}.empty-state h3{color:#374151;font-size:18px;font-weight:600;margin:0 0 8px}.empty-state p{font-size:14px;margin:0 0 8px}.tag-management-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;height:calc(100vh - 200px);min-height:500px}.places-panel{max-height:100%;overflow-y:auto}.filter-controls{border-bottom:1px solid #e5e7eb;display:flex;gap:12px;padding:16px}.type-filter{background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;min-width:150px;padding:10px 14px}.places-list{max-height:calc(100% - 80px);overflow-y:auto;padding:16px}.place-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;margin-bottom:12px;padding:16px;position:relative;transition:all .2s ease}.place-item:hover{border-color:#7581f0}.place-item.selected{background:#eef2ff;border-color:#7581f0}.place-info h4{color:#111827;font-size:15px;font-weight:600;margin:0 0 4px}.place-type{background:#f3f4f6;border-radius:4px;color:#6b7280;display:inline-block;font-size:11px;font-weight:500;margin-bottom:6px;padding:2px 8px}.place-address{color:#6b7280;font-size:13px;margin:0 0 8px}.place-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag-chip{align-items:center;background:#eef2ff;border-radius:16px;color:#7581f0;display:flex;font-size:12px;font-weight:500;gap:6px;padding:4px 10px}.tag-chip.large{font-size:14px;padding:6px 14px}.tag-remove{cursor:pointer;font-size:14px;opacity:.7}.tag-remove:hover{opacity:1}.tag-editor-panel{overflow-y:auto}.current-tags-section,.place-details-section,.suggested-tags-section,.tag-editor-section{border-bottom:1px solid #e5e7eb;padding:20px 24px}.current-tags-section h3,.place-details-section h3,.suggested-tags-section h3,.tag-editor-section h3{color:#374151;font-size:15px;font-weight:600;margin:0 0 12px}.tag-input{border:1px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;min-height:80px;padding:12px;resize:vertical;width:100%}.tag-input:focus{border-color:#7581f0;outline:none}.form-actions{display:flex;gap:12px;margin-top:12px}.suggested-tags{display:flex;flex-wrap:wrap;gap:8px}.tag-suggestion{background:#f3f4f6;border:none;border-radius:16px;color:#6b7280;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s ease}.tag-suggestion:hover{background:#eef2ff;color:#7581f0}.detail-row{display:flex;font-size:14px;gap:12px;margin-bottom:8px}.detail-row strong{color:#374151;min-width:80px}.tag-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-top:20px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));padding:24px}.stat-item{align-items:center;background:linear-gradient(135deg,#f8f9ff,#f3f4f6);border:1px solid #e5e7eb;border-radius:12px;display:flex;flex-direction:column;padding:20px 16px;text-align:center}.stat-number{color:#7581f0;font-size:32px;font-weight:700;margin-bottom:4px}.stat-label{color:#6b7280;font-size:13px;font-weight:500}.filters-section{align-items:center;background:#fafbfc;border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:16px;padding:20px 24px}.search-button{background:linear-gradient(135deg,#7581f0,#6366f1);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;padding:12px 16px;transition:all .2s ease}.search-button:hover{background:linear-gradient(135deg,#6366f1,#5558e8)}.filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:10px;font-size:14px;min-width:140px;padding:12px 16px}.filter-select:focus{border-color:#7581f0;outline:none}.users-list{padding:24px}.user-item{align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;gap:16px;margin-bottom:16px;padding:20px;transition:all .2s ease}.user-item:hover{border-color:#7581f0;box-shadow:0 4px 12px #7581f014}.user-avatar{align-items:center;background:linear-gradient(135deg,#7581f0,#6366f1);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:48px;justify-content:center;width:48px}.user-info{flex:1 1;min-width:0}.user-primary{margin-bottom:12px}.user-primary h4{color:#111827;font-size:17px;font-weight:600;margin:0 0 4px}.user-email{color:#6b7280;font-size:14px}.user-details{display:flex;flex-direction:column;gap:8px}.user-detail{align-items:center;color:#6b7280;display:flex;font-size:14px;gap:8px}.user-detail strong{color:#374151;min-width:60px}.role-select{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;font-size:12px;padding:4px 8px}.role-select:focus{border-color:#7581f0;outline:none}.user-actions{display:flex;flex-shrink:0;gap:8px}.pagination{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:16px;justify-content:center;padding:24px}.pagination-info{color:#6b7280;font-size:14px}.city-image-section{background:#fafbfc;border:1px solid #e5e7eb;border-radius:10px;margin:12px 0;padding:12px}.city-image-preview{display:inline-block;position:relative}.city-preview-img{border:2px solid #e5e7eb;border-radius:8px;height:80px;object-fit:cover;width:80px}.remove-image-btn{border-radius:50%;font-size:12px;height:24px;min-height:24px;padding:0;position:absolute;right:-8px;top:-8px;width:24px}.city-image-upload,.remove-image-btn{align-items:center;display:flex;justify-content:center}.city-image-upload{min-height:80px}.image-upload-input{display:none}.image-upload-label{align-items:center;background:#fff;border:2px dashed #d1d5db;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:6px;min-width:100px;padding:16px 24px;text-align:center;transition:all .2s}.image-upload-label:hover{background:#f8f9ff;border-color:#7581f0}.upload-icon{color:#6b7280;font-size:20px}.image-upload-label span:last-child{color:#6b7280;font-size:12px;font-weight:500}.mobile-tab-navigation{display:none}@media (max-width:1200px){.admin-main{padding:24px}.tag-management-layout{grid-template-columns:1fr;height:auto}.places-panel{max-height:400px}.connections-layout{grid-template-columns:1fr}}@media (max-width:768px){.admin-dashboard{flex-direction:column}.admin-sidebar{display:none}.mobile-tab-navigation{-webkit-overflow-scrolling:touch;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:6px;overflow-x:auto;padding:12px;position:-webkit-sticky;position:sticky;scrollbar-width:none;top:0;z-index:100}.mobile-tab-navigation::-webkit-scrollbar{display:none}.mobile-tab-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:20px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:13px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease;white-space:nowrap}.mobile-tab-btn:hover{border-color:#7581f0;color:#7581f0}.mobile-tab-btn.active{background:linear-gradient(135deg,#7581f0,#6366f1);border-color:#0000;color:#fff}.mobile-tab-btn .nav-icon{font-size:14px}.admin-main{margin-left:0;max-width:100%;padding:16px}.page-header{margin-bottom:16px}.page-header h2{font-size:22px}.page-header p{font-size:14px}.card-header{align-items:stretch;flex-direction:column;gap:12px;padding:16px}.search-container{min-width:auto;width:100%}.form-grid{gap:16px;grid-template-columns:1fr}.city-form{padding:16px}.cities-grid{gap:12px;grid-template-columns:1fr;padding:16px}.stats-grid{gap:12px;grid-template-columns:repeat(2,1fr);padding:16px}.stat-number{font-size:24px}.filters-section{align-items:stretch;gap:12px;padding:16px}.filter-controls,.filters-section{flex-direction:column}.filter-select{width:100%}.user-item{flex-direction:column;gap:12px;padding:16px}.user-actions{justify-content:center;width:100%}.tag-management-layout{gap:16px}.tag-stats{gap:12px;grid-template-columns:1fr}.trips-list{max-height:350px;padding:12px}.pagination{flex-direction:column;gap:12px;padding:16px}}@media (max-width:480px){.admin-main{padding:12px}.page-header h2{font-size:20px}.mobile-tab-btn{font-size:12px;padding:8px 12px}.card{margin-bottom:16px}.card-header{padding:12px}.card-header h2{font-size:16px}.stats-grid{gap:8px;grid-template-columns:1fr}.stat-item{padding:16px}.stat-number{font-size:20px}.btn{font-size:13px;padding:10px 14px}.btn-sm{font-size:12px;padding:6px 10px}.city-card{padding:16px}.trips-list{max-height:280px}}@media (max-width:768px){.btn,.city-select,.filter-select,.mobile-tab-btn,.search-input,.type-filter{min-height:44px}.nav-button{min-height:48px}.tag-chip{min-height:32px;padding:8px 12px}}:root{--sphereloop-primary:#7581f0;--sphereloop-bg:#fff;--sphereloop-text:#222}html{scroll-behavior:smooth}.app,.app-container,body{background-color:#fff;background-color:var(--sphereloop-bg);color:#222;color:var(--sphereloop-text);font-family:Montserrat,Arial,sans-serif}.cta-button{background-color:#7581f0;background-color:var(--sphereloop-primary);border:none;border-radius:8px;box-shadow:0 2px 8px 0 #7581f014;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 28px;transition:background .2s,box-shadow .2s}.cta-button:hover{background-color:#5a67d8}.badge{background:#fff;border-radius:16px;color:#7581f0;color:var(--sphereloop-primary);display:inline-block;font-size:.95em;font-weight:600;padding:4px 12px}.badge,.badge-fill{border:2px solid #7581f0;border:2px solid var(--sphereloop-primary)}.badge-fill{background:#7581f0;background:var(--sphereloop-primary);color:#fff}.app{min-height:100vh}.app,.header{background-color:#fff;background-color:var(--sphereloop-bg)}.header{box-shadow:0 2px 4px #0000001a;justify-content:space-between;margin:0 auto;max-width:800px;padding:1rem 2rem;position:relative;width:100%;z-index:1000}.header,.header-left{align-items:center;display:flex}.header-left{gap:2rem}.logo{color:#222;color:var(--sphereloop-text);font-size:1.5rem;font-weight:700;text-decoration:none}.main-nav{display:flex;gap:1rem}.nav-link{border-radius:4px;color:#7581f0;padding:.5rem 1rem;text-decoration:none;transition:all .2s}.nav-link:hover{background-color:#f0f0f0;color:#222;color:var(--sphereloop-text)}.header-right{align-items:center;display:flex;gap:1rem;justify-content:flex-end;min-width:200px}.app-container{display:flex;flex-direction:column;margin:0 auto;max-width:800px;min-height:100vh;padding-bottom:70px;width:100%}.app-container,.main-content{background:#fff;background:var(--sphereloop-bg)}.main-content{color:#222;color:var(--sphereloop-text);flex:1 1;padding:56px 5px 20px}.place-badge{background:#7581f01f;border:none;border-radius:16px;color:#7581f0;display:inline-block;font-family:Montserrat,Arial,sans-serif;font-size:13px;font-weight:500;letter-spacing:.01em;margin-bottom:6px;margin-right:8px;padding:6px 16px}
/*# sourceMappingURL=main.b216d0ca.css.map*/