/* feriados/css/viz.css
 * Componentes visuais de estacoes/datas (viz_render.php). Light + dark-mode.
 * Flat, sem glassmorphism, sem borda lateral colorida. Mobile-first. */

/* ---- Barra de progresso da estacao ---- */
.viz-progress{margin:18px 0;padding:16px 18px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;}
.viz-progress-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:8px;}
.viz-progress-name{font-weight:700;color:#0f172a;font-size:1rem;}
.viz-progress-pct{font-variant-numeric:tabular-nums;font-weight:800;color:#1d4ed8;font-size:1.1rem;}
.viz-progress-track{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden;}
.viz-progress-fill{height:100%;background:linear-gradient(90deg,#38bdf8,#1d4ed8);border-radius:999px;transition:width .6s ease;}
.viz-progress-sub{margin-top:8px;font-size:.86rem;color:#475569;}
.viz-progress-ends{display:flex;justify-content:space-between;margin-top:4px;font-size:.74rem;color:#94a3b8;}

/* ---- Roda do ano ---- */
.viz-wheel{display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin:18px 0;}
.viz-wheel-svg{width:236px;height:236px;flex:0 0 auto;}
.viz-wheel-track{stroke:#eef2f7;}
.viz-wheel-seg{opacity:.45;}
.viz-wheel-seg--on{opacity:1;}
.viz-wheel-tick{stroke:#cbd5e1;stroke-width:1;}
.viz-wheel-mon{font-size:10px;font-weight:600;fill:#94a3b8;letter-spacing:.02em;}
.viz-wheel-mon--on{fill:#0f172a;font-weight:800;}
.viz-wheel-needle{stroke:#0f172a;stroke-width:2;stroke-linecap:round;}
.viz-wheel-hub{fill:#fff;stroke:#e2e8f0;stroke-width:1;}
.viz-wheel-c1{font-size:12px;font-weight:700;fill:#94a3b8;}
.viz-wheel-c2{font-size:18px;font-weight:800;fill:#0f172a;}
.viz-wheel-legend{display:flex;flex-direction:column;gap:6px;font-size:.86rem;color:#334155;}
.viz-wheel-legend span{display:inline-flex;align-items:center;gap:8px;}
.viz-wheel-legend i{width:14px;height:14px;border-radius:4px;display:inline-block;}

/* ---- Diagrama da inclinacao ---- */
.viz-tilt{margin:18px 0;padding:14px 16px;background:#0b1120;border-radius:14px;}
.viz-tilt-cap{font-size:.9rem;color:#cbd5e1;margin:0 0 8px;line-height:1.5;}
.viz-tilt-svg{width:100%;max-width:360px;height:auto;display:block;margin:0 auto;}
.viz-tilt-lbl{font-size:11px;fill:#94a3b8;}
.viz-tilt-cred{font-size:.66rem;color:#64748b;text-align:center;margin:6px 0 0;}
.viz-tilt-cred a{color:#94a3b8;text-decoration:none;}
.viz-tilt-cred a:hover{text-decoration:underline;}

/* ---- Horas de luz ---- */
.viz-daylight{margin:18px 0;padding:16px 18px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;}
.viz-daylight-head{font-weight:700;color:#0f172a;margin-bottom:12px;font-size:.95rem;}
.viz-day-row{display:grid;grid-template-columns:140px 1fr 52px;align-items:center;gap:10px;margin-bottom:8px;}
.viz-day-city{font-size:.84rem;color:#334155;}
.viz-day-bar{height:12px;background:#e2e8f0;border-radius:999px;overflow:hidden;}
.viz-day-bar span{display:block;height:100%;background:linear-gradient(90deg,#fde047,#f59e0b);border-radius:999px;}
.viz-day-val{font-size:.82rem;font-weight:700;color:#0f172a;text-align:right;font-variant-numeric:tabular-nums;}
.viz-daylight-note{margin-top:8px;font-size:.8rem;color:#64748b;}

/* ---- Mapa de clima por regiao (flagship) ---- */
.viz-climate{margin:18px 0;}
.viz-climate-seasons{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;}
.viz-climate-sbtn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#334155;font-size:.85rem;font-weight:600;cursor:pointer;}
.viz-climate-sbtn.is-active{background:#1d4ed8;border-color:#1d4ed8;color:#fff;}
.viz-climate-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start;}
.viz-map{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.viz-region{border:1px solid #e2e8f0;border-radius:10px;padding:12px 10px;text-align:left;cursor:pointer;color:#0f172a;min-height:62px;}
.viz-region.is-sel{outline:2px solid #0f172a;outline-offset:2px;}
.viz-region b{font-size:.82rem;font-weight:700;display:block;}
.viz-region span{font-size:1.05rem;font-weight:800;font-variant-numeric:tabular-nums;}
.viz-map-legend{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:.74rem;color:#64748b;}
.viz-map-legend i{flex:1;height:8px;border-radius:999px;background:linear-gradient(90deg,#3b82f6,#22d3ee,#fbbf24,#ef4444);}
.viz-detail{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:14px 16px;}
.viz-detail-rn{font-size:1rem;font-weight:700;color:#0f172a;}
.viz-detail-sn{font-size:.82rem;color:#64748b;margin-bottom:12px;}
.viz-detail-lbl{font-size:.74rem;color:#64748b;margin-bottom:4px;}
.viz-temp-track{position:relative;height:14px;background:#fff;border:1px solid #e2e8f0;border-radius:999px;margin-bottom:4px;}
.viz-temp-seg{position:absolute;top:0;bottom:0;border-radius:999px;}
.viz-detail-val{font-size:.86rem;color:#0f172a;margin-bottom:12px;}
.viz-rain-track{height:10px;background:#fff;border:1px solid #e2e8f0;border-radius:999px;overflow:hidden;margin-bottom:4px;}
.viz-rain-fill{height:100%;background:#3b82f6;border-radius:999px;}
.viz-detail-note{display:flex;gap:8px;font-size:.86rem;color:#0f172a;line-height:1.5;margin-top:6px;}
@media (max-width:640px){.viz-climate-grid{grid-template-columns:1fr;}.viz-day-row{grid-template-columns:110px 1fr 48px;}}

/* ---- Dark mode ---- */
body.dark-mode .viz-progress,
body.dark-mode .viz-daylight,
body.dark-mode .viz-detail{background:#0f172a;border-color:rgba(148,163,184,.2);}
body.dark-mode .viz-progress-name,body.dark-mode .viz-daylight-head,body.dark-mode .viz-detail-rn,body.dark-mode .viz-day-val,body.dark-mode .viz-wheel-c2,body.dark-mode .viz-region b{color:#e2e8f0;}
body.dark-mode .viz-progress-sub,body.dark-mode .viz-day-city,body.dark-mode .viz-wheel-legend{color:#cbd5e1;}
body.dark-mode .viz-progress-track,body.dark-mode .viz-day-bar{background:rgba(148,163,184,.18);}
body.dark-mode .viz-climate-sbtn{background:#1e293b;border-color:rgba(148,163,184,.25);color:#cbd5e1;}
body.dark-mode .viz-wheel-track{stroke:#334155;}
body.dark-mode .viz-wheel-tick{stroke:#475569;}
body.dark-mode .viz-wheel-mon{fill:#64748b;}
body.dark-mode .viz-wheel-mon--on{fill:#e2e8f0;}
body.dark-mode .viz-wheel-needle{stroke:#e2e8f0;}
body.dark-mode .viz-wheel-hub{fill:#1e293b;stroke:#334155;}
body.dark-mode .viz-wheel-c2{fill:#f1f5f9;}
body.dark-mode .viz-climate-sbtn.is-active{background:#2563eb;border-color:#2563eb;color:#fff;}
body.dark-mode .viz-region,body.dark-mode .viz-temp-track,body.dark-mode .viz-rain-track{border-color:rgba(148,163,184,.2);background:#1e293b;}
body.dark-mode .viz-region{color:#e2e8f0;}
body.dark-mode .viz-detail-note{color:#e2e8f0;}

/* ---- Galeria de foto da estacao ---- */
.viz-figure{margin:18px 0;}
.viz-figure-img{width:100%;height:auto;border-radius:14px;display:block;border:1px solid #e2e8f0;}
.viz-figure-cap{font-size:.8rem;color:#64748b;margin-top:8px;line-height:1.5;}
.viz-figure-cap a{color:#1d4ed8;text-decoration:none;}
.viz-figure-cap a:hover{text-decoration:underline;}
body.dark-mode .viz-figure-img{border-color:rgba(148,163,184,.2);}
body.dark-mode .viz-figure-cap{color:#94a3b8;}

/* ---- Calendario sazonal (agro/natureza/clima/cultura) ---- */
.viz-cal{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:18px 0;}
.viz-cal-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 15px;}
.viz-cal-tag{display:inline-block;font-size:.66rem;font-weight:700;color:#fff;padding:3px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;}
.viz-cal-t{font-weight:700;color:#0f172a;margin-top:9px;font-size:.95rem;}
.viz-cal-r{font-weight:400;color:#64748b;font-size:.8rem;}
.viz-cal-d{font-size:.85rem;color:#334155;margin-top:5px;line-height:1.55;}
.viz-cal-s{font-size:.72rem;color:#94a3b8;margin-top:7px;}
body.dark-mode .viz-cal-card{background:#0f172a;border-color:rgba(148,163,184,.2);}
body.dark-mode .viz-cal-t{color:#e2e8f0;}
body.dark-mode .viz-cal-d{color:#cbd5e1;}

/* ---- Roda do ano em paginas de data ---- */
.viz-wheel--date{align-items:flex-start;}
.viz-wheel-cap{margin:8px 0 0;font-size:.86rem;color:#334155;line-height:1.55;}
body.dark-mode .viz-wheel-cap{color:#cbd5e1;}
