/* ============================================================
   SBS Public & Portal Stylesheet
   ============================================================ */

:root {
    --sbs-navy:   #1a3a5c;
    --sbs-blue:   #2563eb;
    --sbs-green:  #16a34a;
    --sbs-red:    #dc2626;
    --sbs-yellow: #f0a500;
    --sbs-gray:   #6b7280;
    --sbs-light:  #f8fafc;
    --sbs-border: #e2e8f0;
    --sbs-radius: 10px;
    --sbs-shadow: 0 1px 4px rgba(0,0,0,.10);
}

/* ── Shared utilities ─────────────────────────────────────── */
.sbs-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    padding: 10px 20px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1;
    text-decoration: none;
    border: 1.5px solid transparent;
    cursor: pointer;
    transition: background .15s, color .15s, transform .1s, opacity .15s;
    white-space: nowrap;
    font-family: inherit;
    vertical-align: middle;
}
.sbs-btn:hover { opacity: .85; transform: translateY(-1px); }
.sbs-btn:active { transform: translateY(0); }
.sbs-btn--primary { background: var(--sbs-navy); color: #fff; }
.sbs-btn--ghost   { background: transparent; color: var(--sbs-navy); border: 1.5px solid var(--sbs-navy); }
.sbs-btn--sm {
    padding: 8px 14px;
    font-size: 13px;
    line-height: 1;
}

/* ── Directory ────────────────────────────────────────────── */
.sbs-archive-header { text-align: center; padding: 40px 0 20px; }
.sbs-archive-header h1 { color: var(--sbs-navy); }

.sbs-directory { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

.sbs-directory__filters {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.sbs-directory__search-form { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; width: 100%; }
.sbs-directory__search-input {
    flex: 1;
    min-width: 200px;
    padding: 10px 14px;
    border: 1.5px solid var(--sbs-border);
    border-radius: 6px;
    font-size: 14px;
}
.sbs-directory__cat-select {
    padding: 10px 14px;
    border: 1.5px solid var(--sbs-border);
    border-radius: 6px;
    font-size: 14px;
    background: #fff;
}

.sbs-directory__alpha {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 20px;
}
.sbs-alpha-link {
    display: inline-block;
    width: 32px;
    height: 32px;
    line-height: 32px;
    text-align: center;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 600;
    color: var(--sbs-navy);
    text-decoration: none;
    transition: background .15s;
}
.sbs-alpha-link:hover { background: var(--sbs-navy); color: #fff; }
.sbs-alpha-link--active { background: var(--sbs-navy); color: #fff; }

.sbs-directory__count { color: var(--sbs-gray); font-size: 13px; margin-bottom: 20px; }
.sbs-directory__empty { text-align: center; padding: 60px 0; color: var(--sbs-gray); }

/* Grid */
.sbs-directory__grid {
    display: grid;
    gap: 20px;
    margin-bottom: 40px;
}
.sbs-directory__grid--3col { grid-template-columns: repeat(3, 1fr); }
.sbs-directory__grid--2col { grid-template-columns: repeat(2, 1fr); }
.sbs-directory__grid--4col { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 900px) {
    .sbs-directory__grid--3col,
    .sbs-directory__grid--4col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
    .sbs-directory__grid { grid-template-columns: 1fr; }
}

/* Exhibitor card */
.sbs-exhibitor-card {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1.5px solid var(--sbs-border);
    border-radius: var(--sbs-radius);
    text-decoration: none;
    color: inherit;
    overflow: hidden;
    box-shadow: var(--sbs-shadow);
    transition: box-shadow .2s, transform .2s;
    position: relative;
}
.sbs-exhibitor-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.13); transform: translateY(-3px); }

.sbs-exhibitor-card--sponsor    { border-color: #e5c97e; }
.sbs-exhibitor-card--gold       { border-color: #ca8a04; }
.sbs-exhibitor-card--platinum   { border-color: #94a3b8; background: linear-gradient(135deg,#f8fafc,#e2e8f0); }

.sbs-exhibitor-card__logo {
    height: 140px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: var(--sbs-light);
    border-bottom: 1px solid var(--sbs-border);
}
.sbs-exhibitor-card__logo img { max-height: 100px; max-width: 100%; object-fit: contain; }
.sbs-exhibitor-card__logo-placeholder {
    width: 80px; height: 80px;
    background: var(--sbs-navy);
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    font-weight: 700;
}
.sbs-exhibitor-card__body { padding: 16px; flex: 1; }
.sbs-exhibitor-card__name { font-size: 15px; font-weight: 700; color: var(--sbs-navy); margin: 0 0 4px; }
.sbs-exhibitor-card__cat  { font-size: 12px; color: var(--sbs-gray); margin: 0 0 4px; }
.sbs-exhibitor-card__booth { font-size: 12px; color: var(--sbs-blue); margin: 0; }
.sbs-exhibitor-card__excerpt { font-size: 13px; color: #555; margin: 8px 0 0; }

.sbs-sponsor-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: 3px 8px;
    border-radius: 20px;
}
.sbs-sponsor-badge--gold     { background: #fef9c3; color: #854d0e; }
.sbs-sponsor-badge--platinum { background: #e2e8f0; color: #334155; }
.sbs-sponsor-badge--silver   { background: #f1f5f9; color: #475569; }
.sbs-sponsor-badge--bronze   { background: #fef3c7; color: #92400e; }

/* ── Single exhibitor ─────────────────────────────────────── */
.sbs-single-exhibitor__hero {
    background: var(--sbs-navy);
    color: #fff;
    padding: 48px 40px;
}
.sbs-single-exhibitor__hero--sponsor { background: linear-gradient(135deg, #1a3a5c, #2563eb); }
.sbs-single-exhibitor__hero-inner {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 32px;
    flex-wrap: wrap;
}
.sbs-single-exhibitor__logo-wrap {
    width: 120px;
    height: 120px;
    background: rgba(255,255,255,.15);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 12px;
}
.sbs-single-exhibitor__logo { max-width: 100%; max-height: 96px; object-fit: contain; }
.sbs-single-exhibitor__logo-placeholder {
    font-size: 48px;
    font-weight: 700;
    color: rgba(255,255,255,.6);
}
.sbs-single-exhibitor__name  { font-size: 28px; font-weight: 700; margin: 8px 0 4px; }
.sbs-single-exhibitor__cat   { font-size: 14px; opacity: .8; margin: 0 0 4px; }
.sbs-single-exhibitor__booth { font-size: 14px; opacity: .7; margin: 0; }

.sbs-single-exhibitor__body {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 20px;
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 32px;
}
@media (max-width: 720px) { .sbs-single-exhibitor__body { grid-template-columns: 1fr; } }

.sbs-single-exhibitor__about h2 { color: var(--sbs-navy); }
.sbs-single-exhibitor__sidebar-card {
    background: #fff;
    border: 1.5px solid var(--sbs-border);
    border-radius: var(--sbs-radius);
    padding: 20px;
    margin-bottom: 16px;
}
.sbs-single-exhibitor__sidebar-card h3 { font-size: 14px; color: var(--sbs-navy); margin: 0 0 12px; }

.sbs-social-links { display: flex; gap: 10px; margin-top: 10px; }
.sbs-social-link {
    width: 36px; height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--sbs-light);
    color: var(--sbs-navy);
    transition: background .2s;
    text-decoration: none;
}
.sbs-social-link svg { width: 18px; height: 18px; }
.sbs-social-link:hover { background: var(--sbs-navy); color: #fff; }

/* ── Portal SPA ───────────────────────────────────────────── */
.sbs-portal { max-width: 820px; margin: 0 auto; padding: 0 16px 60px; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }

.sbs-portal__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 32px 0 20px;
    border-bottom: 2px solid var(--sbs-border);
    margin-bottom: 24px;
    gap: 16px;
}
.sbs-portal__company  { font-size: 22px; font-weight: 700; color: var(--sbs-navy); margin: 0 0 4px; }
.sbs-portal__subtitle { font-size: 14px; color: var(--sbs-gray); margin: 0; }
.sbs-portal__logout   { align-self: center; flex-shrink: 0; }

.sbs-portal__progress { display: flex; align-items: center; gap: 12px; margin-bottom: 24px; }
.sbs-progress-bar { flex: 1; height: 10px; background: var(--sbs-border); border-radius: 5px; overflow: hidden; }
.sbs-progress-bar__fill { height: 100%; background: var(--sbs-green); transition: width .4s ease; }
.sbs-progress-label { font-size: 14px; font-weight: 600; color: var(--sbs-green); min-width: 70px; }

.sbs-portal__tabs { display: flex; gap: 4px; border-bottom: 2px solid var(--sbs-border); margin-bottom: 28px; }
.sbs-portal__tab {
    padding: 10px 20px;
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: var(--sbs-gray);
    margin-bottom: -2px;
    transition: color .15s;
}
.sbs-portal__tab--active { color: var(--sbs-navy); border-bottom-color: var(--sbs-navy); }
.sbs-portal__tab:hover   { color: var(--sbs-navy); }

/* Checklist groups */
.sbs-checklist-group { margin-bottom: 32px; }
.sbs-checklist-group__label { font-size: 13px; text-transform: uppercase; letter-spacing: .07em; color: var(--sbs-gray); margin: 0 0 12px; font-weight: 700; }
.sbs-checklist-group--overdue .sbs-checklist-group__label { color: var(--sbs-red); }
.sbs-checklist-group--complete .sbs-checklist-group__label { color: var(--sbs-green); }

/* ── Task cards — redesigned ──────────────────────────── */
.sbs-task {
    background: #fff;
    border: 1.5px solid var(--sbs-border);
    border-radius: var(--sbs-radius);
    padding: 16px 20px;
    margin-bottom: 10px;
    transition: box-shadow .15s;
}
.sbs-task:hover { box-shadow: var(--sbs-shadow); }
.sbs-task--complete { background: #f0fdf4; border-color: #bbf7d0; }
.sbs-task--overdue  { background: #fff5f5; border-color: #fecaca; }
.sbs-task--waived   { background: var(--sbs-light); opacity: .75; }

.sbs-task__main { width: 100%; }

/* Top row: title left, due date right */
.sbs-task__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 6px;
}
.sbs-task__title-row {
    display: flex;
    align-items: baseline;
    gap: 8px;
    flex: 1;
    min-width: 0;
}
.sbs-task__icon { font-size: 16px; flex-shrink: 0; }
.sbs-task__name {
    font-size: 15px;
    font-weight: 600;
    color: var(--sbs-navy);
    line-height: 1.3;
}
.sbs-task--complete .sbs-task__name { color: var(--sbs-green); }

.sbs-task__due-col { flex-shrink: 0; padding-top: 2px; }

/* Due date badges */
.sbs-due-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}
.sbs-due-badge--overdue { background: #fee2e2; color: #991b1b; }
.sbs-due-badge--today   { background: #ffedd5; color: #9a3412; }
.sbs-due-badge--soon    { background: #fef3c7; color: #92400e; }
.sbs-due-badge--future  { background: #eff6ff; color: #1e40af; }
.sbs-due-badge--neutral { background: var(--sbs-light); color: var(--sbs-gray); }

.sbs-task__desc {
    font-size: 13px;
    color: var(--sbs-gray);
    margin: 0 0 10px 24px;
    line-height: 1.5;
}
.sbs-task__uploaded {
    font-size: 13px;
    margin: 6px 0 8px 24px;
}
.sbs-task__completed-at {
    font-size: 12px;
    color: var(--sbs-green);
    font-style: italic;
    margin: 4px 0 0 24px;
}
.sbs-task--waived .sbs-task__completed-at { color: var(--sbs-blue); }

.sbs-task__actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 12px;
    margin-left: 24px;
}

/* Outline button variant for secondary actions */
.sbs-btn--outline {
    background: transparent;
    border-color: var(--sbs-navy);
    color: var(--sbs-navy);
}
.sbs-btn--outline:hover { background: var(--sbs-navy); color: #fff; }
.sbs-btn--ghost   { border-color: var(--sbs-navy); }
.sbs-optional { font-size: 11px; color: var(--sbs-gray); font-style: italic; font-weight: 400; }

/* Badges tab */
.sbs-badges__desc  { color: var(--sbs-gray); font-size: 14px; margin-bottom: 20px; }
.sbs-badges__empty { color: var(--sbs-gray); font-size: 14px; margin-bottom: 20px; }
.sbs-badges__list  { margin-bottom: 28px; }

.sbs-badge-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    background: #fff;
    border: 1.5px solid var(--sbs-border);
    border-radius: 8px;
    margin-bottom: 8px;
}
.sbs-badge-row__photo {
    width: 44px; height: 44px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}
.sbs-badge-row__photo-placeholder {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: var(--sbs-navy);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}
.sbs-badge-row__info { flex: 1; }
.sbs-badge-row__info strong { display: block; font-size: 14px; color: var(--sbs-navy); }
.sbs-badge-row__info span   { font-size: 12px; color: var(--sbs-gray); }

.sbs-badge-form { background: var(--sbs-light); border: 1.5px solid var(--sbs-border); border-radius: var(--sbs-radius); padding: 20px; }
.sbs-badge-form h3 { margin: 0 0 16px; color: var(--sbs-navy); }

/* Profile tab */
.sbs-profile__note { color: var(--sbs-gray); font-size: 14px; background: var(--sbs-light); border-left: 4px solid var(--sbs-blue); padding: 10px 14px; border-radius: 0 6px 6px 0; margin-bottom: 24px; }
.sbs-profile__readonly { background: var(--sbs-light); border-radius: 8px; padding: 16px; margin-bottom: 28px; }
.sbs-profile__field { display: flex; gap: 12px; font-size: 14px; margin-bottom: 6px; }
.sbs-profile__field label { font-weight: 600; color: var(--sbs-navy); min-width: 140px; }

/* Shared form elements */
.sbs-form-label { display: block; font-size: 14px; font-weight: 600; color: var(--sbs-navy); margin-bottom: 16px; }
.sbs-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 0; }
@media (max-width: 540px) { .sbs-form-row { grid-template-columns: 1fr; } }

.sbs-input {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 9px 12px;
    border: 1.5px solid var(--sbs-border);
    border-radius: 6px;
    font-size: 14px;
    margin-top: 4px;
    font-family: inherit;
    background: #fff;
    transition: border-color .15s;
}
.sbs-input:focus { outline: none; border-color: var(--sbs-blue); box-shadow: 0 0 0 3px rgba(37,99,235,.12); }
.sbs-textarea { resize: vertical; min-height: 90px; }

/* Feedback messages */
.sbs-feedback { font-size: 13px; margin: 8px 0 0; font-weight: 600; }
.sbs-feedback--success { color: var(--sbs-green); }
.sbs-feedback--error   { color: var(--sbs-red); }

/* Logged-out portal */
.sbs-portal--logged-out { text-align: center; padding: 60px 20px; }
.sbs-portal__icon { font-size: 48px; margin-bottom: 16px; }
.sbs-portal__logged-out-msg h2 { color: var(--sbs-navy); }
.sbs-portal__contact { margin-top: 24px; font-size: 14px; }

.sbs-portal__empty { color: var(--sbs-gray); text-align: center; padding: 40px; }

/* ── Public Floorplan ─────────────────────────────────────── */
.sbs-floorplan-public { max-width: 1100px; margin: 0 auto; }
.sbs-floorplan-public__search { margin-bottom: 16px; }
.sbs-floorplan-search-input {
    width: 100%;
    max-width: 400px;
    padding: 10px 14px;
    border: 1.5px solid var(--sbs-border);
    border-radius: 6px;
    font-size: 14px;
}
.sbs-floorplan-public__canvas {
    border: 1.5px solid var(--sbs-border);
    border-radius: var(--sbs-radius);
    overflow: auto;
    background: #fff;
    max-height: 70vh;
    position: relative;
}
.sbs-floorplan-public__canvas svg { max-width: 100%; display: block; }
.sbs-floorplan-public__legend { display: flex; gap: 20px; margin-top: 12px; font-size: 13px; align-items: center; }
.sbs-legend-dot { display: inline-block; width: 12px; height: 12px; border-radius: 50%; margin-right: 5px; vertical-align: middle; }
.sbs-legend-dot--sold      { background: var(--sbs-navy); }
.sbs-legend-dot--available { background: #93c5fd; }

/* Floorplan detail panel */
.sbs-fp-detail {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 260px;
    background: #fff;
    border: 1.5px solid var(--sbs-border);
    border-radius: var(--sbs-radius);
    padding: 20px;
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
    z-index: 9999;
}
.sbs-fp-detail__close {
    position: absolute;
    top: 10px; right: 12px;
    background: none; border: none;
    font-size: 18px; cursor: pointer; color: var(--sbs-gray);
}
.sbs-fp-detail__booth   { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--sbs-gray); }
.sbs-fp-detail__name    { font-size: 16px; font-weight: 700; color: var(--sbs-navy); margin: 4px 0 2px; }
.sbs-fp-detail__cat     { font-size: 13px; color: var(--sbs-gray); margin-bottom: 12px; }

.sbs-no-floorplan { color: var(--sbs-gray); text-align: center; padding: 40px; }

/* ── Staff badges external link ───────────────────────────── */
.sbs-badges-external { padding: 8px 0; }
.sbs-badges-external__card {
    background: var(--sbs-light);
    border: 2px solid var(--sbs-border);
    border-radius: var(--sbs-radius);
    padding: 40px 32px;
    text-align: center;
    max-width: 480px;
}
.sbs-badges-external__icon  { font-size: 48px; margin-bottom: 12px; }
.sbs-badges-external__card h3 { color: var(--sbs-navy); font-size: 20px; margin: 0 0 10px; }
.sbs-badges-external__card p  { color: #555; line-height: 1.6; margin: 0 0 8px; font-size: 14px; }
.sbs-badges-external__note    { font-size: 12px !important; color: var(--sbs-gray) !important; margin-top: 16px !important; }

/* ── Theme button inheritance ─────────────────────────────── */
/* The directory uses .sbs-btn as a fallback.
   If the active theme provides a .wp-element-button or .button class,
   you can add those classes to directory links via the shortcode atts
   or override .sbs-btn--primary below to match your theme. */
.sbs-directory .sbs-btn--primary,
.sbs-directory .sbs-btn--ghost {
    /* Inherits font-family from theme */
    font-family: inherit;
}

/* Allow theme's own link styles to show through on directory cards */
.sbs-exhibitor-card,
.sbs-exhibitor-card:visited {
    color: inherit;
    text-decoration: none;
}

/* ── Single exhibitor: updated hero ──────────────────────────── */
.sbs-single-exhibitor__hero {
    /* background set inline via PHP (image or gradient) */
    padding: 56px 40px;
    color: #fff;
}
.sbs-single-exhibitor__hero-inner {
    max-width: 960px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    gap: 36px;
    flex-wrap: wrap;
}
.sbs-single-exhibitor__logo-wrap {
    width: 130px;
    height: 130px;
    background: rgba(255,255,255,.15);
    backdrop-filter: blur(4px);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 14px;
    border: 2px solid rgba(255,255,255,.25);
}
.sbs-single-exhibitor__logo {
    max-width: 100%;
    max-height: 102px;
    object-fit: contain;
}
.sbs-single-exhibitor__logo-placeholder {
    font-size: 44px;
    font-weight: 800;
    color: rgba(255,255,255,.7);
    line-height: 1;
    text-transform: uppercase;
}
.sbs-single-exhibitor__hero-info { flex: 1; min-width: 200px; }
.sbs-single-exhibitor__name  { font-size: 30px; font-weight: 800; margin: 10px 0 6px; line-height: 1.2; text-shadow: 0 1px 4px rgba(0,0,0,.3); }
.sbs-single-exhibitor__cat   { font-size: 14px; opacity: .85; margin: 0 0 5px; }
.sbs-single-exhibitor__booth { font-size: 14px; opacity: .75; margin: 0 0 16px; }

/* ── Hall pass CTA button ──────────────────────────────────────── */
.sbs-single-exhibitor__cta { margin-top: 16px; }

.sbs-cta-btn {
    display: inline-block;
    background: #f0a500;
    color: #1a1a1a;
    font-size: 14px;
    font-weight: 700;
    padding: 13px 24px;
    border-radius: 8px;
    text-decoration: none;
    border: none;
    cursor: pointer;
    letter-spacing: .01em;
    box-shadow: 0 3px 10px rgba(0,0,0,.25);
    transition: background .15s, transform .1s, box-shadow .15s;
}
.sbs-cta-btn:hover {
    background: #f5b61a;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0,0,0,.28);
    color: #1a1a1a;
    text-decoration: none;
}
.sbs-cta-btn:active { transform: translateY(0); }

.sbs-cta-btn--block {
    display: block;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
}

.sbs-sidebar-cta { padding: 16px !important; }

/* ── Contact rows ────────────────────────────────────────────── */
.sbs-contact-row {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin: 0 0 10px;
    font-size: 15px;
}
.sbs-contact-row a { color: var(--sbs-navy); text-decoration: none; word-break: break-all; }
.sbs-contact-row a:hover { text-decoration: underline; }
.sbs-contact-icon { flex-shrink: 0; }

/* ── Portal loading state ───────────────────────────────────── */
.sbs-portal--loading { min-height: 200px; display: flex; align-items: center; justify-content: center; }

/* ── Booth acknowledgment box ────────────────────────────── */
.sbs-booth-ack {
    background: #fffbeb;
    border: 2px solid #f59e0b;
    border-radius: var(--sbs-radius);
    padding: 20px 24px;
    margin-bottom: 28px;
}
.sbs-booth-ack--done {
    background: #f0fdf4;
    border-color: #4ade80;
}
.sbs-booth-ack__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
    font-size: 16px;
    color: var(--sbs-navy);
}
.sbs-booth-ack__icon { font-size: 20px; }
.sbs-booth-ack__list {
    margin: 0 0 16px 28px;
    padding: 0;
    font-size: 14px;
    line-height: 1.8;
    color: #374151;
}
.sbs-booth-ack__label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 14px;
    font-weight: 600;
    color: var(--sbs-navy);
    cursor: pointer;
    padding: 10px 14px;
    background: rgba(255,255,255,.6);
    border-radius: 6px;
    border: 1.5px solid #f59e0b;
}
.sbs-booth-ack__confirmed {
    font-size: 14px;
    font-weight: 600;
    color: var(--sbs-green);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* ── Social share buttons ────────────────────────────────── */
.sbs-share-buttons {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.sbs-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9px 14px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    border: 1.5px solid transparent;
    cursor: pointer;
    transition: filter .15s, transform .1s;
    font-family: inherit;
    width: 100%;
    box-sizing: border-box;
    justify-content: flex-start;
}
.sbs-share-btn:hover { filter: brightness(.92); transform: translateX(2px); text-decoration: none; }
.sbs-share-btn svg   { flex-shrink: 0; }

.sbs-share-btn--facebook { background: #1877f2; color: #fff; }
.sbs-share-btn--twitter  { background: #000; color: #fff; }
.sbs-share-btn--linkedin { background: #0a66c2; color: #fff; }
.sbs-share-btn--copy     { background: var(--sbs-light); color: var(--sbs-navy); border-color: var(--sbs-border); }
.sbs-share-btn--copy:hover { background: var(--sbs-navy); color: #fff; border-color: var(--sbs-navy); }
