/* Police par défaut : OpenDyslexic depuis CDN (déclarée via la feuille min.css) */
html, body {
  font-family: "OpenDyslexic", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}

/* === Variables & base === */
:root {
  --bg-top: #7ec8ff;
  --bg-bottom: #fef6c7;
  --sun: #ffc107;
  --card-bg: rgba(255, 255, 255, 0.75);
  --text: #16334a;
  --muted: #446075;
  --ring: #ffd54f;
  --shadow: 0 12px 28px rgba(17, 40, 61, 0.15);
  --radius: 16px;
  --focus: #0f2a3c;
  --focus-offset: 3px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0; height: 100%;
  color: var(--text);
  line-height: 1.6;
}

/* Lien d’évitement (accessibilité) */
.skip-link {
  position: absolute; left: -9999px; top: auto;
}
.skip-link:focus-visible {
  left: 8px; top: 8px;
  padding: 8px 12px;
  background: white; color: black;
  border-radius: 6px; box-shadow: var(--shadow);
  outline: 3px solid var(--focus);
}

/* Focus visible générique */
:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: var(--focus-offset);
}

body {
  background: linear-gradient(180deg, var(--bg-top), var(--bg-bottom));
  display: flex; flex-direction: column; gap: 16px;
}

/* HEADER / FOOTER */
.app-header, .app-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px clamp(16px, 4vw, 32px);
  flex-wrap: wrap; gap: 12px;
}

.location {
  display: flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: clamp(20px, 3vw, 28px);
}
.location .dept {
  background: var(--ring); color: #5a3d00; border-radius: 999px; padding: 4px 10px;
}

.badge {
  background: var(--card-bg);
  border: 1px solid rgba(255, 193, 7, .45);
  padding: 8px 12px; border-radius: 10px; font-weight: 600;
  backdrop-filter: blur(6px); box-shadow: var(--shadow);
}

/* MAIN */
.app-main {
  display: grid; gap: 24px;
  padding: 0 clamp(16px, 4vw, 32px) 24px;
}

.current {
  display: grid; grid-template-columns: 1.1fr .9fr; gap: 24px; align-items: stretch;
}
@media (max-width: 860px) { .current { grid-template-columns: 1fr; } }

.sky {
  position: relative; overflow: hidden; border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.2), rgba(255,255,255,.05));
  min-height: 260px; box-shadow: var(--shadow);
}

/* Soleil */
.sun {
  position: absolute; left: 50%; top: 46%; transform: translate(-50%, -50%);
  width: 160px; height: 160px; background: var(--sun); border-radius: 50%;
  box-shadow: 0 0 80px 20px rgba(255,193,7,.45), 0 0 120px 40px rgba(255,193,7,.25);
  animation: float 10s ease-in-out infinite;
}
@keyframes float {
  0%,100% { transform: translate(-50%, -52%) }
  50%     { transform: translate(-50%, -48%) }
}

/* Rayons */
.ray {
  position: absolute; left: 50%; top: 50%;
  width: 4px; height: 110px;
  background: linear-gradient(to bottom, rgba(255,193,7,.9), rgba(255,193,7,0));
  transform-origin: top center; border-radius: 2px; opacity: .8;
}
.r1{ transform:translate(-50%,-100%) rotate(0deg) }
.r2{ transform:translate(-50%,-100%) rotate(30deg) }
.r3{ transform:translate(-50%,-100%) rotate(60deg) }
.r4{ transform:translate(-50%,-100%) rotate(90deg) }
.r5{ transform:translate(-50%,-100%) rotate(120deg) }
.r6{ transform:translate(-50%,-100%) rotate(150deg) }
.r7{ transform:translate(-50%,-100%) rotate(180deg) }
.r8{ transform:translate(-50%,-100%) rotate(210deg) }
.r9{ transform:translate(-50%,-100%) rotate(240deg) }
.r10{ transform:translate(-50%,-100%) rotate(270deg) }
.r11{ transform:translate(-50%,-100%) rotate(300deg) }
.r12{ transform:translate(-50%,-100%) rotate(330deg) }

/* Nuages */
.cloud {
  position: absolute; background: rgba(255,255,255,.85); filter: blur(1px);
  width: 140px; height: 46px; border-radius: 28px;
  box-shadow: 20px -12px 0 10px rgba(255,255,255,.85), -18px -10px 0 14px rgba(255,255,255,.85);
  opacity: .7;
}
.c1{ bottom: 24px; left: 24px; animation: drift 48s linear infinite; }
.c2{ top: 18px; right: 24px; width: 180px; height: 54px; animation: drift 60s linear infinite reverse; }
@keyframes drift {
  0% { transform: translateX(-10%) }
  50% { transform: translateX(10%) }
  100% { transform: translateX(-10%) }
}

/* Carte info */
.current-info {
  background: var(--card-bg); border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 20px;
  display: grid; grid-template-columns: auto 1fr; gap: 16px 24px; align-content: center;
  backdrop-filter: blur(8px);
}

.temp {
  grid-row: 1 / span 2;
  font-size: clamp(42px, 8vw, 72px);
  font-weight: 800; color: #0f2a3c; line-height: 1;
}
.temp .unit { font-size: .5em; color: var(--muted); margin-left: 6px }

.meta { display: grid; gap: 8px; align-content: center }
.meta .line { color: var(--muted) }
.meta .label { color: #0f2a3c; font-weight: 600; margin-right: 6px }

/* Prévisions */
.forecast h2 { margin: 0 0 12px; font-size: clamp(18px, 2.6vw, 24px); }

.grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.card {
  background: var(--card-bg); border-radius: 14px; padding: 14px;
  box-shadow: var(--shadow);
  display: grid; gap: 10px; align-content: center; text-align: center;
}
.card .day { font-weight: 700; color: #0f2a3c }
.card .icon { font-size: 28px }
.card .t { display: flex; gap: 10px; justify-content: center }
.card .t span { padding: 2px 8px; border-radius: 999px; font-weight: 700 }
.card .t .max { background: #ffe082; color: #5a3d00 }
.card .t .min { background: #cbe9ff; color: #104a78 }

/* Footer + liens */
.app-footer { gap: 12px; flex-wrap: wrap; color: var(--muted); font-size: 14px; }

.btn, .realweather, .github-link {
  min-height: 44px; min-width: 44px;
  display: inline-flex; align-items: center; justify-content: center;
}
.btn {
  appearance: none; border: none; background: #16334a; color: #fff;
  padding: 10px 14px; border-radius: 10px; box-shadow: var(--shadow); cursor: pointer; font-weight: 700;
}
.btn:hover { filter: brightness(1.05) }
.btn:active { transform: translateY(1px) }

/* Liens */
.realweather {
  background: #ffb300; color: #5a3d00 !important;
  padding: 10px 16px; border-radius: 10px; text-decoration: none; font-weight: 700; box-shadow: var(--shadow);
}
.github-link {
  background: #24292f; color: #fff !important;
  padding: 10px 16px; border-radius: 10px; font-weight: 700; text-decoration: none; box-shadow: var(--shadow);
}

/* Responsive */
@media (max-width: 600px) {
  .grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 400px) {
  .grid { grid-template-columns: 1fr; }
}
