/* ─── Conference Program Builder — Frontend v2 ──────────────────────────── */

:root {
    --cpb-primary:        #4f46e5;
    --cpb-primary-dark:   #4338ca;
    --cpb-primary-light:  #e0e7ff;
    --cpb-accent:         #7c3aed;
    --cpb-accent-light:   #ede9fe;
    --cpb-teal:           #0d9488;
    --cpb-teal-light:     #ccfbf1;
    --cpb-rose:           #e11d48;
    --cpb-rose-light:     #ffe4e6;
    --cpb-amber:          #d97706;
    --cpb-amber-light:    #fef3c7;
    --cpb-green:          #16a34a;
    --cpb-green-light:    #dcfce7;
    --cpb-surface:        #ffffff;
    --cpb-bg:             #f8fafc;
    --cpb-border:         #e2e8f0;
    --cpb-border-strong:  #cbd5e1;
    --cpb-text:           #0f172a;
    --cpb-text-muted:     #64748b;
    --cpb-radius:         14px;
    --cpb-radius-sm:      8px;
    --cpb-radius-xs:      6px;
    --cpb-shadow-sm:      0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);
    --cpb-shadow:         0 4px 12px rgba(0,0,0,.09), 0 2px 4px rgba(0,0,0,.04);
    --cpb-shadow-lg:      0 12px 40px rgba(0,0,0,.14), 0 4px 12px rgba(0,0,0,.06);
    --cpb-shadow-xl:      0 24px 64px rgba(0,0,0,.18), 0 8px 20px rgba(0,0,0,.08);
    --cpb-font:           -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', sans-serif;
    --cpb-ease:           cubic-bezier(.4,0,.2,1);

    /* Calendar sizing — 2px per minute, 60-min = 120px */
    --cpb-min-height:     120px;
    --cpb-px-per-min:     2;
    --cpb-time-col:       80px;
    --cpb-day-start:      420; /* 07:00 = 420 min */
    --cpb-day-end:        1320; /* 22:00 = 1320 min */
    --cpb-total-min:      900; /* 22:00 - 07:00 */
}

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

.cpb-events-list,
.cpb-login-page,
.cpb-program-page {
    font-family: var(--cpb-font);
    -webkit-font-smoothing: antialiased;
    color: var(--cpb-text);
}

/* ══════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════ */
.cpb-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 9px 18px;
    border-radius: var(--cpb-radius-sm);
    font-size: 14px;
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: all .2s var(--cpb-ease);
    text-decoration: none;
    white-space: nowrap;
    font-family: var(--cpb-font);
    position: relative;
    overflow: hidden;
}
.cpb-btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: transparent;
    transition: background .15s;
}
.cpb-btn:hover::after { background: rgba(255,255,255,.1); }
.cpb-btn:active { transform: scale(.97); }
.cpb-btn:focus-visible { outline: 3px solid rgba(79,70,229,.4); outline-offset: 2px; }

.cpb-btn--primary { background: linear-gradient(135deg, var(--cpb-primary), var(--cpb-accent)); color: #fff; box-shadow: 0 2px 8px rgba(79,70,229,.35); }
.cpb-btn--primary:hover { box-shadow: 0 4px 16px rgba(79,70,229,.5); color: #fff; transform: translateY(-1px); }
.cpb-btn--glow { animation: cpb-glow-pulse 3s ease-in-out infinite; }
@keyframes cpb-glow-pulse {
    0%, 100% { box-shadow: 0 2px 8px rgba(79,70,229,.35); }
    50%       { box-shadow: 0 4px 20px rgba(79,70,229,.6); }
}

.cpb-btn--accent { background: linear-gradient(135deg, var(--cpb-accent), #a855f7); color: #fff; box-shadow: 0 2px 8px rgba(124,58,237,.3); }
.cpb-btn--accent:hover { box-shadow: 0 4px 14px rgba(124,58,237,.5); color: #fff; transform: translateY(-1px); }

.cpb-btn--ghost { background: var(--cpb-surface); color: var(--cpb-text-muted); border: 1.5px solid var(--cpb-border); }
.cpb-btn--ghost:hover { border-color: var(--cpb-primary); color: var(--cpb-primary); }

.cpb-btn--danger { background: linear-gradient(135deg, var(--cpb-rose), #f43f5e); color: #fff; box-shadow: 0 2px 8px rgba(225,29,72,.3); }
.cpb-btn--danger:hover { box-shadow: 0 4px 14px rgba(225,29,72,.5); color: #fff; transform: translateY(-1px); }

.cpb-btn--full { width: 100%; }
.cpb-btn--sm { padding: 6px 12px; font-size: 13px; }
.cpb-btn--xs { padding: 3px 9px; font-size: 11px; border-radius: 5px; }

/* ══════════════════════════════════════════════════════
   ALERTS
══════════════════════════════════════════════════════ */
.cpb-alert {
    padding: 12px 16px;
    border-radius: var(--cpb-radius-sm);
    font-size: 14px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 10px;
    animation: cpb-slide-in .3s var(--cpb-ease);
}
.cpb-alert--error { background: var(--cpb-rose-light); color: #9f1239; border: 1px solid #fecdd3; }
.cpb-alert--success { background: var(--cpb-green-light); color: #15803d; border: 1px solid #bbf7d0; }
@keyframes cpb-slide-in { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:none; } }

/* ══════════════════════════════════════════════════════
   EVENT LIST (SHORTCODE)
══════════════════════════════════════════════════════ */
.cpb-events-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 28px;
    padding: 8px 0;
}
.cpb-no-events { text-align: center; padding: 60px; color: var(--cpb-text-muted); }

.cpb-event-item {
    background: var(--cpb-surface);
    border-radius: var(--cpb-radius);
    box-shadow: var(--cpb-shadow);
    overflow: hidden;
    border: 1px solid var(--cpb-border);
    display: flex;
    flex-direction: column;
    transition: box-shadow .3s var(--cpb-ease), transform .3s var(--cpb-ease);
    animation: cpb-card-in .4s var(--cpb-ease) both;
}
.cpb-event-item:nth-child(2) { animation-delay: .07s; }
.cpb-event-item:nth-child(3) { animation-delay: .14s; }
.cpb-event-item:nth-child(4) { animation-delay: .21s; }
@keyframes cpb-card-in { from { opacity:0; transform:translateY(20px) scale(.97); } to { opacity:1; transform:none; } }
.cpb-event-item:hover { box-shadow: var(--cpb-shadow-lg); transform: translateY(-4px); }

.cpb-event-item__header { height: 190px; overflow: hidden; position: relative; background: linear-gradient(135deg, #c7d2fe 0%, #ddd6fe 100%); }
.cpb-event-item__header img { width:100%; height:100%; object-fit:cover; transition: transform .5s var(--cpb-ease); }
.cpb-event-item:hover .cpb-event-item__header img { transform: scale(1.06); }
.cpb-event-item__header--placeholder { display:flex; align-items:center; justify-content:center; }
.cpb-placeholder-icon { font-size: 56px; filter: drop-shadow(0 2px 8px rgba(79,70,229,.2)); }

.cpb-event-item__body { padding: 22px; flex:1; display:flex; flex-direction:column; }
.cpb-event-item__name { font-size: 20px; font-weight: 800; color: var(--cpb-text); margin-bottom: 8px; line-height: 1.25; }
.cpb-event-item__dates {
    font-size: 13px; color: var(--cpb-text-muted); margin-bottom: 20px;
    display: flex; align-items: center; gap: 6px;
}
.cpb-event-item__body .cpb-btn { margin-top: auto; }

/* ══════════════════════════════════════════════════════
   LOGIN PAGE
══════════════════════════════════════════════════════ */
.cpb-login-page {
    min-height: 100vh;
    background: linear-gradient(135deg, #eff6ff 0%, #f5f3ff 50%, #fdf2f8 100%);
    display: flex; align-items: center; justify-content: center;
    padding: 32px 16px;
}
.cpb-login-container { width: 100%; max-width: 450px; display: flex; flex-direction: column; gap: 20px; }

.cpb-login-event-info { text-align: center; animation: cpb-fade-down .5s var(--cpb-ease) both; }
@keyframes cpb-fade-down { from { opacity:0; transform:translateY(-16px); } to { opacity:1; transform:none; } }

.cpb-login-event-img { width:100%; max-height:220px; object-fit:cover; border-radius: var(--cpb-radius); margin-bottom:18px; box-shadow: var(--cpb-shadow-lg); }
.cpb-login-event-name { font-size: 28px; font-weight: 900; color: var(--cpb-text); margin-bottom: 6px; letter-spacing: -.02em; }
.cpb-login-event-dates { font-size: 14px; color: var(--cpb-text-muted); }

.cpb-login-box {
    background: var(--cpb-surface); border-radius: var(--cpb-radius);
    box-shadow: var(--cpb-shadow-xl); padding: 36px;
    border: 1px solid var(--cpb-border);
    animation: cpb-slide-up .4s var(--cpb-ease) .1s both;
}
@keyframes cpb-slide-up { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:none; } }

.cpb-login-title { font-size: 22px; font-weight: 800; margin-bottom: 6px; }
.cpb-login-subtitle { font-size: 14px; color: var(--cpb-text-muted); margin-bottom: 28px; }

.cpb-login-form { display: flex; flex-direction: column; gap: 18px; }
.cpb-login-field { display: flex; flex-direction: column; gap: 7px; }
.cpb-login-field label { font-size: 13px; font-weight: 700; color: var(--cpb-text); letter-spacing: .01em; }
.cpb-login-field input {
    width: 100%; padding: 11px 14px;
    border: 2px solid var(--cpb-border); border-radius: var(--cpb-radius-sm);
    font-size: 15px; font-family: var(--cpb-font);
    background: var(--cpb-bg);
    transition: border-color .2s, box-shadow .2s, background .2s;
}
.cpb-login-field input:focus { border-color: var(--cpb-primary); box-shadow: 0 0 0 4px rgba(79,70,229,.12); outline:none; background:#fff; }

.cpb-password-wrap { position: relative; }
.cpb-password-wrap input { padding-right: 46px; }
.cpb-toggle-pw {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer; color: var(--cpb-text-muted);
    padding: 4px; display: flex; align-items: center; transition: color .15s;
}
.cpb-toggle-pw:hover { color: var(--cpb-primary); }

.cpb-login-back { text-align: center; margin-top: 16px; }
.cpb-login-back a { font-size: 13px; color: var(--cpb-text-muted); text-decoration: none; transition: color .15s; }
.cpb-login-back a:hover { color: var(--cpb-primary); }

/* ══════════════════════════════════════════════════════
   PROGRAM PAGE — HEADER
══════════════════════════════════════════════════════ */
.cpb-program-page { min-height: 100vh; background: var(--cpb-bg); }

.cpb-program-header {
    position: relative; min-height: 220px;
    background: linear-gradient(135deg, #1e1b4b 0%, #312e81 50%, #4c1d95 100%);
    background-size: cover; background-position: center;
}
.cpb-program-header__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,.3) 0%, rgba(0,0,0,.7) 100%);
    display: flex; align-items: flex-end;
}
.cpb-program-header__inner {
    width: 100%; padding: 28px 32px;
    display: flex; align-items: flex-end; justify-content: space-between; gap: 20px;
}
.cpb-program-header__text {}
.cpb-program-header__title { font-size: 32px; font-weight: 900; color: #fff; letter-spacing: -.02em; text-shadow: 0 2px 8px rgba(0,0,0,.4); margin-bottom: 6px; }
.cpb-program-header__dates { font-size: 14px; color: rgba(255,255,255,.8); display: flex; align-items: center; gap: 6px; }

.cpb-logout-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 9px 18px; background: rgba(255,255,255,.12);
    border: 1.5px solid rgba(255,255,255,.3); border-radius: 8px;
    color: #fff; font-size: 13px; font-weight: 600;
    cursor: pointer; backdrop-filter: blur(8px);
    transition: background .2s, border-color .2s, transform .15s;
    white-space: nowrap; font-family: var(--cpb-font);
    flex-shrink: 0;
}
.cpb-logout-btn:hover { background: rgba(255,255,255,.22); border-color: rgba(255,255,255,.5); transform: translateY(-1px); }

/* ── PROGRAM BODY ── */
.cpb-program-body { max-width: 1100px; margin: 0 auto; padding: 28px 20px 80px; }
.cpb-no-halls { text-align: center; padding: 80px 40px; color: var(--cpb-text-muted); }
.cpb-no-halls__icon { font-size: 48px; margin-bottom: 16px; }

/* ── Hall Tabs ── */
.cpb-hall-tabs { margin-bottom: 24px; }
.cpb-hall-tabs__list {
    display: flex; gap: 6px; padding-bottom: 0;
    border-bottom: 2px solid var(--cpb-border);
    overflow-x: auto; scrollbar-width: none;
}
.cpb-hall-tabs__list::-webkit-scrollbar { display:none; }

.cpb-hall-tab {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 18px 11px; background: none; border: none;
    border-bottom: 3px solid transparent; margin-bottom: -2px;
    font-size: 14px; font-weight: 600; color: var(--cpb-text-muted);
    cursor: pointer; white-space: nowrap;
    transition: color .2s, border-color .2s;
    font-family: var(--cpb-font);
}
.cpb-hall-tab svg { transition: stroke .2s; }
.cpb-hall-tab:hover { color: var(--cpb-primary); }
.cpb-hall-tab.is-active { color: var(--cpb-primary); border-bottom-color: var(--cpb-primary); }
.cpb-hall-tab.is-active svg { stroke: var(--cpb-primary); }

/* ── Day Selector ── */
.cpb-day-selector { margin-bottom: 24px; }
.cpb-day-selector__inner { display: flex; gap: 10px; flex-wrap: wrap; }

.cpb-day-btn {
    display: flex; flex-direction: column; align-items: center;
    padding: 10px 20px; min-width: 85px;
    background: var(--cpb-surface); border: 2px solid var(--cpb-border);
    border-radius: var(--cpb-radius-sm); cursor: pointer;
    transition: all .2s var(--cpb-ease); font-family: var(--cpb-font);
}
.cpb-day-btn:hover { border-color: var(--cpb-primary); color: var(--cpb-primary); }
.cpb-day-btn.is-active {
    background: linear-gradient(135deg, var(--cpb-primary), var(--cpb-accent));
    border-color: transparent; color: #fff;
    box-shadow: 0 4px 12px rgba(79,70,229,.4);
    transform: translateY(-2px);
}
.cpb-day-btn__label { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; }
.cpb-day-btn__date  { font-size: 13px; margin-top: 3px; }

/* ── Toolbar ── */
.cpb-program-toolbar { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.cpb-loading { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--cpb-text-muted); }
.cpb-spinner {
    width: 16px; height: 16px;
    border: 2.5px solid var(--cpb-border); border-top-color: var(--cpb-primary);
    border-radius: 50%; animation: cpb-spin .7s linear infinite; display: inline-block;
}
@keyframes cpb-spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════
   CALENDAR
══════════════════════════════════════════════════════ */
.cpb-calendar {
    background: var(--cpb-surface);
    border: 1px solid var(--cpb-border);
    border-radius: var(--cpb-radius);
    box-shadow: var(--cpb-shadow);
    overflow: visible; /* IMPORTANT — never clip session blocks */
}

.cpb-calendar__header {
    display: grid; grid-template-columns: var(--cpb-time-col) 1fr;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9);
    border-bottom: 2px solid var(--cpb-border);
    border-radius: var(--cpb-radius) var(--cpb-radius) 0 0;
    padding: 12px 0;
}
.cpb-calendar__time-label,
.cpb-calendar__grid-label {
    padding: 0 16px;
    font-size: 11px; font-weight: 800; text-transform: uppercase;
    letter-spacing: .08em; color: var(--cpb-text-muted);
}

.cpb-calendar__body {
    position: relative;
    /* Total height: 900 minutes * 2px/min = 1800px */
    min-height: calc(900 * 2px);
    padding-bottom: 24px;
}

/* Hour rows */
.cpb-hour-row {
    display: grid; grid-template-columns: var(--cpb-time-col) 1fr;
    /* Each hour = 60min * 2px = 120px */
    height: 120px;
    position: relative;
}
.cpb-hour-row__label {
    padding: 0 12px; font-size: 11px; font-weight: 700;
    color: var(--cpb-text-muted); display: flex; align-items: flex-start;
    padding-top: 6px; white-space: nowrap;
}
.cpb-hour-row__line {
    border-top: 1px solid var(--cpb-border);
    position: relative; margin-top: 0;
}
.cpb-hour-row:nth-child(odd) .cpb-hour-row__line { background: rgba(79,70,229,.012); }

/* Sessions overlay — absolutely positioned over the calendar body */
.cpb-sessions-overlay {
    position: absolute;
    top: 0;
    left: var(--cpb-time-col);
    right: 0;
    /* height is controlled by min-height of calendar body */
    pointer-events: none;
}

/* ── Session Block ── */
.cpb-session-block {
    position: absolute;
    left: 8px;
    right: 8px;
    pointer-events: all;
    border-radius: var(--cpb-radius-sm);
    padding: 10px 12px;
    cursor: pointer;
    overflow: visible; /* NEVER clip — let content determine display */
    min-height: 80px;
    transition: box-shadow .2s var(--cpb-ease), transform .2s var(--cpb-ease);
    animation: cpb-block-in .3s var(--cpb-ease) both;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
@keyframes cpb-block-in { from { opacity:0; transform:scale(.97) translateX(-4px); } to { opacity:1; transform:none; } }

/* Gradient themes per block — cycle via nth-child */
.cpb-session-block:nth-child(6n+1) { background: linear-gradient(135deg,#eff6ff,#dbeafe); border-left: 4px solid #3b82f6; }
.cpb-session-block:nth-child(6n+2) { background: linear-gradient(135deg,#f5f3ff,#ede9fe); border-left: 4px solid #8b5cf6; }
.cpb-session-block:nth-child(6n+3) { background: linear-gradient(135deg,#ecfdf5,#d1fae5); border-left: 4px solid #10b981; }
.cpb-session-block:nth-child(6n+4) { background: linear-gradient(135deg,#fff7ed,#fed7aa); border-left: 4px solid #f97316; }
.cpb-session-block:nth-child(6n+5) { background: linear-gradient(135deg,#fdf2f8,#fce7f3); border-left: 4px solid #ec4899; }
.cpb-session-block:nth-child(6n+6) { background: linear-gradient(135deg,#f0fdfa,#ccfbf1); border-left: 4px solid #14b8a6; }

.cpb-session-block:hover {
    box-shadow: 0 6px 24px rgba(0,0,0,.15);
    transform: translateX(3px);
    z-index: 10;
}

.cpb-block-time {
    font-size: 10px; font-weight: 800; letter-spacing: .05em;
    color: var(--cpb-primary); text-transform: uppercase;
}
.cpb-block-name { font-size: 13px; font-weight: 800; color: var(--cpb-text); line-height: 1.3; }

.cpb-block-roles { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 2px; }
.cpb-role-chip {
    padding: 2px 8px; border-radius: 20px; font-size: 10px; font-weight: 700;
    display: inline-flex; align-items: center; gap: 3px;
}
.cpb-role-chip--moderator   { background: #dcfce7; color: #166534; }
.cpb-role-chip--panelist    { background: #fef9c3; color: #854d0e; }
.cpb-role-chip--chairperson { background: #ede9fe; color: #5b21b6; }

.cpb-block-talks { margin-top: 6px; display: flex; flex-direction: column; gap: 4px; }
.cpb-talk-row {
    background: rgba(255,255,255,.75); backdrop-filter: blur(4px);
    border: 1px solid rgba(255,255,255,.9);
    border-radius: 6px; padding: 5px 9px;
    display: grid; grid-template-columns: auto 1fr auto;
    gap: 6px; align-items: center; font-size: 11px;
}
.cpb-talk-row__time    { font-weight: 800; color: var(--cpb-primary); white-space: nowrap; font-size: 10px; }
.cpb-talk-row__info    { min-width: 0; }
.cpb-talk-row__doctor  { font-weight: 700; color: var(--cpb-accent); }
.cpb-talk-row__name    { color: var(--cpb-text); font-size: 10px; }
.cpb-talk-row__country { font-size: 10px; color: var(--cpb-text-muted); white-space: nowrap; }

/* Empty state */
.cpb-calendar-empty {
    position: absolute; inset: 0;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    text-align: center; color: var(--cpb-text-muted);
    pointer-events: none;
}
.cpb-calendar-empty__icon { font-size: 48px; margin-bottom: 16px; opacity: .5; }
.cpb-calendar-empty p { font-size: 15px; }
.cpb-calendar-empty strong { color: var(--cpb-primary); }

/* ══════════════════════════════════════════════════════
   MODALS
══════════════════════════════════════════════════════ */
.cpb-modal {
    position: fixed; inset: 0; z-index: 99999;
    display: flex; align-items: center; justify-content: center;
    padding: 20px; font-family: var(--cpb-font);
}
.cpb-modal__backdrop {
    position: fixed; inset: 0;
    background: rgba(15,23,42,.6);
    backdrop-filter: blur(6px);
    animation: cpb-fade-in .2s ease;
}
@keyframes cpb-fade-in { from { opacity:0; } to { opacity:1; } }

.cpb-modal__dialog {
    position: relative; z-index: 1;
    background: var(--cpb-surface);
    border-radius: var(--cpb-radius);
    box-shadow: var(--cpb-shadow-xl);
    width: 100%; max-width: 640px; max-height: 90vh;
    display: flex; flex-direction: column;
    animation: cpb-modal-in .25s var(--cpb-ease);
    border: 1px solid var(--cpb-border);
}
.cpb-modal--sm .cpb-modal__dialog { max-width: 460px; }
.cpb-modal--xs .cpb-modal__dialog { max-width: 360px; }
@keyframes cpb-modal-in { from { opacity:0; transform:translateY(20px) scale(.97); } to { opacity:1; transform:none; } }

.cpb-modal__header {
    padding: 20px 24px 18px;
    border-bottom: 1px solid var(--cpb-border);
    display: flex; align-items: center; gap: 12px;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9);
    border-radius: var(--cpb-radius) var(--cpb-radius) 0 0;
}
.cpb-modal__header-icon {
    width: 36px; height: 36px; border-radius: 9px;
    background: linear-gradient(135deg, var(--cpb-primary), var(--cpb-accent));
    display: flex; align-items: center; justify-content: center;
    color: #fff; flex-shrink: 0;
}
.cpb-modal__header-icon--accent {
    background: linear-gradient(135deg, var(--cpb-accent), #a855f7);
}
.cpb-modal__title { font-size: 17px; font-weight: 800; color: var(--cpb-text); flex: 1; }
.cpb-modal__close {
    background: none; border: none; cursor: pointer;
    font-size: 18px; color: var(--cpb-text-muted); padding: 6px 8px;
    border-radius: 6px; line-height: 1; transition: color .15s, background .15s;
}
.cpb-modal__close:hover { color: var(--cpb-text); background: var(--cpb-bg); }

.cpb-modal__body { padding: 22px 24px; overflow-y: auto; flex: 1; }

.cpb-modal__footer {
    padding: 16px 24px;
    border-top: 1px solid var(--cpb-border);
    display: flex; align-items: center; justify-content: space-between;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9);
    border-radius: 0 0 var(--cpb-radius) var(--cpb-radius);
}
.cpb-modal__footer-right { display: flex; gap: 10px; align-items: center; margin-left: auto; }

/* ── Modal form fields ── */
.cpb-form-row { margin-bottom: 16px; }
.cpb-form-row--2col { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cpb-form-col { display: flex; flex-direction: column; gap: 6px; }
.cpb-form-col--full { grid-column: 1 / -1; }

.cpb-form-col label {
    font-size: 11px; font-weight: 800; color: var(--cpb-text);
    text-transform: uppercase; letter-spacing: .07em; display: flex; align-items: center; gap: 5px;
}
.cpb-form-col label .req { color: var(--cpb-rose); }
.cpb-optional { font-weight: 400; text-transform: none; letter-spacing: 0; color: var(--cpb-text-muted); font-size: 11px; }

.cpb-form-col input[type="text"],
.cpb-form-col input[type="time"],
.cpb-form-col select {
    padding: 10px 12px;
    border: 2px solid var(--cpb-border); border-radius: var(--cpb-radius-sm);
    font-size: 14px; font-family: var(--cpb-font);
    background: var(--cpb-bg); width: 100%;
    transition: border-color .2s, box-shadow .2s, background .2s;
    color: var(--cpb-text);
}
.cpb-form-col input:focus { border-color: var(--cpb-primary); box-shadow: 0 0 0 4px rgba(79,70,229,.1); outline: none; background: #fff; }

.cpb-section-label {
    display: flex; align-items: center; gap: 7px;
    font-size: 11px; font-weight: 800; text-transform: uppercase;
    letter-spacing: .07em; color: var(--cpb-text-muted); margin-bottom: 12px;
}

/* ── Roles ── */
.cpb-roles-section {
    margin-bottom: 20px; padding: 16px;
    background: linear-gradient(135deg, #f8fafc, #f1f5f9);
    border-radius: var(--cpb-radius-sm); border: 1px solid var(--cpb-border);
}
.cpb-roles-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
@media (max-width: 500px) { .cpb-roles-grid { grid-template-columns: 1fr; } }

.cpb-role-group {
    background: var(--cpb-surface); border-radius: 8px;
    padding: 10px; border: 1px solid var(--cpb-border);
    transition: border-color .2s;
}
.cpb-role-group--green { border-top: 3px solid var(--cpb-green); }
.cpb-role-group--yellow { border-top: 3px solid var(--cpb-amber); }
.cpb-role-group--purple { border-top: 3px solid var(--cpb-accent); }

.cpb-role-group__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.cpb-role-group__name { font-size: 11px; font-weight: 800; color: var(--cpb-text); text-transform: uppercase; letter-spacing: .04em; }

.cpb-role-list { list-style: none; display: flex; flex-direction: column; gap: 4px; }
.cpb-role-list__item {
    display: flex; align-items: center; justify-content: space-between;
    font-size: 12px; padding: 4px 7px; border-radius: 5px;
    background: var(--cpb-bg); gap: 6px;
    animation: cpb-pop-in .2s var(--cpb-ease);
}
@keyframes cpb-pop-in { from { opacity:0; transform:scale(.9); } to { opacity:1; transform:none; } }
.cpb-role-list__item span { flex:1; word-break: break-word; font-weight: 500; }
.cpb-role-remove { background:none; border:none; cursor:pointer; color: var(--cpb-rose); font-size: 14px; padding: 0 2px; opacity:.7; transition: opacity .15s; }
.cpb-role-remove:hover { opacity: 1; }

/* ── Talks in session modal ── */
.cpb-talks-section {}
.cpb-talks-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.cpb-talk-item {
    background: linear-gradient(135deg, #f8fafc, #eff6ff);
    border: 1px solid #dbeafe; border-left: 3px solid var(--cpb-accent);
    border-radius: var(--cpb-radius-sm); padding: 10px 12px; margin-bottom: 8px;
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    cursor: pointer; transition: box-shadow .2s, transform .15s;
    animation: cpb-pop-in .25s var(--cpb-ease);
}
.cpb-talk-item:hover { box-shadow: var(--cpb-shadow); transform: translateX(2px); }
.cpb-talk-item__info { flex: 1; min-width: 0; }
.cpb-talk-item__time { font-size: 11px; font-weight: 800; color: var(--cpb-primary); margin-bottom: 2px; }
.cpb-talk-item__doctor { font-size: 12px; font-weight: 700; color: var(--cpb-accent); }
.cpb-talk-item__country { font-size: 11px; color: var(--cpb-text-muted); font-style: italic; }
.cpb-talk-item__name { font-size: 12px; color: var(--cpb-text); }
.cpb-talk-item__actions { flex-shrink: 0; }

.cpb-talk-empty {
    text-align: center; padding: 24px;
    border: 2px dashed var(--cpb-border); border-radius: var(--cpb-radius-sm);
    color: var(--cpb-text-muted); font-size: 13px;
}

/* ══════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════ */
@media (max-width: 640px) {
    .cpb-program-header__inner { padding: 18px; flex-wrap: wrap; }
    .cpb-program-header__title { font-size: 22px; }
    .cpb-program-body { padding: 16px 12px 60px; }
    .cpb-form-row--2col { grid-template-columns: 1fr; }
    .cpb-modal__dialog { max-height: 95vh; }
    :root { --cpb-time-col: 58px; }
}
