/* ============================================
   HIMSS26 APAC REGISTRATION - FINAL PRODUCTION CSS
   Version 1.1 | April 2026
   Based on: HIMSS26 Europe v5.53 FINAL
   APAC Changes:
   - Primary gradient: linear-gradient(134deg, #0f1288, #4429c5)
   - Navbar background: #FCFCFC
   ============================================ */

/* Import Fonts */
@import url('https://p.typekit.net/p.css?s=1&k=cxk2txu&ht=tk&f=23725.23726.23746.23748.23751&a=24129811&app=typekit&e=css');

/* Font Face Declarations */
@font-face {
  font-family: "prometo";
  src: url("https://use.typekit.net/af/c4af2b/00000000000000007735a47a/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n7&v=3") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "soleto";
  src: url("https://use.typekit.net/af/0b3ef7/00000000000000007735fdcc/30/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n4&v=3") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}




[data-testid="speaker-names"] .css-nsjg29-MuiTypography-root {
  display: block;
  margin-bottom: 8px;
}

[data-testid="speaker-names"] .css-nsjg29-MuiTypography-root .css-1xg2o9w-MuiTypography-root {
  display: block;
  margin-top: 2px;
}

[data-testid="speaker-names"] > .css-1xg2o9w-MuiTypography-root {
  display: none;
}

.css-116mf15-MuiAvatarGroup-root {
  display: none;
}

[data-testid="speaker-names"] {
  display: block !important;
  overflow: visible !important;
  -webkit-line-clamp: unset !important;
  max-height: none !important;
  white-space: normal !important;
}

.css-16p0ujb {
  overflow: visible !important;
  max-height: none !important;
}

.css-1pbzb24-MuiStack-root {
  overflow: visible !important;
  max-height: none !important;
}




/* ================================================
   EVENTSAIR AGENDA - KEYWORD TAGS FIX
   ================================================ */

.css-1kfcngz:has(.css-10isx4t) { overflow: visible !important; flex-grow: 0 !important; align-self: auto !important; height: auto !important; }
.css-1kfcngz:has(.css-10isx4t) .css-4yqwy4 { flex-wrap: wrap !important; flex-direction: row !important; width: 100% !important; }
.css-1kfcngz:has(.css-10isx4t) > div[style*="gradient"] { display: none !important; }
.css-10isx4t { align-self: auto !important; width: auto !important; flex-grow: 0 !important; }
.css-12p7far { overflow: visible !important; height: auto !important; }
div[style="margin: 5px 0"] { display: flex !important; flex-wrap: wrap !important; }
div[style="margin: 5px 0"] .trackHeading { background-color: transparent !important; }

/* Hide duplicate Title heading and session title on speaker bio page */
.sectionTitle,
h4.font14[role="paragraph"] {
    display: none !important;
}

/* Fix black color overrides */
.fontBlack14,
.attendees h4,
.attendeeInfo h4,
.contactPosition,
.contactOrganization,
.contactState,
.fontBlack12,
.font14,
.sessionInfoItem h4,
.agenda h3,
.agenda h4 {
    color: inherit !important;
}




/* ======================================= */
/* SESSION INFO - FULL LAYOUT FIX          */
/* ======================================= */

.css-iz07a1-MuiTypography-root {
    margin-bottom: 12px !important;
}

.css-nen11g-MuiStack-root > h3.css-1v0o0at-MuiTypography-root {
    visibility: hidden !important;
    font-size: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 0 !important;
}

.css-nen11g-MuiStack-root > h3.css-1v0o0at-MuiTypography-root::before {
    content: "SPEAKER" !important;
    visibility: visible !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    color: #888888 !important;
    display: block !important;
    line-height: normal !important;
    margin-bottom: 8px !important;
}

.css-nen11g-MuiStack-root {
    gap: 6px !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    margin-bottom: 8px !important;
}

.css-nen11g-MuiStack-root .css-1kyhjjn-MuiTypography-root {
    margin-bottom: 8px !important;
}

.css-160glkp {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

.css-43htc {
    display: none !important;
}

.css-nen11g-MuiStack-root:has(> .css-1j99hcx-MuiStack-root) {
    border-top: 1px solid #d0d0d0 !important;
    padding-top: 14px !important;
    margin-top: 8px !important;
    margin-bottom: 0 !important;
    gap: 0 !important;
}

/* ======================================= */
/* TYPOGRAPHY - SPEAKER PAGE WEB           */
/* ======================================= */
.ea-data-Presenters .speaker-container .col-sm-10 p {
    margin-top: 0 !important;
    margin-bottom: 14px !important;
    line-height: 1.45 !important;
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
}
.ea-data-Presenters .speaker-container .col-sm-10 br { display: none !important; }
.ea-data-Presenters .speaker-container .col-sm-10 ul {
    margin-top: 0 !important;
    margin-bottom: 14px !important;
    padding-left: 20px !important;
}
.ea-data-Presenters .speaker-container .col-sm-10 li {
    margin-bottom: 6px !important;
    line-height: 1.45 !important;
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
}

/* ======================================= */
/* TYPOGRAPHY - MOBILE APP SPEAKER BIO     */
/* ======================================= */
.css-mk3vku-MuiTypography-root p {
    margin-top: 0 !important;
    margin-bottom: 14px !important;
    line-height: 1.45 !important;
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
}
.css-mk3vku-MuiTypography-root br { display: none !important; }
.css-mk3vku-MuiTypography-root ul {
    margin-top: 0 !important;
    margin-bottom: 14px !important;
    padding-left: 20px !important;
}
.css-mk3vku-MuiTypography-root li {
    margin-bottom: 6px !important;
    line-height: 1.45 !important;
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
}

/* ======================================= */
/* TYPOGRAPHY - MOBILE APP SESSION DESC    */
/* ======================================= */
.css-1kyhjjn-MuiTypography-root p {
    margin-top: 0 !important;
    margin-bottom: 14px !important;
    line-height: 1.45 !important;
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
}
.css-1kyhjjn-MuiTypography-root br { display: none !important; }
.css-1kyhjjn-MuiTypography-root ul {
    margin-top: 0 !important;
    margin-bottom: 14px !important;
    padding-left: 20px !important;
}
.css-1kyhjjn-MuiTypography-root li {
    margin-bottom: 6px !important;
    line-height: 1.45 !important;
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
}

@media screen and (max-width: 640px) {
    .ea-data-Presenters .speaker-container .col-sm-10 p,
    .css-mk3vku-MuiTypography-root p,
    .css-1kyhjjn-MuiTypography-root p {
        margin-bottom: 12px !important;
        line-height: 1.4 !important;
    }
    .ea-data-Presenters .speaker-container .col-sm-10 li,
    .css-mk3vku-MuiTypography-root li,
    .css-1kyhjjn-MuiTypography-root li {
        line-height: 1.4 !important;
    }
}

#ext-modernSessionInformationScreen-1 ul li {
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
    line-height: 1.45 !important;
}

/* ============================================
   MODERN CSS VARIABLES
   APAC: Navy-purple gradient #0f1288 -> #4429c5
   ============================================ */
:root {
    /* Brand Colors */
    --himss-navy: #21145f;
    --himss-blue: #1e22aa;
    --himss-cyan: #54c0e8;
    --himss-teal: #3CD5AF;
    --himss-coral: #F15A29;
    --himss-yellow: #FFC72C;

    /* APAC Gradient Colors */
    --gradient-start: #0f1288;
    --gradient-end: #4429c5;

    /* Semantic Colors */
    --color-primary: var(--himss-blue);
    --color-secondary: var(--himss-cyan);
    --color-accent: #4429c5;
    --color-success: var(--himss-teal);
    --color-warning: var(--himss-yellow);
    --color-danger: #f04438;

    /* APAC Gradients */
    --gradient-primary: linear-gradient(134deg, #0f1288, #4429c5);
    --gradient-hover: linear-gradient(134deg, #0a0c6a, #3520a8);
    --gradient-title: linear-gradient(90deg, #3CD5AF 0%, #FFC72C 100%);
    --gradient-fade: linear-gradient(90deg, #e0e0e0 0%, rgba(224, 224, 224, 0.3) 85%, rgba(255, 255, 255, 0) 100%);
    --gradient-background: linear-gradient(90deg, #21145f 20%, #1e22aa 100%);

    /* Neutrals */
    --color-white: #FFFFFF;
    --color-black: #000000;
    --color-gray-50: #f8f9fb;
    --color-gray-100: #f5f5f5;
    --color-gray-200: #f0f0f0;
    --color-gray-300: #e0e0e0;
    --color-gray-400: #ccc;
    --color-gray-600: #666;
    --color-gray-800: #555;

    /* Spacing Scale */
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 2.5rem;
    --space-3xl: 3rem;

    /* Border Radius */
    --radius-sm: 8px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --radius-2xl: 24px;
    --radius-full: 9999px;

    /* Shadows */
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.06);
    --shadow-md: 0 4px 20px rgba(0, 0, 0, 0.08);
    --shadow-lg: 0 8px 30px rgba(30, 34, 170, 0.15);
    --shadow-xl: 0 15px 40px rgba(0, 0, 0, 0.2);
    --shadow-2xl: 0 25px 80px rgba(33, 20, 95, 0.2);
    --shadow-glow: 0 0 0 3px rgba(68, 41, 197, 0.1);
    --shadow-glow-primary: 0 4px 12px rgba(68, 41, 197, 0.35);
    --shadow-glow-primary-lg: 0 6px 20px rgba(68, 41, 197, 0.55);

    /* Typography */
    --font-xs: 0.75rem;
    --font-sm: 0.875rem;
    --font-base: 1rem;
    --font-lg: 1.125rem;
    --font-xl: 1.25rem;
    --font-2xl: 1.5rem;
    --font-3xl: 2rem;
    --font-4xl: 2.5rem;
    --font-5xl: 3.5rem;

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-base: 250ms ease;
    --transition-slow: 400ms ease;
    --transition-bounce: 600ms cubic-bezier(0.34, 1.56, 0.64, 1);

    /* Font Families */
    --font-heading: "prometo", "Century Gothic", "Helvetica Neue", Arial, sans-serif;
    --font-body: "soleto", "Century Gothic", "Helvetica Neue", Arial, sans-serif;
}

/* ============================================
   MODERN CSS RESET
   ============================================ */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    scroll-behavior: smooth;
}

/* ============================================
   BODY - GRADIENT BACKGROUND
   ============================================ */
body {
    font-family: var(--font-body);
    background: linear-gradient(90deg, #21145f 20%, #1e22aa 100%) !important;
    color: var(--color-gray-800);
    min-height: 100vh;
}

img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
    height: auto;
}

svg#SvgjsSvg1000 {
    height: 100%;
}

/* ============================================
   GLOBAL FONT APPLICATION
   ============================================ */
body, .container, .row, div:not([class*="fa-"]):not(.fa):not([class*="glyphicon"]),
span:not([class*="fa-"]):not(.fa):not([class*="glyphicon"]), p, li, a, label, button {
    font-family: var(--font-body) !important;
}

.glyphicon, [class*="glyphicon-"] {
    font-family: 'Glyphicons Halflings' !important;
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6,
.page-title, .section-title, legend, .form-section-title {
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
}

/* ============================================
   PARAGRAPH AND LIST FORMATTING
   ============================================ */
p {
    line-height: 1.6;
    margin-bottom: 15px;
}

ul, ol {
    padding-left: 20px;
    margin-bottom: 15px;
}

ul li, ol li { margin-bottom: 5px; }
ul li { list-style-type: disc; }
ol li { list-style-type: decimal; }

ul li::marker, ol li::marker {
    color: #1e22aa;
    font-weight: bold;
}

/* ============================================
   CONTAINER
   ============================================ */
.container {
    max-width: min(1200px, 100% - var(--space-xl));
    margin: 0 auto;
    padding: var(--space-lg);
}

/* ============================================
   HEADER STYLING
   ============================================ */
.page-header, .event-header {
    border-radius: var(--radius-2xl);
    overflow: hidden;
    box-shadow: var(--shadow-2xl);
    margin-bottom: 0;
    border: 2px solid rgba(30, 34, 170, 0.1);
    position: relative;
}

.page-header img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

/* ============================================
   PAGE TITLES & HEADINGS
   APAC: Teal to Yellow title gradient
   ============================================ */
.page-title, h1.page-title {
    font-size: clamp(2rem, 4vw + 1rem, 3.5rem);
    font-weight: 800;
    letter-spacing: -0.05rem;
    line-height: 1.1;
    text-align: center;
    background: var(--gradient-title);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: var(--space-xl);
    margin-top: var(--space-2xl);
}

h1, .h1 {
    font-size: clamp(1.75rem, 3vw, 2rem);
    color: var(--color-primary);
    margin-bottom: var(--space-lg);
    margin-top: var(--space-xl);
}

h2, .h2, .section-title {
    font-size: clamp(1.5rem, 2.5vw, 1.75rem);
    color: var(--color-primary);
    margin-bottom: var(--space-lg);
    margin-top: var(--space-xl);
}

h3, .h3 {
    font-size: clamp(1.25rem, 2vw, 1.5rem);
    color: var(--color-primary);
    margin-bottom: var(--space-md);
    margin-top: var(--space-lg);
}

h4, .h4 {
    font-size: clamp(1.125rem, 1.5vw, 1.25rem);
    color: var(--color-primary);
    margin-bottom: var(--space-md);
    margin-top: var(--space-lg);
}

/* ============================================
   NAVIGATION BAR - APAC #FCFCFC BACKGROUND
   PageBreak component: Next / Back / Cancel
   ============================================ */
.navbar.navbar-inverse.navbar-inside-page {
    background: #FCFCFC !important;
    background-image: none !important;
    border: none !important;
    border-top: 1px solid var(--color-gray-300) !important;
    border-bottom: 1px solid var(--color-gray-300) !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06) !important;
    border-radius: 0 !important;
}

.navbar.navbar-inverse.navbar-inside-page .container-fluid {
    padding: 8px 16px !important;
}

/* Buttons inside the navbar */
.navbar.navbar-inverse.navbar-inside-page .btn.btn-default.navbar-btn,
.navbar.navbar-inverse.navbar-inside-page .theme-btn-primary {
    background: var(--gradient-primary) !important;
    color: var(--color-white) !important;
    border: none !important;
    border-radius: var(--radius-full) !important;
    font-family: var(--font-body) !important;
    font-weight: 600 !important;
    padding: 10px 24px !important;
    font-size: var(--font-base) !important;
    box-shadow: var(--shadow-glow-primary) !important;
    transition: all var(--transition-base) !important;
}

.navbar.navbar-inverse.navbar-inside-page .btn.btn-default.navbar-btn:hover,
.navbar.navbar-inverse.navbar-inside-page .theme-btn-primary:hover {
    background: var(--gradient-hover) !important;
    box-shadow: var(--shadow-glow-primary-lg) !important;
    transform: translateY(-1px) !important;
    color: var(--color-white) !important;
}

/* ============================================
   FORM SECTIONS
   ============================================ */
.form-section, .registration-section, .panel, .card {
    background: var(--color-white);
    border-radius: var(--radius-xl);
    padding: var(--space-2xl) var(--space-xl);
    margin-bottom: var(--space-xl);
    box-shadow: var(--shadow-md);
    border: 2px solid transparent;
    transition: all var(--transition-base);
}

.form-section:hover, .registration-section:hover,
.panel:hover, .card:hover {
    box-shadow: var(--shadow-lg);
    border-color: var(--color-secondary);
    transform: translateY(-2px);
}

.panel-heading, .card-header {
    background: transparent !important;
    border: none !important;
    padding-bottom: var(--space-lg);
}

.panel-title, .card-title {
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
    color: var(--color-primary) !important;
    font-size: var(--font-2xl);
}

/* ============================================
   FORM INPUTS
   ============================================ */
.form-group {
    margin-bottom: var(--space-lg);
}

label, .control-label {
    font-family: var(--font-body) !important;
    font-weight: 600;
    color: var(--himss-navy);
    margin-bottom: var(--space-sm);
    display: block;
}

/* ============================================
   SELECT2 DROPDOWN - REMOVE ALL ANIMATIONS
   ============================================ */
.select2-container *,
.select2-dropdown *,
.select2-results *,
.select2-container,
.select2-dropdown {
    transition: none !important;
    animation: none !important;
    transform: none !important;
}

.select2-dropdown,
.select2-container--open .select2-dropdown {
    animation: none !important;
    transition: none !important;
}

/* ============================================
   BUTTONS - APAC navy-purple gradient
   ============================================ */
.btn, button, input[type="submit"], input[type="button"] {
    font-family: var(--font-body) !important;
    font-weight: 600;
    padding: 14px 32px;
    border-radius: var(--radius-full);
    border: none;
    font-size: var(--font-lg);
    cursor: pointer;
    transition: all var(--transition-base);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-sm);
    text-decoration: none;
    position: relative;
    overflow: hidden;
}

/* Primary Buttons */
.btn-primary, input[type="submit"], button[type="submit"],
.btn-register, .btn-continue, .register-button {
    background: var(--gradient-primary) !important;
    color: var(--color-white) !important;
    box-shadow: var(--shadow-glow-primary);
}

/* Shimmer effect on hover */
.btn-primary::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.25), transparent);
    transform: translateX(-100%);
    transition: transform var(--transition-slow);
}

.btn-primary:hover::before {
    transform: translateX(100%);
}

.btn-primary:hover, input[type="submit"]:hover,
button[type="submit"]:hover, .btn-register:hover {
    background: var(--gradient-hover) !important;
    box-shadow: var(--shadow-glow-primary-lg) !important;
    transform: translateY(-2px) scale(1.02);
    color: var(--color-white) !important;
}

.btn-primary:active {
    transform: translateY(0) scale(0.98);
}

/* Secondary Buttons */
.btn-secondary, .btn-back {
    background: var(--color-white) !important;
    color: var(--color-primary) !important;
    border: 2px solid var(--color-primary) !important;
}

.btn-secondary:hover, .btn-back:hover {
    background: var(--color-primary) !important;
    color: var(--color-white) !important;
}

/* Default Buttons */
.btn-default {
    background: var(--gradient-primary) !important;
    color: var(--color-white) !important;
    box-shadow: var(--shadow-glow-primary) !important;
    border: none !important;
}

.btn-default:hover {
    background: var(--gradient-hover) !important;
    box-shadow: var(--shadow-glow-primary-lg) !important;
    transform: translateY(-2px);
    color: var(--color-white) !important;
}

/* ============================================
   NAVIGATION BUTTONS
   ============================================ */
.form-navigation, .wizard-navigation {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--space-md);
    margin-top: var(--space-2xl);
    padding-top: var(--space-xl);
    border-top: 2px solid var(--color-gray-200);
}

/* ============================================
   PRICING TABLES
   ============================================ */
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
    gap: var(--space-lg);
    margin: var(--space-xl) 0;
}

.pricing-option, .registration-option, .ticket-option {
    background: var(--color-white);
    border: 2px solid var(--color-gray-300);
    border-radius: var(--radius-lg);
    padding: var(--space-xl);
    margin-bottom: var(--space-lg);
    transition: all var(--transition-base);
    cursor: pointer;
    position: relative;
}

.pricing-option:hover, .registration-option:hover, .ticket-option:hover {
    border-color: var(--color-secondary);
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px);
}

.pricing-option.selected, .registration-option.selected, .ticket-option.selected {
    border-color: var(--color-success);
    background: rgba(60, 213, 175, 0.05);
    box-shadow: 0 8px 30px rgba(60, 213, 175, 0.2);
}

.pricing-option.selected::after {
    content: 'v';
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    width: 32px;
    height: 32px;
    background: var(--color-success);
    color: var(--color-white);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
}

.price, .registration-price {
    font-family: var(--font-heading) !important;
    font-size: var(--font-4xl);
    font-weight: 800;
    color: var(--color-primary);
    margin: var(--space-lg) 0;
}

/* ============================================
   ALERTS
   ============================================ */
.alert, .message, .notification {
    border-radius: var(--radius-md);
    padding: var(--space-md) var(--space-lg);
    margin-bottom: var(--space-lg);
    border: none;
    display: flex;
    gap: var(--space-sm);
    align-items: start;
    position: relative;
}

.alert .close,
.alert button.close {
    position: absolute;
    top: 8px;
    right: 12px;
    padding: 0;
    background: transparent;
    border: none;
    font-size: 24px;
    line-height: 1;
    color: inherit;
    opacity: 0.6;
    cursor: pointer;
    transition: opacity var(--transition-fast);
    width: auto;
    height: auto;
}

.alert .close:hover { opacity: 1; transform: none; }

.alert-success, .success-message {
    background: rgba(60, 213, 175, 0.1);
    color: #2a957a;
    border-left: 4px solid var(--color-success);
}

.alert-info, .info-message {
    background: rgba(84, 192, 232, 0.1);
    color: var(--color-primary);
    border-left: 4px solid var(--color-secondary);
}

.alert-warning, .warning-message {
    background: rgba(255, 199, 44, 0.1);
    color: #d68900;
    border-left: 4px solid var(--color-warning);
}

.alert-danger, .error-message {
    background: rgba(240, 68, 56, 0.1);
    color: #c73a33;
    border-left: 4px solid var(--color-danger);
}

/* ============================================
   PROGRESS BARS - APAC navy-purple gradient
   ============================================ */
.progress-bar, .wizard-progress {
    height: 15pt;
    background: var(--color-gray-100);
    border-radius: 0;
    overflow: hidden;
    margin-bottom: 15pt;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

.progress-bar-fill, .wizard-progress-fill {
    height: 100%;
    background: var(--gradient-primary);
    transition: width 0.6s cubic-bezier(0.65, 0, 0.35, 1);
    position: relative;
    overflow: hidden;
}

.progress-bar-fill::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    animation: shimmer 2s infinite;
}

@keyframes shimmer {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* ============================================
   EVENTSAIR PROGRESS BAR
   ============================================ */
.progress.theme-progress {
    height: 15pt !important;
    background: var(--color-gray-100) !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    margin-bottom: 0 !important;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1) !important;
    position: relative;
}

.progress.theme-progress .progress-bar {
    float: left;
    width: 0%;
    height: 100% !important;
    font-size: 10pt;
    line-height: 15pt;
    color: #fff;
    text-align: center;
    background-image: var(--gradient-primary) !important;
    box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15) !important;
    transition: width 0.6s ease !important;
    position: relative;
    overflow: hidden;
}

.progress.theme-progress .progress-bar::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    animation: shimmer 2s infinite;
}

.progress.theme-progress .progress-bar::after {
    content: attr(aria-valuenow) '%';
    position: absolute;
    top: 50%;
    right: 8px;
    transform: translateY(-50%);
    color: var(--color-white);
    font-family: var(--font-heading) !important;
    font-size: 11px;
    font-weight: 700;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
    z-index: 2;
    opacity: 1;
    transition: none !important;
}

.progress.theme-progress .progress-bar[aria-valuenow="0"]::after {
    display: none;
}

.progress.theme-progress.background-opacity {
    background: var(--color-gray-100) !important;
}

.progress.theme-progress .progressbar-value {
    display: none;
}

/* ============================================
   STEP INDICATOR
   ============================================ */
.step-indicator, .wizard-steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: var(--space-md);
    align-items: center;
    margin-bottom: var(--space-xl);
    position: relative;
}

.step-indicator::before {
    content: '';
    position: absolute;
    top: 20px;
    left: var(--space-3xl);
    right: var(--space-3xl);
    height: 3px;
    background: var(--color-gray-300);
    z-index: 0;
}

.step, .wizard-step {
    text-align: center;
    position: relative;
    padding: var(--space-sm) 0;
}

.step-number, .wizard-step-number {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
    background: var(--color-gray-300);
    color: var(--color-gray-600);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    margin-bottom: var(--space-sm);
    position: relative;
    z-index: 1;
    transition: all var(--transition-base);
}

.step.active .step-number,
.step.completed .step-number {
    background: var(--gradient-primary);
    color: var(--color-white);
    transform: scale(1.1);
}

.step.completed .step-number {
    background: var(--color-success);
}

.step-label, .wizard-step-label {
    font-size: var(--font-sm);
    color: var(--color-gray-600);
}

.step.active .step-label {
    color: var(--color-primary);
    font-weight: 600;
}

/* ============================================
   CHECKBOXES & RADIO BUTTONS
   APAC: navy-purple gradient on checked state
   ============================================ */
input[type="checkbox"], input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid var(--color-gray-300);
    cursor: pointer;
    position: relative;
    margin-right: var(--space-sm);
    transition: all var(--transition-fast);
    display: inline-block;
    vertical-align: middle;
    flex-shrink: 0;
}

input[type="checkbox"] {
    border-radius: 6px !important;
    border-width: 2.5px;
}

input[type="checkbox"].form-control {
    width: 20px !important;
    height: 20px !important;
    padding: 0 !important;
    border-radius: 6px !important;
}

input[type="radio"] {
    border-radius: var(--radius-full) !important;
    border-width: 2px;
    width: 20px;
    height: 20px;
    overflow: hidden;
}

/* Checked state - APAC navy-purple gradient */
input[type="checkbox"]:checked,
input[type="radio"]:checked {
    background: var(--gradient-primary);
    border-color: #4429c5;
    overflow: hidden;
}

/* Checkbox checkmark */
input[type="checkbox"]:checked::after {
    content: 'v';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--color-white);
    font-weight: bold;
    font-size: 14px;
    line-height: 1;
}

/* Radio button dot */
input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 6px;
    height: 6px;
    border-radius: var(--radius-full);
    background: var(--color-white);
    z-index: 2;
}

/* ============================================
   PAID EVENT DATE/TIME
   ============================================ */
.theme-feetype-box .col-xs-6 > div .function-date-time {
    display: block;
    font-size: var(--font-sm);
    color: var(--color-gray-600);
    font-weight: 500;
    margin-top: 4px;
    font-style: italic;
}

.theme-feetype-box .col-xs-6 > div .function-date-time span {
    display: inline-block;
}

/* ============================================
   REGISTRATION TYPE - APAC GRADIENT BORDER
   ============================================ */
.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) {
    display: grid;
    grid-template-columns: auto 1fr auto !important;
    gap: 16px !important;
    align-items: center !important;
    padding: 18px 24px !important;
    margin-bottom: 20px !important;
    background: var(--color-white);
    border: 3px solid transparent;
    border-radius: var(--radius-lg);
    transition: all var(--transition-base);
    min-height: auto !important;
    box-shadow: var(--shadow-md);
    position: relative;
}

/* APAC gradient border */
.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"])::before {
    content: '';
    position: absolute;
    top: -3px; left: -3px; right: -3px; bottom: -3px;
    border-radius: var(--radius-lg);
    background: linear-gradient(134deg, #0f1288, #4429c5);
    -webkit-mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    padding: 3px;
    pointer-events: none;
    z-index: 0;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]):hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}

/* Selected state */
.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]:checked) {
    background: linear-gradient(to right, rgba(15, 18, 136, 0.03), rgba(68, 41, 197, 0.04));
    box-shadow: 0 8px 30px rgba(68, 41, 197, 0.2);
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-8 {
    grid-column: 1 !important;
    width: auto !important;
    padding: 0 !important;
    display: flex;
    align-items: center !important;
    gap: 0 !important;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-8 .radio {
    display: flex;
    align-items: center !important;
    gap: 0 !important;
    margin: 0 !important;
    width: auto !important;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-8 input[type="radio"] {
    margin: 0 !important;
    margin-right: 12px !important;
    flex-shrink: 0 !important;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-8 label {
    grid-column: 2 !important;
    margin: 0 !important;
    flex-grow: 0 !important;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-8 label strong {
    color: var(--color-primary);
    font-size: clamp(0.95rem, 1.5vw, 1.125rem);
    font-weight: 700;
    display: block;
    line-height: 1.4;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box {
    grid-column: 3 !important;
    width: auto !important;
    padding: 0 !important;
    text-align: right !important;
    min-width: 200px;
    position: relative;
    z-index: 1;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box .row {
    display: flex;
    gap: 15px;
    margin: 0 !important;
    flex-wrap: nowrap;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box .col-sm-6 {
    padding: 0 !important;
    width: auto !important;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .text-muted {
    font-size: var(--font-xs);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 6px;
    font-weight: 600;
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-amount,
.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-summary {
    font-family: var(--font-heading) !important;
    font-size: 0 !important;
    font-weight: 800;
    color: var(--color-primary);
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-amount::before {
    content: "$" attr(data-amount);
    font-family: var(--font-heading) !important;
    font-size: var(--font-2xl);
    font-weight: 800;
    color: var(--color-primary);
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-summary::before {
    content: "$" attr(data-summary);
    font-family: var(--font-heading) !important;
    font-size: var(--font-2xl);
    font-weight: 800;
    color: var(--color-primary);
}

.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"][disabled]) {
    opacity: 0.6;
    cursor: not-allowed;
}

/* ============================================
   PAID EVENT SESSIONS - DESKTOP (1025px+)
   ============================================ */
@media screen and (min-width: 1025px) {
    .theme-feetype-box {
        display: grid;
        grid-template-columns: auto 1fr auto;
        gap: 16px;
        align-items: start;
        padding: 20px !important;
        margin-bottom: 16px !important;
        background: var(--color-white);
        border: 2px solid var(--color-gray-300);
        border-radius: var(--radius-md);
        transition: all var(--transition-base);
        min-height: auto !important;
    }

    .theme-feetype-box:hover {
        border-color: var(--color-secondary);
        box-shadow: var(--shadow-md);
    }

    .theme-feetype-box .col-sm-2 {
        grid-column: 1;
        width: auto !important;
        padding: 0 !important;
        margin: 0 !important;
        display: flex;
        flex-direction: column;
        gap: 6px;
    }

    .theme-feetype-box .col-sm-2 input[type="checkbox"] {
        margin: 0 !important;
        margin-top: 4px !important;
    }

    .theme-feetype-box .col-xs-6 {
        grid-column: 2;
        width: auto !important;
        padding: 0 !important;
    }

    .theme-feetype-box .col-xs-6 > div {
        display: flex;
        flex-direction: column;
        gap: 6px;
    }

    .theme-feetype-box .col-xs-6 label { margin: 0; }

    .theme-feetype-box .col-xs-6 label strong {
        color: var(--color-primary);
        font-size: var(--font-lg);
        font-weight: 700;
    }

    .theme-feetype-box .theme-box {
        grid-column: 3;
        width: auto !important;
        padding: 0 !important;
        text-align: right !important;
    }

    .theme-feetype-box .theme-box .row {
        display: flex;
        gap: 20px;
        margin: 0 !important;
    }

    .theme-feetype-box .theme-box .col-sm-6 {
        padding: 0 !important;
        width: auto !important;
    }

    .theme-feetype-box .text-muted {
        font-size: var(--font-xs);
        text-transform: uppercase;
        letter-spacing: 0.5px;
        margin-bottom: 4px;
    }

    .theme-feetype-box .fee-amount,
    .theme-feetype-box .fee-summary {
        font-family: var(--font-heading) !important;
        font-size: 0 !important;
        font-weight: 700;
        color: var(--color-primary);
    }

    .theme-feetype-box .fee-amount::before {
        content: "$" attr(data-amount);
        font-family: var(--font-heading) !important;
        font-size: var(--font-xl);
        font-weight: 700;
        color: var(--color-primary);
    }

    .theme-feetype-box .fee-summary::before {
        content: "$" attr(data-summary);
        font-family: var(--font-heading) !important;
        font-size: var(--font-xl);
        font-weight: 700;
        color: var(--color-primary);
    }
}

/* ============================================
   FREE AGENDA SESSIONS - TEAL ACCENT
   ============================================ */
.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) {
    background: var(--color-white);
    border: 2px solid var(--himss-teal);
    border-left: 6px solid var(--himss-teal);
    border-radius: var(--radius-md);
    padding: 18px !important;
    margin-bottom: 16px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    transition: all var(--transition-base);
    position: relative;
    width: 100% !important;
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]).col-sm-6 {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]):hover {
    border-color: var(--himss-teal);
    box-shadow: 0 4px 16px rgba(60, 213, 175, 0.2);
    transform: translateY(-2px);
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) .col-xs-12 {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: 8px 12px;
    align-items: start;
    padding: 0 !important;
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) input[type="checkbox"] {
    grid-column: 1;
    grid-row: 1 / 3;
    margin: 4px 0 0 0 !important;
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) label {
    grid-column: 2;
    grid-row: 1;
    margin: 0 !important;
    padding-right: 60px;
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) .session-label {
    color: var(--color-primary);
    cursor: pointer;
    text-decoration: none;
    font-weight: 700;
    font-size: var(--font-base);
    display: inline-block;
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) .session-label:hover {
    text-decoration: underline;
    color: var(--himss-teal);
}

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) .session-date-time-display {
    grid-column: 2;
    grid-row: 2;
    font-size: var(--font-sm);
    color: var(--color-gray-600);
    margin: 0;
    font-weight: 500;
}

/* ============================================
   SUMMARY SECTION
   ============================================ */
.summary-section, .confirmation-section {
    background: var(--color-gray-50);
    border-radius: var(--radius-xl);
    padding: var(--space-xl);
    margin-bottom: var(--space-xl);
}

.summary-item, .confirmation-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--space-md);
    padding: var(--space-sm) 0;
    border-bottom: 1px solid var(--color-gray-300);
}

.summary-item:last-child, .confirmation-item:last-child {
    border-bottom: none;
    font-weight: 700;
    font-size: var(--font-xl);
    color: var(--color-primary);
}

.summary-heading h3,
.summary-content h3,
.theme-summary-content h3,
.summary-heading h4,
.summary-content h4,
.theme-summary-content h4 {
    border-bottom: none !important;
    padding-bottom: 15px !important;
    margin-bottom: 15px !important;
    position: relative;
}

.summary-heading h3::after,
.summary-content h3::after,
.theme-summary-content h3::after,
.summary-heading h4::after,
.summary-content h4::after,
.theme-summary-content h4::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 120px;
    height: 1px;
    background: var(--gradient-fade);
}

.summary-heading { margin-top: var(--space-xl) !important; }

.summary-content .summary-heading:first-child,
.theme-summary-content .summary-heading:first-child {
    margin-top: 0 !important;
}

/* ============================================
   SUMMARY TOTAL BOX - BLUE GRADIENT
   ============================================ */
.theme-summary {
    background: linear-gradient(135deg, var(--himss-blue) 0%, var(--himss-navy) 100%);
    padding: var(--space-xl);
    border-radius: var(--radius-lg);
    margin-top: var(--space-2xl);
    box-shadow: var(--shadow-lg);
}

.theme-summary .row { display: flex; align-items: center; }

.theme-summary strong {
    color: var(--color-white);
    font-family: var(--font-heading) !important;
}

.theme-summary .col-sm-4.text-right strong,
.theme-summary .col-xs-4.text-right strong {
    font-size: var(--font-xl);
    display: inline-block;
}

.theme-summary .fixed-width-cost-col strong {
    font-size: var(--font-2xl);
    display: inline-block;
}

.theme-summary .col-sm-4.text-right strong::before,
.theme-summary .col-xs-6.text-right strong::before {
    content: none !important;
}

.theme-summary .fixed-width-cost-col.text-right::before {
    content: "$";
    color: var(--color-white);
    font-size: var(--font-base);
    font-weight: 600;
    font-family: var(--font-heading) !important;
    margin-right: 8px;
}

/* ============================================
   PAYMENT SUMMARY BOX
   ============================================ */
.theme-payment-summary {
    background: rgba(84, 192, 232, 0.08);
    padding: var(--space-lg);
    border-radius: var(--radius-md);
    margin: var(--space-md) 0;
    border: 2px solid rgba(84, 192, 232, 0.2);
    box-shadow: var(--shadow-sm);
    width: 100% !important;
    max-width: 100% !important;
}

.theme-payment-summary .row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0 !important;
}

.theme-payment-summary strong {
    color: var(--color-primary);
    font-family: var(--font-heading) !important;
    font-weight: 700;
}

.theme-payment-summary .col-sm-4,
.theme-payment-summary .col-xs-6 { padding: 0 !important; }

.theme-payment-summary .text-right strong { font-size: var(--font-lg); }

.theme-payment-summary .fixed-width-cost-col strong {
    font-size: var(--font-xl);
    color: var(--color-primary);
}

.theme-payment-summary .fixed-width-cost-col.text-right::before {
    content: "$";
    color: var(--color-primary);
    font-size: var(--font-sm);
    font-weight: 600;
    font-family: var(--font-heading) !important;
    margin-right: 6px;
}

.summary-table .col-sm-5.col-xs-12 {
    width: 100% !important;
    max-width: 100% !important;
    flex: 0 0 100% !important;
}

.summary-table .row:has(.theme-payment-summary) { display: block; }

.summary-table .col-sm-7.col-xs-12:has(+ .col-sm-5 .theme-payment-summary) {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: var(--space-md);
}

/* ============================================
   PAYMENT TABLE
   ============================================ */
.payment-panel,
.theme-panel-mini {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: 0;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-gray-300);
    overflow: hidden;
    margin-bottom: var(--space-xl);
}

.table-payment {
    margin: 0 !important;
    width: 100%;
    border-collapse: collapse;
}

.table-payment tbody tr { border: none; }
.table-payment .first-column { display: none; }
.table-payment tbody tr:first-child { display: none; }

.table-payment tbody tr:not(:first-child):not(.header):not(:last-child) {
    background: var(--color-gray-50);
}

.table-payment tbody tr:not(:first-child):not(.header) th,
.table-payment tbody tr:not(:first-child):not(.header) td {
    padding: 16px 24px !important;
    border: none !important;
    font-size: var(--font-sm);
    border-bottom: 1px solid var(--color-gray-200) !important;
}

.table-payment tbody tr:not(:first-child):not(.header) th.nonbold-th {
    font-family: var(--font-body) !important;
    font-weight: 500;
    color: var(--color-gray-800);
    text-align: left;
}

.table-payment tbody tr:not(:first-child):not(.header):not(:nth-child(2)) th.nonbold-th {
    padding-left: 40px !important;
    font-size: var(--font-sm);
    color: var(--color-gray-600);
}

.table-payment tbody tr:not(:first-child):not(.header) td {
    font-family: var(--font-heading) !important;
    font-weight: 600;
    color: var(--color-gray-800);
    font-size: var(--font-base);
    text-align: right;
}

.table-payment tbody tr:nth-child(2) { background: var(--color-white); }

.table-payment tbody tr:nth-child(2) th.nonbold-th {
    font-weight: 700 !important;
    color: var(--color-primary) !important;
    font-size: var(--font-base) !important;
}

.table-payment tbody tr:nth-child(2) td {
    font-weight: 700 !important;
    color: var(--color-primary) !important;
    font-size: var(--font-lg) !important;
}

/* Total row - blue gradient */
.table-payment tbody tr.header {
    background: linear-gradient(135deg, var(--himss-blue) 0%, var(--himss-navy) 100%);
}

.table-payment tbody tr.header th,
.table-payment tbody tr.header td {
    padding: 24px !important;
    border: none !important;
    color: var(--color-white) !important;
}

.table-payment tbody tr.header th {
    font-family: var(--font-heading) !important;
    font-weight: 700;
    font-size: var(--font-lg);
}

.table-payment tbody tr.header td {
    font-family: var(--font-heading) !important;
    font-weight: 800;
    font-size: var(--font-2xl);
    text-align: right;
}

.table-payment tbody tr.header td::before {
    content: "$";
    font-size: var(--font-base);
    font-weight: 600;
    margin-right: 8px;
    color: var(--color-white);
}

.table-payment tbody tr:not(:first-child):not(.header) td::before {
    content: "$";
    font-size: var(--font-xs);
    font-weight: 600;
    opacity: 0.8;
    margin-right: 6px;
    color: currentColor;
}

.table-payment .fixed-width-cost-col { width: auto; }

/* ============================================
   CURRENCY FIX - GLOBAL
   EventsAir hardcodes the € sign directly into
   .fee-amount and .fee-summary elements across ALL
   optional events, add-ons, and registration pages.
   This global rule catches every instance regardless
   of parent wrapper class.
   ============================================ */

/* Step 1: Hide ALL hardcoded € text globally */
.fee-amount,
.fee-summary {
    font-size: 0 !important;
    color: var(--color-primary) !important;
    font-family: var(--font-heading) !important;
    font-weight: 700 !important;
}

/* Step 2: Rewrite with $ using data-amount attribute */
.fee-amount::before {
    content: "$" attr(data-amount) !important;
    font-size: var(--font-xl) !important;
    font-weight: 700 !important;
    font-family: var(--font-heading) !important;
    color: var(--color-primary) !important;
    margin-right: 0 !important;
}

.fee-summary::before {
    content: "$" attr(data-summary) !important;
    font-size: var(--font-xl) !important;
    font-weight: 700 !important;
    font-family: var(--font-heading) !important;
    color: var(--color-primary) !important;
    margin-right: 0 !important;
}

/* ============================================
   LOADING STATES
   ============================================ */
.loading, .spinner {
    display: inline-block;
    width: 40px;
    height: 40px;
    border: 4px solid rgba(68, 41, 197, 0.2);
    border-top-color: #4429c5;
    border-radius: var(--radius-full);
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ============================================
   FOOTER
   ============================================ */
.brand-footer.brand-footer-bg.footer-image {
    background-color: var(--himss-navy) !important;
    background-image: none !important;
    padding: var(--space-3xl) var(--space-lg) var(--space-2xl) var(--space-lg) !important;
    margin-top: var(--space-2xl);
    border-top: 4px solid var(--color-secondary);
    min-height: auto !important;
    position: relative;
}

.brand-footer.brand-footer-bg.footer-image > img {
    display: block;
    max-width: 220px;
    max-height: 56px;
    width: auto;
    height: auto;
    margin: 0 auto var(--space-lg) auto !important;
}

.brand-footer .is-section {
    text-align: center;
    background-color: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
}

.brand-footer .container-fluid {
    padding: 0 !important;
    max-width: 1400px;
    margin: 0 auto !important;
}

.brand-footer header { display: none !important; }

.brand-footer p {
    margin: 8px 0 !important;
    color: var(--color-white) !important;
    font-family: var(--font-body) !important;
    font-size: var(--font-xs) !important;
    line-height: 1.6 !important;
}

.brand-footer hr {
    border: none !important;
    height: 2px !important;
    background-color: var(--color-secondary) !important;
    margin: 16px 0 !important;
    width: 100% !important;
}

.brand-footer p:last-of-type {
    color: var(--color-secondary) !important;
    margin: 12px 0 !important;
}

.brand-footer a {
    color: var(--color-secondary) !important;
    text-decoration: none !important;
    transition: color var(--transition-fast);
}

.brand-footer a:hover {
    color: var(--color-success) !important;
    text-decoration: underline !important;
}

.himss-registration-footer {
    background-color: var(--himss-navy);
    padding: var(--space-2xl) var(--space-lg);
    margin-top: var(--space-2xl);
    text-align: left;
    font-family: var(--font-body);
    border-top: 4px solid var(--color-secondary);
}

.footer-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--space-lg);
}

.footer-logo {
    width: auto;
    max-height: 51px;
    margin-bottom: var(--space-md);
    display: block;
}

.footer-address {
    margin: var(--space-sm) 0;
    color: var(--color-white);
    font-size: var(--font-xs);
    line-height: 1.6;
}

.footer-divider {
    border: none;
    height: 2px;
    background-color: var(--color-secondary);
    margin: var(--space-md) 0;
    width: 100%;
}

.footer-copyright {
    margin: var(--space-sm) 0;
    color: var(--color-secondary);
    font-size: var(--font-xs);
}

/* ============================================
   RESPONSIVE - MOBILE (640px and under)
   ============================================ */
@media screen and (max-width: 640px) {
    .container { padding: var(--space-sm); }

    .form-section, .registration-section, .panel, .card {
        padding: var(--space-md);
        border-radius: var(--radius-md);
    }

    .page-title, h1.page-title {
        font-size: 1.75rem;
        margin-bottom: var(--space-md);
    }

    .form-navigation { grid-template-columns: 1fr; }
    .pricing-grid { grid-template-columns: 1fr; }

    /* Mobile Registration Categories */
    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) {
        display: flex;
        flex-direction: column !important;
        align-items: stretch !important;
        padding: 20px 16px !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-8 {
        display: block;
        width: 100% !important;
        flex: none !important;
        margin-bottom: 16px !important;
        order: 1 !important;
        position: relative !important;
        z-index: 1 !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-8 .radio {
        display: block;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) input[type="radio"] {
        display: inline-block;
        margin-right: 10px !important;
        vertical-align: top !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) label {
        display: inline-block;
        width: calc(100% - 35px) !important;
        vertical-align: top !important;
        margin-bottom: 0 !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) label strong {
        font-size: 0.95rem !important;
        line-height: 1.5 !important;
        word-break: break-word !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box,
    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .col-xs-4.theme-box {
        display: block;
        width: 100% !important;
        flex: none !important;
        text-align: center !important;
        margin: 0 !important;
        padding-top: 16px !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        border-top: 1px solid rgba(224, 224, 224, 0.5) !important;
        order: 2 !important;
        position: relative !important;
        z-index: 1 !important;
        float: none !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box .row {
        display: flex;
        justify-content: center !important;
        gap: 32px !important;
        margin: 0 !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box .col-sm-6,
    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box .col-xs-12 {
        width: auto !important;
        float: none !important;
        padding: 0 !important;
        text-align: center !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .text-muted.small {
        font-size: 10px !important;
        text-transform: uppercase !important;
        margin-bottom: 6px !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-amount,
    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-summary {
        font-size: 1.125rem !important;
        font-weight: 700 !important;
    }

    /* Mobile Discount Code Validation */
    .allow-discount .form-control-feedback { display: none !important; }

    .allow-discount .has-success .form-control-feedback {
        display: block;
        position: relative !important;
        top: auto !important;
        right: auto !important;
        text-align: center !important;
        margin-top: 8px !important;
        font-size: 1.5rem !important;
    }

    .allow-discount .has-error .help-block,
    .allow-discount .error-message {
        text-align: center !important;
        margin-top: 8px !important;
    }

    /* Mobile Paid Events */
    .row.checkbox.form-group.has-feedback.theme-feetype-box input[type="checkbox"][style*="margin-left"] {
        margin-left: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box {
        display: block;
        padding: 20px 16px !important;
        margin-bottom: 20px !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box > .col-sm-2 {
        display: inline-block;
        width: auto !important;
        vertical-align: top !important;
        margin-right: 10px !important;
        margin-bottom: 12px !important;
        padding: 0 !important;
        float: none !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box > .col-sm-2 input[type="checkbox"] {
        margin: 0 !important;
        vertical-align: top !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box > .col-xs-6 {
        display: inline-block;
        width: calc(100% - 45px) !important;
        vertical-align: top !important;
        margin-bottom: 16px !important;
        padding: 0 !important;
        float: none !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box > .col-xs-6 > div { width: 100% !important; }

    .row.checkbox.form-group.has-feedback.theme-feetype-box > .col-xs-6 label {
        width: 100% !important;
        margin: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box > .col-xs-6 label strong {
        font-size: 0.95rem !important;
        line-height: 1.5 !important;
        word-break: break-word !important;
        color: var(--color-primary) !important;
        font-weight: 700 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box > .theme-box.col-xs-4,
    .row.checkbox.form-group.has-feedback.theme-feetype-box > .col-xs-4.theme-box {
        display: block;
        width: 100% !important;
        float: none !important;
        clear: both !important;
        text-align: center !important;
        margin: 0 !important;
        padding: 16px 0 0 0 !important;
        border-top: 1px solid rgba(224, 224, 224, 0.5) !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box .theme-box .row {
        display: flex;
        justify-content: center !important;
        gap: 32px !important;
        margin: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box .theme-box .col-sm-6,
    .row.checkbox.form-group.has-feedback.theme-feetype-box .theme-box .col-xs-12 {
        width: auto !important;
        float: none !important;
        padding: 0 !important;
        text-align: center !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box .text-muted.small {
        font-size: 10px !important;
        text-transform: uppercase !important;
        margin-bottom: 6px !important;
        font-weight: 600 !important;
        letter-spacing: 0.5px !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-amount,
    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-summary {
        font-size: 0 !important;
        font-weight: 800 !important;
        color: var(--color-primary) !important;
        font-family: var(--font-heading) !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-amount::before {
        content: "$" attr(data-amount) !important;
        font-family: var(--font-heading) !important;
        font-size: 1.125rem !important;
        font-weight: 800 !important;
        color: var(--color-primary) !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-summary::before {
        content: "$" attr(data-summary) !important;
        font-family: var(--font-heading) !important;
        font-size: 1.125rem !important;
        font-weight: 800 !important;
        color: var(--color-primary) !important;
    }

    /* Mobile Discount Code for Paid Events */
    .row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code {
        width: 100% !important;
        margin: 0 !important;
        margin-top: 24px !important;
        padding: 0 20px !important;
        display: block;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code .form-group {
        width: 100% !important;
        margin: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code input.form-control {
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Mobile Free Agenda Sessions */
    .form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) { padding: 14px !important; }
    .form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) input[type="checkbox"] { margin-top: 2px !important; }
    .form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) label { padding-right: 50px !important; }
    .form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) .session-label { font-size: 0.95rem !important; }
    .form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"]) .session-date-time-display { font-size: 0.85rem !important; }

    /* Mobile Footer */
    .himss-registration-footer,
    .brand-footer { padding: var(--space-lg) var(--space-md) !important; }

    .footer-logo,
    .brand-footer.brand-footer-bg.footer-image > img {
        max-width: 160px;
        max-height: 42px;
    }

    /* Mobile Payment table */
    .table-payment tbody tr:not(:first-child):not(.header) th,
    .table-payment tbody tr:not(:first-child):not(.header) td {
        padding: 10px 12px !important;
        font-size: 0.85rem !important;
    }

    .table-payment tbody tr.header th,
    .table-payment tbody tr.header td { padding: 16px 12px !important; }
    .table-payment tbody tr.header td { font-size: var(--font-xl) !important; }

    /* Mobile Navbar */
    .navbar.navbar-inverse.navbar-inside-page .btn.btn-default.navbar-btn,
    .navbar.navbar-inverse.navbar-inside-page .theme-btn-primary {
        padding: 8px 18px !important;
        font-size: var(--font-sm) !important;
    }
}

/* Tablets (641px to 1024px) */
@media screen and (min-width: 641px) and (max-width: 1024px) {
    .bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .theme-box .row {
        gap: 12px !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .theme-box .row {
        gap: 12px !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ============================================
   ACCESSIBILITY
   ============================================ */
*:focus-visible {
    outline: 3px solid #4429c5;
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

.sr-only, .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ============================================
   PRINT STYLES
   ============================================ */
@media print {
    .btn, button, .form-navigation, .wizard-navigation { display: none; }

    .form-section, .panel, .card {
        box-shadow: none;
        border: 1px solid var(--color-gray-400);
    }

    .himss-registration-footer,
    .brand-footer { page-break-inside: avoid; }
}

/* ============================================
   FIX: Remove dot from radio containers
   ============================================ */
.bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"])::before,
.bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"])::after {
    display: none !important;
    content: none !important;
}

/* ============================================
   FIX: Registration category alignment - DESKTOP (1025px+)
   ============================================ */
@media screen and (min-width: 1025px) {
    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) {
        display: grid;
        grid-template-columns: auto 1fr auto !important;
        align-items: center !important;
        gap: 16px !important;
        padding: 20px !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) .col-xs-8 {
        grid-column: 1 / 3 !important;
        display: grid;
        grid-template-columns: auto 1fr !important;
        align-items: center !important;
        gap: 12px !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) .col-xs-8 .radio {
        display: contents !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) .col-xs-8 .radio input[type="radio"] {
        grid-column: 1 !important;
        margin: 0 !important;
        flex-shrink: 0 !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) .col-xs-8 .radio label {
        grid-column: 2 !important;
        margin: 0 !important;
        display: flex;
        align-items: center !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) .theme-box {
        grid-column: 3 !important;
        margin: 0 !important;
        flex-shrink: 0 !important;
        width: auto !important;
        padding: 0 !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) .theme-box .row {
        display: flex;
        align-items: center !important;
        margin: 0 !important;
        gap: 20px !important;
    }

    .bottom-padding-10.row.has-feedback:has(input[type="radio"].inv-aware[data-inv-type="Registration"]) .theme-box .col-sm-6 {
        padding: 0 !important;
        width: auto !important;
    }
}

/* ============================================
   FIX: Checkbox events alignment - DESKTOP (1025px+)
   ============================================ */
@media screen and (min-width: 1025px) {
    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) {
        display: grid;
        grid-template-columns: auto 1fr auto !important;
        align-items: center !important;
        gap: 16px !important;
        padding: 20px !important;
        min-height: auto !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .col-sm-2 {
        grid-column: 1 !important;
        display: flex;
        align-items: center !important;
        justify-content: flex-start !important;
        flex-direction: row !important;
        width: auto !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .col-sm-2 input[type="checkbox"] {
        margin: 0 !important;
        flex-shrink: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .col-xs-6 {
        grid-column: 2 !important;
        display: flex;
        align-items: center !important;
        flex: 1 !important;
        width: auto !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .col-xs-6 > div {
        width: 100% !important;
        margin: 0 !important;
        display: flex;
        flex-direction: column !important;
        gap: 4px !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .col-xs-6 label {
        margin: 0 !important;
        display: block;
        line-height: 1.4 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .col-xs-6 label strong {
        margin: 0 !important;
        display: inline-block;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .theme-box {
        grid-column: 3 !important;
        margin-left: 0 !important;
        flex-shrink: 0 !important;
        width: auto !important;
        padding: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .theme-box .row {
        display: flex;
        align-items: center !important;
        margin: 0 !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box:has(input.inv-aware[type="checkbox"]) .visually-hidden {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }
}

/* ============================================
   MODAL STYLING FOR AGENDA SESSIONS
   ============================================ */
#GenericModal .modal-lg .modal-content,
.modal-lg .modal-content {
    padding: 24px !important;
    border: none !important;
    border-radius: 16px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6) !important;
}

#GenericModal .modal-header h3,
.modal-lg .modal-content .modal-header h3 {
    margin-bottom: 24px !important;
    font-family: var(--font-heading) !important;
    color: var(--color-primary) !important;
}

#GenericModal .agenda-details-section1 > div,
.modal-lg .modal-content .agenda-details-section1 > div { margin: 4px 0 !important; }

#GenericModal ul li,
.modal-lg .modal-content ul li { margin-bottom: 1em !important; }

#GenericModal .row .col-sm-3 + .col-sm-9,
.modal-lg .row .col-sm-3 + .col-sm-9 { display: none !important; }

#GenericModal .row .col-sm-3,
.modal-lg .row .col-sm-3 {
    min-height: 100px !important;
    max-width: 100% !important;
    margin-top: 16px !important;
}

#GenericModal .row .col-sm-3 img[style="margin: 0"],
.modal-lg .row .col-sm-3 img[style="margin: 0"] {
    float: left !important;
    padding-right: 8px !important;
    border-radius: 8px !important;
    margin-bottom: 16px !important;
    object-fit: cover !important;
}

#GenericModal .row .col-sm-3 img[style="margin: 0"] + div[class="bold"],
.modal-lg .row .col-sm-3 img[style="margin: 0"] + div[class="bold"] {
    font-family: var(--font-heading) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
}

#GenericModal .row .col-sm-3 > div[class="bold"]:nth-child(1),
.modal-lg .row .col-sm-3 > div[class="bold"]:nth-child(1) {
    margin-left: 100px !important;
    border-left: 1px solid #ccc !important;
    padding-left: 8px !important;
    font-family: var(--font-heading) !important;
    font-size: 18px !important;
    margin-top: -8px !important;
}

#GenericModal .row .col-sm-3 img[style="margin: 0"] + div[class="bold"] + div,
.modal-lg .row .col-sm-3 img[style="margin: 0"] + div[class="bold"] + div {
    font-size: 14px !important;
    line-height: 1.2em !important;
    padding-top: 8px !important;
}

#GenericModal .row .col-sm-3 > div[class="bold"]:nth-child(1) + div,
#GenericModal .row .col-sm-3 > div[class="bold"]:nth-child(1) + div + div,
.modal-lg .row .col-sm-3 > div[class="bold"]:nth-child(1) + div,
.modal-lg .row .col-sm-3 > div[class="bold"]:nth-child(1) + div + div {
    font-size: 14px !important;
    line-height: 1.2em !important;
    padding-top: 8px !important;
    margin-left: 100px !important;
    border-left: 1px solid #ccc !important;
    padding-left: 8px !important;
}

#GenericModal .row .col-sm-3 + .col-sm-9 > h5[style="margin-top: 0"],
.modal-lg .row .col-sm-3 + .col-sm-9 > h5[style="margin-top: 0"] { display: none !important; }

div#GenericModalContent .row > .col-sm-3 .img-responsive:first-child { max-height: 100px !important; }
div#GenericModalContent .row { max-height: fit-content !important; }

@media screen and (min-width: 576px) {
    .modal-lg { margin: 32px 10%; }
    .modal-lg .modal-content { padding: 24px; border-radius: 16px !important; }
    .row .col-sm-3 { flex-basis: 100%; }
}

@media screen and (min-width: 1024px) {
    .modal-lg { margin: 48px 20%; }
    .modal-lg .modal-content { padding: 48px; }
}

/* ============================================
   DISCOUNT CODE SECTION
   ============================================ */
.row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code {
    display: none !important;
}

.row.checkbox.form-group.has-feedback.theme-feetype-box:has(input[type="checkbox"]:checked) + .row.has-feedback.allow-discount.discount-code {
    display: block !important;
}

@media screen and (min-width: 768px) {
    .row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code {
        margin-top: 24px !important;
        margin-bottom: 20px !important;
        padding: 0 24px !important;
        width: 100% !important;
        clear: both !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code .form-group {
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
        max-width: none !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code label {
        text-transform: none !important;
        font-size: var(--font-base) !important;
        font-weight: 500 !important;
        color: var(--color-gray-800) !important;
        margin-bottom: 8px !important;
        display: block !important;
    }

    .row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code input.form-control {
        width: 100% !important;
        max-width: 400px !important;
    }
}

/* ============================================
   CALENDAR SECTION
   ============================================ */
@media screen and (min-width: 768px) {
    #calendar.row {
        display: flex;
        justify-content: center;
        align-items: flex-start;
        gap: var(--space-xl);
        margin: var(--space-2xl) 0;
    }

    #calendar .col-sm-2,
    #calendar .col-xs-6 {
        flex: 0 1 auto;
        max-width: none;
        width: auto;
        text-align: center;
    }

    #calendar a {
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        gap: var(--space-sm);
        text-decoration: none;
        transition: all var(--transition-base);
        padding: var(--space-md);
        border-radius: var(--radius-md);
    }

    #calendar a:hover {
        background: rgba(68, 41, 197, 0.06);
        transform: translateY(-2px);
    }

    #calendar a img {
        width: 48px !important;
        height: 48px !important;
        margin-bottom: var(--space-xs);
    }

    #calendar a p {
        margin: 0 !important;
        white-space: nowrap !important;
        font-size: var(--font-base) !important;
        color: var(--color-primary) !important;
        font-weight: 500 !important;
    }

    #calendar a:hover p { color: #4429c5 !important; }
}

@media screen and (max-width: 767px) {
    #calendar.row {
        display: flex;
        justify-content: center;
        gap: var(--space-md);
        margin: var(--space-lg) 0;
    }

    #calendar .col-xs-6 {
        flex: 0 1 auto;
        width: auto;
        max-width: 45%;
    }

    #calendar a {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-decoration: none;
    }

    #calendar a p {
        font-size: var(--font-sm);
        text-align: center;
        margin-top: var(--space-xs);
    }
}

/* ============================================
   UTILITY CLASSES
   ============================================ */
.flex { display: flex; }
.grid { display: grid; }
.hidden { display: none; }
.gap-sm { gap: var(--space-sm); }
.gap-md { gap: var(--space-md); }
.gap-lg { gap: var(--space-lg); }

/* ============================================
   FIX: Remove white space between progress bar
   and HTML heading component
   ============================================ */
.progress.theme-progress { margin-bottom: 0 !important; }

.progress.theme-progress + .component.modern-component,
.progress.theme-progress + div[data-component-type="NextGen.Online.Components.Client.Html.HtmlComponent"] {
    margin-top: 0 !important;
}

.progress.theme-progress + .component.modern-component form.modern-spacing-3xl,
.progress.theme-progress + div[data-component-type="NextGen.Online.Components.Client.Html.HtmlComponent"] form.modern-spacing-3xl {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

.container-booth {
    margin-top: 0 !important;
    padding-top: 20px !important;
}

.manual-header { margin-top: 0 !important; }
