/* =====================================================
   Héliantis Éligibilité – Front CSS  v2.0
   Palette : #F5C200 jaune | #E87E04 orange | #1A2E4A bleu
   ===================================================== */
:root{
  --hc-yellow:#F5C200;--hc-orange:#E87E04;
  --hc-blue:#1A2E4A;--hc-blue2:#2C4A72;--hc-blue3:#3A6EA5;
  --hc-white:#FFFFFF;--hc-grey:#F2F5FA;--hc-grey2:#D0D9E8;
  --hc-green:#22C55E;--hc-amber:#F59E0B;--hc-red:#EF4444;
  --hc-r:14px;--hc-sh:0 10px 40px rgba(26,46,74,.15);
}

/* wrapper */
.hele-wrapper{font-family:'Segoe UI',system-ui,sans-serif;max-width:620px;margin:2rem auto;background:var(--hc-white);border-radius:var(--hc-r);box-shadow:var(--hc-sh);overflow:hidden;}

/* header */
.hele-header{background:linear-gradient(140deg,var(--hc-blue) 0%,var(--hc-blue2) 100%);padding:1.6rem 2rem;border-bottom:4px solid var(--hc-yellow);}
.hele-header-inner{display:flex;align-items:center;gap:1rem;}
.hele-bolt{font-size:2.4rem;filter:drop-shadow(0 2px 8px rgba(245,194,0,.6));}
.hele-title{color:#fff;font-size:1.3rem;font-weight:700;margin:0 0 .2rem;letter-spacing:-.01em;}
.hele-sub{color:rgba(255,255,255,.55);font-size:.78rem;margin:0;letter-spacing:.04em;text-transform:uppercase;}

/* tabs */
.hele-tabs{display:flex;background:var(--hc-grey);border-bottom:1px solid var(--hc-grey2);}
.hele-tab{flex:1;border:none;background:transparent;cursor:pointer;padding:.8rem 1rem;font-size:.88rem;font-weight:600;color:var(--hc-blue2);display:flex;align-items:center;justify-content:center;gap:.4rem;border-bottom:3px solid transparent;margin-bottom:-1px;transition:all .2s;}
.hele-tab svg{width:16px;height:16px;fill:currentColor;}
.hele-tab:hover{background:rgba(26,46,74,.05);}
.hele-tab.active{color:var(--hc-orange);border-bottom-color:var(--hc-orange);background:var(--hc-white);}

/* panel */
.hele-panel{padding:1.75rem 2rem;}

/* form */
.hele-row{display:flex;gap:.8rem;margin-bottom:.9rem;}
.hele-field{display:flex;flex-direction:column;flex:1;margin-bottom:.9rem;}
.hele-field--sm{flex:0 0 90px;}
.hele-field--lg{flex:1;}
.hele-field label{font-size:.74rem;font-weight:700;color:var(--hc-blue);margin-bottom:.3rem;letter-spacing:.06em;text-transform:uppercase;}
.hele-field input{padding:.62rem .9rem;border:1.5px solid var(--hc-grey2);border-radius:8px;font-size:.93rem;color:var(--hc-blue);background:var(--hc-white);outline:none;transition:border-color .2s,box-shadow .2s;width:100%;box-sizing:border-box;}
.hele-field input:focus{border-color:var(--hc-blue3);box-shadow:0 0 0 3px rgba(58,110,165,.18);}
.hele-field input.hel-invalid{border-color:var(--hc-red);box-shadow:0 0 0 3px rgba(239,68,68,.14);}
.req{color:var(--hc-orange);}
.hele-hint{font-size:.76rem;color:#7A8FA8;margin-top:.25rem;}

/* button */
.hele-btn{width:100%;margin-top:.3rem;padding:.82rem 1.5rem;background:linear-gradient(135deg,var(--hc-orange),var(--hc-yellow));color:var(--hc-blue);font-weight:700;font-size:.95rem;border:none;border-radius:10px;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 18px rgba(232,126,4,.3);transition:opacity .2s,transform .2s;}
.hele-btn:hover{opacity:.9;transform:translateY(-1px);}
.hele-btn:active{transform:translateY(0);}
.hele-btn.loading .btn-label{opacity:.35;}
.hele-btn.loading{pointer-events:none;}
.btn-spin{display:none;width:18px;height:18px;border:2.5px solid rgba(26,46,74,.2);border-top-color:var(--hc-blue);border-radius:50%;animation:spin .7s linear infinite;position:absolute;}
.hele-btn.loading .btn-spin{display:inline-block;}
@keyframes spin{to{transform:rotate(360deg);}}

/* map */
.hele-map-container{position:relative;margin:0 2rem 0;}
#hele-map{height:280px;border-radius:10px;overflow:hidden;border:2px solid var(--hc-grey2);}
.hele-map-legend{display:flex;gap:1.2rem;justify-content:center;padding:.6rem 0 1rem;font-size:.78rem;font-weight:600;}
.leg.eligible{color:var(--hc-green);}
.leg.en_cours{color:var(--hc-amber);}
.leg.ineligible{color:var(--hc-red);}

/* result card */
.hele-result{margin:0 2rem 2rem;border-radius:10px;overflow:hidden;animation:fadeUp .3s ease;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.hele-result.is-eligible  {border:2px solid var(--hc-green);background:#F0FDF4;}
.hele-result.is-en_cours  {border:2px solid var(--hc-amber);background:#FFFBEB;}
.hele-result.is-ineligible{border:2px solid var(--hc-grey2);background:var(--hc-grey);}
.hele-result.is-error     {border:2px solid var(--hc-red);background:#FEF2F2;}
.hele-result.is-unknown   {border:2px solid var(--hc-grey2);background:var(--hc-grey);}

.hele-rh{display:flex;align-items:center;gap:.75rem;padding:1rem 1.2rem;border-bottom:1px solid rgba(0,0,0,.06);}
.hele-rh-icon{font-size:1.5rem;}
.hele-rh-title{font-weight:700;color:var(--hc-blue);margin:0 0 .1rem;font-size:1rem;}
.hele-rh-sub{font-size:.8rem;color:#5A6F88;margin:0;}

.hele-rb{padding:1rem 1.2rem;}

/* source badges */
.hele-sources{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.8rem;}
.hele-badge{font-size:.75rem;font-weight:700;padding:.3rem .75rem;border-radius:20px;display:flex;align-items:center;gap:.3rem;}
.hele-badge.eligible  {background:#DCFCE7;color:#15803D;}
.hele-badge.en_cours  {background:#FEF9C3;color:#A16207;}
.hele-badge.ineligible{background:#FEE2E2;color:#B91C1C;}
.hele-badge.unknown   {background:#F1F5F9;color:#64748B;}
.hele-badge.error     {background:#FEE2E2;color:#B91C1C;}

.hele-cta{display:inline-block;margin-top:.7rem;padding:.5rem 1.1rem;background:var(--hc-blue);color:#fff;border-radius:7px;font-size:.86rem;font-weight:600;text-decoration:none;transition:background .2s;}
.hele-cta:hover{background:var(--hc-blue2);color:#fff;}

/* raw toggle */
.hele-toggle{background:none;border:1.5px solid var(--hc-grey2);color:var(--hc-blue2);border-radius:6px;padding:.25rem .75rem;font-size:.74rem;cursor:pointer;margin-top:.6rem;transition:background .15s;}
.hele-toggle:hover{background:var(--hc-grey);}
.hele-raw{font-size:.72rem;font-family:'Courier New',monospace;background:var(--hc-blue);color:var(--hc-yellow);padding:.8rem 1rem;border-radius:6px;overflow:auto;white-space:pre-wrap;word-break:break-all;max-height:260px;margin-top:.5rem;}

/* responsive */
@media(max-width:500px){
  .hele-wrapper{margin:.8rem;border-radius:10px;}
  .hele-header,.hele-panel{padding:1.2rem;}
  .hele-row{flex-direction:column;gap:0;}
  .hele-field--sm{flex:1;}
  .hele-map-container,.hele-result{margin:0 1.2rem 1.2rem;}
}
