*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    --bg: #0d0f14;
    --surface: #161920;
    --surface2: #1e2230;
    --border: #272c3d;
    --border-light: #313649;
    --text: #e2e4ed;
    --text-muted: #6b718f;
    --text-dim: #8b92ad;
    --accent: #f0a500;
    --accent-dim: rgba(240,165,0,0.12);
    --green: #27c96a;
    --green-dim: rgba(39,201,106,0.1);
    --red-dim: rgba(220,60,60,0.1);
    --radius: 12px;
    --radius-sm: 8px;
    --font: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
}

body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--font);
    min-height: 100vh;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }

/* ── Header ── */
header {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 0 16px;
    height: 52px;
    display: flex;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(8px);
}

.logo { font-size: 1rem; font-weight: 700; color: var(--accent); letter-spacing: -0.01em; flex-shrink: 0; }
.nav { display: flex; align-items: center; justify-content: space-between; width: 100%; gap: 8px; overflow: hidden; }
.nav-sync { font-size: 0.68rem; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; text-align: right; }

main { padding: 20px 0 80px; }

.container { max-width: 1080px; margin: 0 auto; padding: 0 14px; }

h1 { font-size: clamp(1.3rem, 3.5vw, 1.8rem); font-weight: 700; letter-spacing: -0.02em; }
.subtitle { color: var(--text-muted); font-size: 0.875rem; margin-top: 4px; }

.breadcrumb {
    display: flex; gap: 6px; align-items: center; flex-wrap: wrap;
    color: var(--text-muted); font-size: 0.78rem; margin-bottom: 16px;
}
.breadcrumb a { color: var(--accent); }
.breadcrumb a:hover { text-decoration: underline; }

/* ── Wizard home ── */
.wizard-home .hero { padding: 40px 0 28px; }
.wizard-home h1 { font-size: clamp(1.5rem, 4vw, 2.2rem); }

.scenario-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
@media (min-width: 600px) { .scenario-grid { grid-template-columns: 1fr 1fr; } }

.scenario-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: border-color 0.15s;
}
.scenario-card:hover { border-color: var(--border-light); }

.scenario-icon { font-size: 1.6rem; margin-bottom: 4px; }
.scenario-title { font-size: 1.1rem; font-weight: 700; }
.scenario-desc { color: var(--text-muted); font-size: 0.85rem; line-height: 1.4; margin-bottom: 16px; }
.scenario-body { display: flex; flex-direction: column; gap: 10px; }

.step-label { font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-muted); margin-bottom: 4px; display: block; }

.wizard-select {
    width: 100%;
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 10px 36px 10px 12px;
    font-size: 0.875rem;
    outline: none;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b718f' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    transition: border-color 0.15s;
}
.wizard-select:focus, .wizard-select:hover { border-color: var(--border-light); }

.city-btns { display: flex; flex-wrap: wrap; gap: 6px; }
.btn-city {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px 14px;
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s;
    display: inline-block;
}
.btn-city:hover { border-color: var(--accent); color: var(--accent); }

/* ── Page header ── */
.page-header { margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border); }

/* ── User panel ── */
.user-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px 14px;
    margin-bottom: 16px;
}

.user-form { display: flex; gap: 8px; align-items: stretch; }

.user-form input[type="text"] {
    flex: 1;
    min-width: 0;
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 9px 12px;
    font-size: 0.875rem;
    outline: none;
    transition: border-color 0.15s;
}
.user-form input:focus { border-color: var(--border-light); }

.user-form button {
    background: var(--accent);
    color: #000;
    border: none;
    border-radius: var(--radius-sm);
    padding: 9px 16px;
    font-size: 0.85rem;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.15s;
    flex-shrink: 0;
}
.user-form button:hover { opacity: 0.88; }

/* user badge — replaces the whole user-panel after login */
.user-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.875rem;
    font-weight: 600;
    min-width: 0;
    flex: 1;
}
.user-badge .stats { color: var(--text-muted); font-weight: 400; font-size: 0.8rem; white-space: nowrap; }
.btn-link { color: var(--text-muted); font-size: 0.78rem; font-weight: 400; text-decoration: underline; cursor: pointer; white-space: nowrap; background: none; border: none; padding: 0; }

/* ── Toolbar (filters + badge in one row) ── */
.toolbar {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 16px;
    padding: 10px 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}
.toolbar-top { display: flex; align-items: center; gap: 8px; }
.toolbar-actions { display: flex; gap: 10px; margin-left: auto; flex-shrink: 0; }
.toolbar-filters { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.toolbar .wizard-select { width: auto; flex: 1; min-width: 110px; max-width: 180px; }

.filter-btns { display: flex; gap: 5px; flex-wrap: wrap; }

.btn {
    background: var(--surface2);
    color: var(--text-dim);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 7px 13px;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: border-color 0.15s, color 0.15s, background 0.15s;
    white-space: nowrap;
}
.btn:hover { border-color: var(--border-light); color: var(--text); }
.btn.active { border-color: var(--accent); color: var(--accent); background: var(--accent-dim); }
.btn-green { background: var(--green-dim); color: var(--green); border-color: rgba(39,201,106,0.3); }
.btn-green:hover { background: var(--green); color: #000; border-color: var(--green); }
.btn-green.active { background: var(--green); color: #000; border-color: var(--green); }
.btn-drunk { background: var(--surface2); color: var(--text-dim); border-color: var(--border); }
.btn-drunk.active { border-color: var(--text-dim); color: var(--text); background: var(--surface2); }

/* ── Section header ── */
.section-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 28px 0 12px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
}
.section-header:first-child { margin-top: 0; }

.section-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 3px 10px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}
.section-pill.draft { border-color: rgba(240,165,0,0.3); color: var(--accent); background: var(--accent-dim); }
.section-pill.bottle { border-color: rgba(107,113,143,0.3); color: var(--text-dim); }

.section-count {
    margin-left: auto;
    font-size: 0.72rem;
    color: var(--text-muted);
    font-weight: 400;
}

/* ── Beer grid ── */
.beer-grid, .explore-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
}
@media (min-width: 500px) { .beer-grid, .explore-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 860px) { .beer-grid, .explore-grid { grid-template-columns: repeat(3, 1fr); } }

/* ── Beer card ── */
.beer-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px;
    display: flex;
    gap: 10px;
    align-items: flex-start;
    position: relative;
    transition: border-color 0.12s;
    min-width: 0;
}
.beer-card:hover { border-color: var(--border-light); }

.beer-card.not-drunk {
    border-color: rgba(39,201,106,0.35);
    background: linear-gradient(135deg, var(--surface) 60%, rgba(39,201,106,0.06) 100%);
}
.beer-card.drunk { opacity: 0.45; }

.beer-label {
    width: 44px;
    height: 44px;
    object-fit: contain;
    border-radius: 6px;
    flex-shrink: 0;
    background: var(--surface2);
}

.beer-info { flex: 1; min-width: 0; }

.beer-name {
    font-weight: 600;
    font-size: 0.875rem;
    line-height: 1.3;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.beer-name a:hover { color: var(--accent); }

.beer-brewery {
    color: var(--text-muted);
    font-size: 0.75rem;
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.beer-meta { display: flex; flex-wrap: wrap; gap: 3px; margin-top: 5px; }

.tag {
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 1px 5px;
    font-size: 0.7rem;
    color: var(--text-muted);
    white-space: nowrap;
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.beer-price { color: var(--accent); font-size: 0.8rem; margin-top: 4px; font-weight: 700; }
.tag-rating { color: var(--accent); border-color: rgba(240,165,0,0.25); background: var(--accent-dim); }

/* drunk indicator */
.drunk-indicator {
    position: absolute;
    top: 9px; right: 9px;
    width: 18px; height: 18px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.65rem; font-weight: 800;
    flex-shrink: 0;
}
.drunk .drunk-indicator { background: var(--surface2); color: var(--text-muted); }
.not-drunk .drunk-indicator { background: var(--green); color: #000; }

/* ── Venue chips (explore) ── */
.venue-tags { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 6px; }

.venue-chip {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 0.7rem; font-weight: 600;
    padding: 2px 7px;
    border-radius: 4px;
    border: 1px solid;
    transition: opacity 0.12s;
    white-space: nowrap;
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
}
.venue-chip:hover { opacity: 0.75; }
.chip-draft { background: var(--accent-dim); border-color: rgba(240,165,0,0.3); color: var(--accent); }
.chip-bottle { background: var(--surface2); border-color: var(--border); color: var(--text-dim); }

.chip-dot {
    width: 5px; height: 5px;
    border-radius: 50%;
    flex-shrink: 0;
}
.chip-draft .chip-dot { background: var(--accent); }
.chip-bottle .chip-dot { background: var(--text-muted); }

/* ── Loading ── */
.user-loading {
    display: flex; align-items: center; gap: 14px;
    padding: 20px 14px;
    color: var(--text-muted);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    margin-bottom: 16px;
}
.user-loading small { display: block; font-size: 0.78rem; margin-top: 2px; }
.progress-text { color: var(--accent); font-size: 0.82rem; margin-top: 2px; }

.spinner {
    width: 20px; height: 20px;
    border: 2px solid var(--border);
    border-top-color: var(--accent);
    border-radius: 50%;
    animation: spin 0.75s linear infinite;
    flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── States ── */
.empty-state { padding: 48px 0; text-align: center; color: var(--text-muted); font-size: 0.9rem; }
.error-msg {
    background: var(--red-dim);
    border: 1px solid rgba(220,60,60,0.25);
    color: #e07070;
    border-radius: var(--radius);
    padding: 12px 16px;
    font-size: 0.875rem;
}

/* ── City / venue grids ── */
.city-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 10px; margin-top: 20px;
}
.city-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 18px 16px;
    display: block;
    transition: border-color 0.15s;
}
.city-card:hover { border-color: var(--border-light); }
.city-name { font-size: 0.95rem; font-weight: 600; }
.city-meta { color: var(--text-muted); font-size: 0.78rem; margin-top: 4px; }

.venue-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px; margin-top: 16px;
}
@media (min-width: 500px) { .venue-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 800px) { .venue-grid { grid-template-columns: repeat(3, 1fr); } }

.venue-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 16px;
    display: block;
    transition: border-color 0.15s;
}
.venue-card:hover { border-color: var(--border-light); }
.venue-name { font-size: 0.95rem; font-weight: 600; }
.venue-address { color: var(--text-muted); font-size: 0.78rem; margin-top: 3px; }
.venue-meta { color: var(--accent); font-size: 0.8rem; margin-top: 8px; }

.venue-header { margin-bottom: 20px; }
.venue-address { color: var(--text-muted); font-size: 0.85rem; margin-top: 3px; }

.venue-meta-card {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.venue-meta-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 20px;
    color: var(--text-muted);
    font-size: 0.82rem;
    text-decoration: none;
    transition: border-color 0.15s, color 0.15s;
    white-space: nowrap;
}

.venue-meta-item:hover {
    border-color: var(--accent);
    color: var(--accent);
}

.venue-meta-icon { font-size: 0.9rem; }

.htmx-indicator { display: none; }
.htmx-request .htmx-indicator { display: inline; }

/* ── Admin ── */
.admin-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 28px;
}
@media (max-width: 600px) { .admin-stats { grid-template-columns: repeat(2, 1fr); } }

.stat-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px 16px;
    text-align: center;
}
.stat-value { font-size: 2rem; font-weight: 700; color: var(--accent); }
.stat-label { font-size: 0.75rem; color: var(--text-muted); margin-top: 4px; }

.admin-section { margin-bottom: 32px; }

/* ── Admin tabs ── */
.admin-tabs-radio { display: none; }

.admin-tab-nav {
    display: flex;
    gap: 4px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 24px;
}
.admin-tab-label {
    padding: 8px 16px;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    border: 1px solid transparent;
    border-bottom: none;
    margin-bottom: -1px;
    transition: color 0.15s;
}
.admin-tab-label:hover { color: var(--text); }
.admin-tab-panel { display: none; }

#tab-sync:checked ~ .admin-tab-nav label[for="tab-sync"],
#tab-users:checked ~ .admin-tab-nav label[for="tab-users"],
#tab-venues:checked ~ .admin-tab-nav label[for="tab-venues"] {
    color: var(--text);
    background: var(--surface);
    border-color: var(--border);
}
#tab-sync:checked ~ .admin-tab-panels #panel-sync,
#tab-users:checked ~ .admin-tab-panels #panel-users,
#tab-venues:checked ~ .admin-tab-panels #panel-venues { display: block; }

.admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}
.admin-table th {
    text-align: left;
    padding: 8px 12px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
}
.admin-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
}
.admin-table tr:last-child td { border-bottom: none; }
.admin-table .muted { color: var(--text-muted); }

.btn-delete {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 0.78rem;
    cursor: pointer;
    padding: 0;
    text-decoration: underline;
}
.btn-delete:hover { color: #e07070; }

.admin-input {
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 5px 8px;
    font-size: 0.875rem;
    outline: none;
    width: 200px;
    transition: border-color 0.15s;
}
.admin-input:focus { border-color: var(--border-light); }

.btn-save {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 0.78rem;
    cursor: pointer;
    padding: 0;
    text-decoration: underline;
    white-space: nowrap;
}
.btn-save:hover { color: var(--accent); }

/* ── Sync progress ── */
.sync-progress-header {
    display: flex; align-items: center; gap: 10px; margin-bottom: 10px;
}
.sync-status-badge {
    font-size: 0.72rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.06em; padding: 3px 8px; border-radius: 4px;
}
.sync-status-badge.running { background: var(--accent-dim); color: var(--accent); }
.sync-status-badge.done { background: var(--green-dim); color: var(--green); }
.sync-counter { font-size: 0.78rem; color: var(--text-muted); }

.sync-venue-list { display: flex; flex-direction: column; gap: 4px; }
.sync-venue-row {
    display: flex; align-items: center; gap: 8px;
    font-size: 0.82rem;
}
.sync-venue-icon { width: 16px; text-align: center; font-size: 0.75rem; }
.sync-venue-icon.ok { color: var(--green); }
.sync-venue-icon.error { color: #e07070; }
.sync-venue-icon.syncing { color: var(--accent); }
.sync-venue-name { flex: 1; }
.sync-venue-beers { color: var(--text-muted); font-size: 0.75rem; }

/* ── Style dropdown ── */
.style-dropdown { position: relative; }

.style-dropdown-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 10px 12px;
    font-size: 0.875rem;
    cursor: pointer;
    white-space: nowrap;
    transition: border-color 0.15s;
    width: 100%;
}
.style-dropdown-btn:hover,
.style-dropdown.open .style-dropdown-btn { border-color: var(--border-light); }
.style-dropdown-btn svg { margin-left: auto; flex-shrink: 0; color: var(--text-muted); transition: transform 0.15s; }
.style-dropdown.open .style-dropdown-btn svg { transform: rotate(180deg); }

.style-dropdown-menu {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    min-width: 240px;
    max-width: 320px;
    max-height: 360px;
    overflow-y: auto;
    background: var(--surface);
    border: 1px solid var(--border-light);
    border-radius: var(--radius);
    z-index: 200;
    padding: 6px 0;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.style-dropdown-menu.open { display: block; }

.style-dropdown-clear {
    padding: 4px 10px 8px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 4px;
    display: flex;
    gap: 10px;
}
.style-dropdown-clear button {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 0.75rem;
    cursor: pointer;
    text-decoration: underline;
    padding: 0;
}
.style-dropdown-clear button:hover { color: var(--text); }

.style-group { padding: 2px 0; }

.style-group-label {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 12px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
    cursor: pointer;
    user-select: none;
}
.style-group-label:hover { color: var(--text); }
.style-group-label input { accent-color: var(--accent); cursor: pointer; }

.style-item-label {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 12px 4px 24px;
    font-size: 0.82rem;
    color: var(--text-dim);
    cursor: pointer;
    user-select: none;
    transition: background 0.1s, color 0.1s;
}
.style-item-label:hover { background: var(--surface2); color: var(--text); }
.style-item-label.checked { color: var(--text); }
.style-item-label input { accent-color: var(--accent); cursor: pointer; flex-shrink: 0; }

/* ── Mobile ── */
@media (max-width: 480px) {
    h1 { font-size: 1.3rem; }

    .btn { padding: 6px 10px; font-size: 0.78rem; }

    .page-header { margin-bottom: 14px; padding-bottom: 12px; }

    /* venue grid stays 1-col, already default */

    /* beer card tighter */
    .beer-card { padding: 10px; gap: 8px; }
    .beer-label { width: 38px; height: 38px; }
    .beer-name { font-size: 0.82rem; }

    /* toolbar select full width on small screens */
    .toolbar-filters { flex-direction: column; align-items: stretch; }
    .toolbar .wizard-select { max-width: 100%; }
    .filter-btns { justify-content: flex-start; }

    /* admin table horizontal scroll */
    .admin-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .admin-input { width: 140px; }

    /* scenario cards full width (already 1-col, just tighten padding) */
    .scenario-card { padding: 18px 14px; }

    /* city/venue cards */
    .city-grid { grid-template-columns: repeat(2, 1fr); }
}

