@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400..900&family=Cormorant:ital,wght@0,300..700;1,300..700&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Playfair+Display:ital,wght@0,400..900;1,400..900&family=Whisper&display=swap');.no-scroll{overflow:hidden !important;height:100vh !important;touch-action:none;/* Disable touch scroll on mobile */}/* ── SAMI custom SVG icon (mask technique — colore via currentColor) ── */ .sami-icon{display:inline-block;width:1em;height:1em;background-color:currentColor;-webkit-mask-image:url('/img/sami-icon.svg');mask-image:url('/img/sami-icon.svg');-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;vertical-align:middle;flex-shrink:0}/* About Gallery Widget */ .about-grid{display:flex;flex-direction:column;gap:24px}.about-gallery-widget{margin-top:0;padding-top:24px;border-top:1px solid var(--border);max-width:50%}.about-text{max-height:-webkit-fill-available;overflow-y:auto;height:100%;padding-bottom:60px;font-weight:300}@media (min-width:769px){.about-grid{display:flex;grid-template-columns:1fr 1fr;gap:32px;align-items:start;flex-direction:row;height:100%;max-height:calc(100vh - 200px)}.about-gallery-widget{border-top:none;padding-top:0}}.about-gallery-widget h3{font-size:14px;font-weight:500;margin-bottom:16px;color:var(--text-primary);letter-spacing:1px}.about-slider-container{position:relative;width:100%;height:-webkit-fill-available;max-height:50vh;border-radius:0px;overflow:hidden}.about-slider-track{display:flex;height:100%;transition:transform 0.3s ease-out}.about-slider-track img{width:100%;height:100%;object-fit:cover;flex-shrink:0;cursor:grab}.about-nav{position:absolute;top:50%;transform:translateY(-50%);border:none;width:36px;height:36px;border-radius:50%;background:transparent;color:var(--text-muted);border:none;font-size:16px;padding:4px;cursor:pointer;z-index:10;transition:background 0.2s}.about-nav:hover{opacity:0.8}.about-nav.prev{left:10px}.about-nav.next{right:10px}.about-dots{display:flex;justify-content:center;gap:8px;margin-top:12px}.about-dots .dot{width:8px;height:8px;border-radius:50%;background:transparent;cursor:pointer;transition:background 0.2s;border:solid 1px var(--text-primary)}.about-dots .dot.active{background:var(--accent)}.contact-slider{position:relative;width:100%;margin-bottom:24px}.contact-slider-track{display:flex;width:100%;transition:transform 0.3s ease-out;overflow:hidden}.contact-slider-track .contact-card{flex:0 0 100%;max-width:100%}.contact-nav{position:absolute;top:50%;transform:translateY(-50%);border:none;width:34px;height:34px;border-radius:50%;background:rgb(147 147 147 / 70%);color:var(--text-secondary);font-size:14px;cursor:pointer;z-index:10;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.contact-nav.prev{left:6px}.contact-nav.next{right:6px}.contact-dots{display:flex;justify-content:center;gap:8px;margin-top:12px}.contact-dots .dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:background 0.2s}.contact-dots .dot.active{background:var(--accent)}/* Mobile optimizations for slider */ @media (max-width:768px){.about-slider-container{height:-webkit-fill-available}.about-gallery-widget{max-width:-webkit-fill-available}.about-text{padding-bottom:0}}/* All CSS variables (palette,fonts,themes) are defined in themes.css — loaded first in head-renderer.php */ .mobile-only{display:none !important}.hidden{display:none !important}.desktop-only{display:block !important}@media (max-width:1024px){.desktop-only{display:none !important}}*{box-sizing:border-box}.maplibregl-map{filter:saturate(0.5)}/* ── Google Translate — hide all injected UI (custom switcher used instead) ── */ .goog-te-banner-frame{display:none !important}body>.skiptranslate{display:none !important}.goog-te-gadget{display:none !important}.goog-te-gadget-icon{display:none !important}.goog-logo-link{display:none !important}.goog-te-balloon-frame{display:none !important}.goog-gt-tt{display:none !important}/* Floating translate bubble/icon (mobile & desktop) */ .VIpgJd-ZVi9od-aZ2wEe-OiiCO{display:none !important}.VIpgJd-ZVi9od-aZ2wEe{display:none !important}body{top:0 !important}body{margin:0;font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);height:100vh;display:flex;flex-direction:column;overflow:hidden}/* ── Scroll/Load Reveal ── */ .sr{opacity:0;transform:translateY(20px);transition:opacity 0.55s cubic-bezier(0.22,1,0.36,1),transform 0.55s cubic-bezier(0.22,1,0.36,1);will-change:opacity,transform}.sr.sr--left{transform:translateX(-28px)}.sr.sr--right{transform:translateX(28px)}.sr.in{opacity:1;transform:none}/* ── Property card reveal (listing widget) ── */ .property-card.sr-card{opacity:0;transform:translateY(12px);transition:opacity 0.42s cubic-bezier(0.22,1,0.36,1),transform 0.42s cubic-bezier(0.22,1,0.36,1)}.property-card.sr-card.in{opacity:1;transform:none}button,input,select,textarea{font-family:var(--font-sans)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 20px;background:transparent;border-bottom:solid 1px var(--border);height:64px;width:100%}.brand{display:flex;align-items:center;flex-shrink:0;max-width:300px}.brand img{height:60px;width:auto;max-width:100%;object-fit:contain}.search-box{flex:1;max-width:600px;min-width:200px}.search-box input{width:100%;height:40px;border-radius:0px;border:1px solid var(--border);padding:0 12px;background:var(--bg-primary);font-size:16px;outline:none;font-family:var(--font-sans-2)}.main-nav{display:flex;gap:16px;flex-shrink:0}.nav-link{padding:10px 14px;border-radius:0px;text-decoration:none;font-weight:500;background:var(--bg-primary);color:var(--text-primary);border:none;transition:all ease .5s;text-transform:lowercase;letter-spacing:.1px;display:flex;flex-direction:row;justify-content:center;align-items:center;gap:10px;letter-spacing:.5px}.nav-link i{font-size:8px}.nav-link:hover{border-color:var(--accent);color:var(--accent)}.nav-link.active{color:var(--accent);font-weight:600}.page{padding:16px;height:calc(100vh - 64px);overflow:hidden}.cockpit{display:grid;grid-template-columns:max(430px,30vw) 1fr;gap:16px;height:100%}.left-column{display:flex;flex-direction:column;gap:16px;height:100%;min-height:0;overflow:hidden}.list-panel{background:transparent;border:1px solid var(--border);border-radius:0px;display:flex;flex-direction:column;flex:1;position:relative;z-index:10;min-height:0}.custom-price-marker{border:none}.price-tag{background:var(--bg-panel);color:var(--text-main);padding:4px 8px;border-radius:0px;font-weight:500;font-size:12px;white-space:nowrap;display:inline-block;border:solid 1px var(--border);transition:transform 0.2s,z-index 0.2s;position:relative;letter-spacing:2px}.price-tag::after{content:"";position:absolute;bottom:-4px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--primary)}.custom-price-marker:hover .price-tag{transform:scale(1.1);z-index:1000;background:var(--text-primary);color:var(--text-secondary);border-color:var(--text-primary)}.custom-price-marker:hover .price-tag::after{border-top-color:var(--primary)}.leaflet-container{outline:none}.map-panel{position:relative}.draw-banner{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(250,249,247,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-main);padding:12px 28px;border-radius:0;display:flex;align-items:center;gap:20px;box-shadow:0 4px 24px rgba(0,0,0,0.12),0 0 0 1px rgba(160,120,80,0.2);border:1px solid rgba(160,120,80,0.25);z-index:2000;font-size:14px;font-weight:400;letter-spacing:0.3px;white-space:nowrap}.draw-banner.hidden{display:none}.btn-text{background:transparent;border:none;font-weight:500;cursor:pointer;font-size:14px;text-transform:lowercase;letter-spacing:0.5px;transition:color 0.2s}.btn-text:hover{color:var(--accent);text-decoration:none}.btn-text.confirm{background:var(--accent);color:var(--text-secondary);padding:10px 20px;border-radius:0px;box-shadow:var(--shadow-sm)}.btn-text.confirm:hover{background:var(--accent-dark);text-decoration:none;transform:translateY(-1px)}.draw-controls{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:1000}.pill-draw{background:var(--bg-secondary);color:var(--text-main);border:none;padding:10px 20px;border-radius:0px;font-weight:500;font-size:10px;box-shadow:var(--shadow-sm);cursor:pointer;display:flex;align-items:center;gap:8px;transition:transform 0.2s;backdrop-filter:blur(9px);-webkit-backdrop-filter:blur(9px);will-change:blur;letter-spacing:2px}.pill-draw:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.map.drawing-mode{cursor:crosshair}/* Draw vertices for map polygon editing */ .draw-vertex,.draw-vertex-edit{width:12px;height:12px;background:var(--bg-primary);border:2px solid var(--accent);border-radius:50%;box-sizing:border-box;display:block}.draw-vertex{width:10px;height:10px}.draw-vertex-edit{cursor:grab}.custom-preview-popup .leaflet-popup-content-wrapper{padding:0;border-radius:0px;overflow:hidden;box-shadow:var(--shadow-sm);background:var(--bg-panel)}.custom-preview-popup .leaflet-popup-content{margin:0;width:280px !important}.custom-preview-popup .leaflet-popup-tip{background:var(--bg-dark);border-radius:3px}.preview-card{display:flex;flex-direction:column}.preview-image-container{position:relative;height:160px;background:var(--bg-dark);border-bottom:solid 1px var(--border)}.preview-img{width:100%;height:100%;object-fit:cover}.preview-info{padding:12px}.preview-price{font-size:20px;font-weight:500;color:var(--text-main);margin-bottom:8px}.preview-meta{display:flex;gap:12px;color:var(--text-main);font-size:13px;margin-bottom:12px}.preview-meta span{display:flex;align-items:center;gap:4px}.leaflet-control-attribution{display:none !important}.legal-footer{background:var(--panel);border:0;border-radius:0px;padding:12px;display:flex;flex-direction:column-reverse;gap:8px;flex-shrink:0}.legal-branding{display:flex;align-items:center;gap:0;justify-content:center;text-decoration:none;font-family:var(--font-whisper);font-size:20px;font-style:normal;font-weight:400;-webkit-text-stroke-width:0.5px;-webkit-text-stroke-color:var(--accent);paint-order:stroke fill}.legal-branding:hover{color:var(--primary)}.legal-branding img{width:20px;height:20px;border-radius:4px;object-fit:cover}.legal-branding .brand{display:flex;align-items:center;font-size:inherit;font-weight:inherit;margin:0}.legal-branding span{color:var(--accent);transform:translate(0,4px)}mc-ico-parallel:after{content:'';position:absolute;padding:0px 10px;border:solid 2px var(--button-color);margin-left:-13px;border:solid 1px transparent;margin-top:-8px;transition:all ease 0.33s;transform:rotate(150deg);height:3px;background-color:var(--accent-dim-2);border-radius:30% 70% 70% 30% / 30% 30% 70% 70%;border-bottom:none;transition:all ease 0.33s;box-shadow:0px 0px 0px var(--pill-text)}mc-ico-parallel:before{content:'';border-color:transparent;margin-top:3px;margin-left:14px;padding:0;background-color:var(--accent);width:6px;height:6px;margin-top:1px;margin-right:3px;float:left;border-radius:100%;transition:all ease 0.4s}mc-ico{display:block;float:right;width:auto;transform:scale(0.7) translate(10px,-3px);transition:all ease 0.33s;position:relative;margin:0 auto;float:left;top:unset;opacity:1;padding:0;z-index:100;transform:scale(0.6) translate(0px,10px);margin-top:0;margin-bottom:0;padding:5px 5px;will-change:transform}mc-ico.active{opacity:1;width:33px;transform:scale(1.5);top:calc(50vh - 167px)}mc-ico.active.check:before,mc-ico.active.check:after,mc-ico.active.check mc-ico-parallel:before,mc-ico.active.check mc-ico-parallel:after{background-color:var(--green);opacity:0}mc-ico[back_mode] mc-ico-parallel:after{margin-top:-17px;padding:0 16px;margin-left:-24px;height:3px}mc-ico[back_mode] mc-ico-parallel:before{display:none}mc-ico[back_mode] mc-ico-parallel{float:left}mc-ico[back_mode]:before{display:none}mc-ico[back_mode]:after{margin-top:4px;height:4px;margin-left:-24px}mc-ico:after{content:'';position:absolute;padding:0px 16px;border:solid 2px var(--button-color);margin-left:-47px;border:solid 0px var(--pill-text);margin-top:-13px;transition:all ease 0.33s;transform:rotate(38deg) translate(0,0);height:5px;background-color:var(--accent-dim-2);border-radius:30% 70% 70% 30% / 30% 30% 70% 70%;border-top:none;border-bottom:none;animation-iteration-count:3}mc-ico:before{content:' ';line-height:50px;border-color:transparent;padding:0;width:10px;height:10px;margin-top:0px;float:left;border-radius:100%;background-color:var(--accent);margin-right:-4px;transition:all ease 0.33s;font-weight:800;text-transform:uppercase;font-size:10px;letter-spacing:2px;color:var(--text-main);animation:net-eye 3s 0.1s ease-in-out 1}@keyframes net-eye{0%{box-shadow:0px 3px 19px var(--net-color-4)}50%{box-shadow:0px 3px 0px var(--net-color-4)}100%{box-shadow:0px 3px 19px var(--net-color-4)}}@keyframes fadeIn{from{opacity:0}top{opacity:1}}@keyframes loading{from{transform:rotate(360deg)}to{transform:rotate(0deg)}}.legal-links{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:11px;justify-content:space-evenly}.legal-links a{color:var(--accent);text-decoration:none;font-weight:500;text-transform:lowercase;letter-spacing:.5px}.legal-links a:hover{text-decoration:underline;color:var(--primary)}.filters-bar{padding:16px;border-bottom:solid 1px var(--border);background:transparent;display:flex;gap:12px;border-radius:0px 16px 0 0;flex-shrink:0;overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap}.filter-dropdown{position:relative}.filter-btn i{font-size:12px;margin-top:2px}.filter-btn{padding:8px 16px;border-radius:0px;border:1px solid var(--border);background:var(--bg-panel);color:var(--text-primary);font-weight:400;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s;font-size:16px;width:-webkit-fill-available;text-transform:lowercase;letter-spacing:1px;align-content:center}.filter-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--bg-panel)}.filter-popup{position:absolute;top:100%;left:0;margin-top:8px;background:var(--bg-panel);border:1px solid var(--border);border-radius:0px;box-shadow:var(--shadow-sm);padding:12px;min-width:200px;z-index:10000;display:flex;flex-direction:column;gap:8px;max-height:600px;overflow-y:auto;/* ── Tenda / serranda animation ── */ transform-origin:top center;clip-path:inset(0 0 0% 0);opacity:1;transition:clip-path 0.26s cubic-bezier(0.4,0,0.2,1),opacity 0.22s ease}/* Serranda chiusa:clip dall'alto verso il basso,scompare in alto */ .filter-popup.hidden{display:flex !important;/* sovrascrive .hidden{display:none !important}*/ clip-path:inset(0 0 100% 0);opacity:0;pointer-events:none;overflow:hidden;/* nasconde scrollbar durante la chiusura */}/* Chevron ruota quando il popup è aperto */ .filter-dropdown:has(.filter-popup:not(.hidden)) .filter-btn .fa-chevron-down,.filter-dropdown:has(.filter-popup:not(.hidden)) .pill .fa-chevron-down{transform:rotate(-180deg)}.filter-btn .fa-chevron-down,.pill .fa-chevron-down{transition:transform 0.24s cubic-bezier(0.4,0,0.2,1);display:inline-block}.filter-option{display:flex;align-items:center;gap:8px;padding:6px;border-radius:0px;cursor:pointer;font-size:16px;border:solid 1px var(--border);padding-left:10px;color:var(--text-main);transition:all ease .3s;text-transform:lowercase}.filter-option.selected,.filter-option.selected:hover{background:var(--accent);color:var(--text-secondary);border-color:var(--accent)}.filter-option:hover{background:transparent;color:var(--accent);border:solid 1px var(--accent)}.list-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;flex-shrink:0;color:var(--text-primary);font-size:11px;letter-spacing:2px;font-weight:300}.cards{display:grid;grid-template-columns:1fr;gap:12px;padding:0 16px 16px;overflow-y:auto;flex:1;min-height:0}/* â”€â”€ Skeleton shimmer (Facebook-style) â”€â”€ */ @keyframes skel-shimmer{0%{background-position:-600px 0}100%{background-position:600px 0}}.skel-block{background:linear-gradient(90deg,var(--bg-tertiary,#f1f5f9) 25%,var(--bg-lighter,#e2e8f0) 50%,var(--bg-tertiary,#f1f5f9) 75%);background-size:1200px 100%;animation:skel-shimmer 1.5s infinite linear;border-radius:6px}.property-card--skeleton .card-thumb.skel-block{width:80px;height:70px;flex-shrink:0;border-radius:8px}.property-card--skeleton .skel-title{height:13px;width:80%;margin-bottom:8px}.property-card--skeleton .skel-price{height:15px;width:45%;margin-bottom:8px}.property-card--skeleton .skel-meta{height:11px;width:90%;margin-bottom:0}.property-card--skeleton .skel-feat{height:11px;width:55%}.property-card--skeleton .card-content{display:flex;flex-direction:column;gap:0;flex:1}.property-card--skeleton .card-features{padding-top:4px}.property-card{display:flex;flex-direction:column;gap:12px;padding:20px;background:transparent;border:solid 1px var(--border-color);border-radius:0px;cursor:pointer;transition:all ease .5s}.card-top-row{display:grid;grid-template-columns:190px 1fr;gap:12px;position:relative}.card-content{display:flex;flex-direction:column;justify-content:center}.property-card:hover{border-color:var(--accent)}.card-thumb{width:180px;height:116px;border-radius:0;background:var(--border);object-fit:cover}.prop-star-badge{position:absolute;top:6px;left:6px;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;pointer-events:none}.prop-star-badge i{font-size:13px;color:var(--accent);line-height:1}.card-thumb-placeholder{display:flex;align-items:center;justify-content:center;background:var(--bg-dark,#1a1a2e);color:var(--text-muted,#64748b);font-size:1.5rem;flex-shrink:0}.card-title{font-weight:700;margin-bottom:4px;letter-spacing:0;font-size:15px;line-height:1.6;font-family:var(--font-sans-4)}.card-price{font-family:var(--font-sans);font-size:15px;font-weight:400;letter-spacing:0.18em;color:var(--oro);display:block;margin-bottom:8px}.card-meta{display:flex;gap:10px;color:var(--text-primary);opacity:0.9;font-size:13px;margin-bottom:0;letter-spacing:1px}.card-features{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 12px;margin-top:0;padding-top:12px;border-top:none;font-size:13px;letter-spacing:1px;text-transform:lowercase}.card-features i{font-size:10px}.right-column{display:flex;flex-direction:column;gap:16px;height:100%;overflow:hidden;/* Restore hidden overflow for auto-fit */ min-height:0}.map-panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:0px;overflow:hidden;flex:1 1 auto;/* Flex grow and shrink */ display:flex;flex-direction:column;min-height:0;/* Allow shrinking below content size if needed */}.map-filters{padding:10px;border-bottom:1px solid var(--border);background:transparent;position:relative;z-index:1001;overflow-x:auto;overflow-y:hidden}.pillbar{display:flex;gap:8px}.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:0px;background:var(--bg-primary);border:1px solid var(--border);color:var(--text-primary);font-weight:400;font-size:16px;cursor:pointer;transition:all ease .3s;white-space:nowrap;text-transform:lowercase;letter-spacing:1px}.pill:hover{border-color:var(--accent);color:var(--accent);background:var(--bg-primary)}.pill i{font-size:10px}.pill.active{background:transparent;color:var(--accent);border-color:var(--accent)}.popup-header{padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:8px}.range-inputs{display:flex;gap:8px}.range-inputs input{width:100%;padding:8px;border:1px solid var(--border);border-radius:0px;font-size:16px;outline:none;background:var(--bg-primary)}.popup-options{max-height:200px;overflow-y:auto;display:grid;gap:4px}.popup-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}/* Onboarding progress bar */ .ob-progress{margin-bottom:12px}.ob-progress-header{font-size:12px;font-weight:700;color:var(--text-muted);margin-bottom:6px}.ob-progress-track{width:100%;height:6px;background:var(--bg-lighter);border:1px solid var(--border);border-radius:0px;overflow:hidden}.ob-progress-fill{height:100%;background:var(--accent);border-radius:0px;transition:width 0.2s ease}.btn-apply{width:100%;padding:12px;background:var(--accent);color:var(--text-secondary);border:none;border-radius:0;font-weight:500;cursor:pointer;font-size:15px;letter-spacing:0.5px;transition:background 0.2s,transform 0.2s}.btn-apply:hover{background:var(--accent-dark);transform:translateY(-1px)}.rooms-selector{display:flex;gap:8px;justify-content:space-between;padding:8px 0}.room-btn{width:40px;height:40px;border:1px solid var(--border);border-radius:0px;background:var(--bg-panel);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all ease .5s}.room-btn:hover{border-color:var(--accent);color:var(--accent)}.room-btn.selected{background:var(--accent);color:var(--surface-white);border-color:var(--accent)}.tags-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;max-height:-webkit-fill-available;overflow-y:auto}.tag-option{padding:6px 10px;border:1px solid var(--border);border-radius:0px;font-size:16px;cursor:pointer;text-align:center;transition:all ease .5s}.tag-option:hover{border-color:var(--accent);color:var(--accent)}.tag-option.selected{background:var(--accent);color:var(--text-secondary);border-color:var(--accent)}.map{width:100%;flex:1;min-height:0;z-index:1}.bottom-panels{display:flex;gap:16px;height:fit-content;min-height:260px;flex-shrink:0;max-height:25vh}.avatar-panel,.cta-panel{background:#eff1f5;border:1px solid var(--border);border-radius:0px;height:100%;min-height:180px;display:flex;place-items:center;max-width:23vw;transition:all ease .5s;overflow:hidden}.avatar-panel{position:relative}.avatar-panel img,.avatar-panel canvas{width:100%;height:100%;object-fit:cover;object-position:top;background:var(--bg-base);max-height:-webkit-fill-available;border-radius:0px;min-height:320px;height:30vh;max-height:unset;height:150% !important;object-position:top;margin-top:50%;cursor:pointer}.avatar-preview-canvas{opacity:0;transition:opacity 1s ease}.avatar-preview-canvas.ready{opacity:1}.avatar-preview-loader{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:200px;background:var(--bg-tertiary);border-radius:0px;padding:10px}.avatar-preview-tts-spinner{position:absolute;inset:0;display:none;align-items:center;justify-content:center;z-index:3;pointer-events:none}.avatar-preview-tts-spinner-icon{width:30px;height:30px;border:2px solid var(--accent-dim);border-radius:50%;border-top-color:var(--accent);animation:spin 1s ease-in-out infinite;position:absolute;top:20px;right:20px}.avatar-loader-spinner{font-size:32px;color:var(--primary,#2563eb)}.avatar-title{color:var(--muted);font-weight:700}.cta-placeholder{color:var(--muted)}@media (max-width:1024px){.cockpit{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.page{height:auto;overflow:auto}html,body{height:auto;overflow:auto}.list-panel{height:50vh}.right-column{height:auto}.map-panel{height:50vh;min-height:50vh;flex:0 0 auto;/* Disable flex grow/shrink on mobile */}.bottom-panels{grid-template-columns:1fr}.detail-grid{grid-template-columns:1fr}}.detail-grid{display:grid;grid-template-columns:max(430px,30vw) 1fr;gap:16px;height:100%}.detail-left{background:var(--bg-primary);border:1px solid var(--border);border-radius:0px;display:flex;flex-direction:column;flex:1;overflow:hidden}.detail-header{padding:32px;border-bottom:1px solid var(--border);padding-bottom:40px;background:transparent;flex-shrink:0}.detail-header .detail-meta{color:var(--accent);font-size:17px;letter-spacing:.5px;padding:20px 0;font-family:var(--font-sans)}.detail-title{margin:0 0 8px 0;margin-top:38px;margin-bottom:0;font-weight:600;font-size:30px;color:var(--text-primary);font-family:var(--font-sans-4)}.detail-scroll-content{overflow-y:auto;flex:1;padding-bottom:20px}.detail-box{padding:12px 16px;padding-top:32px;display:grid;gap:8px}.feature-row{display:grid;grid-template-columns:160px 1fr;gap:12px;padding:25px 25px}.feature-row:last-child{border-bottom:none}.feature-name{color:var(--text-primary);font-weight:300;display:flex;align-items:center;gap:5px;font-family:var(--font-sans-2);letter-spacing:1px}.feature-name i{font-size:10px}.nd-accordion{border:1px solid var(--border);border-radius:8px;overflow:hidden;width:100%}.nd-accordion--unstyled{border:none;background:transparent}.nd-accordion__item{border-bottom:1px solid var(--border)}.nd-accordion__item:last-child{border-bottom:none}.nd-accordion__title{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;font-weight:600;user-select:none;transition:background 0.2s}.nd-accordion__title:hover{background:var(--bg-secondary)}.nd-accordion__title.is-selected{background:var(--accent-dim)}.nd-accordion__icon{width:16px;height:16px;fill:var(--text);transition:transform 0.3s ease}.nd-accordion__item.is-open .nd-accordion__icon{transform:rotate(180deg)}.nd-accordion__content{display:none;padding:0;padding-top:10px;padding-bottom:10px;background:transparent;border-top:1px solid var(--border)}.nd-accordion__item.is-open .nd-accordion__content{display:block;animation:slideDown 0.2s ease-out}@keyframes slideDown{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.nd-stack{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.nd-radio,.nd-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:16px;color:var(--text-main)}.modal-window.wide{max-width:800px}.contacts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.contact-card{background:var(--bg-primary);border:1px solid var(--border);border-radius:0px;padding:16px;display:flex;flex-direction:column;gap:12px;transition:transform 0.2s,box-shadow 0.2s}.contact-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.05)}.agent-card{display:flex;flex-direction:row;align-items:flex-start;gap:16px;text-align:left}.agent-avatar{flex-shrink:0;width:80px;height:80px}.agent-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:0;display:block}.agent-info{display:flex;flex-direction:column;flex:1}.agent-info h3{margin:0;font-size:18px;color:var(--text)}.agent-info .role{font-size:13px;color:var(--primary);font-weight:600;margin-bottom:8px;display:block}.agent-contacts{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;align-items:flex-start}.agent-contacts a{font-size:13px;color:var(--muted);text-decoration:none;display:flex;align-items:center;gap:6px}.agent-contacts a:hover{color:var(--primary)}.office-card{display:flex;flex-direction:row;align-items:flex-start;gap:16px}.office-icon{background:var(--bg-dark);color:var(--primary);width:48px;height:48px;border-radius:00;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.office-info h3{margin:0 0 4px 0;font-size:16px}.office-info .address{font-size:13px;color:var(--muted);margin-bottom:12px;display:block}.office-contacts .contact-row{font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px;margin-bottom:4px}.map-card{padding:0;overflow:hidden;height:33vh;min-height:250px;position:relative}.map-embed{width:100%;height:100%}.map-overlay-label{position:absolute;bottom:10px;left:10px;background:var(--bg-primary);padding:4px 8px;border-radius:0;font-size:11px;font-weight:700;box-shadow:0 2px 4px rgba(0,0,0,0.2);font-weight:500}.about-cta-btn{display:block;width:100%;margin-top:20px;padding:10px 14px;border-radius:0px;text-decoration:none;font-weight:600;background:var(--text-primary);color:var(--text-secondary);border:1px solid var(--text-primary);transition:all ease .5s;letter-spacing:2px;text-transform:lowercase;font-weight:400;cursor:pointer}.hours-display{margin-top:8px}.hours-status-row{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:wrap}.hours-badge{display:inline-block;padding:2px 9px;border-radius:0px;font-size:11px;font-weight:700;letter-spacing:0.03em;text-transform:uppercase}.hours-badge.open{background:rgba(34,197,94,0.15);color:#16a34a}.hours-badge.closed{background:rgba(239,68,68,0.1);color:#dc2626}.hours-status-detail{font-size:12px;color:var(--text-muted,#888)}.hours-toggle-btn{background:none;border:none;padding:0;font-size:12px;color:var(--accent,#4a90d9);cursor:pointer;display:inline-flex;align-items:center;gap:5px;margin-bottom:4px}.hours-toggle-btn:hover{text-decoration:underline}.hours-schedule{display:flex;flex-direction:column;gap:4px;margin-top:4px}.hours-schedule.collapsed{display:none}.hours-row{display:flex;justify-content:space-between;font-size:13px;gap:12px}.hours-row.today .hours-day,.hours-row.today .hours-time{font-weight:700;color:var(--text-main,#333)}.hours-day{color:var(--text-muted,#666);min-width:80px}.hours-time{text-align:right}.hours-closed{color:var(--text-muted,#999);font-style:italic}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-overlay);z-index:20000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);will-change:blur}.modal-overlay.hidden{display:none}.modal-window{background:var(--bg-primary);border-radius:0px;padding:32px;width:90%;max-width:960px;height:fit-content;position:relative;box-shadow:0 10px 25px rgba(0,0,0,0.2);animation:modalSlideIn 0.3s ease-out;overflow:hidden;font-weight:400}.modal-window h1{font-weight:500;letter-spacing:1px;font-size:21px}.modal-window h2{font-weight:400;letter-spacing:1px;font-size:18px}@keyframes modalSlideIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:24px;cursor:pointer;color:var(--muted)}.modal-body{margin-top:16px;display:flex;flex-direction:column;gap:16px;max-height:calc(100vh - 120px);overflow-y:auto;letter-spacing:.5px}.contact-info{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.contact-item{display:flex;align-items:center;gap:12px;color:var(--text)}.contact-item i{color:var(--primary);width:20px;text-align:center}.contact-form{display:flex;flex-direction:column;gap:12px;padding-top:16px;border-top:1px solid var(--border)}.contact-form input,.contact-form textarea{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px}.nd-radio__element,.nd-checkbox__element{accent-color:var(--primary);width:18px;height:18px;cursor:pointer;margin:0}.nd-radio__text,.nd-checkbox__text{user-select:none}.nd-dropdown__contentScrollable{max-height:600px;overflow-y:auto;text-transform:lowercase}.feature-name i{color:var(--muted);width:20px;text-align:center}.feature-val{font-weight:500;letter-spacing:1px}.detail-price-box{background:var(--bg-secondary);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px;display:flex;justify-content:space-between;align-items:center;margin-top:16px}.price-value{font-size:24px;font-weight:800}.detail-description{padding:16px;line-height:1.6;color:var(--text-primary);text-align:justify;font-size:14px;letter-spacing:.5px}.detail-description p{font-size:17px;line-height:1.75;color:var(--text-primary);margin:0 0 12px;text-align:justify;font-family:var(--font-sans-2);letter-spacing:.33px}.detail-description h3{margin-top:0;font-size:14px;margin-bottom:10px;color:var(--text-primary);font-weight:600;text-transform:lowercase}.detail-right{background:var(--bg-primary);border:1px solid var(--border);border-radius:0px;display:flex;flex-direction:column;overflow:hidden;flex:1 1 auto;min-height:0;max-height:calc(100% - 220px);/* Leave space for bottom-panels */}.gallery-tabs{display:flex;gap:8px;padding:14px;border-bottom:none;background:var(--surface-charcoal)}.gallery-tabs .pill{background-color:var(--surface-charcoal);color:rgba(255,255,255,0.55);border-color:rgba(255,255,255,0.18)}.gallery-tabs .pill.active{background-color:#ffffff;color:#111111;border-color:#ffffff}.gallery-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.main-image-area{flex:1;background:var(--text-primary);display:block;place-items:center;overflow:hidden;position:relative;transition:opacity 0.22s ease;user-select:none;-webkit-user-select:none}.main-image-area.content-mode{background:transparent;display:block}.main-image-area img{display:block;max-width:100%;max-height:100%;object-fit:contain;cursor:grab;height:-webkit-fill-available;width:100%}.main-image-area iframe{width:100%;height:100%;min-height:232px;border:none}/* ── Gallery Strip:3-slot persistent DOM,3D cover-flow ── */ .gallery-strip-wrapper{width:100%;height:100%;position:relative;overflow:hidden;background:var(--bg-gallery)}.gallery-strip-track{width:100%;height:100%;position:relative}.strip-slot{position:absolute;top:0;height:100%;overflow:hidden;will-change:width,left,transform,opacity,filter;user-select:none;-webkit-user-select:none;transition:width 0.32s cubic-bezier(0.4,0,0.2,1),left 0.32s cubic-bezier(0.4,0,0.2,1),transform 0.32s cubic-bezier(0.4,0,0.2,1),opacity 0.28s ease,filter 0.28s ease,box-shadow 0.32s ease}.strip-slot img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;transition:transform 0.55s cubic-bezier(0.4,0,0.2,1);will-change:transform}/* ─ Center (active) slot ─ */ .strip-slot.strip-active{width:58%;left:21%;transform:perspective(900px) rotateY(0deg) rotateX(0deg);opacity:1;z-index:3;cursor:pointer;box-shadow:0 12px 50px rgba(0,0,0,0.6),0 4px 18px rgba(0,0,0,0.4);filter:brightness(1) saturate(1.05)}.strip-slot.strip-active:hover img{transform:scale(1.022)}/* ─ Left side slot ─ */ .strip-slot.strip-side-left{width:20%;left:0.5%;transform:perspective(900px) rotateY(18deg) scale(0.93);opacity:0.5;z-index:1;cursor:pointer;filter:brightness(0.55) saturate(0.55)}.strip-slot.strip-side-left:hover{opacity:0.72;filter:brightness(0.73) saturate(0.76)}/* ─ Right side slot ─ */ .strip-slot.strip-side-right{width:20%;left:79.5%;transform:perspective(900px) rotateY(-18deg) scale(0.93);opacity:0.5;z-index:1;cursor:pointer;filter:brightness(0.55) saturate(0.55)}.strip-slot.strip-side-right:hover{opacity:0.72;filter:brightness(0.73) saturate(0.76)}/* ─ Exit states ─ */ .strip-slot.strip-exit-left{width:0%;left:-5%;transform:perspective(900px) rotateY(28deg) scale(0.7) translateZ(-60px);opacity:0;z-index:0;pointer-events:none;filter:brightness(0.15) saturate(0)}.strip-slot.strip-exit-right{width:0%;left:105%;transform:perspective(900px) rotateY(-28deg) scale(0.7) translateZ(-60px);opacity:0;z-index:0;pointer-events:none;filter:brightness(0.15) saturate(0)}/* ─ Enter positions (instant snap — no transition) ─ */ .strip-slot.strip-enter-left{width:0%;left:-5%;transform:perspective(900px) rotateY(28deg) scale(0.7) translateZ(-60px);opacity:0;z-index:0;pointer-events:none;filter:brightness(0.15) saturate(0);transition:none !important}.strip-slot.strip-enter-right{width:0%;left:105%;transform:perspective(900px) rotateY(-28deg) scale(0.7) translateZ(-60px);opacity:0;z-index:0;pointer-events:none;filter:brightness(0.15) saturate(0);transition:none !important}.no-images{color:var(--text-main);height:100%;display:flex;flex-direction:column;justify-content:center;min-height:100px}.thumbs-scroll-container{height:82px;background:var(--bg-gallery);border-top:1px solid rgba(255,255,255,0.05);overflow-x:auto;overflow-y:hidden;padding:7px 10px;scroll-behavior:smooth;cursor:grab;scrollbar-width:thin;scrollbar-color:rgba(160,120,80,0.38) transparent}.thumbs-scroll-container::-webkit-scrollbar{height:3px}.thumbs-scroll-container::-webkit-scrollbar-track{background:transparent}.thumbs-scroll-container::-webkit-scrollbar-thumb{background:rgba(160,120,80,0.45);border-radius:2px}.thumbs-scroll-container.active{cursor:grabbing;user-select:none}.thumbs-track{display:inline-flex;gap:5px;height:100%}.thumbs-track:empty{display:none}.thumb-item{width:94px;height:100%;border-radius:1px;overflow:hidden;opacity:0.4;cursor:pointer;flex-shrink:0;border:2px solid transparent;transition:opacity 0.24s ease,transform 0.28s cubic-bezier(0.34,1.56,0.64,1),border-color 0.24s ease,box-shadow 0.24s ease}.thumb-item:hover:not(.active){opacity:0.68;transform:translateY(-2px) scale(1.04)}.thumb-item.active{opacity:1;transform:translateY(-3px) scale(1.07);border-color:var(--accent,#a07850);box-shadow:0 4px 14px rgba(160,120,80,0.5)}.thumb-item img{width:100%;height:100%;object-fit:cover;pointer-events:none}.chat-panel{background:var(--bg-panel);border:1px solid var(--border);border-radius:0px;display:flex;flex-direction:column;overflow:hidden;width:-webkit-fill-available}.chat-header{padding:12px 16px;border-bottom:1px solid var(--border);font-weight:700;color:var(--muted);font-size:13px}.quick-qa{padding:16px;display:flex;flex-wrap:wrap;gap:8px;border-bottom:1px solid var(--border)}.qa-answer{padding:16px;flex:1;font-style:italic;color:var(--text-muted);background:var(--bg-secondary);display:none}.fullscreen-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-gallery);z-index:9999;display:flex;flex-direction:column;animation:fadeIn 0.35s ease}.fullscreen-modal.hidden{display:none}/* Topbar:counter + close */ .modal-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,0.15)}.modal-counter{color:rgba(255,255,255,0.75);font-size:14px;font-weight:300;letter-spacing:6px;font-variant-numeric:tabular-nums}.close-modal{background:rgba(255,255,255,0.1);border:none;color:var(--text-secondary);font-size:16px;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.2s;z-index:10001;background:transparent;font-weight:100}.close-modal:hover{background:transparent}/* Area immagine principale */ .modal-content{flex:1;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;min-height:0}.modal-content img{max-width:92%;max-height:100%;object-fit:contain;border-radius:4px;will-change:opacity,transform}/* Pulsanti nav nel modal */ .nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-secondary);font-size:18px;width:46px;height:46px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:50%;transition:background 0.2s,transform 0.2s;z-index:10}.nav-btn:hover{background:transparent}.nav-btn.prev{left:16px}.nav-btn.next{right:16px}/* Thumbnail strip nel modal */ .modal-thumbs{flex-shrink:0;height:88px;display:flex;gap:8px;padding:10px 16px;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.2) transparent;justify-content:flex-start;align-items:center;border-top:1px solid rgba(255,255,255,0.15)}.detail-features-pills{display:flex;flex-wrap:wrap;gap:16px;padding:50px}.feature-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:0;background:var(--bg-panel);color:var(--accent);font-size:13px;font-weight:500;border:solid 1px var(--text-primary);transition:background 0.2s;text-transform:lowercase;letter-spacing:.3px}.feature-pill i{font-size:12px;color:var(--accent,#60a5fa)}.price-info-box{background:transparent;border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:50px;margin-top:32px;margin-bottom:20px}.price-info-header{font-size:14px;margin-bottom:10px;color:var(--text-primary);font-weight:600;text-transform:lowercase}.price-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.price-info-item{display:flex;flex-direction:column;gap:4px;letter-spacing:2px}.price-info-label{font-size:13px;font-weight:500;display:flex;align-items:center;text-transform:lowercase;gap:6px;letter-spacing:2px;font-family:var(--font-sans-2)}.price-info-value{font-size:14px;color:var(--muted)}.mortgage-container{padding:32px;height:100%;overflow-y:auto;background:transparent;display:flex;flex-direction:column;gap:24px;width:-webkit-fill-available;padding-left:15px;padding-right:15px;padding-bottom:0;padding-top:20px}.mortgage-header{font-size:20px;font-weight:400;margin-bottom:8px;color:var(--text-primary);letter-spacing:1px;text-transform:lowercase}.mortgage-grid{display:grid;grid-template-columns:1fr;gap:20px}/* ── Gallery Navigation Arrows ── */ .gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(18,15,12,0.42);backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);color:rgba(255,255,255,0.88);border:1px solid rgba(255,255,255,0.13);font-size:13px;height:42px;width:42px;padding:0;cursor:pointer;z-index:20;transition:background 0.22s ease,transform 0.22s cubic-bezier(0.4,0,0.2,1),opacity 0.22s ease,border-color 0.22s ease;border-radius:0;display:flex;justify-content:center;align-items:center;opacity:0}.main-image-area:hover .gallery-nav{opacity:1}.gallery-nav:hover{background:rgba(255,255,255,0.14);border-color:rgba(255,255,255,0.26);transform:translateY(-50%) scale(1.1)}.gallery-nav:active{transform:translateY(-50%) scale(0.92)}/* Positioned inside the center slot boundaries */ .gallery-nav.prev{left:calc(21% + 14px)}.gallery-nav.next{right:calc(21% + 14px)}@media (hover:none),(max-width:768px){.gallery-nav{opacity:1}/* always visible on touch / mobile */}@media (max-width:768px){/* On mobile there's no 3-slot strip — arrows sit at the edges */ .gallery-nav.prev{left:12px}.gallery-nav.next{right:12px}}.mortgage-input-group{display:flex;flex-direction:column;gap:8px}.mortgage-input-group label{font-size:13px;font-weight:400;color:var(--text-primary);letter-spacing:.5px;text-transform:lowercase;font-family:var(--font-sans-2)}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper input,.input-wrapper select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:0;font-size:16px;transition:border-color 0.2s;padding-right:33px;background:var(--bg-panel);color:var(--text-primary)}.input-wrapper input:focus,.input-wrapper select:focus{border-color:var(--accent);outline:none}.input-wrapper .suffix{position:absolute;right:16px;color:var(--text-muted);pointer-events:none;font-weight:600}.mortgage-result{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px;background:transparent;border-radius:0;border:1px solid var(--border)}@media (min-width:900px){.mortgage-container{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto 1fr;gap:20px;align-items:start;padding:20px}.mortgage-header{grid-column:1 / -1;margin-bottom:0}.mortgage-grid{display:flex;flex-direction:column;justify-content:center;gap:24px;height:100%}.mortgage-result{height:100%;justify-content:center;margin-top:0}}.donut-chart{position:relative;width:160px;height:160px;border-radius:50%;background:conic-gradient(var(--primary) 0% 70%,#e5e7eb 70% 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,0.05)}.donut-inner{width:120px;height:120px;background:var(--bg-primary);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.monthly-payment{font-size:24px;font-weight:400;color:var(--text-primary);line-height:1}.payment-label{font-size:12px;color:var(--muted);margin-top:4px;font-weight:600}.result-details{display:flex;flex-direction:column;gap:16px;width:100%}.result-row{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px dashed var(--border);gap:10px}.result-row:last-child{border-bottom:none}.result-row label{font-size:13px;color:var(--text-primary);font-weight:500;letter-spacing:.5px;text-transform:lowercase;font-family:var(--font-sans-2)}.result-row span{font-weight:400;font-size:16px;color:var(--text-primary);letter-spacing:1px;white-space:nowrap}.avatar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,var(--bg-tertiary) 0%,var(--bg-dark) 100%);z-index:10000;display:flex;flex-direction:column;opacity:1;visibility:visible;transition:opacity 1s ease,visibility 1s ease}.avatar-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.overlay-header{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border);height:64px}.overlay-brand img{height:60px;width:auto;max-width:100%;object-fit:contain}.overlay-close{padding:10px 14px;border-radius:0px;text-decoration:none;font-weight:600;background:transparent;color:var(--text-primary);border:solid 1px var(--text-primary);transition:all ease .3s;cursor:pointer}.overlay-close:hover{background:transparent;color:var(--accent);border-color:var(--accent)}.overlay-content{flex:1;display:flex;padding:0;gap:0;overflow:hidden;background:#eff1f5}.avatar-full-box{flex:1;background:transparent;display:flex;align-items:center;justify-content:center;transition:flex 0.8s cubic-bezier(0.22,1,0.36,1);overflow:hidden}.avatar-full-box img,.avatar-full-box canvas{height:100%;width:100%;object-fit:cover;object-position:bottom;vertical-align:bottom;margin-top:30%}.onboarding-box{flex:1;background:transparent;display:flex;align-items:center;justify-content:center;transition:flex 0.8s cubic-bezier(0.22,1,0.36,1),opacity 0.4s ease,margin 0.8s cubic-bezier(0.22,1,0.36,1);overflow:hidden;opacity:1}.onboarding-box.collapsed{flex:0;opacity:0;margin:0;padding:0;pointer-events:none}.box-content{text-align:center;height:-webkit-fill-available;display:flex;flex-direction:column;align-items:center}.box-content h2{font-size:24px;font-weight:800;margin-bottom:20px;text-transform:lowercase}.btn-termina{margin-top:20px;padding:12px 30px;font-size:16px;cursor:pointer;background:var(--text-primary);color:var(--bg-panel);border:none;font-weight:bold;text-transform:uppercase;transition:transform 0.2s,background 0.2s}.btn-termina:hover{background:var(--color-dark);transform:scale(1.05)}.leaflet-control-zoom{border:none !important;box-shadow:none !important}.leaflet-control-zoom a{border-radius:0 !important;width:40px !important;height:40px !important;line-height:40px !important;color:var(--text-main) !important;background-color:var(--warm-glass) !important;border:none !important;box-shadow:0 2px 12px rgba(0,0,0,0.1),0 0 0 1px rgba(160,120,80,0.18) !important;margin-bottom:3px !important;display:flex !important;align-items:center;justify-content:center;font-size:20px !important;font-weight:300 !important;transition:all 0.2s ease;text-decoration:none !important;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.leaflet-control-zoom a:hover{background-color:var(--accent) !important;color:var(--text-secondary) !important;border-color:var(--accent) !important;box-shadow:0 4px 16px rgba(160,120,80,0.3) !important}.leaflet-touch .leaflet-control-zoom a:first-child{border-radius:0 !important;background:var(--warm-glass) !important;color:var(--text-main) !important;border-bottom:1px solid rgba(160,120,80,0.15) !important}.leaflet-touch .leaflet-control-zoom a:last-child{border-radius:0 !important;background:var(--warm-glass) !important;color:var(--text-main) !important}/* Legal Pages Layout */ .legal-page{padding-top:40px;padding-bottom:40px;height:auto;/* Fix scrolling issue by removing fixed height */ overflow:visible;/* Allow content to flow naturally */ max-height:-webkit-fill-available;overflow-y:auto}.legal-container{max-width:1200px;margin:0 auto;padding:0 20px;display:grid;grid-template-columns:280px 1fr;gap:40px;align-items:start;/* Ensure sidebar aligns to top */}/* Legal Sidebar */ .legal-sidebar{position:sticky;top:100px;height:fit-content;max-height:calc(100vh - 240px);/* Prevent sidebar from overflowing viewport */ overflow-y:auto;/* Allow internal scrolling if sidebar is too long */ background:var(--bg-panel);/* Use defined var */ border-radius:0px;padding:24px;border:1px solid var(--border);min-height:calc(100vh - 215px)}.legal-nav-title{font-size:14px;text-transform:uppercase;letter-spacing:0.05em;color:var(--text-main);margin-bottom:16px;font-weight:600}.legal-nav ul{list-style:none;padding:0;margin:0}.legal-nav li{margin-bottom:8px}.legal-nav a{display:block;padding:8px 12px;color:var(--text-primary);text-decoration:none;border-radius:6px;font-size:14px;transition:all 0.2s ease}.legal-nav a:hover{background-color:var(--surface-hover);color:var(--primary)}.legal-nav a.active{color:var(--accent);font-weight:500}/* Legal Content */ .legal-content-wrapper{background:var(--bg-panel);border-radius:0px;padding:40px;border:1px solid var(--border);min-height:600px;max-height:calc(100vh - 215px);overflow-y:auto}.legal-header{margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--border)}.legal-header h1{font-size:32px;font-weight:700;color:var(--accent);margin-bottom:8px;margin-top:0}.legal-header .subtitle{color:var(--text-muted);font-size:16px}.legal-header .last-updated{color:var(--text-muted);font-size:14px;margin-top:12px;font-style:italic}.legal-chapter{margin-bottom:40px;scroll-margin-top:100px;/* Offset for sticky header */}.legal-chapter h2{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.legal-chapter .chapter-content{color:var(--text-primary);line-height:1.6;font-size:15px}.legal-chapter .chapter-content table{background:var(--bg-secondary);padding:10px;overflow-x:auto;width:100%;max-width:-webkit-fill-available;position:relative;display:block;border-radius:0px}.legal-chapter .chapter-content table td{padding:10px}.legal-chapter .chapter-content p{margin-bottom:16px}/* ===== GDPR COOKIE POPUP STYLES ===== */ .gdpr-popup,.cookie-consent-banner{position:fixed;bottom:0;right:10px;background:var(--bg-secondary);border:solid 1px var(--border);border-radius:0;box-shadow:0 4px 20px rgba(0,0,0,0.15);z-index:10000;transform:translateY(100%);transition:transform 0.3s ease;max-width:480px;max-height:450px;overflow:hidden;display:flex;flex-direction:column}.gdpr-popup.show,.cookie-consent-banner.show{transform:translateY(0);bottom:10px}.gdpr-popup-content{padding:20px 20px 0 20px;flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.gdpr-popup-content::-webkit-scrollbar{width:6px}.gdpr-popup-content::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:3px}.gdpr-popup-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.gdpr-popup-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.gdpr-popup h3{font-size:18px;font-weight:500;margin-bottom:12px;color:var(--text-primary);margin-top:0;text-transform:lowercase}.gdpr-popup p{font-size:11px;line-height:1.5;color:var(--text-primary);margin-bottom:15px;letter-spacing:.5px}.cookie-preferences{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.cookie-option{border:none;border-radius:0;padding:12px;background:transparent;border:solid 1px var(--border)}.cookie-option label{display:flex;align-items:center;font-weight:600;font-size:11px;color:var(--text-primary);margin-bottom:6px;cursor:pointer}.cookie-option input[type="checkbox"]{margin-right:8px;width:16px;height:16px;accent-color:var(--brand-signature-blue)}.cookie-option input[type="checkbox"]:disabled{opacity:0.6}.cookie-description{font-size:11px;color:var(--text-muted);line-height:1.4;margin:0}.gdpr-popup-buttons{position:sticky;bottom:0;background:var(--bg-secondary);padding:15px 20px;display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:0;padding-right:0;padding-left:0}.gdpr-popup-buttons .btn{padding:8px 16px;border-radius:0;font-weight:400;font-size:12px;cursor:pointer;transition:all 0.2s ease;border:1px solid transparent;text-decoration:none;display:inline-block;flex:1;text-align:center;min-width:80px;letter-spacing:0.5px}.gdpr-popup-buttons .btn.primary{background:var(--accent);color:var(--text-secondary);border-color:var(--accent)}.gdpr-popup-buttons .btn.primary:hover{background:var(--bg-secondary);border-color:var(--text-primary);color:var(--text-primary)}.gdpr-popup-buttons .btn:not(.primary):not(.secondary){background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border)}.gdpr-popup-buttons .btn:not(.primary):not(.secondary):hover{background:var(--bg-dark);border-color:var(--border)}.gdpr-popup-buttons .btn.secondary{background:transparent;color:var(--text-muted);border-color:var(--border)}.gdpr-popup-buttons .btn.secondary:hover{background:var(--bg-secondary);color:var(--accent)}.gdpr-popup-footer{text-align:center;padding:10px 20px 15px 20px;background:transparent;border-top:solid 1px var(--border)}.gdpr-popup-footer a{color:var(--accent);text-decoration:none;font-size:11px;margin:0 8px}.gdpr-popup-footer a:hover{text-decoration:underline}/* Mobile responsive */ @media (max-width:1024px){.gdpr-popup{bottom:0;right:10px;left:10px;max-width:none}.gdpr-popup-content{padding:15px;max-height:50vh;padding-bottom:0}.gdpr-popup-buttons{flex-direction:column;align-items:stretch;padding-right:0;padding-left:0}.gdpr-popup-buttons .btn{text-align:center;margin-bottom:5px}.gdpr-popup h3{font-size:16px}.gdpr-popup p{font-size:13px}}@media (max-width:900px){.legal-container{grid-template-columns:1fr}.legal-sidebar{position:static;margin-bottom:24px}}