/* ============================================
   HIMSS26 EUROPE REGISTRATION - FINAL PRODUCTION CSS
   Version 5.53 FINAL | February 2026
   Updates: Removed white space between header image and HTML heading component (fixed page-header margin-bottom)
   ============================================ */

/* 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;
}




[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
   App: HIMSS26 Europe Attendee App / Mobile App
   Goal: Show all keyword tags on each session card,
   wrapped in rows instead of hidden in a single line
   ================================================ */

/* 1. Allow the keyword tag container to grow and be visible */
.css-1kfcngz:has(.css-10isx4t) { overflow: visible !important; flex-grow: 0 !important; align-self: auto !important; height: auto !important; }

/* 2. Make tags sit side by side and wrap to next line when out of space */
.css-1kfcngz:has(.css-10isx4t) .css-4yqwy4 { flex-wrap: wrap !important; flex-direction: row !important; width: 100% !important; }

/* 3. Hide the white gradient fade that was masking hidden tags on the right */
.css-1kfcngz:has(.css-10isx4t) > div[style*="gradient"] { display: none !important; }

/* 4. Stop each individual tag from stretching full width */
.css-10isx4t { align-self: auto !important; width: auto !important; flex-grow: 0 !important; }

/* 5. Allow the card itself to grow in height as tags expand */
.css-12p7far { overflow: visible !important; height: auto !important; }

/* 6. Fix tag layout inside the session detail view (when you open a session) */
div[style="margin: 5px 0"] { display: flex !important; flex-wrap: wrap !important; }

/* 7. Remove red background on keyword tags in session detail view only.
      Targets the exact parent div (margin: 5px 0) that wraps keywords,
      so the Track/Stage tag above it (with its pink/purple background) 
      is completely untouched. Keywords show with border and text only. */
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 - inherit parent color instead */
.fontBlack14, 
.attendees h4, 
.attendeeInfo h4, 
.contactPosition, 
.contactOrganization, 
.contactState, 
.fontBlack12,
.font14,
.sessionInfoItem h4,
.agenda h3,
.agenda h4 {
    color: inherit !important;
}




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

/* Space between session title and Overview */
.css-iz07a1-MuiTypography-root {
    margin-bottom: 12px !important;
}

/* Replace repeating session title with SPEAKER label */
.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;
}

/* Control gap inside each section (between heading and text) */
.css-nen11g-MuiStack-root {
    gap: 6px !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    margin-bottom: 8px !important;
}
/* Add space after Overview/Details text before next heading */
.css-nen11g-MuiStack-root .css-1kyhjjn-MuiTypography-root {
    margin-bottom: 8px !important;
}

/* Remove extra padding on the heading box */
.css-160glkp {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* Remove divider boxes between speaker blocks */
.css-43htc {
    display: none !important;
}

/* Grey divider line on all speaker blocks */
.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;
}

/* ======================================= */
/* RESPONSIVE - ALL                        */
/* ======================================= */
@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;
    }
}

/* Fix bullet point text color in session info screen - mobile app */
#ext-modernSessionInformationScreen-1 ul li {
    color: inherit !important;
    font-size: inherit !important;
    font-family: inherit !important;
    line-height: 1.45 !important;
}


@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;
}

/* ============================================
   MODERN CSS VARIABLES
   ============================================ */
:root {
    /* Brand Colors */
    --himss-navy: #21145f;
    --himss-blue: #1e22aa;
    --himss-cyan: #54c0e8;
    --himss-teal: #3CD5AF;
    --himss-coral: #F15A29;
    --himss-yellow: #FFC72C;
    --gradient-pink: #d444f1;
    --gradient-red: #f04438;
    
    /* Semantic Colors */
    --color-primary: var(--himss-blue);
    --color-secondary: var(--himss-cyan);
    --color-accent: var(--gradient-pink);
    --color-success: var(--himss-teal);
    --color-warning: var(--himss-yellow);
    --color-danger: var(--gradient-red);
    
    /* Gradients */
    --gradient-primary: linear-gradient(134deg, #d444f1, #f04438);
    --gradient-hover: linear-gradient(134deg, #9e2ee4, #c73a33);
    --gradient-title: linear-gradient(90deg, #F15A29 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(84, 192, 232, 0.1);
    --shadow-glow-pink: 0 4px 12px rgba(212, 68, 241, 0.3);
    --shadow-glow-pink-lg: 0 6px 20px rgba(212, 68, 241, 0.5);
    
    /* 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 - FIXED
   ============================================ */
*, *::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 - FIXED
   EXCLUDES .fa classes AND glyphicons to preserve icons
   Form fields (input, textarea, select) excluded to preserve EventsAir defaults
   ============================================ */
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;
}

/* Ensure glyphicons use their proper font */
.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
   Fixes bullet point spacing and text readability
   ============================================ */
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
   ============================================ */
.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);
}

/* ============================================
   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;
}

/* ============================================
   FORM CONTROLS - REVERT TO EVENTSAIR DEFAULTS
   All custom form field styling removed
   SlimSelect dropdowns reverted to default - no custom height/styling
   ============================================ */

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

/* Remove any slide/fade animations on dropdown open */
.select2-dropdown {
    animation: none !important;
    transition: none !important;
}

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

/* ============================================
   BUTTONS - PREMIUM GRADIENT STYLE
   ============================================ */
.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 - Magenta Gradient */
.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-pink);
}

/* 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.3), 
        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-pink-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 - Gradient */
.btn-default {
    background: var(--gradient-primary) !important;
    color: var(--color-white) !important;
    box-shadow: var(--shadow-glow-pink) !important;
    border: none !important;
}

.btn-default:hover {
    background: var(--gradient-hover) !important;
    box-shadow: var(--shadow-glow-pink-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);
}

/* Selected badge */
.pricing-option.selected::after {
    content: '✓';
    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;
}

/* Close button positioned in top corner */
.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 - MAGENTA 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;
}

/* Animated shimmer on progress bar */
.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 - MAGENTA GRADIENT
   ============================================ */
.progress.theme-progress {
    height: 15pt !important;
    background: var(--color-gray-100) !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    margin-bottom: 15pt !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;
}

/* Add shimmer to EventsAir progress bar - CONTAINED INSIDE */
.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;
}

/* Add percentage number inside progress bar - HIDE AT 0% */
.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;
}

/* Hide percentage when at 0% */
.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 - DISTINCT DESIGNS
   UPDATED: Radio button perfectly centered with better alignment
   ============================================ */
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;
}

/* Checkboxes - MORE SQUARE with rounded corners */
input[type="checkbox"] {
    border-radius: 6px !important;
    border-width: 2.5px;
}

/* Fix for checkboxes with form-control class */
input[type="checkbox"].form-control {
    width: 20px !important;
    height: 20px !important;
    padding: 0 !important;
    border-radius: 6px !important;
}

/* Radio buttons - CIRCULAR - BETTER CENTERED */
input[type="radio"] {
    border-radius: var(--radius-full) !important;
    border-width: 2px;
    width: 20px;
    height: 20px;
    overflow: hidden;
}

/* Checked state - Magenta gradient */
input[type="checkbox"]:checked, 
input[type="radio"]:checked {
    background: var(--gradient-primary);
    border-color: var(--gradient-pink);
    overflow: hidden;
}

/* Checkbox checkmark - BOLD */
input[type="checkbox"]:checked::after {
    content: '✓';
    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 - PERFECTLY CENTERED - SMALLER */
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 - POSITIONED UNDER TITLE
   UPDATED: Show date under the event title
   ============================================ */
.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 - GRADIENT BORDER + CENTERED TEXT
   Gradient border with centered label text - FIXED ALIGNMENT
   ============================================ */
.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;
}

/* Gradient border using pseudo-element - DOT FIX */
.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, #d444f1, #f04438);
    -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;
}

/* Hover effect */
.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 - HIGHLIGHTED */
.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]:checked) {
    background: linear-gradient(to right, rgba(212, 68, 241, 0.03), rgba(240, 68, 56, 0.03));
    box-shadow: 0 8px 30px rgba(212, 68, 241, 0.25);
}

/* Radio button column - FIXED */
.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;
}

/* Label column - FIXED to span middle */
.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;
}

/* OPTIMIZED font sizing for long text - responsive and readable */
.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;
}

/* Price column */
.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: var(--font-2xl);
    font-weight: 800;
    color: var(--color-primary);
}

/* Fix EUR symbol to match price font */
.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-amount::before,
.bottom-padding-10.row.has-feedback:has(input[type="radio"][data-inv-type="Registration"]) .fee-summary::before {
    content: "€";
    font-family: var(--font-heading) !important;
    margin-right: 4px;
}

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

/* ============================================
   PAID EVENT SESSIONS - ENHANCED WITH DATE/TIME
   DESKTOP ONLY - 1025px and above
   ============================================ */
@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: var(--font-xl);
    font-weight: 700;
    color: var(--color-primary);
}
}

/* ============================================
   FREE AGENDA SESSIONS - UNIQUE STYLING
   ============================================ */
.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;
}

/* Ensure parent container doesn't restrict width */
.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;
}


/* ============================================
   FREE BADGE - TOGGLE SECTION

.form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"])::after {
    content: 'FREE';
    position: absolute;
    top: 12px;
    right: 12px;
    background: var(--himss-teal);
    color: var(--color-white);
    font-size: var(--font-xs);
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 12px;
    letter-spacing: 0.5px;
}

============================================ */

.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);
}

/* Gradient divider effect */
.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 DESIGN
   Enhanced version with proper EUR alignment
   ============================================ */
.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;
}

/* Align Total text and amount properly */
.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;
}

/* Remove the ::before EUR - we'll add it properly */
.theme-summary .col-sm-4.text-right strong::before,
.theme-summary .col-xs-6.text-right strong::before {
    content: none !important;
}

/* Add EUR in white, properly formatted */
.theme-summary .fixed-width-cost-col.text-right::before {
    content: "EUR ";
    color: var(--color-white);
    font-size: var(--font-base);
    font-weight: 600;
    opacity: 1;
    font-family: var(--font-heading) !important;
    margin-right: 8px;
}

/* ============================================
   PAYMENT SUMMARY BOX - LIGHTER VERSION
   For paid events on summary page
   ============================================ */
.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);
}

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

/* Make payment summary boxes full width */
.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);
}

/* ============================================
   SIMPLIFIED PAYMENT TABLE (PAYMENT PAGE)
   Modern design with itemized breakdown
   ============================================ */
.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;
}

/* Hide first column and currency row */
.table-payment .first-column {
    display: none;
}

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

/* Show all payment items (Registration + Paid Events) */
.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;
}

/* Indent paid event items */
.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;
}

/* Style for Registration Total row (first item) */
.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 Amount Due 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;
}

/* Add EUR to the total in white */
.table-payment tbody tr.header td::before {
    content: "EUR ";
    font-size: var(--font-base);
    font-weight: 600;
    opacity: 1;
    margin-right: 8px;
    color: var(--color-white);
}

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

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

/* ============================================
   LOADING STATES
   ============================================ */
.loading, .spinner {
    display: inline-block;
    width: 40px;
    height: 40px;
    border: 4px solid rgba(84, 192, 232, 0.3);
    border-top-color: var(--color-secondary);
    border-radius: var(--radius-full);
    animation: spin 1s linear infinite;
}

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

/* ============================================
   FOOTER - HIMSS CUSTOM 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;
}

.brand-footer .is-section {
    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 DESIGN - MOBILE FIRST
   ============================================ */

/* Mobile phones (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/TABLET: Registration Categories
       KEEP gradient border and make sure prices stay inside
       ============================================ */
    
    /* DON'T remove the gradient styling - just adjust layout to stack vertically */
    .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;
        /* Keep gradient border - don't override these */
        /* background, border, border-radius, box-shadow from desktop stay */
    }
    
    /* Top section - Radio + Label takes full width */
    .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;
    }
    
    /* Price section - STAYS INSIDE gradient border */
    .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 - Fix positioning
       ============================================ */
    
    /* Hide the feedback icon when field is empty or invalid */
    .allow-discount .form-control-feedback {
        display: none !important;
    }
    
    /* Only show validation feedback when valid */
    .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;
    }
    
    /* Error message - center below field */
    .allow-discount .has-error .help-block,
    .allow-discount .error-message {
        text-align: center !important;
        margin-top: 8px !important;
    }
    
    /* ============================================
       MOBILE: Paid Events - COMPLETE FIX
       Full specificity to override desktop grid
       Checkbox inline with title, prices below, brand colors
       ============================================ */
    
    /* Override the inline style margin-left on checkbox */
    .row.checkbox.form-group.has-feedback.theme-feetype-box input[type="checkbox"][style*="margin-left"] {
        margin-left: 0 !important;
    }
    
    /* Container - simple block, keep gradient border from desktop */
    .row.checkbox.form-group.has-feedback.theme-feetype-box {
        display: block;
        padding: 20px 16px !important;
        margin-bottom: 20px !important;
        /* gradient border, background, etc. stay from desktop */
    }
    
    /* Checkbox column - inline-block on the left */
    .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;
    }
    
    /* Label column - inline-block on the right, takes remaining width */
    .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;
    }
    
    /* Event title - BLUE like registration */
    .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;
    }
    
    /* Price box - full width below, centered */
    .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;
    }
    
    /* AMOUNT / TOTAL labels */
    .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;
    }
    
    /* Price amounts - BLUE with brand font like registration */
    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-amount,
    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-summary {
        font-size: 1.125rem !important;
        font-weight: 800 !important;
        color: var(--color-primary) !important;
        font-family: var(--font-heading) !important;
    }
    
    /* EUR symbol with brand font - match registration */
    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-amount::before,
    .row.checkbox.form-group.has-feedback.theme-feetype-box .fee-summary::before {
        content: "€" !important;
        font-family: var(--font-heading) !important;
        margin-right: 4px !important;
    }
    
    /* ============================================
       MOBILE: Discount Code for Paid Events
       Style to match registration discount codes
       ============================================ */
    
    /* Discount code container for paid events - full width, proper spacing from edges and paid event */
    .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;
    }
    
    /* Discount code input field */
    .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: Paid Event Sessions - REMOVED DUPLICATE
       The section above handles everything
       ============================================ */
    
    /* Free Agenda Sessions - Mobile */
    .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;
    }
    
    .form-group.has-feedback:has(.inv-aware[data-inv-type="Agenda"])::after {
        top: 8px;
        right: 8px;
        font-size: 9px;
        padding: 3px 8px;
    }
    
    /* Footer - Mobile */
    .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;
    }
    
    /* Payment table - Mobile */
    .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;
    }
}

/* ============================================
   DESKTOP: Discount Code for Paid Events - REMOVED
   Now handled by the updated section at the end of the file
   ============================================ */

/* 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 var(--color-secondary);
    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 magenta dot from radio containers
   Only target container pseudo-elements, not radio buttons
   ULTRA SPECIFIC: Only affects registration type radio buttons
   ============================================ */
.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: Align registration category with price headers
   ULTRA SPECIFIC: Only targets registration type radio button rows
   DESKTOP ONLY - 1025px and above (true desktop screens)
   ============================================ */
@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: Align checkbox events with price boxes - ULTRA SPECIFIC
   Only targets checkbox events with theme-feetype-box AND has inv-aware checkbox
   DESKTOP ONLY - 1025px and above
   ============================================ */
@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;
    margin-top: 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;
}

/* Hide redundant session titles in list of speakers */
#GenericModal .row .col-sm-3 + .col-sm-9,
.modal-lg .row .col-sm-3 + .col-sm-9 {
    display: none !important;
}

/* Ensure speaker details can go full width */
#GenericModal .row .col-sm-3,
.modal-lg .row .col-sm-3 {
    min-height: 100px !important;
    max-width: 100% !important;
    margin-top: 16px !important;
}

/* Speaker pics */
#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;
}

/* Speaker names */
#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;
}

/* Speaker name but missing speaker pic */
#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;
}

/* Speaker details */
#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;
}

/* Speaker details where pic is missing */
#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;
}

/* Repeated session titles */
#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;
}

/* Modal responsive */
@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 - DESKTOP FIX
   Hide until checkbox checked, align with paid event container
   ============================================ */

/* Hide discount code by default - EventsAir shows it when checkbox is checked */
.row.checkbox.form-group.has-feedback.theme-feetype-box + .row.has-feedback.allow-discount.discount-code {
    display: none !important;
}

/* Show discount code when parent checkbox is checked */
.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) {
    /* Discount code row for paid events - more space from paid event box */
    .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;
    }
    
    /* Discount code form group - match paid event width */
    .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;
    }
    
    /* Discount code label - normal case, not uppercase */
    .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;
    }
    
    /* Discount code input field - revert to EventsAir default behavior */
    .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;
        /* Remove custom styling to allow EventsAir defaults */
    }
}

/* ============================================
   CALENDAR SECTION - DESKTOP FIX
   Prevent text wrapping on "Add to Outlook Calendar" and "Add to Google Calendar"
   ============================================ */
@media screen and (min-width: 768px) {
    /* Calendar row container */
    #calendar.row {
        display: flex;
        justify-content: center;
        align-items: flex-start;
        gap: var(--space-xl);
        margin: var(--space-2xl) 0;
    }

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

    /* Calendar links */
    #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(84, 192, 232, 0.1);
        transform: translateY(-2px);
    }

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

    /* Calendar text - NO WRAPPING */
    #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: var(--gradient-pink) !important;
    }
}

/* Mobile calendar - keep existing mobile-friendly layout */
@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
   ============================================ */
/* Target the progress bar wrapper */
.progress.theme-progress {
    margin-bottom: 0 !important;
}

/* Target the HTML component that comes right after progress bar */
.progress.theme-progress + .component.modern-component,
.progress.theme-progress + div[data-component-type="NextGen.Online.Components.Client.Html.HtmlComponent"] {
    margin-top: 0 !important;
}

/* Remove spacing from the form inside the HTML component */
.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;
}

/* Remove spacing from the manual header container */
.container-booth {
    margin-top: 0 !important;
    padding-top: 20px !important;
}

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

