.trail-detail{display:flex;flex-direction:column;gap:var(--space-2xl);padding:var(--space-xl) var(--space-lg);background-color:var(--white);color:var(--gray-900);max-width:var(--width-2xl);margin:0;overflow-x:visible}.trail-detail__header{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg);align-items:flex-start}.trail-detail__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-heading);color:var(--gray-900);max-width:var(--width-2xl);margin:0}.trail-detail__location{font-size:var(--font-size-md);color:var(--gray-600);font-weight:var(--font-weight-medium);max-width:var(--width-2xl);margin:0;display:flex;align-items:center;gap:var(--space-sm)}.trail-detail__description{margin-top:var(--space-xs);max-width:var(--width-2xl)}.trail-detail__description .description-text{font-size:var(--font-size-md);line-height:var(--line-height-body);color:var(--gray-800);margin:0}.group-recommend__loading,.trail-info__loading{display:flex;align-items:center;justify-content:center;padding:var(--space-lg);color:var(--gray-600);font-size:var(--font-size-sm);background-color:var(--gray-50);border-radius:var(--radius-md);margin:var(--space-md) 0}.group-recommend__loading:before,.trail-info__loading:before{content:"";width:1rem;height:1rem;border-top:2px solid var(--gray-300);border:2px solid var(--gray-300);border-top-color:var(--primary-600);border-radius:50%;animation:spin 1s linear infinite;margin-right:var(--space-sm)}.trail-detail__info{display:flex;flex-direction:column;gap:var(--space-md);font-size:var(--font-size-md);line-height:var(--line-height-body)}.trail-detail__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(var(--space-5xl),1fr));grid-gap:var(--space-sm);gap:var(--space-sm);list-style:none;padding:0;margin:0}.trail-detail__stats-item{background-color:var(--gray-100);border-radius:var(--radius-md);padding:var(--space-sm);font-weight:var(--font-weight-medium);box-shadow:var(--shadow-sm)}.trail-detail__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.trail-detail__tag{background-color:var(--primary-100);color:var(--primary-800);padding:var(--space-xxs) var(--space-xs);font-size:var(--font-size-sm);border-radius:var(--radius-sm);font-weight:var(--font-weight-medium)}.trail-detail__no-tags{font-size:var(--font-size-sm);color:var(--gray-600)}@media (max-width:767px){.trail-detail{padding:var(--space-lg) var(--space-md)}.trail-detail__title{font-size:var(--font-size-xl)}.trail-detail__stats{grid-template-columns:1fr}}.auth-modal-overlay{position:fixed;inset:0;background:rgb(0 0 0/50%);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.auth-modal{background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;position:relative;padding:var(--space-xl)}.auth-modal__close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;font-size:var(--font-size-2xl);color:var(--gray-400);cursor:pointer;padding:var(--space-xs);line-height:1;transition:color .2s ease}.auth-modal__close:hover{color:var(--gray-600)}.auth-modal__header{margin-bottom:var(--space-lg)}.auth-modal__header h2{margin:0 0 var(--space-xs) 0;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--gray-900)}.auth-modal__header p{margin:0;color:var(--gray-600);font-size:var(--font-size-md)}.auth-modal__benefits{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-xl)}.auth-modal__benefit{font-size:var(--font-size-sm);color:var(--gray-700);padding-left:var(--space-xs)}.auth-modal__providers{display:flex;flex-direction:column;gap:var(--space-md)}.auth-btn{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);background:white;color:var(--gray-800);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);transition:all .2s ease}.auth-btn:hover:not(:disabled){border-color:var(--gray-400);background:var(--gray-50)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-btn--google{border-color:var(--gray-300)}.auth-btn--google:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-400)}.auth-btn__icon{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.auth-btn--email{border-color:var(--primary-300);color:var(--primary-600)}.auth-btn--email:hover:not(:disabled){background:var(--primary-50);border-color:var(--primary-400)}.auth-btn--primary{background:var(--primary-600);color:white;border-color:var(--primary-600)}.auth-btn--primary:hover:not(:disabled){background:var(--primary-700);border-color:var(--primary-700)}.auth-modal__divider{display:flex;align-items:center;margin:var(--space-md) 0;color:var(--gray-500);font-size:var(--font-size-sm)}.auth-modal__divider:after,.auth-modal__divider:before{content:"";flex:1 1;height:1px;background:var(--gray-300)}.auth-modal__divider span{padding:0 var(--space-sm)}.auth-modal__email-form{display:flex;flex-direction:column;gap:var(--space-md)}.auth-modal__email-field{display:flex;flex-direction:column;gap:var(--space-xs)}.auth-modal__email-field label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--gray-700)}.auth-modal__email-field input{padding:var(--space-sm);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:all .2s ease}.auth-modal__email-field input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.auth-modal__email-field input:disabled{background:var(--gray-100);cursor:not-allowed}.auth-modal__error{padding:var(--space-sm);background:var(--red-50);border:1px solid var(--red-200);border-radius:var(--radius-md);color:var(--red-700);font-size:var(--font-size-sm)}.auth-modal__toggle{text-align:center;font-size:var(--font-size-sm);color:var(--gray-600)}.auth-modal__toggle p{margin:0}.auth-modal__toggle-link{background:none;border:none;color:var(--primary-600);font-weight:var(--font-weight-medium);cursor:pointer;padding:0;text-decoration:underline}.auth-modal__toggle-link:hover:not(:disabled){color:var(--primary-700)}.auth-modal__toggle-link:disabled{opacity:.5;cursor:not-allowed}.auth-modal__back{background:none;border:none;color:var(--gray-600);font-size:var(--font-size-sm);cursor:pointer;padding:var(--space-xs);align-self:flex-start}.auth-modal__back:hover:not(:disabled){color:var(--gray-800)}.auth-modal__back:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.auth-modal{padding:var(--space-lg);max-height:95vh}.auth-modal__header h2{font-size:var(--font-size-xl)}}.universal-upload__button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:none;border:none;cursor:pointer;transition:all .2s ease;font-family:inherit}.universal-upload__button--placeholder{width:100%;height:100%;background:var(--gray-100);border:2px dashed var(--gray-300);border-radius:var(--radius-md);color:var(--gray-600);padding:1rem}.universal-upload__button--placeholder:hover{background:var(--gray-50);border-color:var(--primary-300);color:var(--primary-600)}.universal-upload__button--modal{background:var(--primary-600);color:white;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px rgba(0,0,0,.2);font-size:.875rem;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;height:auto;line-height:1}.universal-upload__button--modal:hover{background:var(--primary-700);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}.universal-upload__button--hero{background:rgba(0,0,0,.8);color:white;border:none;border-radius:var(--radius-md);padding:.5rem 1rem;font-size:.875rem;font-weight:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.universal-upload__button--hero:hover{background:rgba(0,0,0,.9)}.universal-upload__button--empty-state{background:var(--primary-600);color:white;border:none;border-radius:var(--radius-lg);padding:1rem 2rem;font-size:1.1rem;font-weight:600;box-shadow:var(--shadow-md)}.universal-upload__button--empty-state:hover{background:var(--primary-700);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.universal-upload__icon{font-size:1.5rem;opacity:.8}.universal-upload__icon--svg{width:1.25rem;height:1.25rem;opacity:.8}.universal-upload__text{font-size:.875rem;font-weight:500}.universal-upload__modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);z-index:10002;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .3s ease-out}.universal-upload__modal{background:white;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;position:relative;padding:var(--space-xl)}.universal-upload__close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;color:var(--gray-400);cursor:pointer;padding:.5rem;line-height:1;transition:color .2s ease}.universal-upload__close:hover{color:var(--gray-600)}.universal-upload__header{margin-bottom:var(--space-lg)}.universal-upload__header h3{margin:0 0 var(--space-xs) 0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--gray-900)}.universal-upload__header p{margin:0;color:var(--gray-600);font-size:var(--font-size-md)}.universal-upload__dropzone{border:2px dashed var(--gray-300);border-radius:var(--radius-md);padding:2rem;text-align:center;transition:all .2s ease;cursor:pointer}.universal-upload__dropzone:hover{border-color:var(--primary-300);background:var(--primary-50)}.universal-upload__input{display:none}.universal-upload__label{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);cursor:pointer;color:var(--gray-600)}.universal-upload__icon-large{font-size:3rem;opacity:.7}.universal-upload__hint{font-size:var(--font-size-sm);color:var(--gray-500)}.universal-upload__preview-container{display:flex;flex-direction:column;gap:var(--space-md)}.universal-upload__preview{width:100%;max-height:300px;object-fit:cover;border-radius:var(--radius-md)}.universal-upload__actions{display:flex;gap:var(--space-sm);justify-content:center}.universal-upload__btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:all .2s ease}.universal-upload__btn--secondary{background:var(--gray-100);color:var(--gray-700)}.universal-upload__btn--secondary:hover{background:var(--gray-200)}.universal-upload__btn--primary{background:var(--primary-600);color:white}.universal-upload__btn--primary:hover{background:var(--primary-700)}.universal-upload__btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width:768px){.universal-upload__modal{padding:var(--space-lg);margin:var(--space-sm)}.universal-upload__dropzone{padding:1.5rem}.universal-upload__actions{flex-direction:column}.universal-upload__btn{width:100%}}.full-page-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);z-index:9999;display:flex;flex-direction:column;overflow:hidden;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.full-page-modal__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:rgba(0,0,0,.8);color:white;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.full-page-modal__close{background:none;border:none;color:white;font-size:2rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s ease}.full-page-modal__close:hover{background-color:rgba(255,255,255,.1)}.full-page-modal__navigation{display:flex;align-items:center;gap:1rem}.full-page-modal__nav-button{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:white;padding:.5rem 1rem;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:1.2rem}.full-page-modal__nav-button:hover:not(:disabled){background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.5)}.full-page-modal__nav-button:disabled{opacity:.3;cursor:not-allowed}.full-page-modal__counter{font-weight:600;font-size:1.1rem;min-width:80px;text-align:center}.full-page-modal__upload-container{position:absolute;top:1rem;right:1rem}.full-page-modal__mobile-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:rgba(0,0,0,.8);color:white;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.full-page-modal__count{font-weight:600;font-size:1.1rem}.full-page-modal__content{flex:1 1;overflow:hidden;padding:1rem}.full-page-modal__content,.full-page-modal__photo-container{display:flex;align-items:center;justify-content:center;position:relative}.full-page-modal__photo-container{width:100%;height:100%;cursor:-webkit-grab;cursor:grab;touch-action:pan-y}.full-page-modal__photo-container:active{cursor:-webkit-grabbing;cursor:grabbing}.full-page-modal__photo{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:transform .2s ease}.full-page-modal__photo:hover{transform:scale(1.02)}.full-page-modal__metadata{position:absolute;bottom:1rem;left:1rem;right:1rem;background:rgba(0,0,0,.8);color:white;padding:1rem;border-radius:8px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.full-page-modal__description{margin:0 0 .5rem;font-size:.9rem;line-height:1.4}.full-page-modal__uploader{margin:0;font-size:.8rem;opacity:.8}.full-page-modal__thumbnails{display:flex;gap:.5rem;padding:1rem 2rem;background:rgba(0,0,0,.8);overflow-x:auto;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.full-page-modal__thumbnail{border:2px solid transparent;border-radius:4px;overflow:hidden;cursor:pointer;transition:all .2s ease;background:none;padding:0;min-width:80px;height:60px;position:relative}.full-page-modal__thumbnail:hover{border-color:rgba(255,255,255,.3);transform:scale(1.05)}.full-page-modal__thumbnail.active{border-color:var(--primary-500);box-shadow:0 0 0 1px var(--primary-500)}.full-page-modal__thumbnail-image{width:100%;height:100%;object-fit:cover}.full-page-modal__dots{display:flex;gap:.5rem;justify-content:center;padding:1rem;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.full-page-modal__dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);transition:background .2s ease}.full-page-modal__dot.active{background:white;transform:scale(1.2)}.full-page-modal__back-button{position:absolute;bottom:2rem;left:2rem;z-index:10}.full-page-modal__back-btn{background:rgba(255,255,255,.9);color:black;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px rgba(0,0,0,.2)}.full-page-modal__back-btn:hover{background:white;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.3)}.full-page-modal__load-more{position:absolute;bottom:0;left:0;right:0;height:1px}.full-page-modal__loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;color:white;font-size:.9rem}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin 1s linear infinite}@media (max-width:768px){.full-page-modal__content{padding:.5rem}.full-page-modal__photo{border-radius:0}.full-page-modal__back-button{bottom:1rem;left:1rem;right:1rem;display:flex;flex-direction:column;gap:.75rem}.full-page-modal__back-btn{width:100%;text-align:center}.full-page-modal__metadata{bottom:.5rem;left:.5rem;right:.5rem;padding:.75rem}}@media (hover:none) and (pointer:coarse){.full-page-modal__photo:hover,.full-page-modal__thumbnail:hover{transform:none}}.route-detail-hero{margin-bottom:1.5rem}.route-detail-hero__image-grid{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;grid-gap:.5rem;gap:.5rem;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:2.5}.route-detail-hero__image-large{grid-row:span 2;position:relative;overflow:hidden}.route-detail-hero__image-side{display:contents}.route-detail-hero__photo{position:relative;overflow:hidden;aspect-ratio:1.6}.route-detail-hero__photo--placeholder{display:flex;align-items:center;justify-content:center}.route-detail-hero__photo--map{position:relative}.route-detail-hero__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:2px dashed var(--gray-300);border-radius:var(--radius-md);transition:all .2s ease}.route-detail-hero__placeholder:hover{background:var(--gray-50);border-color:var(--primary-300)}.route-detail-hero__placeholder-gradient{width:100%;height:100%;background:linear-gradient(135deg,var(--gray-100) 0,var(--gray-200) 100%)}.route-detail-hero__image{object-fit:cover;width:100%;height:100%}.route-detail-hero__map-container{position:absolute;inset:0;border-radius:var(--radius-lg);overflow:hidden}.route-detail-hero__map-button{position:absolute;bottom:2.5rem;right:2rem;z-index:10;padding:.75rem 1.5rem;background:var(--primary-600);color:white;border:none;border-radius:var(--radius-full);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);cursor:pointer;box-shadow:var(--shadow-md);transition:all .2s ease}.route-detail-hero__map-button:hover{background:var(--primary-700);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.route-detail-hero__map-button--mobile{bottom:1.5rem;padding:.875rem 2rem;font-size:var(--font-size-lg)}.route-detail-hero__map-error,.route-detail-hero__map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:var(--gray-50);color:var(--gray-600);font-size:.875rem;text-align:center;padding:1rem}.route-detail-hero__loading-spinner{width:1.25rem;height:1.25rem;border-top:2px solid var(--gray-200);border:2px solid var(--gray-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:.5rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.route-detail-hero__link-container{position:absolute;top:1rem;right:1rem;z-index:3}.route-detail-hero__photos-link{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:rgb(255 255 255/.9);color:var(--gray-800);text-decoration:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s ease}.route-detail-hero__photos-link:hover{background-color:var(--gray-100)}.photo__action-mount{position:absolute;top:8px;left:8px;z-index:3}.route-detail-hero__photo--clickable{cursor:pointer;transition:transform .2s ease}.route-detail-hero__photo--clickable:hover{transform:scale(1.02)}.route-detail-hero__see-all{position:absolute;bottom:1rem;right:1rem;z-index:10}.route-detail-hero__see-all-button{background:rgba(0,0,0,.8);color:white;border:none;padding:.5rem 1rem;border-radius:4px;font-size:.875rem;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s ease;font-weight:500}.route-detail-hero__see-all-button:hover{background:rgba(0,0,0,.9);transform:translateY(-1px)}.route-detail-hero__mobile-count{position:absolute;bottom:1rem;left:1rem;z-index:10;display:none}.route-detail-hero__count-text{background:rgba(0,0,0,.8);color:white;padding:.5rem 1rem;border-radius:4px;font-size:.875rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-weight:500}@media (max-width:48rem){.route-detail-hero__image-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:0;border-radius:0;margin-bottom:1rem;aspect-ratio:1.5}.route-detail-hero__image-large{grid-row:auto}.route-detail-hero__image-side{display:none}.route-detail-hero__photo{aspect-ratio:1.5}.route-detail-hero__map-button{bottom:1rem;right:1rem;padding:.375rem .75rem;font-size:var(--font-size-sm)}.route-detail-hero__see-all{display:none}.route-detail-hero__mobile-count{display:block}}.difficulty-badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.025em;border:2px solid transparent;transition:all .2s ease;width:-moz-fit-content;width:fit-content;text-align:center}.difficulty-badge--easy{background-color:var(--primary-100);color:var(--primary-800);border-color:var(--primary-200)}.difficulty-badge--moderate{background-color:var(--primary-200);color:var(--primary-900);border-color:var(--primary-300)}.difficulty-badge--hard{background-color:var(--primary-300);color:var(--primary-900);border-color:var(--primary-400)}.difficulty-badge--very-hard{background-color:var(--primary-500);color:var(--white);border-color:var(--primary-600)}.difficulty-badge--unknown{background-color:var(--gray-100);color:var(--gray-800);border-color:var(--gray-200)}.difficulty-badge:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}