/* ==========================================================================
   ISIE 2027 - GLOBAL DESIGN SYSTEM V3
   White background / unified academic premium style
   Single canonical card model across the entire website
   ========================================================================== */

/* ==========================================================================
   1. DESIGN TOKENS
   ========================================================================== */

:root {
  /* Brand palette */
  --isie-primary-900: #0f2f5f;
  --isie-primary-800: #123b78;
  --isie-primary-700: #184d96;
  --isie-primary-600: #1f66bc;
  --isie-primary-500: #2e7dd1;

  --isie-accent-700: #d67d12;
  --isie-accent-600: #e58a17;
  --isie-accent-500: #f0a43a;
  --isie-accent-100: #fff4e3;

  /* Neutral palette */
  --isie-bg: #ffffff;
  --isie-surface: #ffffff;
  --isie-surface-soft: #f8fbff;
  --isie-surface-muted: #fbfcfe;

  --isie-text-strong: #17365f;
  --isie-text: #26384d;
  --isie-text-muted: #66758a;
  --isie-text-soft: #8b98aa;

  --isie-border-strong: #c7d6e7;
  --isie-border: #d9e4ef;
  --isie-border-soft: #eaf0f6;

  /* Semantic */
  --isie-info-bg: #f3f8ff;
  --isie-success-bg: #f2f9f4;
  --isie-warning-bg: #fff8ec;
  --isie-danger-bg: #fff2f2;

  --isie-info-text: #174b90;
  --isie-success-text: #1d6b42;
  --isie-warning-text: #9a6100;
  --isie-danger-text: #9c2f2f;

  /* Generic */
  --isie-white: #ffffff;
  --isie-black: #101820;

  /* Typography */
  --isie-font-sans: "Inter", "Segoe UI", "Helvetica Neue", Arial, sans-serif;

  --isie-fs-900: clamp(2.1rem, 2vw + 1.4rem, 3rem);
  --isie-fs-800: clamp(1.8rem, 1.4vw + 1.2rem, 2.4rem);
  --isie-fs-700: clamp(1.45rem, 0.9vw + 1.1rem, 1.9rem);
  --isie-fs-600: 1.25rem;
  --isie-fs-500: 1.06rem;
  --isie-fs-400: 0.98rem;
  --isie-fs-300: 0.9rem;
  --isie-fs-200: 0.82rem;

  --isie-lh-tight: 1.18;
  --isie-lh-title: 1.25;
  --isie-lh-base: 1.72;
  --isie-lh-relaxed: 1.85;

  /* Spacing */
  --isie-space-1: 0.25rem;
  --isie-space-2: 0.5rem;
  --isie-space-3: 0.75rem;
  --isie-space-4: 1rem;
  --isie-space-5: 1.5rem;
  --isie-space-6: 2rem;
  --isie-space-7: 2.5rem;
  --isie-space-8: 3rem;
  --isie-space-9: 4rem;

  /* Radius */
  --isie-radius-xs: 8px;
  --isie-radius-sm: 10px;
  --isie-radius-md: 14px;
  --isie-radius-lg: 18px;
  --isie-radius-xl: 24px;
  --isie-radius-pill: 999px;

  /* Shadows */
  --isie-shadow-sm: 0 4px 14px rgba(18, 59, 120, 0.045);
  --isie-shadow-md: 0 8px 24px rgba(18, 59, 120, 0.07);
  --isie-shadow-lg: 0 14px 34px rgba(18, 59, 120, 0.1);

  /* Layout */
  --isie-max-width: 1200px;
  --isie-max-width-narrow: 940px;

  /* Motion */
  --isie-transition-fast: 0.18s ease;
  --isie-transition-base: 0.24s ease;
}

/* ==========================================================================
   2. BASE / RESET
   ========================================================================== */

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--isie-font-sans);
  color: var(--isie-text);
  background: var(--isie-bg);
  line-height: var(--isie-lh-base);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--isie-primary-700);
  text-decoration: none;
  transition:
    color var(--isie-transition-fast),
    background var(--isie-transition-fast),
    border-color var(--isie-transition-fast),
    box-shadow var(--isie-transition-fast),
    transform var(--isie-transition-fast);
}

a:hover,
a:focus {
  color: var(--isie-primary-800);
}

p,
ul,
ol {
  margin-top: 0;
  margin-bottom: 1rem;
}

ul,
ol {
  padding-left: 1.2rem;
}

strong {
  color: var(--isie-text-strong);
  font-weight: 700;
}

hr {
  border: 0;
  border-top: 1px solid var(--isie-border-soft);
  margin: var(--isie-space-6) 0;
}
/* ==========================================================================
   3. PAGE SHELL
   ========================================================================== */

.isie-page {
  color: var(--isie-text);
  background: var(--isie-bg);
}

.isie-container {
  width: min(100% - 2rem, var(--isie-max-width));
  margin-inline: auto;
}

.isie-container--narrow {
  width: min(100% - 2rem, var(--isie-max-width-narrow));
  margin-inline: auto;
}

.isie-section {
  margin-bottom: var(--isie-space-8);
}

.isie-section:last-child {
  margin-bottom: 0;
}

.isie-stack {
  display: grid;
  gap: var(--isie-space-5);
}

.isie-stack--sm {
  gap: var(--isie-space-3);
}

.isie-stack--lg {
  gap: var(--isie-space-6);
}

.isie-grid {
  display: grid;
  gap: var(--isie-space-5);
}

.isie-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.isie-grid--3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.isie-grid--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.isie-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(280px, 0.9fr);
  gap: var(--isie-space-6);
  align-items: start;
}

.isie-sidebar {
  display: grid;
  gap: var(--isie-space-4);
}

/* ==========================================================================
   4. TYPOGRAPHY SYSTEM
   ========================================================================== */

.isie-page-title {
  margin: 0 0 var(--isie-space-4);
  font-size: var(--isie-fs-900);
  line-height: var(--isie-lh-tight);
  font-weight: 800;
  color: var(--isie-text-strong);
  letter-spacing: -0.02em;
  text-align: center;
}

.isie-page-subtitle {
  margin: 0 auto var(--isie-space-5);
  max-width: 900px;
  font-size: var(--isie-fs-500);
  line-height: var(--isie-lh-relaxed);
  color: var(--isie-text-muted);
  text-align: center;
}

.isie-section-title {
  margin: 0 0 var(--isie-space-3);
  font-size: var(--isie-fs-700);
  line-height: var(--isie-lh-title);
  font-weight: 800;
  color: var(--isie-text-strong);
  letter-spacing: -0.015em;
}

.isie-section-title::after {
  content: "";
  display: block;
  width: 56px;
  height: 3px;
  margin-top: 0.5rem;
  border-radius: var(--isie-radius-pill);
  background: var(--isie-accent-600);
}

.isie-block-title {
  margin: 0 0 var(--isie-space-2);
  font-size: var(--isie-fs-500);
  line-height: 1.35;
  font-weight: 800;
  color: var(--isie-text-strong);
}

.isie-subtitle {
  margin: 0 0 var(--isie-space-2);
  font-size: var(--isie-fs-300);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--isie-text-muted);
}

.isie-lead {
  font-size: var(--isie-fs-400);
  line-height: var(--isie-lh-relaxed);
  color: var(--isie-text-muted);
}

.isie-text-muted {
  color: var(--isie-text-muted);
}

.isie-meta {
  font-size: var(--isie-fs-300);
  color: var(--isie-text-soft);
}

.isie-highlight {
  color: var(--isie-accent-600);
  font-weight: 700;
}

/* ==========================================================================
   5. HERO / BANNER
   ========================================================================== */

.isie-hero {
  display: grid;
  gap: var(--isie-space-5);
}

.isie-hero__media {
  overflow: hidden;
  border-radius: var(--isie-radius-lg);
  box-shadow: var(--isie-shadow-md);
}

.isie-hero__image {
  width: 100%;
  object-fit: cover;
}

.isie-hero__body {
  text-align: center;
}

.isie-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  justify-content: center;
  align-items: center;
}

/* ==========================================================================
   6. PILLS / TAGS
   ========================================================================== */

.isie-pill,
.isie-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 40px;
  padding: 0.55rem 0.95rem;
  border-radius: var(--isie-radius-pill);
  font-size: var(--isie-fs-300);
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}

.isie-pill--primary {
  background: var(--isie-primary-900);
  color: var(--isie-white);
  box-shadow: var(--isie-shadow-sm);
}

.isie-pill--accent {
  background: var(--isie-accent-600);
  color: var(--isie-white);
  box-shadow: var(--isie-shadow-sm);
}

.isie-pill--soft {
  background: var(--isie-surface-soft);
  color: var(--isie-primary-800);
  border: 1px solid var(--isie-border);
}

.isie-tag {
  min-height: auto;
  padding: 0.28rem 0.6rem;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.isie-tag--programme {
  background: #e6f6ed;
  color: #16734f;
}

.isie-tag--deadline {
  background: var(--isie-accent-100);
  color: var(--isie-warning-text);
}

.isie-tag--website {
  background: #eef5ff;
  color: var(--isie-info-text);
}

/* ==========================================================================
   7. BUTTONS
   ========================================================================== */

.isie-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  min-height: 44px;
  padding: 0.72rem 1.15rem;
  border-radius: var(--isie-radius-sm);
  border: 1px solid transparent;
  font-size: var(--isie-fs-300);
  font-weight: 800;
  line-height: 1.2;
  text-decoration: none;
  cursor: pointer;
  transition:
    transform var(--isie-transition-fast),
    box-shadow var(--isie-transition-fast),
    background var(--isie-transition-fast),
    color var(--isie-transition-fast),
    border-color var(--isie-transition-fast);
}

.isie-btn:hover,
.isie-btn:focus {
  transform: translateY(-1px);
}

.isie-btn--primary {
  background: var(--isie-primary-600);
  color: var(--isie-white);
  box-shadow: var(--isie-shadow-sm);
}

.isie-btn--primary:hover,
.isie-btn--primary:focus {
  background: var(--isie-primary-700);
  color: var(--isie-white);
}

.isie-btn--secondary {
  background: var(--isie-white);
  color: var(--isie-primary-800);
  border-color: var(--isie-border);
}

.isie-btn--secondary:hover,
.isie-btn--secondary:focus {
  border-color: var(--isie-border-strong);
  box-shadow: var(--isie-shadow-sm);
}

.isie-btn--ghost {
  background: transparent;
  color: var(--isie-primary-700);
  border-color: var(--isie-border);
}

.isie-btn--ghost:hover,
.isie-btn--ghost:focus {
  background: var(--isie-surface-soft);
}

.isie-btn--sm {
  min-height: 38px;
  padding: 0.55rem 0.9rem;
  font-size: var(--isie-fs-200);
}

.isie-btn--block {
  width: 100%;
}

/* ==========================================================================
   8. CARDS — CANONICAL MODEL
   Reference: Organising Committee / Conference Leadership cards
   ========================================================================== */

.isie-card {
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: 16px;
  box-shadow: 0 4px 14px rgba(18, 59, 120, 0.045);
  padding: 1rem;
}

.isie-card--soft {
  background: var(--isie-surface);
}

.isie-card--accent {
  background: var(--isie-surface);
  color: var(--isie-text);
  border: 1px solid var(--isie-border);
  box-shadow: 0 4px 14px rgba(18, 59, 120, 0.045);
}

.isie-card--accent .isie-block-title,
.isie-card--accent .isie-section-title,
.isie-card--accent .isie-lead,
.isie-card--accent .isie-meta,
.isie-card--accent p,
.isie-card--accent li,
.isie-card--accent strong {
  color: inherit;
}

.isie-card--accent .isie-section-title::after {
  background: var(--isie-accent-600);
}

.isie-card--compact {
  padding: 0.9rem;
}

.isie-card--notice {
  border-left: 4px solid var(--isie-accent-600);
}

.isie-card--border-strong {
  border-color: var(--isie-border-strong);
}

/* ==========================================================================
   8B. CANONICAL CARD INTERNAL STRUCTURE
   ========================================================================== */

.isie-card-row {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 1rem;
  align-items: center;
}

.isie-card-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  background: #eef3f9;
  border: 2px solid #c9d5e5;
  display: block;
}

.isie-card-body {
  min-width: 0;
}

.isie-card-title {
  margin: 0 0 0.2rem;
  font-size: 1rem;
  line-height: 1.2;
  font-weight: 800;
  color: var(--isie-primary-800);
  text-transform: uppercase;
}

.isie-card-subtitle {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.45;
  color: var(--isie-text-muted);
}

.isie-card-meta {
  margin-top: 0.3rem;
  font-size: var(--isie-fs-300);
  color: var(--isie-text-soft);
}

.isie-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.55rem;
}

.isie-card-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0.28rem 0.7rem;
  border-radius: 999px;
  border: 1px solid var(--isie-border-strong);
  background: #eef4fb;
  color: var(--isie-primary-700);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
}

.isie-card-chip:hover,
.isie-card-chip:focus {
  background: #e6eef9;
  color: var(--isie-primary-800);
}
/* ==========================================================================
   CANONICAL CARD VARIANT — NO AVATAR
   ========================================================================== */

.isie-card--no-avatar {
  padding: 1rem 1rem 0.95rem;
}

.isie-card--no-avatar .isie-card-row {
  display: block;
}

.isie-card--no-avatar .isie-card-body {
  min-width: 0;
}

.isie-card--no-avatar .isie-card-title {
  margin: 0 0 0.28rem;
  font-size: 0.98rem;
  line-height: 1.22;
  font-weight: 800;
  color: var(--isie-primary-800);
  text-transform: uppercase;
}

.isie-card--no-avatar .isie-card-subtitle {
  margin: 0 0 0.55rem;
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--isie-text-muted);
}

.isie-card--no-avatar .isie-card-meta {
  margin: 0.18rem 0 0;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--isie-text);
}

.isie-card--no-avatar .isie-card-meta + .isie-card-meta {
  margin-top: 0.28rem;
}

/* ==========================================================================
   CARD GRIDS FOLLOW CONTENT HEIGHT
   ========================================================================== */

.isie-grid,
.isie-track-grid {
  align-items: start;
}

.isie-group-stack {
  align-items: start;
}
/* ==========================================================================
   TECHNICAL TRACK CHAIRS - LAYOUT ONLY
   ========================================================================== */

.isie-track-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--isie-space-5);
  align-items: start;
}

.isie-track-grid > .isie-group-panel {
  display: inline-block;
  width: 100%;
  margin: 0 0 var(--isie-space-5);
  break-inside: avoid;
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  vertical-align: top;
}

/* ==========================================================================
   TECHNICAL TRACK CHAIRS - TWO MANUAL COLUMNS
   Stable layout without masonry gaps
   ========================================================================== */

.isie-track-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--isie-space-5);
  align-items: start;
}

.isie-track-column {
  display: grid;
  gap: var(--isie-space-5);
  align-content: start;
}



.isie-group-panel {
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: 18px;
  padding: 1rem;
  box-shadow: 0 4px 14px rgba(18, 59, 120, 0.035);
  position: relative;
}

.isie-group-panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  border-radius: 18px 18px 0 0;
  background: var(--isie-primary-600);
}

.isie-group-panel--orange::before {
  background: var(--isie-accent-600);
}

.isie-group-header {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.9rem;
}

.isie-group-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #edf4ff;
  border: 1px solid var(--isie-border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--isie-primary-700);
  font-size: 0.88rem;
  font-weight: 800;
  flex: 0 0 auto;
}

.isie-group-title {
  margin: 0;
  font-size: 1.18rem;
  line-height: 1.25;
  font-weight: 800;
  color: var(--isie-text-strong);
}

.isie-group-stack {
  display: grid;
  gap: 0.75rem;
}

@media (max-width: 1100px) {
  .isie-track-grid {
    grid-template-columns: 1fr;
  }
}


@media (max-width: 680px) {
  .isie-card--no-avatar .isie-card-row {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

@media (max-width: 1100px) {
  .isie-track-columns {
    grid-template-columns: 1fr;
  }
}
/* ==========================================================================
   9. PANELS / SIDEBAR
   ========================================================================== */

.isie-panel {
  background: var(--isie-surface-soft);
  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-md);
  padding: var(--isie-space-4);
  box-shadow: var(--isie-shadow-sm);
}

.isie-panel-title {
  margin: 0 0 var(--isie-space-3);
  font-size: var(--isie-fs-300);
  font-weight: 800;
  color: var(--isie-text-strong);
}

.isie-panel .isie-btn,
.isie-panel .isie-link-card {
  margin-top: 0.35rem;
}

/* ==========================================================================
   10. LINK CARDS / QUICK LINKS
   ========================================================================== */

.isie-link-list {
  display: grid;
  gap: 0.7rem;
}

.isie-link-card {
  display: block;
  background: var(--isie-surface);
  color: var(--isie-primary-800);
  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-sm);
  padding: 0.82rem 0.95rem;
  font-size: var(--isie-fs-300);
  font-weight: 800;
  line-height: 1.35;
}

.isie-link-card:hover,
.isie-link-card:focus {
  background: var(--isie-info-bg);
  border-color: var(--isie-border-strong);
  color: var(--isie-primary-900);
}

/* ==========================================================================
   11. COUNTDOWN
   ========================================================================== */

.isie-countdown {
  display: grid;
  gap: var(--isie-space-3);
}

.isie-countdown-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
}

.isie-countdown-item {
  background: var(--isie-primary-600);
  color: var(--isie-white);
  border-radius: var(--isie-radius-sm);
  text-align: center;
  padding: 0.7rem 0.35rem;
  box-shadow: var(--isie-shadow-sm);
}

.isie-countdown-value {
  display: block;
  font-size: 1.15rem;
  line-height: 1;
  font-weight: 800;
  margin-bottom: 0.2rem;
}

.isie-countdown-label {
  display: block;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  opacity: 0.95;
}

/* ==========================================================================
   12. DEADLINES / DATE LISTS
   ========================================================================== */

.isie-deadline-list {
  display: grid;
  gap: 0.95rem;
}

.isie-deadline-item {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.8rem 0;
  border-bottom: 1px solid var(--isie-border-soft);
}

.isie-deadline-item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.isie-deadline-label {
  color: var(--isie-text);
  font-size: var(--isie-fs-300);
  font-weight: 600;
}

.isie-deadline-date {
  color: var(--isie-accent-600);
  font-size: var(--isie-fs-300);
  font-weight: 800;
  text-align: right;
  white-space: nowrap;
}

/* ==========================================================================
   13. BASIC LISTS
   ========================================================================== */

.isie-list {
  margin: 0;
  padding-left: 1rem;
}

.isie-list li {
  margin-bottom: 0.55rem;
}

.isie-list--clean {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.isie-list--clean li {
  margin-bottom: 0.7rem;
}

.isie-list--two-cols {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0 2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.isie-list--two-cols li {
  position: relative;
  padding-left: 1rem;
  margin-bottom: 0.6rem;
}

.isie-list--two-cols li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62rem;
  width: 5px;
  height: 5px;
  border-radius: var(--isie-radius-pill);
  background: var(--isie-primary-600);
}

/* ==========================================================================
   14. STATS
   ========================================================================== */

.isie-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.isie-stat {
  background: var(--isie-surface-soft);
  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-md);
  padding: 1rem;
  text-align: center;
}

.isie-stat-value {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--isie-primary-800);
  font-size: 1.55rem;
  font-weight: 800;
  line-height: 1.1;
}

.isie-stat-label {
  display: block;
  color: var(--isie-text-muted);
  font-size: var(--isie-fs-300);
  line-height: 1.45;
}

/* ==========================================================================
   15. PERSON / COMMITTEE CARDS
   Backward-compatible aliases to the canonical card model
   ========================================================================== */

.isie-person {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 1rem;
  align-items: center;
}

.isie-person-photo {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  background: #eef3f9;
  border: 2px solid #c9d5e5;
}

.isie-person-name {
  margin: 0 0 0.2rem;
  font-size: 1rem;
  line-height: 1.2;
  font-weight: 800;
  color: var(--isie-primary-800);
  text-transform: uppercase;
}

.isie-person-role {
  margin: 0 0 0.15rem;
  font-size: var(--isie-fs-300);
  font-weight: 800;
  color: var(--isie-primary-700);
}

.isie-person-affiliation {
  margin: 0;
  color: var(--isie-text-muted);
  font-size: 0.95rem;
  line-height: 1.45;
}

.isie-person-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.55rem;
}

/* ==========================================================================
   16. LOGOS / PARTNERS
   ========================================================================== */

.isie-logo-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1rem;
}

.isie-logo-card {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 84px;
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-sm);
  padding: 1rem;
  box-shadow: var(--isie-shadow-sm);
}

.isie-logo-card img {
  max-height: 52px;
  width: auto;
  object-fit: contain;
}

/* ==========================================================================
   17. TIMELINE
   ========================================================================== */

.isie-timeline {
  position: relative;
  display: grid;
  gap: 1.4rem;
}

.isie-timeline::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 0.2rem;
  bottom: 0.2rem;
  width: 1px;
  background: var(--isie-border-strong);
}

.isie-timeline-item {
  position: relative;
  padding-left: 2rem;
}

.isie-timeline-item::before {
  content: "";
  position: absolute;
  left: 1px;
  top: 1.05rem;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--isie-surface);
  border: 2px solid var(--isie-primary-600);
}

.isie-timeline-card {
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-md);
  padding: 1rem 1.1rem;
  box-shadow: var(--isie-shadow-sm);
}

.isie-timeline-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin-bottom: 0.45rem;
}

.isie-timeline-date {
  font-size: var(--isie-fs-200);
  font-weight: 700;
  color: var(--isie-text-soft);
}


/* ==========================================================================
   IMPORTANT DATES - PREMIUM ROW STYLE
   ========================================================================== */

.isie-date-section {
  margin-bottom: var(--isie-space-8);
}

.isie-date-section-title {
  margin: 0 0 1.25rem;
  font-size: clamp(1.9rem, 1vw + 1.4rem, 2.5rem);
  line-height: 1.2;
  font-weight: 800;
  color: var(--isie-text-strong);
  letter-spacing: -0.02em;
}

.isie-date-section-title::after {
  content: "";
  display: block;
  width: 88px;
  height: 4px;
  margin-top: 1rem;
  border-radius: var(--isie-radius-pill);
  background: var(--isie-accent-600);
}

.isie-date-list {
  display: grid;
  gap: 1.35rem;
}

.isie-date-row {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(220px, 0.8fr);
  gap: 1.5rem;
  align-items: center;
  padding: 2rem 2.25rem;
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: 28px;
  box-shadow: none;
}

.isie-date-row--featured {
  border-left: 4px solid var(--isie-primary-600);
}

.isie-date-label {
  min-width: 0;
}

.isie-date-title {
  margin: 0;
  font-size: clamp(1.35rem, 0.5vw + 1.15rem, 1.85rem);
  line-height: 1.25;
  font-weight: 700;
  color: #243041;
  letter-spacing: -0.015em;
}

.isie-date-subtitle {
  margin: 0.45rem 0 0;
  font-size: var(--isie-fs-300);
  line-height: 1.6;
  color: var(--isie-text-muted);
}

.isie-date-value {
  text-align: right;
  justify-self: end;
}

.isie-date-main {
  display: block;
  margin: 0;
  color: var(--isie-accent-600);
  font-size: clamp(1.35rem, 0.5vw + 1.15rem, 1.8rem);
  line-height: 1.2;
  font-weight: 800;
  font-style: italic;
  letter-spacing: -0.01em;
}

.isie-date-extended {
  display: block;
  margin-top: 0.45rem;
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--isie-text-muted);
}

.isie-date-extended strong {
  color: var(--isie-text-strong);
}

@media (max-width: 900px) {
  .isie-date-row {
    grid-template-columns: 1fr;
    gap: 0.8rem;
    padding: 1.4rem 1.2rem;
    border-radius: 22px;
  }

  .isie-date-value {
    text-align: left;
    justify-self: start;
  }

  .isie-date-main {
    font-size: 1.2rem;
  }

  .isie-date-title {
    font-size: 1.18rem;
  }
}



/* ==========================================================================
   18. FAQ
   ========================================================================== */

.isie-faq {
  display: grid;
  gap: 0.85rem;
}

.isie-faq-group-title {
  margin: 1rem 0 0.3rem;
  font-size: var(--isie-fs-300);
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--isie-primary-800);
}

.isie-faq-item {
  border: 1px solid var(--isie-border);
  background: var(--isie-surface);
  border-radius: var(--isie-radius-sm);
  overflow: hidden;
  box-shadow: var(--isie-shadow-sm);
}

.isie-faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  background: transparent;
  border: 0;
  padding: 0.95rem 1rem;
  text-align: left;
  font-size: var(--isie-fs-300);
  font-weight: 800;
  color: var(--isie-text-strong);
  cursor: pointer;
}

.isie-faq-answer {
  padding: 0 1rem 1rem;
  color: var(--isie-text);
  font-size: var(--isie-fs-300);
  line-height: 1.7;
}

.isie-faq-item[open] {
  border-color: var(--isie-primary-600);
}

.isie-faq-item[open] .isie-faq-question {
  color: var(--isie-primary-800);
}

/* ==========================================================================
   19. NOTICES / CALLOUTS
   ========================================================================== */

.isie-notice {
  padding: 1rem 1.1rem;
  border-radius: var(--isie-radius-md);
  border: 1px solid var(--isie-border);
  background: var(--isie-surface);
  box-shadow: var(--isie-shadow-sm);
}

.isie-notice--info {
  background: var(--isie-info-bg);
  border-color: #d8e6ff;
}

.isie-notice--warning {
  background: var(--isie-warning-bg);
  border-color: #f0d8ae;
}

.isie-notice--success {
  background: var(--isie-success-bg);
  border-color: #d5eadb;
}

/* ==========================================================================
   20. FEATURE PANELS / SPECIAL BLOCKS
   ========================================================================== */

.isie-feature {
  display: grid;
  gap: var(--isie-space-5);
  align-items: start;
}

.isie-feature--split {
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.9fr);
}

.isie-feature-facts {
  display: grid;
  gap: 0.75rem;
}

.isie-feature-fact {
  display: grid;
  grid-template-columns: 22px 1fr;
  align-items: start;
  column-gap: 0.75rem;
  background: var(--isie-surface);
  color: var(--isie-text);
  border-radius: var(--isie-radius-md);
  padding: 0.9rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.45);
  box-shadow: var(--isie-shadow-sm);
}

.isie-feature-fact__icon {
  font-size: 1rem;
  line-height: 1.2;
  margin-top: 0.1rem;
}

.isie-feature-fact__text {
  font-size: var(--isie-fs-300);
  font-weight: 600;
  color: var(--isie-text);
  line-height: 1.45;
}

/* ==========================================================================
   21. TABLES
   ========================================================================== */

.isie-table-wrap {
  overflow-x: auto;
}

.isie-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-md);
  overflow: hidden;
  box-shadow: var(--isie-shadow-sm);
}

.isie-table th,
.isie-table td {
  padding: 0.9rem 1rem;
  border-bottom: 1px solid var(--isie-border-soft);
  text-align: left;
  font-size: var(--isie-fs-300);
}

.isie-table th {
  background: var(--isie-surface-soft);
  color: var(--isie-text-strong);
  font-weight: 800;
}

.isie-table tr:last-child td {
  border-bottom: 0;
}

/* ==========================================================================
   22. HELPERS
   ========================================================================== */

.isie-center {
  text-align: center;
}

.isie-mx-auto {
  margin-inline: auto;
}

.isie-mb-0 {
  margin-bottom: 0;
}

.isie-mt-0 {
  margin-top: 0;
}

.isie-w-full {
  width: 100%;
}

.isie-track-cta {
  margin-top: 1.5rem;
}

/* ==========================================================================
   23. HOME SPECIFIC LAYOUT
   ========================================================================== */

.isie-home-header {
  margin-bottom: var(--isie-space-6);
}

.isie-home-title-wrap {
  text-align: center;
  margin-top: var(--isie-space-5);
}

.isie-home-top-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(300px, 0.9fr);
  gap: var(--isie-space-6);
  align-items: start;
}

.isie-home-main-column {
  display: grid;
  gap: var(--isie-space-5);
}

.isie-home-side-column {
  display: grid;
  gap: var(--isie-space-4);
}

.isie-home-partners {
  text-align: center;
}

.isie-home-partners-title {
  font-size: var(--isie-fs-700);
  font-weight: 800;
  margin-bottom: var(--isie-space-4);
  color: var(--isie-text-strong);
}

.isie-home-partners-logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
  align-items: center;
}

.isie-home-partners-logos img {
  max-height: 52px;
  width: auto;
  object-fit: contain;
}

/* ==========================================================================
   HOME FINAL PATCH
   ========================================================================== */

.isie-home-title-wrap {
  max-width: 980px;
  margin: var(--isie-space-5) auto 0;
  padding-inline: 0.5rem;
}

.isie-home-title-wrap .isie-page-title {
  max-width: 900px;
  margin-inline: auto;
  margin-bottom: 1.1rem;
  font-size: clamp(2.25rem, 1.25vw + 1.95rem, 3.2rem);
  line-height: 1.08;
  letter-spacing: -0.028em;
  text-wrap: balance;
}

.isie-home-title-wrap .isie-pill-row {
  gap: 0.9rem;
}

.isie-home-top-layout {
  grid-template-columns: minmax(0, 1.95fr) minmax(300px, 0.78fr);
  gap: 2rem;
  align-items: start;
}

.isie-home-main-column {
  gap: 1.75rem;
}

.isie-home-side-column {
  gap: 1rem;
  position: relative;
}

.isie-home-side-column .isie-panel {
  padding: 1rem 1rem 1.05rem;
}

.isie-home-side-column .isie-panel-title {
  margin-bottom: 0.85rem;
}

.isie-home-main-column > .isie-stack:first-child {
  gap: 0.95rem;
}

.isie-home-main-column > .isie-stack:first-child .isie-lead {
  font-size: 1.02rem;
  line-height: 1.82;
}

.isie-home-main-column > .isie-stack:first-child p:not(.isie-lead) {
  line-height: 1.8;
}

.isie-home-main-column .isie-card.isie-card--soft {
  padding: 1.45rem 1.45rem 1.3rem;
}

.isie-home-side-column .isie-link-card {
  padding: 0.78rem 0.92rem;
  font-size: 0.89rem;
}

.isie-home-side-column .isie-countdown-grid {
  gap: 0.5rem;
}

.isie-home-side-column .isie-countdown-item {
  padding: 0.8rem 0.3rem;
}

.isie-home-side-column .isie-countdown-value {
  font-size: 1.2rem;
}

.isie-home-side-column .isie-countdown-label {
  font-size: 0.66rem;
}

.isie-home-partners {
  padding-top: 0.25rem;
}

.isie-home-partners-title {
  margin-bottom: 1.25rem;
}

.isie-home-partners-logos {
  gap: 2.25rem;
  padding: 0.25rem 0 0.5rem;
}

.isie-home-partners-logos img {
  max-height: 58px;
  width: auto;
  opacity: 0.98;
  filter: none;
}

.isie-home-partners::before {
  content: "";
  display: block;
  width: min(220px, 40%);
  height: 1px;
  margin: 0 auto 1.4rem;
  background: var(--isie-border-soft);
}

/* ==========================================================================
   TECHNICAL TRACK CHAIRS - LAYOUT ONLY
   No specific card style
   ========================================================================== */

.isie-track-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--isie-space-5);
}

.isie-track-group {
  display: grid;
  gap: 0.75rem;
}

.isie-track-heading {
  margin: 0 0 0.25rem;
  font-size: var(--isie-fs-500);
  font-weight: 800;
  color: var(--isie-text-strong);
}

.isie-track-subheading {
  margin: 0 0 0.75rem;
  font-size: var(--isie-fs-300);
  color: var(--isie-text-muted);
}

/* ==========================================================================
   GROUP PANELS
   For committee groups, chair groups, track groups
   ========================================================================== */

.isie-group-panel {
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: 18px;
  padding: 1rem;
  box-shadow: 0 4px 14px rgba(18, 59, 120, 0.035);
  position: relative;
}

.isie-group-panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  border-radius: 18px 18px 0 0;
  background: var(--isie-primary-600);
}

.isie-group-panel--green::before {
  background: #1e9b72;
}

.isie-group-panel--orange::before {
  background: var(--isie-accent-600);
}

.isie-group-header {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.9rem;
}

.isie-group-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #edf4ff;
  border: 1px solid var(--isie-border);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--isie-primary-700);
  font-size: 0.9rem;
  flex: 0 0 auto;
}

.isie-group-title {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--isie-text-strong);
}

.isie-group-stack {
  display: grid;
  gap: 0.75rem;
}

/* ==========================================================================
   NEWS & UPDATES PAGE
   ========================================================================== */

.isie-news-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.75fr) minmax(250px, 0.7fr);
  gap: var(--isie-space-6);
  align-items: start;
}

.isie-news-sidebar {
  display: grid;
  gap: var(--isie-space-4);
}

.isie-news-hero-panel {
  background: linear-gradient(180deg, var(--isie-primary-900), var(--isie-primary-600));
  color: var(--isie-white);
  border-radius: var(--isie-radius-lg);
  padding: 1.25rem 1.2rem;
  box-shadow: var(--isie-shadow-md);
}

.isie-news-hero-panel .isie-block-title,
.isie-news-hero-panel p {
  color: var(--isie-white);
}

.isie-news-hero-panel .isie-block-title {
  margin-bottom: 0.55rem;
  text-align: center;
}

.isie-news-hero-panel p {
  margin-bottom: 0;
  text-align: center;
  line-height: 1.7;
}

.isie-news-card .isie-timeline-card {
  padding: 1.15rem 1.2rem 1.1rem;
}

.isie-news-card .isie-block-title {
  margin-bottom: 0.55rem;
}

.isie-news-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.55rem;
  font-weight: 800;
  color: var(--isie-primary-700);
}

.isie-news-link:hover,
.isie-news-link:focus {
  color: var(--isie-primary-800);
}
/* ==========================================================================
   EQUAL HEIGHT CARDS
   Use for grids where all cards must have identical height
   ========================================================================== */

.isie-grid--equal {
  align-items: stretch;
}

.isie-grid--equal > .isie-card,
.isie-grid--equal > .isie-card--no-avatar,
.isie-grid--equal > .isie-card--soft,
.isie-grid--equal > .isie-card--accent {
  height: 100%;
}

.isie-grid--equal > .isie-card .isie-card-row,
.isie-grid--equal > .isie-card--no-avatar .isie-card-row,
.isie-grid--equal > .isie-card--soft .isie-card-row,
.isie-grid--equal > .isie-card--accent .isie-card-row {
  height: 100%;
}

.isie-grid--equal > .isie-card .isie-card-body,
.isie-grid--equal > .isie-card--no-avatar .isie-card-body,
.isie-grid--equal > .isie-card--soft .isie-card-body,
.isie-grid--equal > .isie-card--accent .isie-card-body {
  height: 100%;
}


/* ==========================================================================
   CLUSTER CARDS — SUBTLE DIFFERENTIATION
   ========================================================================== */

/* Base (déjà existant, juste rappel visuel) */
.isie-card--cluster {
  position: relative;
  overflow: hidden;
}

/* Accent line */
.isie-card--cluster::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
}

/* ENERGY */
.isie-card--energy::before {
  background: #2e7d32;
}
.isie-card--energy {
  background: #f6fbf7;
}

/* CONTROL */
.isie-card--control::before {
  background: #1565c0;
}
.isie-card--control {
  background: #f4f8ff;
}

/* ICT */
.isie-card--ict::before {
  background: #6a1b9a;
}
.isie-card--ict {
  background: #faf6fd;
}

/* CROSS */
.isie-card--cross::before {
  background: #d67d12;
}
.isie-card--cross {
  background: #fffaf2;
}

/* IMPORTANT DATES — extended dates */
.isie-date-wrap {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.2rem;
}

/* ==========================================================================
   IMPORTANT DATES — EXTENDED DATES SYSTEM
   ========================================================================== */

.isie-date-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.12rem; /* compact */
}

/* anciennes dates (multiples possibles) */
.isie-date-old {
  font-size: 0.82rem;              /* plus petit */
  line-height: 1.2;
  color: var(--isie-text-soft);    /* gris */
  text-decoration: line-through;
  font-weight: 600;
  opacity: 0.9;
}

/* date finale (toujours la dernière) */
.isie-date-current {
  font-size: var(--isie-fs-300);   /* taille normale */
  line-height: 1.25;
  color: var(--isie-accent-600);   /* ORANGE modèle */
  font-weight: 800;
}
/* ==========================================================================
   PERSON CARD MEDIA
   ========================================================================== */

.isie-person-card {
  background: var(--isie-surface);
  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-md);
  overflow: hidden;
  box-shadow: var(--isie-shadow-sm);
}

.isie-person-card__media {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1.25rem 1rem 0.75rem;
}

.isie-person-card__photo {
  width: 108px;
  height: 108px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  border: 3px solid var(--isie-border-soft);
  background: var(--isie-surface-soft);
}

.isie-person-card__avatar-placeholder {
  width: 108px;
  height: 108px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 3px solid var(--isie-border-soft);
  background: var(--isie-surface-soft);
  color: var(--isie-text-soft);
  font-size: 0.8rem;
  font-weight: 700;
}

.isie-person-card__content {
  padding: 0 1rem 1rem;
  text-align: center;
}

.isie-person-card__role {
  margin: 0 0 0.35rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--isie-primary-700);
}

.isie-person-card__name {
  margin: 0 0 0.35rem;
  font-size: var(--isie-fs-400);
  font-weight: 800;
  color: var(--isie-text-strong);
  line-height: 1.3;
}

.isie-person-card__affiliation {
  margin: 0;
  font-size: var(--isie-fs-300);
  line-height: 1.55;
  color: var(--isie-text-muted);
}

/* ==========================================================================
   HOST CITY PANEL — STACKED SOFT VERSION
   ========================================================================== */

.isie-card--host-soft {
  background: var(--isie-surface-soft);
  border: 1px solid var(--isie-border);
  border-radius: 22px;
  padding: 0;
  box-shadow: var(--isie-shadow-sm);
}

.isie-host-soft {
  padding: 1.6rem 1.6rem 1.35rem;
}

.isie-host-soft__intro {
  min-width: 0;
}

.isie-host-soft .isie-subtitle {
  margin-bottom: 0.7rem;
}

.isie-host-soft__title {
  margin: 0 0 1rem;
  font-size: clamp(1.7rem, 0.8vw + 1.35rem, 2.4rem);
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--isie-text-strong);
}

.isie-host-soft__text {
  max-width: 1080px;
}

.isie-host-soft__text p {
  line-height: 1.78;
}

.isie-host-soft__cta {
  margin-top: 1.2rem;
}

.isie-host-soft__divider {
  height: 1px;
  margin: 1.8rem 0 1.25rem;
  background: var(--isie-border);
}

.isie-host-soft__facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem 1.25rem;
}

.isie-host-fact {
  display: grid;
  grid-template-columns: 18px 1fr;
  column-gap: 0.75rem;
  align-items: start;
}

.isie-host-fact__icon {
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--isie-text-soft);
  margin-top: 0.15rem;
}

.isie-host-fact__icon svg {
  width: 18px;
  height: 18px;
  display: block;
}

.isie-host-fact__label {
  display: block;
  margin-bottom: 0.12rem;
  font-size: 0.88rem;
  line-height: 1.3;
  color: var(--isie-text-soft);
}

.isie-host-fact__value {
  display: block;
  font-size: 0.98rem;
  line-height: 1.45;
  font-weight: 700;
  color: var(--isie-text-strong);
}

@media (max-width: 980px) {
  .isie-host-soft__facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .isie-card--host-soft {
    border-radius: 18px;
  }

  .isie-host-soft {
    padding: 1.1rem 1rem;
  }

  .isie-host-soft__title {
    font-size: clamp(1.4rem, 5.5vw, 1.8rem);
  }

  .isie-host-soft__divider {
    margin: 1.35rem 0 1rem;
  }

  .isie-host-soft__facts {
    grid-template-columns: 1fr;
    gap: 0.9rem;
  }

  .isie-host-fact__value {
    font-size: 0.93rem;
  }
}

/* ==========================================================================
   HOME — MOBILE NO-CROP BANNER + SMALLER TITLE
   Strict no-crop policy on mobile
   ========================================================================== */

@media (max-width: 680px) {
  .isie-home-header {
    margin-bottom: 1.1rem;
  }

  .isie-hero {
    gap: 0.9rem;
  }

  .isie-hero__media {
    border-radius: 22px;
    overflow: visible;          /* important: do not clip */
    box-shadow: var(--isie-shadow-md);
    background: transparent;
    aspect-ratio: auto !important;
    min-height: 0 !important;
    height: auto !important;
  }

  .isie-hero__image {
    display: block;
    width: 100% !important;
    height: auto !important;    /* keep original ratio */
    min-height: 0 !important;
    max-height: none !important;
    object-fit: contain !important;   /* never crop */
    object-position: center center !important;
    aspect-ratio: auto !important;
    border-radius: 22px;
    background: transparent;
  }

  .isie-home-title-wrap {
    margin-top: 0.95rem;
    padding-inline: 0.15rem;
    max-width: 100%;
  }

  .isie-home-title-wrap .isie-page-title {
    max-width: 100%;
    margin: 0 auto 0.8rem;
    font-size: clamp(1.52rem, 6vw, 1.9rem);
    line-height: 1.08;
    letter-spacing: -0.028em;
    text-wrap: balance;
  }

  .isie-home-title-wrap .isie-pill-row {
    flex-direction: column;
    align-items: center;
    gap: 0.7rem;
    margin-top: 0.1rem;
  }

  .isie-home-title-wrap .isie-pill {
    min-height: 42px;
    padding: 0.62rem 0.95rem;
    font-size: 0.87rem;
    border-radius: 999px;
  }

  .isie-home-main-column > .isie-stack:first-child .isie-lead {
    font-size: 0.98rem;
    line-height: 1.72;
  }

  .isie-home-main-column > .isie-stack:first-child p:not(.isie-lead) {
    font-size: 0.93rem;
    line-height: 1.7;
  }
}

@media (max-width: 480px) {
  .isie-hero__media {
    border-radius: 20px;
    overflow: visible;
    aspect-ratio: auto !important;
    min-height: 0 !important;
    height: auto !important;
  }

  .isie-hero__image {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    object-fit: contain !important;
    aspect-ratio: auto !important;
    border-radius: 20px;
  }

  .isie-home-title-wrap .isie-page-title {
    font-size: clamp(1.38rem, 5.4vw, 1.72rem);
    line-height: 1.1;
    letter-spacing: -0.022em;
    margin-bottom: 0.75rem;
  }

  .isie-home-title-wrap .isie-pill {
    min-height: 40px;
    padding: 0.58rem 0.88rem;
    font-size: 0.84rem;
  }

  .isie-home-main-column > .isie-stack:first-child .isie-lead {
    font-size: 0.96rem;
    line-height: 1.68;
  }

  .isie-home-main-column > .isie-stack:first-child p:not(.isie-lead) {
    font-size: 0.91rem;
    line-height: 1.66;
  }
}

/* ==========================================================================
   PAGE EYEBROW
   Canonical version for all inner pages except Home

   Recommended HTML:
   <div class="isie-page-eyebrow-wrap">
     <div class="isie-page-eyebrow">
       <span>IEEE ISIE 2027 · Paris, France ·</span>
       <span>15-17 June 2027</span>
     </div>
   </div>
   ========================================================================== */

.isie-page-eyebrow-wrap {
  display: flex;
  justify-content: center;
  margin: 0 0 0.9rem;
}

.isie-page-eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;

  max-width: 100%;
  padding: 0.42rem 0.95rem;

  border: 1px solid var(--isie-border);
  border-radius: var(--isie-radius-pill);
  background: var(--isie-surface-soft);

  color: var(--isie-primary-800);
  font-size: 0.92rem;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
}

.isie-page-eyebrow span {
  white-space: nowrap;
}

@media (max-width: 680px) {
  .isie-page-eyebrow {
    flex-direction: column;
    gap: 0.08rem;
    max-width: 92%;
    padding: 0.38rem 0.8rem;
    font-size: 0.76rem;
    line-height: 1.22;
  }
}

@media (max-width: 480px) {
  .isie-page-eyebrow {
    max-width: 90%;
    padding: 0.34rem 0.72rem;
    font-size: 0.71rem;
  }
}














@media (max-width: 1080px) {
  .isie-news-layout {
    grid-template-columns: 1fr;
  }
}



/* ==========================================================================
   24. RESPONSIVE
   ========================================================================== */

@media (max-width: 1180px) {
  .isie-home-top-layout {
    grid-template-columns: minmax(0, 1.7fr) minmax(290px, 0.9fr);
  }
}

@media (max-width: 1100px) {
  .isie-track-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1080px) {
  .isie-layout,
  .isie-feature--split,
  .isie-home-top-layout {
    grid-template-columns: 1fr;
  }

  .isie-logo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .isie-home-title-wrap .isie-page-title {
    font-size: clamp(2rem, 4.8vw, 2.65rem);
    line-height: 1.12;
  }

  .isie-home-top-layout {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .isie-home-partners-logos {
    gap: 1.6rem;
  }

  .isie-home-partners-logos img {
    max-height: 52px;
  }
}

@media (max-width: 900px) {
  .isie-grid--2,
  .isie-grid--3,
  .isie-grid--4,
  .isie-list--two-cols,
  .isie-stats {
    grid-template-columns: 1fr;
  }

  .isie-container,
  .isie-container--narrow {
    width: min(100% - 1.25rem, var(--isie-max-width));
  }

  .isie-card,
  .isie-panel,
  .isie-group-panel {
    padding: 1rem;
  }

  .isie-page-title {
    font-size: clamp(1.9rem, 6vw, 2.35rem);
  }
}

@media (max-width: 680px) {
  .isie-pill-row {
    justify-content: center;
  }

  .isie-countdown-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .isie-logo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .isie-person,
  .isie-card-row {
    grid-template-columns: 56px 1fr;
    gap: 0.85rem;
  }

  .isie-person-photo,
  .isie-card-avatar {
    width: 56px;
    height: 56px;
  }

  .isie-deadline-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.2rem;
  }

  .isie-deadline-date {
    text-align: left;
    white-space: normal;
  }

  .isie-home-title-wrap {
    margin-top: 1rem;
  }

  .isie-home-title-wrap .isie-page-title {
    font-size: clamp(1.75rem, 7vw, 2.2rem);
    line-height: 1.14;
    letter-spacing: -0.02em;
  }

  .isie-home-side-column .isie-panel {
    padding: 0.95rem;
  }

  .isie-home-partners-logos {
    gap: 1.1rem 1.4rem;
  }

  .isie-home-partners-logos img {
    max-height: 44px;
  }
}