/* ============================================================
   Vienna Photo Atlas — own page identity overrides global chrome.
   Global header (author, lang-switch, socials, made-by) hidden;
   page provides its own minimal top-right lang switcher in hero
   and full identity/contact in the outro section.
   ============================================================ */
body.is-photo-spots .author,
body.is-photo-spots .locale-switch,
body.is-photo-spots .socials,
body.is-photo-spots .made-by,
body.is-photo-spots > .skip,
body.is-photo-spots .grain{
  display:none !important;
}

/* ============================================================
   Left nav rail (desktop) / Bottom tab bar (mobile)
   ============================================================ */
.ps-nav-rail{
  position:fixed; left:0; top:0; bottom:0;
  width:78px;
  background:#0a0b0e;
  border-right:1px solid rgba(255,255,255,.06);
  z-index:100;
  display:flex; flex-direction:column;
  padding:14px 0;
  overflow-y:auto;
}
.ps-nav-rail::-webkit-scrollbar{ display:none; }

.ps-nav-brand{
  display:flex; align-items:center; justify-content:center;
  width:48px; height:48px;
  margin:0 auto 16px;
  background:#E03030;
  color:#fff;
  border-radius:10px;
  font-family:"Archivo Black", Inter, sans-serif;
  font-size:14px; font-weight:700;
  letter-spacing:-.02em;
  text-decoration:none;
  transition:background-color .2s ease;
}
.ps-nav-brand:hover{ background:#ff5050; }
.ps-nav-brand-mark{
  display:inline-flex; align-items:center; justify-content:center;
  line-height:1;
  color:#fff;
}
.ps-nav-brand-mark svg{ display:block; }

.ps-nav-items{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column;
  gap:2px;
}
.ps-nav-item{
  display:flex; flex-direction:column; align-items:center;
  gap:5px;
  padding:12px 4px;
  color:#a8acb3;
  text-decoration:none;
  font-size:10px;
  letter-spacing:.02em;
  font-weight:500;
  transition:all .15s ease;
  position:relative;
  text-align:center;
  border-radius:8px;
  margin:0 6px;
}
.ps-nav-item:before{
  content:"";
  position:absolute; left:0; top:50%; transform:translateY(-50%);
  width:3px; height:0;
  background:#E03030;
  border-radius:0 2px 2px 0;
  transition:height .2s ease;
}
.ps-nav-item:hover{
  color:#e8e9ec;
  background:rgba(255,255,255,.03);
}
.ps-nav-item.is-active{
  color:#e8e9ec;
  background:rgba(224,48,48,.06);
}
.ps-nav-item.is-active:before{
  height:24px;
}
.ps-nav-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:18px; height:18px;
  color:var(--fg-mute);
  transition:color .15s ease, transform .15s ease;
}
.ps-nav-icon svg{
  width:100%; height:100%;
  stroke:currentColor;
}
.ps-nav-item:hover .ps-nav-icon{
  color:var(--fg);
  transform:scale(1.06);
}
.ps-nav-item.is-active .ps-nav-icon{
  color:var(--accent);
  transform:scale(1.06);
}
.ps-nav-label{
  white-space:nowrap;
  font-size:9.5px;
  letter-spacing:.04em;
}

/* Page body shifts right to make room for the rail (desktop only) */
@media (min-width:768px){
  body.is-photo-spots .ps-page-body,
  body.is-photo-spots .ps-outro{
    margin-left:78px;
  }
}

/* ===== Hamburger + drawer (visible only on mobile) ===== */
.va-burger,
.va-drawer-backdrop,
.va-drawer-close{ display:none; }

/* CSS-driven body scroll-lock: only locks while drawer is actually open.
   Prevents a JS-error race from leaving body stuck in overflow:hidden. */
body:has(.ps-nav-rail.is-open){ overflow:hidden; }

/* Hide burger when a pin-detail modal is open — modal close X handles it. */
body:has(.ps-modal:not([hidden])) .va-burger{ display:none !important; }

@media (max-width:767px){
  /* Hamburger trigger — top-left fixed button, brand-red ring */
  .va-burger{
    display:flex;
    flex-direction:column; justify-content:center; align-items:center;
    gap:5px;
    position:fixed;
    top:12px; left:12px;
    z-index:1100;
    width:44px; height:44px;
    background:rgba(15,16,22,.92);
    border:1px solid rgba(255,255,255,.1);
    border-radius:12px;
    cursor:pointer;
    -webkit-backdrop-filter:blur(10px);
    backdrop-filter:blur(10px);
    box-shadow:0 4px 14px rgba(0,0,0,.4);
    -webkit-tap-highlight-color:transparent;
    transition:transform .15s, border-color .2s;
  }
  .va-burger:active{ transform:scale(.95); }
  .va-burger-bar{
    display:block;
    width:18px; height:2px;
    background:#fff;
    border-radius:1px;
    transition:transform .25s, opacity .2s;
  }
  .va-burger[aria-expanded="true"] .va-burger-bar:nth-child(1){
    transform:translateY(7px) rotate(45deg);
  }
  .va-burger[aria-expanded="true"] .va-burger-bar:nth-child(2){ opacity:0; }
  .va-burger[aria-expanded="true"] .va-burger-bar:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
  }

  /* Backdrop — pointer-events:none keeps it from blocking clicks when closed.
     The `hidden` attribute is also respected (display:none) so backdrop is
     truly inert on initial load until the user opens the drawer. */
  .va-drawer-backdrop{
    display:block;
    position:fixed; inset:0;
    z-index:1090;
    background:rgba(0,0,0,.6);
    -webkit-backdrop-filter:blur(4px);
    backdrop-filter:blur(4px);
    opacity:0;
    pointer-events:none;
    transition:opacity .26s ease;
  }
  .va-drawer-backdrop[hidden]{ display:none; }
  .va-drawer-backdrop.is-open{ opacity:1; pointer-events:auto; }

  /* Close-X inside drawer (top-right) */
  .va-drawer-close{
    display:flex; align-items:center; justify-content:center;
    position:absolute;
    top:14px; right:14px;
    width:36px; height:36px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08);
    border-radius:10px;
    color:#fff;
    cursor:pointer;
    -webkit-tap-highlight-color:transparent;
  }
  .va-drawer-close:hover{ background:rgba(255,255,255,.12); }

  /* Rail → slide-out drawer from the LEFT.
     Top padding clears the fixed burger (44px + 12px top + 12px gap). */
  .ps-nav-rail{
    position:fixed;
    top:0; left:0; bottom:0;
    width:min(78vw, 320px);
    max-width:320px;
    height:100%;
    flex-direction:column;
    border-right:1px solid rgba(255,255,255,.08);
    border-top:none;
    padding:72px 18px 32px;
    background:linear-gradient(180deg, #0e0f14 0%, #07080c 100%);
    box-shadow:8px 0 32px rgba(0,0,0,.5);
    overflow-y:auto;
    z-index:1095;
    transform:translateX(-100%);
    transition:transform .28s cubic-bezier(.4,0,.2,1);
  }
  .ps-nav-rail.is-open{ transform:translateX(0); }

  /* Brand-mark hidden on mobile — burger button represents brand presence.
     Removes the visual conflict where the red square sat under the X icon. */
  .ps-nav-brand{ display:none; }
  .ps-nav-brand-mark{ color:#fff; }
  .ps-nav-brand-mark svg{ width:24px; height:24px; }

  .ps-nav-items{
    display:flex; flex-direction:column;
    gap:4px;
  }
  .ps-nav-items > li{ display:block; }
  .ps-nav-item{
    display:flex; align-items:center; gap:14px;
    padding:14px 14px;
    border-radius:10px;
    color:rgba(255,255,255,.78);
    text-decoration:none;
    font-size:15px;
    font-weight:500;
  }
  .ps-nav-item:before{ display:none; }
  .ps-nav-item:hover{
    background:rgba(255,255,255,.05);
    color:#fff;
  }
  .ps-nav-item.is-active{
    background:linear-gradient(135deg, rgba(224,48,48,.18) 0%, rgba(255,74,74,.06) 100%);
    color:#fff;
    border:1px solid rgba(224,48,48,.32);
  }
  .ps-nav-icon{
    flex:0 0 auto;
    width:22px; height:22px;
    display:flex; align-items:center; justify-content:center;
    color:var(--accent-2,#FF4A4A);
  }
  .ps-nav-label{ display:inline; font-weight:600; letter-spacing:.01em; }

  /* No bottom-bar padding — drawer doesn't shove the layout */
  body.is-photo-spots{ padding-bottom:0; }
}

/* ============================================================
   Vienna Photo Atlas — sidebar blocks.
   Design tokens unified. Adding a new block:
     1. Create _includes/atlas/blocks/<id>.njk with .ab-block class
     2. Append a section to this file with a section-header comment
     3. Add init function to atlas-blocks.js (if hydration needed)
   ============================================================ */

/* ===== Design tokens (atlas-scoped) ===== */
.ab-grid,
.ab-block,
.ab-col-left,
.ab-col-right,
.ab-col-map{
  --ab-card-bg:           #14161b;
  --ab-card-bg-hover:     #181a20;
  --ab-card-border:       rgba(255,255,255,.06);
  --ab-card-border-hover: rgba(255,255,255,.12);
  --ab-card-radius:       10px;
  --ab-card-padding:      14px;
  --ab-card-gap:          8px;
  --ab-fg:                #e8e9ec;
  --ab-fg-mute:           #8a8f99;
  --ab-fg-dim:            #5b6068;
  --ab-accent:            #ff5050;
  --ab-accent-soft:       rgba(224,48,48,.10);
  --ab-line:              rgba(255,255,255,.06);
  --ab-easing:            cubic-bezier(.4,0,.2,1);
}

/* ===== Grid layout — ViennaGo format: BIG map left, single sidebar right ===== */
.ab-grid{
  max-width:1440px; margin:16px auto 0; padding:0 24px 0 12px;
  display:grid;
  gap:var(--ab-card-gap);
  grid-template-columns:1fr;
  grid-template-areas:
    "map"
    "right";
}
.ab-col-map{
  grid-area:map;
  max-width:none !important;
  margin:0 !important;
  padding:0 !important;
  display:flex; flex-direction:column;
  gap:var(--ab-card-gap);
}
.ab-col-map .ps-map-wrap{
  width:100%;
  border-radius:var(--ab-card-radius);
  overflow:hidden;
  position:relative;  /* anchor for floating overlay controls */
}
/* Floating dropdown over the map (top-left, glass effect) */
.ps-controls-overlay{
  position:absolute;
  top:12px; left:12px;
  z-index:500;  /* above tiles, below Leaflet zoom (z=1000) */
  margin:0 !important; padding:0 !important; max-width:none !important;
}
.ps-controls-overlay .ps-menu-trigger{
  background:rgba(20,22,27,.85);
  border-color:rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 4px 12px rgba(0,0,0,.35);
}
.ps-controls-overlay .ps-menu-trigger:hover{
  background:rgba(28,31,38,.92);
  border-color:rgba(255,255,255,.18);
}
.ps-controls-overlay .ps-menu.is-open .ps-menu-trigger{
  background:rgba(28,31,38,.95);
  border-color:rgba(255,255,255,.2);
}
.ps-controls-overlay .ps-menu-list{
  background:rgba(24,26,32,.95);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:
    0 0 0 1px rgba(0,0,0,.05),
    0 8px 16px rgba(0,0,0,.4),
    0 24px 48px rgba(0,0,0,.6);
}
.ps-controls-meta{
  display:flex; align-items:center; gap:8px;
  font-size:12px;
  color:var(--ab-fg-mute, #8a8f99);
  letter-spacing:-.005em;
}
.ps-meta-status{
  display:inline-flex; align-items:center; gap:5px;
  color:var(--ab-fg, #e8e9ec);
  font-weight:500;
}
.ps-meta-status[data-phase="golden"]{ color:#ffb84a; }
.ps-meta-status[data-phase="blue"]{   color:#4a8acc; }
.ps-meta-status[data-phase="night"]{  color:var(--ab-fg-mute, #8a8f99); }
.ps-meta-sep{
  color:var(--ab-fg-dim, #5b6068);
}
@media (max-width:640px){
  .ps-controls-meta{ font-size:11px; gap:6px; }
  .ps-meta-updated{ display:none; }
}
.ab-col-left{ display:none; } /* legacy — no longer used in ViennaGo layout */
.ab-col-right{
  grid-area:right;
  display:flex; flex-direction:column;
  gap:var(--ab-card-gap);
}
@media (min-width:1024px){
  /* last sidebar widget grows to fill column height — keeps bottom aligned with map+legend */
  .ab-col-right > :last-child{ flex:1; }
}

@media (min-width:1024px){
  .ab-grid{
    grid-template-columns:minmax(0, 1fr) 360px;
    grid-template-areas:"map right";
    align-items:stretch;
    gap:16px;
  }
  /* Sidebar flows naturally — no sticky, no internal scroll. */
  .ab-col-right{
    /* deliberately fixed-flow */
  }
}
@media (min-width:1440px){
  .ab-grid{ grid-template-columns:minmax(0, 1fr) 400px; }
}

/* ===== Block chrome — unified glass card (v2 spec §5) ===== */
.ab-block{
  --accent-line:var(--accent, #E03030);
  background:var(--glass-card, rgba(22,25,34,.62));
  backdrop-filter:var(--blur-soft, blur(12px) saturate(140%));
  -webkit-backdrop-filter:var(--blur-soft, blur(12px) saturate(140%));
  border:1px solid var(--line-1, rgba(255,255,255,.06));
  border-radius:var(--radius-md, 14px);
  padding:16px;
  font-size:var(--fs-body, 14px);
  line-height:1.45;
  color:var(--fg, #EDEEF2);
  position:relative;
  box-shadow:var(--shadow-2, 0 8px 24px rgba(0,0,0,.40));
  transition:border-color var(--dur-base, 220ms) var(--ease, cubic-bezier(.16,1,.3,1)),
             box-shadow var(--dur-base, 220ms) var(--ease, cubic-bezier(.16,1,.3,1));
}
.ab-block::before{
  content:""; position:absolute;
  top:0; left:14px; right:14px; height:2px;
  border-radius:0 0 2px 2px;
  background:linear-gradient(90deg,
    color-mix(in srgb, var(--accent-line) 65%, transparent) 0%,
    transparent 100%);
  opacity:.55;
}
.ab-block:hover{
  border-color:var(--line-2, rgba(255,255,255,.10));
}
.ab-block + .ab-block{ margin-top:12px; }

/* Per-widget accent-line tint */
.ab-best-now    { --accent-line:#FFC944; }
.ab-sun-live    { --accent-line:var(--sun-golden-pm, #FF8A3A); }
.ab-live-weather{ --accent-line:var(--cat-water, #4DA8FF); }
.ab-atlas-health{ --accent-line:var(--cat-park, #6BCB77); }
.ab-photo-events{ --accent-line:var(--sun-blue, #6F7CBF); }
.ab-permits     { --accent-line:var(--cat-art, #FFC857); }

.ab-block-head{
  display:flex; align-items:center; justify-content:space-between;
  margin:0 0 12px 0;
  gap:8px;
  min-height:18px;
}
.ab-block-title{
  display:flex; align-items:center; gap:8px;
  font-size:var(--fs-h2, 22px);
  font-weight:600;
  color:var(--fg, #EDEEF2);
  margin:0;
  letter-spacing:-0.008em;
  text-transform:none;
}
.ab-block-icon{
  flex-shrink:0;
  color:var(--accent-line, currentColor);
  opacity:.85;
}

/* Compact upcoming-events list (no calendar grid) */
.ab-photo-events-compact .ab-block-head{
  margin-bottom:8px;
}
.ab-photo-events-compact .ab-events-count{
  font-size:var(--fs-micro);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.10em;
  color:var(--fg-dim);
}
.ab-photo-events-compact .ab-events-list{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column;
  gap:0;
}
.ab-events-li{
  display:grid;
  grid-template-columns:42px 1fr auto;
  align-items:center;
  gap:12px;
  padding:10px 0;
  border-top:1px solid var(--line-1);
}
.ab-events-li:first-child{ border-top:0; }
.ab-events-date{
  display:flex; flex-direction:column; align-items:flex-start;
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.ab-events-d{
  font-size:18px;
  font-weight:700;
  color:var(--fg);
}
.ab-events-m{
  font-size:9.5px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--fg-dim);
  margin-top:2px;
}
.ab-events-meta{
  min-width:0;
  display:flex; flex-direction:column;
  gap:2px;
}
.ab-events-title{
  font-size:13px;
  font-weight:500;
  letter-spacing:-.005em;
  color:var(--fg);
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.ab-events-type{
  font-size:10px;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--fg-dim);
}
.ab-events-type-conference { color:#FF6E5A; }
.ab-events-type-workshop   { color:#FFC857; }
.ab-events-type-vernissage { color:#6BCB77; }
.ab-events-type-networking { color:#4DA8FF; }
.ab-events-link{
  font-size:18px;
  color:var(--fg-dim);
  text-decoration:none;
  transition:color var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.ab-events-link:hover{
  color:var(--accent);
  transform:translateX(2px);
}
.ab-events-empty{
  text-align:center;
  font-size:11px;
  color:var(--fg-dim);
  padding:8px 0;
}

/* Mobile-collapsible wrapper */
@media (max-width:767px){
  .ab-block[data-mobile="collapsible"]{ padding:0; }
  .ab-block[data-mobile="collapsible"] .ab-block-head{
    padding:14px;
    margin-bottom:0;
    cursor:pointer;
    user-select:none;
  }
  .ab-block[data-mobile="collapsible"]:not(.is-open) > *:not(.ab-block-head){
    display:none;
  }
  .ab-block[data-mobile="collapsible"].is-open > *:not(.ab-block-head){
    padding:0 14px 14px;
  }
  .ab-block[data-mobile="collapsible"] .ab-block-head:after{
    content:"▾";
    color:var(--ps-fg-dim);
    transition:transform .2s ease;
  }
  .ab-block[data-mobile="collapsible"].is-open .ab-block-head:after{
    transform:rotate(180deg);
  }
}

/* ===== ab-sun-live — arc edition (v2 spec §6) ===== */
.ab-sun-live-stats{
  display:flex; align-items:baseline; gap:10px;
  margin-bottom:8px;
  flex-wrap:wrap;
}
.ab-sun-live-time{
  font-size:36px;
  font-weight:700;
  color:var(--fg);
  font-variant-numeric:tabular-nums;
  letter-spacing:-.02em;
  line-height:1;
}
.ab-sun-live-phase{
  font-size:var(--fs-meta, 12px);
  font-weight:600;
  color:var(--fg-mute);
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ab-sun-live-till{
  font-size:var(--fs-meta, 12px);
  color:var(--fg-dim);
  font-variant-numeric:tabular-nums;
}
.ab-sun-live.is-night .ab-sun-live-phase{ color:var(--sun-blue, #6F7CBF); }
.ab-sun-live.is-golden .ab-sun-live-phase{ color:var(--sun-golden-pm, #FF8A3A); }

.ab-sun-arc{
  display:block;
  width:100%;
  margin:4px 0 8px;
  height:auto;
  overflow:visible;
}
.ab-sun-arc [data-sun-arc-day]{
  transition:stroke-dasharray 1.2s var(--ease, cubic-bezier(.16,1,.3,1));
}
.ab-sun-arc [data-sun-arc-disc],
.ab-sun-arc [data-sun-arc-glow]{
  transition:cx 1.2s var(--ease, cubic-bezier(.16,1,.3,1)),
             cy 1.2s var(--ease, cubic-bezier(.16,1,.3,1)),
             opacity .4s var(--ease, cubic-bezier(.16,1,.3,1));
}

.ab-sun-bar{
  position:relative;
  display:flex;
  height:8px;
  border-radius:4px;
  overflow:hidden;
  margin-bottom:10px;
  background:#1a1c22;
}
.ab-sun-segment{ flex:0 0 auto; height:100%; }
.ab-sun-night     { background:#1a1c22; }
.ab-sun-dawn      { background:#3a3a55; }
.ab-sun-golden-am { background:#d97a3a; }
.ab-sun-day       { background:#4a8acc; }
.ab-sun-golden-pm { background:#d97a3a; }
.ab-sun-dusk      { background:#5a4a8a; }
.ab-sun-cursor{
  position:absolute; top:-3px; bottom:-3px; width:2px;
  background:#fff;
  border-radius:1px;
  box-shadow:0 0 6px rgba(255,255,255,.6);
  pointer-events:none;
  transition:left .3s ease;
}

.ab-sun-times{
  list-style:none; padding:0; margin:8px 0 0;
  display:grid; grid-template-columns:1fr 1fr;
  gap:4px 10px;
  font-size:11px;
}
.ab-sun-times li{
  display:flex; align-items:center; justify-content:space-between;
  gap:6px;
  color:var(--ps-fg-mute);
}
.ab-sun-times strong{
  color:var(--ps-fg);
  font-weight:600;
  font-variant-numeric:tabular-nums;
}

/* ===== ab-todays-pick ===== */
.ab-pick-link{
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius:10px;
  overflow:hidden;
  transition:transform .2s ease;
}
.ab-pick-link:hover{ transform:translateY(-2px); }
.ab-pick-figure{
  margin:0;
  aspect-ratio:3/2;
  overflow:hidden;
  border-radius:8px;
}
.ab-pick-figure img{ width:100%; height:100%; object-fit:cover; display:block; }
.ab-pick-body{ padding:8px 0 0; }
.ab-pick-name{
  display:block;
  font-size:13px; font-weight:600;
  color:var(--ps-fg);
  line-height:1.25;
  margin-bottom:4px;
}
.ab-pick-cta{
  font-size:11px;
  color:var(--ps-accent-2);
  font-weight:600;
}

/* ===== ab-ad-promo ===== */
.ab-ad-label{
  display:inline-block;
  font-size:9px; text-transform:uppercase; letter-spacing:.1em;
  color:var(--ps-fg-dim);
  margin-bottom:6px;
}
.ab-ad-promo-link{
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius:10px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(224,48,48,.08) 0%, transparent 70%);
  border:1px solid rgba(224,48,48,.25);
  padding:10px;
  transition:border-color .2s ease;
}
.ab-ad-promo-link:hover{ border-color:var(--ps-accent); }
.ab-ad-promo-image{
  height:80px;
  background-size:cover;
  background-position:center;
  border-radius:6px;
  margin-bottom:8px;
}
.ab-ad-promo-headline{
  display:block;
  font-size:13px; font-weight:700; color:var(--ps-fg);
  margin-bottom:4px;
  line-height:1.2;
}
.ab-ad-promo-sub{
  display:block;
  font-size:11px; color:var(--ps-fg-mute);
  margin-bottom:8px;
  line-height:1.35;
}
.ab-ad-promo-cta{
  font-size:11px; font-weight:600;
  color:var(--ps-accent-2);
}

/* ===== ab-ad-partner ===== */
.ab-ad-partner-link{
  display:block;
  text-decoration:none;
  color:inherit;
  border:1px solid var(--ps-line-2);
  border-radius:10px;
  padding:10px;
  transition:border-color .2s ease;
}
.ab-ad-partner-link:hover{ border-color:var(--ps-fg-mute); }
.ab-ad-partner-image{
  height:60px;
  background-size:cover; background-position:center;
  border-radius:6px;
  margin-bottom:8px;
}
.ab-ad-partner-body strong{
  display:block;
  font-size:12px; font-weight:700; color:var(--ps-fg);
  margin-bottom:2px;
}
.ab-ad-partner-body span{
  display:block;
  font-size:11px; color:var(--ps-fg-mute);
}

/* ===== ab-atlas-health (replaces atlas-numbers) ===== */
.ab-health-list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:8px;
}
.ab-health-row{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:baseline;
  gap:8px;
  font-size:12px;
}
.ab-health-label{
  color:var(--ps-fg-mute);
  font-weight:500;
  letter-spacing:-.005em;
}
.ab-health-value{
  color:var(--ps-fg);
  font-weight:600;
  font-variant-numeric:tabular-nums;
  text-align:right;
}
.ab-health-sub{
  color:var(--ps-fg-dim);
  font-weight:500;
  font-size:10.5px;
  margin-left:1px;
}
.ab-health-bar{
  grid-column:1 / -1;
  display:block;
  width:100%; height:3px;
  background:rgba(255,255,255,.05);
  border-radius:2px;
  overflow:hidden;
  margin-top:2px;
}
.ab-health-bar-fill{
  display:block;
  height:100%;
  background:linear-gradient(90deg, var(--ps-accent) 0%, #62d29a 100%);
  border-radius:2px;
  transition:width .4s ease;
}

/* ===== ab-best-now (slider edition) ===== */
.ab-best-now{
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(255,201,68,.10) 0%, transparent 55%),
    radial-gradient(80% 60% at 100% 100%, rgba(255,201,68,.05) 0%, transparent 60%),
    var(--block-bg, rgba(255,255,255,.02));
  border-color:rgba(255,201,68,.18);
}
.ab-best-now-titleblock{
  display:flex;
  flex-direction:column;
  gap:8px;
  width:100%;
  min-width:0;
}
.ab-best-now-title-row{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.ab-best-now-title{
  font-size:18px;
  line-height:1.2;
  font-weight:700;
  letter-spacing:-.012em;
  margin:0;
  background:linear-gradient(135deg, #FFE08C 0%, #FFC944 55%, #E5A625 100%);
  -webkit-background-clip:text;
          background-clip:text;
  -webkit-text-fill-color:transparent;
          color:transparent;
  /* keep icon out of this element so it doesn't get clipped */
}
.ab-best-now-icon{
  flex-shrink:0;
  color:#FFD66B;
  filter:drop-shadow(0 0 6px rgba(255,201,68,.45));
}
.ab-best-now-status{
  display:inline-flex;
  align-items:center;
  gap:5px;
  align-self:flex-start;
  padding:3px 9px 3px 7px;
  font-size:10.5px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:none;
  color:rgba(255,224,140,.95);
  background:rgba(255,201,68,.10);
  border:1px solid rgba(255,201,68,.22);
  border-radius:999px;
}
.ab-best-now-status svg{ flex-shrink:0; opacity:.85; }
.ab-bn-slider{
  display:flex; flex-direction:column;
  gap:6px;
  margin:8px 0 10px;
}
.ab-bn-slider[hidden]{ display:none; }
.ab-bn-stage{
  position:relative;
  border-radius:10px;
  overflow:hidden;
  aspect-ratio: 16/10;
  background:#0e0f12;
  border:1px solid var(--line-1);
}
.ab-bn-img{
  display:block;
  width:100%; height:100%;
  object-fit:cover;
  transition:opacity var(--dur-base) var(--ease);
}
.ab-bn-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(0,0,0,.65);
  backdrop-filter:var(--blur-glass);
  -webkit-backdrop-filter:var(--blur-glass);
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  color:#fff;
  cursor:pointer;
  z-index:2;
  opacity:.85;  /* visible by default — works on touch + desktop */
  transition:opacity var(--dur-fast) var(--ease), background-color var(--dur-fast) var(--ease);
}
.ab-bn-stage:hover .ab-bn-arrow{ opacity:1; }
.ab-bn-prev{ left:8px; }
.ab-bn-next{ right:8px; }
.ab-bn-arrow:hover{ background:rgba(0,0,0,.85); }
.ab-bn-arrow:active{ transform:translateY(-50%) scale(0.94); }
.ab-bn-counter{
  position:absolute;
  bottom:8px; right:10px;
  z-index:2;
  font-size:10px;
  font-variant-numeric:tabular-nums;
  font-weight:600;
  letter-spacing:.04em;
  color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.55);
  padding:2px 6px;
  border-radius:4px;
}
.ab-bn-caption{
  margin:0;
  font-size:12px;
  color:var(--fg);
  line-height:1.35;
  letter-spacing:-.005em;
}
.ab-bn-tech{
  margin:0;
  font-size:10.5px;
  font-family:'SF Mono', ui-monospace, Menlo, monospace;
  color:var(--fg-dim);
  letter-spacing:.02em;
}
.ab-bn-meta{
  display:flex; flex-direction:column; gap:1px;
  margin-bottom:10px;
}
.ab-bn-name{
  font-size:14px;
  font-weight:600;
  letter-spacing:-.006em;
  color:var(--fg);
}
.ab-bn-bezirk{
  font-size:10.5px;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--fg-dim);
}
.ab-best-now-cta{
  display:inline-flex; align-items:center; gap:6px;
  padding:9px 16px;
  background:linear-gradient(135deg, #FFD66B 0%, #FFC944 60%, #E5A625 100%);
  color:#1a1410;
  border:0;
  border-radius:var(--radius-pill);
  font:inherit;
  font-size:12.5px; font-weight:700;
  text-decoration:none;
  cursor:pointer;
  box-shadow:0 4px 14px rgba(255,201,68,.25), inset 0 1px 0 rgba(255,255,255,.30);
  transition:transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.ab-best-now-cta:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(255,201,68,.40), inset 0 1px 0 rgba(255,255,255,.45);
}
.ab-best-now-cta:active{ transform:translateY(0); }
.ab-best-now-cta[hidden]{ display:none; }
.ab-best-now-cta svg{ flex-shrink:0; opacity:.9; }

/* ===== ab-sun-compass ===== */
.ab-sun-compass{ position:relative; }
.ab-compass-wrap{
  display:grid;
  grid-template-columns:120px 1fr;
  align-items:center;
  gap:14px;
}
.ab-compass-svg{
  width:120px; height:120px;
  display:block;
}
.ab-compass-ring{
  fill:rgba(255,255,255,.02);
  stroke:rgba(255,255,255,.10);
  stroke-width:1;
}
.ab-compass-ring-inner{
  fill:none;
  stroke:rgba(255,255,255,.06);
  stroke-width:1;
  stroke-dasharray:2 4;
}
.ab-compass-card{
  font-size:9px;
  font-weight:600;
  fill:var(--ps-fg-mute, #9aa0a8);
  text-transform:uppercase;
  letter-spacing:.05em;
  font-family:inherit;
}
.ab-compass-needle{
  transition:transform .8s cubic-bezier(.4,0,.2,1);
  transform-box:fill-box;
  transform-origin:center;
}
.ab-compass-arrow{
  fill:#FFB347;
  stroke:#fff;
  stroke-width:.8;
  stroke-linejoin:round;
  filter:drop-shadow(0 0 4px rgba(255,184,71,.7));
}
.ab-compass-tail{
  fill:rgba(255,255,255,.45);
  stroke:rgba(255,255,255,.25);
  stroke-width:.4;
  stroke-linejoin:round;
}
.ab-compass-hub{
  fill:#fff;
  stroke:rgba(0,0,0,.5);
  stroke-width:1;
}
.ab-sun-compass.is-low .ab-compass-arrow{ fill:#E03030; }
.ab-sun-compass.is-night .ab-compass-arrow{ fill:#4a8acc; opacity:.6; }
.ab-sun-compass.is-night .ab-compass-needle{ opacity:.45; }
.ab-compass-meta{
  margin:0;
  display:flex; flex-direction:column; gap:6px;
  font-size:11.5px;
}
.ab-compass-row{
  display:flex; align-items:baseline; justify-content:space-between;
  gap:8px;
}
.ab-compass-row dt{
  color:var(--ps-fg-mute, #9aa0a8);
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:10px;
  font-weight:600;
}
.ab-compass-row dd{
  margin:0;
  color:var(--ps-fg, #eaeaea);
  font-weight:600;
  font-variant-numeric:tabular-nums;
  font-size:13px;
  letter-spacing:-.005em;
}
.ab-compass-deg{
  color:var(--ps-fg-dim, #6b7280);
  font-weight:500;
  margin-right:2px;
}
.ab-compass-below{
  grid-column:1 / -1;
  margin:6px 0 0;
  font-size:11px;
  color:var(--ps-fg-dim, #6b7280);
  text-align:center;
}
@media (max-width:480px){
  .ab-compass-wrap{ grid-template-columns:96px 1fr; gap:10px; }
  .ab-compass-svg{ width:96px; height:96px; }
}

/* ===== ab-permits ===== */
.ab-permits-list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:8px;
}
.ab-permit{
  display:flex; flex-direction:column;
  padding:8px 10px;
  background:var(--ps-bg-3);
  border-radius:8px;
  border-left:3px solid var(--ps-accent);
  font-size:11.5px;
  line-height:1.35;
}
.ab-permit-label{
  font-weight:600;
  color:var(--ps-fg);
  margin-bottom:2px;
  font-size:12px;
}
.ab-permit-fee{
  color:var(--ps-accent-2);
  font-weight:500;
  margin-bottom:1px;
}
.ab-permit-lead{
  color:var(--ps-fg-dim);
}
.ab-permits-source{
  font-size:9px;
  color:var(--ps-fg-dim);
  text-align:right;
  margin:8px 0 0 0;
}

/* ===== Horizontal scroll rows (Apple TV / Spotify style) ===== */
.ps-rows{
  max-width:1440px; margin:32px auto 0; padding:0 24px 0 12px;
  display:flex; flex-direction:column;
  gap:32px;
}
.ps-row-head{
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:12px;
  gap:16px;
}
.ps-row-title{
  font-family:"Archivo Black", Inter, sans-serif;
  font-size:18px; font-weight:700;
  color:var(--ab-fg);
  margin:0;
  letter-spacing:-.018em;
}
.ps-row-all{
  font-size:12px; font-weight:600;
  color:var(--ab-fg-mute);
  text-decoration:none;
  letter-spacing:.02em;
  transition:color .15s ease;
}
.ps-row-all:hover{ color:var(--ab-fg); }
.ps-row-count{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:24px; height:22px;
  padding:0 8px;
  background:rgba(255,255,255,.06);
  border-radius:5px;
  color:var(--ab-fg-mute);
  font-size:11px; font-weight:600;
  font-variant-numeric:tabular-nums;
}
.ps-row-list{
  list-style:none; padding:0; margin:0;
  display:flex; gap:12px;
  overflow-x:auto;
  overflow-y:hidden;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:4px 0 12px;  /* room for shadow + scrollbar */
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.1) transparent;
}
.ps-row-list::-webkit-scrollbar{ height:6px; }
.ps-row-list::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.08); border-radius:3px; }
.ps-row-list::-webkit-scrollbar-track{ background:transparent; }
.ps-row-card{
  flex:0 0 auto;
  width:240px;
  scroll-snap-align:start;
}
.ps-row-link{
  display:flex; flex-direction:column;
  text-decoration:none;
  color:inherit;
  border-radius:10px;
  overflow:hidden;
  transition:transform .25s var(--ab-easing), box-shadow .25s var(--ab-easing);
}
.ps-row-link:hover{
  transform:translateY(-3px);
  box-shadow:0 12px 32px rgba(0,0,0,.5);
}
.ps-row-figure{
  position:relative;
  margin:0;
  aspect-ratio:3/2;
  overflow:hidden;
  border-radius:10px;
  background:#1a1c22;
}
.ps-row-figure img{
  width:100%; height:100%; object-fit:cover;
  display:block;
  /* Gentle normalization so very dark Wikimedia frames don't look broken next
     to brighter shots. Subtle — preserves photo intent. */
  filter:brightness(1.05) contrast(1.04) saturate(1.05);
  transition:transform .4s var(--ab-easing), filter .25s ease;
}
.ps-row-link:hover .ps-row-figure img{
  transform:scale(1.04);
  filter:brightness(1.1) contrast(1.06) saturate(1.1);
}
/* Subtle vignette on the bottom — keeps overlaid number readable on bright skies */
.ps-row-figure::after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:30%;
  background:linear-gradient(180deg, transparent 0%, rgba(0,0,0,.35) 100%);
  pointer-events:none;
  border-radius:inherit;
}
.ps-row-num{
  position:absolute; top:8px; left:8px;
  display:inline-flex; align-items:center; justify-content:center;
  min-width:24px; height:24px;
  padding:0 7px;
  background:rgba(0,0,0,.7);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:#fff;
  border-radius:6px;
  font-size:11px; font-weight:700;
  font-variant-numeric:tabular-nums;
}
.ps-row-meta{
  padding:8px 4px 0;
  display:flex; flex-direction:column;
  gap:2px;
}
.ps-row-name{
  font-size:13px; font-weight:600;
  color:var(--ab-fg);
  letter-spacing:-.005em;
  line-height:1.3;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.ps-row-sub{
  font-size:11px;
  color:var(--ab-fg-dim);
}
@media (max-width:640px){
  .ps-rows{ padding:0 16px; }
  .ps-row-card{ width:180px; }
  .ps-row-title{ font-size:16px; }
}

/* ===== ab-photo-events ===== */
.ab-events-head{
  display:flex; align-items:flex-start; justify-content:space-between;
}
.ab-events-month{
  font-size:11px;
  color:var(--ps-fg-mute);
  margin:2px 0 0 0;
  font-weight:500;
}
.ab-events-count{
  font-size:11px;
  color:var(--ps-fg-dim);
  margin:2px 0 0 0;
}
.ab-events-count .ab-events-count-confs{ color:var(--ps-accent-2); font-weight:600; }
.ab-events-nav{
  display:flex; gap:4px;
}
.ab-events-prev,
.ab-events-next{
  width:26px; height:26px;
  background:var(--ps-bg-3);
  border:1px solid var(--ps-line);
  border-radius:6px;
  color:var(--ps-fg);
  font-size:14px;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all .15s ease;
}
.ab-events-prev:hover,
.ab-events-next:hover{
  border-color:var(--ps-accent);
  color:var(--ps-accent-2);
}

.ab-events-weekdays{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:2px;
  margin:8px 0 4px;
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--ps-fg-dim);
  text-align:center;
}

.ab-events-grid{
  display:grid;
  grid-template-columns:repeat(7, 1fr);
  gap:2px;
}
.ab-events-day{
  position:relative;
  aspect-ratio:1;
  display:flex; align-items:center; justify-content:center;
  font-size:11px;
  color:var(--ps-fg-mute);
  border-radius:6px;
  background:transparent;
  cursor:default;
}
.ab-events-day.is-empty{ visibility:hidden; }
.ab-events-day.is-today{
  border:2px solid var(--ps-cat-photo-zone);
  color:var(--ps-fg);
  font-weight:700;
}
.ab-events-day.has-event{
  background:#1c1f26;
  color:var(--ps-fg);
  font-weight:600;
  cursor:pointer;
}
.ab-events-day.has-event:hover{
  background:var(--ps-bg-3);
}
.ab-events-day-dots{
  position:absolute; bottom:3px; left:50%;
  transform:translateX(-50%);
  display:flex; gap:2px;
}
.ab-events-day-dot{
  width:4px; height:4px;
  border-radius:50%;
}

.ab-events-dot{
  display:inline-block;
  width:8px; height:8px;
  border-radius:50%;
  margin-right:4px;
  vertical-align:1px;
}
.ab-events-dot-conference,  .ab-events-day-dot.ab-events-day-dot-conference  { background:#E03030; }
.ab-events-dot-workshop,    .ab-events-day-dot.ab-events-day-dot-workshop    { background:#E0A030; }
.ab-events-dot-vernissage,  .ab-events-day-dot.ab-events-day-dot-vernissage  { background:#62D29A; }
.ab-events-dot-networking,  .ab-events-day-dot.ab-events-day-dot-networking  { background:#0066CC; }

.ab-events-legend{
  list-style:none; padding:0; margin:10px 0 0 0;
  display:flex; flex-wrap:wrap; gap:8px 12px;
  font-size:10px;
  color:var(--ps-fg-mute);
}

.ab-events-list{
  list-style:none; padding:8px 0 0; margin:8px 0 0;
  border-top:1px solid var(--ps-line);
  display:flex; flex-direction:column; gap:8px;
  font-size:11px;
}
.ab-events-list li{
  display:flex; flex-direction:column;
  color:var(--ps-fg-mute);
}
.ab-events-list li strong{
  color:var(--ps-fg);
  font-weight:600;
  font-size:12px;
  display:block;
}
.ab-events-list li a{
  color:var(--ps-accent-2);
  font-size:10px;
  font-weight:500;
  text-decoration:none;
  margin-top:2px;
}
.ab-events-list li a:hover{ text-decoration:underline; }
