/*
 * frizbys-ufo.css — Frizby's UFO / Alien theme
 * Green alien glow, dark-space cards, round controls, and playful sci-fi styling.
 */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@600;700;800;900&family=Space+Mono:wght@400;700&display=swap');

:root {
    --bg:       #020604;
    --surface:  rgba(4,12,8,.94);
    --card:     rgba(7,18,12,.96);
    --card-alt: rgba(11,28,19,.96);
    --border:   rgba(57,255,20,.13);
    --border2:  rgba(57,255,20,.24);
    --text:     #f2fff0;
    --muted:    rgba(242,255,240,.60);
    --muted2:   rgba(242,255,240,.34);
    --shadow:   0 20px 70px rgba(0,0,0,.72);
    --radius:   22px;
    --font-body:    'Space Mono', monospace;
    --font-display: 'Barlow Condensed', sans-serif;

    --alien-green: #39ff14;
    --alien-blue:  #00d7ff;
    --alien-purple:#8b5cf6;

    --hero-text:         #ffffff;
    --hero-border:       rgba(57,255,20,.18);
    --hero-featured-bg:  rgba(5,18,11,.92);
    --hero-ticker-bg:    rgba(1,8,4,.78);
    --hero-ticker-color: var(--alien-green);
}

html {
    background: var(--bg);
}

body {
    font-family: var(--font-body);
    color: var(--text);
    background:
        radial-gradient(circle at 12% 0%, rgba(57,255,20,.18), transparent 28rem),
        radial-gradient(circle at 90% 10%, rgba(0,215,255,.13), transparent 30rem),
        radial-gradient(circle at 50% 100%, rgba(139,92,246,.10), transparent 28rem),
        linear-gradient(180deg, #020604 0%, #040806 48%, #010201 100%);
    font-size: 13px;
    overflow-x: hidden;
}

/* ── Sidebar ── */
.sidebar-label {
    color: var(--alien-green);
    letter-spacing: .18em;
    font-size: .66rem;
    text-transform: uppercase;
    font-family: var(--font-body);
}

.sidebar-label::before {
    content: "🛸 ";
}

.sidebar-link {
    color: var(--muted);
    border-radius: 999px;
    letter-spacing: .035em;
    border-left: 2px solid transparent;
}

.sidebar-link:hover {
    color: var(--text);
    background: rgba(57,255,20,.07);
}

.sidebar-link.active {
    color: var(--alien-green);
    border-left-color: var(--alien-green);
    background: linear-gradient(90deg, rgba(57,255,20,.16), rgba(0,215,255,.05));
    font-weight: 700;
    box-shadow:
        inset 0 0 24px rgba(57,255,20,.08),
        0 0 24px rgba(57,255,20,.10);
}

/* ── Search ── */
.search-wrap {
    background: linear-gradient(180deg, rgba(2,6,4,.96), rgba(2,6,4,.74));
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.search-inner {
    background:
        linear-gradient(135deg, rgba(57,255,20,.06), rgba(0,215,255,.035)),
        rgba(5,14,9,.94);
    border: 1px solid rgba(57,255,20,.20);
    border-radius: 999px;
    box-shadow:
        0 16px 40px rgba(0,0,0,.42),
        inset 0 0 0 1px rgba(255,255,255,.035),
        0 0 22px rgba(57,255,20,.07);
}

.search-inner:focus-within {
    border-color: rgba(57,255,20,.66);
    box-shadow:
        0 0 0 3px rgba(57,255,20,.14),
        0 0 30px rgba(57,255,20,.20);
}

.search-icon {
    color: var(--alien-green);
    text-shadow: 0 0 14px rgba(57,255,20,.62);
}

.search-input {
    color: var(--text);
    font-family: var(--font-body);
    font-size: 12px;
}

.search-input::placeholder { color: var(--muted2); }

.search-clear {
    color: var(--muted);
    border-radius: 999px;
}

.search-clear:hover {
    color: var(--alien-green);
    background: rgba(57,255,20,.08);
}

/* ── Pill bar ── */
.pill-bar {
    background: rgba(2,6,4,.94);
    border-bottom: 1px solid rgba(57,255,20,.14);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.pill-tab {
    border-radius: 999px;
    border: 1px solid rgba(57,255,20,.18);
    background: rgba(57,255,20,.045);
    color: var(--muted);
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: .8rem;
    transition: color .15s, border-color .15s, background .15s, box-shadow .15s, transform .12s;
}

.pill-tab:hover {
    color: var(--alien-green);
    border-color: rgba(57,255,20,.50);
}

.pill-tab.active {
    background: linear-gradient(135deg, var(--alien-green), #9dff7a);
    border-color: var(--alien-green);
    color: #031006;
    font-weight: 900;
    box-shadow:
        0 0 18px rgba(57,255,20,.42),
        0 0 34px rgba(0,215,255,.13);
}

.pill-tab:active { transform: scale(.97); }

/* ── Section ── */
.section-title {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 900;
    letter-spacing: .10em;
    text-transform: uppercase;
    color: var(--alien-green);
    text-shadow:
        0 0 18px rgba(57,255,20,.42),
        0 0 34px rgba(0,215,255,.14);
}

.section-title::before {
    content: "✦ ";
    color: var(--alien-blue);
    text-shadow: 0 0 18px rgba(0,215,255,.45);
}

.section-line {
    background: linear-gradient(90deg, rgba(57,255,20,.48), rgba(0,215,255,.18), rgba(255,255,255,.04));
}

.section-count {
    font-size: 10px;
    color: var(--alien-green);
    font-family: var(--font-body);
    background: rgba(57,255,20,.10);
    border: 1px solid rgba(57,255,20,.23);
    border-radius: 999px;
}

/* ── Items list ── */
.items-list {
    background: transparent;
}

/* ── Item row ── */
.item-row {
    background:
        radial-gradient(circle at top left, rgba(57,255,20,.085), transparent 14rem),
        linear-gradient(135deg, rgba(255,255,255,.04), transparent 42%),
        var(--card);
    border: 1px solid rgba(57,255,20,.14);
    border-left: 3px solid rgba(57,255,20,.36);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow:
        0 16px 42px rgba(0,0,0,.34),
        inset 0 0 0 1px rgba(255,255,255,.025);
    transition: border-color .2s, box-shadow .2s, transform .18s, background .2s;
    animation: tractorBeamIn .25s ease both;
    margin-bottom: 13px;
}

@keyframes tractorBeamIn {
    from { opacity: 0; transform: translateY(6px) scale(.995); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}

.item-row:hover {
    border-color: rgba(57,255,20,.38);
    box-shadow:
        0 20px 56px rgba(0,0,0,.52),
        0 0 30px rgba(57,255,20,.13),
        inset 0 0 0 1px rgba(57,255,20,.10);
    transform: translateY(-2px);
}

.item-img-wrap {
    background:
        radial-gradient(circle at center, rgba(57,255,20,.18), transparent 70%),
        linear-gradient(135deg, rgba(0,215,255,.08), transparent),
        #07120c;
    border-right: 1px solid rgba(57,255,20,.13);
}

.item-img {
    transition: transform .45s ease, filter .45s ease;
    filter: saturate(1.02) contrast(1.05);
}

.item-row:hover .item-img {
    transform: scale(1.06);
    filter: saturate(1.22) contrast(1.08);
}

.item-no-img {
    color: rgba(57,255,20,.45);
    background:
        radial-gradient(circle at center, rgba(57,255,20,.18), transparent 70%),
        #07120c;
}

.item-no-img::before {
    content: "👽";
}

.item-no-img {
    font-size: 0;
}

.item-no-img::before {
    font-size: 1.8rem;
}

.item-name {
    font-family: var(--font-display);
    font-size: 1.12rem;
    font-weight: 900;
    color: var(--text);
    letter-spacing: .05em;
    text-transform: uppercase;
}

.item-desc {
    font-size: .76rem;
    color: var(--muted);
    line-height: 1.55;
    font-family: var(--font-body);
}

.item-badge {
    padding: 2px 8px;
    border-radius: 999px;
    font-size: .6rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: rgba(57,255,20,.055);
}

.item-price {
    font-family: var(--font-display);
    font-size: 1.22rem;
    font-weight: 900;
    color: var(--alien-green);
    letter-spacing: .035em;
    text-shadow:
        0 0 14px rgba(57,255,20,.56),
        0 0 28px rgba(0,215,255,.12);
}

/* ── Qty picker ── */
.qty-picker {
    border: 1px solid rgba(57,255,20,.20);
    border-radius: 999px;
    background: rgba(57,255,20,.06);
    box-shadow: inset 0 0 16px rgba(0,0,0,.18);
}

.qty-btn {
    color: var(--text);
    transition: color .1s, background .1s;
    border-radius: 999px;
}

.qty-btn:hover {
    background: rgba(57,255,20,.11);
    color: var(--alien-green);
}

.qty-val {
    font-weight: 900;
    font-size: 13px;
    font-family: var(--font-display);
    color: var(--alien-green);
}

/* ── Buttons ── */
.add-btn {
    border-radius: 999px;
    background: linear-gradient(135deg, var(--alien-green), #9dff7a);
    color: #031006;
    font-family: var(--font-display);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
    transition: box-shadow .2s, transform .1s, filter .2s;
    box-shadow:
        0 0 15px rgba(57,255,20,.38),
        inset 0 -2px 0 rgba(0,0,0,.18);
}

.add-btn:hover {
    filter: brightness(1.08);
    box-shadow:
        0 0 25px rgba(57,255,20,.58),
        0 0 45px rgba(0,215,255,.14),
        inset 0 -2px 0 rgba(0,0,0,.20);
}

.add-btn:active { transform: scale(.97); }
.add-btn:disabled { opacity: .28; box-shadow: none; }

.customize-btn {
    border-radius: 999px;
    border: 1px solid rgba(57,255,20,.42);
    background: rgba(57,255,20,.10);
    color: var(--alien-green);
    font-family: var(--font-display);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
    transition: background .2s, box-shadow .2s, transform .1s;
}

.customize-btn:hover {
    background: rgba(57,255,20,.17);
    box-shadow: 0 0 18px rgba(57,255,20,.24);
}

.customize-btn:active { transform: scale(.97); }

/* ── Closed banner ── */
.closed-banner {
    background: linear-gradient(135deg, rgba(255,30,30,.13), rgba(255,30,30,.04));
    border: 1px solid rgba(255,80,80,.30);
    border-radius: var(--radius);
    color: #ff9b9b;
    box-shadow: 0 16px 40px rgba(0,0,0,.34);
}

/* ── No results ── */
.no-results {
    color: var(--muted);
    font-family: var(--font-body);
}

/* ── Brand strip ── */
.brand-strip {
    background:
        linear-gradient(90deg, rgba(57,255,20,.06), transparent 40%, rgba(0,215,255,.04)),
        rgba(2,6,4,.92);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(57,255,20,.14);
    box-shadow: 0 1px 0 rgba(57,255,20,.18);
}

.brand-strip-title {
    color: var(--text);
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.brand-strip-title::before {
    content: "👽 ";
}

.hours-tag.open {
    background: rgba(57,255,20,.12);
    color: var(--alien-green);
    border: 1px solid rgba(57,255,20,.38);
    border-radius: 999px;
    text-shadow: 0 0 8px rgba(57,255,20,.42);
}

.hours-tag.open::before {
    content: "SIGNAL LIVE · ";
}

.hours-tag.soon {
    background: rgba(255,200,0,.09);
    color: #ffc800;
    border: 1px solid rgba(255,200,0,.28);
    border-radius: 999px;
}

.brand-action-btn {
    color: var(--text);
    background: rgba(57,255,20,.055);
    border: 1px solid rgba(57,255,20,.16);
    border-radius: 999px;
    font-family: var(--font-display);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.brand-action-btn.call {
    background: rgba(57,255,20,.11);
    border-color: rgba(57,255,20,.34);
    color: var(--alien-green);
}

.brand-action-btn.nav {
    background: rgba(0,215,255,.09);
    border-color: rgba(0,215,255,.28);
    color: var(--alien-blue);
}

.brand-action-btn.locs {
    background: rgba(57,255,20,.08);
    border-color: rgba(57,255,20,.28);
    color: var(--alien-green);
}

/* ── Food truck ── */
.ft-card {
    border: 1px solid rgba(57,255,20,.16);
    border-radius: var(--radius);
    box-shadow:
        0 24px 80px rgba(0,0,0,.60),
        0 0 38px rgba(57,255,20,.09);
    background: var(--card);
}

.ft-header {
    background: rgba(5,16,10,.88);
}

.ft-title {
    color: var(--text);
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.ft-title::before {
    content: "🛸 ";
}

.ft-address {
    color: var(--muted);
    font-family: var(--font-body);
    font-size: .78rem;
}

.ft-status-badge {
    border-radius: 999px;
}

.ft-distance-bar {
    background: rgba(0,0,0,.44);
    color: var(--text);
    border-color: rgba(57,255,20,.12);
}

.ft-actions {
    background: rgba(0,0,0,.30);
    border-color: rgba(57,255,20,.12);
}

.ft-btn-locate {
    border-radius: 14px;
    background: linear-gradient(135deg, var(--alien-green), #9dff7a);
    color: #031006;
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.ft-btn-navigate {
    background: rgba(0,215,255,.09);
    color: var(--alien-blue);
    border-color: rgba(0,215,255,.26);
    border-radius: 14px;
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.ft-manual {
    background: rgba(0,0,0,.38);
    border-color: rgba(57,255,20,.12);
}

.ft-input {
    background: rgba(255,255,255,.055);
    border-color: rgba(57,255,20,.17);
    color: var(--text);
    font-family: var(--font-body);
    border-radius: 14px;
}

.ft-go-btn {
    border-radius: 14px;
    background: var(--alien-green);
    color: #031006;
    font-family: var(--font-display);
    font-weight: 900;
}

.ft-no-loc {
    background: rgba(5,16,10,.86);
    color: var(--muted2);
}

/* ── Mobile store bar ── */
.store-mobile-bar {
    background:
        linear-gradient(90deg, rgba(57,255,20,.06), transparent 55%),
        rgba(2,6,4,.96);
    border-bottom: 1px solid rgba(57,255,20,.14);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.store-mobile-title {
    color: var(--text);
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.store-mobile-title::before {
    content: "👽 ";
}

/* ── Hero ── */
.hero-banner {
    border-bottom: 1px solid rgba(57,255,20,.12);
}

.hero-banner-inner {
    background:
        radial-gradient(circle at 18% 14%, rgba(57,255,20,.17), transparent 30rem),
        radial-gradient(circle at 86% 18%, rgba(0,215,255,.11), transparent 28rem),
        linear-gradient(135deg, rgba(255,255,255,.035), transparent 45%);
}

.hero-announcement {
    font-family: var(--font-display);
    letter-spacing: .055em;
    text-transform: uppercase;
    text-shadow:
        0 0 24px rgba(57,255,20,.25),
        0 0 36px rgba(0,0,0,.75);
}

.hero-cta,
.hero-featured-btn {
    border-radius: 999px;
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .10em;
    text-transform: uppercase;
    background: linear-gradient(135deg, var(--alien-green), #9dff7a);
    color: #031006;
    box-shadow: 0 0 18px rgba(57,255,20,.40);
}

.hero-content-image,
.hero-featured {
    border-radius: var(--radius);
    border: 1px solid rgba(57,255,20,.16);
}

.hero-featured {
    box-shadow:
        0 22px 60px rgba(0,0,0,.50),
        0 0 34px rgba(57,255,20,.08);
}

.hero-featured-name {
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .055em;
    text-transform: uppercase;
}

.hero-featured-price {
    color: var(--alien-green);
    text-shadow:
        0 0 14px rgba(57,255,20,.55),
        0 0 28px rgba(0,215,255,.10);
}

.hero-ticker {
    font-family: var(--font-body);
    font-size: .8rem;
    letter-spacing: .11em;
    text-transform: uppercase;
}

.hero-ticker::before {
    content: "🛸 ";
}

/* ── Modal helpers from base.php inline modal ── */
#itemModal > div {
    background:
        radial-gradient(circle at top, rgba(57,255,20,.09), transparent 18rem),
        #07120c !important;
    border: 1px solid rgba(57,255,20,.18);
    box-shadow: 0 -20px 70px rgba(0,0,0,.68);
}

/* ── Mobile ── */
@media (max-width: 800px) {
    body {
        font-size: 13px;
        background:
            radial-gradient(circle at top, rgba(57,255,20,.16), transparent 20rem),
            radial-gradient(circle at bottom, rgba(0,215,255,.09), transparent 22rem),
            #020604;
    }

    .section-header {
        background: rgba(5,16,10,.88);
        border-top: 1px solid rgba(57,255,20,.12);
    }

    .section-title {
        font-size: 1.14rem;
    }

    .item-row {
        background:
            linear-gradient(90deg, rgba(57,255,20,.045), transparent 45%),
            rgba(5,16,10,.96);
        border-radius: 0;
        border-left: none;
        border-right: none;
        border-top: none;
        border-bottom: 1px solid rgba(57,255,20,.10);
        box-shadow: none;
        margin-bottom: 0;
        animation: none;
        transform: none;
    }

    .item-row:hover {
        transform: none;
        box-shadow: inset 3px 0 0 var(--alien-green);
    }

    .item-img-wrap {
        border-right: 1px solid rgba(57,255,20,.10);
        border-radius: 0;
    }

    .item-name {
        font-size: 1rem;
        letter-spacing: .04em;
    }

    .item-desc {
        font-size: .76rem;
    }

    .item-price {
        font-size: 1.1rem;
    }

    .qty-picker,
    .add-btn,
    .customize-btn {
        border-radius: 14px;
    }

    .brand-strip-title::before,
    .store-mobile-title::before {
        content: "";
    }
}
