    * {
      box-sizing: border-box
    }

    :root {
      --card: #1D2424;
      --inp: #242E2E;
      --teal: #00D2D3;
      --txt: #fff;
      --mut: #9aa8a8;
      --rlg: 32px;
      --rmd: 20px;
      --rsm: 14px
    }

    body {
      font-family: 'SF Pro Rounded', 'Inter', system-ui, sans-serif;
      min-height: 100vh;
      background: linear-gradient(145deg, #003638, #007B80);
      display: flex;
      align-items: flex-start;
      justify-content: center;
      padding: 32px 16px 48px;
      color: var(--txt)
    }

    .card {
      background: rgba(20, 32, 32, .45);
      backdrop-filter: blur(16px);
      -webkit-backdrop-filter: blur(16px);
      border: 1px solid rgba(255, 255, 255, .12);
      border-radius: var(--rlg);
      padding: 40px 32px 36px;
      width: 100%;
      max-width: 480px;
      box-shadow: 0 24px 80px rgba(0, 0, 0, .6)
    }

    .header {
      text-align: center;
      margin-bottom: 24px;
      position: relative;
      padding-top: 135px
    }

    .hero-icons {
      position: absolute;
      top: 8px;
      left: 50%;
      transform: translateX(calc(-50% + 12px));
      pointer-events: none;
      display: flex;
      flex-direction: column;
      align-items: center;
      transition: opacity .7s, transform .7s cubic-bezier(.4, 0, .2, 1)
    }

    .hero-cloud {
      position: relative;
      right: 35px;
      width: 96px;
      height: 78px;
      flex-shrink: 0;
      animation: floatCloud 5s ease-in-out infinite
    }

    .cloud-shape {
      position: absolute;
      top: 0;
      left: 0;
      width: 96px;
      height: 58px
    }

    .cloud-base {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      height: 36px;
      background: rgba(220, 235, 255, .95);
      border-radius: 20px;
      box-shadow: 0 8px 22px rgba(0, 0, 0, .28)
    }

    .cloud-bump {
      position: absolute;
      background: rgba(225, 238, 255, .97);
      border-radius: 50%;
      box-shadow: 0 4px 12px rgba(0, 0, 0, .18)
    }

    .bump-l {
      width: 50px;
      height: 50px;
      bottom: 22px;
      left: 6px
    }

    .bump-r {
      width: 38px;
      height: 38px;
      bottom: 22px;
      left: 46px
    }

    .cloud-rain {
      position: absolute;
      bottom: 12px;
      left: 14px;
      display: flex;
      gap: 9px
    }

    .cloud-rain span {
      width: 3px;
      height: 11px;
      border-radius: 2px;
      background: rgba(110, 175, 255, .65);
      animation: rainDrop 1.3s ease-in-out infinite
    }

    .cloud-rain span:nth-child(2) {
      animation-delay: .22s;
      height: 9px
    }

    .cloud-rain span:nth-child(3) {
      animation-delay: .44s
    }

    .cloud-rain span:nth-child(4) {
      animation-delay: .11s;
      height: 8px
    }

    @keyframes rainDrop {

      0%,
      100% {
        opacity: .5;
        transform: translateY(0)
      }

      50% {
        opacity: 1;
        transform: translateY(3px)
      }
    }

    @keyframes floatCloud {

      0%,
      100% {
        transform: translateY(0) scale(.75)
      }

      50% {
        transform: translateY(-8px) scale(.75)
      }
    }

    .runner-wrap {
      position: relative;
      left: 35px;
      display: flex;
      flex-direction: column;
      align-items: center;
      margin-top: -80px;
      flex-shrink: 0
    }

    .hero-runner {
      filter: drop-shadow(0 5px 12px rgba(0, 0, 0, .45));
      transform: scaleX(-1)
    }

    .sun-wrap {
      position: absolute;
      top: 25px;
      left: 50%;
      transform: translateX(-50%) scale(.25);
      opacity: 0;
      pointer-events: none;
      transition: opacity .6s ease .3s, transform .6s cubic-bezier(.34, 1.56, .64, 1) .3s
    }

    .sun-icon {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      background: linear-gradient(145deg, #ED8F03, #FFD700);
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2.4rem;
      box-shadow: 0 0 30px rgba(255, 185, 0, .6), 0 0 60px rgba(237, 143, 3, .3);
      animation: sunPulse 2.2s ease-in-out infinite;
      position: relative;
      overflow: hidden
    }

    .sun-icon::before {
      content: '';
      position: absolute;
      inset: 0;
      border-radius: inherit;
      background: linear-gradient(135deg, rgba(255, 255, 255, .22), transparent 55%)
    }

    @keyframes sunPulse {

      0%,
      100% {
        box-shadow: 0 0 0 5px rgba(255, 215, 0, .12), 0 0 28px rgba(255, 185, 0, .55)
      }

      50% {
        box-shadow: 0 0 0 9px rgba(255, 215, 0, .08), 0 0 52px rgba(255, 185, 0, .8)
      }
    }

    #hdr.clear-sky .hero-icons {
      opacity: 0;
      transform: translateX(calc(-50% + 12px)) translateY(-14px) scale(.88)
    }

    #hdr.clear-sky .sun-wrap {
      opacity: 1;
      transform: translateX(-50%) scale(1)
    }

    .header h1 {
      font-size: 1.7rem;
      font-weight: 700;
      letter-spacing: -.5px;
      margin: 0
    }

    .header p {
      font-size: .85rem;
      color: var(--mut);
      margin: 4px 0 0
    }

    .form-stack {
      display: flex;
      flex-direction: column;
      gap: 16px
    }

    .fcard {
      background: rgba(255, 255, 255, .03);
      border: 1px solid rgba(255, 255, 255, .08);
      border-radius: var(--rmd);
      padding: 16px;
      display: flex;
      flex-direction: column;
      gap: 16px
    }

    .slabel {
      font-size: .72rem;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--mut)
    }

    .pills-row {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
      justify-content: center
    }

    .pill {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: rgba(255, 255, 255, .08);
      border: 1px solid rgba(255, 255, 255, .15);
      border-radius: 20px;
      padding: 10px 16px;
      color: #d1d1d6;
      font-size: .88rem;
      font-weight: 500;
      cursor: pointer;
      user-select: none;
      white-space: nowrap;
      min-height: 42px;
      font-family: inherit;
      background: none;
      transition: all .2s
    }

    .pill:hover {
      background: rgba(255, 255, 255, .14);
      border-color: rgba(255, 255, 255, .25)
    }

    .pill.active {
      background: rgba(0, 210, 211, .2);
      border-color: var(--teal);
      color: var(--teal);
      box-shadow: 0 0 10px rgba(0, 210, 211, .25)
    }

    /* ── Dropdown principale ──────────────────────────────────────────────── */
    .dropdown {
      position: fixed;
      width: 240px;
      background: #162020;
      border: 1px solid rgba(0, 210, 211, .3);
      border-radius: 20px;
      padding: 14px 12px;
      box-shadow: 0 20px 60px rgba(0, 0, 0, .8);
      z-index: 99999;
      display: none
    }

    .dropdown.open {
      display: block
    }

    .dd-title {
      font-size: .65rem;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--mut);
      margin-bottom: 10px;
      padding: 0 4px
    }

    .dd-opt {
      display: flex;
      align-items: center;
      gap: 8px;
      width: 100%;
      background: transparent;
      border: 1px solid transparent;
      border-radius: 12px;
      padding: 9px 11px;
      color: var(--mut);
      font-size: .875rem;
      font-family: inherit;
      cursor: pointer;
      text-align: left;
      margin-bottom: 3px
    }

    .dd-opt:hover {
      background: rgba(255, 255, 255, .06);
      color: var(--txt)
    }

    .dd-opt.active {
      background: rgba(0, 210, 211, .15);
      border-color: rgba(0, 210, 211, .35);
      color: var(--teal);
      font-weight: 700
    }

    .dd-sep {
      height: 1px;
      background: rgba(255, 255, 255, .07);
      margin: 10px 4px
    }

    .dd-wind {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 8px 11px;
      border-radius: 12px;
      cursor: pointer
    }

    .dd-wind:hover {
      background: rgba(255, 255, 255, .05)
    }

    .dd-wind-lbl {
      font-size: .875rem;
      color: var(--mut);
      flex: 1
    }

    .dd-wind.on .dd-wind-lbl {
      color: var(--txt)
    }

    /* ── Submenu outdoor (pannello figlio del ddP) ────────────────────────── */
    .dd-outdoor-sub {
      overflow: hidden;
      max-height: 0;
      transition: max-height .28s cubic-bezier(.4, 0, .2, 1), opacity .22s ease;
      opacity: 0;
    }

    .dd-outdoor-sub.open {
      max-height: 220px;
      opacity: 1;
    }

    .dd-sub-inner {
      margin-top: 4px;
      padding: 8px 6px 4px;
      background: rgba(0, 210, 211, .05);
      border: 1px solid rgba(0, 210, 211, .15);
      border-radius: 12px;
    }

    .dd-sub-title {
      font-size: .6rem;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: rgba(0, 210, 211, .6);
      padding: 0 6px 6px;
    }

    .dd-sub-opt {
      display: flex;
      align-items: center;
      gap: 8px;
      width: 100%;
      background: transparent;
      border: 1px solid transparent;
      border-radius: 10px;
      padding: 8px 10px;
      color: var(--mut);
      font-size: .84rem;
      font-family: inherit;
      cursor: pointer;
      text-align: left;
      margin-bottom: 2px;
      transition: background .15s, color .15s, border-color .15s;
    }

    .dd-sub-opt:hover {
      background: rgba(255, 255, 255, .06);
      color: var(--txt)
    }

    .dd-sub-opt.active {
      background: rgba(0, 210, 211, .18);
      border-color: rgba(0, 210, 211, .4);
      color: var(--teal);
      font-weight: 700;
    }

    .dd-opt-arrow {
      margin-left: auto;
      font-size: .7rem;
      transition: transform .22s;
      opacity: .5
    }

    .dd-opt.outdoor-row.active .dd-opt-arrow {
      transform: rotate(90deg);
      opacity: 1
    }

    .sw {
      position: relative;
      width: 38px;
      height: 20px;
      flex-shrink: 0
    }

    .sw input {
      display: none
    }

    .sw-t {
      position: absolute;
      inset: 0;
      background: #3e3e42;
      border-radius: 20px;
      cursor: pointer
    }

    .sw-t::after {
      content: '';
      position: absolute;
      top: 2px;
      left: 2px;
      width: 16px;
      height: 16px;
      background: white;
      border-radius: 50%;
      transition: transform .2s;
      box-shadow: 0 1px 4px rgba(0, 0, 0, .25)
    }

    .sw input:checked+.sw-t {
      background: linear-gradient(135deg, #007B80, var(--teal))
    }

    .sw input:checked+.sw-t::after {
      transform: translateX(18px)
    }

    .sw2 {
      position: relative;
      width: 44px;
      height: 24px;
      flex-shrink: 0
    }

    .sw2 input {
      display: none
    }

    .sw2-t {
      position: absolute;
      inset: 0;
      background: #3e3e42;
      border-radius: 24px;
      cursor: pointer
    }

    .sw2-t::after {
      content: '';
      position: absolute;
      top: 3px;
      left: 3px;
      width: 18px;
      height: 18px;
      background: white;
      border-radius: 50%;
      transition: transform .2s
    }

    .sw2 input:checked+.sw2-t {
      background: linear-gradient(135deg, #007B80, var(--teal))
    }

    .sw2 input:checked+.sw2-t::after {
      transform: translateX(20px)
    }

    .tbox {
      background: var(--inp);
      border-radius: var(--rsm);
      padding: 12px 16px;
      transition: background .3s;
      width: fit-content;
      margin: 0 auto;
    }

    .tbox:hover {
      background: #323238
    }

    .trow {
      display: flex;
      align-items: center;
      gap: 10px;
      cursor: pointer;
      user-select: none
    }

    .trow span {
      font-size: .95rem;
      font-weight: 600
    }

    .xfield {
      margin-top: 12px;
      display: none;
      flex-direction: column;
      gap: 8px
    }

    .xfield.on {
      display: flex
    }

    .field {
      background: var(--inp);
      border: 1.5px solid transparent;
      border-radius: var(--rmd);
      padding: 14px 16px;
      font-size: .95rem;
      font-weight: 600;
      font-family: inherit;
      color: var(--txt);
      width: 100%;
      outline: none;
      transition: all .3s;
      appearance: none
    }

    .field:focus {
      border-color: rgba(77, 160, 255, .5);
      background: #323238
    }

    .sbox {
      display: flex;
      align-items: center;
      background: rgba(255, 255, 255, .05);
      border: 1px solid rgba(255, 255, 255, .1);
      border-radius: 28px;
      padding: 6px;
      gap: 12px;
      transition: box-shadow .3s
    }

    .sbox:focus-within {
      box-shadow: 0 0 0 2px var(--teal);
      background: rgba(255, 255, 255, .08)
    }

    .geo {
      background: #009394;
      min-width: 44px;
      height: 44px;
      border-radius: 22px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.2rem;
      cursor: pointer;
      transition: transform .2s, box-shadow .2s
    }

    .geo:hover {
      transform: scale(1.05);
      box-shadow: 0 4px 12px rgba(0, 147, 148, .4)
    }

    .iwrap {
      flex: 1;
      display: flex;
      flex-direction: column;
      min-width: 0
    }

    .flbl {
      font-size: .75rem;
      color: #8e8e93;
      margin-bottom: 2px
    }

    .iwrap input {
      background: transparent;
      border: none;
      color: var(--txt);
      font-size: 1rem;
      font-weight: 500;
      outline: none;
      width: 100%;
      padding: 0
    }

    .iwrap input::placeholder {
      color: rgba(255, 255, 255, .3)
    }

    .sbtn {
      padding: 0 16px;
      font-size: 1.2rem;
      color: #8e8e93;
      cursor: pointer;
      display: flex;
      align-items: center
    }

    .sbtn:hover {
      color: var(--txt)
    }

    .mbtn {
      background: linear-gradient(135deg, #FFB75E, #ED8F03);
      color: #000;
      font-size: 1.15rem;
      font-weight: 800;
      border: none;
      border-radius: 28px;
      padding: 16px 20px;
      width: 100%;
      cursor: pointer;
      display: flex;
      justify-content: center;
      align-items: center;
      gap: 8px;
      box-shadow: 0 8px 16px rgba(237, 143, 3, .3);
      transition: all .3s;
      text-transform: uppercase;
      letter-spacing: .5px
    }

    .mbtn:hover {
      transform: translateY(-2px);
      box-shadow: 0 12px 24px rgba(237, 143, 3, .4);
      filter: brightness(1.1)
    }

    .mbtn:disabled {
      opacity: .6;
      cursor: not-allowed;
      filter: grayscale(100%) !important;
      transform: none !important
    }

    #status {
      border-radius: var(--rsm);
      padding: 14px 16px;
      font-size: .95rem;
      font-weight: 600;
      text-align: center;
      transition: all .3s
    }

    .si {
      background: var(--inp);
      color: var(--mut)
    }

    .ss {
      background: rgba(255, 193, 7, .1);
      color: #ffd54f;
      border: 1px solid rgba(255, 193, 7, .3);
      animation: pulse 1.4s infinite
    }

    .sk {
      background: rgba(76, 175, 80, .1);
      color: #81c784;
      border: 1px solid rgba(76, 175, 80, .3)
    }

    .se {
      background: rgba(244, 67, 54, .1);
      color: #e57373;
      border: 1px solid rgba(244, 67, 54, .3)
    }

    @keyframes pulse {

      0%,
      100% {
        opacity: 1
      }

      50% {
        opacity: .55
      }
    }

    .vtog {
      display: none;
      background: var(--inp);
      border-radius: var(--rmd);
      padding: 6px;
      margin: 24px 0 16px
    }

    .vtog.on {
      display: flex
    }

    .vbtn {
      flex: 1;
      padding: 10px 0;
      text-align: center;
      font-size: .95rem;
      font-weight: 700;
      color: var(--mut);
      background: transparent;
      border: none;
      border-radius: 10px;
      cursor: pointer;
      transition: all .3s
    }

    .vbtn.active {
      background: #323238;
      color: var(--txt);
      box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
      transform: scale(1.02)
    }

    #rlist {
      display: flex;
      flex-direction: column;
      gap: 16px
    }

    .rcard {
      background: var(--card);
      border-radius: var(--rlg);
      padding: 24px;
      box-shadow: 0 10px 30px rgba(0, 0, 0, .5);
      animation: slideIn .35s ease both;
      border-left: 6px solid var(--teal);
      transition: transform .25s, box-shadow .25s
    }

    .rcard:hover {
      transform: translateY(-4px);
      box-shadow: 0 16px 40px rgba(0, 0, 0, .6)
    }

    @keyframes slideIn {
      from {
        opacity: 0;
        transform: translateY(14px)
      }

      to {
        opacity: 1;
        transform: translateY(0)
      }
    }

    .rhead {
      cursor: pointer;
      display: inline-flex;
      flex-direction: column;
      gap: 2px;
      margin-bottom: 8px;
      padding: 6px 10px 6px 6px;
      border-radius: 10px;
      transition: background .18s
    }

    .rhead:hover {
      background: rgba(255, 255, 255, .06)
    }

    .rrank {
      font-size: .75rem;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: var(--teal)
    }

    .rname {
      font-size: 1.25rem;
      font-weight: 800;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      border-bottom: 2px solid rgba(255, 255, 255, .5);
      padding-bottom: 2px;
      transition: color .18s, border-color .18s
    }

    .rname::after {
      content: '\203A';
      color: #fff;
      font-size: 1.4rem;
      font-weight: 300;
      opacity: .8;
      transition: opacity .18s, transform .18s;
      transform: translateX(0)
    }

    .rhead:hover .rname {
      color: var(--teal);
      border-bottom-color: #fff
    }

    .rhead:hover .rname::after {
      opacity: 1;
      transform: translateX(4px)
    }

    .rmeta {
      font-size: .85rem;
      color: var(--mut);
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 6px 8px;
      border-radius: 8px;
      transition: background .2s;
      margin-left: -8px
    }

    .rmeta:hover {
      background: rgba(255, 255, 255, .05)
    }

    .rmeta-ico {
      font-size: .75rem;
      transition: transform .2s
    }

    .rmeta.open .rmeta-ico {
      transform: rotate(180deg)
    }

    .fcont {
      display: none;
      margin: 12px 0 4px;
      padding: 14px;
      background: var(--inp);
      border-radius: 16px;
      gap: 12px;
      overflow-x: auto;
      white-space: nowrap
    }

    .fcont.on {
      display: flex
    }

    .fslot {
      display: inline-flex;
      flex-direction: column;
      align-items: center;
      background: var(--card);
      padding: 10px 14px;
      border-radius: 12px;
      min-width: 70px;
      box-shadow: 0 4px 12px rgba(0, 0, 0, .3);
      border: 1px solid rgba(255, 255, 255, .05)
    }

    .ftime {
      font-size: .8rem;
      font-weight: 600;
      color: var(--mut)
    }

    .ftemp {
      font-size: .95rem;
      font-weight: 700;
      margin-top: 6px
    }

    .rbadge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: rgba(0, 210, 211, .1);
      color: var(--teal);
      border: 1px solid rgba(0, 210, 211, .2);
      font-size: .8rem;
      font-weight: 700;
      padding: 6px 14px;
      border-radius: 20px;
      margin: 8px 0 12px
    }

    .rroute {
      display: inline-block;
      font-size: .85rem;
      font-weight: 600;
      color: var(--teal);
      margin-top: 6px;
      min-height: 18px;
      transition: opacity .3s
    }

    .rroute.loading {
      opacity: .45
    }

    .rwrow {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 6px
    }

    .rwico {
      width: 44px;
      height: 44px;
      flex-shrink: 0
    }

    .rwinfo {
      flex: 1
    }

    .wbadge {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: .8rem;
      font-weight: 700;
      padding: 4px 10px;
      border-radius: 20px;
      margin-top: 2px
    }

    .wcalm {
      background: rgba(76, 175, 80, .15);
      color: #81c784;
      border: 1px solid rgba(76, 175, 80, .3)
    }

    .wlight {
      background: rgba(255, 193, 7, .12);
      color: #ffd54f;
      border: 1px solid rgba(255, 193, 7, .3)
    }

    .wstrong {
      background: rgba(244, 67, 54, .12);
      color: #e57373;
      border: 1px solid rgba(244, 67, 54, .3)
    }

    .navbtns {
      display: flex;
      gap: 8px;
      margin-top: 10px
    }

    .navbtn {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      background: var(--inp);
      color: var(--txt);
      text-decoration: none;
      padding: 11px 16px;
      border-radius: var(--rsm);
      font-size: .88rem;
      font-weight: 600;
      flex: 1;
      justify-content: center;
      transition: all .2s;
      border: 1px solid transparent;
      cursor: pointer;
      font-family: inherit
    }

    .navbtn:hover {
      background: #323238;
      transform: translateY(-1px)
    }

    #map {
      display: none;
      height: 460px;
      border-radius: var(--rlg);
      overflow: hidden;
      border: 1px solid rgba(255, 255, 255, .05);
      box-shadow: 0 12px 32px rgba(0, 0, 0, .5);
      margin-top: 20px;
      background: #1e1e1e
    }

    #map.on {
      display: block
    }

    .leaflet-popup-content-wrapper {
      background: var(--card);
      color: var(--txt);
      border-radius: var(--rmd);
      border: 1px solid rgba(255, 255, 255, .05)
    }

    .leaflet-popup-tip {
      background: var(--card)
    }

    .leaflet-container a.leaflet-popup-close-button {
      color: var(--mut)
    }

    .leaflet-popup-content {
      margin: 16px 20px;
      line-height: 1.4
    }

    .pptitle {
      font-weight: 800;
      font-size: 1.1rem;
      margin-bottom: 6px
    }

    .ppmeta {
      font-size: .85rem;
      color: var(--mut);
      margin-bottom: 8px
    }

    .ppbtn {
      display: inline-block;
      background: linear-gradient(135deg, #007B80, var(--teal));
      color: white;
      padding: 6px 12px;
      border-radius: 8px;
      text-decoration: none;
      font-size: .85rem;
      font-weight: 700;
      border: none;
      cursor: pointer;
      font-family: inherit
    }

    .skel {
      background: var(--card);
      border-radius: var(--rlg);
      padding: 24px;
      border-left: 6px solid rgba(255, 255, 255, .05)
    }

    .sk-line {
      height: 12px;
      border-radius: 6px;
      background: linear-gradient(90deg, rgba(255, 255, 255, .04) 25%, rgba(255, 255, 255, .10) 50%, rgba(255, 255, 255, .04) 75%);
      background-size: 200% 100%;
      animation: shimmer 1.4s infinite;
      margin-bottom: 12px
    }

    .sk-line.s {
      width: 40%
    }

    .sk-line.m {
      width: 65%
    }

    .sk-line.f {
      width: 100%
    }

    .sk-line.t {
      height: 18px;
      margin-bottom: 16px
    }

    @keyframes shimmer {
      0% {
        background-position: 200% 0
      }

      100% {
        background-position: -200% 0
      }
    }

    .lmbtn {
      display: flex;
      align-items: center;
      justify-content: center;
      width: calc(100% - 32px);
      max-width: 300px;
      margin: 16px auto;
      padding: 16px 20px;
      font-family: inherit;
      font-size: 1.05rem;
      font-weight: 700;
      border: none;
      border-radius: var(--rmd);
      cursor: pointer;
      background: var(--inp);
      color: var(--txt);
      transition: all .3s
    }

    .lmbtn:hover {
      background: #323238;
      transform: translateY(-2px)
    }

    .lmbtn:disabled {
      opacity: .6;
      cursor: not-allowed
    }

    .footer {
      margin-top: 32px;
      text-align: center;
      font-size: .70rem;
      color: var(--mut);
      line-height: 1.4;
      padding-top: 16px;
      border-top: 1px solid rgba(255, 255, 255, .05)
    }

    .footer a {
      color: var(--teal);
      text-decoration: none;
      font-weight: 600
    }

    .mtb-badge {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      font-size: .8rem;
      font-weight: 700;
      padding: 4px 10px;
      border-radius: 20px;
      margin-top: 2px;
      background: rgba(139, 92, 246, .15);
      color: #c4b5fd;
      border: 1px solid rgba(139, 92, 246, .3)
    }

    .wx-check {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      font-size: .75rem;
      font-weight: 600;
      color: var(--mut);
      margin-top: 4px
    }

    .gpx-btn {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: rgba(0, 210, 211, .1);
      border: 1px solid rgba(0, 210, 211, .25);
      color: var(--teal);
      padding: 9px 14px;
      border-radius: var(--rsm);
      font-size: .85rem;
      font-weight: 700;
      cursor: pointer;
      font-family: inherit;
      transition: all .2s
    }

    .gpx-btn:hover {
      background: rgba(0, 210, 211, .2);
      border-color: var(--teal)
    }

    @media(max-width:480px) {
      .card {
        padding: 32px 16px 36px
      }

      .fcard {
        padding: 12px
      }

      .pill {
        padding: 8px 12px;
        font-size: .82rem;
        min-height: 40px
      }
    }

    /* ── Explore button ──────────────────────────────────────────────────────── */
    .explore-btn {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: linear-gradient(135deg, rgba(0, 210, 211, .18), rgba(0, 123, 128, .22));
      border: 1px solid rgba(0, 210, 211, .35);
      color: var(--teal);
      padding: 9px 14px;
      border-radius: var(--rsm);
      font-size: .88rem;
      font-weight: 700;
      cursor: pointer;
      font-family: inherit;
      transition: all .2s;
      flex: 1;
      justify-content: center;
    }

    .explore-btn:hover {
      background: linear-gradient(135deg, rgba(0, 210, 211, .28), rgba(0, 123, 128, .32));
      border-color: var(--teal);
      transform: translateY(-1px)
    }

    /* ── Drawer overlay ──────────────────────────────────────────────────────── */
    .drawer-overlay {
      position: fixed;
      inset: 0;
      background: rgba(0, 0, 0, .55);
      backdrop-filter: blur(4px);
      z-index: 1000;
      opacity: 0;
      pointer-events: none;
      transition: opacity .3s ease
    }

    .drawer-overlay.open {
      opacity: 1;
      pointer-events: all
    }

    /* ── Drawer panel ────────────────────────────────────────────────────────── */
    .detail-drawer {
      position: fixed;
      bottom: 0;
      left: 50%;
      transform: translateX(-50%) translateY(100%);
      width: 100%;
      max-width: 520px;
      /* use dvh (dynamic viewport height) where supported, fallback to 85vh */
      max-height: 85vh;
      max-height: 85dvh;
      background: #111c1c;
      border-radius: 28px 28px 0 0;
      border: 1px solid rgba(255, 255, 255, .1);
      border-bottom: none;
      box-shadow: 0 -20px 60px rgba(0, 0, 0, .7);
      z-index: 1001;
      transition: transform .38s cubic-bezier(.32, 1, .52, 1);
      display: flex;
      flex-direction: column;
      overflow: hidden;
      /* prevent drawer itself from being part of page scroll */
      will-change: transform
    }

    .detail-drawer.open {
      transform: translateX(-50%) translateY(0)
    }

    .drawer-handle {
      width: 40px;
      height: 4px;
      background: rgba(255, 255, 255, .18);
      border-radius: 2px;
      margin: 12px auto 0;
      flex-shrink: 0
    }

    .drawer-head {
      padding: 16px 24px 14px;
      flex-shrink: 0;
      border-bottom: 1px solid rgba(255, 255, 255, .07)
    }

    .drawer-place-name {
      font-size: 1.3rem;
      font-weight: 800;
      letter-spacing: -.3px;
      margin-bottom: 4px
    }

    .drawer-weather-row {
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: .85rem;
      color: var(--mut)
    }

    .drawer-close {
      position: absolute;
      top: 14px;
      right: 18px;
      background: rgba(255, 255, 255, .08);
      border: none;
      color: var(--mut);
      width: 30px;
      height: 30px;
      border-radius: 50%;
      font-size: 1rem;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: all .2s;
      font-family: inherit
    }

    .drawer-close:hover {
      background: rgba(255, 255, 255, .15);
      color: var(--txt)
    }

    .drawer-body {
      overflow-y: auto;
      flex: 1;
      min-height: 0;
      /* required for flex children to scroll correctly */
      padding: 20px 24px 32px;
      -webkit-overflow-scrolling: touch;
      overscroll-behavior: contain
        /* prevents page scroll when drawer hits top/bottom */
    }

    /* ── Place photo — blurred backdrop pattern ─────────────────────────────── */
    .drawer-photo-wrap {
      width: 100%;
      height: 200px;
      border-radius: 16px;
      margin-bottom: 16px;
      overflow: hidden;
      position: relative;
      background: #0d1a1a
    }

    .drawer-photo-wrap::before {
      content: '';
      position: absolute;
      inset: -12px;
      background-image: var(--photo-bg);
      background-size: cover;
      background-position: center;
      filter: blur(18px) brightness(.45) saturate(1.3);
      transform: scale(1.05);
      z-index: 0
    }

    .drawer-photo {
      position: relative;
      z-index: 1;
      width: 100%;
      height: 100%;
      object-fit: contain;
      object-position: center;
      display: block;
      transition: transform .4s ease
    }

    .drawer-photo-wrap:hover .drawer-photo {
      transform: scale(1.04)
    }

    /* ── Highlights section ──────────────────────────────────────────────────── */
    .drawer-section-title {
      font-size: .7rem;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--teal);
      margin-bottom: 12px;
      margin-top: 20px
    }

    .drawer-section-title:first-child {
      margin-top: 0
    }

    .highlights-grid {
      display: flex;
      flex-direction: column;
      gap: 10px
    }

    .highlight-item {
      display: flex;
      gap: 12px;
      align-items: flex-start;
      background: rgba(255, 255, 255, .03);
      border: 1px solid rgba(255, 255, 255, .07);
      border-radius: 14px;
      padding: 13px 14px
    }

    .highlight-emoji {
      font-size: 1.4rem;
      flex-shrink: 0;
      line-height: 1.2
    }

    .highlight-text {
      flex: 1
    }

    .highlight-title {
      font-size: .9rem;
      font-weight: 700;
      margin-bottom: 2px
    }

    .highlight-desc {
      font-size: .8rem;
      color: var(--mut);
      line-height: 1.45
    }

    /* Skeleton loading highlights */
    .hl-skel {
      display: flex;
      gap: 12px;
      align-items: flex-start;
      background: rgba(255, 255, 255, .03);
      border: 1px solid rgba(255, 255, 255, .07);
      border-radius: 14px;
      padding: 13px 14px
    }

    .hl-skel-icon {
      width: 32px;
      height: 32px;
      border-radius: 8px;
      background: linear-gradient(90deg, rgba(255, 255, 255, .05) 25%, rgba(255, 255, 255, .1) 50%, rgba(255, 255, 255, .05) 75%);
      background-size: 200% 100%;
      animation: shimmer 1.4s infinite;
      flex-shrink: 0
    }

    .hl-skel-lines {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: 6px
    }

    .hl-skel-line {
      height: 10px;
      border-radius: 5px;
      background: linear-gradient(90deg, rgba(255, 255, 255, .05) 25%, rgba(255, 255, 255, .1) 50%, rgba(255, 255, 255, .05) 75%);
      background-size: 200% 100%;
      animation: shimmer 1.4s infinite
    }

    .hl-skel-line.short {
      width: 55%
    }

    /* ── Affiliate sections ──────────────────────────────────────────────────── */
    .affiliate-grid {
      display: flex;
      flex-direction: column;
      gap: 10px
    }

    .affiliate-card {
      display: flex;
      align-items: center;
      gap: 14px;
      background: rgba(255, 255, 255, .04);
      border: 1px solid rgba(255, 255, 255, .09);
      border-radius: 16px;
      padding: 14px 16px;
      text-decoration: none;
      color: var(--txt);
      transition: all .2s;
      cursor: pointer
    }

    .affiliate-card:hover {
      background: rgba(255, 255, 255, .08);
      border-color: rgba(255, 255, 255, .18);
      transform: translateY(-1px)
    }

    .aff-icon {
      width: 44px;
      height: 44px;
      border-radius: 12px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.4rem;
      flex-shrink: 0
    }

    .aff-icon.hotel {
      background: linear-gradient(135deg, #1a5276, #2980b9)
    }

    .aff-icon.restaurant {
      background: linear-gradient(135deg, #922b21, #e74c3c)
    }

    .aff-icon.experience {
      background: linear-gradient(135deg, #1e8449, #27ae60)
    }

    .aff-text {
      flex: 1
    }

    .aff-title {
      font-size: .92rem;
      font-weight: 700;
      margin-bottom: 2px
    }

    .aff-sub {
      font-size: .78rem;
      color: var(--mut)
    }

    .aff-arrow {
      color: var(--mut);
      font-size: .85rem;
      flex-shrink: 0
    }

    /* ── Route / climbing info card ─────────────────────────────────────────── */
    .route-info {
      display: flex;
      flex-direction: column;
      gap: 6px;
      background: rgba(255, 255, 255, .03);
      border: 1px solid rgba(255, 255, 255, .07);
      border-radius: 14px;
      padding: 14px 16px;
      margin-bottom: 12px
    }

    .ri-row {
      display: flex;
      align-items: baseline;
      gap: 8px;
      font-size: .875rem;
      line-height: 1.4
    }

    .ri-icon {
      flex-shrink: 0;
      font-size: 1rem;
      width: 20px;
      text-align: center
    }

    .ri-label {
      color: var(--mut);
      flex-shrink: 0;
      min-width: 120px
    }

    .ri-value {
      color: var(--txt);
      font-weight: 600;
      flex: 1
    }

    .ri-desc {
      font-size: .82rem;
      color: var(--mut);
      line-height: 1.5;
      margin: 0 0 8px;
      font-style: italic
    }

    .ri-source {
      font-size: .72rem;
      color: rgba(255, 255, 255, .25);
      margin: 0;
      text-align: right
    }

    /* ── Cookie Banner ──────────────────────────────────────────────────────── */
    .cookie-banner {
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      background: rgba(17, 28, 28, 0.95);
      backdrop-filter: blur(12px);
      border-top: 1px solid rgba(0, 210, 211, .3);
      padding: 20px 24px;
      z-index: 100000;
      display: none;
      flex-direction: column;
      gap: 16px;
      box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.8);
      font-family: 'SF Pro Rounded', 'Inter', system-ui, sans-serif;
    }

    .cookie-banner.show {
      display: flex;
    }

    .cb-text {
      font-size: 0.9rem;
      color: var(--txt);
      text-align: center;
      line-height: 1.5;
      max-width: 800px;
      margin: 0 auto;
    }

    .cb-text strong {
      color: var(--teal);
      font-size: 1.05rem;
      display: block;
      margin-bottom: 6px;
    }

    .cb-text p {
      margin: 0 0 8px 0;
      color: var(--mut);
    }

    .cb-text a {
      color: var(--teal);
      text-decoration: underline;
      font-size: 0.8rem;
    }

    .cb-btns {
      display: flex;
      gap: 12px;
      justify-content: center;
      flex-wrap: wrap;
    }

    .cb-btn {
      padding: 12px 20px;
      border-radius: 24px;
      font-size: 0.9rem;
      font-weight: 700;
      cursor: pointer;
      transition: all 0.2s;
      font-family: inherit;
    }

    .cb-btn.reject {
      border: 1px solid rgba(255, 255, 255, 0.2);
      background: transparent;
      color: var(--mut);
    }

    .cb-btn.reject:hover {
      background: rgba(255, 255, 255, 0.05);
      color: var(--txt);
    }

    .cb-btn.accept {
      background: linear-gradient(135deg, #007B80, var(--teal));
      border: none;
      color: #fff;
      box-shadow: 0 4px 12px rgba(0, 210, 211, 0.3);
    }

    .cb-btn.accept:hover {
      transform: translateY(-2px);
      box-shadow: 0 6px 16px rgba(0, 210, 211, 0.4);
      filter: brightness(1.1);
    }

    .popup-below .leaflet-popup-content-wrapper {
      margin-top: 20px !important;
      margin-bottom: 0 !important;
    }

    .popup-below .leaflet-popup-tip-container {
      top: 0 !important;
      bottom: auto !important;
      transform: rotate(180deg) !important;
    }

    /* ── Map info bar (sotto la mappa per marker GPX) ────────────────────────── */
    .map-info-bar {
      display: none;
      flex-direction: column;
      gap: 10px;
      background: var(--card);
      border: 1px solid rgba(255, 255, 255, .08);
      border-top: none;
      border-radius: 0 0 var(--rlg) var(--rlg);
      padding: 14px 16px 16px;
      margin-bottom: 16px;
      box-shadow: 0 8px 24px rgba(0, 0, 0, .4)
    }

    .map-info-bar.show {
      display: flex
    }

    .mi-name {
      font-size: .98rem;
      font-weight: 800;
      letter-spacing: -.2px;
      color: var(--txt)
    }

    .mi-meta {
      font-size: .82rem;
      color: var(--mut);
      margin-top: 2px
    }

    .mi-btns {
      display: flex;
      gap: 8px;
      margin-top: 2px
    }

    /* ── Disambiguation panel ─────────────────────────────────────────── */
    .disambig-panel {
      display: none;
      background: var(--card);
      border: 1px solid rgba(0, 210, 211, .22);
      border-radius: var(--rmd);
      padding: 14px 16px;
      margin: 8px 0 0;
      overflow: hidden;
    }

    .disambig-panel.show {
      display: block;
      animation: fadeIn .2s ease;
    }

    .disambig-title {
      font-size: .75rem;
      color: var(--mut);
      margin-bottom: 10px;
      font-weight: 500;
      letter-spacing: .01em;
    }

    .disambig-opt {
      display: block;
      width: 100%;
      text-align: left;
      background: rgba(0, 210, 211, .07);
      border: 1px solid rgba(0, 210, 211, .18);
      border-radius: var(--rsm);
      padding: 10px 14px;
      margin-bottom: 7px;
      font-size: .88rem;
      color: var(--txt);
      cursor: pointer;
      transition: background .15s, border-color .15s;
      font-family: inherit;
      line-height: 1.3;
    }

    .disambig-opt:hover,
    .disambig-opt:focus {
      background: rgba(0, 210, 211, .18);
      border-color: rgba(0, 210, 211, .45);
      outline: none;
    }

    .disambig-opt:last-child {
      margin-bottom: 0;
    }