/* GOTTA — Geo-routing banner (handoff §13)
 *
 * Non-blocking top-of-page strip shown to visitors whose state-of-residence
 * (from the age gate) is outside NJ/MA. Links to /coming-soon.html.
 */

.geo-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 90;
    background:
        linear-gradient(to right, rgba(201, 165, 104, 0.14), rgba(201, 165, 104, 0.06) 60%, transparent),
        rgba(10, 10, 10, 0.96);
    border-bottom: 1px solid rgba(201, 165, 104, 0.32);
    backdrop-filter: blur(8px) saturate(120%);
    -webkit-backdrop-filter: blur(8px) saturate(120%);
    transition: transform 0.35s var(--ease-quiet, cubic-bezier(0.4, 0, 0.2, 1));
}
.geo-banner.is-dismissed { transform: translateY(-110%); }

.geo-banner__inner {
    max-width: 1240px;
    margin: 0 auto;
    padding: 0.6rem clamp(0.75rem, 2vw, 1.5rem);
    display: flex;
    align-items: center;
    gap: clamp(0.5rem, 1.5vw, 1.25rem);
    flex-wrap: wrap;
}

.geo-banner__label {
    font-family: var(--ff-text);
    font-size: 0.55rem;
    font-weight: 600;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--color-crown-gold);
    padding: 0.35rem 0.7rem;
    border: 1px solid rgba(201, 165, 104, 0.4);
    border-radius: 999px;
    white-space: nowrap;
    flex: 0 0 auto;
}

.geo-banner__msg {
    flex: 1 1 auto;
    margin: 0;
    font-family: var(--ff-text);
    font-size: 0.85rem;
    color: rgba(246, 241, 232, 0.85);
    line-height: 1.4;
}
.geo-banner__msg strong { color: var(--color-ivory); font-weight: 600; }

.geo-banner__cta {
    flex: 0 0 auto;
    font-family: var(--ff-text);
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--color-crown-gold);
    text-decoration: none;
    border-bottom: 1px solid currentColor;
    padding: 0.25rem 0;
    transition: letter-spacing 0.25s var(--ease-quiet, cubic-bezier(0.4,0,0.2,1));
}
.geo-banner__cta:hover,
.geo-banner__cta:focus-visible { letter-spacing: 0.26em; outline: none; }

.geo-banner__close {
    flex: 0 0 auto;
    background: transparent;
    border: 0;
    color: rgba(246, 241, 232, 0.55);
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
    padding: 0.25rem 0.4rem;
    transition: color 0.2s;
}
.geo-banner__close:hover,
.geo-banner__close:focus-visible {
    color: var(--color-crown-gold);
    outline: none;
}

/* Push the site header down so the banner doesn't overlap the logo */
body.has-geo-banner .site-header { transform: translateY(48px); }
body.has-geo-banner main { padding-top: 48px; }

@media (max-width: 720px) {
    .geo-banner__inner {
        padding: 0.5rem 0.75rem;
        gap: 0.5rem;
    }
    .geo-banner__msg { font-size: 0.78rem; flex-basis: 100%; }
    .geo-banner__cta { font-size: 0.62rem; }
    body.has-geo-banner .site-header { transform: translateY(72px); }
    body.has-geo-banner main { padding-top: 72px; }
}

@media (prefers-reduced-motion: reduce) {
    .geo-banner,
    body.has-geo-banner .site-header { transition: none; }
}
