:root{
      --bg:#e9eef5;
      --page:#ffffff;
      --primary:#123b7a;
      --primary-dark:#0d2e60;
      --text:#182231;
      --muted:#5e6b7c;
      --line:#d8e0ea;
      --soft:#f5f8fc;
      --chip:#edf3ff;
      --success:#1f8f56;
    }

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

    html, body{
      width:100%;
      min-height:100%;
    }

    body{
      font-family:"Segoe UI", Arial, sans-serif;
      background:var(--bg);
      color:var(--text);
      padding:16px;
      overflow-x:hidden;
      position:relative;
      isolation:isolate;
    }

    a{
      color:inherit;
    }

    /* =========================
       FOND JEU DE LA VIE
    ========================= */
    .bg-life-wrap{
      position:fixed;
      inset:0;
      z-index:0;
      pointer-events:none;
      overflow:hidden;
    }

    #lifeCanvas{
      position:absolute;
      inset:0;
      width:100%;
      height:100%;
      display:block;
      opacity:.9;
    }

    .bg-life-vignette{
      position:absolute;
      inset:0;
      background:
        radial-gradient(circle at 50% 35%, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 42%),
        linear-gradient(180deg, rgba(233,238,245,.18) 0%, rgba(233,238,245,.42) 100%);
    }

    @media print{
      .bg-life-wrap{
        display:none !important;
      }
    }

    /* =========================
       INTRO
    ========================= */
    #introScreen{
      position:fixed;
      inset:0;
      background:linear-gradient(180deg, rgba(237,242,248,.84) 0%, rgba(232,237,245,.76) 100%);
      backdrop-filter:blur(3px);
      display:flex;
      align-items:center;
      justify-content:center;
      flex-direction:column;
      gap:18px;
      z-index:9999;
      transition:opacity .45s ease, visibility .45s ease;
    }

    #introScreen.hidden{
      opacity:0;
      visibility:hidden;
      pointer-events:none;
    }

    #introPhotoBtn{
      width:230px;
      height:230px;
      border:none;
      border-radius:50%;
      overflow:hidden;
      cursor:pointer;
      background:#fff;
      box-shadow:0 22px 60px rgba(18,59,122,.18);
      border:5px solid #fff;
      transition:transform .2s ease, box-shadow .2s ease;
    }

    #introPhotoBtn:hover{
      transform:scale(1.03);
      box-shadow:0 28px 70px rgba(18,59,122,.24);
    }

    #introPhotoBtn img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }

    #introText{
      font-size:13px;
      font-weight:700;
      letter-spacing:1.5px;
      text-transform:uppercase;
      color:var(--primary-dark);
      opacity:.85;
    }

    /* =========================
       CV
    ========================= */
    .cv{
      width:210mm;
      min-height:297mm;
      margin:0 auto;
      background:rgba(255,255,255,.94);
      backdrop-filter:blur(2px);
      border-radius:18px;
      box-shadow:0 14px 40px rgba(18,59,122,.10);
      overflow:hidden;
      display:flex;
      flex-direction:column;
      transition:opacity .55s ease, transform .55s ease, filter .55s ease;
      transform-origin:center center;
      position:relative;
      z-index:2;
    }

    .cv.cv-hidden{
      opacity:0;
      transform:translateY(24px) scale(.985);
      pointer-events:none;
    }

    .cv.soft-hide{
      opacity:0 !important;
      pointer-events:none !important;
    }

    .cv.invisible-only{
      visibility:hidden !important;
      pointer-events:none !important;
    }

    .topbar{
      height:8px;
      background:linear-gradient(90deg, var(--primary-dark), var(--primary));
      flex:0 0 auto;
    }

    .header{
      display:grid;
      grid-template-columns:110px 1fr;
      gap:14px;
      padding:14px 18px 10px;
      border-bottom:1px solid var(--line);
      align-items:center;
      flex:0 0 auto;
    }

    .photo{
      width:100%;
      aspect-ratio:1/1;
      border-radius:18px;
      overflow:hidden;
      border:3px solid var(--primary);
      background:#dfe6f1;
    }

    .photo a{
      display:block;
      width:100%;
      height:100%;
    }

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

    .hero h1{
      font-size:34px;
      line-height:.92;
      font-weight:900;
      letter-spacing:.5px;
      color:var(--primary-dark);
      text-transform:uppercase;
      margin-bottom:8px;
    }

    .subtitle{
      display:inline-block;
      background:var(--primary);
      color:#fff;
      padding:6px 12px;
      border-radius:999px;
      font-size:11px;
      font-weight:800;
      text-transform:uppercase;
      letter-spacing:1.6px;
      margin-bottom:10px;
    }

    .meta{
      display:flex;
      flex-wrap:wrap;
      gap:6px;
      margin-bottom:10px;
    }

    .meta span,
    .meta-link,
    .tooltip-pill > span,
    .tooltip-pill > a{
      display:inline-block;
      font-size:11px;
      color:var(--muted);
      background:var(--soft);
      border:1px solid var(--line);
      padding:5px 10px;
      border-radius:999px;
      line-height:1;
      text-decoration:none;
      transition:.18s ease;
    }

    .meta-link:hover,
    .tooltip-pill > a:hover{
      color:var(--primary-dark);
      border-color:#bfd0ea;
      background:#f7faff;
    }

    .intro{
      font-size:12.6px;
      line-height:1.55;
      color:var(--muted);
      max-width:100%;
    }

    .content{
      display:grid;
      grid-template-columns:32% 68%;
      flex:1 1 auto;
    }

    .left{
      background:var(--soft);
      border-right:1px solid var(--line);
      padding:12px 14px 10px;
    }

    .right{
      padding:12px 16px 10px;
    }

    .section{
      margin-bottom:10px;
    }

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

    .section h2{
      font-size:13px;
      text-transform:uppercase;
      letter-spacing:2px;
      color:var(--primary-dark);
      margin-bottom:9px;
      font-weight:900;
    }

    .small-title{
      font-size:12px;
      font-weight:800;
      color:var(--text);
      margin-bottom:6px;
    }

    .contact{
      display:grid;
      gap:8px;
    }

    .contact-item{
      font-size:12.2px;
      line-height:1.35;
    }

    .contact-label{
      display:block;
      font-size:10px;
      font-weight:800;
      letter-spacing:1px;
      color:var(--muted);
      text-transform:uppercase;
      margin-bottom:2px;
    }

    .contact-link,
    .company-link,
    .project-link{
      color:var(--text);
      text-decoration:none;
      transition:.18s ease;
    }

    .contact-link:hover,
    .company-link:hover,
    .project-link:hover{
      color:var(--primary-dark);
      text-decoration:underline;
    }

    .skill-block{
      margin-bottom:10px;
    }

    .skill-block:last-child{
      margin-bottom:0;
    }

    .chips{
      display:flex;
      flex-wrap:wrap;
      gap:5px;
    }

    .chip{
      background:var(--chip);
      color:var(--primary-dark);
      border:1px solid #cddaf0;
      border-radius:999px;
      padding:3px 7px;
      font-size:9.8px;
      font-weight:700;
      line-height:1.15;
    }

    .list{
      padding-left:15px;
    }

    .list li{
      font-size:12px;
      line-height:1.4;
      margin-bottom:4px;
    }

    .list li:last-child{
      margin-bottom:0;
    }

    .language-block{
      margin-bottom:10px;
    }

    .language-block:last-child{
      margin-bottom:0;
    }

    .language-name{
      font-size:12px;
      font-weight:800;
      color:var(--text);
      margin-bottom:4px;
    }

    .language-lines{
      padding-left:15px;
      color:var(--muted);
    }

    .language-lines li{
      font-size:12px;
      line-height:1.45;
      margin-bottom:3px;
    }

    .card,
    .profile-box,
    .edu-item{
      border:1px solid var(--line);
      border-radius:14px;
      background:#fff;
    }

    .card{
      padding:12px 14px;
    }

    .profile-box{
      padding:11px 13px;
      font-size:12px;
      line-height:1.5;
      color:var(--muted);
    }

    .job-top{
      margin-bottom:8px;
    }

    .job-date{
      font-size:10.5px;
      text-transform:uppercase;
      letter-spacing:1.2px;
      color:var(--primary);
      font-weight:900;
      margin-bottom:3px;
    }

    .job-title{
      font-size:14px;
      font-weight:900;
      color:var(--text);
      margin-bottom:4px;
    }

    .job-sub{
      font-size:12px;
      color:var(--muted);
      line-height:1.45;
    }

    .job-list{
      padding-left:16px;
      margin-top:8px;
    }

    .job-list li{
      font-size:12px;
      line-height:1.45;
      margin-bottom:5px;
    }

    .job-list li:last-child{
      margin-bottom:0;
    }

    .edu{
      display:grid;
      gap:8px;
    }

    .edu-item{
      padding:10px 12px;
    }

    .edu-year{
      font-size:10.5px;
      text-transform:uppercase;
      letter-spacing:1px;
      color:var(--primary);
      font-weight:900;
      margin-bottom:4px;
    }

    .edu-title{
      font-size:13px;
      font-weight:900;
      margin-bottom:3px;
    }

    .edu-text{
      font-size:11.8px;
      line-height:1.45;
      color:var(--muted);
    }

    /* =========================
       TOOLTIPS
    ========================= */
    .tooltip-pill{
      position:relative;
      display:inline-block;
    }

    .tooltip-pill .tooltip-box,
    .tooltip-pill .tooltip-map{
      position:absolute;
      top:calc(100% + 10px);
      left:50%;
      transform:translateX(-50%) translateY(8px);
      background:#fff;
      border:1px solid var(--line);
      border-radius:14px;
      box-shadow:0 14px 32px rgba(18,59,122,.14);
      opacity:0;
      visibility:hidden;
      transition:.18s ease;
      z-index:50;
    }

    .tooltip-pill .tooltip-box::before,
    .tooltip-pill .tooltip-map::before{
      content:"";
      position:absolute;
      top:-6px;
      left:50%;
      transform:translateX(-50%) rotate(45deg);
      width:12px;
      height:12px;
      background:#fff;
      border-top:1px solid var(--line);
      border-left:1px solid var(--line);
    }

    .tooltip-box{
      min-width:170px;
      padding:10px 12px;
      font-size:11px;
      line-height:1.45;
      color:var(--text);
      white-space:nowrap;
    }

    .tooltip-map{
      width:260px;
      padding:10px;
    }

    .tooltip-map-title{
      font-size:11px;
      font-weight:800;
      color:var(--primary-dark);
      margin-bottom:8px;
    }

    .tooltip-map iframe{
      width:100%;
      height:160px;
      border:0;
      border-radius:10px;
      display:block;
    }

    .tooltip-pill:hover .tooltip-box,
    .tooltip-pill:hover .tooltip-map{
      opacity:1;
      visibility:visible;
      transform:translateX(-50%) translateY(0);
    }

    /* =========================
       ACTIONS
    ========================= */
    .action-panel{
      position:fixed;
      top:50%;
      right:26px;
      transform:translateY(-50%) translateX(20px);
      display:flex;
      flex-direction:column;
      gap:14px;
      z-index:300;
      opacity:0;
      pointer-events:none;
      transition:opacity .35s ease, transform .35s ease;
    }

    .action-panel.is-visible{
      opacity:1;
      pointer-events:auto;
      transform:translateY(-50%) translateX(0);
    }

    .action-btn{
      min-width:170px;
      border:none;
      border-radius:16px;
      padding:14px 18px;
      font-size:13px;
      font-weight:800;
      letter-spacing:.3px;
      cursor:pointer;
      box-shadow:0 12px 28px rgba(18,59,122,.14);
      transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
    }

    .action-btn:hover{
      transform:translateY(-2px);
      box-shadow:0 16px 34px rgba(18,59,122,.20);
    }

    .action-btn:disabled{
      opacity:.55;
      cursor:not-allowed;
      transform:none;
    }

    .action-like{
      background:linear-gradient(135deg, #1f8f56, #2dbf74);
      color:#fff;
    }

    .action-dislike{
      background:linear-gradient(135deg, #111827, #2a3142);
      color:#fff;
    }

    /* =========================
       FX LAYERS
    ========================= */
    .fx-layer{
      position:fixed;
      inset:0;
      pointer-events:none;
      z-index:220;
    }

    #fragmentLayer{
      position:fixed;
      inset:0;
      z-index:230;
      pointer-events:none;
      overflow:hidden;
    }

    .cv-fragment{
      position:fixed;
      overflow:hidden;
      will-change:transform, opacity, filter;
      backface-visibility:hidden;
      transform:translate3d(0,0,0);
      transition:
        transform 1.5s cubic-bezier(.14,.88,.2,1),
        opacity 1.5s ease,
        filter 1.5s ease;
      box-shadow:0 3px 10px rgba(0,0,0,.10);
    }

    .cv-fragment canvas{
      display:block;
      width:100%;
      height:100%;
    }

    /* =========================
       ENVELOPPE
    ========================= */
    .envelope-scene{
      position:fixed;
      inset:0;
      display:grid;
      place-items:center;
      z-index:240;
      pointer-events:none;
      opacity:0;
      transition:opacity .3s ease;
      background:rgba(233,238,245,.72);
      backdrop-filter:blur(3px);
    }

    .envelope-scene.show{
      opacity:1;
    }

    .envelope-wrap{
      position:relative;
      width:460px;
      height:300px;
      opacity:0;
      transform:translateY(18px) scale(.96);
      transition:
        opacity .35s ease,
        transform .45s cubic-bezier(.2,.8,.2,1);
      pointer-events:none;
    }

    .envelope-wrap.show{
      opacity:1;
      transform:translateY(0) scale(1);
    }

    .envelope{
      position:relative;
      width:100%;
      height:100%;
    }

    .envelope-shadow{
      position:absolute;
      left:50%;
      bottom:8px;
      width:250px;
      height:30px;
      transform:translateX(-50%);
      border-radius:50%;
      background:rgba(18,59,122,.14);
      filter:blur(16px);
      z-index:0;
      opacity:.45;
    }

    .envelope-back{
      position:absolute;
      left:35px;
      right:35px;
      bottom:26px;
      height:180px;
      background:linear-gradient(180deg, #fcfdff 0%, #edf3fc 100%);
      border:1px solid #d7e1ef;
      border-radius:20px;
      z-index:1;
      box-shadow:0 18px 38px rgba(18,59,122,.12);
    }

    .envelope-paper{
      position:absolute;
      left:50%;
      top:18px;
      transform:translateX(-50%) translateY(-95px);
      width:72%;
      height:155px;
      background:#fff;
      border:1px solid #dde6f2;
      border-radius:14px 14px 6px 6px;
      z-index:2;
      box-shadow:0 14px 30px rgba(18,59,122,.12);
      padding:18px 18px 12px;
      transition:
        transform .75s cubic-bezier(.2,.85,.2,1),
        height .42s ease,
        box-shadow .42s ease;
      overflow:hidden;
    }

    .envelope-paper::before{
      content:"";
      position:absolute;
      inset:0;
      background:linear-gradient(115deg, transparent 0 35%, rgba(255,255,255,.75) 50%, transparent 65% 100%);
      transform:translateX(-130%);
      opacity:0;
    }

    .envelope-wrap.paper-in .envelope-paper{
      transform:translateX(-50%) translateY(-8px);
    }

    .envelope-wrap.sealed .envelope-paper{
      transform:translateX(-50%) translateY(24px);
      height:118px;
      box-shadow:0 8px 18px rgba(18,59,122,.08);
    }

    .envelope-wrap.done .envelope-paper::before{
      opacity:1;
      animation:paperSweep 1s ease 1;
    }

    .paper-name{
      font-size:15px;
      font-weight:900;
      color:var(--primary-dark);
      margin-bottom:4px;
    }

    .paper-role{
      font-size:11px;
      color:var(--muted);
      margin-bottom:10px;
    }

    .paper-sep{
      width:100%;
      height:1px;
      background:var(--line);
      margin-bottom:10px;
    }

    .paper-contact{
      display:grid;
      gap:8px;
      opacity:0;
      transform:translateY(8px);
      transition:opacity .28s ease, transform .28s ease;
    }

    .envelope-wrap.paper-in .paper-contact{
      opacity:1;
      transform:translateY(0);
    }

    .paper-contact-item{
      color:var(--text);
      font-size:12px;
      font-weight:700;
      background:#f6f9fe;
      border:1px solid var(--line);
      border-radius:10px;
      padding:8px 10px;
    }

    .envelope-front{
      position:absolute;
      left:35px;
      right:35px;
      bottom:26px;
      height:180px;
      background:linear-gradient(180deg, #edf4ff 0%, #dce8f8 100%);
      clip-path:polygon(0 0, 50% 58%, 100% 0, 100% 100%, 0 100%);
      border-bottom-left-radius:20px;
      border-bottom-right-radius:20px;
      z-index:4;
    }

    .envelope-flap{
      position:absolute;
      left:35px;
      right:35px;
      top:92px;
      height:110px;
      background:linear-gradient(180deg, #f8fbff 0%, #e3edf9 100%);
      clip-path:polygon(0 0, 50% 86%, 100% 0, 100% 100%, 0 100%);
      transform-origin:top center;
      transform:rotateX(-178deg);
      transition:transform .7s cubic-bezier(.2,.8,.2,1);
      z-index:5;
      filter:drop-shadow(0 8px 12px rgba(18,59,122,.08));
      backface-visibility:hidden;
    }

    .envelope-wrap.sealed .envelope-flap{
      transform:rotateX(0deg);
    }

    .front-contact-card{
      position:absolute;
      left:50%;
      bottom:34px;
      transform:translateX(-50%) translateY(12px);
      width:66%;
      background:rgba(255,255,255,.92);
      border:1px solid rgba(18,59,122,.10);
      border-radius:18px;
      padding:12px;
      z-index:6;
      opacity:0;
      transition:
        opacity .35s ease,
        transform .4s cubic-bezier(.2,.8,.2,1);
      box-shadow:0 10px 24px rgba(18,59,122,.08);
    }

    .envelope-wrap.done .front-contact-card{
      opacity:1;
      transform:translateX(-50%) translateY(0);
    }

    .front-contact-card .front-title{
      font-size:10px;
      font-weight:900;
      letter-spacing:1px;
      color:var(--primary);
      text-transform:uppercase;
      margin-bottom:8px;
      text-align:center;
    }

    .front-links{
      display:flex;
      flex-direction:column;
      gap:8px;
    }

    .front-link-like{
      display:block;
      text-align:center;
      color:var(--primary-dark);
      font-size:12px;
      font-weight:800;
      background:#fff;
      border:1px solid #d7e2f0;
      border-radius:10px;
      padding:8px 10px;
    }

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

    /* =========================
       PANEL CONTACT PREMIUM
    ========================= */
    .contact-panel{
      position:fixed;
      inset:0;
      z-index:270;
      display:grid;
      place-items:center;
      padding:20px;
      background:rgba(14,24,43,.34);
      backdrop-filter:blur(8px);
      opacity:0;
      visibility:hidden;
      pointer-events:none;
      transition:opacity .28s ease, visibility .28s ease;
    }

    .contact-panel.show{
      opacity:1;
      visibility:visible;
      pointer-events:auto;
    }

    .contact-panel-backdrop{
      position:absolute;
      inset:0;
    }

    .contact-modal{
      position:relative;
      width:min(1120px, 100%);
      max-height:calc(100vh - 40px);
      overflow:auto;
      border-radius:30px;
      border:1px solid rgba(18,59,122,.10);
      background:
        radial-gradient(circle at top right, rgba(18,59,122,.06), transparent 28%),
        linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
      box-shadow:0 26px 70px rgba(18,59,122,.22);
      padding:28px;
    }

    .contact-modal::-webkit-scrollbar{
      width:10px;
    }

    .contact-modal::-webkit-scrollbar-thumb{
      background:rgba(18,59,122,.16);
      border-radius:999px;
    }

    .contact-close{
      position:absolute;
      top:16px;
      right:16px;
      width:46px;
      height:46px;
      border:none;
      border-radius:16px;
      cursor:pointer;
      background:#f4f8fd;
      color:var(--primary-dark);
      font-size:24px;
      font-weight:900;
      box-shadow:0 10px 22px rgba(18,59,122,.08);
      transition:.18s ease;
    }

    .contact-close:hover{
      transform:translateY(-1px);
      background:#edf4fd;
    }

    .contact-modal-top{
      display:flex;
      justify-content:space-between;
      align-items:flex-start;
      gap:18px;
      margin-bottom:22px;
      padding-right:62px;
    }

    .contact-badge{
      display:inline-block;
      background:var(--primary);
      color:#fff;
      padding:7px 12px;
      border-radius:999px;
      font-size:11px;
      font-weight:900;
      letter-spacing:1.4px;
      text-transform:uppercase;
      margin-bottom:12px;
    }

    .contact-modal-top h2{
      font-size:34px;
      line-height:1.02;
      color:var(--primary-dark);
      margin-bottom:10px;
      font-weight:900;
    }

    .contact-subtitle{
      font-size:14px;
      line-height:1.75;
      color:var(--muted);
      max-width:700px;
    }

    .contact-status-card{
      min-width:240px;
      padding:16px 18px;
      border-radius:20px;
      border:1px solid var(--line);
      background:linear-gradient(180deg, #ffffff 0%, #f4f8fe 100%);
      box-shadow:0 12px 24px rgba(18,59,122,.06);
    }

    .contact-status-card strong{
      display:block;
      font-size:14px;
      color:var(--primary-dark);
      margin-bottom:4px;
    }

    .contact-status-card span{
      font-size:13px;
      color:var(--muted);
      line-height:1.5;
    }

    .contact-grid{
      display:grid;
      grid-template-columns:1.15fr .85fr;
      gap:20px;
    }

    .contact-main-col,
    .contact-side-col{
      display:grid;
      gap:16px;
    }

    .contact-profile-card,
    .contact-side-card{
      border:1px solid var(--line);
      border-radius:22px;
      background:#fff;
      box-shadow:0 10px 24px rgba(18,59,122,.05);
    }

    .contact-profile-card{
      padding:18px;
      display:flex;
      align-items:center;
      gap:16px;
    }

    .contact-avatar{
      width:72px;
      height:72px;
      border-radius:22px;
      display:grid;
      place-items:center;
      background:linear-gradient(135deg, var(--primary-dark), var(--primary));
      color:#fff;
      font-size:26px;
      font-weight:900;
      box-shadow:0 14px 28px rgba(18,59,122,.18);
      flex:0 0 auto;
    }

    .contact-name{
      font-size:22px;
      font-weight:900;
      color:var(--primary-dark);
      margin-bottom:4px;
    }

    .contact-role{
      font-size:14px;
      color:var(--muted);
      margin-bottom:10px;
    }

    .contact-inline-list{
      display:flex;
      flex-wrap:wrap;
      gap:8px;
    }

    .contact-inline-list span{
      display:inline-flex;
      align-items:center;
      min-height:34px;
      padding:0 12px;
      border-radius:999px;
      background:var(--soft);
      border:1px solid var(--line);
      font-size:12px;
      color:var(--muted);
    }

    .contact-action-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:12px;
    }

    .contact-action{
      display:flex;
      flex-direction:column;
      justify-content:center;
      gap:6px;
      min-height:96px;
      padding:16px 18px;
      border-radius:20px;
      border:1px solid var(--line);
      background:#fff;
      text-decoration:none;
      box-shadow:0 10px 24px rgba(18,59,122,.05);
      transition:.18s ease;
    }

    .contact-action:hover{
      transform:translateY(-2px);
      box-shadow:0 16px 30px rgba(18,59,122,.10);
      border-color:#bfd0ea;
    }

    .contact-action-primary{
      background:linear-gradient(135deg, var(--primary-dark), var(--primary));
      color:#fff;
      border-color:transparent;
    }

    .contact-action-title{
      font-size:15px;
      font-weight:900;
      line-height:1.3;
    }

    .contact-action-sub{
      font-size:12px;
      opacity:.88;
      line-height:1.5;
    }

    .contact-copy-grid{
      display:grid;
      grid-template-columns:repeat(4, 1fr);
      gap:10px;
    }

    .contact-mini-btn{
      min-height:48px;
      border:none;
      border-radius:16px;
      background:linear-gradient(180deg, #123b7a 0%, #0d2e60 100%);
      color:#fff;
      font-size:13px;
      font-weight:800;
      cursor:pointer;
      box-shadow:0 10px 22px rgba(18,59,122,.14);
      transition:.18s ease;
    }

    .contact-mini-btn:hover{
      transform:translateY(-1px);
    }

    .contact-mini-btn-light{
      background:#f4f8fd;
      color:var(--primary-dark);
      border:1px solid var(--line);
      box-shadow:0 10px 22px rgba(18,59,122,.06);
    }

    .copy-feedback{
      min-height:22px;
      font-size:13px;
      font-weight:800;
      color:var(--success);
      opacity:0;
      transform:translateY(6px);
      transition:.18s ease;
    }

    .copy-feedback.show{
      opacity:1;
      transform:translateY(0);
    }

    .copy-feedback.error{
      color:#c0392b;
    }

    .contact-side-card{
      padding:18px;
    }

    .contact-side-title{
      font-size:13px;
      font-weight:900;
      color:var(--primary-dark);
      text-transform:uppercase;
      letter-spacing:1.6px;
      margin-bottom:14px;
    }

    .contact-qr-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:12px;
    }

    .qr-card{
      padding:14px;
      border-radius:18px;
      border:1px solid var(--line);
      background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
      text-align:center;
    }

    .qr-title{
      font-size:13px;
      font-weight:900;
      color:var(--primary-dark);
      margin-bottom:12px;
    }

    .qr-box{
      min-height:144px;
      display:grid;
      place-items:center;
      border-radius:16px;
      background:#fff;
      border:1px solid var(--line);
      padding:10px;
    }

    .qr-box img,
    .qr-box canvas{
      display:block;
      margin:0 auto;
    }

    .qr-text{
      margin-top:10px;
      font-size:12px;
      color:var(--muted);
      line-height:1.5;
    }

    .contact-mini-list{
      padding-left:18px;
      display:grid;
      gap:8px;
    }

    .contact-mini-list li{
      font-size:13px;
      color:var(--muted);
      line-height:1.6;
    }

    /* =========================
       TROU NOIR AU MILIEU
    ========================= */
    .blackhole-scene{
      position:fixed;
      inset:0;
      display:grid;
      place-items:center;
      pointer-events:none;
      z-index:235;
      opacity:0;
      transition:opacity .35s ease;
    }

    .blackhole-scene.show{
      opacity:1;
    }

    .blackhole-wrap{
      position:relative;
      width:360px;
      height:360px;
      display:grid;
      place-items:center;
      transform:scale(.65);
      transition:transform .35s ease;
    }

    .blackhole-scene.show .blackhole-wrap{
      transform:scale(1);
    }

    .blackhole-glow{
      position:absolute;
      inset:0;
      border-radius:50%;
      background:
        radial-gradient(circle at center,
          rgba(120,185,255,0) 0 26%,
          rgba(72,26,122,.16) 27% 42%,
          rgba(100,50,180,.18) 43% 58%,
          rgba(112,185,255,.18) 59% 68%,
          rgba(112,185,255,0) 69% 100%);
      filter:blur(18px);
      animation:holeBreath 2.3s ease-in-out infinite;
    }

    .blackhole{
      width:240px;
      height:240px;
      border-radius:50%;
      position:relative;
      background:
        radial-gradient(circle at center,
          #010103 0 20%,
          #050711 21% 34%,
          #140b2f 35% 44%,
          #2d1760 45% 56%,
          #4d2e87 57% 65%,
          #8bc5ff 66% 74%,
          rgba(139,197,255,0) 75% 100%);
      box-shadow:
        0 0 40px rgba(70,110,255,.22),
        0 0 90px rgba(98,34,190,.24),
        inset 0 0 38px rgba(0,0,0,.96);
      animation:blackholeSpin 1.4s linear infinite, blackholePulse 1.8s ease-in-out infinite;
    }

    .blackhole::before{
      content:"";
      position:absolute;
      inset:24px;
      border-radius:50%;
      border:2px solid rgba(140,190,255,.26);
      border-top-color:rgba(255,255,255,.9);
      border-left-color:rgba(126,82,225,.7);
      filter:blur(.2px);
      animation:blackholeSpin 1s linear infinite reverse;
    }

    .blackhole::after{
      content:"";
      position:absolute;
      left:50%;
      top:50%;
      width:90px;
      height:90px;
      transform:translate(-50%, -50%);
      border-radius:50%;
      background:radial-gradient(circle, #000 0 60%, rgba(0,0,0,0) 100%);
      box-shadow:0 0 40px rgba(0,0,0,.95);
    }

    .accretion-ring{
      position:absolute;
      width:290px;
      height:140px;
      border-radius:50%;
      border-top:10px solid rgba(145,209,255,.95);
      border-bottom:12px solid rgba(76,38,163,.55);
      border-left:10px solid transparent;
      border-right:10px solid transparent;
      transform:rotate(18deg);
      filter:blur(1px) drop-shadow(0 0 24px rgba(124,195,255,.40));
      animation:ringSpin 1.2s linear infinite;
    }

    .accretion-ring.r2{
      width:315px;
      height:154px;
      transform:rotate(-22deg);
      opacity:.7;
      animation-duration:1.8s;
      filter:blur(1.4px) drop-shadow(0 0 18px rgba(153,97,255,.25));
    }

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

    @keyframes ringSpin{
      from{ transform:rotate(0deg) rotateX(68deg); }
      to{ transform:rotate(360deg) rotateX(68deg); }
    }

    @keyframes blackholePulse{
      0%,100%{ filter:brightness(1) saturate(1); }
      50%{ filter:brightness(1.24) saturate(1.2); }
    }

    @keyframes holeBreath{
      0%,100%{ transform:scale(1); opacity:.8; }
      50%{ transform:scale(1.08); opacity:1; }
    }

    /* =========================
       ANIMS CV
    ========================= */
    .cv.is-folding-center{
      animation:cvFoldToCenter 2.05s cubic-bezier(.2,.8,.2,1) forwards;
      will-change:transform, opacity, filter;
    }

    @keyframes cvFoldToCenter{
      0%{
        transform:translate(0,0) scale(1) rotate(0deg);
        opacity:1;
        filter:blur(0);
      }
      18%{
        transform:translate(0,0) scaleY(.82) scaleX(1);
      }
      35%{
        transform:translate(0,0) scaleY(.82) scaleX(.56);
      }
      65%{
        transform:
          translate(calc(var(--foldX) * .72), calc(var(--foldY) * .72))
          scale(.26)
          rotate(7deg);
        opacity:1;
      }
      100%{
        transform:
          translate(var(--foldX), var(--foldY))
          scale(.04)
          rotate(11deg);
        opacity:0;
        filter:blur(2px);
      }
    }

    /* =========================
       RESPONSIVE
    ========================= */
    @media (max-width:1450px){
      .action-panel{
        right:12px;
      }
    }

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

      .contact-copy-grid{
        grid-template-columns:1fr 1fr;
      }
    }

    @media (max-width:760px){
      body{
        padding:12px;
      }

      .header{
        grid-template-columns:1fr;
      }

      .content{
        grid-template-columns:1fr;
      }

      .action-panel{
        right:12px;
        left:12px;
        top:auto;
        bottom:12px;
        transform:none;
        flex-direction:row;
      }

      .action-panel.is-visible{
        transform:none;
      }

      .action-btn{
        min-width:0;
        flex:1;
      }

      .contact-panel{
        padding:12px;
      }

      .contact-modal{
        padding:18px;
        border-radius:24px;
        max-height:calc(100vh - 24px);
      }

      .contact-modal-top{
        flex-direction:column;
        padding-right:52px;
      }

      .contact-modal-top h2{
        font-size:28px;
      }

      .contact-action-grid,
      .contact-qr-grid,
      .contact-copy-grid{
        grid-template-columns:1fr;
      }

      .contact-profile-card{
        flex-direction:column;
        align-items:flex-start;
      }

      .envelope-wrap{
        width:360px;
        height:240px;
      }

      .paper-contact-item,
      .front-link-like{
        font-size:11px;
      }
    }

    /* =========================
       PRINT
    ========================= */
    @media print{
      body{
        background:#fff;
        padding:0;
      }

      .cv{
        width:210mm;
        min-height:297mm;
        border-radius:0;
        box-shadow:none;
        margin:0;
        transform:none !important;
        opacity:1 !important;
        filter:none !important;
        visibility:visible !important;
      }

      .action-panel,
      .fx-layer,
      .blackhole-scene,
      .envelope-scene,
      .contact-panel,
      #fragmentLayer,
      #introScreen{
        display:none !important;
      }
    }

    @page{
      size:A4;
      margin:0;
    }
