/* ════════════════════════════════════════════════════════════════════════
   AURORA — Semi-modern professional event theme
   Loaded AFTER Bootstrap and the default frontend CSS, so Aurora rules win.
   Brand colors arrive as --primary / --accent (set inline by the PHP shell);
   Aurora aliases them to --ar-primary / --ar-accent below.
   Class prefix: ar-   ·   Vanilla, no build step.
   ════════════════════════════════════════════════════════════════════════ */

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

/* ── Design tokens ──────────────────────────────────────────────────────── */
:root {
    --ar-primary:      var(--primary, #1d4ed8);
    --ar-accent:       var(--accent,  #f59e0b);
    --ar-primary-dark: color-mix(in srgb, var(--ar-primary) 80%, #000);
    --ar-accent-dark:  color-mix(in srgb, var(--ar-accent)  80%, #000);
    --ar-primary-soft: color-mix(in srgb, var(--ar-primary) 8%,  #fff);
    --ar-accent-soft:  color-mix(in srgb, var(--ar-accent)  12%, #fff);

    --ar-ink:    var(--heading, #0f172a);
    --ar-body:   var(--text, #475569);
    --ar-muted:  var(--subtitle, #64748b);
    --ar-surface:var(--card-bg, #ffffff);
    --ar-soft:   var(--section-alt-bg, #f7f9fc);
    --ar-line:   var(--border, #e6eaf2);
    --ar-dark:   #0e1626;

    --ar-grad:       linear-gradient(120deg, var(--grad-from, var(--ar-primary)), var(--grad-to, var(--ar-accent)));
    --ar-grad-brand: linear-gradient(135deg, color-mix(in srgb, var(--ar-primary) 88%, #000), var(--ar-accent));

    --ar-r-sm: 10px;
    --ar-r:    16px;
    --ar-r-lg: 24px;

    --ar-shadow:    0 6px 20px rgba(15, 23, 42, .06);
    --ar-shadow-md: 0 14px 34px rgba(15, 23, 42, .10);
    --ar-shadow-lg: 0 26px 60px rgba(15, 23, 42, .14);

    --ar-font-display: 'Sora', 'Segoe UI', system-ui, sans-serif;
    --ar-font:         'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;

    --btn-text: var(--btn-text, #fff);
}

/* ── Base ───────────────────────────────────────────────────────────────── */
body {
    font-family: var(--ar-font);
    color: var(--ar-body);
    background: var(--ar-surface);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
h1, h2, h3, h4, h5, .ar-display { font-family: var(--ar-font-display); color: var(--ar-ink); letter-spacing: -.01em; }
a { color: var(--ar-primary); }
img { max-width: 100%; }
::selection { background: color-mix(in srgb, var(--ar-accent) 30%, #fff); }

/* Thin gradient progress accent at the very top of every page */
body::before {
    content: ""; position: fixed; inset: 0 0 auto 0; height: 3px; z-index: 1080;
    background: var(--ar-grad);
}

/* ════════════════════════════════════════════════════════════════════════
   NAVBAR
   ════════════════════════════════════════════════════════════════════════ */
.ar-navbar {
    position: sticky; top: 0; z-index: 1030;
    background: var(--ar-nav-bg, rgba(255, 255, 255, .92));
    backdrop-filter: saturate(160%) blur(10px);
    border-bottom: 1px solid transparent;
    padding-block: .85rem;
    transition: padding .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}
.ar-navbar.ar-scrolled {
    padding-block: .5rem;
    box-shadow: var(--ar-shadow);
    border-bottom-color: var(--ar-line);
    background: var(--ar-nav-bg, rgba(255, 255, 255, .97));
}
.ar-navbar .navbar-brand {
    display: inline-flex; align-items: center; gap: .6rem;
    font-family: var(--ar-font-display); font-weight: 800; font-size: 1.18rem;
    color: var(--ar-ink);
}
.ar-navbar .navbar-brand img { max-height: 42px; width: auto; }
.ar-brand-mark {
    display: inline-grid; place-items: center; width: 36px; height: 36px;
    border-radius: 11px; color: #fff; background: var(--ar-grad);
    box-shadow: 0 6px 16px color-mix(in srgb, var(--ar-primary) 35%, transparent);
}
.ar-navbar .nav-link {
    font-weight: 600; font-size: .94rem; color: var(--ar-ink);
    padding: .5rem .85rem; border-radius: 9px; position: relative;
    transition: color .18s ease, background .18s ease;
}
.ar-navbar .nav-link:hover { color: var(--ar-primary); }
.ar-navbar .nav-link.active { color: var(--ar-primary); }
.ar-navbar .nav-link.active::after {
    content: ""; position: absolute; left: .85rem; right: .85rem; bottom: .25rem;
    height: 2px; border-radius: 2px; background: var(--ar-accent);
}
.ar-navbar .dropdown-menu {
    border: 1px solid var(--ar-line); border-radius: var(--ar-r);
    box-shadow: var(--ar-shadow-md); padding: .5rem; margin-top: .6rem;
}
.ar-navbar .dropdown-item {
    border-radius: 9px; font-weight: 500; font-size: .9rem;
    display: flex; align-items: center; gap: .6rem; padding: .55rem .7rem;
}
.ar-navbar .dropdown-item svg { width: 1.05em; height: 1.05em; color: var(--ar-primary); }
.ar-navbar .dropdown-item:hover { background: var(--ar-primary-soft); color: var(--ar-primary-dark); }
.ar-navbar .dropdown-item.active { background: var(--ar-primary-soft); color: var(--ar-primary-dark); }

.ar-nav-outline {
    border: 1.5px solid var(--ar-line) !important; border-radius: 999px !important;
    padding: .42rem 1rem !important; margin-left: .2rem;
}
.ar-nav-outline:hover { border-color: var(--ar-primary) !important; background: var(--ar-primary-soft); }
.ar-nav-cta {
    background: var(--ar-grad); color: var(--btn-text, #fff) !important;
    border-radius: 999px !important; padding: .5rem 1.2rem !important;
    box-shadow: 0 8px 20px color-mix(in srgb, var(--ar-primary) 32%, transparent);
}
.ar-nav-cta:hover { color: #fff !important; filter: brightness(1.05); transform: translateY(-1px); }
.ar-nav-cta::after { display: none !important; }
.navbar-toggler { border-color: var(--ar-line); }
.navbar-toggler:focus { box-shadow: 0 0 0 3px var(--ar-primary-soft); }

/* ════════════════════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════════════════════ */
.ar-btn {
    display: inline-flex; align-items: center; gap: .5rem; justify-content: center;
    font-family: var(--ar-font); font-weight: 600; font-size: .96rem;
    padding: .8rem 1.6rem; border-radius: 999px; border: 1.5px solid transparent;
    text-decoration: none; cursor: pointer; line-height: 1;
    transition: transform .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease;
}
.ar-btn svg { width: 1.05em; height: 1.05em; }
.ar-btn-sm { padding: .56rem 1.1rem; font-size: .88rem; }
.ar-btn-primary {
    background: var(--ar-grad); color: var(--btn-text, #fff);
    box-shadow: 0 12px 26px color-mix(in srgb, var(--ar-primary) 30%, transparent);
}
.ar-btn-primary:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 18px 34px color-mix(in srgb, var(--ar-primary) 36%, transparent); }
.ar-btn-outline { background: #fff; border-color: var(--ar-line); color: var(--ar-ink); }
.ar-btn-outline:hover { border-color: var(--ar-primary); color: var(--ar-primary); transform: translateY(-2px); box-shadow: var(--ar-shadow); }
.ar-btn-on-dark { background: #fff; color: var(--ar-ink); }
.ar-btn-on-dark:hover { transform: translateY(-2px); color: var(--ar-primary-dark); box-shadow: 0 14px 30px rgba(0,0,0,.3); }
.ar-btn-on-dark-outline { border-color: rgba(255,255,255,.6); color: #fff; background: transparent; }
.ar-btn-on-dark-outline:hover { background: rgba(255,255,255,.14); color: #fff; transform: translateY(-2px); }

/* ════════════════════════════════════════════════════════════════════════
   SECTIONS / HEADERS
   ════════════════════════════════════════════════════════════════════════ */
.ar-section { padding-block: clamp(3.5rem, 6vw, 6rem); position: relative; }
.ar-bg-soft { background: var(--ar-soft); }
.ar-bg-tint { background: linear-gradient(180deg, var(--ar-soft), #fff); }
.ar-section-head { max-width: 720px; margin: 0 auto; }
.ar-section-head.text-center { margin-inline: auto; }
.ar-eyebrow {
    display: inline-flex; align-items: center; gap: .45rem;
    font-size: .74rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    color: var(--ar-primary); background: var(--ar-primary-soft);
    padding: .38rem .85rem; border-radius: 999px; margin-bottom: 1rem;
    border: 1px solid color-mix(in srgb, var(--ar-primary) 16%, #fff);
}
.ar-eyebrow svg { width: 1.05em; height: 1.05em; }
.ar-section-title {
    font-size: clamp(1.7rem, 3.2vw, 2.5rem); font-weight: 800; line-height: 1.12;
    margin: 0 0 .85rem; color: var(--ar-ink);
}
.ar-section-sub { font-size: 1.05rem; color: var(--ar-muted); margin: 0; line-height: 1.7; }
.ar-text-grad {
    background: var(--ar-grad); -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
}
.ar-muted { color: var(--ar-muted); }

/* ════════════════════════════════════════════════════════════════════════
   CARDS / FEATURES
   ════════════════════════════════════════════════════════════════════════ */
.ar-card {
    background: var(--ar-surface); border: 1px solid var(--ar-line);
    border-radius: var(--ar-r); box-shadow: var(--ar-shadow);
}
.ar-card-hover { transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.ar-card-hover:hover { transform: translateY(-5px); box-shadow: var(--ar-shadow-lg); border-color: color-mix(in srgb, var(--ar-primary) 30%, var(--ar-line)); }
.ar-feature { padding: 1.9rem 1.6rem; }
.ar-feature h3 { font-size: 1.18rem; margin: 0 0 .5rem; }
.ar-feature p { color: var(--ar-muted); margin: 0; font-size: .95rem; line-height: 1.65; }
.ar-feature-icon {
    display: inline-grid; place-items: center; width: 56px; height: 56px;
    border-radius: 15px; margin-bottom: 1.1rem; color: var(--ar-primary);
    background: var(--ar-primary-soft);
    border: 1px solid color-mix(in srgb, var(--ar-primary) 16%, #fff);
}
.ar-feature-icon svg { width: 1.5rem; height: 1.5rem; }

/* ════════════════════════════════════════════════════════════════════════
   STATS
   ════════════════════════════════════════════════════════════════════════ */
.ar-stats {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem;
}
.ar-stat {
    text-align: center; background: var(--ar-surface); border: 1px solid var(--ar-line);
    border-radius: var(--ar-r); padding: 1.6rem 1rem; box-shadow: var(--ar-shadow);
}
.ar-stat-num { font-family: var(--ar-font-display); font-weight: 800; font-size: 2.2rem; line-height: 1; color: var(--ar-ink); }
.ar-stat-label { font-size: .82rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--ar-muted); margin-top: .35rem; }
.ar-suffix { color: var(--ar-accent); }
@media (max-width: 720px) { .ar-stats { grid-template-columns: repeat(2, 1fr); } }

/* ════════════════════════════════════════════════════════════════════════
   PAGE HEADER (inner pages) + badges
   ════════════════════════════════════════════════════════════════════════ */
.ar-page-header {
    position: relative; text-align: center; color: #fff; overflow: hidden;
    padding: clamp(3.2rem, 7vw, 5.5rem) 0 clamp(2.8rem, 6vw, 4.5rem);
    background: var(--ar-grad-brand);
}
.ar-page-header::after {
    content: ""; position: absolute; inset: 0; opacity: .5;
    background:
        radial-gradient(640px 320px at 12% -10%, rgba(255,255,255,.22), transparent 60%),
        radial-gradient(520px 320px at 100% 120%, rgba(0,0,0,.30), transparent 55%);
}
.ar-page-header > .container { position: relative; z-index: 2; }
.ar-page-header h1 { color: #fff; font-size: clamp(2rem, 4.4vw, 3rem); font-weight: 800; margin: 0; }
.ar-page-sub { color: rgba(255,255,255,.86); font-size: 1.08rem; margin-top: .6rem; }

.ar-badge {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: .76rem; font-weight: 700; letter-spacing: .04em;
    padding: .4rem .85rem; border-radius: 999px;
}
.ar-badge-soft { background: rgba(255,255,255,.18); color: #fff; backdrop-filter: blur(4px); }
.ar-badge-solid { background: var(--ar-accent); color: #111; }
.ar-chip {
    display: inline-flex; align-items: center; gap: .3rem;
    font-size: .72rem; font-weight: 700; color: var(--ar-primary-dark);
    background: var(--ar-primary-soft); padding: .25rem .6rem; border-radius: 999px;
}

/* ════════════════════════════════════════════════════════════════════════
   SPEAKERS
   ════════════════════════════════════════════════════════════════════════ */
.ar-speaker {
    background: var(--ar-surface); border: 1px solid var(--ar-line);
    border-radius: var(--ar-r); overflow: hidden; height: 100%;
    box-shadow: var(--ar-shadow); transition: transform .2s ease, box-shadow .2s ease;
}
.ar-speaker:hover { transform: translateY(-5px); box-shadow: var(--ar-shadow-lg); }
.ar-speaker-photo-wrap { position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--ar-grad-brand); }
.ar-speaker-photo-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.ar-speaker:hover .ar-speaker-photo-wrap img { transform: scale(1.06); }
.ar-speaker-initial { width: 100%; height: 100%; display: grid; place-items: center; font-family: var(--ar-font-display); font-size: 2.6rem; font-weight: 800; color: #fff; }
.ar-speaker-social {
    position: absolute; inset: auto 0 0 0; display: flex; gap: .5rem; justify-content: center;
    padding: 2.2rem .6rem .8rem; opacity: 0; transform: translateY(8px);
    background: linear-gradient(transparent, rgba(8,12,28,.7)); transition: .25s ease;
}
.ar-speaker:hover .ar-speaker-social { opacity: 1; transform: none; }
.ar-speaker-social a { display: grid; place-items: center; width: 32px; height: 32px; border-radius: 9px; background: rgba(255,255,255,.92); color: var(--ar-ink); }
.ar-speaker-social a:hover { background: var(--ar-accent); color: #111; }
.ar-speaker-body { padding: 1.1rem 1.15rem 1.3rem; }
.ar-speaker-name { font-family: var(--ar-font-display); font-weight: 700; font-size: 1.04rem; color: var(--ar-ink); margin: 0; }
.ar-speaker-role { color: var(--ar-primary); font-weight: 600; font-size: .85rem; margin: .25rem 0 0; }
.ar-speaker-org { color: var(--ar-muted); font-size: .82rem; margin: .2rem 0 0; display: flex; align-items: center; gap: .3rem; }
.ar-speaker-bio { color: var(--ar-muted); font-size: .85rem; line-height: 1.6; margin: .7rem 0 0; }

/* Mini speaker (cross-event / platform) */
.ar-speaker-mini { text-align: center; }
.ar-speaker-avatar {
    width: 96px; height: 96px; margin: 0 auto .7rem; border-radius: 20px; overflow: hidden;
    display: grid; place-items: center; font-family: var(--ar-font-display); font-weight: 800;
    font-size: 1.8rem; color: #fff; background: var(--ar-grad-brand);
    box-shadow: var(--ar-shadow); border: 3px solid #fff;
}
.ar-speaker-avatar img { width: 100%; height: 100%; object-fit: cover; }

/* ════════════════════════════════════════════════════════════════════════
   COMMITTEES
   ════════════════════════════════════════════════════════════════════════ */
.ar-committee {
    display: flex; align-items: center; gap: 1rem; height: 100%;
    background: var(--ar-surface); border: 1px solid var(--ar-line);
    border-radius: var(--ar-r); padding: 1.1rem 1.15rem; box-shadow: var(--ar-shadow);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.ar-committee:hover { transform: translateY(-3px); box-shadow: var(--ar-shadow-md); border-color: color-mix(in srgb, var(--ar-primary) 26%, var(--ar-line)); }
.ar-committee-avatar, .ar-committee-avatar-ph {
    width: 64px; height: 64px; border-radius: 16px; flex-shrink: 0; object-fit: cover;
}
.ar-committee-avatar-ph { display: grid; place-items: center; font-family: var(--ar-font-display); font-weight: 800; font-size: 1.4rem; color: #fff; background: var(--ar-grad-brand); }
.ar-committee-name { font-family: var(--ar-font-display); font-weight: 700; font-size: 1rem; color: var(--ar-ink); }
.ar-committee-role { color: var(--ar-primary); font-weight: 600; font-size: .84rem; margin-top: .15rem; }
.ar-committee-org { color: var(--ar-muted); font-size: .8rem; margin-top: .12rem; display: flex; align-items: center; gap: .3rem; }

/* ════════════════════════════════════════════════════════════════════════
   AGENDA / TIMELINE
   ════════════════════════════════════════════════════════════════════════ */
.ar-agenda { position: relative; }
.ar-session { display: grid; grid-template-columns: 92px 1fr; gap: 1rem; position: relative; padding-bottom: 1.2rem; }
.ar-session-time { position: relative; text-align: right; padding-right: 1.1rem; }
.ar-session-time::before { content: ""; position: absolute; top: .2rem; bottom: -1.2rem; right: 0; width: 2px; background: var(--ar-line); }
.ar-t-start { font-family: var(--ar-font-display); font-weight: 800; color: var(--ar-ink); font-size: 1rem; }
.ar-t-end { font-size: .78rem; color: var(--ar-muted); }
.ar-session-node {
    position: absolute; top: .35rem; right: -5px; width: 12px; height: 12px; border-radius: 50%;
    background: #fff; border: 3px solid var(--ar-accent); box-shadow: 0 0 0 4px var(--ar-accent-soft);
}
.ar-session-card {
    background: var(--ar-surface); border: 1px solid var(--ar-line); border-left: 3px solid var(--ar-primary);
    border-radius: var(--ar-r-sm); padding: 1rem 1.2rem; box-shadow: var(--ar-shadow);
    transition: transform .18s ease, box-shadow .18s ease;
}
.ar-session-card:hover { transform: translateX(3px); box-shadow: var(--ar-shadow-md); }
.ar-session-card h4 { font-size: 1.05rem; margin: 0; color: var(--ar-ink); }
.ar-session-meta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: .5rem; font-size: .85rem; color: var(--ar-muted); }
.ar-session-meta span { display: inline-flex; align-items: center; gap: .35rem; }
.ar-session-meta svg { width: 1em; height: 1em; color: var(--ar-primary); }
.ar-agenda-day-label { display: inline-flex; align-items: center; gap: .55rem; font-family: var(--ar-font-display); font-weight: 700; font-size: 1.05rem; color: var(--ar-ink); margin-bottom: 1.4rem; }
.ar-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--ar-grad); }

/* Day / filter tabs */
.ar-day-tabs { display: flex; flex-wrap: wrap; gap: .55rem; justify-content: center; margin-bottom: 2.2rem; }
.ar-day-tab {
    border: 1.5px solid var(--ar-line); background: #fff; color: var(--ar-ink);
    border-radius: 999px; padding: .55rem 1.1rem; font-weight: 600; font-size: .9rem; cursor: pointer;
    display: inline-flex; align-items: center; gap: .4rem; transition: .18s ease;
}
.ar-day-tab small { color: var(--ar-muted); font-weight: 500; }
.ar-day-tab:hover { border-color: var(--ar-primary); color: var(--ar-primary); }
.ar-day-tab.active { background: var(--ar-grad); color: #fff; border-color: transparent; }
.ar-day-tab.active small { color: rgba(255,255,255,.85); }

/* ════════════════════════════════════════════════════════════════════════
   DATES
   ════════════════════════════════════════════════════════════════════════ */
.ar-date-card {
    display: flex; align-items: center; gap: 1rem; height: 100%;
    background: var(--ar-surface); border: 1px solid var(--ar-line);
    border-radius: var(--ar-r); padding: 1.1rem 1.2rem; box-shadow: var(--ar-shadow);
    transition: transform .2s ease, box-shadow .2s ease;
}
.ar-date-card:hover { transform: translateY(-3px); box-shadow: var(--ar-shadow-md); }
.ar-date-badge {
    flex-shrink: 0; width: 64px; height: 64px; border-radius: 14px; color: #fff;
    background: var(--ar-grad-brand); display: grid; place-items: center; line-height: 1;
}
.ar-d-day { font-family: var(--ar-font-display); font-weight: 800; font-size: 1.5rem; }
.ar-d-mon { font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; }
.ar-date-title { font-family: var(--ar-font-display); font-weight: 700; color: var(--ar-ink); }
.ar-date-full { color: var(--ar-muted); font-size: .85rem; margin-top: .15rem; }

/* ════════════════════════════════════════════════════════════════════════
   PARTNERS / LOGOS
   ════════════════════════════════════════════════════════════════════════ */
.ar-tier-label { text-align: center; font-family: var(--ar-font-display); font-weight: 700; color: var(--ar-primary); margin: 1.2rem 0 1.4rem; text-transform: uppercase; letter-spacing: .08em; font-size: .9rem; }
.ar-logo-tile {
    height: 100%; min-height: 96px; display: grid; place-items: center; padding: 1rem;
    background: var(--ar-surface); border: 1px solid var(--ar-line); border-radius: var(--ar-r-sm);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.ar-logo-tile:hover { transform: translateY(-3px); box-shadow: var(--ar-shadow); border-color: color-mix(in srgb, var(--ar-primary) 24%, var(--ar-line)); }
.ar-logo-tile img { max-height: 60px; max-width: 100%; object-fit: contain; filter: grayscale(1); opacity: .82; transition: .2s ease; }
.ar-logo-tile:hover img { filter: none; opacity: 1; }
.ar-logo-tile span { font-weight: 700; color: var(--ar-muted); text-align: center; font-size: .9rem; }

/* ════════════════════════════════════════════════════════════════════════
   CTA
   ════════════════════════════════════════════════════════════════════════ */
.ar-cta {
    position: relative; overflow: hidden; text-align: center; color: #fff;
    background: var(--ar-grad-brand); border-radius: var(--ar-r-lg);
    padding: clamp(2.8rem, 5vw, 4.5rem) 1.5rem; box-shadow: var(--ar-shadow-lg);
}
.ar-cta::after {
    content: ""; position: absolute; inset: 0; opacity: .5;
    background:
        radial-gradient(600px 300px at 8% 0%, rgba(255,255,255,.2), transparent 60%),
        radial-gradient(600px 300px at 100% 100%, rgba(0,0,0,.3), transparent 55%);
}
.ar-cta > * { position: relative; z-index: 2; }
.ar-cta h2 { color: #fff; font-size: clamp(1.6rem, 3.4vw, 2.4rem); font-weight: 800; margin: 0 0 .6rem; }
.ar-cta p { color: rgba(255,255,255,.9); font-size: 1.05rem; margin: 0; }

/* ════════════════════════════════════════════════════════════════════════
   FAQ
   ════════════════════════════════════════════════════════════════════════ */
.ar-faq { max-width: 800px; margin-inline: auto; display: flex; flex-direction: column; gap: .75rem; }
.ar-faq-item { background: var(--ar-surface); border: 1px solid var(--ar-line); border-radius: var(--ar-r-sm); overflow: hidden; transition: border-color .2s ease, box-shadow .2s ease; }
.ar-faq-item.open { border-color: color-mix(in srgb, var(--ar-primary) 30%, var(--ar-line)); box-shadow: var(--ar-shadow); }
.ar-faq-q {
    width: 100%; text-align: left; background: none; border: 0; cursor: pointer;
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    font-family: var(--ar-font-display); font-weight: 700; font-size: 1rem; color: var(--ar-ink);
    padding: 1.1rem 1.25rem;
}
.ar-faq-q svg { width: 1.2em; height: 1.2em; color: var(--ar-primary); transition: transform .25s ease; flex-shrink: 0; }
.ar-faq-item.open .ar-faq-q svg { transform: rotate(180deg); }
.ar-faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.ar-faq-a-inner { padding: 0 1.25rem 1.15rem; color: var(--ar-muted); line-height: 1.7; }

/* ════════════════════════════════════════════════════════════════════════
   EMPTY STATE
   ════════════════════════════════════════════════════════════════════════ */
.ar-empty { text-align: center; padding: 4rem 1rem; color: var(--ar-muted); }
.ar-empty svg { width: 3rem; height: 3rem; color: var(--ar-line); margin-bottom: 1rem; }
.ar-empty p { margin: 0; font-size: 1.05rem; }

/* ════════════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════════════ */
.ar-footer { background: var(--ar-footer-bg, var(--ar-dark)); color: rgba(255,255,255,.72); padding-top: clamp(3rem, 5vw, 4.5rem); margin-top: auto; }
.ar-footer h5 { color: #fff; font-family: var(--ar-font-display); font-weight: 700; font-size: 1rem; margin-bottom: 1.1rem; }
.ar-footer a { color: rgba(255,255,255,.72); text-decoration: none; transition: color .15s ease; }
.ar-footer a:hover { color: #fff; }
.ar-footer p { color: rgba(255,255,255,.62); font-size: .92rem; line-height: 1.7; }
.ar-footer svg { width: 1em; height: 1em; vertical-align: -.12em; }
.ar-foot-brand { display: inline-flex; align-items: center; gap: .6rem; font-family: var(--ar-font-display); font-weight: 800; font-size: 1.25rem; color: #fff; }
.ar-footer-input {
    flex: 1; min-width: 0; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.16);
    color: #fff; border-radius: 999px; padding: .6rem 1rem; font-size: .9rem;
}
.ar-footer-input::placeholder { color: rgba(255,255,255,.5); }
.ar-footer-input:focus { outline: none; border-color: var(--ar-accent); }
.ar-footer-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 2.5rem; padding: 1.3rem 0; font-size: .86rem; }
.ar-footer-bottom p { margin: 0; color: rgba(255,255,255,.6); }

/* ════════════════════════════════════════════════════════════════════════
   BACK TO TOP
   ════════════════════════════════════════════════════════════════════════ */
#ar-back-top {
    position: fixed; right: 1.5rem; bottom: 1.5rem; z-index: 1040;
    width: 46px; height: 46px; border-radius: 14px; border: 0; cursor: pointer;
    display: grid; place-items: center; color: #fff; background: var(--ar-grad);
    box-shadow: var(--ar-shadow-md); opacity: 0; transform: translateY(14px); pointer-events: none;
    transition: opacity .25s ease, transform .25s ease;
}
#ar-back-top.visible { opacity: 1; transform: none; pointer-events: auto; }
#ar-back-top:hover { filter: brightness(1.06); }

/* ════════════════════════════════════════════════════════════════════════
   SCROLL REVEAL
   ════════════════════════════════════════════════════════════════════════ */
.ar-reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.ar-reveal.ar-in { opacity: 1; transform: none; }
.ar-reveal-d1 { transition-delay: .08s; }
.ar-reveal-d2 { transition-delay: .16s; }
.ar-reveal-d3 { transition-delay: .24s; }
.ar-reveal-d4 { transition-delay: .32s; }
@media (prefers-reduced-motion: reduce) {
    .ar-reveal { opacity: 1; transform: none; transition: none; }
    body::before { display: none; }
}

/* ════════════════════════════════════════════════════════════════════════
   FALLBACK-PAGE POLISH
   These default-theme pages render inside the Aurora shell. The default CSS is
   loaded first; here we lift a few shared elements into the Aurora look.
   ════════════════════════════════════════════════════════════════════════ */
.page-header { background: var(--ar-grad-brand) !important; }
.page-header h1, .page-header h2 { font-family: var(--ar-font-display); }
.section-title { font-family: var(--ar-font-display); font-weight: 800; color: var(--ar-ink); }
.rich-content { color: var(--ar-body); line-height: 1.8; }
.rich-content h1, .rich-content h2, .rich-content h3, .rich-content h4 { font-family: var(--ar-font-display); color: var(--ar-ink); }
.rich-content a { color: var(--ar-primary); }
.btn-accent { background: var(--ar-accent); border-color: var(--ar-accent); color: #111; }
.btn-accent:hover { background: var(--ar-accent-dark); border-color: var(--ar-accent-dark); color: #fff; }
.btn-accent-outline { border-color: var(--ar-accent); color: var(--ar-accent); }
.btn-accent-outline:hover { background: var(--ar-accent); color: #111; }
.hover-shadow { transition: transform .2s ease, box-shadow .2s ease; }
.hover-shadow:hover { transform: translateY(-4px); box-shadow: var(--ar-shadow-lg); }

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 991px) {
    .ar-navbar .navbar-nav { padding-top: .6rem; gap: .15rem; }
    .ar-navbar .nav-link.active::after { display: none; }
    .ar-nav-cta, .ar-nav-outline { display: inline-block; margin-top: .3rem; }
}
@media (max-width: 575px) {
    .ar-session { grid-template-columns: 70px 1fr; }
    .ar-cta { border-radius: var(--ar-r); }
}

/* ════════════════════════════════════════════════════════════════════════
   EXTENDED COLOR TOKENS  (Site Colors / per-event color overrides)
   Each maps a universal token onto an Aurora surface with a fallback to the
   theme default — an unset token changes nothing; a set token applies here.
   ════════════════════════════════════════════════════════════════════════ */
a { color: var(--link, var(--ar-primary)); }
a:hover { color: var(--link-hover, var(--ar-primary-dark)); }
.ar-eyebrow { color: var(--badge-text, var(--ar-primary)); background: var(--badge-bg, var(--ar-primary-soft)); }
.ar-eyebrow svg, .ar-badge svg { color: var(--icon, currentColor); }
.ar-navbar .nav-link { color: var(--nav-text, var(--ar-ink)); }
.ar-navbar .nav-link:hover, .ar-navbar .nav-link.active { color: var(--nav-text-hover, var(--ar-primary)); }
.ar-btn-primary { background: var(--btn-bg, var(--ar-grad)); color: var(--btn-text, #fff); }
.ar-btn-primary:hover { background: var(--btn-hover-bg, var(--btn-bg, var(--ar-grad))); }
.ar-footer { color: var(--footer-text, rgba(255,255,255,.72)); }
.ar-footer a { color: var(--footer-link, rgba(255,255,255,.72)); }
