
/* CITY REVEAL V1449 — consolidated responsive and accessibility layer */
:root { --header-safe: 96px; }
html { scroll-padding-top: var(--header-safe); }
body { overflow-x: clip; }
img { height: auto; }
.header .brand img { width: auto; height: 58px; }
.hero { padding-top: 50px; }
.hero-grid { align-items: center; }
.hero-copy { max-width: 660px; }
.hero-copy .lead { max-width: 640px; font-size: clamp(17px, 1.45vw, 20px); line-height: 1.65; }
.hero-actions { margin-top: 24px; }
.hero-video-shell { position:relative; isolation:isolate; overflow:hidden !important; border-radius:28px !important; background:#020617 !important; box-shadow:0 24px 72px rgba(0,0,0,.42) !important; }
.hero-video-shell video { border-radius:0 !important; }
.hero-video-control { position:absolute; inset:auto 18px 18px 18px; z-index:3; display:inline-flex; align-items:center; justify-content:center; gap:10px; min-height:46px; padding:10px 18px; border:1px solid rgba(255,219,145,.38); border-radius:999px; background:rgba(7,17,31,.88); color:#fff; font:inherit; font-size:13px; cursor:pointer; backdrop-filter:blur(14px); box-shadow:0 12px 30px rgba(0,0,0,.34); }
.hero-video-control span { display:grid; place-items:center; width:28px; height:28px; border-radius:999px; background:linear-gradient(135deg,#d29a2e,#f0c76f); color:#08101e; font-weight:900; }
.hero-video-control.is-playing { opacity:.82; }
.hero-video-control:focus-visible { outline:2px solid #9fd8ff; outline-offset:3px; }

/* Globe controls: clear, touch-friendly layout. */
.world-globe-toolbar-left { min-width:min(620px, 100%); }
#worldGlobeGpsBtn { min-height:48px; }
#worldGlobeSearchInput { min-height:48px; }

/* Reduce long card walls while preserving all content on demand. */
.v1449-extra-card { display:none !important; }
.v1449-expanded .v1449-extra-card { display:block !important; }
.v1449-section-actions { display:flex; justify-content:center; gap:12px; flex-wrap:wrap; margin-top:22px; }
.v1449-section-actions .btn { min-width:220px; }
.site-final-block { scroll-margin-top:calc(var(--header-safe) + 18px); }
.site-final-card { min-height:100%; }
.site-final-lead { max-width:920px; }

/* Footer: usable contacts and privacy route. */
.site-public-footer a { text-decoration:none; }
.site-public-footer a:focus-visible { outline:2px solid #9fd8ff; outline-offset:3px; }

/* Partner page hierarchy */
.partner-page-main h1 { margin:0; font-size:clamp(38px, 5vw, 62px); line-height:1.05; letter-spacing:-.035em; }
.site-final-contact-top { align-items:flex-start; }
.site-final-contact-actions { align-content:flex-start; }
.partner-request-panel { margin:28px 0 32px; border-color:rgba(245,158,11,.26); box-shadow:0 24px 70px rgba(0,0,0,.28); }
.partner-request-head h3 { font-size:clamp(28px, 3vw, 38px); }
.partner-consent a { color:#fde68a; text-decoration:underline; text-underline-offset:3px; }
.partner-field input, .partner-field select, .partner-field textarea { transition:border-color .18s, box-shadow .18s, background .18s; }
.partner-field input:focus, .partner-field select:focus, .partner-field textarea:focus { outline:none; border-color:rgba(159,216,255,.65); box-shadow:0 0 0 3px rgba(95,145,255,.14); }
.partner-field.has-error input, .partner-field.has-error select, .partner-field.has-error textarea, .partner-consent.has-error { border-color:#fb7185 !important; box-shadow:0 0 0 3px rgba(251,113,133,.12) !important; }
.partner-field.has-error::after { content:'Controlla questo campo.'; display:block; margin-top:6px; color:#fecdd3; font-size:12px; font-weight:700; }
.partner-form-status:not(:empty) { margin-top:14px; padding:12px 14px; border-radius:14px; background:rgba(159,216,255,.08); border:1px solid rgba(159,216,255,.16); color:#dbeafe; }
.partner-request-actions button[disabled] { cursor:wait; opacity:.72; transform:none; }
.partner-category-toggle { display:none; }
.partner-category-title { font-weight:800; }

/* Light mode parity for new components. */
body.outdoor-mode 
body.outdoor-mode .hero-video-control { background:rgba(255,255,255,.92); color:#09111f; }
body.outdoor-mode .partner-form-status:not(:empty) { background:#eff6ff; color:#1e3a8a; border-color:#bfdbfe; }
body.outdoor-mode .partner-field.has-error::after { color:#be123c; }

@media (min-width: 901px) {
  .site-final-grid.features { grid-template-columns:repeat(4,minmax(0,1fr)); }
  .site-final-contact-grid { grid-template-columns:repeat(4,minmax(0,1fr)); }
}

@media (max-width: 1100px) {
  :root { --header-safe: 132px; }
  .hero-grid { grid-template-columns:minmax(0,1fr) minmax(340px,.9fr); gap:26px; }
}

@media (max-width: 900px) {
  :root { --header-safe: 88px; }
  .hero { padding:30px 0 16px; }
  .hero-grid { display:flex !important; flex-direction:column; gap:24px; }
  .hero-copy { order:1; max-width:none; width:100%; }
  .hero-video-card { order:2 !important; width:100%; }
  .hero-video-shell { width:min(100%, 680px) !important; margin:0 auto; aspect-ratio:4 / 3 !important; max-height:none !important; }
  .hero-video-shell video { width:100%; height:100%; object-fit:cover; object-position:center; }
  .world-globe-toolbar { align-items:stretch; }
  .world-globe-toolbar-left, .world-globe-toolbar-right { width:100%; min-width:0; }
  .world-globe-toolbar-left { display:grid !important; grid-template-columns:1fr; gap:10px; }
  #worldGlobeGpsBtn, #worldGlobeSearchInput { width:100% !important; min-width:0 !important; }
  .site-final-grid.features { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .site-final-contact-top { grid-template-columns:1fr !important; }
  .site-final-contact-actions { display:grid !important; grid-template-columns:1fr 1fr; width:100%; }
  .site-final-contact-actions .btn { width:100%; }
}

@media (max-width: 640px) {
  :root { --header-safe: 82px; }
  .wrap { padding-left:18px; padding-right:18px; }
  .header .brand img { height:46px; }
  .hero { padding-top:24px; }
  .hero h1 { font-size:clamp(38px, 11.5vw, 52px); line-height:1.01; }
  .hero-copy .lead { font-size:17px; line-height:1.58; margin-top:18px; }
  .hero-actions { display:grid; grid-template-columns:1fr; gap:10px; }
  .hero-actions .btn { width:100%; min-height:50px; }
  
.hero-video-shell { aspect-ratio:4 / 5 !important; width:min(100%, 430px) !important; }
  .hero-video-control { left:12px; right:12px; bottom:12px; min-height:44px; }
  .section { padding-top:28px; padding-bottom:28px; }
  .world-globe-map { min-height:460px !important; height:68svh !important; max-height:620px; }
  .site-final-grid.features { grid-template-columns:1fr; }
  .site-final-title { font-size:clamp(30px, 9vw, 40px); }
  .site-final-lead { font-size:16px; line-height:1.66; }
  .site-final-card { padding:20px; }
  .v1449-section-actions { display:grid; grid-template-columns:1fr; }
  .v1449-section-actions .btn { width:100%; min-width:0; }
  .site-final-contact-actions { grid-template-columns:1fr; }
  .partner-request-panel { padding:20px 16px; margin-top:22px; }
  .partner-request-grid { grid-template-columns:1fr !important; }
  .partner-request-actions { display:grid !important; grid-template-columns:1fr; }
  .partner-request-actions .btn { width:100%; }
  .site-final-contact-grid { grid-template-columns:1fr !important; }

  /* Mobile categories become compact, explicit accordions. */
  .partner-category-card { display:grid !important; grid-template-columns:46px minmax(0,1fr); gap:12px !important; align-items:start; }
  .partner-category-card > .icon { margin:0 !important; }
  .partner-category-card .partner-category-title { padding-right:4px; font-size:17px; }
  .partner-category-toggle { display:flex; align-items:center; justify-content:space-between; gap:12px; width:100%; margin-top:8px; padding:9px 0; border:0; border-top:1px solid rgba(148,163,184,.15); background:transparent; color:#9fd8ff; font:inherit; font-size:12px; font-weight:900; text-align:left; cursor:pointer; }
  .partner-category-toggle b { font-size:18px; color:#fde68a; }
  .partner-category-body { display:none; padding-top:4px; }
  .partner-category-card.is-open .partner-category-body { display:block; }
  .partner-category-card.is-open { border-color:rgba(245,158,11,.28); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior:auto !important; animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
}
