/* ======= colour palette (light-only) ======= */
:root{
    --primary:#205781;
    --secondary:#4F959D;
    --accent:#98D2C0;
    --background:#F6F8D5;
    --text:#2A363B;
    --card-bg:#FFFFFF;
}

/* ======= reset / base ======= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{
    font-family:'Segoe UI',system-ui,sans-serif;
    line-height:1.6;
    background:var(--background);
    color:var(--text);
}

/* ======= header ======= */
.header{
    background:linear-gradient(135deg,var(--primary),var(--secondary));
    padding:1rem;
    text-align:center;
    box-shadow:0 4px 15px rgba(0,0,0,.1)
}
.header h1{color:#fff;font-size:2rem;margin:0}

/* ======= container ======= */
.container{max-width:1000px;margin:3rem auto;padding:0 1.5rem}

/* ======= calculator card ======= */
.calculator-card{
    background:var(--card-bg);
    border-radius:20px;
    padding:2rem;
    box-shadow:0 10px 30px rgba(0,0,0,.08);
    margin:2rem 0;
    position:relative
}
.input-note{text-align:center;margin:1rem 0;color:var(--secondary);font-size:1.1rem}

/* grid for state+zip or address */
.input-section{
    display:grid;
    grid-template-columns:1fr 1px 1fr;
    gap:2rem;
    margin:1rem 0
}
.divider{background:var(--accent);width:1px;height:100%;position:relative}
.divider::before{
    content:"OR";
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    background:var(--background);
    padding:0 1rem;
    font-weight:bold
}

/* inputs */
.input-group{margin:.5rem 0}
select,input[type=text]{
    width:100%;
    padding:1rem;
    border:2px solid var(--accent);
    border-radius:8px;
    font-size:1rem;
    margin:.5rem 0;
    background:var(--card-bg);
    color:var(--text)
}

/* buttons */
button{
    background:linear-gradient(45deg,var(--primary),var(--secondary));
    color:#fff;border:none;
    padding:1.2rem 2.5rem;
    border-radius:12px;
    font-size:1.2rem;
    cursor:pointer;
    width:100%;
    margin-top:1rem;
    transition:filter .2s
}
button:hover{filter:brightness(.9)}       /* darker on hover */

/* loader */
.loader{position:fixed;inset:0;background:rgba(255,255,255,.9);
        display:none;justify-content:center;align-items:center;z-index:1000}
.loader-spinner{width:50px;height:50px;border:5px solid #f3f3f3;
                border-top:5px solid var(--primary);border-radius:50%;
                animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* results section */
.results{display:none;margin-top:2rem;animation:fadeIn .5s}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.results h3{font-size:1.45rem;color:var(--primary);margin-bottom:1rem}

/* forecast cards */
.forecast-card{
    background:var(--card-bg);
    border-radius:12px;
    padding:1.5rem;
    margin:1rem 0;
    box-shadow:0 4px 6px rgba(0,0,0,.05);
    border-left:4px solid var(--accent)
}
.status-label{font-weight:700;margin-bottom:.8rem}
.status-label.snow{color:#B71C1C}
.status-label.clear{color:#00796B}

.progress-wrap{
    background:#e0e0e0;
    border-radius:6px;
    height:10px;
    margin-top:.6rem;
    overflow:hidden
}
.progress-fill{
    height:100%;
    background:linear-gradient(90deg,var(--secondary),var(--accent));
    width:0%
}

/* advertisement placeholder */
.ad-space{
    height:100px;
    background:rgba(0,0,0,.05);
    margin:2rem 0;
    border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    opacity:.8;color:var(--text)
}

/* FAQ */
.faq-item{margin:.5rem 0;background:var(--card-bg);
          border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05)}
.faq-question{padding:1rem;cursor:pointer;display:flex;justify-content:space-between}
.faq-answer{display:none;padding:0 1rem 1rem;border-top:1px solid var(--accent)}
.hidden-section{display:none !important;height:0;overflow:hidden}


@media(max-width:768px){
    .input-section{grid-template-columns:1fr;grid-template-rows:auto 1px auto}
    .divider{width:100%;height:1px}
}
