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

    :root {
      --primary: #2563eb;
      --primary-dark: #1d4ed8;
      --primary-light: #eff6ff;
      --primary-muted: #dbeafe;
      --success: #059669;
      --success-light: #ecfdf5;
      --danger: #dc2626;
      --danger-light: #fef2f2;
      --warning: #d97706;
      --warning-light: #fffbeb;
      --gray-50: #f9fafb;
      --gray-100: #f3f4f6;
      --gray-200: #e5e7eb;
      --gray-300: #d1d5db;
      --gray-400: #71717a;
      --gray-500: #6b7280;
      --gray-600: #4b5563;
      --gray-700: #374151;
      --gray-800: #1f2937;
      --gray-900: #111827;
      --radius: 12px;
      --radius-sm: 8px;
      --shadow: 0 1px 3px rgba(0,0,0,0.08), 0 4px 16px rgba(0,0,0,0.06);
      --shadow-md: 0 4px 6px rgba(0,0,0,0.05), 0 10px 40px rgba(0,0,0,0.10);
    }

    body {
      font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
      background: #f0f4f8;
      color: var(--gray-800);
      min-height: 100vh;
    }

    /* ── HEADER ── */
    .header {
      background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 50%, #1d4ed8 100%);
      padding: 0;
      position: relative;
      overflow: hidden;
    }
    .header::before {
      content: '';
      position: absolute; inset: 0;
      background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    }
    .header-inner {
      position: relative;
      max-width: 1100px;
      margin: 0 auto;
      padding: 28px 32px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .logo { display: flex; align-items: center; gap: 12px; text-decoration: none; }
    .logo-icon {
      width: 44px; height: 44px;
      background: linear-gradient(135deg, #60a5fa, #2563eb);
      border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
      font-size: 22px; font-weight: 800; color: white;
      box-shadow: 0 4px 12px rgba(37,99,235,0.4);
    }
    .logo-text { color: white; }
    .logo-text h1 { font-size: 22px; font-weight: 800; letter-spacing: -0.5px; }
    .logo-text p { font-size: 12px; opacity: 0.65; margin-top: 1px; }
    .header-badge {
      background: rgba(255,255,255,0.12);
      border: 1px solid rgba(255,255,255,0.2);
      color: white;
      padding: 6px 14px;
      border-radius: 20px;
      font-size: 12px;
      font-weight: 500;
    }

    /* ── STEPPER ── */
    .stepper-bar {
      background: white;
      border-bottom: 1px solid var(--gray-200);
      padding: 0;
    }
    .stepper-inner {
      max-width: 1100px;
      margin: 0 auto;
      padding: 0 32px;
      display: flex;
      gap: 0;
    }
    .step-tab {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 18px 24px 16px;
      cursor: pointer;
      border-bottom: 3px solid transparent;
      transition: all 0.2s;
      color: var(--gray-400);
      font-size: 13px;
      font-weight: 500;
      white-space: nowrap;
    }
    .step-tab:hover { color: var(--gray-600); }
    .step-tab.active { color: var(--primary); border-bottom-color: var(--primary); }
    .step-tab.completed { color: var(--success); }
    .step-tab.completed .step-num { background: var(--success); color: white; }
    .step-num {
      width: 24px; height: 24px;
      border-radius: 50%;
      background: var(--gray-200);
      color: var(--gray-500);
      font-size: 11px;
      font-weight: 700;
      display: flex; align-items: center; justify-content: center;
      transition: all 0.2s;
      flex-shrink: 0;
    }
    .step-tab.active .step-num { background: var(--primary); color: white; }
    .step-tab .check { display: none; font-size: 13px; }
    .step-tab.completed .check { display: inline; }
    .step-tab.completed .step-num { display: none; }

    /* ── MAIN LAYOUT ── */
    .main {
      max-width: 1100px;
      margin: 32px auto;
      padding: 0 32px;
      display: grid;
      grid-template-columns: 1fr 340px;
      gap: 24px;
      align-items: start;
    }

    /* ── CARDS ── */
    .card {
      background: white;
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      overflow: hidden;
    }
    .card-header {
      padding: 20px 24px 16px;
      border-bottom: 1px solid var(--gray-100);
    }
    .card-header h2 {
      font-size: 16px;
      font-weight: 700;
      color: var(--gray-900);
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .card-header h2 .icon {
      width: 32px; height: 32px;
      background: var(--primary-muted);
      border-radius: 8px;
      display: flex; align-items: center; justify-content: center;
      font-size: 15px;
    }
    .card-header p {
      font-size: 13px;
      color: var(--gray-500);
      margin-top: 4px;
      margin-left: 40px;
    }
    .card-body { padding: 20px 24px 24px; }

    /* ── FORM ELEMENTS ── */
    .form-grid { display: grid; gap: 16px; }
    .form-grid.cols-2 { grid-template-columns: 1fr 1fr; }
    .form-grid.cols-3 { grid-template-columns: 1fr 1fr 1fr; }

    .form-group { display: flex; flex-direction: column; gap: 5px; }
    .form-group.full { grid-column: 1 / -1; }

    label {
      font-size: 12px;
      font-weight: 600;
      color: var(--gray-600);
      text-transform: uppercase;
      letter-spacing: 0.4px;
    }
    label .req { color: var(--danger); margin-left: 2px; }
    label .opt { color: var(--gray-400); font-weight: 400; text-transform: none; font-size: 11px; margin-left: 4px; }

    input[type="text"],
    input[type="email"],
    input[type="tel"],
    input[type="number"],
    select,
    textarea {
      padding: 10px 14px;
      border: 1.5px solid var(--gray-200);
      border-radius: var(--radius-sm);
      font-size: 14px;
      font-family: inherit;
      color: var(--gray-800);
      background: white;
      transition: all 0.15s;
      width: 100%;
      -webkit-appearance: none;
    }
    input:focus, select:focus, textarea:focus {
      outline: none;
      border-color: var(--primary);
      box-shadow: 0 0 0 3px rgba(37,99,235,0.1);
    }
    input::placeholder { color: var(--gray-300); }
    button:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
    .sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
    select { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7280' d='M1 1l5 5 5-5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }

    .input-hint { font-size: 11px; color: var(--gray-400); margin-top: 3px; }
    .input-hint.url { color: var(--primary); font-weight: 500; }
    .color-field { gap: 8px; }
    .color-picker-row {
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .color-input {
      width: 56px;
      min-width: 56px;
      height: 44px;
      padding: 4px;
      border: 1.5px solid var(--gray-200);
      border-radius: 14px;
      background: white;
      cursor: pointer;
      appearance: none;
      -webkit-appearance: none;
    }
    .color-input::-webkit-color-swatch-wrapper { padding: 0; }
    .color-input::-webkit-color-swatch {
      border: none;
      border-radius: 10px;
    }
    .color-input::-moz-color-swatch {
      border: none;
      border-radius: 10px;
    }
    .color-code {
      min-width: 110px;
      padding: 10px 12px;
      border-radius: var(--radius-sm);
      border: 1px solid var(--gray-200);
      background: var(--gray-50);
      color: var(--gray-700);
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.3px;
      text-transform: uppercase;
    }
    .color-presets {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .color-swatch {
      width: 28px;
      height: 28px;
      border-radius: 999px;
      border: 2px solid white;
      box-shadow: 0 0 0 1px var(--gray-200);
      cursor: pointer;
      transition: transform 0.15s ease, box-shadow 0.15s ease;
    }
    .color-swatch:hover {
      transform: translateY(-1px) scale(1.05);
      box-shadow: 0 0 0 2px rgba(37,99,235,0.18);
    }
    .color-swatch.is-active {
      box-shadow: 0 0 0 2px var(--primary), 0 0 0 5px rgba(37,99,235,0.12);
    }
    .slug-line {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      gap: 8px;
      margin-top: 2px;
    }
    .slug-chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 6px 10px;
      border-radius: 999px;
      font-size: 11px;
      font-weight: 700;
      border: 1px solid transparent;
      transition: all 0.15s ease;
    }
    .slug-chip.idle {
      color: var(--gray-500);
      background: var(--gray-50);
      border-color: var(--gray-200);
    }
    .slug-chip.checking {
      color: #1d4ed8;
      background: #eff6ff;
      border-color: #bfdbfe;
    }
    .slug-chip.available {
      color: #047857;
      background: #ecfdf5;
      border-color: #a7f3d0;
    }
    .slug-chip.taken {
      color: #b91c1c;
      background: #fef2f2;
      border-color: #fecaca;
    }

    .identity-intro {
      display: grid;
      gap: 14px;
      padding: 16px 18px;
      border-radius: var(--radius-sm);
      background: linear-gradient(135deg, #eff6ff 0%, #f8fafc 100%);
      border: 1px solid #dbeafe;
      margin-bottom: 18px;
    }
    .identity-eyebrow {
      font-size: 11px;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--primary);
      margin-bottom: 6px;
    }
    .identity-intro h3 {
      font-size: 18px;
      line-height: 1.3;
      color: var(--gray-900);
      margin-bottom: 6px;
    }
    .identity-intro p {
      font-size: 13px;
      line-height: 1.6;
      color: var(--gray-600);
    }
    .identity-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .identity-pill {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 7px 10px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.82);
      border: 1px solid #dbeafe;
      color: var(--gray-700);
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.02em;
    }
    .academic-intro {
      background: linear-gradient(135deg, #fff7ed 0%, #eff6ff 100%);
      border-color: #fed7aa;
    }
    .academic-intro .identity-eyebrow { color: #b45309; }
    .academic-intro .identity-pill { border-color: #fde68a; }

    .about-school-panel {
      display: grid;
      gap: 16px;
      margin-top: 4px;
      padding: 18px;
      border-radius: var(--radius-sm);
      background: linear-gradient(145deg, #fcfdff 0%, #f8fbff 48%, #f7fafc 100%);
      border: 1px solid #dbeafe;
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.72);
    }
    .about-school-intro {
      display: grid;
      gap: 8px;
      padding: 14px 16px;
      border-radius: 10px;
      background: linear-gradient(135deg, rgba(255,255,255,0.95), rgba(239,246,255,0.92));
      border: 1px solid rgba(191,219,254,0.95);
    }
    .about-school-intro strong {
      font-size: 13px;
      color: var(--gray-900);
      line-height: 1.45;
    }
    .about-school-intro p {
      font-size: 12px;
      color: var(--gray-600);
      line-height: 1.65;
    }
    .about-copy-field {
      min-height: 88px;
      resize: vertical;
      line-height: 1.6;
      background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
    }
    .about-copy-rtl {
      text-align: right;
      font-family: 'Noto Sans Arabic', 'Geeza Pro', 'Arial', sans-serif;
    }
    .about-tags-builder {
      display: grid;
      gap: 12px;
      padding: 14px;
      border-radius: 10px;
      border: 1px solid var(--gray-200);
      background: rgba(255, 255, 255, 0.92);
    }
    .about-tags-preset-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .about-tag-preset,
    .about-tag-selected {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-height: 34px;
      padding: 7px 12px;
      border-radius: 999px;
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.01em;
    }
    .about-tag-preset {
      border: 1px solid #bfdbfe;
      background: #eff6ff;
      color: #1d4ed8;
      cursor: pointer;
      transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, background 0.15s ease;
    }
    .about-tag-preset:hover {
      transform: translateY(-1px);
      border-color: #60a5fa;
      box-shadow: 0 6px 18px rgba(59, 130, 246, 0.10);
    }
    .about-tag-preset.selected {
      background: linear-gradient(135deg, #1d4ed8, #2563eb);
      border-color: #1d4ed8;
      color: white;
      box-shadow: 0 8px 22px rgba(37, 99, 235, 0.18);
    }
    .about-tag-input-row {
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .about-tag-input-row input {
      flex: 1;
      min-width: 0;
    }
    .about-tags-selected {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      min-height: 34px;
    }
    .about-tag-selected {
      border: 1px solid #c7f0d8;
      background: #ecfdf5;
      color: #166534;
    }
    .about-tag-remove {
      width: 20px;
      height: 20px;
      border: none;
      border-radius: 999px;
      background: rgba(22, 101, 52, 0.10);
      color: inherit;
      font-size: 14px;
      font-weight: 700;
      line-height: 1;
      cursor: pointer;
      transition: background 0.15s ease, transform 0.15s ease;
    }
    .about-tag-remove:hover {
      background: rgba(22, 101, 52, 0.18);
      transform: scale(1.04);
    }
    .about-tag-empty {
      display: inline-flex;
      align-items: center;
      min-height: 34px;
      padding: 0 2px;
      color: var(--gray-400);
      font-size: 12px;
    }
    .brand-readiness-panel,
    .module-naming-panel {
      display: grid;
      gap: 14px;
      margin-bottom: 16px;
      padding: 16px;
      border-radius: 12px;
      border: 1px solid var(--gray-200);
      background: linear-gradient(145deg, rgba(255,255,255,0.96), rgba(248,250,252,0.98));
    }
    .brand-readiness-intro,
    .module-naming-intro {
      display: grid;
      gap: 6px;
    }
    .brand-readiness-intro strong,
    .module-naming-intro strong {
      font-size: 13px;
      color: var(--gray-900);
      line-height: 1.45;
    }
    .brand-readiness-intro p,
    .module-naming-intro p {
      font-size: 12px;
      color: var(--gray-600);
      line-height: 1.6;
    }
    .brand-readiness-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
    }
    .brand-readiness-card {
      display: grid;
      gap: 8px;
      padding: 14px;
      border-radius: 12px;
      border: 1px solid #dbeafe;
      background: rgba(255, 255, 255, 0.95);
    }
    .brand-readiness-head {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 10px;
    }
    .brand-readiness-head strong {
      font-size: 13px;
      color: var(--gray-900);
    }
    .brand-readiness-card p {
      font-size: 12px;
      color: var(--gray-600);
      line-height: 1.55;
    }
    .brand-readiness-badge {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 26px;
      padding: 4px 10px;
      border-radius: 999px;
      font-size: 11px;
      font-weight: 800;
      letter-spacing: 0.02em;
      white-space: nowrap;
    }
    .brand-readiness-badge.ready {
      background: #ecfdf5;
      color: #166534;
      border: 1px solid #bbf7d0;
    }
    .brand-readiness-badge.scaffold {
      background: #fff7ed;
      color: #b45309;
      border: 1px solid #fed7aa;
    }

    /* ── CHECKBOXES / CYCLES ── */
    .check-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
    .check-card {
      display: flex;
      align-items: flex-start;
      gap: 10px;
      padding: 12px 14px;
      border: 1.5px solid var(--gray-200);
      border-radius: var(--radius-sm);
      cursor: pointer;
      transition: all 0.15s;
      background: white;
    }
    .check-card:hover { border-color: var(--primary); background: var(--primary-light); }
    .check-card.selected { border-color: var(--primary); background: var(--primary-light); }
    .check-card input[type="checkbox"] { display: none; }
    .check-box {
      width: 18px; height: 18px; flex-shrink: 0;
      border: 2px solid var(--gray-300);
      border-radius: 4px;
      display: flex; align-items: center; justify-content: center;
      font-size: 11px; color: white;
      transition: all 0.15s;
    }
    .check-card.selected .check-box { background: var(--primary); border-color: var(--primary); }
    .check-card-content { flex: 1; }
    .check-card-content strong { font-size: 13px; display: block; color: var(--gray-800); }
    .check-card-content span { font-size: 11px; color: var(--gray-500); }
    .cycle-card { min-height: 136px; }
    .cycle-card .check-card-content {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }
    .cycle-topline {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 10px;
    }
    .cycle-duration {
      display: inline-flex;
      align-items: center;
      padding: 4px 8px;
      border-radius: 999px;
      background: rgba(37, 99, 235, 0.08);
      color: var(--primary);
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.03em;
      white-space: nowrap;
    }
    .cycle-meta {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      margin-top: auto;
    }
    .cycle-meta span {
      display: inline-flex;
      align-items: center;
      padding: 4px 7px;
      border-radius: 999px;
      background: var(--gray-100);
      color: var(--gray-600);
      font-size: 10px;
      font-weight: 700;
    }
    .check-card.selected .cycle-meta span {
      background: rgba(255, 255, 255, 0.95);
      color: var(--primary-dark);
    }
    .btn-sm {
      padding: 9px 14px;
      font-size: 12px;
    }
    .level-structure-panel {
      display: grid;
      gap: 16px;
      margin-top: 18px;
      padding: 18px;
      border-radius: var(--radius-sm);
      background: linear-gradient(135deg, #f8fafc, #ffffff);
      border: 1px solid var(--gray-200);
    }
    .level-structure-toolbar {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 18px;
    }
    .level-structure-toolbar h3 {
      font-size: 15px;
      font-weight: 700;
      color: var(--gray-900);
      margin-bottom: 6px;
    }
    .level-structure-toolbar p {
      font-size: 12px;
      color: var(--gray-600);
      line-height: 1.55;
    }
    .level-structure-actions {
      display: flex;
      align-items: center;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: flex-end;
    }
    .level-structure-actions label {
      margin: 0;
      font-size: 11px;
      color: var(--gray-500);
      text-transform: none;
      letter-spacing: 0;
      font-weight: 600;
    }
    .level-structure-actions select {
      min-width: 88px;
    }
    .level-structure-list {
      display: grid;
      gap: 14px;
    }
    .level-structure-empty {
      padding: 14px;
      border-radius: 10px;
      background: var(--gray-50);
      border: 1px dashed var(--gray-300);
      font-size: 12px;
      color: var(--gray-500);
      line-height: 1.55;
    }
    .level-group {
      display: grid;
      gap: 10px;
    }
    .level-group-title {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      font-size: 12px;
      font-weight: 700;
      color: var(--gray-700);
    }
    .level-group-title span:last-child {
      color: var(--gray-400);
      font-size: 11px;
      font-weight: 600;
    }
    .level-grid {
      display: grid;
      gap: 10px;
    }
    .level-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 16px;
      padding: 14px;
      border-radius: 10px;
      background: white;
      border: 1px solid var(--gray-200);
    }
    .level-row-copy {
      display: flex;
      flex-direction: column;
      gap: 4px;
      min-width: 0;
    }
    .level-row-copy strong {
      font-size: 13px;
      color: var(--gray-900);
    }
    .level-row-copy span {
      font-size: 12px;
      color: var(--gray-500);
      line-height: 1.45;
    }
    .level-row-actions {
      display: flex;
      align-items: center;
      gap: 10px;
      flex-shrink: 0;
    }
    .level-row-actions label {
      margin: 0;
      font-size: 11px;
      color: var(--gray-500);
      text-transform: none;
      letter-spacing: 0;
      font-weight: 600;
    }
    .level-row-actions select {
      min-width: 84px;
    }
    .academic-footprint {
      display: grid;
      gap: 14px;
      margin-top: 18px;
      padding: 18px;
      border-radius: var(--radius-sm);
      background: linear-gradient(135deg, #f8fafc, #eff6ff);
      border: 1px solid #dbeafe;
    }
    .academic-footprint-header {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 14px;
    }
    .academic-footprint-header h3 {
      font-size: 15px;
      font-weight: 700;
      color: var(--gray-900);
      margin-bottom: 5px;
    }
    .academic-footprint-header p {
      font-size: 12px;
      line-height: 1.55;
      color: var(--gray-600);
    }
    .academic-meta-list {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      justify-content: flex-end;
    }
    .academic-meta-pill {
      display: inline-flex;
      align-items: center;
      padding: 7px 10px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.88);
      border: 1px solid #dbeafe;
      color: var(--gray-700);
      font-size: 11px;
      font-weight: 700;
      white-space: nowrap;
    }
    .footprint-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 10px;
    }
    .footprint-metric {
      background: rgba(255, 255, 255, 0.92);
      border: 1px solid #dbeafe;
      border-radius: 10px;
      padding: 12px 10px;
      text-align: center;
    }
    .footprint-metric strong {
      display: block;
      font-size: 21px;
      font-weight: 800;
      color: var(--gray-900);
      line-height: 1;
      margin-bottom: 6px;
    }
    .footprint-metric span {
      font-size: 11px;
      font-weight: 600;
      color: var(--gray-500);
    }
    .footprint-note {
      font-size: 12px;
      line-height: 1.6;
      color: var(--gray-600);
    }
    .subject-extra-panel {
      display: grid;
      gap: 14px;
      margin-top: 18px;
      padding: 18px;
      border-radius: var(--radius-sm);
      background: linear-gradient(135deg, #fffdf7, #f8fafc);
      border: 1px solid #fde68a;
    }
    .subject-extra-header {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 14px;
    }
    .subject-extra-header h3 {
      font-size: 15px;
      font-weight: 700;
      color: var(--gray-900);
      margin-bottom: 5px;
    }
    .subject-extra-header p {
      font-size: 12px;
      line-height: 1.55;
      color: var(--gray-600);
    }
    .subject-extra-callout {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 11px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.92);
      border: 1px solid #fde68a;
      font-size: 11px;
      font-weight: 700;
      color: #92400e;
      white-space: nowrap;
    }
    .subject-extra-list {
      display: grid;
      gap: 12px;
    }
    .subject-extra-empty {
      padding: 14px;
      border-radius: 10px;
      background: rgba(255, 255, 255, 0.9);
      border: 1px dashed #fcd34d;
      color: var(--gray-500);
      font-size: 12px;
      line-height: 1.5;
    }
    .subject-group {
      display: grid;
      gap: 10px;
    }
    .subject-group-title {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 10px;
      font-size: 12px;
      font-weight: 700;
      color: var(--gray-700);
      text-transform: uppercase;
      letter-spacing: 0.04em;
    }
    .subject-group-title span:last-child {
      color: var(--gray-500);
      font-weight: 600;
      text-transform: none;
      letter-spacing: 0;
    }
    .subject-level-card {
      display: grid;
      gap: 12px;
      padding: 14px;
      border-radius: 12px;
      border: 1px solid var(--gray-200);
      background: rgba(255, 255, 255, 0.92);
    }
    .subject-level-head {
      display: flex;
      justify-content: space-between;
      gap: 12px;
      align-items: flex-start;
    }
    .subject-level-copy strong {
      display: block;
      font-size: 13px;
      color: var(--gray-900);
      margin-bottom: 4px;
    }
    .subject-level-copy span {
      display: block;
      font-size: 12px;
      color: var(--gray-500);
      line-height: 1.45;
    }
    .subject-level-count {
      font-size: 11px;
      font-weight: 700;
      color: var(--primary);
      padding: 6px 10px;
      border-radius: 999px;
      background: var(--primary-light);
      white-space: nowrap;
    }
    .subject-section {
      display: grid;
      gap: 8px;
    }
    .subject-section-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 12px;
    }
    .subject-section-label {
      font-size: 11px;
      font-weight: 700;
      color: var(--gray-500);
      text-transform: uppercase;
      letter-spacing: 0.05em;
    }
    .subject-section-actions {
      display: inline-flex;
      gap: 8px;
      flex-wrap: wrap;
    }
    .subject-action-btn {
      border: 1px solid var(--gray-200);
      background: white;
      color: var(--gray-600);
      border-radius: 999px;
      padding: 5px 10px;
      font-size: 11px;
      font-weight: 700;
      cursor: pointer;
    }
    .subject-action-btn:hover {
      border-color: var(--primary);
      color: var(--primary);
    }
    .subject-chip-list {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }
    .subject-chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      border-radius: 999px;
      padding: 7px 11px;
      font-size: 11px;
      font-weight: 700;
      border: 1px solid var(--gray-200);
      background: white;
      color: var(--gray-600);
    }
    .subject-chip.locked {
      border-color: #dbeafe;
      background: #eff6ff;
      color: #1d4ed8;
    }
    .subject-chip.optional {
      cursor: pointer;
      transition: all 0.15s;
    }
    .subject-chip.optional:hover {
      border-color: var(--primary);
      color: var(--primary);
    }
    .subject-chip.optional.selected {
      border-color: #16a34a;
      background: #ecfdf5;
      color: #166534;
    }
    .subject-chip-code {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 28px;
      padding: 2px 6px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.7);
      font-size: 10px;
      font-weight: 800;
      letter-spacing: 0.02em;
    }
    .subject-chip.locked .subject-chip-code {
      background: rgba(255, 255, 255, 0.9);
    }
    .subject-chip.optional.selected .subject-chip-code {
      background: rgba(255, 255, 255, 0.92);
    }
    .subject-extra-help {
      font-size: 12px;
      color: var(--gray-500);
      line-height: 1.55;
    }

    /* BAC TRACKS */
    .bac-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
    .bac-tag {
      display: flex; align-items: center; gap: 8px;
      padding: 9px 12px;
      border: 1.5px solid var(--gray-200);
      border-radius: var(--radius-sm);
      cursor: pointer;
      font-size: 12px;
      font-weight: 500;
      color: var(--gray-600);
      transition: all 0.15s;
    }
    .bac-tag:hover { border-color: var(--primary); color: var(--primary); }
    .bac-tag.selected { border-color: var(--primary); background: var(--primary-light); color: var(--primary); }
    .bac-tag input { display: none; }
    .bac-dot {
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--gray-300);
      flex-shrink: 0;
    }
    .bac-tag.selected .bac-dot { background: var(--primary); }
    .bac-helper {
      display: flex;
      gap: 10px;
      padding: 12px 14px;
      border-radius: var(--radius-sm);
      border: 1px solid #fde68a;
      background: linear-gradient(135deg, #fffbeb, #fff7ed);
      font-size: 12px;
      color: #92400e;
      line-height: 1.55;
      margin-bottom: 16px;
    }
    .pedagogy-snapshot {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
      margin-top: 18px;
    }
    .snapshot-card {
      padding: 14px;
      border-radius: 10px;
      border: 1px solid var(--gray-200);
      background: var(--gray-50);
      min-height: 132px;
    }
    .snapshot-card .eyebrow {
      display: inline-block;
      font-size: 10px;
      font-weight: 800;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--primary);
      margin-bottom: 8px;
    }
    .snapshot-card strong {
      display: block;
      font-size: 15px;
      color: var(--gray-900);
      margin-bottom: 6px;
      line-height: 1.4;
    }
    .snapshot-card p {
      font-size: 12px;
      color: var(--gray-600);
      line-height: 1.55;
    }

    /* ── FILE UPLOAD ── */
    .file-zone {
      border: 2px dashed var(--gray-200);
      border-radius: var(--radius-sm);
      padding: 20px;
      text-align: center;
      cursor: pointer;
      transition: all 0.2s;
      background: var(--gray-50);
    }
    .file-zone:hover, .file-zone.dragover { border-color: var(--primary); background: var(--primary-light); }
    .file-zone.has-file { border-color: var(--success); background: var(--success-light); }
    .file-zone input { display: none; }
    .file-icon { font-size: 28px; margin-bottom: 8px; }
    .file-zone p { font-size: 13px; color: var(--gray-500); }
    .file-zone .filename { font-weight: 600; color: var(--success); font-size: 13px; margin-top: 4px; }
    .file-template {
      display: flex; align-items: center; gap: 6px;
      margin-top: 10px; font-size: 11px; color: var(--gray-400);
      justify-content: center;
    }

    /* ── LOGO UPLOAD ── */
    .logo-upload {
      width: 100px; height: 100px;
      border: 2px dashed var(--gray-200);
      border-radius: 12px;
      display: flex; flex-direction: column; align-items: center; justify-content: center;
      cursor: pointer; transition: all 0.2s;
      background: var(--gray-50);
      font-size: 11px; color: var(--gray-400);
      gap: 6px;
    }
    .logo-upload:hover { border-color: var(--primary); background: var(--primary-light); }
    .logo-upload .icon { font-size: 28px; }
    .logo-upload input { display: none; }
    .logo-upload img { width: 100%; height: 100%; object-fit: contain; border-radius: 10px; }

    /* ── STEP PANELS ── */
    .step-panel { display: none; flex-direction: column; gap: 20px; }
    .step-panel.active { display: flex; }

    /* ── NAVIGATION ── */
    .nav-buttons {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 20px 24px;
      border-top: 1px solid var(--gray-100);
      background: white;
      border-radius: 0 0 var(--radius) var(--radius);
    }
    .btn {
      display: inline-flex; align-items: center; gap: 8px;
      padding: 10px 20px;
      border: none; border-radius: var(--radius-sm);
      font-size: 14px; font-weight: 600;
      cursor: pointer; transition: all 0.2s;
      font-family: inherit;
    }
    .btn-primary { background: var(--primary); color: white; padding: 11px 28px; }
    .btn-primary:hover { background: var(--primary-dark); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(37,99,235,0.3); }
    .btn-primary:disabled { background: #93c5fd; cursor: not-allowed; transform: none; box-shadow: none; }
    .btn-ghost { background: transparent; color: var(--gray-600); border: 1.5px solid var(--gray-200); }
    .btn-ghost:hover { border-color: var(--gray-400); color: var(--gray-800); }
    .btn-success { background: var(--success); color: white; padding: 11px 28px; }
    .btn-success:hover { background: #047857; }

    /* ── SIDEBAR ── */
    .sidebar { display: flex; flex-direction: column; gap: 16px; position: sticky; top: 24px; }

    .preview-card {
      background: white;
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      overflow: hidden;
    }
    .preview-header {
      background: linear-gradient(135deg, #0f172a, #1e3a5f);
      padding: 20px;
      color: white;
    }
    .preview-header .school-name {
      font-size: 16px; font-weight: 700;
      margin-bottom: 4px;
      min-height: 22px;
    }
    .preview-header .school-url {
      font-size: 11px; opacity: 0.6;
      font-family: monospace;
    }
    .preview-header .school-type-badge {
      display: inline-block;
      background: rgba(255,255,255,0.12);
      border: 1px solid rgba(255,255,255,0.2);
      padding: 3px 10px;
      border-radius: 20px;
      font-size: 10px;
      margin-top: 8px;
    }
    .preview-body { padding: 16px 20px; }
    .preview-row {
      display: flex; justify-content: space-between; align-items: center;
      padding: 8px 0;
      border-bottom: 1px solid var(--gray-100);
      font-size: 12px;
    }
    .preview-row:last-child { border-bottom: none; }
    .preview-row .label { color: var(--gray-500); }
    .preview-row .value { font-weight: 600; color: var(--gray-800); }
    .preview-cycles { display: flex; flex-wrap: wrap; gap: 4px; }
    .cycle-badge {
      padding: 2px 8px;
      border-radius: 20px;
      font-size: 10px;
      font-weight: 600;
    }
    .cycle-badge.primaire { background: #fef3c7; color: #92400e; }
    .cycle-badge.college { background: #dbeafe; color: #1e40af; }
    .cycle-badge.lycee { background: #ede9fe; color: #4c1d95; }

    .info-card {
      background: white;
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      padding: 18px 20px;
    }
    .info-card h4 { font-size: 13px; font-weight: 700; color: var(--gray-800); margin-bottom: 12px; }
    .feature-list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
    .feature-list li {
      display: flex; align-items: flex-start; gap: 8px;
      font-size: 12px; color: var(--gray-600);
    }
    .feature-list li .tick { color: var(--success); font-size: 14px; flex-shrink: 0; margin-top: -1px; }
    .summary-list {
      display: flex;
      flex-direction: column;
      gap: 10px;
    }
    .summary-row {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      gap: 12px;
      font-size: 12px;
      color: var(--gray-600);
    }
    .summary-row .key {
      color: var(--gray-500);
    }
    .summary-row .value {
      font-weight: 700;
      color: var(--gray-800);
      text-align: right;
    }
    .summary-callout {
      margin-top: 14px;
      padding: 12px 14px;
      border-radius: 10px;
      background: linear-gradient(135deg, #eff6ff, #f8fafc);
      border: 1px solid #dbeafe;
      font-size: 12px;
      color: var(--gray-600);
      line-height: 1.55;
    }

    .progress-bar-wrap {
      height: 4px; background: var(--gray-100);
      border-radius: 4px; margin-bottom: 4px;
    }
    .progress-bar-fill { height: 100%; background: var(--primary); border-radius: 4px; transition: width 0.3s; }
    .progress-label { font-size: 11px; color: var(--gray-400); text-align: right; }

    /* ── PROGRESS TRACKER ── */
    #progress-section { display: none; }
    .step-list { list-style: none; display: flex; flex-direction: column; gap: 0; }
    .step-item {
      display: flex; align-items: flex-start; gap: 14px;
      padding: 14px 0;
      border-bottom: 1px solid var(--gray-100);
      position: relative;
    }
    .step-item:last-child { border-bottom: none; }
    .step-icon-wrap { display: flex; flex-direction: column; align-items: center; }
    .step-icon {
      width: 32px; height: 32px;
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 14px; flex-shrink: 0;
      transition: all 0.3s;
    }
    .step-icon.pending { background: var(--gray-100); color: var(--gray-400); }
    .step-icon.running { background: var(--primary-muted); color: var(--primary); animation: spin 1s linear infinite; }
    .step-icon.completed { background: var(--success-light); color: var(--success); }
    .step-icon.failed { background: var(--danger-light); color: var(--danger); }
    .step-icon.skipped { background: var(--gray-100); color: var(--gray-300); }
    .step-content { flex: 1; }
    .step-content .step-name { font-size: 13px; font-weight: 600; color: var(--gray-800); }
    .step-content .step-name.running { color: var(--primary); }
    .step-content .step-name.failed { color: var(--danger); }
    .step-content .step-desc { font-size: 11px; color: var(--gray-400); margin-top: 2px; }
    .step-content .step-error { font-size: 11px; color: var(--danger); margin-top: 2px; }

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

    .result-box {
      background: linear-gradient(135deg, #ecfdf5, #d1fae5);
      border: 1px solid #a7f3d0;
      border-radius: var(--radius);
      padding: 24px;
      text-align: center;
      margin-top: 20px;
    }
    .result-box .check-big { font-size: 40px; margin-bottom: 12px; }
    .result-box h3 { font-size: 18px; font-weight: 700; color: #065f46; margin-bottom: 6px; }
    .result-box p { font-size: 13px; color: #047857; margin-bottom: 12px; }
    .filtered-box h3 { color: #0f172a; }
    .filtered-box p { color: var(--gray-600); }
    .result-box .url-box {
      background: white;
      border: 1px solid #a7f3d0;
      border-radius: 8px;
      padding: 12px 16px;
      margin-bottom: 12px;
    }
    .result-box .url-box a { color: var(--primary); font-weight: 700; font-size: 15px; }
    .error-box {
      background: var(--danger-light);
      border: 1px solid #fecaca;
      border-radius: var(--radius);
      padding: 20px;
      margin-top: 20px;
    }
    .error-box p { color: var(--danger); font-size: 13px; margin-bottom: 12px; }
    .submit-error-box {
      margin-top: 12px;
      padding: 14px 16px;
    }
    .submit-error-box p { margin-bottom: 0; }

    /* ── DIVIDER ── */
    .section-divider {
      display: flex; align-items: center; gap: 10px;
      font-size: 11px; font-weight: 600; color: var(--gray-400);
      text-transform: uppercase; letter-spacing: 0.5px;
      margin: 4px 0;
    }
    .section-divider::before, .section-divider::after {
      content: ''; flex: 1; height: 1px; background: var(--gray-100);
    }

    /* ── RESPONSIVE ── */
    @media (max-width: 900px) {
      .main { grid-template-columns: 1fr; }
      .sidebar { position: static; }
      .header-inner { flex-direction: column; gap: 12px; text-align: center; }
      .stepper-inner { overflow-x: auto; }
      .form-grid.cols-2, .form-grid.cols-3 { grid-template-columns: 1fr; }
      .check-grid { grid-template-columns: 1fr 1fr; }
      .bac-grid { grid-template-columns: 1fr; }
      .footprint-grid { grid-template-columns: 1fr 1fr; }
      .pedagogy-snapshot { grid-template-columns: 1fr; }
      .academic-footprint-header { flex-direction: column; }
      .academic-meta-list { justify-content: flex-start; }
      .level-structure-toolbar { flex-direction: column; }
      .level-structure-actions { justify-content: flex-start; }
      .about-tag-input-row { flex-direction: column; align-items: stretch; }
      .brand-readiness-grid { grid-template-columns: 1fr; }
    }
    @media (max-width: 480px) {
      .main { padding: 0 16px; }
      .check-grid { grid-template-columns: 1fr; }
      .footprint-grid { grid-template-columns: 1fr; }
      .level-row { flex-direction: column; align-items: flex-start; }
      .level-row-actions { width: 100%; justify-content: space-between; }
      .about-school-panel { padding: 14px; }
      .about-school-intro { padding: 12px; }
      .brand-readiness-panel,
      .module-naming-panel { padding: 14px; }
      .brand-readiness-head { flex-direction: column; align-items: flex-start; }
    }
