header .header-bar{align-items:center!important;background:var(--sl-bg)!important;border-bottom:1px solid var(--sl-border)!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:var(--sl-text-dark);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:var(--sl-text-primary);cursor:pointer;font-size:1.3rem;padding:6px;transition:background .2s}.header-icon-btn:hover{background:var(--sl-bg-tertiary)}.header-icon{color:var(--sl-text-primary);font-size:1.3rem}.header-btn{align-items:center;background:var(--sl-primary);border:none;border-radius:8px;box-shadow:0 2px 8px 0 var(--sl-shadow);box-sizing:border-box;color:var(--sl-text-white);cursor:pointer;display:flex;flex-shrink:0;font-family:Nunito,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:var(--sl-primary-dark)}.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:var(--sl-bg);bottom:0;box-shadow:0 -4px 12px var(--sl-shadow-light);display:flex;height:56px;justify-content:center;left:0;position:fixed;transform:translateZ(0);width:100%;z-index:10000}.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:var(--sl-text-dark);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:var(--sl-text-light);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:var(--sl-primary-faded);color:var(--sl-primary)}.navbar-icon{font-size:22px}.navbar-label{color:inherit;font-size:12px}.featured-city-filter{margin:0 -16px 12px;padding:8px 0;width:calc(100% + 32px)}.city-filter-container{-ms-overflow-style:none;-webkit-overflow-scrolling:touch;display:flex;flex-wrap:nowrap;gap:12px;overflow-x:auto;padding:0 16px;scroll-behavior:smooth;scrollbar-width:none;touch-action:pan-x;width:100%}.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:var(--sl-bg-secondary);display:flex;justify-content:center}.all-cities-icon{font-size:90px;position:relative;z-index:2}.city-name{color:var(--sl-text-primary);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 var(--sl-shadow-medium);transform:scale(1.1)}.featured-city-filter .city-item.selected .city-name{color:var(--sl-primary);font-weight:600}.loading-circle{animation:shimmer 1.5s ease-in-out infinite;background:linear-gradient(45deg,var(--sl-border) 0,var(--sl-border-light) 50%,var(--sl-border) 100%);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;width:100%}.section-title{color:var(--sl-text-dark);flex-shrink:0;font-family:Nunito,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:var(--sl-bg-secondary);border:1px solid var(--sl-border);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:var(--sl-bg-tertiary);border-color:var(--sl-primary)}.sort-dropdown-text{color:var(--sl-primary);font-family:Nunito,Arial,sans-serif;font-size:14px;font-weight:600}.sort-dropdown-icon{color:var(--sl-primary);flex-shrink:0;transition:transform .2s ease}.sort-dropdown-icon.open{transform:rotate(180deg)}.sort-dropdown-menu{animation:dropdownFadeIn .15s ease;background:var(--sl-bg);border:1px solid var(--sl-border);border-radius:12px;box-shadow:0 4px 20px var(--sl-shadow-medium);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:var(--sl-text-primary);cursor:pointer;display:flex;font-family:Nunito,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:var(--sl-bg-tertiary)}.sort-dropdown-item.selected{background:var(--sl-primary-faded);color:var(--sl-primary)}.sort-dropdown-item svg{color:var(--sl-primary)}@media (max-width:768px){.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:var(--sl-bg);border:1px solid var(--sl-border-light);border-radius:12px;box-shadow:0 4px 6px var(--sl-shadow);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 var(--sl-shadow-medium);transform:translateY(-5px)}.trip-image{background:var(--sl-bg-tertiary);height:240px;overflow:hidden;position:relative;width:100%}.trip-card--portrait{grid-row:span 2}.trip-card--portrait .trip-image{height:300px}.trip-card--landscape .trip-image{height:200px}.trip-card--square .trip-image{height:240px}.trip-card-img,.trip-image img{display:block;height:100%;object-fit:cover;width:100%}.save-button{background:#fffffff2;border:none;border-radius:20px;box-shadow:0 2px 6px var(--sl-shadow-light);color:var(--sl-text-primary);cursor:pointer;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:var(--sl-bg-tertiary);transform:scale(1.05)}.save-button.saved{background:var(--sl-primary);color:var(--sl-text-white)}.trip-info{background:var(--sl-bg);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:var(--sl-text-dark);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:var(--sl-text-secondary);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:var(--sl-tag-bg);border-radius:8px;color:var(--sl-text-primary);display:inline-block;font-size:12px;font-weight:500;margin-bottom:2px;margin-right:4px;padding:2px 10px}.trip-days{color:var(--sl-text-secondary);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:var(--sl-text-tertiary);transition:all .2s ease}.stat-item svg{flex-shrink:0}.stat-item:hover{background:var(--sl-primary-faded);color:var(--sl-primary)}.stat-item:hover svg{color:var(--sl-primary);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:var(--sl-text-primary);font-size:13px;gap:4px;margin-bottom:2px}.trip-card.loading,.trip-place{align-items:center;display:flex}.trip-card.loading{background:var(--sl-bg-tertiary);color:var(--sl-text-secondary);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:var(--sl-primary)}@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}}.home-container{background-color:var(--sl-bg-secondary);min-height:100vh;padding-bottom:80px}.home-content{margin:0 auto;max-width:100%}.home-header-gradient{background:var(--sl-gradient-header);border-bottom-left-radius:24px;border-bottom-right-radius:24px;box-shadow:0 4px 12px var(--sl-shadow);color:var(--sl-text-primary);margin-bottom:20px;padding:20px 20px 30px}.header-top-row{align-items:center;display:flex;margin-bottom:20px}.user-greeting-section{align-items:center;display:flex;gap:12px}.user-avatar-small{align-items:center;background:var(--sl-primary);border:2px solid var(--sl-avatar-border);border-radius:50%;color:var(--sl-text-white);display:flex;font-size:18px;font-weight:700;height:44px;justify-content:center;overflow:hidden;width:44px}.user-avatar-small img{height:100%;object-fit:cover;width:100%}.greeting-text{display:flex;flex-direction:column}.greeting-time{color:var(--sl-text-secondary);font-size:13px;font-weight:500}.greeting-name{color:var(--sl-text-dark);font-size:18px;font-weight:700}.search-bar-container{align-items:center;background:var(--sl-bg);border:1px solid var(--sl-border-light);border-radius:50px;box-shadow:0 8px 20px var(--sl-shadow);display:flex;font-size:16px;font-weight:500;gap:12px;justify-content:center;margin-bottom:2px;margin-top:2px;padding:2px 20px;vertical-align:middle}.search-bar-container .search-icon{color:var(--sl-primary);font-size:20px;opacity:1;position:static;transform:none}.search-bar-container .search-input{-webkit-appearance:none;appearance:none;background:#0000;border:0!important;border-radius:0;box-shadow:none!important;color:var(--sl-text-primary);font-family:Nunito,sans-serif;font-size:16px;font-weight:500;height:40px;margin:2px 0;outline:none;padding:2px 4px 2px 12px;vertical-align:middle;width:100%}.search-bar-container .search-input::placeholder{color:var(--sl-text-light)}.home-filters-section{padding:0 16px}.welcome-banner{background:var(--sl-bg);border-radius:16px;box-shadow:0 2px 8px var(--sl-shadow-light);display:none;margin:16px;padding:24px;text-align:center}.trips-grid{padding:16px}.error,.loading,.no-trips-message{color:var(--sl-text-secondary);padding:40px;text-align:center}@media (max-width:480px){.trips-grid{gap:16px;grid-template-columns:1fr}.search-bar-container{align-items:center;background:var(--sl-bg);border:1px solid var(--sl-border-light);border-radius:50px;box-shadow:0 4px 12px var(--sl-shadow-light);box-sizing:border-box;display:flex;font-size:16px;font-weight:500;gap:12px;justify-content:center;margin-bottom:2px;margin-top:2px;padding:2px 20px;vertical-align:middle;width:100%}.search-bar-container .search-input{-webkit-appearance:none;appearance:none;background:#0000;border:0!important;border-radius:0;box-shadow:none!important;color:var(--sl-text-primary);flex:1 1;font-size:16px;font-weight:500;height:40px;margin:2px 0;outline:none;padding:2px 4px 2px 12px;vertical-align:middle;width:auto}.search-bar-container .search-input::placeholder{color:var(--sl-text-light)}.search-bar-container .search-icon{color:var(--sl-primary);font-size:16px}.home-header-gradient{border-bottom-left-radius:20px;border-bottom-right-radius:20px;padding:20px 16px 24px}.user-avatar-small{font-size:14px;height:36px;width:36px}.greeting-name{font-size:16px}}.discover-places{background-color:var(--sl-bg-secondary);display:flex;flex-direction:column;height:calc(100vh - 60px)}.discover-header{align-items:center;background-color:var(--sl-bg);border-bottom:1px solid var(--sl-border);display:flex;justify-content:space-between;padding:20px}.discover-header h1{color:var(--sl-text-primary);font-size:28px;font-weight:700;margin:0}.view-toggle{align-items:center;background-color:var(--sl-bg);border:2px solid var(--sl-primary);border-radius:8px;color:var(--sl-primary);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .2s}.view-toggle:hover{background-color:var(--sl-primary);color:var(--sl-text-white)}.view-toggle svg{height:20px;width:20px}.city-filters{background-color:var(--sl-bg);border-bottom:1px solid var(--sl-border);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:var(--sl-bg-tertiary);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:var(--sl-bg);border-color:var(--sl-primary)}.city-icon-emoji{font-size:32px}.city-icon-image{height:100%;object-fit:cover;width:100%}.city-icon-placeholder{color:var(--sl-text-secondary);font-size:24px;font-weight:700}.city-label{color:var(--sl-text-secondary);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:var(--sl-primary)}.category-filters{background-color:var(--sl-bg);border-bottom:1px solid var(--sl-border-light);padding:12px 0}.category-scroll{display:flex;gap:10px;overflow-x:auto;padding:0 16px;scrollbar-width:none}.category-scroll::-webkit-scrollbar{display:none}.category-chip{background:#2a2b35d9;border:none;border-radius:24px;box-shadow:0 2px 4px #00000026;color:var(--sl-text-white);cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease;white-space:nowrap}.category-chip:hover{background:#2a2b35f2;box-shadow:0 3px 6px #0003;transform:translateY(-1px)}.category-chip.active{background:var(--sl-gradient-accent);box-shadow:0 2px 8px #e0aaff66;color:var(--sl-text-white);font-weight:600}.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:var(--sl-text-secondary);font-size:16px}.empty-state{flex-direction:column}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{font-size:20px;font-weight:700}.empty-state p{color:var(--sl-text-secondary);font-size:16px;line-height:1.5;margin:0}.places-list-view{height:100%;overflow-y:auto}.limit-notice{background-color:var(--sl-warning-light);border-left:4px solid var(--sl-warning);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:var(--sl-bg);border-radius:16px;box-shadow:0 2px 8px var(--sl-shadow);cursor:pointer;overflow:hidden;transition:transform .2s,box-shadow .2s}.place-card:hover{box-shadow:0 4px 16px var(--sl-shadow-medium);transform:translateY(-4px)}.place-image{background-color:var(--sl-bg-tertiary);background-position:50%;background-size:cover;height:200px;width:100%}.place-placeholder{background:var(--sl-gradient-accent);box-sizing:border-box;flex-direction:column;height:200px;overflow:hidden;padding:20px;width:100%}.place-icon,.place-placeholder{align-items:center;display:flex;justify-content:center}.place-icon{color:var(--sl-text-white);flex-shrink:0;font-size:48px;margin-bottom:8px}.place-icon svg{height:48px;width:48px}.place-icon .material-icons{color:var(--sl-text-white);font-size:48px}.place-placeholder-text{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--sl-text-white);display:-webkit-box;font-size:14px;font-weight:600;max-width:100%;overflow:hidden;padding:0 8px;text-align:center;text-overflow:ellipsis}.place-info{padding:16px}.place-name{color:var(--sl-text-primary);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:var(--sl-text-tertiary);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{align-items:center;border-radius:16px;box-shadow:0 2px 6px #e0aaff4d;display:inline-flex;font-size:12px;gap:4px;padding:6px 14px}.place-type svg{height:14px;width:14px}@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:var(--sl-bg);display:flex;justify-content:center;min-height:100vh;padding:16px}.login-card{background:var(--sl-bg);border-radius:16px;box-shadow:0 4px 16px var(--sl-shadow);box-sizing:border-box;margin:32px auto;max-width:480px;padding:48px 40px;width:100%}.login-title{color:var(--sl-primary);font-size:2rem;font-weight:700;margin-bottom:24px;text-align:center}.login-form{width:100%}.login-form label{color:var(--sl-primary);display:block;font-size:1rem;font-weight:600;margin-bottom:8px}.login-input{border:1.5px solid var(--sl-border);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:var(--sl-primary);box-shadow:0 0 0 2px var(--sl-primary-faded);outline:none}.login-button{align-items:center;background:var(--sl-primary);border:none;border-radius:8px;color:var(--sl-text-white);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:var(--sl-primary-dark)}.login-button:disabled{cursor:not-allowed;opacity:.7}.link-button{color:var(--sl-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:var(--sl-success);border-radius:50%;color:var(--sl-text-white);display:flex;font-size:24px;font-weight:700;height:60px;justify-content:center;margin:0 auto 20px;width:60px}.success-message h3{color:var(--sl-primary);font-size:1.5rem;font-weight:600;margin:0 0 16px}.success-message p{color:var(--sl-text-secondary);line-height:1.5;margin:12px 0}.action-buttons{display:flex;flex-direction:column;gap:10px;margin-top:20px}.retry-button{background-color:var(--sl-primary)}.secondary-button{background-color:initial;border:1px solid var(--sl-primary);color:var(--sl-primary)}.secondary-button:hover{background-color:var(--sl-primary-faded)}@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:var(--sl-bg);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:16px}.register-container{background:var(--sl-bg);border-radius:16px;box-shadow:0 4px 16px var(--sl-shadow);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:var(--sl-primary);font-size:2rem;font-weight:700;margin:0}.register-form{display:flex;flex-direction:column}.form-group label{color:var(--sl-text-dark);font-size:1rem}.form-control{border:1.5px solid var(--sl-border);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:var(--sl-primary);box-shadow:0 0 0 2px var(--sl-primary-faded);outline:none}.register-button{align-items:center;background:var(--sl-primary);border:none;border-radius:8px;color:var(--sl-text-white);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:var(--sl-primary-dark)}.register-button:disabled{background:var(--sl-primary-light);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:var(--sl-primary);font-size:1.05rem;font-weight:600;letter-spacing:.01em;text-decoration:underline;-webkit-text-decoration-color:var(--sl-primary);text-decoration-color:var(--sl-primary)}.error-message{background:var(--sl-error-light);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:var(--sl-success-light);border:1px solid #9ae6b4;color:#22543d}.notification.error{background-color:var(--sl-error-light);border:1px solid #feb2b2;color:#742a2a}.loading-spinner{border:2px solid #ffffff40;border-top-color:#fff;height:20px;width:20px}.password-requirements{color:var(--sl-text-secondary);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:var(--sl-bg-tertiary);border-radius:4px;color:var(--sl-text-secondary);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:var(--sl-bg-tertiary);border:1px solid var(--sl-border);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:var(--sl-bg-secondary);border-color:var(--sl-border-dark)}.terms-checkbox-label input:checked~.checkmark{background-color:var(--sl-primary);border-color:var(--sl-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:var(--sl-primary);cursor:pointer;font-size:.95rem;font-weight:600;padding:0;text-decoration:underline}.terms-modal-overlay{align-items:center;background-color:var(--sl-overlay-dark);bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.terms-modal{background-color:var(--sl-bg);border-radius:10px;box-shadow:0 4px 20px var(--sl-shadow-medium);display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:100%}.terms-modal-header{align-items:center;border-bottom:1px solid var(--sl-border-light);display:flex;justify-content:space-between;padding:15px 20px}.terms-modal-header h3{color:var(--sl-primary);font-size:1.25rem;font-weight:600;margin:0}.close-button{align-items:center;background:none;border:none;color:var(--sl-text-secondary);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:var(--sl-text-primary);font-weight:600;margin:15px 0 8px}.terms-modal-content h4:first-child{margin-top:0}.terms-modal-content p{color:var(--sl-text-secondary);font-size:.95rem;line-height:1.5;margin:8px 0 15px;white-space:pre-line}.terms-modal-footer{border-top:1px solid var(--sl-border-light);display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.accept-button{background-color:var(--sl-primary);border:none;border-radius:6px;color:var(--sl-text-white)}.accept-button,.decline-button{cursor:pointer;font-weight:600;min-height:40px;padding:10px 16px}.decline-button{background-color:initial;border:1px solid var(--sl-border);border-radius:6px;color:var(--sl-text-secondary)}.optional-label{color:var(--sl-text-tertiary);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:var(--sl-primary);transition:background-color .3s}.back-button:hover{background-color:var(--sl-primary-faded)}.create-trip-container h1{color:var(--sl-primary);flex:1 1;margin:0 auto;text-align:center}.trip-info-section{background-color:var(--sl-bg);border-radius:8px;box-shadow:0 2px 4px var(--sl-shadow);margin-bottom:30px;padding:20px}.form-group{margin-bottom:20px}.form-group label{color:var(--sl-primary);margin-bottom:8px}.form-group input,.form-group select{border:1.5px solid var(--sl-border);border-radius:4px;font-size:1rem;padding:10px;width:100%}.form-group input:focus,.form-group select:focus{box-shadow:0 0 0 2px var(--sl-primary-faded)}.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:var(--sl-bg);border:1.5px solid var(--sl-border);border-radius:20px;color:var(--sl-primary);cursor:pointer;display:flex;font-size:14px;gap:6px;padding:8px 12px;transition:all .2s ease}.style-tag:hover{background:var(--sl-primary-faded);border-color:var(--sl-primary-light)}.style-tag.selected{background:var(--sl-primary);border-color:var(--sl-primary);color:var(--sl-text-white)}.style-tag .style-icon{font-size:16px}.style-tag .style-label{font-weight:500}.white-card{background:var(--sl-bg);border-radius:16px;box-shadow:0 4px 16px var(--sl-shadow);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:var(--sl-primary);border:2px solid var(--sl-bg);border-radius:50%;box-shadow:0 2px 4px var(--sl-shadow);cursor:pointer;height:20px;width:20px}input[type=range]::-moz-range-thumb{background:var(--sl-primary);border:2px solid var(--sl-bg);border-radius:50%;box-shadow:0 2px 4px var(--sl-shadow);cursor:pointer;height:20px;width:20px}input[type=range]:focus{outline:none}input[type=range]::-webkit-slider-runnable-track{background:var(--sl-primary-faded);border-radius:4px;height:8px}input[type=range]::-moz-range-track{background:var(--sl-primary-faded);border-radius:4px;height:8px}.image-gallery{background-color:var(--sl-bg-tertiary);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:var(--sl-bg-tertiary);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:var(--sl-overlay-dark);bottom:0;color:var(--sl-text-white);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 var(--sl-shadow-medium);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 var(--sl-shadow-medium)}.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:var(--sl-overlay-dark);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:var(--sl-bg);border-radius:10px;box-shadow:0 5px 20px var(--sl-shadow-medium);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 var(--sl-border-light);display:flex;justify-content:space-between;padding:16px 20px}.modal__title{color:var(--sl-text-primary);font-size:18px;font-weight:600;margin:0}.modal__close-button{align-items:center;background:none;border:none;border-radius:4px;color:var(--sl-text-tertiary);cursor:pointer;display:flex;font-size:18px;justify-content:center;padding:5px;transition:all .2s}.modal__close-button:hover{background-color:var(--sl-bg-tertiary);color:var(--sl-text-primary)}.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:var(--sl-text-primary);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:var(--sl-bg-secondary);border:2px dashed var(--sl-border-dark);border-radius:8px;cursor:pointer;margin-bottom:1.5rem;padding:2rem;text-align:center;transition:all .2s ease}.image-upload-zone:hover{background-color:var(--sl-primary-faded);border-color:var(--sl-primary)}.image-upload-zone.uploading{opacity:.8;pointer-events:none}.upload-icon{font-size:2.5rem;margin-bottom:.5rem}.upload-progress{background-color:var(--sl-border);border-radius:4px;height:8px;margin:1rem 0;overflow:hidden;position:relative;width:100%}.progress-bar{background-color:var(--sl-primary);border-radius:4px;height:100%;transition:width .3s ease}.image-gallery{margin-top:1.5rem}.image-gallery h4{color:var(--sl-text-primary);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 var(--sl-shadow);overflow:hidden;position:relative;transition:transform .2s ease,box-shadow .2s ease}.image-item:hover{box-shadow:0 4px 8px var(--sl-shadow-medium);transform:translateY(-2px)}.image-item img{display:block;height:150px;object-fit:cover;width:100%}.image-item-main{border:3px solid var(--sl-primary)}.image-actions{background:var(--sl-overlay-dark);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:var(--sl-primary);color:var(--sl-text-white)}.set-main-btn:hover{background-color:var(--sl-primary-dark)}.delete-btn{background-color:var(--sl-error);color:var(--sl-text-white)}.delete-btn:hover{background-color:#e04444}.main-badge{background-color:var(--sl-primary);border-radius:4px;color:var(--sl-text-white);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}}.google-maps-attribution{align-items:center;cursor:pointer;display:flex;justify-content:center;padding:8px 12px;transition:opacity .2s ease}.google-maps-attribution:hover{opacity:.8}.google-maps-attribution--full{background-color:#f8f9fa;border-radius:8px;flex-direction:column;margin:8px 0;padding:16px}.google-maps-attribution__logo{align-items:center;display:flex;margin-bottom:4px}.google-logo{font-size:16px;font-weight:600}.google-logo__g{color:#4285f4}.google-logo__o{color:#ea4335}.google-logo__o2{color:#fbbc05}.google-logo__g2{color:#4285f4}.google-logo__l{color:#34a853}.google-logo__e{color:#ea4335}.google-maps-text{color:#666;font-size:16px;font-weight:600}.google-maps-attribution__text{color:#999;font-size:12px}.google-maps-link{color:#4285f4;font-weight:600}.google-maps-attribution__text:hover .google-maps-link{text-decoration:underline}@media (max-width:768px){.google-maps-attribution{padding:6px 10px}.google-maps-attribution__text{font-size:11px}}.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-top:4px solid var(--sl-bg-tertiary);border:4px solid var(--sl-bg-tertiary)}.place-header{padding:20px 0;position:relative}.back-button{background:none;border:none;color:var(--sl-text-primary);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:var(--sl-text-secondary);display:flex;font-size:14px;gap:16px}.place-main-image{align-items:center;aspect-ratio:16/9;border-radius:12px 12px 0 0;box-shadow:0 4px 12px var(--sl-shadow);display:flex;justify-content:center;max-height:none;overflow:hidden;position:relative;width:100%}.place-main-image img{background-color:var(--sl-bg-tertiary);height:100%;object-fit:contain;width:100%}.place-image-placeholder{align-items:center;background:var(--sl-gradient-accent);box-sizing:border-box;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:300px;padding:40px 20px;width:100%}.place-image-placeholder .placeholder-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;height:80px;justify-content:center;margin-bottom:16px;width:80px}.place-image-placeholder .placeholder-icon .material-icons{color:var(--sl-text-white);font-size:48px}.place-image-placeholder .placeholder-text{color:var(--sl-text-white);font-size:20px;font-weight:700;max-width:80%;text-align:center;text-shadow:0 1px 2px #0000001a}.image-overlay-buttons{align-items:flex-start;display:flex;height:auto!important;justify-content:flex-end;left:16px;pointer-events:none;position:absolute;right:16px;top:16px;width:auto!important;z-index:20}.image-overlay-buttons>*{pointer-events:auto}.overlay-back-btn{display:none;margin-right:auto}.overlay-btn{align-items:center;background:#0006;border:none;border-radius:50%;box-shadow:0 2px 8px #0000004d;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s ease;width:44px}.overlay-btn:hover{background:#0009;transform:scale(1.05)}.overlay-btn .material-icons{color:#fff;font-size:24px}.overlay-actions{display:flex;gap:10px}.place-main-image>div:not(.image-overlay-buttons){height:100%;width:100%}.place-main-image .image-gallery-slide img{background-color:var(--sl-bg-tertiary);height:100%;max-height:100%;object-fit:contain;width:100%}.place-image-container{border-radius:12px;box-shadow:0 4px 12px var(--sl-shadow);margin:20px 0;overflow:hidden}.place-meta-container{background-color:var(--sl-bg-secondary);border-radius:0 0 12px 12px;border-top:1px solid var(--sl-border-light);padding:16px}.place-title-mobile{color:var(--sl-text-dark);display:none;font-size:24px;font-weight:700;margin:0 0 12px}.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:12px}.place-image-container{border-radius:0;box-shadow:none;margin:0 -12px 20px;width:calc(100% + 24px)}.place-main-image{aspect-ratio:4/5;border-radius:0;max-height:60vh}.place-meta-container{background-color:var(--sl-bg);border-radius:12px;box-shadow:0 -4px 12px var(--sl-shadow-light);margin:-20px 12px 0;position:relative;z-index:5}.place-title-mobile{display:block}.overlay-btn{height:40px;width:40px}.overlay-btn .material-icons{font-size:22px}.image-overlay-buttons{right:12px;top:12px}.overlay-actions{gap:8px}.map-container{border-radius:12px!important;margin:12px 0!important}.info-section{margin-bottom:24px}.info-section h2{font-size:18px;margin-bottom:12px}}@media (max-width:480px){.place-detail{padding:0 12px 12px}.place-header{display:none}.overlay-back-btn{display:flex}.image-overlay-buttons{justify-content:space-between}.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}.place-image-container{margin-top:0}.place-main-image{aspect-ratio:3/4;max-height:55vh}.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-rating,.place-meta .place-type{align-items:center;border-radius:20px;display:inline-flex;font-weight:500;gap:4px;padding:6px 14px}.place-meta .place-type{background:var(--sl-gradient-accent);box-shadow:0 2px 6px #e0aaff4d;color:var(--sl-text-white)}.place-meta .place-rating{background-color:var(--sl-warning-light);color:var(--sl-warning);font-weight:600}.place-meta .place-rating .review-count{color:var(--sl-text-tertiary);font-weight:400;margin-left:2px}.place-content{padding:20px 0}.info-section{margin-bottom:40px}.info-section h2{font-size:20px;margin-bottom:16px}.address{color:var(--sl-text-secondary);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 var(--sl-border-light);display:flex;justify-content:space-between;padding:8px 0}.day{font-weight:500}.attribution-section{border-top:1px solid var(--sl-border-light);margin-top:24px;padding-top:16px}.reviews-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.write-review-button{background:var(--sl-primary);border:none;border-radius:20px;color:var(--sl-text-white);cursor:pointer;padding:8px 16px}.review-card{border:1px solid var(--sl-border-light);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:var(--sl-text-secondary);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 var(--sl-shadow);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 var(--sl-shadow-medium);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:var(--sl-overlay-dark);bottom:0;color:var(--sl-text-white);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}.edit-category-btn{background:none;border:none;cursor:pointer;font-size:12px;margin-left:6px;opacity:.7;padding:2px;transition:opacity .2s}.edit-category-btn:hover{opacity:1}.category-editor{padding:8px 0}.category-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.category-option{align-items:center;background:var(--sl-bg);border:1px solid var(--sl-border);border-radius:20px;color:var(--sl-text-primary);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:10px 16px;transition:all .2s ease}.category-option:hover{background:var(--sl-primary-faded);border-color:var(--sl-primary)}.category-option.selected{background:var(--sl-primary);border-color:var(--sl-primary);color:var(--sl-text-white)}.category-option .check{font-size:12px}.category-editor-actions{border-top:1px solid var(--sl-border-light);display:flex;gap:12px;padding-top:16px}.category-editor-actions .save-btn{background:var(--sl-primary);border:none;border-radius:8px;color:var(--sl-text-white);cursor:pointer;font-weight:600;padding:10px 20px;transition:background .2s}.category-editor-actions .save-btn:hover{background:var(--sl-primary-dark)}.category-editor-actions .save-btn:disabled{background:var(--sl-primary-light);cursor:not-allowed}.category-editor-actions .cancel-btn{background:var(--sl-bg-tertiary);border:none;border-radius:8px;color:var(--sl-text-secondary);cursor:pointer;font-weight:500;padding:10px 20px;transition:background .2s}.category-editor-actions .cancel-btn:hover{background:var(--sl-border)}.saved-trips-container{margin:0 auto;max-width:800px;padding:20px}.saved-trips-container h1{color:var(--sl-text-dark);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:var(--sl-bg);border-radius:12px;line-height:1.6}.loading,.no-trips,.no-trips-message{color:var(--sl-text-secondary)}.error,.loading,.no-trips,.no-trips-message{font-size:16px;padding:40px;text-align:center}.error{background:var(--sl-error-light);border-radius:12px;color:var(--sl-error)}.profile-container{background-color:var(--sl-bg-secondary);margin:0 auto;max-width:800px;min-height:100vh;padding:20px 20px 90px}.profile-header h1{color:var(--sl-text-dark);font-size:28px;font-weight:800;margin-bottom:20px}.user-card-mobile{background:var(--sl-bg);border-radius:16px;box-shadow:0 4px 12px var(--sl-shadow-light);margin-bottom:20px;padding:20px}.user-info-row{align-items:center;display:flex;position:relative}.user-avatar-large{align-items:center;background:var(--sl-primary);border:4px solid var(--sl-primary-faded);border-radius:50%;color:var(--sl-text-white);display:flex;font-size:28px;font-weight:700;height:70px;justify-content:center;margin-right:20px;overflow:hidden;width:70px}.user-avatar-large img{height:100%;object-fit:cover;width:100%}.user-details-column{flex:1 1}.user-name{color:var(--sl-text-dark);font-size:20px;font-weight:700;margin-bottom:4px}.user-email{color:var(--sl-text-secondary);margin-bottom:4px}.user-bio{color:var(--sl-text-tertiary);font-size:13px;font-style:italic;margin-bottom:4px}.user-location{color:var(--sl-text-secondary);font-size:13px;margin-bottom:8px}.user-badge{background:var(--sl-primary-faded);border-radius:12px;display:inline-block;padding:2px 8px}.edit-icon-button,.user-badge{color:var(--sl-primary);font-size:12px;font-weight:600}.edit-icon-button{background:#0000;border:1px solid var(--sl-primary);border-radius:20px;cursor:pointer;padding:4px 12px;position:absolute;right:0;top:0;transition:all .2s}.edit-icon-button:hover{background:var(--sl-primary-faded)}.stats-row{background:var(--sl-bg);border-radius:16px;box-shadow:0 4px 12px var(--sl-shadow-light);display:flex;justify-content:space-around;margin-bottom:20px;padding:16px}.stat-item-mobile{align-items:center;display:flex;flex-direction:column}.stat-number{color:var(--sl-text-dark);font-size:20px;font-weight:800}.stat-label{color:var(--sl-text-tertiary)}.menu-list-card{background:var(--sl-bg);border-radius:16px;box-shadow:0 4px 12px var(--sl-shadow-light);margin-bottom:20px;overflow:hidden}.menu-item{align-items:center;background:var(--sl-bg);border:none;border-bottom:1px solid var(--sl-border-light);cursor:pointer;display:flex;padding:16px 20px;text-align:left;transition:background .2s;width:100%}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:var(--sl-bg-secondary)}.menu-icon{color:var(--sl-primary);font-size:20px;margin-right:16px}.menu-text{color:var(--sl-text-primary);flex:1 1;font-size:16px;font-weight:500}.menu-arrow{color:var(--sl-text-disabled);font-size:20px}.logout-button-mobile{background:var(--sl-bg);border:2px solid var(--sl-error);border-radius:12px;color:var(--sl-error);cursor:pointer;font-size:16px;font-weight:700;margin-bottom:30px;padding:16px;transition:all .2s;width:100%}.logout-button-mobile:hover{background:var(--sl-error-light)}.profile-section-header h2{color:var(--sl-text-primary);font-size:20px;margin-bottom:12px;margin-left:4px}.trips-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-bottom:24px}@media (max-width:480px){.trips-grid{gap:16px;grid-template-columns:1fr}}.empty-state{background:var(--sl-bg);border-radius:12px;color:var(--sl-text-tertiary);font-size:15px;margin-bottom:24px;padding:40px 20px}.edit-profile-container{margin:0 auto;max-width:900px;padding:30px 20px}.edit-profile-box{background:var(--sl-bg);border-radius:10px;box-shadow:0 2px 8px var(--sl-shadow);padding:30px;position:relative}.edit-profile-title{color:var(--sl-text-primary);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:var(--sl-text-secondary);display:block;font-size:16px;font-weight:500;margin-bottom:8px}.edit-profile-field input,.edit-profile-field textarea{border:1px solid var(--sl-border);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:var(--sl-primary);box-shadow:0 0 0 1px var(--sl-primary-faded);outline:none}.edit-profile-field textarea{min-height:100px;resize:vertical}.edit-profile-actions{border-top:1px solid var(--sl-border-light);display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:25px}.save-btn{background-color:var(--sl-primary);border:none;border-radius:8px;color:var(--sl-text-white);cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 25px;transition:all .2s}.save-btn:hover{background-color:var(--sl-primary-dark);transform:translateY(-1px)}.save-btn:disabled{background-color:var(--sl-primary-light);cursor:not-allowed;transform:none}.cancel-btn{background-color:var(--sl-bg);border:1px solid var(--sl-border);border-radius:8px;color:var(--sl-text-secondary);cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 25px;transition:all .2s}.cancel-btn:hover{background-color:var(--sl-bg-tertiary);border-color:var(--sl-border-dark)}.cancel-btn:disabled{cursor:not-allowed;opacity:.7}.error-message,.loading-message{border-radius:8px;padding:20px;text-align:center}.loading-message{color:var(--sl-text-secondary)}.error-message{background-color:var(--sl-error-light);border:1px solid #feb2b2;color:var(--sl-error)}.success-message{background-color:var(--sl-success-light);border:1px solid #c6f6d5;border-radius:8px;color:var(--sl-success);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:var(--sl-bg-secondary);display:flex;font-family:Nunito,Arial,sans-serif;min-height:100vh}.admin-sidebar{background:var(--sl-bg);border-right:1px solid var(--sl-border);box-shadow:2px 0 12px var(--sl-shadow-light);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 var(--sl-border);margin-bottom:16px;padding:0 24px 24px}.sidebar-header h1{align-items:center;color:var(--sl-text-dark);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:var(--sl-text-secondary);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:var(--sl-text-secondary);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:var(--sl-bg-tertiary);color:var(--sl-primary)}.nav-button.active{background:var(--sl-primary);box-shadow:0 4px 12px var(--sl-shadow-medium);color:var(--sl-text-white)}.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:var(--sl-text-dark);font-size:28px;font-weight:700;margin:0 0 8px}.page-header p{color:var(--sl-text-secondary);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:var(--sl-error-light);border:1px solid #fecaca;color:var(--sl-error)}.alert-success{background:var(--sl-success-light);border:1px solid #bbf7d0;color:var(--sl-success)}.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-top:4px solid var(--sl-primary-faded);border:4px solid var(--sl-primary-faded);border-radius:50%;border-top-color:var(--sl-primary);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.card{background:var(--sl-bg);border:1px solid var(--sl-border);border-radius:16px;box-shadow:0 1px 3px var(--sl-shadow-light);margin-bottom:24px;overflow:hidden}.card-header{align-items:center;background:var(--sl-bg-secondary);border-bottom:1px solid var(--sl-border);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:20px 24px}.card-header h2{color:var(--sl-text-dark);font-size:18px;font-weight:700;margin:0}.card-header p{color:var(--sl-text-secondary);font-size:13px;margin:4px 0 0}.search-container{min-width:280px;position:relative}.search-input{background:var(--sl-bg);border:1px solid var(--sl-border);border-radius:10px;font-size:14px;padding:12px 16px 12px 44px;transition:all .2s ease;width:100%}.search-input:focus{border-color:var(--sl-primary);box-shadow:0 0 0 3px var(--sl-primary-faded);outline:none}.search-icon{color:var(--sl-text-muted);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:var(--sl-text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:6px}.form-help{color:var(--sl-text-secondary);font-size:12px;font-style:italic;margin:4px 0 8px}.form-group input,.form-group select,.form-group textarea{background:var(--sl-bg);border:1px solid var(--sl-border);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:var(--sl-primary);box-shadow:0 0 0 3px var(--sl-primary-faded);outline:none}.form-group small{color:var(--sl-text-secondary);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:var(--sl-primary);color:var(--sl-text-white)}.btn-primary:hover:not(:disabled){background:var(--sl-primary-dark);box-shadow:0 4px 12px var(--sl-shadow-medium);transform:translateY(-1px)}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563}.btn-success{background:var(--sl-success);color:var(--sl-text-white)}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:var(--sl-error);color:var(--sl-text-white)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-warning{background:var(--sl-warning);color:var(--sl-text-white)}.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:var(--sl-bg);border:1px solid var(--sl-border);border-radius:12px;padding:20px;transition:all .2s ease}.city-card:hover{border-color:var(--sl-primary);box-shadow:0 4px 12px var(--sl-shadow);transform:translateY(-2px)}.city-info h3{color:var(--sl-text-dark);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:var(--sl-bg-tertiary);border-radius:4px;color:var(--sl-text-primary);font-family:Monaco,Menlo,monospace;font-size:12px;padding:2px 6px}.city-country{color:var(--sl-text-secondary);font-size:14px}.city-coordinates{color:var(--sl-text-secondary);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:var(--sl-success-light);color:var(--sl-success)}.status-badge.inactive{background:var(--sl-error-light);color:var(--sl-error)}.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:var(--sl-bg);border:1px solid var(--sl-border);border-radius:12px;cursor:pointer;margin-bottom:12px;padding:16px;position:relative;transition:all .2s ease}.trip-item:hover{background:var(--sl-bg-secondary);border-color:var(--sl-primary)}.trip-item.selected{background:var(--sl-primary-faded);border-color:var(--sl-primary);box-shadow:0 2px 8px var(--sl-shadow)}.trip-info h4{color:var(--sl-text-dark);font-size:16px;font-weight:600;margin:0 0 4px}.trip-info p{color:var(--sl-text-secondary);font-size:14px;margin:0 0 8px}.trip-meta{color:var(--sl-text-muted);font-size:12px}.selected-indicator{color:var(--sl-primary);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:var(--sl-primary);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:var(--sl-primary);border-radius:50%;color:var(--sl-text-white);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:var(--sl-success);border-radius:6px;color:var(--sl-text-white);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:var(--sl-text-secondary);padding:48px 24px;text-align:center}.empty-state h3{color:var(--sl-text-primary);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.selected,.place-item:hover{border-color:var(--sl-primary)}.place-item.selected{background:var(--sl-primary-faded)}.place-info h4{color:#111827;font-size:15px;font-weight:600;margin:0 0 4px}.place-type{background:var(--sl-gradient-accent);border-radius:12px;box-shadow:0 2px 4px #e0aaff40;color:var(--sl-text-white);display:inline-block;font-size:11px;font-weight:600;margin-bottom:6px;padding:4px 10px}.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:var(--sl-primary-faded);border-radius:16px;color:var(--sl-primary);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:var(--sl-primary);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:var(--sl-primary-faded);color:var(--sl-primary)}.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:var(--sl-primary);font-size:32px;font-weight:700;margin-bottom:4px}.stat-label{color:var(--sl-text-secondary);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:var(--sl-primary);border:none;border-radius:10px;color:var(--sl-text-white);cursor:pointer;font-size:16px;padding:12px 16px;transition:all .2s ease}.search-button:hover{background:var(--sl-primary-dark)}.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:var(--sl-primary);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:var(--sl-primary);box-shadow:0 4px 12px var(--sl-shadow)}.user-avatar{align-items:center;background:var(--sl-primary);border-radius:50%;color:var(--sl-text-white);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:var(--sl-primary);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:var(--sl-primary-faded);border-color:var(--sl-primary)}.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:var(--sl-primary);color:var(--sl-primary)}.mobile-tab-btn.active{background:var(--sl-primary);border-color:#0000;color:var(--sl-text-white)}.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{--sl-primary:#7581f0;--sl-primary-light:#9ba3f5;--sl-primary-dark:#5a67d8;--sl-primary-faded:#f0f2ff;--sl-gradient-header:linear-gradient(90deg,#f3c6d9,#c2e0f9);--sl-gradient-accent:linear-gradient(90deg,#e0aaff,#a5f3fc);--sl-bg:#fff;--sl-bg-secondary:#f8f9fa;--sl-bg-tertiary:#f5f5f5;--sl-bg-page:#f8f9fa;--sl-bg-card:#fff;--sl-bg-input:#f5f5f5;--sl-bg-disabled:#f0f0f0;--sl-text-primary:#333;--sl-text-secondary:#666;--sl-text-tertiary:#888;--sl-text-muted:#999;--sl-text-light:#aaa;--sl-text-disabled:#ccc;--sl-text-white:#fff;--sl-text-dark:#222;--sl-text-link:#7581f0;--sl-border:#e0e0e0;--sl-border-light:#f0f0f0;--sl-border-dark:#ccc;--sl-border-focus:#7581f0;--sl-success:#4caf50;--sl-success-light:#e8f5e9;--sl-error:#f44;--sl-error-light:#ffebee;--sl-warning:orange;--sl-warning-light:#fff3e0;--sl-info:#2196f3;--sl-info-light:#e3f2fd;--sl-btn-primary:#7581f0;--sl-btn-secondary:#f5f5f5;--sl-btn-disabled:#ccc;--sl-btn-danger:#f44;--sl-btn-text:#fff;--sl-btn-text-secondary:#333;--sl-shadow:#0000001a;--sl-shadow-light:#0000000d;--sl-shadow-medium:#0003;--sl-overlay:#0000004d;--sl-overlay-light:#0000001a;--sl-overlay-dark:#00000080;--sl-avatar-bg:#7581f0cc;--sl-avatar-border:#ffffff80;--sl-avatar-text:#fff;--sl-tag-bg:#f0f0f0;--sl-tag-text:#666;--sl-badge-bg:#7581f0;--sl-badge-text:#fff;--sl-divider:#e0e0e0;--sl-divider-light:#f0f0f0;--sphereloop-primary:var(--sl-primary);--sphereloop-bg:var(--sl-bg-secondary);--sphereloop-text:var(--sl-text-dark)}html{scroll-behavior:smooth}.app,.app-container,body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;background-color:var(--sphereloop-bg);color:#222;color:var(--sphereloop-text);font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;max-width:100vw;overflow-x:hidden}.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;background-color:var(--sl-primary-dark)}.badge{background:#fff;background:var(--sl-bg);border-radius:16px;color:#7581f0;color:var(--sl-primary);display:inline-block;font-size:.95em;font-weight:600;padding:4px 12px}.badge,.badge-fill{border:2px solid #7581f0;border:2px solid var(--sl-primary)}.badge-fill{background:#7581f0;background:var(--sl-primary);color:#fff;color:var(--sl-text-white)}.app{min-height:100vh}.app,.header{background-color:#f8f9fa;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;color:var(--sl-primary);padding:.5rem 1rem;text-decoration:none;transition:all .2s}.nav-link:hover{background-color:#f5f5f5;background-color:var(--sl-bg-tertiary);color:#333;color:var(--sl-text-primary)}.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:calc(70px + env(safe-area-inset-bottom));width:100%}.app-container,.main-content{background:#f8f9fa;background:var(--sphereloop-bg)}.main-content{color:#222;color:var(--sphereloop-text);flex:1 1;padding:56px 5px 20px}.place-badge{background:#f0f2ff;background:var(--sl-primary-faded);border:none;border-radius:16px;color:#7581f0;color:var(--sl-primary);display:inline-block;font-family:Nunito,Arial,sans-serif;font-size:13px;font-weight:500;letter-spacing:.01em;margin-bottom:6px;margin-right:8px;padding:6px 16px}
/*# sourceMappingURL=main.8f6cb19a.css.map*/