.detail-page{min-height:100vh;background:var(--bg-main);padding-bottom:5rem}.back-btn{position:fixed;top:1.5rem;left:1.5rem;z-index:100;background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-glass);padding:.75rem 1.25rem;border-radius:var(--radius-full);cursor:pointer;font-size:1rem;font-weight:600;color:var(--text-primary);box-shadow:var(--shadow-md);transition:all var(--transition-fast);display:flex;align-items:center;gap:.5rem}.back-btn:hover{transform:translateX(-5px);box-shadow:var(--shadow-lg);background:var(--bg-surface)}.detail-header{position:relative;width:100%;height:65vh;min-height:450px;max-height:700px;overflow:hidden;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%)}@media (min-width:1024px){.detail-header{height:55vh;min-height:450px;max-height:650px}}.detail-header img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.8,.2,1)}.detail-header:hover img{transform:scale(1.05)}.detail-header:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.6));pointer-events:none}.detail-no-photo-hero{display:flex;align-items:center;justify-content:center;min-height:88px;padding:1.25rem 1rem;background:linear-gradient(135deg,#e8f0ea,#d4e5d8 55%,#c5d9c9);border-bottom:1px solid #d4e5d8}.detail-no-photo-icon{font-size:1.75rem;line-height:1}.header-actions{position:absolute;top:1.5rem;right:1.5rem;display:flex;gap:1rem;z-index:10}.favorite-btn-large,.share-btn-large,.visited-btn-large{background:rgba(255,255,255,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-glass);border-radius:var(--radius-full);width:50px;height:50px;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.favorite-btn-large:hover,.share-btn-large:hover,.visited-btn-large:hover:not(:disabled){background:var(--bg-surface);transform:scale(1.1) rotate(5deg);box-shadow:var(--shadow-lg)}.favorite-btn-large.active{background:#ff6b6b;color:white;border-color:#ff6b6b}.visited-btn-large.active{background:var(--secondary);color:white;border-color:var(--secondary)}.visited-btn-large:disabled{opacity:.6;cursor:not-allowed}.detail-content{background:var(--bg-main);margin-top:-80px;border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;padding:3.5rem 2rem;max-width:1100px;margin-left:auto;margin-right:auto;box-shadow:var(--shadow-xl);position:relative;z-index:5}.detail-content.no-header{margin-top:0;border-radius:0;padding-top:2rem}.detail-page .detail-content.no-header{margin-top:0;padding-top:1.75rem}.open-in-app-banner{margin-bottom:2.5rem;animation:openInAppSlide .5s ease-out}@keyframes openInAppSlide{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.open-in-app-btn{width:100%;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);color:white;border:none;border-radius:var(--radius-xl);padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md);font-family:var(--font-sans)}.open-in-app-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.open-in-app-btn:active{transform:translateY(-1px)}.open-in-app-btn .app-icon{flex-shrink:0;width:2.75rem;height:2.75rem;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.2)}.open-in-app-btn .app-icon img{width:100%;height:100%;object-fit:cover;display:block}.open-in-app-btn .btn-text{flex:1 1;text-align:left;display:flex;flex-direction:column;gap:.25rem}.open-in-app-btn .btn-text strong{font-size:1.2rem;font-weight:700;display:block}.open-in-app-btn .btn-text small{font-size:.9rem;opacity:.92;font-weight:400;display:block}.open-in-app-btn .arrow{font-size:1.5rem;flex-shrink:0;transition:transform .3s}.open-in-app-btn:hover .arrow{transform:translateX(5px)}@media (min-width:1024px){.detail-content{padding:3rem;margin-top:-100px}.detail-content.no-header,.detail-page .detail-content.no-header{margin-top:0;padding-top:2rem}}.detail-content h1{font-family:var(--font-sans);font-size:3rem;font-weight:800;color:var(--text-primary);margin-top:0;margin-bottom:1.5rem;line-height:1.15;letter-spacing:-.02em}@media (min-width:1024px){.detail-content h1{font-size:3.5rem;margin-bottom:1rem}}.detail-meta{flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}.detail-meta,.location,.period{display:flex;align-items:center}.location,.period{font-size:1.05rem;color:var(--text-secondary);font-weight:500;gap:.5rem}.unesco-badge{background:var(--secondary);color:white;padding:.4rem 1rem;border-radius:var(--radius-full);font-size:.85rem;font-weight:700;box-shadow:0 4px 10px rgba(16,185,129,.3);font-family:var(--font-sans)}.categories{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}.category-tag{background:var(--bg-surface);color:var(--primary);padding:.5rem 1.2rem;border-radius:var(--radius-full);font-size:.9rem;font-weight:600;border:1px solid var(--border-light);transition:all var(--transition-fast)}.category-tag:hover{border-color:var(--primary);background:var(--bg-hover);transform:translateY(-2px)}.section{background:var(--bg-surface);border-radius:var(--radius-xl);padding:2.5rem;margin-bottom:2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.section h2{font-family:var(--font-sans);font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;letter-spacing:-.01em}.section h2:before{content:"";width:5px;height:24px;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);border-radius:var(--radius-full)}.section p{color:var(--text-secondary);line-height:1.8;font-size:1.05rem;margin-bottom:1rem}.section ul{list-style:none;padding:0}.section li{padding:1rem 1.5rem;color:var(--text-secondary);background:var(--bg-hover);border-radius:var(--radius-md);margin-bottom:1rem;border-left:4px solid var(--primary);transition:all var(--transition-fast);font-size:1.05rem;line-height:1.6}.section li:hover{transform:translateX(4px);background:var(--border-light)}.section li:last-child{margin-bottom:0}.photo-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:1.25rem;gap:1.25rem;margin-top:1rem}.photo-gallery img{width:100%;height:220px;object-fit:cover;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.photo-gallery img:hover{transform:scale(1.03);box-shadow:var(--shadow-md);border-color:var(--primary)}.photo-lightbox-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:3rem 4rem;animation:photoLightboxFadeIn .2s ease-out}@keyframes photoLightboxFadeIn{0%{opacity:0}to{opacity:1}}.photo-lightbox-image{max-width:min(92vw,1200px);max-height:85vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:0 25px 50px rgba(0,0,0,.5);-webkit-user-select:none;-moz-user-select:none;user-select:none}.photo-lightbox-close{position:fixed;top:1.25rem;right:1.25rem;width:44px;height:44px;border:none;border-radius:var(--radius-full);background:rgba(255,255,255,.15);color:white;font-size:1.75rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);z-index:2001}.photo-lightbox-close:hover{background:rgba(255,255,255,.3)}.photo-lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;border:none;border-radius:var(--radius-full);background:rgba(255,255,255,.15);color:white;font-size:2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);z-index:2001}.photo-lightbox-nav:hover{background:rgba(255,255,255,.3)}.photo-lightbox-prev{left:1.25rem}.photo-lightbox-next{right:1.25rem}.photo-lightbox-counter{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:.9rem;font-weight:500;letter-spacing:.05em;z-index:2001}@media (max-width:640px){.photo-lightbox-overlay{padding:2.5rem .5rem}.photo-lightbox-nav{width:40px;height:40px;font-size:1.5rem}.photo-lightbox-prev{left:.5rem}.photo-lightbox-next{right:.5rem}}.map-container{width:100%;height:450px;margin:1.5rem auto;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);display:block}.action-buttons{display:flex;gap:1.5rem;margin-top:2.5rem;flex-wrap:wrap}.map-link,.route-btn,.suggest-edit-btn{flex:1 1;min-width:220px;padding:1rem 2rem;border:none;border-radius:var(--radius-lg);font-weight:700;font-size:1rem;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;text-align:center;display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:var(--font-sans)}.map-link{background:var(--primary);color:white}.map-link:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(79,70,229,.4);background:var(--primary-hover)}.route-btn{background:var(--bg-surface);color:var(--primary);border:2px solid var(--primary)}.route-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);background:var(--primary);color:white}.route-btn.in-route{background:var(--secondary);color:white;border-color:var(--secondary)}.route-btn:disabled{opacity:.5;cursor:not-allowed}.suggest-edit-btn{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border-light)}.suggest-edit-btn:hover{transform:translateY(-3px);background:var(--border-light)}.add-photo-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:var(--primary);color:white;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.9rem;transition:all var(--transition-fast)}.add-photo-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(79,70,229,.4)}.add-photo-btn .material-icons{font-size:1.2rem}.rating-btn{width:100%;padding:1rem;background:var(--bg-surface);color:var(--text-primary);border:2px dashed var(--border-light);border-radius:var(--radius-lg);font-weight:700;font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all var(--transition-fast);margin-bottom:1.5rem}.rating-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(245,158,11,.05);transform:translateY(-2px)}.rating-btn .material-icons{font-size:1.5rem}.ratings-list{display:flex;flex-direction:column;gap:1rem}.rating-item{padding:1.25rem;background:var(--bg-surface);border-radius:var(--radius-md);border-left:4px solid var(--accent);border:1px solid var(--border-light);transition:all var(--transition-fast)}.rating-item:hover{transform:translateX(4px);border-color:var(--border-glass)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-surface);border-radius:var(--radius-2xl);padding:2.5rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);border:1px solid var(--border-light)}.close-btn{background:var(--bg-hover);border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:all var(--transition-fast)}.close-btn:hover{background:var(--danger);color:white}.submit-rating-btn,.upload-photo-btn{flex:1 1;padding:1rem;background:var(--primary);color:white;border:none;border-radius:var(--radius-lg);font-weight:700;font-size:1.05rem;cursor:pointer;transition:all var(--transition-fast)}.submit-rating-btn:hover:not(:disabled),.upload-photo-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 15px rgba(79,70,229,.4)}.submit-rating-btn:disabled,.upload-photo-btn:disabled{opacity:.6;cursor:not-allowed}.delete-rating-btn{padding:1rem 1.5rem;background:var(--bg-surface);color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius-lg);font-weight:700;font-size:1.05rem;cursor:pointer;transition:all var(--transition-fast)}.delete-rating-btn:hover{background:var(--danger);color:white;transform:translateY(-2px)}.loading{text-align:center;padding:5rem 2rem;color:var(--text-muted);font-size:1.2rem}@media (max-width:1024px){.detail-content{padding:2.5rem 1.5rem}}@media (max-width:768px){.detail-header{height:50vh;min-height:400px}.detail-content{margin-top:-40px;padding:2rem 1.5rem;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.detail-content.no-header{margin-top:0;border-radius:0;padding-top:1.25rem}.detail-content h1{font-size:2.25rem}.map-container{height:350px;border-radius:var(--radius-lg)}.section{padding:1.5rem}.section h2{font-size:1.35rem}.photo-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.photo-gallery img{height:140px}.action-buttons{flex-direction:column;gap:1rem}.map-link,.route-btn,.suggest-edit-btn{width:100%}.header-actions{top:1rem;right:1rem;gap:.75rem}.favorite-btn-large,.share-btn-large,.visited-btn-large{width:45px;height:45px;font-size:1.3rem}}@media (max-width:480px){.detail-content h1{font-size:1.8rem}.detail-meta{flex-direction:column;align-items:flex-start;gap:1rem}}