:root{
  --sky-1:#1e3a8a;      /* bleu profond */
  --sky-2:#2563eb;      /* bleu */
  --sky-3:#38bdf8;      /* bleu clair */
  --sun:#fbbf24;        /* soleil */
  --sun-deep:#f59e0b;
  --coral:#fb7185;      /* alerte */
  --ink:#0f172a;        /* texte principal */
  --ink-soft:#475569;   /* texte secondaire */
  --line:#e2e8f0;
  --bg:#f6f8fc;         /* fond */
  --card:#ffffff;
  --radius:20px;
  --shadow:0 10px 30px -12px rgba(15,23,42,.18);
  --shadow-soft:0 4px 16px -6px rgba(15,23,42,.12);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --hero-grad:linear-gradient(160deg,var(--sky-1) 0%,var(--sky-2) 55%,var(--sky-3) 100%);
  --glow:rgba(251,191,36,.35);
  --anim-speed:.15s;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img,svg{display:block}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}


header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;gap:28px;height:68px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.25rem;letter-spacing:-.02em}
.logo .dot{width:34px;height:34px;border-radius:11px;background:linear-gradient(135deg,var(--sky-2),var(--sky-3));display:grid;place-items:center}
.logo .dot svg{width:20px;height:20px}
.nav-links{display:flex;gap:18px;align-items:center;font-weight:500;font-size:.95rem;color:var(--ink-soft);margin-left:8px}
.nav-search-toggle{border:none;background:transparent;color:var(--sky-2);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:.15s;font-size:0}
.nav-search-toggle svg{width:20px;height:20px}
.nav-search-toggle:hover{color:var(--ink)}
.nav-links a:hover{color:var(--sky-2);cursor:pointer}
.nav-spacer{flex:1}

.header-search-overlay{position:absolute;top:100%;left:0;right:0;display:none;justify-content:center;padding:16px 24px;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);box-shadow:0 18px 40px rgba(15,23,42,.14);z-index:60}
.header-search-overlay.active{display:flex}
.header-search-box{width:100%;max-width:560px}
.header-search-box .search{margin:0;max-width:none;box-shadow:0 20px 50px -20px rgba(0,0,0,.18);background:#fff;border-radius:16px;display:flex;align-items:center;padding:8px 8px 8px 18px}
.header-search-box .search svg{width:22px;height:22px;color:var(--ink-soft);flex:none}
.header-search-box .search input{flex:1;border:none;outline:none;font-family:var(--font);font-size:1.05rem;padding:12px;color:var(--ink);background:transparent}
.header-search-box .search .btn-primary{flex:none}


.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--ink)}
.menu-toggle svg{width:24px;height:24px}
.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(8px,8px)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}
.menu-toggle span{display:block;width:24px;height:2px;background:currentColor;margin:5px 0;transition:.3s}

.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 4px 12px rgba(0,0,0,.1);z-index:40;max-height:calc(100vh - 68px);overflow-y:auto}
.mobile-menu.active{display:block;animation:slideDown .3s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu a, .mobile-menu .mobile-search-item{display:block;width:100%;padding:16px 24px;font-weight:500;color:var(--ink-soft);border-bottom:1px solid var(--line);background:none;border:none;text-align:left;cursor:pointer;transition:.15s;font-family:var(--font);font-size:.95rem}
.mobile-menu a:hover, .mobile-menu .mobile-search-item:hover{color:var(--sky-2);background:#f6f8fc}
.mobile-search-item svg{width:18px;height:18px;margin-right:10px;vertical-align:middle;color:currentColor}

@media(max-width:920px){
  .menu-toggle{display:block}
  .nav-links{display:none}
}
.nav-cta{display:flex;gap:10px;align-items:center}
.btn{border:none;cursor:pointer;font-family:var(--font);font-weight:600;border-radius:12px;padding:10px 18px;font-size:.92rem;transition:.15s}
.btn-ghost{background:transparent;color:var(--ink-soft)}
.btn-ghost:hover{background:#eef2f9;color:var(--ink)}
.btn-primary{background:linear-gradient(135deg,var(--sky-2),var(--sky-3));color:#fff;box-shadow:0 6px 16px -6px rgba(37,99,235,.6)}
.btn-primary:hover{transform:translateY(-1px)}


.hero{background:var(--hero-grad);color:#fff;position:relative}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(900px 400px at 80% -10%,var(--glow),transparent 60%);pointer-events:none}
.hero-inner{position:relative;padding:64px 0 110px;text-align:center}
.hero h1{font-size:clamp(2rem,4.5vw,3.4rem);font-weight:800;letter-spacing:-.03em;line-height:1.05}
.hero p.sub{margin:16px auto 0;max-width:560px;font-size:1.1rem;color:rgba(255,255,255,.85)}
.search{position:relative;margin:34px auto 0;max-width:560px;background:#fff;border-radius:16px;display:flex;align-items:center;gap:12px;padding:8px 18px;box-shadow:0 20px 50px -20px rgba(0,0,0,.5)}
.search-suggestions{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:14px;box-shadow:0 18px 40px rgba(15,23,42,.18);overflow:hidden;z-index:55;max-height:380px;overflow-y:auto;display:none;text-align:left}
.search-suggestions.active{display:block}
.search-suggestion{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;border-bottom:1px solid #f1f5f9;text-decoration:none;color:var(--ink)}
.search-suggestion:last-child{border-bottom:none}
.search-suggestion:hover,.search-suggestion.active{background:#f1f5f9}
.search-suggestion .ss-pin{width:18px;height:18px;color:var(--ink-soft);flex:none}
.search-suggestion .ss-main{flex:1;min-width:0}
.search-suggestion .ss-city{font-weight:600;font-size:.98rem;color:var(--ink)}
.search-suggestion .ss-meta{font-size:.8rem;color:var(--ink-soft);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-suggestion .ss-cp{font-size:.85rem;color:var(--ink-soft);font-variant-numeric:tabular-nums;flex:none}
.search-empty,.search-loading{padding:14px 16px;color:var(--ink-soft);font-size:.92rem}
.search svg{width:22px;height:22px;color:var(--ink-soft);flex:none}
.search input{flex:1;min-width:0;border:none;outline:none;font-family:var(--font);font-size:1.05rem;padding:12px 0;color:var(--ink);background:transparent}
.search .btn-primary{flex:none;white-space:nowrap}

.header-search-overlay .search{margin:0;}
.quick{margin:20px auto 0;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.chip{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:.85rem;font-weight:500;padding:7px 14px;border-radius:999px;cursor:pointer;transition:.15s}
.chip:hover{background:rgba(255,255,255,.28)}
.chip a{display:block}


.float-cards{position:relative;margin:-64px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;z-index:5}
.mini{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);text-align:left;cursor:pointer;transition:.15s}
.mini:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.mini a{display:block}
.mini .city{font-weight:700;font-size:1rem}
.mini .reg{font-size:.78rem;color:var(--ink-soft);margin-top:2px}
.mini .row{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.mini .temp{font-size:2rem;font-weight:800;letter-spacing:-.02em}
.mini .ico{width:46px;height:46px}
.mini .meta{display:flex;gap:14px;margin-top:12px;font-size:.78rem;color:var(--ink-soft)}
.mini .meta span{display:flex;align-items:center;gap:5px}

/
section.block{padding:64px 0}
.sec-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:28px}
.sec-head h2{font-size:1.6rem;font-weight:800;letter-spacing:-.02em}
.sec-head p{color:var(--ink-soft);font-size:.95rem;margin-top:4px}
.sec-head a.more{color:var(--sky-2);font-weight:600;font-size:.9rem}


.regions{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.region{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;align-items:center;justify-content:space-between;transition:.15s;cursor:pointer;text-decoration:none}
.region:hover{border-color:var(--sky-3);box-shadow:var(--shadow);transform:translateY(-2px)}
.region .name{font-weight:600;font-size:.95rem}
.region .t{font-weight:800;color:var(--sky-2)}


.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feature{background:var(--card);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-soft);border:1px solid var(--line)}
.feature .ic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#dbeafe,#eff6ff);margin-bottom:16px}
.feature .ic svg{width:26px;height:26px;color:var(--sky-2)}
.feature h3{font-size:1.1rem;font-weight:700}
.feature p{color:var(--ink-soft);font-size:.92rem;margin-top:8px}

/
.breadcrumb{font-size:.85rem;color:var(--ink-soft);padding:22px 0 0}
.breadcrumb a:hover{color:var(--sky-2)}
.commune-hero-wrap{position:relative;margin-top:16px}
.commune-hero{background:var(--hero-grad);color:#fff;border-radius:24px;padding:34px;display:grid;grid-template-columns:1.1fr .9fr;gap:24px;position:relative;overflow:hidden}
.commune-hero::after{content:"";position:absolute;right:-40px;top:-40px;width:240px;height:240px;background:radial-gradient(circle,var(--glow),transparent 65%)}
.ch-left h1{font-size:2.2rem;font-weight:800;letter-spacing:-.02em}
.ch-left .place-meta{color:rgba(255,255,255,.85);font-size:.92rem;margin-top:4px}
.ch-now{display:flex;align-items:center;gap:20px;margin-top:24px}
.ch-now .big-ico{width:96px;height:96px}
.ch-now .big-temp{font-size:4.4rem;font-weight:800;letter-spacing:-.04em;line-height:1}
.ch-now .desc{font-size:1.05rem;font-weight:600}
.ch-now .feels{color:rgba(255,255,255,.82);font-size:.9rem}
.ch-stats{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:12px;align-content:center}
.stat{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.22);border-radius:14px;padding:14px 16px}
.stat .l{font-size:.75rem;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:6px}
.stat .v{font-size:1.3rem;font-weight:700;margin-top:4px}

.alert{display:flex;align-items:center;gap:12px;background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;border-radius:14px;padding:14px 18px;margin-top:18px;font-size:.9rem;font-weight:500}
.alert svg{width:22px;height:22px;flex:none}
.noalert{display:flex;align-items:center;gap:12px;padding:14px 18px;margin-top:18px;font-size:.9rem;font-weight:500;min-height:52px;border:1px solid transparent}


.strip15{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px}
.d15{flex:none;width:64px;text-align:center;padding:12px 6px;border-radius:13px;border:1px solid var(--line);transition:.15s}
.d15:hover{background:#f1f6ff;border-color:var(--sky-3)}
.d15.today{background:linear-gradient(160deg,#eff6ff,#dbeafe);border-color:var(--sky-3)}
.d15 .dn{font-size:.74rem;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.03em}
.d15 .dd{font-size:.72rem;color:var(--ink-soft)}
.d15 .ico{width:30px;height:30px;margin:8px auto}
.d15 .hi{font-weight:700;font-size:.9rem}
.d15 .lo{font-size:.8rem;color:var(--ink-soft)}


.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-top:22px;box-shadow:var(--shadow-soft)}
.panel h3{font-size:1.05rem;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.hours{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px}
.hour{flex:none;width:78px;text-align:center;padding:14px 8px;border-radius:14px;border:1px solid var(--line);transition:.15s}
.hour:hover{background:#f1f6ff;border-color:var(--sky-3)}
.hour .h{font-size:.8rem;color:var(--ink-soft);font-weight:600}
.hour .ico{width:34px;height:34px;margin:8px auto}
.hour .t{font-weight:700}
.hour .p{font-size:.72rem;color:var(--sky-2);margin-top:4px;display:flex;align-items:center;justify-content:center;gap:3px}

.chart-container{width:100%;margin:20px 0;background:linear-gradient(135deg, rgba(241,246,255,0.5), rgba(255,255,255,0));border-radius:12px;padding:16px;overflow:hidden}
.forecast-chart{width:100%;height:auto;min-height:320px}
.chart-legend{display:flex;gap:24px;margin-top:16px;font-size:.85rem;color:var(--ink-soft)}
.chart-legend span{display:flex;align-items:center;gap:8px}
.legend-dot{display:inline-block;width:12px;height:12px;border-radius:3px}

.days{display:flex;flex-direction:column}
.day{display:grid;grid-template-columns:120px 44px 1fr 90px;align-items:center;gap:14px;padding:14px 4px}
.day-wrap{border-bottom:1px solid var(--line)}
.day-wrap:last-child{border-bottom:none}
.day .dname{font-weight:600;font-size:.95rem}
.day .dname small{display:block;color:var(--ink-soft);font-weight:400;font-size:.78rem}
.day .ico{width:32px;height:32px}
.day .bar{height:7px;border-radius:999px;background:linear-gradient(90deg,#bae6fd,var(--sun),var(--sun-deep))}
.day .day-range{text-align:right;font-weight:600;font-size:.92rem}
.day .day-range small{color:var(--ink-soft);font-weight:400}

/* Styles pour le mini-tableau 3h sous chaque ligne jour */
.day-mini{padding:8px 4px 12px}
.mini-table th,.mini-table td{border:none;padding:4px 6px;font-size:11px}
.mini-table th:first-child,.mini-table td:first-child{color:var(--ink);text-align:left;padding-left:8px;font-weight:600}
.mini-table th{color:var(--ink-soft);font-weight:600}
.mini-table td{color:var(--ink-soft)}
.mini-table .mini-icons td{padding-top:6px;padding-bottom:6px}
.mini-table .mini-icons svg{width:20px;height:20px;vertical-align:middle}
.mini-table .mini-wind td svg{width:14px;height:14px}
.mini-table .mini-precip td{color:#2563eb;font-weight:700}
.mini-table tr{border-bottom:1px solid transparent}

@media(max-width:720px){
  .mini-table th:first-child{display:none}
  .mini-table td:first-child{display:none}
  .mini-table{font-size:10px}
}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:22px}
.map-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;min-height:380px}
.map-card .map{flex:1;min-height:300px;background:linear-gradient(135deg,#e0f2fe,#dbeafe);position:relative;z-index:0}
.map-card .cap{flex:none;padding:12px 18px;font-size:.85rem;color:var(--ink-soft);background:#fff;border-top:1px solid var(--line)}
.leaflet-container{font-family:var(--font);background:#dbeafe}

.meteo-ico{display:inline-block;vertical-align:middle}
.wind-arrow{display:inline-block;vertical-align:middle;color:var(--ink-soft);transform-origin:center}

/* Apparence nocturne des icônes météo : teinte plus sombre, saturation réduite */
.meteo-ico.night svg { filter: brightness(.72) saturate(.6) hue-rotate(-10deg); }
.meteo-ico.night { opacity: 0.95; }


.france-map-section{display:grid;grid-template-columns:1.7fr 1fr;gap:18px;margin-top:8px}
.france-map-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;min-height:520px}
.france-map{flex:1;min-height:460px;background:#dbeafe}
.france-map-cap{flex:none;padding:12px 18px;font-size:.85rem;color:var(--ink-soft);background:#fff;border-top:1px solid var(--line)}

.big-cities-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-soft);max-height:520px;overflow-y:auto}
.big-cities-card h3{font-size:1rem;font-weight:700;margin-bottom:12px}
.big-cities-card a{display:block;padding:7px 0;color:var(--ink);font-size:.88rem;text-decoration:none;border-bottom:1px solid #f1f5f9;transition:.15s}
.big-cities-card a:last-child{border-bottom:none}
.big-cities-card a:hover{color:var(--sky-2);padding-left:4px}

@media(max-width:920px){
  .france-map-section{grid-template-columns:1fr}
  .big-cities-card{max-height:none}
  .france-map-card{min-height:auto}
  .france-map{min-height:380px}
}


.fm-marker{background:transparent;border:none}
.fm-marker a{display:flex;flex-direction:column;align-items:center;text-decoration:none;transition:transform .15s}
.fm-marker a:hover{transform:scale(1.12);z-index:1000}
.fm-ico{display:grid;place-items:center;background:#fff;border-radius:50%;width:42px;height:42px;box-shadow:0 4px 10px rgba(15,23,42,.25);border:2px solid #fff}
.fm-ico svg{width:28px;height:28px}
.fm-t{font-weight:700;font-size:.72rem;color:#fff;background:rgba(15,23,42,.85);border-radius:10px;padding:1px 7px;margin-top:3px;white-space:nowrap}


:root{
  --vig-2:#eab308; --vig-3:#f97316; --vig-4:#dc2626;
}
.vigilance-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-top:16px;padding:24px 28px;background:var(--hero-grad);color:#fff;border-radius:24px;flex-wrap:wrap}
.vigilance-hero h1{font-size:1.9rem;font-weight:700;margin-bottom:4px}
.vigilance-hero .vig-sub{color:rgba(255,255,255,.85);font-size:.95rem}
.vigilance-updated{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.32);border-radius:999px;padding:6px 14px;font-size:.82rem;white-space:nowrap}

.vigilance-panel{padding:0;overflow:hidden}
.vigilance-toolbar{display:flex;flex-wrap:wrap;gap:10px;padding:16px 20px;border-bottom:1px solid var(--line);background:#fff}
.vig-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;cursor:pointer;font-size:.85rem;font-weight:600;color:#fff;user-select:none;transition:.15s;border:2px solid transparent}
.vig-chip input{accent-color:#fff;cursor:pointer}
.vig-chip:has(input:not(:checked)){opacity:.4}
.vig-chip--2{background:var(--vig-2)}
.vig-chip--3{background:var(--vig-3)}
.vig-chip--4{background:var(--vig-4)}

.vigilance-map{height:620px;background:#dbeafe}
@media(max-width:920px){.vigilance-map{height:480px}}
@media(max-width:560px){.vigilance-map{height:380px}}


.vigilance-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.vig-empty{color:var(--ink-soft);font-size:.92rem}
.vig-dpt{display:flex;flex-direction:column;gap:6px;padding:12px 14px;border-radius:12px;background:#fff;border-left:4px solid var(--line)}
.vig-dpt[data-level="2"]{border-left-color:var(--vig-2);background:#fffbeb}
.vig-dpt[data-level="3"]{border-left-color:var(--vig-3);background:#fff7ed}
.vig-dpt[data-level="4"]{border-left-color:var(--vig-4);background:#fef2f2}
.vig-dpt-name{font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:space-between;gap:8px}
.vig-dpt-code{font-size:.78rem;color:var(--ink-soft);font-weight:500}
.vig-dpt-types{display:flex;flex-wrap:wrap;gap:4px}
.vig-type{font-size:.72rem;padding:2px 8px;border-radius:999px;background:rgba(0,0,0,.06);color:var(--ink)}

.vig-help{display:grid;grid-template-columns:1fr;gap:10px;font-size:.92rem;color:var(--ink)}
.vig-help li{display:flex;align-items:flex-start;gap:12px;list-style:none}
.vig-dot{flex:none;width:14px;height:14px;border-radius:50%;margin-top:4px}
.vig-dot--2{background:var(--vig-2)}
.vig-dot--3{background:var(--vig-3)}
.vig-dot--4{background:var(--vig-4)}


.leaflet-tooltip.vig-tooltip{background:#1f2937;color:#fff;border:none;border-radius:8px;padding:8px 12px;font-size:.85rem;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.leaflet-tooltip.vig-tooltip::before{display:none}


.news{display:grid;grid-template-columns:repeat(4,250px);gap:20px;justify-content:center}
.ncard{display:block;width:250px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);transition:.18s;text-decoration:none;color:inherit}
.ncard:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.ncard-thumb{width:250px;height:140px;overflow:hidden;background:#f1f5f9;position:relative}
.ncard-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.ncard-thumb-fallback{width:100%;height:100%;background:linear-gradient(135deg,var(--sky-3),var(--sky-2));position:relative}
.ncard-thumb-fallback svg{position:absolute;right:14px;bottom:14px;width:42px;height:42px;color:rgba(255,255,255,.85)}
.ncard-body{padding:12px 14px 16px}
.ncard-tag{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:4px;color:#fff;background:#64748b}
.ncard-tag--tendance{background:#0ea5e9}
.ncard-tag--vigilance{background:#f97316}
.ncard-tag--climat{background:#475569}
.ncard-tag--alerte{background:#dc2626}
.ncard-tag--records{background:#ca8a04}
.ncard-tag--prevision{background:#6366f1}
.ncard-tag--tempete{background:#374151}
.ncard-tag--saison{background:#10b981}
.ncard h3{font-size:.95rem;font-weight:700;margin-top:8px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:1140px){
  .news{grid-template-columns:repeat(2,250px)}
}
@media(max-width:560px){
  .news{grid-template-columns:repeat(1,250px)}
}


.widget-promo{background:linear-gradient(135deg,#0f172a,#1e3a8a);color:#fff;border-radius:var(--radius);padding:30px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;margin-top:22px}
.widget-promo h3{font-size:1.3rem;font-weight:800}
.widget-promo p{color:rgba(255,255,255,.8);font-size:.92rem;margin-top:8px;max-width:460px}
.widget-promo .btn-primary{background:linear-gradient(135deg,var(--sun),var(--sun-deep));box-shadow:0 6px 16px -6px rgba(245,158,11,.6);white-space:nowrap}
.widget-preview{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:14px;padding:16px 20px;text-align:center;min-width:150px}
.widget-preview .wp-city{font-size:.8rem;color:rgba(255,255,255,.8)}
.widget-preview .wp-t{font-size:2rem;font-weight:800}
.widget-preview svg{width:36px;height:36px;margin:4px auto}


.fil-head{display:flex;align-items:end;justify-content:space-between;gap:12px;margin-bottom:18px}
.fil-title{display:flex;align-items:center;gap:10px}
.fil-title h2{font-size:1.6rem;font-weight:800;letter-spacing:-.02em}
.pulse{width:10px;height:10px;border-radius:50%;background:#22c55e;flex:none;animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 9px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.fil-rail{display:flex;gap:16px;overflow-x:auto;padding:2px 2px 10px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.fil-card{flex:0 0 330px;scroll-snap-align:start;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px 20px;box-shadow:var(--shadow-soft);transition:.15s}
.fil-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.fil-card .fmeta{display:flex;align-items:center;gap:8px;font-size:.74rem;color:var(--ink-soft);margin-bottom:8px}
.fil-card .when{font-weight:700;color:var(--sky-2)}
.fil-card .ftag{background:#eef2f9;padding:2px 9px;border-radius:999px;font-weight:600}
.fil-card .ftag.is-alert{background:#fff1f2;color:#9f1239}
.fil-card p{font-size:.9rem;line-height:1.55;color:var(--ink)}
.fil-card .author{font-size:.76rem;color:var(--ink-soft);margin-top:10px}
.fil-card .seemore{font-size:.8rem;color:var(--sky-2);font-weight:600;margin-top:8px;display:inline-block}
@media(max-width:560px){ .fil-card{flex:0 0 84%} .fil-title h2{font-size:1.35rem} }


.reg-hero{background:var(--hero-grad);color:#fff;border-radius:24px;margin-top:16px;padding:34px;position:relative}
.reg-hero::after{content:"";position:absolute;right:-30px;top:-30px;width:220px;height:220px;background:radial-gradient(circle,var(--glow),transparent 65%)}
.reg-hero h1{font-size:2rem;font-weight:800;letter-spacing:-.02em}
.reg-hero p{color:rgba(255,255,255,.85);margin-top:8px;max-width:560px}
.reg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.rcard{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;display:flex;align-items:center;gap:14px;transition:.15s;cursor:pointer;text-decoration:none}
.rcard:hover{border-color:var(--sky-3);box-shadow:var(--shadow-soft);transform:translateY(-2px)}
.rcard .rico{width:48px;height:48px;flex:none}
.rcard .rinfo{flex:1;min-width:0}
.rcard .rname{font-weight:700;font-size:.98rem;line-height:1.2}
.rcard .rsub{font-size:.76rem;color:var(--ink-soft);margin-top:2px}
.rcard .rtemp{text-align:right}
.rcard .rtemp .hi{font-weight:800;font-size:1.15rem;color:var(--sky-2)}
.rcard .rtemp .lo{font-size:.78rem;color:var(--ink-soft)}


.fav-btn{cursor:pointer;border:none;display:grid;place-items:center;transition:.2s;--heart-fill:none;font:inherit;outline:none}
.fav-btn svg{width:22px;height:22px;transition:.2s}
.fav-btn:focus-visible{outline:2px solid var(--sky-3);outline-offset:2px}

.fav-btn--hero{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.32);color:#fff;z-index:3}
.fav-btn--hero:hover{background:rgba(255,255,255,.30);transform:scale(1.06)}
.fav-btn--hero.is-fav{background:#fff;--heart-fill:#fb7185;color:#fb7185}

.fav-btn--header{display:none;background:transparent;color:var(--ink-soft);padding:8px;border-radius:8px}
.fav-btn--header:hover{color:#fb7185;background:#f1f5f9}
.fav-btn--header.is-fav{color:#fb7185;--heart-fill:#fb7185}

@media(max-width:920px){
  .fav-btn--hero{display:none}
  .fav-btn--header{display:inline-grid}
}


.cities-btn--hero{position:absolute;top:18px;right:70px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.32);color:#fff;z-index:3;cursor:pointer;display:grid;place-items:center;transition:.2s;outline:none;font:inherit}
.cities-btn--hero:hover{background:rgba(255,255,255,.30);transform:scale(1.06)}
.cities-btn--hero:focus-visible{outline:2px solid var(--sky-3);outline-offset:2px}
.cities-btn--hero svg{width:20px;height:20px}
.nearby-btn--hero{right:122px}
.cities-menu{position:absolute;top:74px;right:18px;width:min(460px,calc(100% - 36px));background:#fff;color:var(--ink);border-radius:16px;box-shadow:0 24px 60px -12px rgba(15,23,42,.4);padding:18px;z-index:10;display:none;max-height:70vh;overflow-y:auto}
.cities-menu.is-open{display:block;animation:cities-pop .18s ease-out}
@keyframes cities-pop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.cities-menu-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.cities-menu-head h3{font-size:.95rem;font-weight:700;color:var(--ink);margin:0;display:block}
.cities-menu-close{border:none;background:transparent;cursor:pointer;color:var(--ink-soft);padding:6px;border-radius:8px;display:grid;place-items:center;transition:.15s}
.cities-menu-close:hover{background:#f1f5f9;color:var(--ink)}
.cities-menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.cities-menu-grid a{display:block;padding:8px 10px;border-radius:8px;color:var(--ink);font-size:.88rem;text-decoration:none;transition:.15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cities-menu-grid a:hover{background:#f1f5f9;color:var(--sky-2)}

@media(max-width:920px){
  .cities-btn--hero{right:18px}
  .nearby-btn--hero{right:70px}
  .cities-menu-grid{grid-template-columns:repeat(2,1fr)}
  /* Hero empilé : plus de chevauchement possible, on n'a pas besoin de réserver l'espace. */
  .noalert{display:none}
}
@media(max-width:560px){
  .cities-menu{top:70px;width:calc(100% - 36px)}
  .cities-menu-grid{grid-template-columns:repeat(2,1fr)}
}

footer{background:#0b1220;color:#cbd5e1;margin-top:72px;padding:48px 0 32px}
.foot-bottom{border-top:1px solid #1e293b;margin-top:36px;padding-top:22px;font-size:.82rem;color:#94a3b8;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

@media(max-width:920px){
  .float-cards{grid-template-columns:repeat(2,1fr)}
  .regions{grid-template-columns:repeat(2,1fr)}
  .features{grid-template-columns:1fr}
  .nav-links{display:none}
  .commune-hero{grid-template-columns:1fr; padding:28px; gap:18px;}
  .two-col{grid-template-columns:1fr}
  .commune-hero::after{right:-20px;top:-20px;width:200px;height:200px;}
  .panel{padding:18px;}
  .chart-container{padding:10px;margin:14px 0;}
  .forecast-chart{min-height:240px;}
  .chart-legend{gap:16px; margin-top:12px;}
  .ch-left, .ch-stats{min-width:0}
  .ch-now{flex-direction:column;align-items:flex-start;gap:16px}
  .ch-now .big-ico{width:84px;height:84px}
  .ch-now .big-temp{font-size:3.2rem}
}
@media(max-width:720px){
  .commune-hero{padding:22px;}
  .ch-now .big-ico{width:72px;height:72px}
  .ch-now .big-temp{font-size:2.8rem}
}
@media(max-width:560px){
  .float-cards{grid-template-columns:1fr 1fr}
  .commune-hero{padding:18px;}
  .ch-left h1{font-size:1.8rem}
  .ch-now{gap:14px}
  .ch-now .big-temp{font-size:2.4rem}
  .ch-stats{grid-template-columns:1fr}
  .alert{flex-direction:column;align-items:flex-start}
  .panel{padding:18px}
}
@media(max-width:560px){
  .day{grid-template-columns:90px 32px 1fr 76px}
}

#wfx{position:fixed;inset:0;z-index:0;pointer-events:none;transition:background .6s ease}
main,footer{position:relative;z-index:1}
body[data-weather="sun"]{
  --sky-1:#ea580c; --sky-2:#f97316; --sky-3:#fbbf24;
  --sun:#fbbf24; --sun-deep:#f59e0b;
  --ink:#2a1f10; --ink-soft:#8a6f4a; --line:#f0e4cf;
  --bg:#fff7ea; --card:#fffdf8;
  --hero-grad:linear-gradient(160deg,#ea580c 0%,#f59e0b 48%,#7dd3fc 120%);
  --glow:rgba(255,237,160,.55);
}
body[data-weather="storm"]{
  --sky-1:#475569; --sky-2:#3b6ea5; --sky-3:#7d9bc1;
  --sun:#94a3b8;
  --ink:#1f2a37; --ink-soft:#5b6b7d; --line:#d8dfe8;
  --bg:#e9edf3; --card:#fbfcfe;
  --hero-grad:linear-gradient(160deg,#3f4c5a 0%,#5b6b7d 52%,#8fa3b8 115%);
  --glow:rgba(148,163,184,.28);
}
body[data-weather="night"]{
  --sky-1:#1e1b4b; --sky-2:#6366f1; --sky-3:#818cf8;
  --sun:#fcd34d;
  --ink:#e7ecf5; --ink-soft:#8b97a9; --line:#1f2937;
  --bg:#0a0e16; --card:#121826;
  --hero-grad:linear-gradient(160deg,#0f172a 0%,#1e1b4b 55%,#312e81 110%);
  --glow:rgba(129,140,248,.30);
  --shadow:0 10px 30px -12px rgba(0,0,0,.65);
  --shadow-soft:0 4px 16px -6px rgba(0,0,0,.5);
}
body[data-weather="night"] header.nav{background:rgba(13,20,32,.8)}

.ad-slot{margin:22px auto;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}
.ad-slot::before{content:"Publicité";display:block;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);opacity:.7;margin-bottom:6px}
.ad-slot ins.adsbygoogle{display:block;background:#f1f5f9;border:1px dashed var(--line);border-radius:8px}
.ad-slot--square ins.adsbygoogle{width:300px;height:250px}
.ad-slot--square{min-height:268px}
.ad-skyscraper{position:fixed;top:100px;left:calc(50vw - 890px);width:300px;z-index:5;display:none}
.ad-skyscraper::before{content:"Publicité";display:block;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);opacity:.7;margin-bottom:6px;text-align:center}
.ad-skyscraper ins.adsbygoogle{display:block;width:300px;height:600px;background:#f1f5f9;border:1px dashed var(--line);border-radius:8px}
@media(min-width:1800px){
  .ad-skyscraper{display:block}
}
.ad-slot--banner ins.adsbygoogle{display:block;width:100%;height:auto;min-height:90px}
.ad-slot--banner{min-height:108px}
