.weather-sales-page {
    width: min(1120px, 92%);
    margin: 2rem auto;
    color: #e6f4ff;
}

.weather-sales-hero,
.weather-sales-form,
.weather-sales-seo,
.sales-cta {
    border: 1px solid rgba(125, 211, 252, 0.24);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(13, 27, 42, 0.94), rgba(30, 58, 88, 0.78));
    box-shadow: 0 12px 38px rgba(0, 0, 0, 0.2);
}

.weather-sales-hero {
    padding: clamp(1.5rem, 4vw, 3rem);
    text-align: center;
}

.weather-sales-hero h1 {
    margin: .5rem 0 1rem;
    color: #f0f9ff;
    font-size: clamp(1.8rem, 4vw, 3rem);
}

.weather-sales-hero p,
.weather-sales-seo p {
    line-height: 1.65;
    color: #cde8f5;
}

.weather-sales-kicker {
    color: #67e8f9;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.weather-sales-form {
    display: grid;
    grid-template-columns: 1.3fr 1fr auto;
    gap: 1rem;
    align-items: end;
    margin: 1rem 0;
    padding: 1.2rem;
}

.weather-sales-form label {
    display: block;
    margin-bottom: .4rem;
    font-weight: 700;
}

.weather-sales-form input,
.weather-sales-form select {
    box-sizing: border-box;
    width: 100%;
    min-height: 46px;
    padding: .7rem .85rem;
    border: 1px solid #5f91a8;
    border-radius: 10px;
    background: rgba(7, 21, 34, .86);
    color: #fff;
}

.weather-sales-form button,
.sales-cta a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: .7rem 1.25rem;
    border: 0;
    border-radius: 24px;
    background: linear-gradient(90deg, #0e7490, #2563eb);
    color: #fff;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
}

.weather-sales-status {
    min-height: 1.5rem;
    margin: .5rem 0;
    color: #bae6fd;
    text-align: center;
}

.demand-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin: 1rem 0;
}

.demand-card {
    padding: 1.1rem;
    border: 1px solid rgba(255, 255, 255, .13);
    border-radius: 14px;
    background: rgba(13, 27, 42, .9);
}

.demand-card-positive { border-top: 4px solid #4ade80; }
.demand-card-negative { border-top: 4px solid #f87171; }
.demand-card-action { border-top: 4px solid #60a5fa; }
.demand-card h2 { margin: 0 0 .8rem; font-size: 1.1rem; }
.demand-card ul { margin: 0; padding: 0; list-style: none; }
.demand-card li { display: flex; justify-content: space-between; gap: .8rem; padding: .32rem 0; }
.positive { color: #4ade80; font-weight: 700; }
.negative { color: #f87171; font-weight: 700; }
.zero { color: #9ca3af; }

.sales-disclaimer {
    padding: .7rem 1rem;
    border-radius: 10px;
    background: rgba(148, 163, 184, .12);
    color: #cbd5e1;
    font-size: .9rem;
}

.sales-table-wrap { overflow-x: auto; }
.sales-table { width: 100%; border-collapse: collapse; background: rgba(13, 27, 42, .92); }
.sales-table th { padding: .75rem; background: #9bc2d5; color: #102335; }
.sales-table td { padding: .7rem; border-bottom: 1px solid rgba(255, 255, 255, .1); vertical-align: top; }
.sales-table small { color: #b6d4e3; }

.sales-cta {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    margin: 1.5rem 0;
    padding: 1.3rem;
}
.sales-cta h2 { margin: 0 0 .4rem; font-size: 1.25rem; }
.sales-cta p { margin: 0; color: #cde8f5; }
.sales-cta a { flex: 0 0 auto; }
.weather-sales-seo { padding: 1.5rem; }

@media (max-width: 800px) {
    .weather-sales-form,
    .demand-cards { grid-template-columns: 1fr; }
    .sales-cta { align-items: stretch; flex-direction: column; }
    .sales-table { min-width: 900px; }
}
