/*
 * coastal-breeze.css — MenuSpace full storefront theme
 * Light seafood/beach house theme with navy type, aqua accents, and sandy cards.
 * Drop into /themes and select it from Admin > Appearance.
 */

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

:root {
    color-scheme: light;

    --bg:       #eef9fb;
    --surface:  rgba(248,253,253,.96);
    --card:     #ffffff;
    --card-alt: #dff4f4;
    --border:   rgba(14,64,88,.13);
    --border2:  rgba(14,64,88,.23);
    --text:     #0e4058;
    --muted:    rgba(14,64,88,.63);
    --muted2:   rgba(14,64,88,.36);
    --shadow:   0 18px 46px rgba(14,64,88,.11);
    --radius:   22px;
    --font-body:    'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --font-display: 'Fraunces', Georgia, serif;

    --theme-primary: #0e7791;
    --theme-secondary: #efb64d;
    --theme-warm: #ffe9b8;
    --theme-cool: #bdeff2;
    --theme-ink: #0e4058;
    --theme-soft: #f7edd8;
    --on-accent: #ffffff;

    --input-bg: rgba(255,255,255,.78);
    --btn-subtle-bg: rgba(14,119,145,.08);
    --btn-subtle-hover: rgba(14,119,145,.14);
    --overlay-bg: rgba(6,35,48,.62);
    --build-header-bg: rgba(238,249,251,.94);

    --hero-text: #0e4058;
    --hero-border: rgba(14,64,88,.14);
    --hero-featured-bg: rgba(255,255,255,.92);
    --hero-ticker-bg: rgba(223,244,244,.82);
    --hero-ticker-color: #0e7791;

    --footer-bg: #dff4f4;
    --footer-border: rgba(14,64,88,.14);
    --footer-text: rgba(14,64,88,.64);
    --footer-heading: #0e4058;
}

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

body {
    font-family: var(--font-body);
    color: var(--text);
    background: radial-gradient(circle at top left, rgba(89,196,205,.22), transparent 30rem), radial-gradient(circle at 88% 5%, rgba(239,182,77,.15), transparent 26rem), linear-gradient(180deg, #f8fdfd 0%, #eef9fb 50%, #f7edd8 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: 16px;
    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(238,249,251,.96), rgba(238,249,251,.76));
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.search-inner {
    background: linear-gradient(135deg, rgba(255,255,255,.94), rgba(223,244,244,.86));
    border: 1px solid var(--border);
    border-radius: 20px;
    box-shadow: var(--shadow), inset 0 0 0 1px rgba(255,255,255,.78);
}

.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: 16px;
}

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

/* ── Category pills ────────────────────────────────────────────────── */
.pill-bar {
    background: rgba(238,249,251,.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,.70);
    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,.96), rgba(240,250,249,.90));
    border: 1px solid var(--border);
    border-left: 4px solid color-mix(in srgb, var(--accent) 64%, var(--theme-primary));
    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(14,64,88,.15);
}

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

.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, #dff4f4, #f7edd8);
}

.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: 16px;
    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: #fff3d7;
    color: #92630a;
    border: 1px solid rgba(239,182,77,.34);
    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(248,253,253,.96);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 8px 30px rgba(14,64,88,.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(223,244,244,.94), 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(223,244,244,.90), rgba(255,255,255,.70), rgba(247,237,216,.74));
    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(14,64,88,.76);
    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(14,64,88,.72);
    color: #fff;
    border-color: rgba(255,255,255,.22);
    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(14,64,88,.32);
}

.item-view-close {
    background: rgba(14,64,88,.72);
    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(248,253,253,.98);
        border-bottom-color: var(--border);
    }

    .search-wrap {
        background: rgba(238,249,251,.98);
        border-bottom-color: var(--border);
    }

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

    .pill-bar {
        background: rgba(238,249,251,.98);
        border-bottom-color: var(--border);
    }

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

    .section-header {
        background: rgba(223,244,244,.90);
        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;
    }
}
