/* ============================================================
   Météo Montagne Conseils – style.css v1.2.0
   Design fidèle aux captures : conditions + scroll 7j + scroll heures + dots
   ============================================================ */

:root {
    --mmc-green:   #10b981;
    --mmc-blue:    #3b82f6;
    --mmc-orange:  #f59e0b;
    --mmc-red:     #ef4444;
    --mmc-gray:    #6b7280;
    --mmc-dark:    #111827;
    --mmc-light:   #f9fafb;
    --mmc-radius:  20px;
    --mmc-shadow:  0 2px 16px rgba(0,0,0,.08);
    --mmc-font:    inherit;
}

/* ---- Reset ---- */
.mmc-conditions-wrap *, .mmc-activites-grid *, .mmc-7j-block *,
.mmc-heures-block *, .mmc-comp-block *, .mmc-conseil-global *,
.mmc-creneau-block *, .mmc-scroll-outer * { box-sizing: border-box; }

/* ================================================================
   ERREUR
================================================================ */
.mmc-error {
    background: #fef2f2;
    border-left: 4px solid var(--mmc-red);
    border-radius: 10px;
    padding: 16px 20px;
    color: #7f1d1d;
    font-size: 0.95em;
}

/* ================================================================
   SCROLL HORIZONTAL – wrapper universel
   outer = clip Y, visible X
   rail  = flex nowrap + overflow-x:auto
   cartes = triple-lock width
================================================================ */
.mmc-scroll-outer {
    display: block;
    width: 100%;
    overflow-x: visible;
    overflow-y: hidden;
    padding-bottom: 4px;
}

.mmc-7j-rail,
.mmc-h-rail {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    gap: 12px;
    padding: 8px 2px 16px;
    scrollbar-width: none;    /* Firefox – on n'affiche pas la scrollbar native */
    touch-action: pan-x;
    cursor: grab;
}
.mmc-7j-rail:active,
.mmc-h-rail:active { cursor: grabbing; }

/* Masquer scrollbar webkit */
.mmc-7j-rail::-webkit-scrollbar,
.mmc-h-rail::-webkit-scrollbar { display: none; }

/* ================================================================
   DOTS DE NAVIGATION
================================================================ */
.mmc-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin: 6px 0 10px;
    min-height: 10px;
}

.mmc-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #d1d5db;
    transition: background 0.25s, transform 0.25s;
    cursor: pointer;
    flex-shrink: 0;
}

.mmc-dot.mmc-dot-active {
    background: var(--mmc-blue);
    transform: scaleX(2.8);
    border-radius: 4px;
}

/* ================================================================
   CONDITIONS EN DIRECT – design Image 3
================================================================ */
.mmc-conditions-wrap { margin: 0 0 10px; }

.mmc-conditions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
@media(max-width:640px) { .mmc-conditions-grid { grid-template-columns: 1fr; } }

.mmc-cond-card {
    background: #fff;
    border-radius: var(--mmc-radius);
    box-shadow: var(--mmc-shadow);
    padding: 24px 28px;
    position: relative;
    overflow: hidden;
}

/* En-tête */
.mmc-cond-header { margin-bottom: 18px; }
.mmc-cond-header strong { font-size: 1em; font-weight: 700; color: var(--mmc-dark); }

/* Hero : grande température + emoji décoratif */
.mmc-cond-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 24px;
}

.mmc-cond-hero-left { display: flex; flex-direction: column; gap: 4px; }

.mmc-cond-big-temp {
    font-size: 3.4em;
    font-weight: 800;
    color: var(--mmc-dark);
    line-height: 1;
    letter-spacing: -0.02em;
}

.mmc-cond-ressenti {
    font-size: 0.92em;
    color: var(--mmc-gray);
}

/* Emoji décoratif large en fond à droite */
.mmc-cond-hero-emoji {
    font-size: 4.5em;
    line-height: 1;
    opacity: 0.18;
    position: absolute;
    right: 20px;
    top: 50px;
    pointer-events: none;
    user-select: none;
}

/* Grille 3 colonnes x 2 lignes de métriques */
.mmc-cond-metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px 12px;
}

.mmc-cond-metric { display: flex; flex-direction: column; gap: 3px; }

.mmc-cond-metric-head {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.78em;
    color: var(--mmc-gray);
}

.mmc-cond-metric-icon { font-size: 1em; }

.mmc-cond-metric-val {
    font-size: 1.05em;
    font-weight: 700;
    color: var(--mmc-dark);
}

.mmc-cond-bar {
    height: 3px;
    background: #e5e7eb;
    border-radius: 99px;
    overflow: hidden;
    margin-top: 2px;
}

.mmc-cond-bar-fill {
    height: 100%;
    border-radius: 99px;
}

/* ================================================================
   GRILLE ACTIVITÉS – cartes avec photos
================================================================ */
.mmc-activites-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin: 4px 0 10px;
}
@media(max-width:900px) { .mmc-activites-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:520px) { .mmc-activites-grid { grid-template-columns: 1fr 1fr; gap:10px; } }

.mmc-act-card {
    position: relative;
    border-radius: var(--mmc-radius);
    overflow: hidden;
    min-height: 200px;
    background-size: cover;
    background-position: center;
    transition: transform 0.2s, box-shadow 0.2s;
    box-shadow: 0 2px 16px rgba(0,0,0,.15);
}
.mmc-act-card:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(0,0,0,.22); }

.mmc-act-overlay {
    position: absolute;
    inset: 0;
    border-radius: var(--mmc-radius);
}

.mmc-act-score-badge {
    position: absolute;
    top: 10px; right: 10px;
    width: 34px; height: 34px;
    border-radius: 50%;
    background: rgba(255,255,255,.92);
    color: var(--mmc-dark);
    font-weight: 800;
    font-size: 0.88em;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,.2);
    z-index: 2;
}
.mmc-act-hs { font-size: 0.7em; color: var(--mmc-gray); }

.mmc-act-content {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    padding: 14px 16px 16px;
    z-index: 2;
    color: #fff;
}

.mmc-act-title {
    font-size: 1.1em; font-weight: 800;
    margin: 0 0 4px; color: #fff;
    line-height: 1.2;
    text-shadow: 0 1px 4px rgba(0,0,0,.5);
    border: none; padding: 0;
}

.mmc-act-advice {
    font-size: 0.74em; color: rgba(255,255,255,.92);
    line-height: 1.4; margin: 0 0 10px;
    text-shadow: 0 1px 3px rgba(0,0,0,.4);
}

.mmc-act-bottom { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }

.mmc-act-statut {
    font-size: 0.68em; font-weight: 700;
    background: rgba(255,255,255,.15);
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 20px; padding: 3px 10px;
    color: #fff; text-transform: uppercase; letter-spacing: 0.05em;
}

.mmc-act-creneau { font-size: 0.68em; color: rgba(255,255,255,.75); }

/* ================================================================
   PRÉVISIONS 7 JOURS – cartes fixes dans scroll horizontal
================================================================ */
.mmc-7j-block { margin: 4px 0 6px; }

.mmc-7j-card {
    /* Triple-lock */
    flex: 0 0 140px !important;
    width: 140px !important;
    min-width: 140px !important;
    flex-shrink: 0 !important;
    scroll-snap-align: start;

    background: #fff;
    border-radius: 16px;
    padding: 16px 12px;
    text-align: center;
    box-shadow: 0 1px 8px rgba(0,0,0,.08);
    border-top: 3px solid transparent;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.mmc-7j-today { border-top-color: var(--mmc-green); background: #f0fdf4; }
.mmc-7j-good  { border-top-color: #86efac; }
.mmc-7j-bad   { border-top-color: var(--mmc-red); background: #fef2f2; }

.mmc-7j-header { display: flex; flex-direction: column; align-items: center; gap: 1px; }
.mmc-7j-dname  { font-weight: 700; font-size: 0.95em; color: var(--mmc-dark); }
.mmc-7j-date   { font-size: 0.75em; color: var(--mmc-gray); }
.mmc-7j-emoji  { font-size: 2.2em; line-height: 1; margin: 6px 0; }
.mmc-7j-cond   { font-size: 0.72em; color: var(--mmc-gray); line-height: 1.3; min-height: 2.4em; text-align: center; }

.mmc-7j-temps  { display: flex; gap: 8px; margin: 4px 0; align-items: baseline; }
.mmc-tmax      { font-weight: 700; color: #ef4444; font-size: 1.05em; }
.mmc-tmin      { color: #3b82f6; font-size: 0.9em; }

.mmc-7j-pp { width: 100%; display: flex; flex-direction: column; gap: 3px; align-items: center; font-size: 0.72em; color: #3b82f6; }
.mmc-pp-track { width: 100%; height: 3px; background: #e5e7eb; border-radius: 99px; overflow: hidden; }
.mmc-pp-bar   { height: 100%; border-radius: 99px; }

.mmc-7j-meta {
    display: flex; gap: 6px; flex-wrap: wrap;
    justify-content: center; font-size: 0.7em; color: var(--mmc-gray);
}

/* ================================================================
   PRÉVISIONS HEURE PAR HEURE – design Image 2
================================================================ */
.mmc-heures-block { margin: 4px 0 6px; }

.mmc-h-card {
    /* Triple-lock */
    flex: 0 0 155px !important;
    width: 155px !important;
    min-width: 155px !important;
    flex-shrink: 0 !important;
    scroll-snap-align: start;

    background: #fff;
    border-radius: 18px;
    padding: 18px 14px 16px;
    text-align: center;
    box-shadow: 0 1px 8px rgba(0,0,0,.07);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.mmc-h-now {
    background: #f0f4ff;
    border: 2px solid #c7d7fb;
    box-shadow: 0 2px 14px rgba(59,130,246,.12);
}

/* Heure – "Maintenant" en texte, sinon "16h" */
.mmc-h-time {
    font-size: 0.95em;
    font-weight: 700;
    color: var(--mmc-dark);
    margin-bottom: 2px;
}

.mmc-h-now .mmc-h-time { color: var(--mmc-blue); }

.mmc-h-emoji { font-size: 2.4em; line-height: 1; margin: 6px 0 4px; }

.mmc-h-temp {
    font-size: 1.9em;
    font-weight: 800;
    color: var(--mmc-dark);
    letter-spacing: -0.01em;
    line-height: 1;
}

.mmc-h-apt { font-size: 0.8em; color: var(--mmc-gray); margin-bottom: 4px; }

/* Ligne de 3 métriques avec icône + valeur */
.mmc-h-metrics {
    display: flex;
    gap: 10px;
    margin-top: 8px;
    padding-top: 10px;
    border-top: 1px solid #f3f4f6;
    width: 100%;
    justify-content: center;
}

.mmc-h-metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.mmc-h-mi { font-size: 1em; color: var(--mmc-gray); }
.mmc-h-mv { font-size: 0.72em; color: var(--mmc-dark); font-weight: 600; }

.mmc-h-uv { font-size: 0.72em; color: #f59e0b; font-weight: 600; margin-top: 4px; }

/* ================================================================
   COMPARAISON BAS / HAUT
================================================================ */
.mmc-comp-block { margin: 4px 0 10px; }

.mmc-comp-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
@media(max-width:540px) { .mmc-comp-grid { grid-template-columns: 1fr; } }

.mmc-comp-card {
    background: #fff;
    border-radius: var(--mmc-radius);
    box-shadow: var(--mmc-shadow);
    overflow: hidden;
}

.mmc-comp-header {
    padding: 18px 22px;
    background: #1e3a5f;
    color: #fff;
    display: flex; flex-direction: column; gap: 2px;
}
.mmc-comp-haut .mmc-comp-header { background: #064e3b; }
.mmc-comp-header strong { font-size: 1em; font-weight: 700; }
.mmc-comp-alt { font-size: 0.78em; opacity: 0.75; }

.mmc-comp-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 22px;
    border-bottom: 1px solid #f3f4f6;
    font-size: 0.88em;
}
.mmc-comp-row:last-child { border-bottom: none; }
.mmc-comp-label { color: var(--mmc-gray); }
.mmc-comp-val   { font-weight: 600; color: var(--mmc-dark); }
.mmc-nd         { color: #d1d5db; }

/* ================================================================
   CONSEIL GLOBAL
================================================================ */
.mmc-conseil-global {
    background: #fff;
    border-radius: var(--mmc-radius);
    box-shadow: var(--mmc-shadow);
    padding: 22px 26px;
    margin: 4px 0 10px;
}

.mmc-cg-header { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 14px; }
.mmc-cg-emoji  { font-size: 2.8em; line-height: 1; flex-shrink: 0; }
.mmc-cg-meta   { display: flex; flex-direction: column; gap: 6px; }
.mmc-cg-condition { font-size: 0.9em; color: var(--mmc-gray); }

.mmc-cg-temps { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.mmc-cg-temp-lieu {
    display: flex; align-items: center; gap: 6px;
    font-size: 1.3em; font-weight: 700; color: var(--mmc-dark);
}

.mmc-badge-lieu {
    font-size: 0.5em; font-weight: 600;
    background: #dbeafe; color: #1e40af;
    border-radius: 4px; padding: 2px 7px;
    text-transform: uppercase; letter-spacing: 0.03em;
}
.mmc-badge-haut { background: #dcfce7; color: #14532d; }

.mmc-cg-text { font-size: 0.95em; line-height: 1.6; color: #374151; margin: 0 0 12px; }

.mmc-cg-badge {
    display: inline-block; font-size: 0.85em;
    padding: 6px 14px; border-radius: 20px;
    background: #f3f4f6; color: #374151; margin-bottom: 10px;
}
.mmc-cg-badge-matin       { background:#dbeafe; color:#1e40af; }
.mmc-cg-badge-apres_midi  { background:#fef3c7; color:#92400e; }
.mmc-cg-badge-soir        { background:#ede9fe; color:#4c1d95; }
.mmc-cg-badge-journee     { background:#dcfce7; color:#14532d; }
.mmc-cg-badge-deconseille { background:#fee2e2; color:#7f1d1d; }

/* ================================================================
   MEILLEUR CRÉNEAU
================================================================ */
.mmc-creneau-block {
    background: #fff;
    border-radius: var(--mmc-radius);
    box-shadow: var(--mmc-shadow);
    padding: 20px 24px; margin: 4px 0 10px;
    border-left: 5px solid #d1d5db;
}
.mmc-creneau-matin       { border-left-color: #3b82f6; }
.mmc-creneau-apres_midi  { border-left-color: #f59e0b; }
.mmc-creneau-soir        { border-left-color: #8b5cf6; }
.mmc-creneau-journee     { border-left-color: var(--mmc-green); }
.mmc-creneau-deconseille { border-left-color: var(--mmc-red); }

.mmc-cr-main   { display: flex; align-items: center; gap: 14px; margin-bottom: 10px; }
.mmc-cr-icon   { font-size: 2.2em; }
.mmc-cr-label  { font-size: 0.82em; color: var(--mmc-gray); margin: 0 0 3px; }
.mmc-cr-value  { font-size: 1.4em; font-weight: 700; color: var(--mmc-dark); }
.mmc-cr-details{ display: flex; flex-wrap: wrap; gap: 12px; font-size: 0.9em; color: var(--mmc-gray); }

/* ================================================================
   ATTRIBUTION
================================================================ */
.mmc-attribution { font-size: 0.72em; color: #9ca3af; margin: 12px 0 0; line-height: 1.4; }
.mmc-attribution a { color: #6b7280; text-decoration: underline; }

/* ================================================================
   RESPONSIVE MOBILE
================================================================ */
@media(max-width:640px) {
    .mmc-cond-card       { padding: 18px 18px; }
    .mmc-cond-big-temp   { font-size: 2.8em; }
    .mmc-cond-hero-emoji { font-size: 3.5em; top: 40px; right: 14px; }
    .mmc-cond-metrics    { grid-template-columns: repeat(2,1fr); gap: 12px 10px; }
    .mmc-act-card        { min-height: 175px; }
    .mmc-7j-card         { flex: 0 0 120px !important; width: 120px !important; min-width: 120px !important; }
    .mmc-h-card          { flex: 0 0 135px !important; width: 135px !important; min-width: 135px !important; }
    .mmc-h-emoji         { font-size: 2em; }
    .mmc-h-temp          { font-size: 1.6em; }
}

@media(max-width:380px) {
    .mmc-7j-card { flex: 0 0 108px !important; width: 108px !important; min-width: 108px !important; }
    .mmc-h-card  { flex: 0 0 120px !important; width: 120px !important; min-width: 120px !important; }
    .mmc-activites-grid  { grid-template-columns: 1fr; }
    .mmc-conditions-grid { grid-template-columns: 1fr; }
}
