/* Donor status page — themed to match donateacar-theme. Mobile-first. */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@700;800;900&family=Open+Sans:wght@400;600&display=swap');

:root {
    --teal:        #1bbfbf;
    --teal-dark:   #159a9a;
    --teal-light:  #e6fafa;
    --blue:        #2d6a9f;
    --blue-dark:   #1e4d75;
    --gray:        #4a5568;
    --gray-light:  #f7f8fa;
    --gray-mid:    #e2e8f0;
    --dark:        #1a202c;
    --white:       #ffffff;
    --border:      #dde3ea;
    --font-head:   'Nunito', sans-serif;
    --font-body:   'Open Sans', sans-serif;
    --radius:      10px;
    --shadow:      0 4px 24px rgba(0,0,0,0.09);
    --shadow-lg:   0 8px 40px rgba(0,0,0,0.13);
}

*, *::before, *::after { box-sizing: border-box; }
body {
    margin: 0;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    font-family: var(--font-body);
    font-size: 16px;
    color: var(--gray);
    background: var(--gray-light);
    line-height: 1.7;
}

/* ── Header ── */
.site-header {
    background: var(--white);
    border-bottom: 2px solid var(--gray-mid);
    box-shadow: 0 2px 12px rgba(0,0,0,0.07);
    position: sticky;
    top: 0;
    z-index: 100;
}
.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    max-width: 1160px;
    margin: 0 auto;
    padding: 12px 20px;
}
.site-logo { display: block; flex-shrink: 0; }
.site-logo img { display: block; height: 48px; width: auto; }
.header-phone {
    font-family: var(--font-head);
    font-size: 20px;
    font-weight: 900;
    color: var(--blue);
    text-decoration: none;
    line-height: 1.1;
}
.header-phone:hover { color: var(--teal-dark); }

/* ── Page wrap ── */
.wrap {
    flex: 1;
    width: 100%;
    max-width: 720px;
    margin: 0 auto;
    padding: 32px 20px 56px;
}
h1 {
    font-family: var(--font-head);
    font-weight: 900;
    font-size: clamp(24px, 4vw, 32px);
    color: var(--dark);
    line-height: 1.2;
    margin: 0 0 24px;
}
h2 {
    font-family: var(--font-head);
    font-weight: 800;
    font-size: 17px;
    color: var(--dark);
    margin: 0 0 12px;
}
p { margin: 0 0 1rem; }
a { color: var(--teal-dark); }
a:hover { color: var(--teal); }

p.notice {
    background: #fff8e1;
    border: 1.5px solid #f0d97a;
    color: #5b4a14;
    padding: 14px 16px;
    border-radius: var(--radius);
}

/* ── Lookup form (themed as card) ── */
form.lookup {
    background: var(--white);
    border: 1.5px solid var(--border);
    border-radius: 14px;
    box-shadow: var(--shadow);
    padding: 28px;
    margin-top: 8px;
}
form.lookup label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 14px 0 5px;
}
form.lookup label:first-child { margin-top: 0; }
form.lookup input[type="text"] {
    width: 100%;
    padding: 11px 13px;
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--dark);
    border: 1.5px solid var(--border);
    border-radius: 8px;
    transition: border-color 0.15s, box-shadow 0.15s;
}
form.lookup input[type="text"]:focus {
    outline: none;
    border-color: var(--teal);
    box-shadow: 0 0 0 3px rgba(27,191,191,0.12);
}
form.lookup button {
    margin-top: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 13px 28px;
    font-family: var(--font-head);
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background: var(--teal);
    color: var(--white);
    border: 0;
    border-radius: var(--radius);
    cursor: pointer;
    transition: background 0.15s;
}
form.lookup button:hover { background: var(--teal-dark); }

/* ── Status block ── */
.status-block {
    background: var(--white);
    border: 1.5px solid var(--border);
    border-radius: 14px;
    box-shadow: var(--shadow);
    padding: 22px 24px;
    margin: 0 0 18px;
}
.status-badge {
    display: inline-block;
    background: var(--teal);
    color: var(--white);
    padding: 6px 14px;
    border-radius: 999px;
    font-family: var(--font-head);
    font-weight: 800;
    font-size: 12.5px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.status-badge.status-closed { background: var(--dark); }
.status-paragraph { margin-top: 14px; color: var(--gray); }
.status-paragraph a { color: var(--teal-dark); font-weight: 600; }

/* ── Details ── */
.details {
    background: var(--white);
    border: 1.5px solid var(--border);
    border-radius: 14px;
    box-shadow: var(--shadow);
    padding: 22px 24px;
    margin: 0 0 18px;
}
.details dl { margin: 0; }
.details dt {
    font-size: 11px;
    font-weight: 700;
    color: var(--gray);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 12px;
}
.details dt:first-child { margin-top: 0; }
.details dd {
    margin: 4px 0 0;
    font-size: 15px;
    color: var(--dark);
    font-weight: 600;
}

/* ── Downloads ── */
.downloads { margin: 0 0 18px; }
.downloads form.download-button { margin: 0 0 10px; }
.downloads form.download-button button {
    width: 100%;
    padding: 14px 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-head);
    font-size: 15px;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    background: var(--blue);
    color: var(--white);
    border: 0;
    border-radius: var(--radius);
    cursor: pointer;
    transition: background 0.15s;
}
.downloads form.download-button button:hover { background: var(--blue-dark); }
.receipt-pending {
    background: var(--teal-light);
    color: var(--blue-dark);
    border: 1.5px dashed var(--teal);
    padding: 14px 16px;
    border-radius: var(--radius);
    margin-bottom: 10px;
    font-style: italic;
}

/* ── Footer ── */
.site-footer {
    background: var(--dark);
    color: #9aa5b4;
    padding: 22px 20px;
    text-align: center;
}
.footer-inner {
    max-width: 1160px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 6px 14px;
    font-size: 14px;
}
.footer-phone {
    font-family: var(--font-head);
    font-weight: 800;
    color: var(--teal);
    text-decoration: none;
    letter-spacing: 0.02em;
}
.footer-phone:hover { color: var(--white); }

/* ── Small screens ── */
@media (max-width: 520px) {
    .header-inner { padding: 10px 14px; gap: 10px; }
    .site-logo img { height: 38px; }
    .header-phone { font-size: 17px; }
    .wrap { padding: 24px 14px 48px; }
    form.lookup, .status-block, .details { padding: 20px 18px; }
    .site-footer { padding: 18px 14px; }
}
