/* Meteo Ponza — Widget styles
   Coastal Glass v3 + 0.3.0 G2 layout (container queries, 2 col ≥720px). */

.meteo-ponza {
    --mp-text:        #0c2f4f;
    --mp-text-soft:   #2a4d6d;
    --mp-text-mute:   #6e8aa3;
    --mp-accent:      #2c6fb1;
    --mp-accent-soft: #e8f1fb;
    --mp-live:        #34c77b;
    --mp-sun:         #f4a93b;
    --mp-bg:          #ffffff;
    --mp-bg-card:     #f7fafd;
    --mp-border:      #e6edf5;
    --mp-shadow:      0 24px 48px -20px rgba(20, 60, 110, 0.12),
                      0 4px 12px -4px rgba(20, 60, 110, 0.06);
    font-family: -apple-system, "Inter", "SF Pro Text", system-ui, sans-serif;
    -webkit-font-smoothing: antialiased;
    color: var(--mp-text);
    box-sizing: border-box;
}
.meteo-ponza *, .meteo-ponza *::before, .meteo-ponza *::after { box-sizing: inherit; }

/* ============ FULL ============ */

.meteo-ponza--full .mp-card {
    max-width: 960px;
    margin: 0 auto;
    background: linear-gradient(180deg, var(--mp-bg) 0%, var(--mp-bg-card) 100%);
    border: 1px solid var(--mp-border);
    border-radius: 24px;
    padding: 28px;
    box-shadow: var(--mp-shadow);
    container-type: inline-size;
    container-name: mp-card;
}

/* Layout G2: container queries adapt to parent width */
.meteo-ponza--full .mp-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@container mp-card (min-width: 720px) {
    .meteo-ponza--full .mp-grid {
        grid-template-columns: 3fr 2fr;
        gap: 28px;
    }
}
.meteo-ponza--full .mp-col { min-width: 0; }

.meteo-ponza--full .mp-top {
    display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: 18px;
}

.meteo-ponza .mp-loc {
    font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
    color: var(--mp-accent); margin-bottom: 8px;
    display: flex; align-items: center; gap: 8px;
}
.meteo-ponza .mp-live-dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--mp-live);
    box-shadow: 0 0 0 3px rgba(52, 199, 123, 0.18);
    animation: mp-pulse 2.4s ease-in-out infinite;
}
@keyframes mp-pulse {
    0%,100% { box-shadow: 0 0 0 3px rgba(52, 199, 123, 0.18); }
    50%     { box-shadow: 0 0 0 6px rgba(52, 199, 123, 0.06); }
}

.meteo-ponza--full .mp-temp {
    display: inline-flex; align-items: flex-start; gap: 4px;
    line-height: 1;
}
.meteo-ponza--full .mp-temp-num {
    font-size: 76px; font-weight: 250; letter-spacing: -0.04em; line-height: 1;
    color: var(--mp-text);
}
.meteo-ponza--full .mp-temp-unit {
    font-size: 26px; font-weight: 300; line-height: 1;
    padding-top: 8px; opacity: .55;
}
.meteo-ponza--full .mp-cond { font-size: 15px; color: var(--mp-text-soft); margin-top: 4px; font-weight: 500; }
.meteo-ponza--full .mp-cond span { color: var(--mp-text-mute); font-weight: 400; }

.meteo-ponza .mp-icon {
    width: 72px; height: 72px;
    background: radial-gradient(circle at 30% 30%, #fff8e1 0%, #ffe79a 50%, #f9c66b 100%);
    border-radius: 50%;
    box-shadow: 0 0 30px rgba(255,195,80,0.25), 0 8px 20px -6px rgba(244,169,59,0.2);
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
}
.meteo-ponza .mp-icon-emoji {
    font-size: 40px;
    line-height: 1;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.15));
}

.meteo-ponza .mp-stale-badge {
    background: #fff7ed; color: #9a4a00;
    border: 1px solid #ffd9a8;
    padding: 6px 12px; border-radius: 999px;
    font-size: 12px; font-weight: 600;
    display: inline-block; margin-bottom: 18px;
}

/* Stats panel: 6 cards auto-fit */
.meteo-ponza--full .mp-stats {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 8px;
    margin-bottom: 22px;
}
.meteo-ponza .mp-stat {
    background: var(--mp-bg-card);
    border: 1px solid var(--mp-border);
    border-radius: 14px;
    padding: 14px;
}
.meteo-ponza .mp-stat-label {
    font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--mp-text-mute); margin-bottom: 6px; font-weight: 600;
}
.meteo-ponza .mp-stat-value { font-size: 19px; font-weight: 600; color: var(--mp-text); letter-spacing: -0.01em; }
.meteo-ponza .mp-stat-unit { font-size: 12px; color: var(--mp-text-mute); font-weight: 400; margin-left: 2px; }
.meteo-ponza .mp-uv-peak {
    font-size: 10.5px;
    color: var(--mp-text-mute);
    margin-top: 4px;
    font-weight: 500;
}
.meteo-ponza .mp-stat--pollen .mp-stat-value { display: flex; align-items: center; gap: 6px; }

.meteo-ponza .mp-section {
    font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--mp-text-mute); margin: 4px 0 12px; font-weight: 600;
}

.meteo-ponza--full .mp-hourly {
    background: var(--mp-bg-card);
    border: 1px solid var(--mp-border);
    border-radius: 16px;
    padding: 16px;
    margin-bottom: 0;
    overflow: hidden;
}
.meteo-ponza .mp-chart-wrap { position: relative; height: 130px; margin-bottom: 8px; }
.meteo-ponza .mp-chart-svg { width: 100%; height: 100%; display: block; }
.meteo-ponza .mp-chart-line { fill: none; stroke: var(--mp-accent); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.meteo-ponza .mp-chart-dot { fill: var(--mp-bg); stroke: var(--mp-accent); stroke-width: 2; }
.meteo-ponza .mp-chart-dot-now { fill: var(--mp-accent); stroke: var(--mp-bg); stroke-width: 3; }
.meteo-ponza .mp-chart-label { font-size: 11px; font-weight: 700; fill: var(--mp-text); }
.meteo-ponza .mp-chart-now-line { stroke: var(--mp-accent); stroke-width: 1; stroke-dasharray: 3 3; opacity: .35; }

.meteo-ponza .mp-hours {
    display: grid; grid-template-columns: repeat(8, 1fr);
    padding-top: 10px;
    border-top: 1px solid var(--mp-border);
}
.meteo-ponza .mp-hour { text-align: center; }
.meteo-ponza .mp-hour-time { font-size: 10px; font-weight: 600; color: var(--mp-text-mute); letter-spacing: .04em; }
.meteo-ponza .mp-hour-icon { font-size: 16px; margin-top: 4px; line-height: 1; }
.meteo-ponza .mp-hour-rain {
    font-size: 9.5px;
    color: var(--mp-accent);
    margin-top: 3px;
    font-weight: 600;
    opacity: 0.85;
}

/* 7-day forecast list */
.meteo-ponza--full .mp-fc-list {
    background: var(--mp-bg-card);
    border: 1px solid var(--mp-border);
    border-radius: 16px;
    padding: 4px 0;
    margin-bottom: 16px;
}
.meteo-ponza .mp-day-row {
    display: grid;
    grid-template-columns: 28px 1fr auto auto auto;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--mp-border);
    font-size: 13px;
}
.meteo-ponza .mp-day-row:last-child { border-bottom: none; }
.meteo-ponza .mp-day-row.is-today { background: var(--mp-accent-soft); }
.meteo-ponza .mp-day-row.is-today:first-child { border-radius: 12px 12px 0 0; }
.meteo-ponza .mp-day-icon { font-size: 20px; line-height: 1; text-align: center; }
.meteo-ponza .mp-day-name { font-weight: 600; color: var(--mp-text); }
.meteo-ponza .mp-day-name .num { color: var(--mp-text-mute); font-weight: 400; margin-left: 4px; font-size: 12px; }
.meteo-ponza .mp-day-t { font-weight: 600; color: var(--mp-text); font-size: 13px; min-width: 60px; text-align: right; }
.meteo-ponza .mp-day-t .min { color: var(--mp-text-mute); font-weight: 400; margin-left: 5px; }
.meteo-ponza .mp-day-rain { font-size: 11px; color: var(--mp-accent); font-weight: 600; min-width: 48px; text-align: right; }
.meteo-ponza .mp-day-sun { font-size: 11px; color: var(--mp-sun); font-weight: 600; min-width: 38px; text-align: right; }

/* Marine + astro mini-grids */
.meteo-ponza--full .mp-marine,
.meteo-ponza--full .mp-astro {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin-bottom: 16px;
}
.meteo-ponza .mp-mi {
    background: var(--mp-bg-card);
    border: 1px solid var(--mp-border);
    border-radius: 12px;
    padding: 10px 12px;
}
.meteo-ponza .mp-mi-label {
    font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
    color: var(--mp-text-mute); margin-bottom: 4px; font-weight: 600;
}
.meteo-ponza .mp-mi-value { font-size: 15px; font-weight: 600; color: var(--mp-text); }

.meteo-ponza .mp-attribution {
    text-align: center;
    font-size: 10.5px;
    color: var(--mp-text-mute);
    margin-top: 20px;
    letter-spacing: .02em;
}
.meteo-ponza .mp-attribution a {
    color: var(--mp-accent);
    text-decoration: none;
    font-weight: 600;
}
.meteo-ponza .mp-attribution a:hover { text-decoration: underline; }

/* Container-based mobile breakpoint */
@container mp-card (max-width: 540px) {
    .meteo-ponza--full .mp-card { padding: 18px; }
    .meteo-ponza--full .mp-stats { grid-template-columns: repeat(2, 1fr); }
    .meteo-ponza--full .mp-temp-num { font-size: 60px; }
    .meteo-ponza .mp-icon { width: 64px; height: 64px; }
    .meteo-ponza .mp-icon-emoji { font-size: 32px; }
    .meteo-ponza .mp-day-row { grid-template-columns: 24px 1fr auto auto auto; gap: 6px; padding: 9px 10px; font-size: 12px; }
    .meteo-ponza .mp-day-rain { min-width: 40px; font-size: 10.5px; }
    .meteo-ponza .mp-day-sun { min-width: 34px; font-size: 10.5px; }
}

/* Fallback for browsers without container query support */
@supports not (container-type: inline-size) {
    @media (min-width: 768px) {
        .meteo-ponza--full .mp-grid { grid-template-columns: 3fr 2fr; gap: 28px; }
    }
    @media (max-width: 540px) {
        .meteo-ponza--full .mp-stats { grid-template-columns: repeat(2, 1fr); }
        .meteo-ponza--full .mp-temp-num { font-size: 60px; }
    }
}

/* ============ SKELETON ============ */

.meteo-ponza--skeleton {
    --mp-skel-bg: #e8eef3;
    --mp-skel-hl: rgba(255, 255, 255, 0.6);
    pointer-events: none;
}
.meteo-ponza--skeleton .mp-skel-block {
    background: var(--mp-skel-bg);
    border-radius: 12px;
    position: relative;
    overflow: hidden;
}
.meteo-ponza--skeleton .mp-skel-block::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(90deg,
        transparent 0%,
        var(--mp-skel-hl) 50%,
        transparent 100%);
    transform: translateX(-100%);
    animation: mp-shimmer 1.5s ease-in-out infinite;
}
@keyframes mp-shimmer {
    100% { transform: translateX(100%); }
}

/* Heights calibrated on rendered widget heights to keep CLS ≈ 0 */
.meteo-ponza--skeleton .mp-skel-top      { height: 110px; margin-bottom: 18px; }
.meteo-ponza--skeleton .mp-skel-stats    { height: 96px;  margin-bottom: 22px; }
.meteo-ponza--skeleton .mp-skel-chart    { height: 220px; }
.meteo-ponza--skeleton .mp-skel-forecast { height: 320px; margin-bottom: 16px; }
.meteo-ponza--skeleton .mp-skel-marine   { height: 100px; margin-bottom: 16px; }
.meteo-ponza--skeleton .mp-skel-astro    { height: 60px;  margin-bottom: 16px; }

/* Smooth swap when JS replaces skeleton with rendered widget */
.meteo-ponza-mount .meteo-ponza:not(.meteo-ponza--skeleton) {
    animation: mp-fade-in 0.25s ease-out;
}
@keyframes mp-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* ============ ERROR ============ */
.meteo-ponza--error {
    max-width: 720px; margin: 0 auto;
    background: var(--mp-bg-card);
    border: 1px solid var(--mp-border);
    border-radius: 16px;
    padding: 24px;
    text-align: center;
    color: var(--mp-text-soft);
}
.meteo-ponza--error small { display: block; margin-top: 8px; color: var(--mp-text-mute); font-size: 11px; }
