/*
 * candy-shop.css — MenuSpace full storefront theme
 * Pastel pink, mint, vanilla, and playful family-friendly cards.
 * Drop into /themes and select it from Admin > Appearance.
 */

@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@600;700;800&family=Nunito:wght@400;500;600;700;800;900&display=swap');

:root {
    color-scheme: light;

    --bg:       #fff1f7;
    --surface:  rgba(255,251,253,.96);
    --card:     #ffffff;
    --card-alt: #ffe1ee;
    --border:   rgba(112,44,77,.13);
    --border2:  rgba(112,44,77,.23);
    --text:     #442236;
    --muted:    rgba(68,34,54,.62);
    --muted2:   rgba(68,34,54,.38);
    --shadow:   0 18px 46px rgba(112,44,77,.11);
    --radius:   26px;
    --font-body:    'Nunito', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-display: 'Baloo 2', cursive;

    --theme-primary: #d94f87;
    --theme-secondary: #18a8a2;
    --theme-warm: #ffd76a;
    --theme-cool: #bdf3ef;
    --theme-ink: #442236;
    --theme-soft: #fff7d7;
    --on-accent: #ffffff;

    --input-bg: rgba(255,255,255,.78);
    --btn-subtle-bg: rgba(217,79,135,.08);
    --btn-subtle-hover: rgba(217,79,135,.14);
    --overlay-bg: rgba(68,34,54,.62);
    --build-header-bg: rgba(255,241,247,.94);

    --hero-text: #442236;
    --hero-border: rgba(112,44,77,.14);
    --hero-featured-bg: rgba(255,255,255,.94);
    --hero-ticker-bg: rgba(255,225,238,.78);
    --hero-ticker-color: #d94f87;

    --footer-bg: #ffe1ee;
    --footer-border: rgba(112,44,77,.14);
    --footer-text: rgba(68,34,54,.64);
    --footer-heading: #442236;
}

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

body {
    font-family: var(--font-body);
    color: var(--text);
    background: radial-gradient(circle at 10% 0%, rgba(217,79,135,.18), transparent 28rem), radial-gradient(circle at 90% 8%, rgba(24,168,162,.16), transparent 28rem), radial-gradient(circle at 50% 100%, rgba(255,215,106,.16), transparent 26rem), linear-gradient(180deg, #fffafd 0%, #fff1f7 52%, #f6fffb 100%);
    font-size: 14px;
    overflow-x: hidden;
}

/* ── Sidebar ───────────────────────────────────────────────────────── */
.sidebar-label {
    color: var(--theme-primary);
    letter-spacing: .15em;
    font-size: .68rem;
    text-transform: uppercase;
    font-family: var(--font-display);
    font-weight: 900;
}

.sidebar-link {
    color: var(--muted);
    border-radius: 18px;
    letter-spacing: .01em;
    border-left: 3px solid transparent;
    font-weight: 700;
}

.sidebar-link:hover {
    color: var(--text);
    background: color-mix(in srgb, var(--theme-primary) 12%, transparent);
}

.sidebar-link.active {
    color: var(--theme-ink);
    border-left-color: var(--accent);
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--accent) 20%, transparent), color-mix(in srgb, var(--theme-secondary) 8%, transparent));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 22%, transparent);
}

/* ── Search ────────────────────────────────────────────────────────── */
.search-wrap {
    background: linear-gradient(180deg, rgba(255,241,247,.96), rgba(255,241,247,.76));
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.search-inner {
    background: linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,225,238,.82));
    border: 1px solid var(--border);
    border-radius: 999px;
    box-shadow: var(--shadow), inset 0 0 0 1px rgba(255,255,255,.76);
}

.search-inner:focus-within {
    border-color: color-mix(in srgb, var(--accent) 62%, var(--border2));
    box-shadow:
        0 0 0 4px color-mix(in srgb, var(--accent) 16%, transparent),
        var(--shadow);
}

.search-icon {
    color: var(--accent);
}

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

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

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

.search-clear:hover {
    color: var(--text);
    background: color-mix(in srgb, var(--accent) 12%, transparent);
}

/* ── Category pills ────────────────────────────────────────────────── */
.pill-bar {
    background: rgba(255,241,247,.94);
    border-bottom: 1px solid var(--border);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

.pill-tab {
    border-radius: 999px;
    border: 1px solid var(--border);
    background: rgba(255,255,255,.72);
    color: var(--muted);
    font-family: var(--font-display);
    font-weight: 900;
    letter-spacing: .075em;
    text-transform: uppercase;
    transition: color .15s ease, border-color .15s ease, background .15s ease, box-shadow .15s ease, transform .12s ease;
}

.pill-tab:hover {
    color: var(--theme-ink);
    border-color: color-mix(in srgb, var(--accent) 48%, var(--border));
}

.pill-tab.active {
    color: var(--on-accent);
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 72%, var(--theme-secondary)));
    border-color: color-mix(in srgb, var(--accent) 78%, var(--theme-secondary));
    box-shadow: 0 12px 26px color-mix(in srgb, var(--accent) 26%, transparent);
}

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

/* ── Sections ──────────────────────────────────────────────────────── */
.section-title {
    font-family: var(--font-display);
    font-size: 1.42rem;
    font-weight: 900;
    letter-spacing: .065em;
    text-transform: uppercase;
    color: var(--theme-ink);
}

.section-title::after {
    content: "";
    display: inline-block;
    width: .48em;
    height: .48em;
    margin-left: .46em;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);
    vertical-align: .08em;
}

.section-line {
    background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 42%, transparent), color-mix(in srgb, var(--theme-secondary) 22%, transparent), transparent);
}

.section-count {
    font-size: 10px;
    color: var(--theme-ink);
    font-weight: 900;
    background: color-mix(in srgb, var(--accent) 11%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 24%, transparent);
}

.items-list { background: transparent; }

/* ── Menu item rows ────────────────────────────────────────────────── */
.item-row {
    background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(255,244,250,.92));
    border: 1px solid var(--border);
    border-left: 4px solid color-mix(in srgb, var(--accent) 58%, var(--theme-secondary));
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
    margin-bottom: 13px;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.item-row:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--accent) 40%, var(--border));
    box-shadow: 0 22px 54px rgba(112,44,77,.15);
}

.item-img-wrap {
    background: #ffe1ee;
}

.item-img {
    transition: transform .35s ease, filter .35s ease;
    filter: saturate(.94) contrast(1.03);
}

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

.item-no-img {
    color: var(--muted2);
    background: linear-gradient(135deg, #ffe1ee, #bdf3ef);
}

.item-name {
    font-family: var(--font-display);
    font-size: 1.04rem;
    font-weight: 900;
    letter-spacing: .025em;
    color: var(--text);
}

.item-desc {
    color: var(--muted);
    font-size: .82rem;
    line-height: 1.45;
}

.item-badge {
    padding: 2px 8px;
    border-radius: 999px;
    font-size: .64rem;
    font-weight: 900;
    letter-spacing: .045em;
    text-transform: uppercase;
    color: var(--theme-ink);
    background: color-mix(in srgb, var(--accent) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 26%, transparent);
}

.item-price {
    font-family: var(--font-display);
    color: var(--theme-ink);
    font-weight: 900;
    font-size: 1.12rem;
    letter-spacing: .02em;
}

/* ── Quantity and action buttons ───────────────────────────────────── */
.qty-picker {
    border: 1px solid var(--border2);
    border-radius: 18px;
    background: var(--input-bg);
}

.qty-btn { color: var(--text); }
.qty-btn:hover {
    color: var(--theme-ink);
    background: color-mix(in srgb, var(--accent) 12%, transparent);
}
.qty-val {
    color: var(--theme-ink);
    font-family: var(--font-display);
    font-weight: 900;
}

.add-btn,
.item-view-add-btn {
    border-radius: 999px;
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 76%, var(--theme-secondary)));
    color: var(--on-accent);
    font-family: var(--font-display);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .07em;
    text-transform: uppercase;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--accent) 24%, transparent);
    transition: transform .13s ease, box-shadow .15s ease, opacity .15s ease;
}

.add-btn:hover,
.item-view-add-btn:hover {
    box-shadow: 0 14px 30px color-mix(in srgb, var(--accent) 32%, transparent);
}

.add-btn:active,
.item-view-add-btn:active { transform: scale(.97); }
.add-btn:disabled { opacity: .36; box-shadow: none; }
.add-btn.added { background: #00d26a !important; color: #07130b !important; }

.customize-btn,
.item-view-customize {
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--accent) 42%, var(--border));
    background: color-mix(in srgb, var(--accent) 9%, var(--card));
    color: var(--theme-ink);
    font-family: var(--font-display);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .06em;
    text-transform: uppercase;
}

.customize-btn:hover,
.item-view-customize:hover {
    background: color-mix(in srgb, var(--accent) 16%, var(--card));
}

/* ── Store status / empty states ───────────────────────────────────── */
.closed-banner {
    background: #fff0f6;
    color: #af3569;
    border: 1px solid rgba(217,79,135,.30);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
}

.no-results {
    color: var(--muted);
}

/* ── Reservation CTA ───────────────────────────────────────────────── */
.reservation-cta {
    font-family: var(--font-display);
    letter-spacing: .035em;
    box-shadow: var(--shadow);
}

.reservation-cta.primary {
    color: var(--on-accent);
}

.reservation-cta.secondary {
    background: var(--btn-subtle-bg);
    color: var(--text);
}

/* ── Brand strip ───────────────────────────────────────────────────── */
.brand-strip,
.store-mobile-bar {
    background: rgba(255,251,253,.96);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 8px 30px rgba(112,44,77,.08);
}

.brand-strip-title,
.store-mobile-title {
    color: var(--text);
    font-family: var(--font-display);
    letter-spacing: .035em;
    text-transform: uppercase;
}

.hours-tag {
    color: var(--theme-ink);
    background: color-mix(in srgb, var(--accent) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--accent) 26%, transparent);
}

.brand-action-btn {
    border-radius: 999px;
    border: 1px solid var(--border2);
    background: var(--btn-subtle-bg);
    color: var(--text);
}

.brand-action-btn.locs {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--on-accent);
}

.brand-action-btn.call {
    background: color-mix(in srgb, #00d26a 13%, transparent);
    color: #00a85a;
    border-color: color-mix(in srgb, #00d26a 28%, transparent);
}

.brand-action-btn.nav {
    background: color-mix(in srgb, var(--theme-secondary) 13%, transparent);
    color: var(--theme-secondary);
    border-color: color-mix(in srgb, var(--theme-secondary) 28%, transparent);
}

/* ── Food truck widget ─────────────────────────────────────────────── */
.ft-card {
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
}

.ft-header {
    background: linear-gradient(135deg, rgba(255,225,238,.90), rgba(189,243,239,.55), rgba(255,255,255,.88));
    border-bottom: 1px solid var(--border);
}

.ft-icon,
.ft-title {
    color: var(--theme-ink);
}

.ft-address { color: var(--muted); }
.ft-status-badge {
    color: var(--theme-ink);
    background: color-mix(in srgb, var(--accent) 11%, transparent);
    border-color: color-mix(in srgb, var(--accent) 28%, transparent);
}
.ft-map,
.ft-no-loc { background: var(--card-alt); color: var(--muted); }
.ft-distance-bar,
.ft-actions,
.ft-manual { border-color: var(--border); }
.ft-btn-locate,
.ft-go-btn { background: var(--accent); color: var(--on-accent); }
.ft-btn-navigate { color: var(--theme-ink); border-color: color-mix(in srgb, var(--accent) 32%, var(--border)); }
.ft-input {
    background: var(--input-bg);
    color: var(--text);
    border-color: var(--border2);
}
.ft-input:focus {
    border-color: color-mix(in srgb, var(--accent) 54%, var(--border2));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 13%, transparent);
}

/* ── Hero banner ───────────────────────────────────────────────────── */
.hero-banner {
    background: linear-gradient(135deg, rgba(255,225,238,.82), rgba(189,243,239,.58), rgba(255,247,215,.72));
    border-bottom: 1px solid var(--hero-border);
}

.hero-announcement {
    font-family: var(--font-display);
    letter-spacing: .025em;
}

.hero-cta,
.hero-featured-btn {
    color: var(--on-accent);
    box-shadow: 0 12px 28px color-mix(in srgb, var(--accent) 24%, transparent);
}

.hero-featured {
    background: var(--hero-featured-bg);
    border-color: var(--hero-border);
    box-shadow: var(--shadow);
}

.hero-featured-name {
    font-family: var(--font-display);
    color: var(--text);
    letter-spacing: .025em;
}

.hero-featured-desc { color: var(--muted); }
.hero-featured-price { color: var(--theme-ink); }
.hero-featured-img-ph { background: var(--card-alt); color: var(--muted2); }
.carousel-prev,
.carousel-next {
    background: rgba(68,34,54,.72);
    border: 1px solid var(--border2);
    color: #ffffff;
}
.carousel-dot { background: color-mix(in srgb, var(--theme-ink) 24%, transparent); }
.carousel-dot.active { background: var(--accent); }
.hero-ticker-wrap { border-top-color: var(--hero-border); }

/* ── Item view modal ───────────────────────────────────────────────── */
.item-zoom-btn {
    background: rgba(68,34,54,.70);
    color: #fff;
    border-color: rgba(255,255,255,.23);
    font-family: var(--font-display);
    font-weight: 900;
}

.item-view-backdrop {
    background: var(--overlay-bg);
}

.item-view-dialog {
    background: var(--surface);
    border-color: var(--border2);
    border-radius: calc(var(--radius) + 6px);
    box-shadow: 0 32px 100px rgba(68,34,54,.32);
}

.item-view-close {
    background: rgba(68,34,54,.70);
    color: #fff;
    border-color: var(--border2);
}

.item-view-media,
.item-view-no-img {
    background: var(--card-alt);
    color: var(--muted2);
}

.item-view-name {
    font-family: var(--font-display);
    color: var(--text);
}

.item-view-desc { color: var(--muted); }
.item-view-price { color: var(--theme-ink); }

/* ── Mobile tuning ─────────────────────────────────────────────────── */
@media (max-width: 800px) {
    .store-mobile-bar {
        background: rgba(255,251,253,.98);
        border-bottom-color: var(--border);
    }

    .search-wrap {
        background: rgba(255,241,247,.98);
        border-bottom-color: var(--border);
    }

    .search-inner {
        border-radius: 0;
        box-shadow: none;
    }

    .pill-bar {
        background: rgba(255,241,247,.98);
        border-bottom-color: var(--border);
    }

    .pill-tab {
        border-radius: 999px;
        font-size: 12px;
    }

    .section-header {
        background: rgba(255,225,238,.84);
        border-top: 1px solid var(--border);
    }

    .section-title {
        font-size: 1rem;
        letter-spacing: .045em;
    }

    .section-title::after { display: none; }

    .item-row {
        margin-bottom: 0;
        border-radius: 0;
        border-left: none;
        border-right: none;
        box-shadow: none;
        transform: none !important;
        background: #ffffff;
    }

    .item-row:hover {
        box-shadow: none;
    }

    .item-name { font-size: .96rem; }
    .item-price { font-size: .98rem; }

    .closed-banner {
        border-radius: 0;
        box-shadow: none;
    }

    .hero-banner {
        margin-bottom: 0;
    }
}
