    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }

    :root {
      --navy:        #0f1f6b;
      --navy-dark:   #091454;
      --navy-deep:   #07103e;
      --navy-mid:    #1a2f8a;
      --navy-input:  #1e2f85;
      --accent-blue: #7098e8;
      --white:       #ffffff;
      --white-60:    rgba(255,255,255,0.6);
      --white-40:    rgba(255,255,255,0.4);
      --white-20:    rgba(255,255,255,0.2);
      --white-10:    rgba(255,255,255,0.1);
      --white-06:    rgba(255,255,255,0.06);
      --green:       #3dd68c;
      --green-bg:    rgba(61,214,140,0.15);
      --orange:      #ff6b00;
      --radius:      14px;
      --radius-lg:   20px;
    }

    body {
      font-family: 'Inter', sans-serif;
      background: var(--navy-dark);
      color: var(--white);
      overflow-x: hidden;
    }

    /* ── NAV ── */
    nav {
      position: fixed; top: 0; left: 0; right: 0; z-index: 200;
      display: flex; align-items: center; justify-content: space-between;
      padding: 0 3rem; height: 64px;
      background: rgba(9,20,84,0.93);
      backdrop-filter: blur(16px);
      border-bottom: 1px solid var(--white-10);
    }
    .nav-logo {
      font-family: 'Playfair Display', serif;
      font-size: 1.1rem; font-weight: 700;
      color: var(--white); text-decoration: none;
    }
    .nav-links { display: flex; list-style: none; }
    .nav-links a {
      display: block; padding: 0 1rem;
      color: var(--white-60); text-decoration: none;
      font-size: 0.76rem; font-weight: 500;
      letter-spacing: 0.06em; text-transform: uppercase;
      transition: color .2s; line-height: 64px;
    }
    .nav-links a:hover,
    .nav-links a.active { color: var(--white); }
    .burger {
      display: none; flex-direction: column; gap: 5px;
      cursor: pointer; padding: 6px; background: none; border: none;
    }
    .burger span { display: block; width: 22px; height: 2px; background: var(--white); border-radius: 2px; }

    /* ── SHARED ── */
    section { padding-top: 64px; }
    .section-wrap { padding: 4rem 5rem; }
    .section-eyebrow {
      display: flex; align-items: center; gap: 0.7rem;
      font-family: 'Space Mono', monospace;
      font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
      color: var(--white-40); margin-bottom: 0.7rem;
    }
    .section-eyebrow::before { content: ''; display: inline-block; width: 2rem; height: 1.5px; background: var(--white-30,rgba(255,255,255,0.3)); }
    .section-title {
      font-family: 'Playfair Display', serif;
      font-size: clamp(2rem, 4vw, 3rem); font-weight: 700; line-height: 1.1;
      color: var(--white); margin-bottom: 0.5rem;
    }
    .section-title em { font-style: italic; color: var(--accent-blue); }
    .section-desc { font-size: 0.9rem; color: var(--white-60); margin-bottom: 2.5rem; }

    /* ═══════════════════════════════════
       FOND GLOBAL UNIFIÉ
    ═══════════════════════════════════ */
    body { background: #0c1870; }
    #accueil, #apropos, #experiences, #realisations, #etudes, #contact {
      background: linear-gradient(160deg, #0c1870 0%, #091454 100%);
    }
    #accueil {
      min-height: 100vh;
      display: flex; align-items: center; justify-content: center;
      padding: 64px 5rem 0;
    }
    .accueil-inner {
      display: grid;
      grid-template-columns: 1fr 420px;
      gap: 3.5rem; width: 100%; max-width: 1200px; align-items: center;
      padding: 4rem 0; margin: 0 auto;
    }
    /* LEFT */
    .hero-eyebrow {
      display: flex; align-items: center; gap: 0.7rem;
      font-family: 'Space Mono', monospace;
      font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
      color: var(--white-40); margin-bottom: 1.4rem;
    }
    .hero-eyebrow::before { content: ''; display: inline-block; width: 2rem; height: 1.5px; background: var(--white-30,rgba(255,255,255,0.3)); }
    .hero-name {
      font-family: 'Playfair Display', serif;
      font-weight: 900; line-height: 0.95; margin-bottom: 1.2rem;
    }
    .hero-name .first {
      font-size: clamp(3.8rem, 6.5vw, 6rem);
      display: block; font-style: italic; color: var(--white);
    }
    .hero-name .last {
      font-size: clamp(3.8rem, 6.5vw, 6rem);
      display: block; font-style: normal; color: var(--accent-blue);
    }
    .hero-sub1 { font-size: 0.9rem; color: var(--white-60); margin-bottom: 0.4rem; }
    .hero-sub2 { font-size: 0.9rem; color: var(--white-60); margin-bottom: 2rem; }
    .hero-tags { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 2.2rem; }
    .hero-tag {
      padding: 0.45rem 1.1rem;
      border: 1px solid var(--white-20); border-radius: 100px;
      font-size: 0.8rem; color: var(--white-60);
    }
    .btn-primary {
      display: inline-flex; align-items: center; gap: 0.5rem;
      padding: 0.75rem 1.8rem; background: #1e40af;
      border-radius: 8px; font-size: 0.82rem; font-weight: 600;
      color: var(--white); text-decoration: none;
      letter-spacing: 0.04em; text-transform: uppercase; transition: background .2s;
    }
    .btn-primary:hover { background: #2563eb; }
    /* RIGHT – info card */
    .hero-card {
      background: var(--white-06);
      border: 1px solid var(--white-10);
      border-radius: var(--radius-lg); padding: 1.6rem;
      backdrop-filter: blur(8px);
    }
    .hcr {
      display: flex; justify-content: space-between; align-items: flex-start;
      padding: 0.9rem 0; border-bottom: 1px solid var(--white-10);
    }
    .hcr:first-child { padding-top: 0.2rem; }
    .hcr:last-of-type { border-bottom: none; padding-bottom: 0.2rem; }
    .hcr-label { font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--white-40); }
    .hcr-val { font-size: 0.88rem; color: var(--white); font-weight: 600; text-align: right; }
    .dispo-badge {
      margin-top: 1rem; display: flex; align-items: center; gap: 0.6rem;
      padding: 0.7rem 1rem; background: var(--green-bg);
      border: 1px solid rgba(61,214,140,0.25); border-radius: 8px;
      font-size: 0.85rem; color: var(--green); font-weight: 500;
    }
    .dispo-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(61,214,140,0.25); flex-shrink: 0; }

    /* ═══════════════════════════════════
       À PROPOS
    ═══════════════════════════════════ */
    #apropos { }
    /* À PROPOS – layout maquette : formation gauche, 4 cartes droite */
    .ap-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; align-items: start; }
    .ap-left-col { display: flex; flex-direction: column; gap: 1rem; }
    .ap-right { display: flex; flex-direction: column; gap: 1rem; }
    .ap-formation { }
    .ap-bio { font-size: 0.95rem; color: var(--white-60); line-height: 1.75; padding: 0 0 0.4rem; }
    /* legacy grid – kept for fallback */
    .ap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.4rem; }
    /* comp pills – flex wrap like maquette */
    .comp-tags-wrap { display: flex; flex-wrap: wrap; gap: 0.45rem; }
    .ap-card {
      background: var(--white-06); border: 1px solid var(--white-10);
      border-radius: var(--radius); padding: 1.7rem;
    }
    .ap-card-lbl { font-family: 'Space Mono', monospace; font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--white-40); margin-bottom: 1.1rem; }
    .f-item { margin-bottom: 1.2rem; padding-bottom: 1.2rem; border-bottom: 1px solid var(--white-10); }
    .f-item:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
    .f-school { font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-blue); font-weight: 700; margin-bottom: 0.25rem; }
    .f-degree { font-size: 0.9rem; font-weight: 600; color: var(--white); margin-bottom: 0.15rem; }
    .f-sub { font-size: 0.78rem; color: var(--white-60); }
    .comp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.45rem; }
    .comp-pill { padding: 0.52rem 0.8rem; background: var(--white-10); border-radius: 8px; font-size: 0.8rem; color: var(--white-60); }
    .outils-wrap { display: flex; flex-wrap: wrap; gap: 0.45rem; }
    .outil-tag { padding: 0.32rem 0.75rem; background: var(--white-10); border-radius: 6px; font-size: 0.76rem; color: var(--white-60); }
    .lang-row { display: flex; justify-content: space-between; align-items: center; padding: 0.5rem 0; border-bottom: 1px solid var(--white-10); }
    .lang-row:last-child { border-bottom: none; }
    .lang-name { font-size: 0.88rem; color: var(--white); font-weight: 500; }
    .lang-lvl { font-size: 0.72rem; color: var(--white-40); font-family: 'Space Mono', monospace; }
    .int-wrap { display: flex; flex-wrap: wrap; gap: 0.45rem; margin-top: 0.8rem; }
    .int-pill { padding: 0.32rem 0.75rem; background: rgba(112,152,232,0.15); border: 1px solid rgba(112,152,232,0.2); border-radius: 6px; font-size: 0.76rem; color: var(--accent-blue); }

    /* ═══════════════════════════════════
       EXPÉRIENCES
    ═══════════════════════════════════ */
    #experiences { }
    .exp-list { display: flex; flex-direction: column; gap: 1.1rem; }
    .exp-card {
      background: var(--white-06); border: 1px solid var(--white-10);
      border-left: 3px solid var(--accent-blue);
      border-radius: var(--radius); padding: 1.7rem 2rem;
      transition: background .2s;
    }
    .exp-card:hover { background: var(--white-10); }
    .exp-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 0.5rem; flex-wrap: wrap; gap: 0.4rem; }
    .exp-co { font-size: 0.68rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--accent-blue); font-weight: 700; font-family: 'Space Mono', monospace; margin-bottom: 0.2rem; }
    .exp-role { font-family: 'Playfair Display', serif; font-size: 1.1rem; font-weight: 600; color: var(--white); }
    .exp-period { font-family: 'Space Mono', monospace; font-size: 0.68rem; color: var(--white-40); background: var(--white-10); padding: 0.28rem 0.65rem; border-radius: 100px; white-space: nowrap; }
    .exp-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 0.7rem; }
    .exp-tag { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.07em; text-transform: uppercase; color: var(--accent-blue); background: rgba(112,152,232,0.12); padding: 0.18rem 0.55rem; border-radius: 4px; }
    .exp-desc { font-size: 0.86rem; color: var(--white-60); line-height: 1.65; }
    .btn-rapport {
      display: inline-flex; align-items: center; gap: 0.45rem;
      padding: 0.6rem 1.3rem; border: 1.5px solid var(--accent-blue);
      border-radius: 8px; font-size: 0.78rem; font-weight: 600;
      color: var(--accent-blue); text-decoration: none; margin-top: 1.2rem;
      transition: background .2s, color .2s;
    }
    .btn-rapport:hover { background: var(--accent-blue); color: var(--white); }

    /* ═══════════════════════════════════
       RÉALISATIONS
    ═══════════════════════════════════ */
    #realisations { }
    .real-block { margin-bottom: 3.5rem; }
    .real-block-title { font-family: 'Playfair Display', serif; font-size: 1.45rem; font-weight: 700; color: var(--white); margin-bottom: 0.35rem; }
    .real-block-sub { font-size: 0.86rem; color: var(--white-60); margin-bottom: 1.5rem; line-height: 1.65; }


    /* ── VIDEO PLAYER – approche robuste ── */
    /* Conteneur 9:16 */
    .vp {
      position: relative; width: 100%;
      padding-bottom: 177.78%; /* 16/9 × 100 */
      background: #000; border-radius: var(--radius); overflow: hidden;
    }
    /* Conteneur 16:9 (interview SNCF) */
    .vp-16-9 {
      position: relative; width: 100%;
      padding-bottom: 56.25%;
      background: #000; border-radius: var(--radius) var(--radius) 0 0; overflow: hidden;
    }
    /* La vidéo remplit toujours son conteneur */
    .vp video,
    .vp-16-9 video {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      object-fit: cover; display: block;
    }
    /* Overlay play */
    .vp-overlay {
      position: absolute; inset: 0; z-index: 2;
      display: flex; align-items: center; justify-content: center;
      background: rgba(0,0,0,0.28); cursor: pointer; transition: background .2s;
    }
    .vp-overlay:hover { background: rgba(0,0,0,0.12); }
    .play-btn {
      width: 54px; height: 54px; border-radius: 50%;
      background: rgba(255,255,255,0.93);
      display: flex; align-items: center; justify-content: center;
      transition: transform .18s; flex-shrink: 0;
    }
    .vp-overlay:hover .play-btn { transform: scale(1.1); }
    .play-btn svg { width: 20px; height: 20px; margin-left: 4px; }

    /* MIMONISA – pas de padding-bottom supplémentaire, .vp gère tout */
    .mim-wrap { display: flex; justify-content: center; gap: 1.5rem; }
    .mim-card { width: 260px; flex-shrink: 0; }
    .mim-info { padding: 0.9rem 0; }
    .vid-brand { font-family: 'Space Mono', monospace; font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--accent-blue); margin-bottom: 0.22rem; }
    .vid-title { font-size: 0.86rem; font-weight: 600; color: var(--white); margin-bottom: 0.65rem; }
    .btn-ig { display: inline-flex; align-items: center; gap: 0.38rem; padding: 0.36rem 0.75rem; background: linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); border-radius: 6px; font-size: 0.7rem; font-weight: 600; color: var(--white); text-decoration: none; transition: opacity .2s; }
    .btn-ig:hover { opacity: 0.85; }
    .btn-yt { display: inline-flex; align-items: center; gap: 0.38rem; padding: 0.36rem 0.75rem; background: #ff0000; border-radius: 6px; font-size: 0.7rem; font-weight: 600; color: var(--white); text-decoration: none; transition: opacity .2s; }
    .btn-yt:hover { opacity: 0.85; }
    .btn-linktree { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.58rem 1.3rem; background: #39e09b; color: #111; border-radius: 8px; font-size: 0.8rem; font-weight: 700; text-decoration: none; transition: opacity .2s; }
    .btn-linktree:hover { opacity: 0.85; }

    /* ORANGE phone grid – même taille que Mimonisa (260px/carte) */
    .phone-grid { display: flex; justify-content: center; flex-wrap: wrap; gap: 1.5rem; }
    .phone-card { background: #0a0e2a; border-radius: 20px; overflow: hidden; border: 2.5px solid rgba(255,255,255,0.06); box-shadow: 0 8px 28px rgba(0,0,0,0.4); width: 260px; flex-shrink: 0; }
    /* Conteneur 9:16 pour les phone cards */
    .phone-vid {
      position: relative; width: 100%;
      padding-bottom: 177.78%;
      background: #000; overflow: hidden;
    }
    .phone-vid video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; }
    .phone-overlay {
      position: absolute; inset: 0; z-index: 2;
      display: flex; align-items: center; justify-content: center;
      background: rgba(0,0,0,0.3); cursor: pointer; transition: background .2s;
    }
    .phone-overlay:hover { background: rgba(0,0,0,0.12); }
    .phone-label { position: absolute; bottom: 0; left: 0; right: 0; padding: 0.6rem; background: linear-gradient(to top,rgba(0,0,0,0.85) 0%,transparent 100%); pointer-events: none; z-index: 1; }
    .tuto-badge { display: inline-block; background: var(--orange); color: var(--white); font-size: 0.7rem; font-weight: 800; padding: 0.1rem 0.38rem; margin-bottom: 0.22rem; }
    .phone-title { font-size: 0.74rem; font-weight: 700; color: var(--white); line-height: 1.3; }
    .phone-bottom { padding: 0.55rem 0.7rem; display: flex; align-items: center; justify-content: space-between; }
    .phone-name { font-size: 0.6rem; color: var(--white-40); }

    /* SNCF */
    .sncf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
    .sncf-card { background: var(--white-06); border: 1px solid var(--white-10); border-radius: var(--radius); overflow: hidden; }
    .sncf-img-wrap { width: 100%; }
    .sncf-img-wrap img { width: 100%; height: auto; display: block; }
    .sncf-info { padding: 1.1rem 1.3rem; }
    .sncf-meta { font-family: 'Space Mono', monospace; font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--accent-blue); margin-bottom: 0.3rem; }
    .sncf-title { font-size: 0.92rem; font-weight: 600; color: var(--white); margin-bottom: 0.35rem; }
    .sncf-desc { font-size: 0.8rem; color: var(--white-60); line-height: 1.6; }


    /* ═══════════════════════════════════
       ÉTUDES DE CAS
    ═══════════════════════════════════ */
    #etudes { }
    #etudes .section-eyebrow { color: var(--accent-blue); }
    #etudes .section-eyebrow::before { background: var(--accent-blue); }
    #etudes .section-title { color: var(--white); }
    #etudes .section-title em { color: var(--accent-blue); }
    #etudes .section-desc { color: var(--white-60); }
    .etudes-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.3rem; }
    .etude-card { background: var(--white-06); border: 1px solid var(--white-10); border-radius: var(--radius); padding: 1.6rem; box-shadow: 0 2px 16px rgba(0,0,0,0.2); display: flex; flex-direction: column; transition: box-shadow .2s, transform .2s; }
    .etude-card:hover { box-shadow: 0 6px 28px rgba(0,0,0,0.35); transform: translateY(-2px); }
    .etude-num { font-family: 'Space Mono', monospace; font-size: 0.63rem; letter-spacing: 0.15em; text-transform: uppercase; color: #f4a124; margin-bottom: 0.55rem; font-weight: 700; }
    .etude-title { font-family: 'Playfair Display', serif; font-size: 1.02rem; font-weight: 700; color: var(--white); margin-bottom: 0.55rem; }
    .etude-desc { font-size: 0.8rem; color: var(--white-60); line-height: 1.6; flex: 1; }
    .etude-link { display: inline-flex; align-items: center; gap: 0.28rem; font-family: 'Space Mono', monospace; font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-blue); font-weight: 700; text-decoration: none; margin-top: 1.1rem; transition: color .2s; }
    .etude-link:hover { color: #f4a124; }
    .etude-soon { background: var(--white-06); border: 2px dashed var(--white-20); }
    .etude-soon .etude-title { color: var(--accent-blue); font-size: 1.1rem; }
    .etude-soon .etude-desc { color: var(--white-60); }
    .soon-link { display: inline-flex; align-items: center; gap: 0.28rem; font-family: 'Space Mono', monospace; font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-blue); font-weight: 700; text-decoration: none; margin-top: 1.1rem; transition: color .2s; }
    .soon-link:hover { color: #f4a124; }

    /* ═══════════════════════════════════
       CONTACT
    ═══════════════════════════════════ */
    #contact {
      min-height: 100vh; display: flex; align-items: center;
      padding: 64px 5rem;
    }
    .contact-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; width: 100%; align-items: center; }
    .contact-eyebrow { display: flex; align-items: center; gap: 0.7rem; font-family: 'Space Mono', monospace; font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--white-40); margin-bottom: 1.4rem; }
    .contact-eyebrow::before { content: ''; display: inline-block; width: 2rem; height: 1.5px; background: var(--white-30,rgba(255,255,255,0.3)); }
    .contact-big { font-family: 'Playfair Display', serif; font-weight: 900; line-height: 1.05; color: var(--white); font-size: clamp(2.4rem, 4vw, 3.8rem); margin-bottom: 1.5rem; white-space: nowrap; }
    .contact-big em { font-style: italic; }
    .contact-big .blue { color: var(--accent-blue); }
    .contact-sub { font-size: 0.88rem; color: var(--white-60); line-height: 1.65; max-width: 380px; margin-bottom: 2rem; }
    .contact-dispo { display: inline-flex; align-items: center; gap: 0.6rem; padding: 0.65rem 1.2rem; background: var(--green-bg); border: 1px solid rgba(61,214,140,0.25); border-radius: 8px; font-size: 0.84rem; color: var(--green); font-weight: 500; }
    .cdot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(61,214,140,0.25); flex-shrink: 0; }
    /* Grille 2×2 : Email|LinkedIn / Téléphone|CV – identique à la photo */
    .contact-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 0.85rem; }
    .contact-card { display: flex; align-items: center; gap: 1rem; background: var(--navy-input); border: 1px solid var(--white-10); border-radius: var(--radius); padding: 1.05rem 1.3rem; text-decoration: none; transition: background .2s, border-color .2s; }
    .contact-card:hover { background: rgba(35,55,170,0.9); border-color: var(--white-20); }
    .cc-icon { width: 38px; height: 38px; border-radius: 10px; background: var(--white-10); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .cc-icon svg { width: 17px; height: 17px; color: var(--white-60); }
    .cc-body { flex: 1; min-width: 0; }
    .cc-label { font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--white-40); margin-bottom: 0.22rem; }
    .cc-value { font-size: 0.93rem; font-weight: 500; color: var(--white); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

    /* ── FOOTER ── */
    footer { background: var(--navy-deep); padding: 1.5rem 5rem; display: flex; justify-content: space-between; align-items: center; border-top: 1px solid var(--white-10); }
    footer p { font-size: 0.73rem; color: var(--white-40); }

    /* ── RESPONSIVE ── */
    @media (max-width: 1100px) {
      .accueil-inner { grid-template-columns: 1fr; }
      .hero-card { max-width: 460px; }
      .contact-inner { grid-template-columns: 1fr; gap: 2.5rem; }
    }
    @media (max-width: 900px) {
      nav { padding: 0 1.5rem; }
      .nav-links { display: none; flex-direction: column; position: absolute; top: 64px; left: 0; right: 0; background: rgba(9,20,84,0.97); padding: 0.5rem 1.5rem; }
      .nav-links.open { display: flex; }
      .nav-links a { line-height: 3rem; border-bottom: 1px solid var(--white-10); }
      .burger { display: flex; }
      #accueil, #contact { padding-left: 1.5rem; padding-right: 1.5rem; }
      .section-wrap { padding: 3rem 1.5rem; }
      .ap-layout { grid-template-columns: 1fr; }
      .ap-left-col { gap: 1rem; }
      .ap-grid { grid-template-columns: 1fr; }
      .etudes-grid { grid-template-columns: repeat(2,1fr); }
      .sncf-grid { grid-template-columns: 1fr; }
      footer { padding: 1.5rem; flex-direction: column; gap: 0.5rem; text-align: center; }
    }
    @media (max-width: 640px) {
      .etudes-grid { grid-template-columns: 1fr; }
      .phone-card { width: 100%; max-width: 280px; }
      .mim-wrap { flex-direction: column; align-items: center; }
      .mim-card { width: 100%; max-width: 280px; }
    }