/* =========================================================
   PUBLIC PORTAL / MAP-FIRST SHELL
   Responsive: smartphone / tablet / desktop
   Theme-ready: uses project tokens when available
========================================================= */

/* =========================
   THEME BRIDGE
========================= */
:root{
  --portal-bg: var(--bg, #07111f);
  --portal-bg-soft: var(--surface, rgba(9,19,34,.82));
  --portal-card: var(--surface-2, rgba(12,24,43,.76));
  --portal-card-2: var(--surface-3, rgba(255,255,255,.08));
  --portal-line: var(--border, rgba(255,255,255,.12));
  --portal-text: var(--text, #eff6ff);
  --portal-muted: var(--text-2, #b6c6df);
  --portal-accent: var(--accent, #5eead4);
  --portal-accent-2: var(--accent-2, #60a5fa);
  --portal-overlay: var(--overlay, rgba(0,0,0,.46));
  --portal-control-bg: var(--control-bg, rgba(255,255,255,.06));
  --portal-shadow: 0 18px 40px rgba(0,0,0,.28);
  --portal-radius: 22px;

  --header-h: 72px;
  --header-h-compact: 58px;
  --footer-h: 74px;

  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);

  /* z-index scale */
  --z-map-search: 900;
  --z-search-layer: 1500;
  --z-map-status: 910;
  --z-header: 1700;
  --z-header-menu: 1710;
  --z-footer: 1020;
  --z-cookie: 1200;
  --z-backdrop: 1300;
  --z-filter: 1500;
  --z-drawer: 1800;
  --z-splash: 4000;
}

/* =========================
   RESET
========================= */
*{box-sizing:border-box}

html,
body{
  margin:0;
  padding:0;
  background:var(--portal-bg);
  color:var(--portal-text);
  font-family:Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html{
  -webkit-text-size-adjust:100%;
}

body{
  min-height:100dvh;
  overflow:hidden;
}

a{
  color:inherit;
  text-decoration:none;
}

button,
input,
select,
textarea{
  font:inherit;
}

button{
  cursor:pointer;
}

/* =========================
   BASE SHELL
========================= */
.portal-shell{
  position:relative;
  min-height:100dvh;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--portal-accent-2) 16%, transparent), transparent 22%),
    radial-gradient(circle at top right, color-mix(in srgb, var(--portal-accent) 12%, transparent), transparent 18%),
    linear-gradient(180deg, color-mix(in srgb, var(--portal-bg) 96%, #000 4%) 0%, var(--portal-bg) 100%);
}

/* =========================
   SPLASH / INTRO
========================= */
.portal-splash{
  position:fixed;
  inset:0;
  z-index:var(--z-splash);
  display:grid;
  place-items:center;
  overflow:hidden;
  background:var(--portal-bg);
  transition:
    opacity .85s ease,
    visibility .85s ease,
    transform .85s ease;
}

.portal-splash.is-hidden{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:scale(1.01);
}

.portal-splash__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 18% 18%, color-mix(in srgb, var(--portal-accent-2) 10%, transparent), transparent 34%),
    radial-gradient(circle at 82% 12%, color-mix(in srgb, var(--portal-accent) 10%, transparent), transparent 28%),
    linear-gradient(180deg, color-mix(in srgb, var(--portal-bg) 96%, #000 4%) 0%, var(--portal-bg) 100%);
  transform:scale(1.03);
  animation:portal-bg-soft-move 10s ease-in-out infinite alternate;
}

.portal-splash__veil{
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--portal-bg) 16%, transparent),
      transparent 30%,
      color-mix(in srgb, var(--portal-bg) 14%, transparent) 100%
    );
  pointer-events:none;
}

.portal-splash__grain{
  position:absolute;
  inset:0;
  opacity:.06;
  pointer-events:none;
  background-image:
    radial-gradient(circle at 20% 30%, color-mix(in srgb, var(--portal-text) 18%, transparent) 0 1px, transparent 1.5px),
    radial-gradient(circle at 80% 60%, color-mix(in srgb, var(--portal-text) 14%, transparent) 0 1px, transparent 1.5px),
    radial-gradient(circle at 45% 75%, color-mix(in srgb, var(--portal-text) 12%, transparent) 0 1px, transparent 1.5px);
  background-size:120px 120px, 160px 160px, 140px 140px;
}

.portal-splash__box{
  position:relative;
  z-index:3;
  width:min(100%, 720px);
  min-height:240px;
  padding:36px 24px;
  text-align:center;
}

.portal-splash__stage{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  align-content:center;
  opacity:0;
  visibility:hidden;
  transform:translateY(18px);
  filter:blur(10px);
  transition:
    opacity .75s ease,
    transform .75s ease,
    filter .75s ease,
    visibility .75s ease;
}

.portal-splash__stage.is-active{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  filter:blur(0);
}

.portal-loader{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
}

.portal-loader__line{
  display:block;
  width:4px;
  height:34px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--portal-accent) 0%, var(--portal-accent-2) 100%);
  opacity:.85;
  transform-origin:center bottom;
  animation:portal-loader-wave 1s ease-in-out infinite;
}

.portal-loader__line:nth-child(2){ animation-delay:.12s; }
.portal-loader__line:nth-child(3){ animation-delay:.24s; }

.portal-splash__loading-text{
  margin:16px 0 0;
  color:var(--portal-muted);
  font-size:1rem;
  letter-spacing:.03em;
}

.portal-splash__eyebrow{
  margin:0 0 10px;
  color:var(--portal-muted);
  letter-spacing:.2em;
  text-transform:uppercase;
  font-size:.76rem;
}

.portal-splash__title{
  margin:0;
  color:var(--portal-text);
  font-size:clamp(2.4rem, 7vw, 4.8rem);
  line-height:1.03;
  letter-spacing:-.04em;
  font-weight:800;
}

.portal-splash__letter{
  display:inline-block;
  opacity:0;
  transform:translateY(16px);
  filter:blur(8px);
}

.portal-splash.is-welcome .portal-splash__letter{
  animation:portal-letter-soft-in .6s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay:calc(var(--letter-delay) * 48ms);
}

.portal-splash__logo-wrap{
  position:relative;
  margin:24px auto 0;
  width:88px;
  height:88px;
}

.portal-splash.is-welcome .portal-splash__logo-wrap{
  animation:portal-logo-soft-pop .75s cubic-bezier(.2,.8,.2,1) .3s both;
}

.portal-splash__logo-img,
.portal-splash__logo-fallback{
  width:100%;
  height:100%;
  border-radius:26px;
  box-shadow:0 18px 40px rgba(0,0,0,.14);
}

.portal-splash__logo-img{
  display:block;
  object-fit:cover;
  background:var(--portal-card);
  border:1px solid var(--portal-line);
}

.portal-splash__logo-fallback{
  display:none;
  place-items:center;
  font-weight:800;
  font-size:2rem;
  background:url('../public/images/LevantGo_icona_20260324.png');
  background-size:cover;
  background-position:center;
  color:#04101f;
}

/* =========================
   HEADER
========================= */
.portal-header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:var(--z-header);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  height:calc(var(--header-h) + var(--safe-top));
  padding:
    calc(10px + var(--safe-top))
    calc(16px + var(--safe-right))
    10px
    calc(16px + var(--safe-left));
  background:linear-gradient(180deg, color-mix(in srgb, var(--portal-bg) 72%, transparent), color-mix(in srgb, var(--portal-bg) 18%, transparent));
  backdrop-filter:blur(16px);
  border-bottom:1px solid color-mix(in srgb, var(--portal-line) 85%, transparent);
}

.portal-brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.portal-brand__logo,
.icon-btn{
  width:46px;
  height:46px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:color-mix(in srgb, var(--portal-card) 86%, transparent);
  border:1px solid var(--portal-line);
  box-shadow:var(--portal-shadow);
}

.portal-brand__logo{
  flex:0 0 auto;
  font-weight:800;
  color:#031220;
  background:url('../public/images/LevantGo_icona_20260324.png');
  background-size:cover;
  background-position:center;
}

.portal-brand__text{
  display:flex;
  flex-direction:column;
  min-width:0;
}

.portal-brand__text strong{
  font-size:1rem;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.portal-brand__text small{
  color:var(--portal-muted);
  font-size:.72rem;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.portal-header__actions{
  display:flex;
  align-items:center;
  gap:10px;
}

.icon-btn{
  color:var(--portal-text);
}

/* =========================
   PUBLIC TOPBAR / LANGUAGE
========================= */
.public-topbar-tools{
  max-width:1180px;
  margin:0 auto;
  padding:18px 16px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.public-topbar-tools__left,
.public-topbar-tools__right{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

.public-link-btn,
.public-icon-btn,
.public-lang-btn{
  min-height:44px;
  border-radius:14px;
  border:1px solid var(--portal-line);
  background:color-mix(in srgb, var(--portal-card) 86%, transparent);
  color:var(--portal-text);
  text-decoration:none;
  box-shadow:var(--portal-shadow);
}

.public-link-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0 14px;
}

.public-icon-btn{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
}

.public-lang{
  position:relative;
}

.public-lang summary{
  list-style:none;
}

.public-lang summary::-webkit-details-marker{
  display:none;
}

.public-lang-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:0 12px;
  cursor:pointer;
  user-select:none;
}

.public-lang-menu{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  z-index:var(--z-header-menu);
  min-width:176px;
  padding:8px;
  border-radius:16px;
  border:1px solid var(--portal-line);
  background:color-mix(in srgb, var(--portal-bg-soft) 94%, transparent);
  backdrop-filter:blur(18px);
  box-shadow:var(--portal-shadow);
}

.public-lang-menu a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  min-height:40px;
  padding:8px 10px;
  border-radius:12px;
  color:var(--portal-text);
}

.public-lang-menu a:hover,
.public-lang-menu a.is-current{
  background:color-mix(in srgb, var(--portal-card-2) 90%, transparent);
}

@media (max-width:760px){
  .public-topbar-tools{
    align-items:stretch;
  }

  .public-topbar-tools__left,
  .public-topbar-tools__right{
    width:100%;
  }

  .public-link-btn{
    flex:1 1 auto;
    justify-content:center;
  }

  .public-lang{
    flex:1 1 auto;
  }

  .public-lang-btn{
    width:100%;
    justify-content:center;
  }
}

/* =========================
   MAIN
========================= */
.portal-main{
  padding:
    calc(var(--header-h) + var(--safe-top) + 12px)
    14px
    calc(var(--footer-h) + var(--safe-bottom) + 14px)
    14px;
}

.portal-map-wrap{
  position:relative;
}

/* =========================
   SHARED GLASS
========================= */
.portal-search__bar,
.glass-card,
.portal-filter-sheet,
.portal-map-status,
.portal-drawer{
  background:color-mix(in srgb, var(--portal-bg-soft) 90%, transparent);
  border:1px solid var(--portal-line);
  backdrop-filter:blur(18px);
  box-shadow:var(--portal-shadow);
}

/* =========================
   SEARCH
========================= */
.portal-search-floating{
  position:absolute;
  z-index:var(--z-search-layer);
  top:16px;
  left:16px;
  right:16px;
  pointer-events:none;
}

.portal-search{
  pointer-events:auto;
}

.portal-search__bar{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:20px;
}

.portal-search__bar i{
  color:var(--portal-muted);
}

.portal-search__bar input{
  flex:1 1 auto;
  min-width:0;
  border:none;
  outline:none;
  background:transparent;
  color:var(--portal-text);
}

.portal-search__bar input::placeholder{
  color:var(--portal-muted);
}

/* =========================
   BUTTONS
========================= */
.ghost-btn,
.primary-btn{
  border-radius:14px;
  padding:10px 14px;
  border:1px solid var(--portal-line);
  background:var(--portal-control-bg);
  color:var(--portal-text);
  transition:
    transform .18s ease,
    background .18s ease,
    border-color .18s ease,
    opacity .18s ease;
}

.ghost-btn:hover,
.primary-btn:hover,
.icon-btn:hover{
  transform:translateY(-1px);
}

.primary-btn{
  background:linear-gradient(135deg, var(--portal-accent), var(--portal-accent-2));
  color:#051220;
  border-color:transparent;
  font-weight:700;
}

/* =========================
   FILTER SHEET
========================= */
.portal-filter-sheet{
  position:relative;
  margin-top:12px;
  padding:16px;
  border-radius:22px;
  display:none;
  max-height:min(62dvh, 680px);
  overflow:auto;
  z-index:var(--z-filter);
}

.portal-filter-sheet.is-open{
  display:block;
  animation:portal-fade-up .28s ease both;
}

.portal-filter-sheet__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}

.portal-filter-sheet__head p{
  margin:4px 0 0;
  color:var(--portal-muted);
  font-size:.9rem;
}

.portal-filter-block + .portal-filter-block{
  margin-top:16px;
}

.portal-filter-block__title{
  display:block;
  margin-bottom:10px;
  font-weight:700;
}

.chip-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.chip-check input{
  display:none;
}

.chip-check span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--portal-line);
  background:color-mix(in srgb, var(--portal-card-2) 72%, transparent);
  color:var(--portal-text);
  cursor:pointer;
}

.chip-check input:checked + span{
  background:color-mix(in srgb, var(--portal-accent) 16%, transparent);
  border-color:color-mix(in srgb, var(--portal-accent) 45%, transparent);
  color:var(--portal-text);
}

/* =========================
   MAP STATUS
========================= */
.portal-map-status{
  position:absolute;
  left:16px;
  bottom:16px;
  z-index:var(--z-map-status);
  padding:10px 12px;
  border-radius:14px;
  color:var(--portal-muted);
  font-size:.85rem;
  max-width:min(80%, 360px);
}

/* =========================
   MAP
========================= */
.portal-map{
  border-radius:28px !important;
  overflow:hidden;
  min-height:420px;
  height:calc(100dvh - var(--header-h) - var(--footer-h) - var(--safe-top) - var(--safe-bottom) - 42px);
}

.leaflet-container{
  background:color-mix(in srgb, var(--portal-bg) 92%, #000 8%);
}

.leaflet-control-attribution{
  font-size:.68rem;
}

.leaflet-popup-content-wrapper,
.leaflet-popup-tip{
  background:var(--portal-card);
  color:var(--portal-text);
  border:1px solid var(--portal-line);
}

.leaflet-popup-content{
  color:var(--portal-text);
}

.leaflet-popup-content a{
  color:var(--portal-accent);
}

.leaflet-bar a,
.leaflet-bar a:hover{
  background:var(--portal-card);
  color:var(--portal-text);
  border-bottom-color:var(--portal-line);
}

.leaflet-control-zoom a{
  border-color:var(--portal-line);
}

/* =========================
   PANELS UNDER MAP
========================= */
.portal-panels{
  display:grid;
  grid-template-columns:1.25fr .95fr;
  gap:14px;
  margin-top:14px;
}

.glass-card{
  border-radius:28px;
  padding:20px;
}

.hero-card__eyebrow{
  display:inline-flex;
  margin-bottom:10px;
  color:var(--portal-accent);
  text-transform:uppercase;
  font-size:.75rem;
  letter-spacing:.1em;
}

.hero-card h2{
  margin:0 0 10px;
  font-size:clamp(1.5rem, 3vw, 2.35rem);
}

.hero-card p{
  margin:0;
  color:var(--portal-muted);
  line-height:1.55;
}

.hero-card__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
}

.mini-card-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}

.mini-card{
  padding:16px;
  border-radius:20px;
  background:color-mix(in srgb, var(--portal-card-2) 78%, transparent);
  border:1px solid var(--portal-line);
}

.mini-card i{
  font-size:1.2rem;
  color:var(--portal-accent);
}

.mini-card strong{
  display:block;
  margin:10px 0 6px;
}

.mini-card p{
  margin:0;
  color:var(--portal-muted);
  font-size:.92rem;
  line-height:1.45;
}

/* =========================
   DRAWER
========================= */
.portal-drawer{
  position:fixed;
  top:12px;
  bottom:12px;
  left:12px;
  width:min(360px, calc(100vw - 24px));
  z-index:var(--z-drawer);
  border-radius:28px;
  padding:18px;
  transform:translateX(calc(-100% - 24px));
  transition:transform .28s ease;
  overflow:auto;
}

.portal-drawer.is-open{
  transform:translateX(0);
}

.portal-drawer__head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:18px;
}

.portal-drawer__head p{
  margin:6px 0 0;
  color:var(--portal-muted);
}

.portal-nav{
  display:grid;
  gap:16px;
}

.portal-nav__title{
  display:block;
  margin-bottom:8px;
  color:var(--portal-muted);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.74rem;
}

.portal-nav__section a,
.portal-nav__linkbtn{
  width:100%;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid transparent;
  background:transparent;
  color:var(--portal-text);
  text-decoration:none;
  text-align:left;
  font:inherit;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease, transform .18s ease, opacity .18s ease;
}

.portal-nav__section a:hover,
.portal-nav__linkbtn:hover{
  background:color-mix(in srgb, var(--portal-card-2) 68%, transparent);
  border-color:var(--portal-line);
  transform:translateX(2px);
}

.portal-nav__section a i,
.portal-nav__linkbtn i{
  width:18px;
  text-align:center;
  flex:0 0 18px;
}

.portal-nav__linkbtn[disabled]{
  opacity:.7;
  cursor:wait;
  transform:none;
}

.portal-install-btn{
  margin-top:8px;
  border-color:color-mix(in srgb, var(--portal-accent) 44%, var(--portal-line));
  background:linear-gradient(
    135deg,
    color-mix(in srgb, var(--portal-accent) 16%, transparent),
    color-mix(in srgb, var(--portal-accent-2) 16%, transparent)
  );
}

.portal-install-btn span{
  font-weight:700;
}

.portal-nav__hint{
  margin:10px 2px 0;
  color:var(--portal-muted);
  font-size:.84rem;
  line-height:1.45;
}

.portal-backdrop{
  position:fixed;
  inset:0;
  background:var(--portal-overlay);
  z-index:var(--z-backdrop);
}

/* =========================
   MOBILE FOOTER NAV
========================= */
.portal-footer-nav{
  position:fixed;
  left:12px;
  right:12px;
  bottom:calc(12px + var(--safe-bottom));
  z-index:var(--z-footer);
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:8px;
  padding:8px;
  border-radius:22px;
  background:color-mix(in srgb, var(--portal-bg) 78%, transparent);
  backdrop-filter:blur(18px);
  border:1px solid var(--portal-line);
  box-shadow:var(--portal-shadow);
}

.portal-footer-nav a,
.portal-footer-nav button{
  min-height:58px;
  border:none;
  background:transparent;
  border-radius:16px;
  color:var(--portal-text);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
}

.portal-footer-nav span{
  font-size:.75rem;
  color:var(--portal-muted);
}

/* =========================
   DESKTOP / TABLET HELPERS
========================= */
.portal-desktop-only{ display:none; }
.portal-mobile-only{ display:initial; }

/* =========================================================
   BREAKPOINTS
========================================================= */
@media (max-width:980px){
  .portal-panels{
    grid-template-columns:1fr;
  }
}

@media (max-width:760px){
  .portal-brand__text small{
    display:none;
  }

  .portal-main{
    padding-left:10px;
    padding-right:10px;
  }

  .portal-search-floating{
    left:12px;
    right:12px;
    top:12px;
  }

  .portal-search__bar{
    padding:11px 12px;
  }

  .portal-map{
    min-height:calc(100dvh - var(--header-h) - var(--footer-h) - var(--safe-top) - var(--safe-bottom) - 28px);
  }

  .portal-filter-sheet{
    position:fixed;
    left:12px;
    right:12px;
    bottom:calc(96px + var(--safe-bottom));
    top:auto;
    z-index:var(--z-filter);
    max-height:58dvh;
  }

  .portal-drawer{
    width:min(360px, calc(100vw - 24px));
  }
}

@media (max-width:760px) and (orientation:portrait){
  .portal-header{
    height:calc(var(--header-h) + var(--safe-top));
  }

  .portal-footer-nav{
    display:grid;
  }
}

@media (max-width:900px) and (orientation:landscape){
  :root{
    --header-h:58px;
  }

  .portal-header{
    height:calc(var(--header-h-compact) + var(--safe-top));
    padding:
      calc(8px + var(--safe-top))
      calc(12px + var(--safe-right))
      8px
      calc(12px + var(--safe-left));
  }

  .portal-brand__logo,
  .icon-btn{
    width:40px;
    height:40px;
    border-radius:14px;
  }

  .portal-brand__text strong{
    font-size:.95rem;
  }

  .portal-brand__text small{
    display:none;
  }

  .portal-main{
    padding:
      calc(var(--header-h-compact) + var(--safe-top) + 8px)
      10px
      10px
      10px;
  }

  .portal-footer-nav{
    display:none;
  }

  .portal-search-floating{
    top:10px;
    left:10px;
    right:10px;
  }

  .portal-search__bar{
    border-radius:18px;
    padding:10px 12px;
  }

  .portal-map{
    min-height:calc(100dvh - var(--header-h-compact) - var(--safe-top) - 18px);
    height:calc(100dvh - var(--header-h-compact) - var(--safe-top) - 18px);
    border-radius:22px !important;
  }

  .portal-map-status{
    bottom:12px;
    left:12px;
    padding:8px 10px;
    font-size:.8rem;
  }

  .portal-filter-sheet{
    position:fixed;
    top:calc(var(--header-h-compact) + var(--safe-top) + 8px);
    right:10px;
    left:auto;
    bottom:10px;
    width:min(420px, calc(100vw - 20px));
    margin-top:0;
    z-index:var(--z-filter);
    max-height:none;
    border-radius:20px;
  }

  .portal-panels{
    display:none;
  }

  .portal-drawer{
    top:8px;
    bottom:8px;
    left:8px;
    width:min(340px, calc(100vw - 16px));
    border-radius:22px;
  }
}

@media (min-width:761px) and (max-width:1199px){
  .portal-main{
    padding-bottom:18px;
  }

  .portal-footer-nav{
    display:none;
  }

  .portal-map{
    min-height:calc(100dvh - var(--header-h) - var(--safe-top) - 36px);
    height:calc(100dvh - var(--header-h) - var(--safe-top) - 36px);
  }

  .portal-filter-sheet{
    position:absolute;
    top:0;
    right:0;
    left:auto;
    margin-top:0;
    width:min(460px, 44vw);
    max-width:460px;
    max-height:min(72dvh, 760px);
    z-index:var(--z-filter);
  }

  .portal-drawer{
    width:min(380px, 40vw);
  }

  .portal-desktop-only{
    display:initial;
  }
}

@media (min-width:1200px){
  .portal-main{
    padding:
      calc(var(--header-h) + var(--safe-top) + 16px)
      18px
      18px
      18px;
  }

  .portal-footer-nav{
    display:none;
  }

  .portal-header{
    padding:
      calc(10px + var(--safe-top))
      calc(20px + var(--safe-right))
      10px
      calc(20px + var(--safe-left));
  }

  .portal-search-floating{
    top:18px;
    left:18px;
    right:auto;
    width:min(520px, calc(100% - 36px));
  }

  .portal-search{
    width:100%;
  }

  .portal-filter-sheet{
    position:absolute;
    top:0;
    right:0;
    left:auto;
    width:min(480px, 34vw);
    max-width:480px;
    margin-top:0;
    max-height:min(72dvh, 760px);
    z-index:var(--z-filter);
  }

  .portal-map{
    min-height:calc(100dvh - var(--header-h) - var(--safe-top) - 42px);
    height:calc(100dvh - var(--header-h) - var(--safe-top) - 42px);
  }

  .portal-drawer{
    width:min(400px, 28vw);
  }

  .portal-panels{
    grid-template-columns:minmax(0, 1.2fr) minmax(320px, .9fr);
    gap:16px;
  }

  .portal-desktop-only{
    display:initial;
  }

  .portal-mobile-only{
    display:none;
  }
}

@media (max-width:390px){
  .portal-brand__logo,
  .icon-btn{
    width:42px;
    height:42px;
    border-radius:14px;
  }
  
  #mobile_disabled_{
  	display:none;
  }

  .portal-brand__text strong{
    font-size:.94rem;
  }

  .portal-footer-nav{
    left:10px;
    right:10px;
    gap:6px;
    padding:6px;
  }

  .portal-footer-nav a,
  .portal-footer-nav button{
    min-height:54px;
  }

  .portal-footer-nav span{
    font-size:.7rem;
  }

  .portal-map{
    border-radius:22px !important;
  }
}

/* =========================================================
   ANIMATIONS
========================================================= */
@keyframes portal-loader-wave{
  0%,100%{
    transform:scaleY(.55);
    opacity:.45;
  }
  50%{
    transform:scaleY(1.08);
    opacity:1;
  }
}

@keyframes portal-bg-soft-move{
  from{
    transform:scale(1.03) translate3d(0,0,0);
  }
  to{
    transform:scale(1.06) translate3d(6px,-4px,0);
  }
}

@keyframes portal-letter-soft-in{
  from{
    opacity:0;
    transform:translateY(16px);
    filter:blur(8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
    filter:blur(0);
  }
}

@keyframes portal-logo-soft-pop{
  from{
    opacity:0;
    transform:translateY(10px) scale(.9);
  }
  to{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

@keyframes portal-fade-up{
  from{
    opacity:0;
    transform:translateY(10px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* ===============================
   COOKIE CONSENT
================================ */
.cookie-consent{
  position:fixed;
  left:0;
  right:0;
  bottom:calc(14px + env(safe-area-inset-bottom, 0px));
  z-index:var(--z-cookie);
  padding:0 14px;
  pointer-events:none;
}

.cookie-consent__card{
  max-width:980px;
  margin:0 auto;
  border-radius:20px;
  border:1px solid var(--border, rgba(255,255,255,.10));
  background:color-mix(in srgb, var(--surface, rgba(20,20,20,.94)) 92%, black 8%);
  box-shadow:0 18px 50px rgba(0,0,0,.28);
  padding:16px;
  display:grid;
  gap:14px;
  pointer-events:auto;
  backdrop-filter:blur(16px);
}

.cookie-consent__text strong{
  display:block;
  margin-bottom:6px;
  font-size:1rem;
}

.cookie-consent__text p{
  margin:0;
  color:var(--text-2, rgba(255,255,255,.78));
  line-height:1.6;
}

.cookie-consent__links{
  margin-top:10px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.cookie-consent__links a{
  text-decoration:none;
  font-weight:600;
}

.cookie-consent__actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.cookie-consent__actions .btn,
.cookie-consent__panel-actions .btn{
  appearance:none;
  border:0;
  border-radius:12px;
  padding:11px 14px;
  font:inherit;
  cursor:pointer;
}

.cookie-consent__actions .btn-primary,
.cookie-consent__panel-actions .btn-primary{
  background:var(--accent, #3b82f6);
  color:#fff;
}

.cookie-consent__actions .btn-soft{
  background:rgba(255,255,255,.08);
  color:var(--text, #fff);
}

.cookie-consent__actions .btn-ghost{
  background:transparent;
  color:var(--text, #fff);
  border:1px solid var(--border, rgba(255,255,255,.10));
}

.cookie-consent__panel{
  border-top:1px solid var(--border, rgba(255,255,255,.08));
  padding-top:12px;
  display:grid;
  gap:10px;
}

.cookie-consent__toggle{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:.96rem;
}

.cookie-consent__toggle input{
  width:18px;
  height:18px;
}

.cookie-consent__panel-actions{
  padding-top:4px;
}

/* =========================================================
   ADS / SOCIAL
========================================================= */
.pp-ads-grid,
.pp-social-grid{
  display:grid;
  gap:12px;
}

.pp-ads-grid{
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
}

.pp-adv-badge{
  color:var(--text-2, rgba(255,255,255,.72));
}

.pp-adv-card{
  display:flex;
  flex-direction:column;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--border, rgba(255,255,255,.08));
  background:var(--surface-2, rgba(255,255,255,.04));
}

.pp-adv-card__image img{
  display:block;
  width:100%;
  height:180px;
  object-fit:cover;
}

.pp-adv-card__body{
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.pp-adv-card__cta{
  text-decoration:none;
}

.pp-social-grid{
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
}

.pp-social-link{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
  padding:14px;
  border-radius:14px;
  border:1px solid var(--border, rgba(255,255,255,.08));
  background:var(--surface-2, rgba(255,255,255,.04));
  text-decoration:none;
}

.pp-social-link__icon{
  width:42px;
  height:42px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex:0 0 42px;
  border:1px solid var(--border, rgba(255,255,255,.08));
  background:rgba(255,255,255,.06);
}

.pp-social-link__text{
  display:flex;
  flex-direction:column;
  min-width:0;
  gap:2px;
}

.pp-social-link__text small{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:var(--text-2, rgba(255,255,255,.72));
}

.pp-social-link__arrow{
  margin-left:auto;
}

/* =========================================================
   EVENTI PUBBLICI / CALENDARIO MENSILE / LISTE EVENTI
========================================================= */
.pp-events{
  --pp-ev-bg: var(--surface, #ffffff);
  --pp-ev-bg-soft: color-mix(in srgb, var(--surface, #ffffff) 88%, transparent);
  --pp-ev-card: color-mix(in srgb, var(--surface, #ffffff) 94%, transparent);
  --pp-ev-card-hover: color-mix(in srgb, var(--surface, #ffffff) 100%, var(--primary, #2563eb) 4%);
  --pp-ev-border: var(--border, rgba(15, 23, 42, 0.12));
  --pp-ev-text: var(--text, #0f172a);
  --pp-ev-muted: var(--muted, #64748b);
  --pp-ev-primary: var(--primary, #2563eb);
  --pp-ev-primary-soft: color-mix(in srgb, var(--primary, #2563eb) 14%, transparent);
  --pp-ev-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  --pp-ev-shadow-hover: 0 16px 38px rgba(15, 23, 42, 0.14);
  --pp-ev-radius: 22px;
  color:var(--pp-ev-text);
}

html[data-theme="dark"] .pp-events,
body.dark .pp-events,
.theme-dark .pp-events{
  --pp-ev-bg: color-mix(in srgb, var(--surface, #0f172a) 96%, black 4%);
  --pp-ev-bg-soft: color-mix(in srgb, var(--surface, #0f172a) 88%, white 2%);
  --pp-ev-card: color-mix(in srgb, var(--surface, #0f172a) 92%, white 3%);
  --pp-ev-card-hover: color-mix(in srgb, var(--surface, #0f172a) 88%, var(--primary, #60a5fa) 10%);
  --pp-ev-border: rgba(255,255,255,.10);
  --pp-ev-text: var(--text, #e5eefc);
  --pp-ev-muted: color-mix(in srgb, var(--text, #e5eefc) 62%, transparent);
  --pp-ev-primary: var(--primary, #60a5fa);
  --pp-ev-primary-soft: color-mix(in srgb, var(--primary, #60a5fa) 18%, transparent);
  --pp-ev-shadow: 0 12px 34px rgba(0,0,0,.34);
  --pp-ev-shadow-hover: 0 16px 42px rgba(0,0,0,.45);
}

.pp-events-list,
.pp-events-groups{
  display:grid;
  gap:16px;
}

.pp-events-group{
  display:grid;
  gap:14px;
}

.pp-events-group__title{
  margin:4px 0 0;
  font-size:1rem;
  font-weight:800;
  letter-spacing:.01em;
  color:var(--pp-ev-text);
}

.pp-event-card{
  display:grid;
  grid-template-columns:minmax(88px, 116px) 1fr auto;
  gap:16px;
  align-items:center;
  padding:16px 18px;
  border-radius:var(--pp-ev-radius);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--pp-ev-card) 100%, transparent), color-mix(in srgb, var(--pp-ev-card) 96%, var(--pp-ev-primary) 1%));
  border:1px solid var(--pp-ev-border);
  box-shadow:var(--pp-ev-shadow);
  text-decoration:none;
  color:inherit;
  position:relative;
  overflow:hidden;
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    background .18s ease;
}

.pp-event-card::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg, var(--pp-ev-primary), color-mix(in srgb, var(--pp-ev-primary) 55%, white 45%));
  opacity:.9;
}

.pp-event-card:hover,
.pp-event-card:focus-visible{
  transform:translateY(-2px);
  background:var(--pp-ev-card-hover);
  border-color:color-mix(in srgb, var(--pp-ev-primary) 22%, var(--pp-ev-border));
  box-shadow:var(--pp-ev-shadow-hover);
}

.pp-event-card:focus-visible{
  outline:2px solid color-mix(in srgb, var(--pp-ev-primary) 38%, transparent);
  outline-offset:3px;
}

.pp-event-card__date{
  display:grid;
  gap:4px;
  align-content:start;
  padding:10px 12px;
  border-radius:16px;
  background:var(--pp-ev-primary-soft);
  color:var(--pp-ev-text);
  min-height:72px;
}

.pp-event-card__date strong{
  font-size:.95rem;
  line-height:1.15;
  font-weight:800;
}

.pp-event-card__date small{
  font-size:.78rem;
  color:var(--pp-ev-muted);
  line-height:1.3;
}

.pp-event-card__body{
  display:grid;
  gap:6px;
  min-width:0;
}

.pp-event-card__body > strong{
  font-size:1rem;
  line-height:1.3;
  font-weight:800;
  color:var(--pp-ev-text);
}

.pp-event-card__body .muted{
  color:var(--pp-ev-muted);
  font-size:.94rem;
  line-height:1.45;
}

.pp-event-card__meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  font-size:.84rem;
  color:var(--pp-ev-muted);
}

.pp-event-card__meta span{
  display:inline-flex;
  align-items:center;
}

.pp-event-card__arrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:999px;
  background:color-mix(in srgb, var(--pp-ev-primary) 10%, transparent);
  color:var(--pp-ev-primary);
  flex-shrink:0;
  transition:transform .18s ease, background .18s ease;
}

.pp-event-card:hover .pp-event-card__arrow,
.pp-event-card:focus-visible .pp-event-card__arrow{
  transform:translateX(2px);
  background:color-mix(in srgb, var(--pp-ev-primary) 18%, transparent);
}

.pp-events-calendar{
  display:grid;
  gap:18px;
  padding:18px;
  border-radius:calc(var(--pp-ev-radius) + 4px);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--pp-ev-primary) 10%, transparent), transparent 34%),
    linear-gradient(180deg, var(--pp-ev-bg-soft), color-mix(in srgb, var(--pp-ev-bg) 98%, transparent));
  border:1px solid var(--pp-ev-border);
  box-shadow:var(--pp-ev-shadow);
}

.pp-events-calendar__nav{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:10px;
}

.pp-events-calendar__nav strong{
  text-align:center;
  font-size:1.05rem;
  font-weight:800;
  letter-spacing:.01em;
  color:var(--pp-ev-text);
}

.pp-events-calendar__nav .btn{
  min-width:42px;
  min-height:42px;
  border-radius:14px;
}

.pp-calendar-pane{
  display:none;
}

.pp-calendar-pane.is-active{
  display:block;
  animation:ppCalFade .18s ease;
}

@keyframes ppCalFade{
  from{
    opacity:0;
    transform:translateY(3px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.pp-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7, minmax(0,1fr));
  gap:10px;
}

.pp-calendar-grid--head{
  margin-bottom:10px;
}

.pp-calendar-grid--head > div{
  text-align:center;
  font-size:.78rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--pp-ev-muted);
  padding:8px 4px;
}

.pp-calendar-day{
  min-height:124px;
  display:grid;
  align-content:start;
  gap:10px;
  padding:12px;
  border-radius:18px;
  border:1px solid var(--pp-ev-border);
  background:color-mix(in srgb, var(--pp-ev-card) 100%, transparent);
  box-shadow:0 4px 16px rgba(15,23,42,.04);
  position:relative;
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.pp-calendar-day:hover{
  transform:translateY(-1px);
  border-color:color-mix(in srgb, var(--pp-ev-primary) 22%, var(--pp-ev-border));
  box-shadow:0 10px 24px rgba(15,23,42,.08);
}

.pp-calendar-day.is-empty{
  background:transparent;
  border-style:dashed;
  opacity:.42;
  box-shadow:none;
}

.pp-calendar-day.has-events{
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--pp-ev-card) 100%, transparent), color-mix(in srgb, var(--pp-ev-primary-soft) 42%, transparent));
}

.pp-calendar-day__num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  font-size:.88rem;
  font-weight:800;
  background:color-mix(in srgb, var(--pp-ev-primary) 10%, transparent);
  color:var(--pp-ev-text);
}

.pp-calendar-day__events{
  display:grid;
  gap:6px;
}

.pp-calendar-pill{
  display:block;
  padding:8px 10px;
  border-radius:12px;
  background:color-mix(in srgb, var(--pp-ev-primary) 11%, transparent);
  border:1px solid color-mix(in srgb, var(--pp-ev-primary) 16%, transparent);
  color:var(--pp-ev-text);
  font-size:.8rem;
  line-height:1.3;
  font-weight:700;
  text-decoration:none;
  transition:transform .14s ease, background .14s ease, border-color .14s ease;
}

.pp-calendar-pill:hover,
.pp-calendar-pill:focus-visible{
  transform:translateX(1px);
  background:color-mix(in srgb, var(--pp-ev-primary) 18%, transparent);
  border-color:color-mix(in srgb, var(--pp-ev-primary) 28%, transparent);
  outline:none;
}

.pp-calendar-more{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:fit-content;
  padding:4px 9px;
  border-radius:999px;
  background:color-mix(in srgb, var(--pp-ev-text) 8%, transparent);
  color:var(--pp-ev-muted);
  font-size:.75rem;
  font-weight:700;
}

.pp-events > h2{
  margin-bottom:8px;
  font-size:clamp(1.25rem, 1.1rem + .6vw, 1.8rem);
  line-height:1.15;
}

.pp-events > .muted{
  color:var(--pp-ev-muted);
  max-width:70ch;
}

.pp-events .pp-event-card,
.pp-events .pp-calendar-day,
.pp-events .pp-calendar-pill{
  will-change:transform;
}

/* =========================================================
   SIDEBAR EVENTI - variante compatta
========================================================= */
.pp-block.pp-events{
  position:relative;
}

.public-page-aside .pp-events,
aside .pp-events,
.pp-layout-sidebar .pp-events{
  --pp-side-radius:20px;
}

.public-page-aside .pp-events .pp-events-list,
aside .pp-events .pp-events-list,
.pp-layout-sidebar .pp-events .pp-events-list{
  gap:12px;
}

.public-page-aside .pp-events .pp-event-card,
aside .pp-events .pp-event-card,
.pp-layout-sidebar .pp-events .pp-event-card{
  grid-template-columns:1fr;
  gap:10px;
  padding:14px 14px 13px;
  border-radius:var(--pp-side-radius);
  box-shadow:0 8px 24px rgba(15,23,42,.08);
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--pp-ev-card) 100%, transparent),
      color-mix(in srgb, var(--pp-ev-primary-soft) 32%, transparent)
    );
}

.public-page-aside .pp-events .pp-event-card::before,
aside .pp-events .pp-event-card::before,
.pp-layout-sidebar .pp-events .pp-event-card::before{
  width:100%;
  height:3px;
  inset:0 0 auto 0;
  background:linear-gradient(90deg, var(--pp-ev-primary), color-mix(in srgb, var(--pp-ev-primary) 45%, white 55%));
}

.public-page-aside .pp-events .pp-event-card:hover,
aside .pp-events .pp-event-card:hover,
.pp-layout-sidebar .pp-events .pp-event-card:hover,
.public-page-aside .pp-events .pp-event-card:focus-visible,
aside .pp-events .pp-event-card:focus-visible,
.pp-layout-sidebar .pp-events .pp-event-card:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(15,23,42,.12);
}

.public-page-aside .pp-events .pp-event-card__date,
aside .pp-events .pp-event-card__date,
.pp-layout-sidebar .pp-events .pp-event-card__date{
  width:100%;
  min-height:auto;
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 11px;
  border-radius:14px;
  background:color-mix(in srgb, var(--pp-ev-primary) 12%, transparent);
}

.public-page-aside .pp-events .pp-event-card__date strong,
aside .pp-events .pp-event-card__date strong,
.pp-layout-sidebar .pp-events .pp-event-card__date strong{
  font-size:.84rem;
  line-height:1.1;
  font-weight:800;
}

.public-page-aside .pp-events .pp-event-card__date small,
aside .pp-events .pp-event-card__date small,
.pp-layout-sidebar .pp-events .pp-event-card__date small{
  font-size:.72rem;
  line-height:1.2;
  color:var(--pp-ev-muted);
}

.public-page-aside .pp-events .pp-event-card__body,
aside .pp-events .pp-event-card__body,
.pp-layout-sidebar .pp-events .pp-event-card__body{
  gap:5px;
}

.public-page-aside .pp-events .pp-event-card__body > strong,
aside .pp-events .pp-event-card__body > strong,
.pp-layout-sidebar .pp-events .pp-event-card__body > strong{
  font-size:.95rem;
  line-height:1.28;
  font-weight:800;
  letter-spacing:-.01em;
}

.public-page-aside .pp-events .pp-event-card__body .muted,
aside .pp-events .pp-event-card__body .muted,
.pp-layout-sidebar .pp-events .pp-event-card__body .muted{
  font-size:.83rem;
  line-height:1.35;
  color:var(--pp-ev-muted);
}

.public-page-aside .pp-events .pp-event-card__meta,
aside .pp-events .pp-event-card__meta,
.pp-layout-sidebar .pp-events .pp-event-card__meta{
  gap:4px 8px;
  font-size:.76rem;
  line-height:1.25;
}

.public-page-aside .pp-events .pp-event-card__arrow,
aside .pp-events .pp-event-card__arrow,
.pp-layout-sidebar .pp-events .pp-event-card__arrow{
  display:none;
}

.public-page-aside .pp-events > h2,
aside .pp-events > h2,
.pp-layout-sidebar .pp-events > h2{
  font-size:1.05rem;
  line-height:1.15;
  margin-bottom:6px;
  display:flex;
  align-items:center;
  gap:8px;
}

.public-page-aside .pp-events > h2::before,
aside .pp-events > h2::before,
.pp-layout-sidebar .pp-events > h2::before{
  content:"";
  display:inline-block;
  width:10px;
  height:10px;
  border-radius:999px;
  background:linear-gradient(180deg, var(--pp-ev-primary), color-mix(in srgb, var(--pp-ev-primary) 45%, white 55%));
  box-shadow:0 0 0 6px color-mix(in srgb, var(--pp-ev-primary) 10%, transparent);
}

.public-page-aside .pp-events > .muted,
aside .pp-events > .muted,
.pp-layout-sidebar .pp-events > .muted{
  font-size:.84rem;
  line-height:1.4;
  margin-bottom:12px !important;
}

.public-page-aside .pp-events.is-compact .pp-event-card,
aside .pp-events.is-compact .pp-event-card,
.pp-layout-sidebar .pp-events.is-compact .pp-event-card{
  padding:12px;
  gap:8px;
  border-radius:16px;
}

.public-page-aside .pp-events.is-compact .pp-event-card__body > strong,
aside .pp-events.is-compact .pp-event-card__body > strong,
.pp-layout-sidebar .pp-events.is-compact .pp-event-card__body > strong{
  font-size:.89rem;
}

.public-page-aside .pp-events.is-compact .pp-event-card__meta,
aside .pp-events.is-compact .pp-event-card__meta,
.pp-layout-sidebar .pp-events.is-compact .pp-event-card__meta{
  font-size:.72rem;
}

.public-page-aside .pp-events + .pp-events,
aside .pp-events + .pp-events,
.pp-layout-sidebar .pp-events + .pp-events{
  margin-top:2px;
}

html[data-theme="dark"] .public-page-aside .pp-events .pp-event-card,
html[data-theme="dark"] aside .pp-events .pp-event-card,
body.dark .public-page-aside .pp-events .pp-event-card,
body.dark aside .pp-events .pp-event-card,
.theme-dark .public-page-aside .pp-events .pp-event-card,
.theme-dark aside .pp-events .pp-event-card{
  box-shadow:0 10px 26px rgba(0,0,0,.34);
}

html[data-theme="dark"] .public-page-aside .pp-events .pp-event-card:hover,
html[data-theme="dark"] aside .pp-events .pp-event-card:hover,
body.dark .public-page-aside .pp-events .pp-event-card:hover,
body.dark aside .pp-events .pp-event-card:hover,
.theme-dark .public-page-aside .pp-events .pp-event-card:hover,
.theme-dark aside .pp-events .pp-event-card:hover{
  box-shadow:0 14px 32px rgba(0,0,0,.42);
}

/* =========================================================
   SEZIONE SPONSOR / TOP
========================================================= */
.pp-sponsors{
  --pp-sp-bg: var(--surface, #ffffff);
  --pp-sp-card: color-mix(in srgb, var(--surface, #ffffff) 96%, transparent);
  --pp-sp-card-hover: color-mix(in srgb, var(--surface, #ffffff) 90%, var(--primary, #2563eb) 6%);
  --pp-sp-border: var(--border, rgba(15, 23, 42, 0.12));
  --pp-sp-text: var(--text, #0f172a);
  --pp-sp-muted: var(--muted, #64748b);
  --pp-sp-accent: var(--primary, #2563eb);
  --pp-sp-accent-2: var(--accent, #14b8a6);
  --pp-sp-shadow: 0 12px 34px rgba(15,23,42,.08);
  --pp-sp-shadow-hover: 0 18px 40px rgba(15,23,42,.14);
  --pp-sp-radius: 24px;
  color:var(--pp-sp-text);
  display:grid;
  gap:22px;
}

html[data-theme="dark"] .pp-sponsors,
body.dark .pp-sponsors,
.theme-dark .pp-sponsors{
  --pp-sp-bg: color-mix(in srgb, var(--surface, #0f172a) 96%, black 4%);
  --pp-sp-card: color-mix(in srgb, var(--surface, #0f172a) 92%, white 3%);
  --pp-sp-card-hover: color-mix(in srgb, var(--surface, #0f172a) 86%, var(--primary, #60a5fa) 10%);
  --pp-sp-border: rgba(255,255,255,.10);
  --pp-sp-text: var(--text, #e5eefc);
  --pp-sp-muted: color-mix(in srgb, var(--text, #e5eefc) 62%, transparent);
  --pp-sp-accent: var(--primary, #60a5fa);
  --pp-sp-accent-2: var(--accent, #5eead4);
  --pp-sp-shadow: 0 12px 34px rgba(0,0,0,.34);
  --pp-sp-shadow-hover: 0 18px 44px rgba(0,0,0,.46);
}

.pp-sponsors__intro{
  display:grid;
  gap:8px;
}

.pp-sponsors__intro h2{
  margin:0;
}

.pp-sponsors__intro .muted{
  margin:0;
  color:var(--pp-sp-muted);
}

.pp-sponsors__group{
  display:grid;
  gap:16px;
}

.pp-sponsors__group-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.pp-sponsors__group-head h3{
  margin:0;
  font-size:1.04rem;
  font-weight:800;
  letter-spacing:.01em;
  color:var(--pp-sp-text);
}

.pp-sponsors__group-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--pp-sp-accent) 18%, var(--pp-sp-border));
  background:color-mix(in srgb, var(--pp-sp-accent) 10%, transparent);
  color:var(--pp-sp-accent);
  font-size:.8rem;
  font-weight:800;
  letter-spacing:.02em;
}

.pp-sponsors__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  gap:16px;
}

.pp-sponsors__grid--secondary{
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
}

.pp-sponsor-card,
.pp-top-card{
  position:relative;
  display:grid;
  align-content:start;
  min-width:0;
  min-height:100%;
  border-radius:var(--pp-sp-radius);
  overflow:hidden;
  border:1px solid var(--pp-sp-border);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--pp-sp-accent) 10%, transparent), transparent 36%),
    linear-gradient(180deg, var(--pp-sp-card), color-mix(in srgb, var(--pp-sp-card) 96%, var(--pp-sp-accent) 2%));
  box-shadow:var(--pp-sp-shadow);
  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease,
    background .18s ease;
}

.pp-sponsor-card:hover,
.pp-sponsor-card:focus-within,
.pp-top-card:hover,
.pp-top-card:focus-within{
  transform:translateY(-3px);
  box-shadow:var(--pp-sp-shadow-hover);
  border-color:color-mix(in srgb, var(--pp-sp-accent) 22%, var(--pp-sp-border));
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--pp-sp-accent) 16%, transparent), transparent 36%),
    linear-gradient(180deg, var(--pp-sp-card-hover), color-mix(in srgb, var(--pp-sp-card-hover) 96%, var(--pp-sp-accent) 3%));
}

.pp-sponsor-card::before,
.pp-top-card::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  background:linear-gradient(180deg, var(--pp-sp-accent), color-mix(in srgb, var(--pp-sp-accent-2) 60%, white 40%));
  opacity:.95;
}

.pp-sponsor-card--activity{
  background:
    radial-gradient(circle at top right, color-mix(in srgb, #f59e0b 14%, transparent), transparent 34%),
    linear-gradient(180deg, var(--pp-sp-card), color-mix(in srgb, var(--pp-sp-card) 94%, #f59e0b 4%));
}

.pp-sponsor-card--activity:hover,
.pp-sponsor-card--activity:focus-within{
  border-color:color-mix(in srgb, #f59e0b 28%, var(--pp-sp-border));
}

.pp-sponsor-card__media,
.pp-top-card__media{
  position:relative;
  aspect-ratio:16 / 9;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--pp-sp-accent) 12%, transparent), transparent 50%),
    color-mix(in srgb, var(--pp-sp-bg) 94%, transparent);
  overflow:hidden;
}

.pp-sponsor-card__media img,
.pp-top-card__media img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
}

.pp-sponsor-card__media::after,
.pp-top-card__media::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:42%;
  background:linear-gradient(180deg, transparent, rgba(15,23,42,.24));
  pointer-events:none;
}

.pp-sponsor-card__media-flag,
.pp-top-card__media-flag{
  position:absolute;
  top:14px;
  right:14px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(15,23,42,.54);
  backdrop-filter:blur(8px);
  color:#fff;
  font-size:.78rem;
  font-weight:800;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}

.pp-top-card__media-flag i{
  color:#f59e0b;
}

.pp-sponsor-card__body,
.pp-top-card__body{
  display:grid;
  gap:10px;
  padding:18px;
  min-width:0;
}

.pp-sponsor-card__badges,
.pp-top-card__badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.pp-sponsor-badge,
.pp-top-badge,
.pp-top-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  width:fit-content;
  max-width:100%;
  padding:7px 11px;
  border-radius:999px;
  border:1px solid color-mix(in srgb, var(--pp-sp-accent) 16%, var(--pp-sp-border));
  background:color-mix(in srgb, var(--pp-sp-accent) 10%, transparent);
  color:var(--pp-sp-accent);
  font-size:.78rem;
  line-height:1;
  font-weight:800;
}

.pp-top-chip{
  color:var(--pp-sp-text);
  background:color-mix(in srgb, var(--pp-sp-text) 6%, transparent);
  border-color:color-mix(in srgb, var(--pp-sp-text) 10%, transparent);
}

.pp-sponsor-card__eyebrow,
.pp-top-card__eyebrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  color:var(--pp-sp-muted);
  font-size:.8rem;
  font-weight:700;
}

.pp-sponsor-card__title,
.pp-top-card__title{
  margin:0;
  font-size:1.08rem;
  line-height:1.24;
  font-weight:900;
  letter-spacing:-.01em;
  color:var(--pp-sp-text);
}

.pp-sponsor-card__subtitle,
.pp-top-card__meta,
.pp-top-card__contact,
.pp-top-wow__meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  color:var(--pp-sp-muted);
  font-size:.88rem;
  line-height:1.45;
}

.pp-sponsor-card__text,
.pp-top-card__text{
  margin:0;
  color:var(--pp-sp-text);
  font-size:.94rem;
  line-height:1.62;
}

.pp-top-card__text{
  color:color-mix(in srgb, var(--pp-sp-text) 92%, transparent);
}

.pp-sponsor-card__footer,
.pp-top-card__footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-top:4px;
}

.pp-sponsor-card__cta,
.pp-top-card__cta,
.pp-top-wow__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:42px;
  padding:10px 14px;
  border-radius:14px;
  text-decoration:none;
  font-weight:800;
  letter-spacing:.01em;
  transition:transform .16s ease, background .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.pp-sponsor-card__cta{
  background:linear-gradient(135deg, color-mix(in srgb, var(--pp-sp-accent) 14%, transparent), color-mix(in srgb, var(--pp-sp-accent-2) 10%, transparent));
  color:var(--pp-sp-accent);
  border:1px solid color-mix(in srgb, var(--pp-sp-accent) 18%, transparent);
}

.pp-top-card__cta{
  background:linear-gradient(135deg, color-mix(in srgb, #f59e0b 18%, transparent), color-mix(in srgb, var(--pp-sp-accent) 12%, transparent));
  color:var(--pp-sp-text);
  border:1px solid color-mix(in srgb, #f59e0b 24%, transparent);
}

.pp-sponsor-card__cta:hover,
.pp-sponsor-card__cta:focus-visible,
.pp-top-card__cta:hover,
.pp-top-card__cta:focus-visible,
.pp-top-wow__cta:hover,
.pp-top-wow__cta:focus-visible{
  transform:translateX(1px);
  outline:none;
}

.pp-sponsor-card__brand,
.pp-top-card__rank{
  font-size:.8rem;
  font-weight:800;
  color:var(--pp-sp-muted);
}

.pp-top-card__rank strong{
  color:#f59e0b;
  font-weight:900;
}

.pp-sponsors--wow{
  gap:26px;
}

.pp-top-wow{
  display:grid;
  grid-template-columns:minmax(280px, 1.15fr) minmax(320px, 1fr);
  border:1px solid color-mix(in srgb, #f59e0b 28%, var(--pp-sp-border));
  border-radius:30px;
  overflow:hidden;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, #f59e0b 18%, transparent), transparent 30%),
    linear-gradient(135deg, color-mix(in srgb, var(--pp-sp-card) 96%, transparent), color-mix(in srgb, var(--pp-sp-card) 90%, #f59e0b 6%));
  box-shadow:0 24px 60px rgba(15,23,42,.16);
}

html[data-theme="dark"] .pp-top-wow,
body.dark .pp-top-wow,
.theme-dark .pp-top-wow{
  box-shadow:0 24px 60px rgba(0,0,0,.42);
}

.pp-top-wow__media{
  position:relative;
  min-height:100%;
  background:color-mix(in srgb, var(--pp-sp-bg) 94%, transparent);
}

.pp-top-wow__media img{
  width:100%;
  height:100%;
  min-height:100%;
  display:block;
  object-fit:cover;
}

.pp-top-wow__media::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:46%;
  background:linear-gradient(180deg, transparent, rgba(15,23,42,.34));
  pointer-events:none;
}

.pp-top-wow__flag{
  position:absolute;
  left:18px;
  bottom:18px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(15,23,42,.58);
  backdrop-filter:blur(10px);
  color:#fff;
  font-weight:900;
  letter-spacing:.01em;
}

.pp-top-wow__flag i{
  color:#f59e0b;
}

.pp-top-wow__body{
  display:grid;
  align-content:center;
  gap:14px;
  padding:28px;
}

.pp-top-wow__badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.pp-top-wow__eyebrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color:var(--pp-sp-muted);
  font-size:.88rem;
  font-weight:800;
}

.pp-top-wow__title{
  margin:0;
  font-size:clamp(1.6rem, 2.8vw, 2.35rem);
  line-height:1.08;
  font-weight:950;
  letter-spacing:-.03em;
  color:var(--pp-sp-text);
}

.pp-top-wow__text{
  margin:0;
  font-size:1rem;
  line-height:1.72;
  color:color-mix(in srgb, var(--pp-sp-text) 94%, transparent);
  max-width:62ch;
}

.pp-top-wow__actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:4px;
}

.pp-top-wow__cta{
  min-height:48px;
  padding:12px 18px;
  border-radius:16px;
  color:var(--pp-sp-text);
  border:1px solid color-mix(in srgb, #f59e0b 28%, transparent);
  background:linear-gradient(135deg, color-mix(in srgb, #f59e0b 20%, transparent), color-mix(in srgb, var(--pp-sp-accent) 12%, transparent));
}

.pp-top-wow__cta:hover,
.pp-top-wow__cta:focus-visible{
  transform:translateY(-1px);
  box-shadow:0 12px 24px rgba(15,23,42,.12);
}

/* =========================
   RESPONSIVE CONTENT BLOCKS
========================= */
@media (max-width:1080px){
  .pp-calendar-day{
    min-height:112px;
    padding:10px;
  }

  .pp-calendar-pill{
    font-size:.76rem;
    padding:7px 9px;
  }
}

@media (max-width:980px){
  .pp-top-wow{
    grid-template-columns:1fr;
  }

  .pp-top-wow__media{
    min-height:300px;
  }

  .pp-top-wow__body{
    padding:22px;
  }
}

@media (max-width:860px){
  .pp-event-card{
    grid-template-columns:1fr;
    gap:12px;
  }

  .pp-event-card__arrow{
    display:none;
  }

  .pp-event-card__date{
    min-height:auto;
    width:fit-content;
  }

  .pp-calendar-grid{
    gap:8px;
  }

  .pp-calendar-day{
    min-height:96px;
    border-radius:16px;
  }

  .pp-calendar-day__num{
    width:30px;
    height:30px;
    font-size:.82rem;
  }

  .public-page-aside .pp-events .pp-event-card,
  aside .pp-events .pp-event-card,
  .pp-layout-sidebar .pp-events .pp-event-card{
    padding:13px;
  }

  .public-page-aside .pp-events > h2,
  aside .pp-events > h2,
  .pp-layout-sidebar .pp-events > h2{
    font-size:1rem;
  }
}

@media (max-width:820px){
  .pp-sponsors__grid{
    grid-template-columns:1fr;
  }

  .pp-sponsor-card__body,
  .pp-top-card__body{
    padding:16px;
  }
}

@media (max-width:640px){
  .pp-events-calendar{
    padding:14px;
    border-radius:20px;
  }

  .pp-events-calendar__nav{
    grid-template-columns:40px 1fr 40px;
  }

  .pp-events-calendar__nav strong{
    font-size:.96rem;
  }

  .pp-calendar-grid--head > div{
    font-size:.68rem;
    padding:6px 2px;
  }

  .pp-calendar-grid{
    gap:6px;
  }

  .pp-calendar-day{
    min-height:82px;
    padding:8px;
    gap:6px;
    border-radius:14px;
  }

  .pp-calendar-day__events{
    gap:4px;
  }

  .pp-calendar-pill{
    padding:6px 7px;
    font-size:.7rem;
    line-height:1.2;
    border-radius:10px;
  }

  .pp-calendar-more{
    font-size:.68rem;
    padding:3px 7px;
  }

  .pp-event-card{
    padding:14px;
    border-radius:18px;
  }

  .pp-event-card__body > strong{
    font-size:.96rem;
  }

  .pp-event-card__body .muted{
    font-size:.88rem;
  }

  .public-page-aside .pp-events .pp-events-list,
  aside .pp-events .pp-events-list,
  .pp-layout-sidebar .pp-events .pp-events-list{
    gap:10px;
  }

  .public-page-aside .pp-events .pp-event-card,
  aside .pp-events .pp-event-card,
  .pp-layout-sidebar .pp-events .pp-event-card{
    padding:12px;
    border-radius:16px;
  }

  .public-page-aside .pp-events .pp-event-card__date,
  aside .pp-events .pp-event-card__date,
  .pp-layout-sidebar .pp-events .pp-event-card__date{
    padding:8px 10px;
    border-radius:12px;
  }

  .public-page-aside .pp-events .pp-event-card__body > strong,
  aside .pp-events .pp-event-card__body > strong,
  .pp-layout-sidebar .pp-events .pp-event-card__body > strong{
    font-size:.9rem;
  }
}

@media (max-width:560px){
  .pp-sponsors{
    gap:18px;
  }

  .pp-sponsors__group-head{
    align-items:flex-start;
    flex-direction:column;
  }

  .pp-sponsor-card__media,
  .pp-top-card__media{
    aspect-ratio:16 / 10;
  }

  .pp-sponsor-card__footer,
  .pp-top-card__footer{
    align-items:stretch;
    flex-direction:column;
  }

  .pp-sponsor-card__cta,
  .pp-top-card__cta{
    width:100%;
  }

  .pp-top-wow{
    border-radius:24px;
  }

  .pp-top-wow__media{
    min-height:240px;
  }

  .pp-top-wow__body{
    padding:18px;
  }

  .pp-top-wow__actions{
    flex-direction:column;
  }

  .pp-top-wow__cta{
    width:100%;
  }
}

@media (min-width:900px){
  .cookie-consent__card{
    grid-template-columns:minmax(0,1fr) auto;
    align-items:start;
  }

  .cookie-consent__panel{
    grid-column:1 / -1;
  }
}

@media (max-width:640px){
  .cookie-consent{
    padding:0 10px;
    bottom:calc(10px + env(safe-area-inset-bottom, 0px));
  }

  .cookie-consent__actions{
    flex-direction:column;
  }

  .cookie-consent__actions .btn,
  .cookie-consent__panel-actions .btn{
    width:100%;
  }
}

/* =========================
   ACCESSIBILITÀ
========================= */
@media (prefers-reduced-motion:reduce){
  .pp-event-card,
  .pp-calendar-day,
  .pp-calendar-pill,
  .pp-event-card__arrow,
  .pp-calendar-pane,
  .pp-sponsor-card,
  .pp-top-card,
  .pp-top-wow,
  .pp-top-wow__cta{
    transition:none !important;
    animation:none !important;
  }
}

.portal-modal{
  position:fixed;
  inset:0;
  z-index:1300;
  display:grid;
  place-items:center;
  padding:20px;
}

.portal-modal[hidden]{
  display:none;
}

.portal-modal__dialog{
  width:min(100%, 560px);
  border-radius:24px;
  border:1px solid var(--portal-line);
  background:var(--portal-card);
  box-shadow:0 24px 60px rgba(0,0,0,.32);
  backdrop-filter:blur(16px);
  overflow:hidden;
}

.portal-modal__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:18px 18px 14px;
  border-bottom:1px solid var(--portal-line);
}

.portal-modal__head strong{
  display:block;
  font-size:1.05rem;
}

.portal-modal__head p{
  margin:6px 0 0;
  color:var(--portal-muted);
  line-height:1.45;
}

.portal-modal__body{
  padding:18px;
}

.portal-modal__foot{
  padding:0 18px 18px;
}

.portal-install-steps{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:12px;
}

.portal-install-steps li{
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px;
  border-radius:18px;
  border:1px solid var(--portal-line);
  background:color-mix(in srgb, var(--portal-card-2) 72%, transparent);
}

.portal-install-steps__icon{
  width:42px;
  height:42px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(
    135deg,
    color-mix(in srgb, var(--portal-accent) 18%, transparent),
    color-mix(in srgb, var(--portal-accent-2) 18%, transparent)
  );
  border:1px solid color-mix(in srgb, var(--portal-accent) 38%, var(--portal-line));
  flex:0 0 42px;
}

.portal-install-steps li strong{
  display:inline-block;
  margin-right:6px;
}

body.has-modal-open{
  overflow:hidden;
}

.portal-install-tip{
  margin-top:14px;
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid color-mix(in srgb, var(--portal-accent) 26%, var(--portal-line));
  background:linear-gradient(
    135deg,
    color-mix(in srgb, var(--portal-accent) 10%, transparent),
    color-mix(in srgb, var(--portal-accent-2) 10%, transparent)
  );
  color:var(--portal-muted);
  line-height:1.45;
}

.portal-install-tip i{
  margin-top:2px;
  color:var(--portal-accent);
}

.portal-toast{
  position:fixed;
  left:50%;
  bottom:88px;
  z-index:1400;
  transform:translateX(-50%) translateY(16px);
  opacity:0;
  pointer-events:none;
  transition:transform .22s ease, opacity .22s ease;
  width:min(calc(100% - 24px), 420px);
}

.portal-toast.is-visible{
  transform:translateX(-50%) translateY(0);
  opacity:1;
}

.portal-toast__inner{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid var(--portal-line);
  background:color-mix(in srgb, var(--portal-bg-soft) 92%, transparent);
  color:var(--portal-text);
  box-shadow:0 18px 36px rgba(0,0,0,.24);
  backdrop-filter:blur(12px);
}

.portal-toast__inner i{
  color:#22c55e;
}

@media (min-width: 769px){
  .portal-toast{
    bottom:24px;
  }
}