/* Meteo Raíz — Workspace (panel post-login) */
.ws-root { min-height: 100vh; background: var(--ink-50); }

/* topbar */
.ws-topbar { position: sticky; top: 0; z-index: 40; background: var(--white); border-bottom: 1px solid var(--border-soft); display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 12px 24px; }
.ws-topbar-l, .ws-topbar-r { display: flex; align-items: center; gap: 18px; }
.ws-logo { display: flex; align-items: center; gap: 9px; }
.ws-logo-tx { font-family: var(--font-display); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; color: var(--ink-900); white-space: nowrap; }
.ws-logo-tx b { color: var(--green-500); }
.ws-clock { display: flex; flex-direction: column; padding-left: 18px; border-left: 1px solid var(--border-soft); }
.ws-clock-t { font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--ink-900); line-height: 1; }
.ws-clock-s { color: var(--green-500); font-size: 15px; }
.ws-clock-d { font-size: 11.5px; color: var(--fg-subtle); text-transform: capitalize; margin-top: 3px; }
/* bloque de estado del API (última + próxima actualización) */
.ws-apibar { display: flex; flex-direction: column; gap: 4px; align-items: center; padding: 7px 16px; background: var(--ink-50); border: 1px solid var(--border-soft); border-radius: var(--r-md); }
.ws-api-row { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--fg-muted); white-space: nowrap; }
.ws-api-row b { color: var(--ink-800); font-weight: 700; }
.ws-api-fetched { color: var(--fg-subtle); font-size: 11px; }
.ws-api-next { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--fg-muted); white-space: nowrap; }
.ws-api-next b { color: var(--green-700); font-weight: 700; }
.ws-api-track { width: 60px; height: 5px; border-radius: var(--r-pill); background: var(--ink-150); overflow: hidden; margin-left: 2px; }
.ws-api-fill { display: block; height: 100%; background: var(--green-500); border-radius: var(--r-pill); transition: width 1s linear; }
.ws-api-paused { display: flex; align-items: center; gap: 5px; color: var(--fg-subtle); }
.ws-auto { display: inline-flex; align-items: center; gap: 8px; background: var(--ink-50); border: 1.5px solid var(--border); border-radius: var(--r-pill); padding: 8px 14px; font-size: 13px; font-weight: 600; color: var(--fg-muted); }
.ws-auto.on { background: var(--green-50); border-color: var(--green-200); color: var(--green-700); }
.ws-auto-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ink-300); }
.ws-auto.on .ws-auto-dot { background: var(--green-500); animation: wsPulse 1.6s ease-in-out infinite; }
@keyframes wsPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.35; } }
.ws-refresh { width: 38px; height: 38px; border-radius: var(--r-md); border: 1.5px solid var(--border); background: var(--white); display: grid; place-items: center; color: var(--ink-600); }
.ws-refresh:hover { background: var(--ink-50); color: var(--green-600); }
.ws-interval { display: inline-flex; align-items: center; gap: 6px; background: var(--ink-50); border: 1.5px solid var(--border); border-radius: var(--r-pill); padding: 0 8px 0 12px; height: 38px; }
.ws-interval select { border: none; background: transparent; font-family: var(--font-body); font-size: 13px; font-weight: 600; color: var(--ink-700); padding: 8px 4px; outline: none; cursor: pointer; }
.ws-interval select:disabled { color: var(--ink-300); cursor: not-allowed; }
.ws-user { display: flex; align-items: center; gap: 9px; }
.ws-user-n { font-size: 14px; font-weight: 600; color: var(--ink-800); max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ws-logout { width: 34px; height: 34px; border-radius: var(--r-sm); border: none; background: var(--ink-50); display: grid; place-items: center; color: var(--fg-muted); }
.ws-logout:hover { background: var(--risk-high-bg); color: var(--risk-high); }

/* alerta de actualización */
.ws-alert { display: flex; align-items: center; gap: 12px; background: var(--green-600); color: #fff; padding: 12px 24px; animation: demoFade var(--dur) var(--ease-out); }
.ws-alert-tx { font-size: 14px; line-height: 1.4; }
.ws-alert-sub { display: block; font-size: 12px; opacity: 0.85; margin-top: 2px; }
.ws-alert-x { margin-left: auto; background: rgba(255,255,255,0.15); border: none; width: 30px; height: 30px; border-radius: var(--r-sm); display: grid; place-items: center; }

/* nav */
.ws-nav { display: flex; align-items: center; gap: 8px; padding: 12px 24px; background: var(--white); border-bottom: 1px solid var(--border-soft); position: sticky; top: 63px; z-index: 30; overflow-x: auto; }
.ws-nav-b { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px; border-radius: var(--r-pill); border: 1.5px solid transparent; background: transparent; font-size: 14px; font-weight: 600; color: var(--fg-muted); white-space: nowrap; }
.ws-nav-b:hover { background: var(--ink-50); color: var(--ink-800); }
.ws-nav-b.on { background: var(--green-500); color: #fff; }
.ws-nav-upd { margin-left: auto; font-size: 12px; color: var(--fg-subtle); white-space: nowrap; }

.ws-main { max-width: 1240px; margin: 0 auto; padding: 26px 24px 80px; }
.ws-loading { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 80px 20px; color: var(--fg-muted); font-weight: 600; }
.ws-back { display: inline-flex; align-items: center; gap: 7px; background: none; border: none; color: var(--sky-600); font-weight: 600; font-size: 14px; margin-bottom: 16px; }

/* panel genérico */
.ws-panel { background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-xl); box-shadow: var(--shadow-sm); padding: 22px 24px; margin-bottom: 22px; }
.ws-panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.ws-panel-title { display: flex; align-items: center; gap: 9px; font-family: var(--font-display); font-weight: 700; font-size: 20px; letter-spacing: -0.01em; color: var(--green-700); }
.ws-panel-sub { font-size: 13px; color: var(--fg-muted); margin-top: 4px; max-width: 60ch; }
.ws-tag { display: inline-flex; align-items: center; color: #fff; font-size: 12px; font-weight: 700; letter-spacing: 0.02em; padding: 7px 14px; border-radius: var(--r-pill); }
.ws-tag--sm { padding: 4px 11px; font-size: 11px; }

/* stat boxes */
.ws-stats6 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 18px; }
.ws-stats4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 18px; }
.ws-stat { background: var(--white); border: 1px solid var(--border-soft); border-top: 3px solid var(--green-500); border-radius: var(--r-md); padding: 14px 16px; box-shadow: var(--shadow-xs); }
.ws-stat-l { font-size: 12px; color: var(--fg-muted); margin-bottom: 6px; }
.ws-stat-v { font-family: var(--font-display); font-weight: 700; font-size: 26px; color: var(--ink-900); letter-spacing: -0.01em; font-variant-numeric: tabular-nums; }

/* recomendación */
.ws-reco { background: var(--green-50); border: 1px solid var(--green-100); border-radius: var(--r-md); padding: 16px 18px; }
.ws-reco-title { display: flex; align-items: center; gap: 7px; font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--green-700); margin-bottom: 8px; }
.ws-reco-line { font-size: 13.5px; color: var(--ink-700); line-height: 1.55; margin: 0 0 4px; }
.ws-reco-note { display: flex; align-items: center; gap: 9px; font-size: 13px; color: var(--ink-700); margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--green-100); }
.ws-reco-bullet { width: 10px; height: 10px; border-radius: 50%; flex: none; }

/* weeks */
.ws-weeks-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 14px; margin-bottom: 14px; flex-wrap: wrap; }
.ws-legend { display: flex; gap: 14px; flex-wrap: wrap; }
.ws-legend-i { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--fg-muted); }
.ws-legend-sw { width: 13px; height: 13px; border-radius: 4px; }
.ws-weeks { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ws-week { background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-md); padding: 14px 16px; box-shadow: var(--shadow-xs); }
.ws-week--cur { border-color: var(--green-300); box-shadow: 0 0 0 2px var(--green-100); }
.ws-week-h { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--green-700); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.ws-week-now { font-size: 10px; font-weight: 700; background: var(--green-500); color: #fff; padding: 2px 7px; border-radius: var(--r-pill); text-transform: uppercase; letter-spacing: 0.04em; }
.ws-rainrow { display: flex; align-items: center; gap: 10px; margin-bottom: 7px; }
.ws-rainrow:last-child { margin-bottom: 0; }
.ws-rainrow-y { font-size: 12px; font-weight: 700; width: 58px; flex: none; }
.ws-rainrow-track { flex: 1; height: 9px; background: var(--ink-100); border-radius: var(--r-pill); overflow: hidden; }
.ws-rainrow-fill { display: block; height: 100%; border-radius: var(--r-pill); transition: width var(--dur) var(--ease-out); }
.ws-rainrow-v { font-family: var(--font-data); font-size: 12px; font-weight: 700; color: var(--ink-800); width: 62px; text-align: right; flex: none; font-variant-numeric: tabular-nums; }

/* exec summary */
.ws-exec-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.ws-exec-card { background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 16px; box-shadow: var(--shadow-xs); }
.ws-exec-name { display: flex; align-items: center; gap: 7px; font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--ink-900); margin-bottom: 8px; }
.ws-exec-stats { display: flex; flex-direction: column; gap: 8px; margin: 12px 0; }
.ws-mini-l { font-size: 11px; color: var(--fg-subtle); }
.ws-mini-v { font-family: var(--font-display); font-weight: 700; font-size: 18px; color: var(--ink-900); font-variant-numeric: tabular-nums; }
.ws-mini-v2 { font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--ink-900); font-variant-numeric: tabular-nums; }
.ws-exec-proj { display: grid; grid-template-columns: repeat(5, 1fr); gap: 5px; margin: 12px 0; }
.ws-proj-chip { background: var(--ink-50); border-radius: var(--r-sm); padding: 7px 3px; text-align: center; }
.ws-proj-chip span { display: block; font-size: 9px; color: var(--fg-subtle); margin-bottom: 2px; }
.ws-proj-chip b { font-family: var(--font-data); font-size: 12px; color: var(--ink-800); }
.ws-exec-years { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; padding-top: 10px; border-top: 1px solid var(--border-soft); }
.ws-year-chip { text-align: center; }
.ws-year-chip span { display: block; font-size: 10px; color: var(--fg-subtle); }
.ws-year-chip b { font-family: var(--font-display); font-size: 15px; color: var(--ink-800); }

/* top critical days */
.ws-top-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.ws-top-card { background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 14px; box-shadow: var(--shadow-xs); }
.ws-top-name { display: flex; align-items: center; gap: 6px; font-family: var(--font-display); font-weight: 700; font-size: 15px; color: var(--green-700); margin-bottom: 10px; }
.ws-top-row { display: flex; align-items: center; gap: 9px; padding: 6px 0; border-bottom: 1px solid var(--border-soft); }
.ws-top-row:last-child { border: none; }
.ws-top-dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.ws-top-date { font-size: 12.5px; color: var(--ink-700); }
.ws-top-mm { margin-left: auto; font-family: var(--font-data); font-weight: 700; font-size: 12.5px; color: var(--ink-900); }

/* zonas manager */
.ws-zh { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.ws-empty { text-align: center; padding: 60px 20px; color: var(--fg-muted); display: flex; flex-direction: column; align-items: center; gap: 14px; }
.ws-empty-demo { background: none; border: none; padding: 2px 4px; margin-top: -4px; color: var(--sky-600, #2563b8); font: inherit; font-size: 13px; cursor: pointer; text-decoration: underline; text-underline-offset: 3px; }
.ws-empty-demo:hover { color: var(--green-600); }
.ws-zgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.ws-zcard { background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 18px; box-shadow: var(--shadow-sm); cursor: pointer; transition: all var(--dur) var(--ease-out); }
.ws-zcard:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.ws-zcard-h { display: flex; align-items: center; justify-content: space-between; }
.ws-zcard-acts { display: flex; gap: 2px; }
.ws-zcard-name { display: flex; align-items: center; gap: 7px; font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--ink-900); }
.ws-zcard-x { background: none; border: none; padding: 5px; border-radius: var(--r-sm); }
.ws-zcard-x:hover { background: var(--ink-100); }
.ws-zcard-noprov { color: var(--risk-med-fg); font-weight: 600; }
.ws-prov-row { display: flex; gap: 8px; align-items: stretch; margin-bottom: 4px; }
.ws-detect { display: inline-flex; align-items: center; gap: 7px; background: var(--green-50); border: 1.5px solid var(--green-200); border-radius: var(--r-md); padding: 0 14px; font-size: 13px; font-weight: 600; color: var(--green-700); white-space: nowrap; }
.ws-detect:hover { background: var(--green-100); }
.ws-detect:disabled { opacity: 0.6; }
.ws-zcard-sub { font-size: 12px; color: var(--fg-subtle); margin: 4px 0 14px; }
.ws-zcard-body { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.ws-zcard-stat { display: flex; flex-direction: column; }
.ws-zcard-mm { font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--ink-900); font-variant-numeric: tabular-nums; white-space: nowrap; }
.ws-zcard-loading { display: flex; justify-content: center; padding: 10px; }
.ws-zcard-foot { display: flex; align-items: center; gap: 5px; font-size: 12.5px; font-weight: 600; color: var(--sky-600); margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--border-soft); }

/* tira de condición actual (clima en vivo) en la tarjeta de zona */
.ws-zwx { display: flex; align-items: center; gap: 11px; margin: 12px 0 2px; padding: 9px 12px; border-radius: var(--r-md); background: linear-gradient(135deg, #E9F2FB 0%, #F4F9FD 100%); border: 1px solid #E0ECF7; }
.ws-zwx-tx { display: flex; flex-direction: column; line-height: 1.12; min-width: 0; }
.ws-zwx-temp { font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--ink-900); font-variant-numeric: tabular-nums; }
.ws-zwx-sky { font-size: 11.5px; color: var(--fg-subtle); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ===== mini-escena de clima animada (WeatherAnim) ===== */
.wx { position: relative; flex: none; overflow: hidden; }
.wx-sun { position: absolute; border-radius: 50%; background: radial-gradient(circle at 35% 32%, #FFE6A0, #F4A93A); }
.wx--clear .wx-sun { width: 50%; height: 50%; left: 25%; top: 25%; box-shadow: 0 0 12px rgba(244,169,58,0.5); animation: wx-pulse 3.2s ease-in-out infinite; }
.wx--partly .wx-sun { width: 44%; height: 44%; left: 8%; top: 6%; box-shadow: 0 0 9px rgba(244,169,58,0.5); animation: wx-pulse 3.2s ease-in-out infinite; }
.wx--night .wx-sun { background: radial-gradient(circle at 38% 35%, #DCE6F5, #9FB2D0); box-shadow: 0 0 0 1px rgba(120,140,175,0.22), 0 0 8px rgba(150,170,205,0.45); }
.wx-rays { position: absolute; inset: -36%; border-radius: 50%; background: repeating-conic-gradient(from 0deg, rgba(244,169,58,0.55) 0deg 2.4deg, transparent 2.4deg 30deg); -webkit-mask: radial-gradient(circle, transparent 53%, #000 55%, #000 72%, transparent 74%); mask: radial-gradient(circle, transparent 53%, #000 55%, #000 72%, transparent 74%); animation: wx-spin 18s linear infinite; }
.wx-cloud { position: absolute; --wx-cloud: #fff; background: var(--wx-cloud); border-radius: 999px; box-shadow: 0 2px 4px rgba(40,70,100,0.16); animation: wx-bob 4.2s ease-in-out infinite; }
.wx--partly .wx-cloud { width: 56%; height: 20%; left: 36%; top: 60%; }
.wx--cloudy .wx-cloud, .wx--drizzle .wx-cloud, .wx--rain .wx-cloud, .wx--storm .wx-cloud { width: 66%; height: 22%; left: 17%; top: 30%; }
.wx--rain .wx-cloud, .wx--storm .wx-cloud { --wx-cloud: #EDF1F6; }
.wx--night .wx-cloud { --wx-cloud: #D7DEEA; }
.wx-cloud::before, .wx-cloud::after { content: ""; position: absolute; background: var(--wx-cloud); border-radius: 50%; }
.wx-puff { position: absolute; background: var(--wx-cloud); border-radius: 50%; }
.wx-puff--1 { width: 52%; height: 215%; left: 11%; top: -122%; }
.wx-puff--2 { width: 40%; height: 168%; left: 47%; top: -84%; }
.wx-rain { position: absolute; inset: 0; }
.wx-drop { position: absolute; top: 56%; width: 5.5%; height: 20%; border-radius: 3px; background: #5C95D6; animation: wx-fall 0.9s linear infinite; }
.wx--drizzle .wx-drop { background: #8AB4E2; height: 14%; animation-duration: 1.1s; }
.wx-bolt { position: absolute; left: 45%; top: 56%; width: 19%; height: 38%; background: #F6B73C; clip-path: polygon(58% 0, 6% 56%, 44% 56%, 30% 100%, 96% 38%, 50% 38%); filter: drop-shadow(0 0 3px rgba(246,183,60,0.85)); animation: wx-flash 2.4s ease-in-out infinite; }
@keyframes wx-spin { to { transform: rotate(360deg); } }
@keyframes wx-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.07); } }
@keyframes wx-bob { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(7%); } }
@keyframes wx-fall { 0% { transform: translateY(-30%); opacity: 0; } 25% { opacity: 1; } 100% { transform: translateY(130%); opacity: 0; } }
@keyframes wx-flash { 0%, 100% { opacity: 0.85; } 12% { opacity: 0.35; } 20%, 26% { opacity: 1; } 23% { opacity: 0.5; } }
@media (prefers-reduced-motion: reduce) { .wx-sun, .wx-rays, .wx-cloud, .wx-drop, .wx-bolt { animation: none !important; } }

/* ranking */
.ws-ranklist { display: flex; flex-direction: column; gap: 8px; }
.ws-rank-row { display: flex; align-items: center; gap: 14px; padding: 12px 14px; border-radius: var(--r-md); background: var(--ink-50); }
.ws-rank-row--lg { background: var(--white); border: 1px solid var(--border-soft); padding: 16px; box-shadow: var(--shadow-xs); }
.ws-rank-n { width: 34px; height: 34px; border-radius: var(--r-sm); background: var(--green-600); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 13px; flex: none; }
.ws-rank-name { display: flex; flex-direction: column; }
.ws-rank-name b { font-size: 15px; color: var(--ink-900); }
.ws-rank-name span { font-size: 12px; color: var(--fg-subtle); }
.ws-rank-lv { margin-left: auto; display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; }
.ws-rank-dot { width: 8px; height: 8px; border-radius: 50%; }
.ws-rank-v { text-align: right; min-width: 90px; }
.ws-rank-v b { font-family: var(--font-display); font-size: 16px; color: var(--ink-900); }
.ws-rank-v span { display: block; font-size: 11px; color: var(--fg-subtle); }

/* el niño */
.ws-nino-critical { background: var(--white); border: 2px solid var(--risk-high); border-radius: var(--r-md); padding: 12px 16px; min-width: 180px; }
.ws-nino-critical-name { font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--ink-900); margin: 2px 0; }
.ws-nino-mapwrap { display: grid; grid-template-columns: 1.3fr 1fr; gap: 22px; margin-bottom: 22px; }
.ws-leaflet { height: 480px; border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--border); position: relative; z-index: 0; }
.ws-map-tip { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 2px 9px; font-family: var(--font-body); font-size: 11px; font-weight: 700; color: var(--ink-800); box-shadow: var(--shadow-sm); }
.ws-map-tip::before { display: none; }
.leaflet-container { font-family: var(--font-body); }
.ws-nino-rank { margin: 0; }
.ws-nino-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.ws-nino-card { background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-lg); padding: 16px; box-shadow: var(--shadow-xs); }
.ws-nino-card-h { display: flex; align-items: center; justify-content: space-between; }
.ws-nino-card-name { display: flex; align-items: center; gap: 6px; font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--ink-900); margin-top: 8px; }
.ws-nino-anom { font-family: var(--font-display); font-weight: 700; font-size: 32px; color: var(--ink-900); letter-spacing: -0.01em; }
.ws-anom-track { height: 8px; background: var(--ink-100); border-radius: var(--r-pill); overflow: hidden; margin: 8px 0 14px; }
.ws-anom-fill { display: block; height: 100%; border-radius: var(--r-pill); }
.ws-nino-card-stats { display: flex; flex-direction: column; gap: 8px; }
.ws-nino-card-stats > div { display: flex; align-items: center; justify-content: space-between; }
.ws-nino-card-note { font-size: 12px; color: var(--fg-muted); line-height: 1.45; border-left: 3px solid var(--green-500); padding-left: 10px; margin-top: 14px; }
.ws-nino-foot { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--border-soft); }
.ws-nino-foot-eq { font-size: 12px; color: var(--fg-subtle); margin-left: auto; }

/* presets */
.ws-presets { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.ws-preset { background: var(--ink-50); border: 1.5px solid var(--border); border-radius: var(--r-pill); padding: 7px 13px; font-size: 13px; font-weight: 600; color: var(--ink-700); }
.ws-preset:hover { background: var(--green-50); border-color: var(--green-200); color: var(--green-700); }

/* chip de cultivo (en tarjetas de zona y perfil) */
.ws-zcard-crop { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; padding: 4px 10px 4px 7px; border-radius: var(--r-pill); margin: 0 0 14px; line-height: 1; }
.ws-zcard .ws-zcard-crop { margin-top: -6px; }

/* selector de producción agrícola */
.ws-crop-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 14px; }
.ws-crop { display: flex; align-items: center; gap: 8px; background: var(--white); border: 1.5px solid var(--border); border-radius: var(--r-md); padding: 9px 10px; font-size: 13px; font-weight: 600; color: var(--ink-700); text-align: left; transition: all var(--dur) var(--ease); position: relative; }
.ws-crop:hover { border-color: var(--green-300); background: var(--green-50); }
.ws-crop.on { font-weight: 700; box-shadow: inset 0 0 0 1px currentColor; }
.ws-crop-ic { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border-radius: var(--r-sm); flex: none; }
.ws-crop-l { flex: 1; }
.ws-crop-ck { display: inline-flex; flex: none; }
@media (max-width: 560px) { .ws-crop-grid { grid-template-columns: repeat(2, 1fr); } }

@media (max-width: 1100px) {
  .ws-stats6, .ws-exec-grid, .ws-top-grid, .ws-zgrid, .ws-nino-cards, .ws-stats4 { grid-template-columns: repeat(2, 1fr); }
  .ws-nino-mapwrap { grid-template-columns: 1fr; }
  .ws-weeks { grid-template-columns: 1fr; }
}
@media (max-width: 1024px) {
  .ws-apibar { display: none; }
}
@media (max-width: 680px) {
  .ws-clock-d { display: none; }
  .ws-stats6, .ws-exec-grid, .ws-top-grid, .ws-zgrid, .ws-nino-cards, .ws-stats4, .ws-exec-proj { grid-template-columns: 1fr 1fr; }
  .ws-user-n { display: none; }
}

/* campana de notificaciones */
.ws-bell-wrap { position: relative; }
.ws-bell { position: relative; width: 38px; height: 38px; border-radius: var(--r-md); border: 1.5px solid var(--border); background: var(--white); display: grid; place-items: center; color: var(--ink-600); cursor: pointer; }
.ws-bell:hover { background: var(--ink-50); color: var(--green-600); }
.ws-bell.has { color: var(--green-600); border-color: var(--green-200); }
.ws-bell-badge { position: absolute; top: -5px; right: -5px; min-width: 17px; height: 17px; padding: 0 4px; border-radius: 9px; background: var(--risk-high); color: #fff; font-size: 10.5px; font-weight: 700; line-height: 1; display: grid; place-items: center; font-family: var(--font-display); border: 2px solid var(--white); }
.ws-notif-panel { position: absolute; top: 47px; right: 0; width: 344px; max-width: 88vw; background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-md); box-shadow: 0 18px 50px rgba(15, 40, 25, 0.16); z-index: 60; overflow: hidden; animation: wsNotifIn 0.14s ease; }
@keyframes wsNotifIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
.ws-notif-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; border-bottom: 1px solid var(--border-soft); }
.ws-notif-title { display: flex; align-items: center; gap: 7px; font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--ink-900); }
.ws-notif-clear { border: none; background: transparent; color: var(--fg-subtle); font-size: 12px; font-weight: 600; cursor: pointer; padding: 4px 6px; border-radius: var(--r-sm); }
.ws-notif-clear:hover { color: var(--risk-high); background: var(--risk-high-bg); }
.ws-notif-list { max-height: 62vh; overflow-y: auto; }
.ws-notif-empty { display: flex; flex-direction: column; align-items: center; gap: 9px; padding: 38px 16px; color: var(--fg-subtle); font-size: 13px; text-align: center; }
.ws-notif-item { display: flex; gap: 11px; padding: 12px 14px; border-bottom: 1px solid var(--border-soft); position: relative; }
.ws-notif-item:last-child { border-bottom: none; }
.ws-notif-item.unread { background: var(--green-50); }
.ws-notif-ic { width: 32px; height: 32px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0; }
.ws-notif-body { min-width: 0; flex: 1; }
.ws-notif-it { font-size: 13px; font-weight: 700; color: var(--ink-800); }
.ws-notif-zone { color: var(--green-600); font-weight: 600; }
.ws-notif-tx { font-size: 12px; color: var(--fg-muted); margin-top: 2px; line-height: 1.4; }
.ws-notif-time { display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--fg-subtle); margin-top: 5px; }
.ws-notif-dot { position: absolute; top: 14px; right: 12px; width: 8px; height: 8px; border-radius: 50%; }

/* ZoneOps — dashboard / alertas / recomendación / mapa por zona */
.zo-dash { display: grid; grid-template-columns: 1.1fr 2fr; gap: 16px; }
.zo-feature { background: var(--white); border: 1px solid var(--border-soft); border-radius: var(--r-lg); box-shadow: var(--shadow-xs); padding: 18px 20px; display: flex; flex-direction: column; }
.zo-feature-main { display: flex; align-items: center; gap: 18px; margin: 14px 0 16px; }
.zo-feature-foot { display: flex; gap: 16px; flex-wrap: wrap; margin-top: auto; padding-top: 14px; border-top: 1px solid var(--border-soft); }
.zo-feature-foot span { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 500; color: var(--fg-muted); }
.zo-tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.zo-tile { padding: 14px 15px; }
.zo-tile-ico { width: 34px; height: 34px; border-radius: var(--r-md); display: grid; place-items: center; }

.zo-alert-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.zo-alert { padding: 16px; }
.zo-alert-head { display: flex; align-items: center; gap: 10px; }
.zo-alert-ico { width: 36px; height: 36px; border-radius: var(--r-md); display: grid; place-items: center; }
.zo-alert-head .ac-badge { margin-left: auto; }
.zo-alert-title { font-family: var(--font-display); font-weight: 600; font-size: 16px; color: var(--ink-900); margin: 12px 0 6px; }
.zo-alert-time { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--fg-muted); margin-bottom: 7px; }
.zo-alert-desc { font-size: 13px; line-height: 1.5; color: var(--fg-muted); margin: 0; }

.zo-rec-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.zo-rec { padding: 16px; }
.zo-rec-ico { width: 40px; height: 40px; border-radius: var(--r-md); background: var(--green-50); display: grid; place-items: center; }
.zo-rec-title { font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--ink-900); margin: 12px 0 5px; }
.zo-rec-window { display: flex; align-items: center; gap: 6px; font-family: var(--font-display); font-weight: 600; font-size: 13.5px; color: var(--green-700); margin-bottom: 8px; }
.zo-rec-desc { font-size: 12.5px; line-height: 1.5; color: var(--fg-muted); margin: 0; }

.zo-map-chips { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.zo-map { height: 420px; }
.zo-map-legend { display: flex; align-items: center; gap: 16px; margin-top: 14px; flex-wrap: wrap; }
.zo-legend-items { display: flex; gap: 16px; flex-wrap: wrap; }
.zo-map-src { font-size: 11px; color: var(--fg-subtle); margin-left: auto; }

@media (max-width: 1100px) {
  .zo-dash { grid-template-columns: 1fr; }
  .zo-alert-grid { grid-template-columns: 1fr 1fr; }
  .zo-rec-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .zo-tiles { grid-template-columns: 1fr 1fr; }
  .zo-alert-grid, .zo-rec-grid { grid-template-columns: 1fr; }
}

/* ===== Dark mode: ajustes de superficies con colores fijos ===== */
html[data-theme="dark"] .nav { background: rgba(20,27,24,0.85); }
html[data-theme="dark"] .hero-sky { background:
  radial-gradient(900px 360px at 78% -8%, #15293a, transparent 60%),
  radial-gradient(700px 340px at 4% 8%, #16271d, transparent 55%),
  linear-gradient(180deg, #10160f 0%, var(--ink-50) 62%); }
html[data-theme="dark"] .hero-tag { background: var(--white); }
html[data-theme="dark"] .ws-leaflet { filter: brightness(0.86) contrast(1.04); }
html[data-theme="dark"] .leaflet-tile { filter: brightness(0.9); }
html[data-theme="dark"] .map-canvas { filter: brightness(0.8); }
html[data-theme="dark"] .ws-map-tip { background: var(--white); color: var(--ink-800); border-color: var(--ink-200); }
html[data-theme="dark"] .ws-nino-map { background: repeating-linear-gradient(45deg, #18221d, #18221d 10px, #141d18 10px, #141d18 20px); }

/* ===== Controles de tema + idioma en la barra ===== */
.ws-ctrl { display: inline-flex; align-items: center; gap: 8px; }
.ws-iconbtn { width: 38px; height: 38px; border-radius: var(--r-md); border: 1.5px solid var(--border); background: var(--white); display: grid; place-items: center; color: var(--ink-600); }
.ws-iconbtn:hover { background: var(--ink-50); color: var(--green-600); }
.ws-lang { position: relative; }
.ws-lang-btn { display: inline-flex; align-items: center; gap: 6px; height: 38px; padding: 0 12px; border-radius: var(--r-md); border: 1.5px solid var(--border); background: var(--white); color: var(--ink-700); font-size: 13px; font-weight: 600; }
.ws-lang-btn:hover { background: var(--ink-50); }
.ws-lang-menu { position: absolute; right: 0; top: calc(100% + 6px); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-md); box-shadow: var(--shadow-lg); padding: 5px; min-width: 150px; z-index: 60; }
.ws-lang-menu button { display: flex; align-items: center; gap: 8px; width: 100%; text-align: left; background: none; border: none; padding: 9px 11px; border-radius: var(--r-sm); font-size: 13.5px; font-weight: 500; color: var(--ink-700); }
.ws-lang-menu button:hover { background: var(--ink-50); }
.ws-lang-menu button.on { background: var(--green-50); color: var(--green-700); font-weight: 700; }
.ws-flag { font-size: 15px; line-height: 1; }
@media (max-width: 680px) { .ws-lang-btn span.ws-lang-tx { display: none; } }
