/* =========================================================================
   Station Esso Hellange — design "aube sur la route"
   Display: Space Grotesk · Texte: Inter · Données/heures: Space Mono
   ========================================================================= */

:root{
  --ink:#0b1620;          /* nuit petrol */
  --petrol:#103a57;
  --petrol-2:#1b5b84;
  --dawn:#f0a05a;         /* lueur d'aube à l'horizon (motif 05:00) */
  --paper:#ffffff;
  --mist:#eef3f6;
  --line:#dce4ea;
  --text:#0b1620;
  --muted:#5d6f7c;
  --signal:#e3411f;       /* accent marque (rouge Esso) */
  --open:#1c9b54;
  --automate:#cf8400;
  --closed:#cf3b2e;
  --radius:18px;
  --shadow:0 18px 50px -24px rgba(11,22,32,.45);
  --maxw:880px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
html,body{overflow-x:hidden}
body{
  margin:0;
  font-family:"Inter",system-ui,sans-serif;
  color:var(--text);
  background:var(--mist);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:18px 20px 40px}

/* ---- bandeau exceptionnel ---- */
.notice{
  background:var(--signal);color:#fff;font-weight:600;
  padding:12px 18px;border-radius:12px;margin:6px 0 18px;text-align:center;
  font-size:.95rem;
}

/* ---- HERO ---- */
.hero{
  position:relative;overflow:hidden;
  margin-top:8px;padding:34px 30px 32px;
  border-radius:24px;color:#eaf2f7;
  background:
    radial-gradient(120% 90% at 50% 130%, rgba(240,160,90,.55) 0%, rgba(240,160,90,0) 55%),
    linear-gradient(180deg, var(--ink) 0%, var(--petrol) 100%);
  box-shadow:var(--shadow);
}
.hero::after{ /* fine ligne d'horizon */
  content:"";position:absolute;left:0;right:0;bottom:34%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(240,160,90,.5),transparent);
}
.eyebrow{
  margin:0 0 12px;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:#9fc0d4;font-weight:600;
}
.hero-name{
  margin:0 0 18px;font-family:"Space Grotesk",sans-serif;font-weight:700;
  font-size:clamp(1.8rem,6vw,2.6rem);line-height:1.05;letter-spacing:-.01em;
}

/* ---- statut live (élément signature) ---- */
.status{
  display:inline-flex;align-items:center;gap:11px;
  max-width:100%;
  padding:11px 18px 11px 15px;border-radius:18px;
  font-weight:600;font-size:1rem;line-height:1.35;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(4px);
}
.status--open{--sc:var(--open)}
.status--automate{--sc:var(--automate)}
.status--closed{--sc:var(--closed)}
.status .dot{
  width:11px;height:11px;border-radius:50%;flex:0 0 auto;position:relative;
  background:var(--sc,#9fc0d4);
}
.status .dot::after{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:var(--sc,#9fc0d4);
  animation:pulse 2.4s ease-out infinite;
}
@keyframes pulse{
  0%{transform:scale(1);opacity:.55}
  100%{transform:scale(3.4);opacity:0}
}

.badges{margin-top:20px;display:flex;flex-wrap:wrap;gap:10px}
.badge{
  display:inline-flex;align-items:center;gap:7px;max-width:100%;
  padding:9px 14px;border-radius:12px;font-size:.88rem;font-weight:600;line-height:1.3;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
}
.badge--fuel{background:rgba(227,65,31,.18);border-color:rgba(227,65,31,.4);color:#ffd9cf}

/* ---- grille cartes ---- */
.grid{display:grid;grid-template-columns:1.15fr .85fr;gap:16px;margin-top:16px}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 24px 26px;box-shadow:var(--shadow);
}
.card-title{
  margin:0 0 16px;font-family:"Space Grotesk",sans-serif;font-size:1.18rem;font-weight:600;
}
.card-sub{
  margin:22px 0 10px;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
}

/* ---- totem horaires ---- */
.hours{list-style:none;margin:0;padding:0}
.hours li{
  display:flex;justify-content:space-between;align-items:baseline;gap:14px;
  padding:11px 0;border-bottom:1px dashed var(--line);
}
.hours li:last-child{border-bottom:0}
.h-days{font-weight:500}
.h-time{font-family:"Space Mono",monospace;font-weight:700;font-size:1.02rem;font-variant-numeric:tabular-nums}
.hours li.is-closed .h-time{color:var(--closed)}

.exc{list-style:none;margin:0;padding:0;font-size:.92rem}
.exc li{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:baseline;padding:7px 0}
.exc-date{font-family:"Space Mono",monospace;font-weight:700;color:var(--petrol-2)}
.exc-label{color:var(--muted)}
.exc-time{font-family:"Space Mono",monospace;font-variant-numeric:tabular-nums}

/* ---- contact ---- */
.addr{font-style:normal;font-size:1.05rem;line-height:1.7;margin:0 0 22px}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 20px;border-radius:12px;font-weight:600;text-decoration:none;
  font-size:.98rem;transition:transform .12s ease, background .2s ease;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--petrol);color:#fff}
.btn--primary:hover{background:var(--petrol-2)}
.btn--ghost{background:var(--mist);color:var(--text);font-family:"Space Mono",monospace}
.btn--ghost:hover{background:#e3eaef}

/* ---- carte ---- */
.map-wrap{
  margin-top:16px;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);line-height:0;
}
.map-wrap iframe{display:block;width:100%;max-width:100%;border:0}

/* ---- footer (style 2do.lu : version à gauche · © IAV à droite) ---- */
.site-foot{max-width:var(--maxw);margin:26px auto 0;padding:0 20px}
.foot-inner{
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;
  padding:18px 0 8px;border-top:1px solid var(--line);
  font-size:.82rem;color:var(--muted);
}
.foot-ver{font-family:"Space Mono",monospace;font-size:.6rem;letter-spacing:.02em;color:#aab6bf;opacity:.75}
.foot-stat{font-family:"Space Mono",monospace}
.foot-copy{margin-left:auto}
.foot-copy a{color:var(--petrol-2);font-weight:700;text-decoration:none}
.foot-copy a:hover{text-decoration:underline}

/* ---- responsive ---- */
@media(max-width:680px){
  .grid{grid-template-columns:1fr}
  .hero{padding:26px 20px 24px;border-radius:20px}
  .wrap{padding:12px 14px 28px}
  .card{padding:20px 18px 22px}
  .status{font-size:.98rem;align-items:flex-start}
  .h-time{font-size:1rem}
  .actions{flex-wrap:wrap}
  .btn{flex:1 1 auto;text-align:center}
  .exc li{grid-template-columns:auto 1fr;row-gap:2px}
  .exc-time{grid-column:2;justify-self:start}
}

@media(prefers-reduced-motion:reduce){
  .status .dot::after{animation:none}
  .btn{transition:none}
}

:focus-visible{outline:3px solid var(--petrol-2);outline-offset:2px;border-radius:6px}
