/* =====================================================================
   FIND EVENTS TODAY — bone structure
   Tokens mirror app/globals.css per BRAND.md (Ultraviolet Observatory).
   Light mode only. No gradients. Sora (display) + Manrope (UI).
   ===================================================================== */
:root{
  --color-bg: oklch(98.5% 0.008 220);
  --color-surface: oklch(95% 0.015 215);
  --color-surface-elevated: oklch(92% 0.018 215);
  --color-border: oklch(85% 0.02 220);
  --color-border-subtle: oklch(90% 0.012 220);
  --color-text: oklch(18% 0.05 260);
  --color-text-sub: oklch(44% 0.06 255);
  --color-text-muted: oklch(60% 0.04 240);
  --color-accent: oklch(58% 0.18 175);
  --color-secondary: oklch(48% 0.22 290);
  --color-highlight: oklch(62% 0.16 210);
  --color-warning: oklch(70% 0.18 75);
  --color-error: oklch(58% 0.22 25);

  --font-display: "Sora","Manrope",system-ui,-apple-system,sans-serif;
  --font-body: "Manrope",system-ui,-apple-system,sans-serif;

  --text-hero: 88px; --text-display: 64px; --text-4xl: 46px; --text-3xl: 36px;
  --text-2xl: 28px;  --text-xl: 22px;     --text-lg: 18px;   --text-base: 16px;
  --text-sm: 14px;   --text-xs: 12px;     --text-2xs: 11px;

  --space-1:.25rem; --space-2:.5rem; --space-3:.75rem; --space-4:1rem;
  --space-6:1.5rem; --space-8:2rem;  --space-12:3rem; --space-16:4rem;
  --space-24:6rem;  --space-32:8rem;

  --radius-sm:6px; --radius:10px; --radius-lg:18px; --radius-xl:28px; --radius-full:9999px;

  --duration-fast:200ms; --duration-normal:350ms; --duration-slow:600ms;
  --ease-out: cubic-bezier(.2,.7,.2,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
}

/* --- smooth scroll for anchor jumps; wheel/touch use native momentum --- */
html{scroll-behavior:auto;}
html{scroll-padding-top:80px;}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font-body);
  font-size:var(--text-base);
  color:var(--color-text);
  background:var(--color-bg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background var(--duration-slow), color var(--duration-slow);
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0;}

/* ---------- grain overlay ---------- */
body::after{
  content:"";
  position:fixed;inset:0;z-index:9999;
  pointer-events:none;
  opacity:.028;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;
  background-size:180px;
}

/* ---------- scroll reveal ---------- */
.reveal{
  opacity:0;
  transform:translateY(32px);
  transition:opacity var(--duration-slow) var(--ease-out),
             transform var(--duration-slow) var(--ease-out);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
.reveal-delay-1{transition-delay:80ms;}
.reveal-delay-2{transition-delay:160ms;}
.reveal-delay-3{transition-delay:240ms;}
.reveal-delay-4{transition-delay:320ms;}
.reveal-stagger > *{
  opacity:0;
  transform:translateY(24px);
  transition:opacity var(--duration-slow) var(--ease-out),
             transform var(--duration-slow) var(--ease-out);
}
.reveal-stagger.is-visible > *{opacity:1;transform:translateY(0);}
.reveal-stagger.is-visible > *:nth-child(1){transition-delay:0ms;}
.reveal-stagger.is-visible > *:nth-child(2){transition-delay:100ms;}
.reveal-stagger.is-visible > *:nth-child(3){transition-delay:200ms;}
.reveal-stagger.is-visible > *:nth-child(4){transition-delay:300ms;}
.reveal-stagger.is-visible > *:nth-child(5){transition-delay:400ms;}
.reveal-stagger.is-visible > *:nth-child(6){transition-delay:500ms;}

/* ---------- hero entrance ---------- */
.hero-inner > *{
  opacity:0;
  transform:translateY(22px);
  animation:hero-enter var(--duration-slow) var(--ease-out) forwards;
}
.hero-inner > *:nth-child(1){animation-delay:80ms;}
.hero-inner > *:nth-child(2){animation-delay:200ms;}
.hero-inner > *:nth-child(3){animation-delay:380ms;}
.hero-inner > *:nth-child(4){animation-delay:560ms;}
@keyframes hero-enter{
  to{opacity:1;transform:translateY(0);}
}

/* ---------- mobile menu ---------- */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  border-radius:var(--radius);
  border:1px solid var(--color-border-subtle);
  place-items:center;
  flex-shrink:0;
  background:var(--color-bg);
  cursor:pointer;
  transition:background var(--duration-fast), border-color var(--duration-fast);
}
.nav-toggle:hover{border-color:var(--color-text);}
.nav-toggle span{
  display:block;width:20px;height:2px;
  background:var(--color-text);
  position:relative;
  border-radius:2px;
  transition:background var(--duration-fast);
}
.nav-toggle span::before,
.nav-toggle span::after{
  content:"";position:absolute;left:0;width:100%;height:100%;
  background:var(--color-text);
  border-radius:2px;
  transition:transform var(--duration-fast) var(--ease-out);
}
.nav-toggle span::before{transform:translateY(-7px);}
.nav-toggle span::after{transform:translateY(7px);}
.nav-toggle.is-open span{background:transparent;}
.nav-toggle.is-open span::before{transform:translateY(0) rotate(45deg);}
.nav-toggle.is-open span::after{transform:translateY(0) rotate(-45deg);}

.mobile-menu{
  position:fixed;inset:72px 0 0 0;z-index:49;
  background:color-mix(in oklch, var(--color-bg) 96%, transparent);
  backdrop-filter:saturate(140%) blur(20px);
  display:flex;flex-direction:column;
  padding:var(--space-8);gap:var(--space-6);
  transform:translateY(-10px);
  opacity:0;
  pointer-events:none;
  transition:transform var(--duration-normal) var(--ease-out),
             opacity var(--duration-normal) var(--ease-out);
}
.mobile-menu.is-open{
  transform:translateY(0);opacity:1;pointer-events:auto;
}
.mobile-menu a{
  font-family:var(--font-display);
  font-size:var(--text-2xl);
  font-weight:300;
  letter-spacing:-.02em;
  color:var(--color-text);
  padding:var(--space-3) 0;
  border-bottom:1px solid var(--color-border-subtle);
  transition:color var(--duration-fast), padding-left var(--duration-fast) var(--ease-out);
}
.mobile-menu a:hover{color:var(--color-accent);padding-left:var(--space-4);}
/* Sign-in CTA inside the mobile drawer — solid dark pill, full width,
   tucked at the bottom. Replaces the harsh stroked rectangle. */
.mobile-menu-cta{
  display:inline-flex !important;
  align-items:center;justify-content:center;gap:var(--space-2);
  margin-top:auto;
  padding:18px 24px !important;
  background:var(--color-text);
  color:var(--color-bg) !important;
  border-radius:var(--radius-full);
  border:none !important;
  font-family:var(--font-body) !important;
  font-size:var(--text-base) !important;
  font-weight:500 !important;
  letter-spacing:0 !important;
  transition:transform var(--duration-fast) var(--ease-out), background var(--duration-fast);
}
.mobile-menu-cta:hover{
  background:var(--color-accent);
  color:var(--color-bg) !important;
  padding-left:24px !important;
  transform:translateY(-1px);
}
.mobile-menu-cta svg{width:16px;height:16px;stroke-width:1.75;}

/* ---------- image skeleton ---------- */
.img-frame{position:relative;background:var(--color-surface);}
.img-frame img{transition:opacity .4s var(--ease-out);}
.img-frame img[data-wiki]:not([data-wiki-loaded]){
  animation:skeleton-shimmer 1.8s ease-in-out infinite;
}
@keyframes skeleton-shimmer{
  0%,100%{opacity:.7;}
  50%{opacity:.4;}
}

/* ---------- counter animate ---------- */
.count-up{
  display:inline-block;
  min-width:3ch;
}

/* ---------- strip pause hint ---------- */
.strip-pause{
  display:none;
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:var(--text-2xs);font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--color-text-muted);
  background:color-mix(in oklch, var(--color-bg) 85%, transparent);
  backdrop-filter:blur(8px);
  padding:6px 14px;border-radius:var(--radius-full);
  pointer-events:none;
  z-index:2;
  opacity:0;
  transition:opacity var(--duration-fast);
}
.strip:hover .strip-pause{opacity:1;}

/* ---------- newsletter CTA ---------- */
.newsletter{
  text-align:center;
  padding:var(--space-16) var(--space-8);
  border-top:1px solid var(--color-border);
  border-bottom:1px solid var(--color-border);
}
.newsletter h2{
  font-family:var(--font-display);
  font-weight:300;
  font-size:clamp(32px,4vw,var(--text-4xl));
  letter-spacing:-.03em;
  margin:0 0 var(--space-3) 0;
  line-height:1.05;
}
.newsletter h2 em{font-style:normal;font-weight:500;color:var(--color-accent);}
.newsletter p{
  font-size:var(--text-base);color:var(--color-text-sub);
  max-width:48ch;margin:0 auto var(--space-8);
}
.newsletter-form{
  display:flex;gap:var(--space-3);
  max-width:440px;margin:0 auto;
}
.newsletter-form input{
  flex:1;
  padding:12px 18px;
  border:1px solid var(--color-border);
  border-radius:var(--radius-full);
  font:inherit;font-size:var(--text-sm);
  background:var(--color-surface);
  color:var(--color-text);
  outline:none;
  transition:border-color var(--duration-fast);
}
.newsletter-form input:focus{border-color:var(--color-accent);}
.newsletter-form input::placeholder{color:var(--color-text-muted);}
.newsletter-form button{
  padding:12px 24px;
  background:var(--color-text);
  color:var(--color-bg);
  border-radius:var(--radius-full);
  font-size:var(--text-sm);font-weight:500;
  border:none;cursor:pointer;
  white-space:nowrap;
  transition:transform var(--duration-fast) var(--ease-out),
             background var(--duration-fast);
}
.newsletter-form button:hover{transform:translateY(-1px);background:var(--color-accent);}

/* ---------- search in country panel ---------- */
.panel-search{
  margin-bottom:var(--space-8);
  position:relative;
}
.panel-search input{
  width:100%;
  padding:12px 18px 12px 42px;
  border:1px solid var(--color-border);
  border-radius:var(--radius-full);
  font:inherit;font-size:var(--text-sm);
  background:var(--color-surface);
  color:var(--color-text);
  outline:none;
  transition:border-color var(--duration-fast);
}
.panel-search input:focus{border-color:var(--color-accent);}
.panel-search input::placeholder{color:var(--color-text-muted);}
.panel-search .icon{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  width:16px;height:16px;
  color:var(--color-text-muted);
}
.panel-no-results{
  text-align:center;padding:var(--space-12);
  color:var(--color-text-muted);font-size:var(--text-sm);
}

/* ---------- enhanced card hovers ---------- */
.country-card{transition:transform var(--duration-fast) var(--ease-out);}
.country-card:hover{transform:translateY(-4px);}
.country-card:active{transform:translateY(-1px) scale(.99);}

.event-card{transition:transform .25s var(--ease-out), border-color .25s, box-shadow .25s;}
.event-card:hover{
  transform:translateY(-3px);
  border-color:var(--color-border);
  box-shadow:0 8px 32px -8px color-mix(in oklch, var(--color-text) 8%, transparent);
}

/* ---------- active nav indicator ---------- */
.nav-links a{position:relative;}
.nav-links a::after{
  content:"";
  position:absolute;bottom:-4px;left:0;right:0;
  height:1.5px;
  background:var(--color-accent);
  transform:scaleX(0);
  transform-origin:right;
  transition:transform var(--duration-normal) var(--ease-out);
}
.nav-links a:hover::after{
  transform:scaleX(1);
  transform-origin:left;
}

.container{max-width:1320px;margin-inline:auto;padding-inline:var(--space-8);}
.eyebrow{
  font-size:var(--text-2xs);
  font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--color-text-sub);
}
.tabular{font-variant-numeric:tabular-nums;}

/* ---------- navbar ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  /* Solid opaque nav — sticky+backdrop-filter was repainting nav strip every
     scroll frame. Cheaper to be opaque. */
  background:var(--color-bg);
  border-bottom:1px solid var(--color-border-subtle);
  transition:box-shadow var(--duration-fast) var(--ease-out);
}
.nav.is-shadowed{box-shadow:0 1px 12px -4px color-mix(in oklch, var(--color-text) 12%, transparent);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px;}
.brand{display:flex;align-items:center;gap:var(--space-3);}
.brand-mark{
  width:28px;height:28px;border-radius:50%;
  border:1.5px solid var(--color-text);
  position:relative;
}
.brand-mark::before,
.brand-mark::after{
  content:"";position:absolute;inset:2px;border-radius:50%;
  border:1px solid color-mix(in oklch, var(--color-text) 25%, transparent);
}
.brand-mark::after{transform:rotate(60deg);border-style:dashed;}
.brand-wordmark{
  font-family:var(--font-display);
  font-weight:500;
  font-size:var(--text-lg);
  letter-spacing:-.02em;
}
.brand-wordmark em{font-style:normal;font-weight:400;color:var(--color-accent);}
.nav-links{display:flex;align-items:center;gap:var(--space-8);}
.nav-links a{
  font-size:var(--text-sm);
  color:var(--color-text-sub);
  transition:color var(--duration-fast) var(--ease-out);
}
.nav-links a:hover{color:var(--color-text);}

.cta-stroke-accent{
  display:inline-flex;align-items:center;gap:var(--space-2);
  padding:10px 18px;
  border:1px solid var(--color-text);
  border-radius:var(--radius-full);
  font-size:var(--text-sm);font-weight:500;
  position:relative;overflow:hidden;
  transition:color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);
}
.cta-stroke-accent::before{
  content:"";position:absolute;inset:0;
  background:var(--color-accent);
  transform:translateY(100%);
  transition:transform var(--duration-normal) var(--ease-out);
  z-index:-1;
}
.cta-stroke-accent:hover{border-color:var(--color-accent);color:var(--color-bg);}
.cta-stroke-accent:hover::before{transform:translateY(0);}
.cta-stroke-accent svg{width:14px;height:14px;stroke-width:1.75;}

/* ---------- hero ---------- */
.hero{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  padding-block:var(--space-12) var(--space-12);
  border-bottom:1px solid var(--color-border);
}
.hero-inner{
  max-width:1320px;
  width:100%;
  margin:0 auto;
  padding-inline:var(--space-8);
  display:grid;
  gap:var(--space-12);
}
/* ---- ribbon: 3-column tag row at top of hero ---- */
.hero-ribbon{
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-6);
  padding:var(--space-3) 0;
  border-top:1px solid var(--color-text);
  border-bottom:1px solid var(--color-border);
  font-family:var(--font-body);
  font-size:var(--text-2xs);
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--color-text-sub);
}
.hero-issue{color:var(--color-text);}
.hero-live{
  display:inline-flex;align-items:center;gap:var(--space-2);
  color:var(--color-text);
}
.hero-live .live-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--color-accent);
}
/* ---- kinetic editorial headline ---- */
h1.hero-h1{
  font-family:var(--font-display);
  font-weight:300;
  font-size:clamp(40px, 5.8vw, 88px);
  line-height:1;
  letter-spacing:-.035em;
  margin:0 auto;
  text-wrap:balance;
  max-width:22ch;
  text-align:center;
}
h1.hero-h1 .line-muted{
  color:var(--color-text-muted);
  font-weight:200;
  font-style:italic;
}
h1.hero-h1 em{font-style:italic;font-weight:500;color:var(--color-accent);}
.hero-headline{
  display:flex;flex-direction:column;
  align-items:center;
  gap:var(--space-6);
  padding-top:var(--space-2);
  text-align:center;
}
.hero-sub{
  font-size:var(--text-base);
  color:var(--color-text-sub);
  margin:0 auto;
  text-wrap:pretty;
  max-width:64ch;
  text-align:center;
}
.hero-cta{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);}
.cta-google{
  display:inline-flex;align-items:center;gap:var(--space-3);
  padding:14px 24px;
  background:var(--color-accent);
  color:var(--color-bg);
  border:1.5px solid var(--color-accent);
  border-radius:var(--radius-full);
  font-size:var(--text-base);font-weight:500;
  transition:background var(--duration-fast) var(--ease-out),
             color var(--duration-fast) var(--ease-out),
             transform var(--duration-fast) var(--ease-out);
}
.cta-google:hover{
  background:transparent;
  color:var(--color-accent);
  transform:translateY(-1px);
}
.cta-google:hover .g{background:var(--color-accent);color:var(--color-bg);}
.cta-google .g{
  width:18px;height:18px;background:var(--color-bg);border-radius:50%;
  display:grid;place-items:center;color:var(--color-accent);font-weight:700;font-size:11px;
  transition:background var(--duration-fast), color var(--duration-fast);
}
.cta-tertiary{font-size:var(--text-sm);color:var(--color-text-sub);margin:0;}
.cta-why-ask{
  color:var(--color-text);
  text-decoration:underline;
  text-underline-offset:4px;
  text-decoration-thickness:1px;
  text-decoration-color:color-mix(in oklch, var(--color-text) 35%, transparent);
  transition:text-decoration-color var(--duration-fast), color var(--duration-fast);
  cursor:pointer;
}
.cta-why-ask:hover{color:var(--color-accent);text-decoration-color:var(--color-accent);}

/* hero stats row */
/* ---- editorial stat bar at hero foot ---- */
.hero-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  padding-top:var(--space-6);
  border-top:1px solid var(--color-text);
  width:100%;
}
.hero-stats > div{
  display:flex;flex-direction:column;align-items:center;gap:var(--space-2);
  padding:0 var(--space-4);
  border-left:1px solid var(--color-border-subtle);
  text-align:center;
}
.hero-stats > div:first-child{border-left:none;padding-left:0;}
.hero-stats .stat-label{
  font-size:var(--text-2xs);font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--color-text-sub);
}
.hero-stats strong{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(28px, 3.4vw, var(--text-3xl));
  letter-spacing:-.025em;
  color:var(--color-text);
  font-variant-numeric:tabular-nums;
  line-height:1;
}

/* ---------- section frame ---------- */
.section{padding-block:var(--space-16);}
.section.compact{padding-block:var(--space-12);}
.section + .section{padding-top:0;}
.section-head{
  display:flex;flex-direction:column;gap:var(--space-3);
  margin-bottom:var(--space-12);
  border-top:1px solid var(--color-border);
  padding-top:var(--space-6);
  max-width:60ch;
}
.section-head h2{
  font-family:var(--font-display);
  font-weight:300;
  font-size:clamp(36px, 4.2vw, var(--text-4xl));
  line-height:1.05;
  letter-spacing:-.03em;
  margin:0;
  max-width:22ch;
  text-wrap:balance;
}
.section-head h2 em{font-style:normal;font-weight:500;color:var(--color-accent);}
.section-head .meta{
  font-size:var(--text-base);
  color:var(--color-text-sub);
  max-width:60ch;
  margin:0;
  text-wrap:pretty;
}
/* Desktop: centrirani section headeri (h2 + meta) */
@media (min-width: 961px){
  .section-head{
    align-items:center;
    text-align:center;
    max-width:none;
    margin-left:auto;margin-right:auto;
  }
  .section-head h2{max-width:24ch;}
  .section-head .meta{max-width:54ch;}
}

/* ---------- section: tonight bento ---------- */
.tonight-bento{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  gap:var(--space-6);
  align-items:stretch;
}
@media (max-width: 960px){
  .tonight-bento{grid-template-columns:1fr;}
}
.tonight-featured{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--color-border-subtle);
  background:var(--color-surface);
  min-height:520px;
  display:flex;flex-direction:column;justify-content:flex-end;
  cursor:pointer;
  text-align:left;
  isolation:isolate;
  transition:transform .3s var(--ease-out), border-color .3s, box-shadow .3s;
}
.tonight-featured:hover{
  transform:translateY(-3px);
  border-color:var(--color-accent);
  box-shadow:0 18px 50px -16px color-mix(in oklch, var(--color-text) 18%, transparent);
}
.tonight-featured-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:0;
  opacity:0;
  transition:opacity .55s var(--ease-out), transform 1.2s var(--ease-out);
}
.tonight-featured-img.is-active{opacity:1;}
.tonight-featured:hover .tonight-featured-img.is-active{transform:scale(1.025);}
.tonight-feature-meta{
  transition:opacity .35s var(--ease-out);
}
.tonight-feature-meta.is-swapping{opacity:0;}
.tonight-featured::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,
    color-mix(in oklch, var(--color-text) 70%, transparent) 0%,
    color-mix(in oklch, var(--color-text) 30%, transparent) 35%,
    transparent 70%);
  pointer-events:none;
}
.tonight-feature-meta{
  position:relative;z-index:2;
  padding:var(--space-8);
  display:flex;flex-direction:column;gap:var(--space-3);
  color:var(--color-bg);
}
.tonight-feature-meta .eyebrow{
  color:color-mix(in oklch, var(--color-bg) 85%, transparent);
  font-size:var(--text-2xs);font-weight:600;letter-spacing:.22em;text-transform:uppercase;
}
.tonight-feature-meta h3{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(36px, 4vw, 56px);
  letter-spacing:-.03em;
  line-height:1;
  margin:0;
  color:var(--color-bg);
}
.tonight-events{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:var(--space-2);
}
.tonight-events li{
  display:flex;justify-content:space-between;gap:var(--space-4);
  padding:var(--space-3) 0;
  border-top:1px solid color-mix(in oklch, var(--color-bg) 30%, transparent);
  font-size:var(--text-sm);
  color:color-mix(in oklch, var(--color-bg) 92%, transparent);
}
.tonight-events li:first-child{border-top:1px solid color-mix(in oklch, var(--color-bg) 45%, transparent);}
.tonight-events li .ev-title{flex:1;font-weight:500;color:var(--color-bg);}
.tonight-events li .ev-time{font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:.05em;}
.tonight-feature-meta .cta-arrow{
  display:inline-flex;align-items:center;gap:var(--space-2);
  margin-top:var(--space-3);
  font-size:var(--text-sm);font-weight:500;
  color:var(--color-bg);
  border-bottom:1px solid color-mix(in oklch, var(--color-bg) 55%, transparent);
  padding-bottom:2px;align-self:flex-start;
  transition:gap .2s var(--ease-out), border-color .2s;
}
.tonight-featured:hover .cta-arrow{gap:var(--space-3);border-color:var(--color-accent);color:var(--color-accent);}
.tonight-feature-meta .cta-arrow svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.75;}

/* ---- side list ---- */
.tonight-side{
  display:flex;flex-direction:column;
  border:1px solid var(--color-border-subtle);
  border-radius:var(--radius-lg);
  background:var(--color-bg);
  overflow:hidden;
  min-height:520px;
}
.tonight-side-head{
  padding:var(--space-4) var(--space-5);
  border-bottom:1px solid var(--color-border-subtle);
  background:var(--color-surface);
}
.tonight-side-list{
  flex:1;overflow-y:auto;
  display:flex;flex-direction:column;
}
.tonight-side-item{
  display:grid;
  grid-template-columns:1fr auto auto;
  align-items:baseline;gap:var(--space-3);
  padding:10px var(--space-4);
  border-bottom:1px solid var(--color-border-subtle);
  cursor:pointer;text-align:left;
  background:transparent;
  font:inherit;
  width:100%;
  transition:background .15s, padding-left .2s var(--ease-out);
}
.tonight-side-item:hover{background:var(--color-surface);padding-left:calc(var(--space-4) + 4px);}
.tonight-side-item:last-child{border-bottom:none;}
.tonight-side-item.is-active{background:color-mix(in oklch, var(--color-accent) 8%, transparent);}
.tonight-side-item .name{
  font-family:var(--font-display);
  font-weight:500;
  font-size:var(--text-base);
  letter-spacing:-.015em;
  color:var(--color-text);
  line-height:1.2;
}
.tonight-side-item .count{
  font-family:var(--font-display);
  font-weight:500;
  font-size:var(--text-base);
  letter-spacing:-.02em;
  color:var(--color-accent);
  font-variant-numeric:tabular-nums;
  line-height:1;
}
.tonight-side-item .meta{
  font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--color-text-muted);
  white-space:nowrap;
  line-height:1;
}
.tonight-side-head{
  padding:10px var(--space-4);
  border-bottom:1px solid var(--color-border-subtle);
  background:var(--color-surface);
}
.tonight-side-head .eyebrow{font-size:10px;}

/* legacy strip CSS kept for fallback; the bento replaces it visually */
.strip{position:relative;overflow:hidden;display:none;}
.strip-scroll{
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
  -ms-overflow-style:none;
  scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch;
}
.strip-scroll::-webkit-scrollbar{display:none;}
.strip-controls{
  position:absolute;top:50%;left:0;right:0;
  display:flex;justify-content:space-between;align-items:center;
  pointer-events:none;
  transform:translateY(-50%);
  z-index:3;
  padding:0 var(--space-6);
}
.strip-arrow{
  width:48px;height:48px;border-radius:50%;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  color:var(--color-text);
  display:grid;place-items:center;
  pointer-events:auto;
  cursor:pointer;
  opacity:.88;
  box-shadow:0 6px 20px -8px color-mix(in oklch, var(--color-text) 25%, transparent);
  transition:opacity .2s var(--ease-out), background .2s, color .2s, transform .2s var(--ease-out);
}
.strip-arrow:hover{
  background:var(--color-text);
  color:var(--color-bg);
  border-color:var(--color-text);
  opacity:1;
  transform:scale(1.08);
}
.strip-arrow svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.75;}
.strip-arrow:disabled{opacity:0;pointer-events:none;}
.strip-track{
  display:flex;gap:var(--space-4);
  width:max-content;
  animation:strip-drift 80s linear infinite;
  will-change:transform;
}
/* No hover pause — that felt glitchy. The auto-drift continues; users can
   freely scroll the strip horizontally to override. */
.strip[data-paused="1"] .strip-track{animation-play-state:paused;}
@keyframes strip-drift{
  from{transform:translateX(0);}
  to  {transform:translateX(-50%);}
}
.country-card{
  flex:0 0 auto;
  width:240px;
  display:flex;flex-direction:column;gap:var(--space-3);
  cursor:pointer;
  text-align:left;
}
.country-card .img-frame{
  position:relative;
  aspect-ratio:3/4;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--color-border-subtle);
  background:var(--color-surface);
}
.country-card .img-frame img{
  width:100%;height:100%;
  object-fit:cover;
  filter:saturate(.85) contrast(.95);
  transition:transform .6s var(--ease-out), filter .3s var(--ease-out);
}
.country-card:hover .img-frame img,
.country-card:focus-visible .img-frame img{
  transform:scale(1.04);
  filter:saturate(1.05) contrast(1);
}
.country-card .img-frame .arrow{
  position:absolute;
  right:var(--space-3);bottom:var(--space-3);
  width:36px;height:36px;
  border-radius:50%;
  background:var(--color-bg);
  color:var(--color-text);
  display:grid;place-items:center;
  transform:translateY(8px);
  opacity:0;
  transition:transform .3s var(--ease-out), opacity .3s var(--ease-out), background .2s, color .2s;
}
.country-card:hover .arrow,
.country-card:focus-visible .arrow{
  transform:translateY(0);opacity:1;
}
.country-card:hover .arrow{background:var(--color-accent);color:var(--color-bg);}
.country-card .arrow svg{width:16px;height:16px;stroke-width:1.75;fill:none;stroke:currentColor;}
.country-card .row{
  display:flex;align-items:end;justify-content:space-between;gap:var(--space-3);
}
.country-card .name{
  font-family:var(--font-display);
  font-weight:500;
  font-size:var(--text-xl);
  letter-spacing:-.025em;
  line-height:1.15;
}
.country-card .count{
  font-size:var(--text-2xs);font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--color-text-sub);
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}

/* ---------- section: how it works (compact) ---------- */
.how-compact{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-8);
  max-width:1000px;
  margin:0 auto;
}
.how-step-c{
  display:flex;flex-direction:column;align-items:center;gap:var(--space-2);
  padding:0;
  text-align:center;
}
.how-step-c p{margin-left:auto;margin-right:auto;}
.section.compact .section-head{border-top:none;padding-top:0;}
.how-step-c .num{
  font-family:var(--font-body);
  font-weight:600;
  font-size:var(--text-2xs);
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--color-accent);
  font-variant-numeric:tabular-nums;
}
.how-step-c h4{
  font-family:var(--font-display);
  font-weight:500;
  font-size:var(--text-lg);
  letter-spacing:-.02em;
  margin:0;
  line-height:1.2;
}
.how-step-c p{
  font-size:var(--text-sm);
  color:var(--color-text-sub);
  margin:0;
  max-width:30ch;
  line-height:1.5;
}

/* ---------- section: regional editions ---------- */
.cities{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  grid-auto-rows:minmax(280px, auto);
  gap:var(--space-6);
}
/* Asymmetric: first tile spans 3 cols + 2 rows (huge feature), next 5 fill */
.cities > *:nth-child(1){grid-column:span 3;grid-row:span 2;aspect-ratio:auto;}
.cities > *:nth-child(2){grid-column:span 3;}
.cities > *:nth-child(3){grid-column:span 3;}
.cities > *:nth-child(4){grid-column:span 2;}
.cities > *:nth-child(5){grid-column:span 2;}
.cities > *:nth-child(6){grid-column:span 2;}
@media (max-width: 960px){
  .cities{grid-template-columns:repeat(2, 1fr) !important; grid-auto-rows:auto;}
  .cities > *{grid-column:span 1 !important; grid-row:auto !important;}
}
@media (max-width: 600px){
  .cities{grid-template-columns:1fr !important;}
}
.city-tile{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--radius-lg);
  overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0;
  border:1px solid var(--color-border-subtle);
  background:var(--color-surface);
  cursor:pointer;
  text-align:left;
  transition:border-color .2s ease-out;
}
.city-tile:hover{border-color:var(--color-accent);}
.city-tile::after{
  /* graduated dark wash so the glass strip + city name stay readable on any photo */
  content:"";
  position:absolute;inset:0;
  z-index:0;
  background:linear-gradient(to top,
    color-mix(in oklch, var(--color-text) 55%, transparent) 0%,
    color-mix(in oklch, var(--color-text) 12%, transparent) 38%,
    transparent 70%);
  pointer-events:none;
}
.city-tile img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  z-index:0;
}
.city-tile .meta-row{
  position:relative;z-index:2;
  display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);
  padding:var(--space-8) var(--space-6) var(--space-6);
  /* Opaque bg — backdrop-filter on 6 tiles was the single worst paint cost.
     Solid bg looks just as good on a darkened photo and is essentially free. */
  background:linear-gradient(to top,
    var(--color-bg) 0%,
    color-mix(in oklch, var(--color-bg) 96%, transparent) 100%);
  border-top:1px solid var(--color-border-subtle);
  min-height:120px;
}
.city-tile .meta-left{
  display:flex;flex-direction:column;gap:var(--space-2);
  min-width:0;flex:1 1 0;
}
.city-tile .eyebrow{
  font-size:var(--text-2xs);font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--color-text-sub);
}
.city-tile .name{
  font-family:var(--font-display);
  font-weight:500;
  font-size:var(--text-2xl);
  letter-spacing:-.025em;
  line-height:1.1;
  color:var(--color-text);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.city-tile .venues{
  font-size:var(--text-2xs);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--color-text);
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
  display:flex;flex-direction:column;align-items:flex-end;gap:2px;
  line-height:1.1;
  flex-shrink:0;
}
.city-tile .venues strong{
  font-family:var(--font-display);
  font-size:var(--text-xl);
  font-weight:500;
  letter-spacing:-.02em;
  color:var(--color-accent);
}

/* ---------- next month ---------- */
.next-month-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:var(--space-6);
}
.next-month-card{
  display:flex;flex-direction:column;
  text-align:left;
  border-radius:var(--radius-lg);
  border:1px solid var(--color-border-subtle);
  background:var(--color-bg);
  overflow:hidden;
  cursor:pointer;
  transition:border-color .2s ease-out;
}
.next-month-card:hover{border-color:var(--color-accent);}
.next-month-card .img-frame{
  position:relative;aspect-ratio:5/3;overflow:hidden;background:var(--color-surface);
}
.next-month-card .img-frame img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.9);
  transition:transform .8s var(--ease-out);
}

.next-month-card .date-chip{
  position:absolute;top:var(--space-4);left:var(--space-4);
  display:flex;flex-direction:column;align-items:center;
  padding:8px 12px;border-radius:var(--radius);
  background:var(--color-bg);
  font-variant-numeric:tabular-nums;line-height:1;
}
.next-month-card .date-chip .d{
  font-family:var(--font-display);
  font-weight:500;font-size:var(--text-xl);
  color:var(--color-accent);letter-spacing:-.02em;
}
.next-month-card .date-chip .m{
  font-size:9px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--color-text-sub);margin-top:4px;
}
.next-month-card .body{
  padding:var(--space-6) var(--space-6) var(--space-6);
  display:flex;flex-direction:column;gap:var(--space-2);flex:1;
  min-height:190px;
  overflow:hidden;
}
.next-month-card h4{
  font-family:var(--font-display);font-weight:500;
  font-size:var(--text-lg);letter-spacing:-.02em;line-height:1.2;
  margin:var(--space-2) 0 0 0;text-wrap:balance;
}
.next-month-card .where{
  font-size:var(--text-sm);color:var(--color-text-sub);margin:0;
}
.next-month-card .footer-row{
  display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);
  margin-top:auto;padding-top:var(--space-4);
  border-top:1px solid var(--color-border-subtle);
  font-size:var(--text-2xs);font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--color-text-sub);
  white-space:nowrap;
}
.next-month-card .footer-row .cat,
.next-month-card .footer-row > span:last-child{
  overflow:hidden;text-overflow:ellipsis;
}
.next-month-card .footer-row .cat{color:var(--color-accent);}
@media (max-width: 960px){
  .next-month-grid{grid-template-columns:repeat(2, 1fr);}
}
@media (max-width: 600px){
  .next-month-grid{grid-template-columns:1fr;}
}

/* ---------- footer ---------- */
footer{
  border-top:1px solid var(--color-border);
  padding-block:var(--space-12) var(--space-8);
  margin-top:var(--space-24);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:var(--space-8);
  margin-bottom:var(--space-12);
}
.footer-grid h5{
  font-size:var(--text-2xs);font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:var(--color-text-sub);
  margin:0 0 var(--space-4) 0;
}
.footer-grid ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-2);}
.footer-grid a{font-size:var(--text-sm);color:var(--color-text);}
.footer-grid a:hover{color:var(--color-accent);}
.footer-tag{font-size:var(--text-sm);color:var(--color-text-sub);max-width:32ch;}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:var(--space-6);
  border-top:1px solid var(--color-border-subtle);
  font-size:var(--text-xs);
  color:var(--color-text-muted);
}

/* ---------- country panel (overlay with events list) ----------
   Opens when a country card is clicked. Slides up from
   the bottom, with a scrim behind. ESC or backdrop click closes.
---------------------------------------------------------------- */
.country-panel{
  position:fixed;inset:0;z-index:200;
  display:flex;align-items:flex-end;justify-content:center;
  background:color-mix(in oklch, var(--color-text) 35%, transparent);
  opacity:0;
  pointer-events:none;
  transition:opacity .35s var(--ease-out);
}
.country-panel.is-open{opacity:1;pointer-events:auto;}
.country-panel-inner{
  position:relative;
  width:100%;max-width:1400px;
  height:90vh;
  background:var(--color-bg);
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  overflow:auto;
  transform:translateY(100%);
  transition:transform .45s var(--ease-spring);
  padding:var(--space-12) var(--space-12) var(--space-16);
}
.country-panel.is-open .country-panel-inner{transform:translateY(0);}
.country-panel-head{
  display:flex;align-items:start;justify-content:space-between;
  gap:var(--space-8);
  border-bottom:1px solid var(--color-border);
  padding-bottom:var(--space-8);
  margin-bottom:var(--space-12);
}
.country-panel-head .eyebrow{margin-bottom:var(--space-2);display:block;}
.country-panel-head h2{
  font-family:var(--font-display);
  font-weight:300;
  font-size:clamp(40px, 5vw, 64px);
  line-height:1.02;
  letter-spacing:-.035em;
  margin:0 0 var(--space-3) 0;
}
.country-panel-head .summary{
  font-size:var(--text-base);
  color:var(--color-text-sub);
  margin:0;
  max-width:48ch;
  text-wrap:pretty;
}
.country-panel-close{
  position:sticky;
  top:var(--space-6);
  width:44px;height:44px;
  border:1px solid var(--color-border);
  border-radius:50%;
  display:grid;place-items:center;
  flex-shrink:0;
  background:var(--color-bg);
  transition:background .2s, color .2s, border-color .2s;
  z-index:5;
  align-self:flex-start;
}
.country-panel-close:hover{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text);}
.country-panel-close svg{width:18px;height:18px;stroke-width:1.75;fill:none;stroke:currentColor;}

.events-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(300px, 1fr));
  gap:var(--space-8);
}
.event-card{
  display:flex;flex-direction:column;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--color-border-subtle);
  background:var(--color-bg);
  transition:transform .25s var(--ease-out), border-color .25s, box-shadow .3s var(--ease-out);
}
.event-card:hover{
  transform:translateY(-4px);
  border-color:var(--color-accent);
  box-shadow:0 12px 36px -10px color-mix(in oklch, var(--color-text) 12%, transparent);
}
.event-card .img-frame{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--color-surface);
}
.event-card .img-frame img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.85);
  transition:transform .6s var(--ease-out), filter .3s var(--ease-out);
}
.event-card:hover .img-frame img{
  transform:scale(1.05);
  filter:saturate(1.02);
}
.event-card .category{
  position:absolute;
  top:var(--space-4);left:var(--space-4);
  font-size:var(--text-2xs);font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  padding:6px 12px;
  background:var(--color-bg);
  border-radius:var(--radius-full);
  color:var(--color-text);
}
.event-card .body{
  display:flex;flex-direction:column;gap:var(--space-2);
  padding:var(--space-6);
  flex:1;
}
.event-card h4{margin-top:var(--space-2);}
.event-card h4{
  font-family:var(--font-display);
  font-weight:500;
  font-size:var(--text-xl);
  letter-spacing:-.025em;
  line-height:1.15;
  margin:0;
  text-wrap:balance;
}
.event-card .venue{
  font-size:var(--text-sm);
  color:var(--color-text-sub);
  margin:0;
  line-height:1.4;
}
.event-card .meta{
  display:flex;align-items:center;gap:var(--space-3);
  font-size:var(--text-xs);font-weight:500;
  color:var(--color-text);
  font-variant-numeric:tabular-nums;
  letter-spacing:.04em;
  padding-top:var(--space-4);
  border-top:1px solid var(--color-border-subtle);
  margin-top:var(--space-3);
}
.event-card .meta .dot{
  width:3px;height:3px;border-radius:50%;background:var(--color-accent);
}
.event-card .source{
  font-size:var(--text-2xs);
  color:var(--color-text-muted);
  margin:var(--space-2) 0 0 0;
  letter-spacing:.02em;
}
.event-card .body > .meta{margin-top:auto;}
.country-panel-footer{
  margin-top:var(--space-6);
  padding-top:var(--space-6);
  border-top:1px solid var(--color-border-subtle);
  font-size:var(--text-xs);
  color:var(--color-text-muted);
  max-width:80ch;
  text-wrap:pretty;
}
.panel-cta-row{
  margin-top:var(--space-12);
  display:flex;justify-content:center;
}
.cp-back{
  display:inline-flex;align-items:center;gap:var(--space-3);
  padding:14px 28px;
  border:1px solid var(--color-text);
  border-radius:var(--radius-full);
  font-size:var(--text-sm);font-weight:500;
  background:var(--color-bg);color:var(--color-text);
  cursor:pointer;
  transition:background .2s, color .2s, transform .2s var(--ease-out);
}
.cp-back:hover{background:var(--color-text);color:var(--color-bg);transform:translateY(-1px);}
.cp-back svg{width:16px;height:16px;}

/* ---------- info modal (legal text placeholders) ---------- */
.info-modal{
  position:fixed;inset:0;z-index:300;
  display:flex;align-items:center;justify-content:center;
  background:color-mix(in oklch, var(--color-text) 38%, transparent);
  backdrop-filter:blur(4px);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s var(--ease-out);
  padding:var(--space-6);
}
.info-modal.is-open{opacity:1;pointer-events:auto;}
.info-modal-inner{
  position:relative;
  width:100%;max-width:560px;
  max-height:80vh;overflow:auto;
  background:var(--color-bg);
  border:1px solid var(--color-border);
  border-radius:var(--radius-xl);
  padding:var(--space-12) var(--space-8) var(--space-8);
  transform:scale(.96);
  transition:transform .25s var(--ease-spring);
}
.info-modal.is-open .info-modal-inner{transform:scale(1);}
.info-modal-close{
  position:absolute;top:var(--space-4);right:var(--space-4);
  width:40px;height:40px;
  display:grid;place-items:center;
  border:1px solid var(--color-border);border-radius:50%;
  transition:background .2s, color .2s, border-color .2s;
}
.info-modal-close:hover{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text);}
.info-modal-close svg{width:18px;height:18px;}
.info-modal h3{
  font-family:var(--font-display);
  font-weight:400;
  font-size:var(--text-3xl);
  letter-spacing:-.03em;
  margin:var(--space-2) 0 var(--space-6);
  line-height:1.05;
}
.info-modal-body{
  font-size:var(--text-sm);
  color:var(--color-text-sub);
  line-height:1.65;
}
.info-modal-body p{margin:0 0 var(--space-4) 0;}
.info-modal-body strong{color:var(--color-text);font-weight:500;}
.info-modal-meta{
  font-size:var(--text-2xs);
  color:var(--color-text-muted);
  margin:var(--space-6) 0 0;
  letter-spacing:.04em;
  padding-top:var(--space-4);
  border-top:1px solid var(--color-border-subtle);
}

/* ---------- performance hints ----------
   Less is more here. Toggling visibility / display / backdrop-filter ON every
   scroll-end was itself causing repaint flashes the user reads as "stutter".
   We keep only zero-cost hints: GPU layer promotion + layout containment. */
.section{contain:layout;}
.strip-track,
.strip-scroll{
  will-change:transform;
  transform:translateZ(0);
}
/* Pause the strip auto-drift while the user is scrolling — the only is-scrolling
   rule we keep because it's purely an animation pause, not a visibility flip. */
html.is-scrolling .strip-track{animation-play-state:paused;}

/* ---------- responsive ---------- */
@media (max-width: 960px){
  .how-compact{grid-template-columns:1fr;}
  .hero-stats{grid-template-columns:repeat(2,1fr);gap:var(--space-6) 0;}
  .hero-stats > div:nth-child(odd){border-left:none;padding-left:0;}
  .hero-stats > div:nth-child(3),
  .hero-stats > div:nth-child(4){padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle);}
  .hero-ribbon{flex-wrap:wrap;gap:var(--space-2) var(--space-4);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .nav-links{display:none;}
  .nav-inner > .cta-stroke-accent{display:none;}
  .nav-toggle{display:grid;}
  .brand-wordmark{white-space:nowrap;}
  .hero-stats{gap:var(--space-6);flex-wrap:wrap;}
  .country-panel-inner{padding:var(--space-8);}
  .country-panel-head{flex-direction:row;}
  .newsletter-form{flex-direction:column;}
}
@media (max-width:600px){
  .footer-grid{grid-template-columns:1fr;}
  .country-card{width:200px;}
  .hero-stats{flex-direction:column;align-items:center;}
}
@media (prefers-reduced-motion: reduce){
  /* .strip-track kept on — 80s editorial drift cannot trigger vestibular reflex */
  .hero-eyebrow .dot,.hero-stats .live-dot,
}