/*
 * HelpCounter — Home Access Portal Stylesheet
 * Used by: /home  (volunteer home access portal)
 *
 * Design principles:
 *   - Mobile-first: base styles target small screens; breakpoints add desktop layout
 *   - Friendly and approachable — volunteers are community members, not staff
 *   - Card-based layout works naturally on both mobile and desktop
 *   - 16px minimum input font size to prevent iOS automatic zoom on focus
 *   - Touch-friendly tap targets (minimum 44px height on interactive elements)
 *
 * Breakpoints:
 *   sm: 36em  (576px)  — small phones in landscape, larger phones
 *   md: 48em  (768px)  — tablets
 *   lg: 64em  (1024px) — desktop
 *
 * Color contrast ratios:
 *   --color-text    #1f2937 on white  12.6:1  AAA
 *   --color-muted   #4b5563 on white   7.0:1  AAA
 *   --color-primary #1d6e3c on white   7.2:1  AAA  (green — volunteer theme)
 *   status pending  #92400e on #fffbeb 6.3:1  AA
 *   status approved #15803d on #f0fdf4 5.3:1  AA
 *   status denied   #b91c1c on #fef2f2 5.6:1  AA
 */

/* ── Custom properties ─────────────────────────────────────────────────── */

:root {
    /* Brand — green theme (volunteers help the community) */
    --color-primary:        #166534;   /* green-800  — 7.2:1 on white */
    --color-primary-mid:    #15803d;   /* green-700 */
    --color-primary-light:  #dcfce7;   /* green-100 */
    --color-primary-pale:   #f0fdf4;   /* green-50  */

    /* Accent — used for links and interactive highlights */
    --color-accent:         #1d6e3c;

    /* Semantic status */
    --color-approved:       #15803d;
    --color-approved-bg:    #f0fdf4;
    --color-approved-border:#86efac;

    --color-pending:        #92400e;
    --color-pending-bg:     #fffbeb;
    --color-pending-border: #fcd34d;

    --color-denied:         #b91c1c;
    --color-denied-bg:      #fef2f2;
    --color-denied-border:  #fca5a5;

    --color-expired:        #6b21a8;
    --color-expired-bg:     #faf5ff;
    --color-expired-border: #d8b4fe;

    /* Neutrals */
    --color-text:           #1f2937;
    --color-muted:          #4b5563;
    --color-subtle:         #6b7280;
    --color-border:         #e5e7eb;
    --color-border-light:   #f3f4f6;
    --color-bg:             #f9fafb;
    --color-white:          #ffffff;

    /* Typography */
    --font-sans:      system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-size-base: 1rem;          /* 16px — also prevents iOS input zoom */
    --line-height:    1.6;

    /* Spacing */
    --sp-1:  0.25rem;
    --sp-2:  0.5rem;
    --sp-3:  0.75rem;
    --sp-4:  1rem;
    --sp-5:  1.25rem;
    --sp-6:  1.5rem;
    --sp-8:  2rem;
    --sp-10: 2.5rem;

    /* Shape */
    --radius:    8px;
    --radius-lg: 12px;

    /* Shadow */
    --shadow-sm: 0 1px 3px rgb(0 0 0 / 0.08);
    --shadow:    0 2px 8px rgb(0 0 0 / 0.10);

    /* Touch targets */
    --touch-min: 44px;

    /* Layout */
    --content-width: 40rem;   /* single-column max-width */
    --nav-height: 56px;
}


/* ── Reset ─────────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: var(--font-size-base);
    line-height: var(--line-height);
}

img { display: block; max-width: 100%; }

a { color: var(--color-accent); }
a:hover { color: var(--color-primary); }

h1, h2, h3, h4 { line-height: 1.3; }


/* ── Accessibility ─────────────────────────────────────────────────────── */

.skip-link {
    position: absolute;
    top: -100%;
    left: 0;
    z-index: 9999;
    padding: var(--sp-3) var(--sp-5);
    background: var(--color-primary);
    color: var(--color-white);
    font-size: 0.9375rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: 0 0 var(--radius) 0;
}
.skip-link:focus { top: 0; }

:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}
:focus:not(:focus-visible) { outline: none; }

main:focus { outline: none; }


/* ── Navigation bar ────────────────────────────────────────────────────── */

.home-nav {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--color-primary);
    color: var(--color-white);
    padding: 0 var(--sp-4);
    min-height: var(--nav-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-4);
}

.home-nav-brand {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-white);
    text-decoration: none;
    letter-spacing: 0.01em;
}
.home-nav-brand:hover { color: rgba(255,255,255,0.85); }

.home-nav-actions {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    font-size: 0.875rem;
}

@media (min-width: 36em) {
    .home-nav-actions { gap: var(--sp-4); }
}

.home-nav-username {
    color: rgba(255,255,255,0.80);
    /* Hidden on very small screens to save space */
    display: none;
}

.home-nav-link {
    color: rgba(255,255,255,0.90);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s;
}
.home-nav-link:hover { color: var(--color-white); }

.home-nav-signout-form { margin: 0; }
.home-nav-signout {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    font-size: 0.875rem;
    font-weight: 500;
    color: rgba(255,255,255,0.90);
    cursor: pointer;
    transition: color 0.15s;
}
.home-nav-signout:hover { color: var(--color-white); }

/* Show username on wider screens */
@media (min-width: 36em) {
    .home-nav-username { display: block; }
}


/* ── Main content ──────────────────────────────────────────────────────── */

.home-main {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: var(--sp-6) var(--sp-4);
}

@media (min-width: 48em) {
    .home-main { padding: var(--sp-8) var(--sp-6); }
}


/* ── Flash messages ────────────────────────────────────────────────────── */

.flash {
    padding: var(--sp-3) var(--sp-4);
    margin-bottom: var(--sp-5);
    border: 1px solid transparent;
    border-radius: var(--radius);
    font-size: 0.9375rem;
    line-height: 1.5;
}
.flash p     { margin: 0; }
.flash p + p { margin-top: var(--sp-1); }

.flash--success {
    background: var(--color-approved-bg);
    border-color: var(--color-approved-border);
    color: var(--color-approved);
}
.flash--error {
    background: var(--color-denied-bg);
    border-color: var(--color-denied-border);
    color: var(--color-denied);
}
.flash--warning {
    background: var(--color-pending-bg);
    border-color: var(--color-pending-border);
    color: var(--color-pending);
}


/* ── Page heading ──────────────────────────────────────────────────────── */

.page-title {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--sp-6);
    line-height: 1.3;
}

/* Greeting-style heading (e.g. "Welcome back, Jane") */
.greeting {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 var(--sp-1);
}
.greeting-sub {
    font-size: 0.9375rem;
    color: var(--color-muted);
    margin: 0;
}

.dashboard-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-4);
    margin-bottom: var(--sp-6);
}

.dashboard-signout-form { margin: 0; flex-shrink: 0; }


/* ── Background check status ────────────────────────────────────────────── */

.backcheck-status { }

.backcheck-expiry {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: var(--sp-2);
    font-size: 0.9rem;
}

.backcheck-expiry__label { color: var(--color-muted); }

.backcheck-expiry__days {
    color: var(--color-subtle);
    font-size: 0.85rem;
}

.backcheck--expired .backcheck-expiry__label,
.backcheck--expired .backcheck-expiry__date {
    color: var(--color-denied);
    font-weight: 700;
}

.backcheck--expiring-soon .backcheck-expiry__label,
.backcheck--expiring-soon .backcheck-expiry__date {
    color: var(--color-pending);
    font-weight: 700;
}

.backcheck-renew {
    margin-top: var(--sp-4);
    padding: var(--sp-4);
    background: var(--color-denied-bg);
    border: 1px solid var(--color-denied-border);
    border-radius: var(--radius);
}

.backcheck--expiring-soon .backcheck-renew {
    background: var(--color-pending-bg);
    border-color: var(--color-pending-border);
}

.backcheck-renew__note {
    margin: var(--sp-2) 0 0;
    font-size: 0.875rem;
    color: var(--color-muted);
}


/* ── Cards ─────────────────────────────────────────────────────────────── */

.card {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: var(--sp-4);
}
.card-header {
    padding: var(--sp-4) var(--sp-4);
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
}
.card-title {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-text);
    margin: 0;
}
.card-body {
    padding: var(--sp-4);
}

@media (min-width: 36em) {
    .card-header { padding: var(--sp-4) var(--sp-5); }
    .card-body   { padding: var(--sp-5); }
}


/* ── Status indicators ─────────────────────────────────────────────────── */

/* Inline badge */
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-1);
    padding: 2px 10px;
    border-radius: 9999px;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.6;
    white-space: nowrap;
}
.status-badge--approved { background: var(--color-approved-bg); color: var(--color-approved); border: 1px solid var(--color-approved-border); }
.status-badge--pending  { background: var(--color-pending-bg);  color: var(--color-pending);  border: 1px solid var(--color-pending-border); }
.status-badge--denied   { background: var(--color-denied-bg);   color: var(--color-denied);   border: 1px solid var(--color-denied-border); }
.status-badge--expired  { background: var(--color-expired-bg);  color: var(--color-expired);  border: 1px solid var(--color-expired-border); }

/* Full-width status block (e.g. on a status detail card) */
.status-block {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    padding: var(--sp-4);
    border: 1px solid;
    border-radius: var(--radius);
    font-size: 0.9375rem;
    line-height: 1.5;
}
.status-block--approved { background: var(--color-approved-bg); border-color: var(--color-approved-border); color: var(--color-approved); }
.status-block--pending  { background: var(--color-pending-bg);  border-color: var(--color-pending-border);  color: var(--color-pending); }
.status-block--denied   { background: var(--color-denied-bg);   border-color: var(--color-denied-border);   color: var(--color-denied); }
.status-block--expired  { background: var(--color-expired-bg);  border-color: var(--color-expired-border);  color: var(--color-expired); }
.status-block p { margin: 0; }
.status-block p + p { margin-top: var(--sp-1); }


/* ── Detail row (label + value pairs) ─────────────────────────────────── */

.detail-list {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--sp-1) var(--sp-4);
    font-size: 0.9375rem;
}
.detail-label {
    font-weight: 500;
    color: var(--color-muted);
    white-space: nowrap;
}
.detail-value {
    color: var(--color-text);
    word-break: break-word;
}


/* ── Forms ─────────────────────────────────────────────────────────────── */

.form-group { margin-bottom: var(--sp-5); }

.form-label {
    display: block;
    font-size: 0.9375rem;
    font-weight: 500;
    color: var(--color-text);
    margin-bottom: var(--sp-2);
}
.form-label-hint {
    font-weight: 400;
    color: var(--color-subtle);
    font-size: 0.875rem;
}

/* 16px minimum font on inputs prevents iOS zoom on focus */
.form-input,
.form-select,
.form-textarea {
    display: block;
    width: 100%;
    min-height: var(--touch-min);
    padding: var(--sp-3) var(--sp-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-white);
    color: var(--color-text);
    font: inherit;
    font-size: 1rem;    /* 16px — iOS zoom prevention */
    line-height: 1.5;
    appearance: none;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgb(22 101 52 / 0.15);
    outline: none;
}
.form-input.is-invalid,
.form-select.is-invalid { border-color: var(--color-denied); }

.form-textarea { min-height: 6rem; resize: vertical; }

.form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%234b5563'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--sp-3) center;
    background-size: 1.125rem;
    padding-right: 2.5rem;
    cursor: pointer;
}

.field-error {
    font-size: 0.875rem;
    color: var(--color-denied);
    margin-top: var(--sp-1);
}

.form-check {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    font-size: 0.9375rem;
    color: var(--color-text);
    cursor: pointer;
    line-height: 1.5;
}
.form-check input[type="checkbox"],
.form-check input[type="radio"] {
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
    margin-top: 0.125rem;
    accent-color: var(--color-accent);
    cursor: pointer;
}

.error-summary {
    background: var(--color-denied-bg);
    border: 1px solid var(--color-denied-border);
    border-radius: var(--radius);
    padding: var(--sp-3) var(--sp-4);
    margin-bottom: var(--sp-5);
    font-size: 0.9375rem;
    color: var(--color-denied);
}
.error-summary p     { margin: 0; }
.error-summary p + p { margin-top: var(--sp-1); }

.form-actions {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
    margin-top: var(--sp-6);
}

@media (min-width: 36em) {
    .form-actions {
        flex-direction: row;
        align-items: center;
    }
}


/* ── Buttons ───────────────────────────────────────────────────────────── */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--touch-min);
    padding: var(--sp-3) var(--sp-6);
    border: 1px solid transparent;
    border-radius: var(--radius);
    font: inherit;
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.15s, border-color 0.15s;
    white-space: nowrap;
    text-align: center;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

.btn--primary {
    background: var(--color-primary);
    color: var(--color-white);
}
.btn--primary:hover { background: var(--color-primary-mid); color: var(--color-white); }

.btn--outline {
    background: var(--color-white);
    color: var(--color-primary);
    border-color: var(--color-primary);
}
.btn--outline:hover { background: var(--color-primary-pale); }

.btn--ghost {
    background: none;
    color: var(--color-muted);
    border-color: transparent;
}
.btn--ghost:hover { color: var(--color-text); }

/* Full-width on mobile, auto on larger screens */
.btn--full { width: 100%; }
@media (min-width: 36em) {
    .btn--full { width: auto; }
}

.btn--danger {
    background: var(--color-denied);
    color: var(--color-white);
    border-color: var(--color-denied);
}
.btn--danger:hover { background: #991b1b; border-color: #991b1b; color: var(--color-white); }


/* ── Modals ─────────────────────────────────────────────────────────────── */

.home-modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 500;
    padding: var(--sp-4);
}

.home-modal-box {
    background: var(--color-white);
    border-radius: var(--radius);
    padding: var(--sp-6);
    max-width: 28rem;
    width: 100%;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}

.home-modal-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 var(--sp-3);
}

.home-modal-body {
    font-size: 0.9375rem;
    color: var(--color-muted);
    margin: 0 0 var(--sp-4);
}

.home-modal-actions {
    display: flex;
    gap: var(--sp-3);
    flex-wrap: wrap;
}


/* ── Add School screen ──────────────────────────────────────────────────── */

.school-district-group {
    margin-bottom: var(--sp-4);
}

.school-district-label {
    font-size: 0.8125rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-subtle);
    margin: 0 0 var(--sp-2);
}

.school-option {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-3) var(--sp-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    margin-bottom: var(--sp-2);
    cursor: pointer;
    transition: border-color 0.15s, background-color 0.15s;
}

.school-option:hover {
    border-color: var(--color-primary);
    background: var(--color-primary-pale);
}

.school-option--linked {
    background: var(--color-border-light);
    cursor: default;
    opacity: 0.7;
}

.school-option--linked:hover {
    border-color: var(--color-border);
    background: var(--color-border-light);
}

.school-option input[type="radio"] {
    flex-shrink: 0;
}

.school-option-name {
    flex: 1;
    font-size: 0.9375rem;
    color: var(--color-text);
}


/* ── Footer ────────────────────────────────────────────────────────────── */

.home-footer {
    margin-top: var(--sp-10);
    padding: var(--sp-6) var(--sp-4);
    text-align: center;
    font-size: 0.8125rem;
    color: var(--color-subtle);
    border-top: 1px solid var(--color-border);
}


/* ── Dashboard — two-column form rows ─────────────────────────────────── */

.home-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 var(--sp-4);
}

/* City / State / Zip row: city gets more space */
.home-form-row--city {
    grid-template-columns: 1fr auto auto;
}

@media (max-width: 35.999em) {
    .home-form-row,
    .home-form-row--city { grid-template-columns: 1fr; }
}


/* ── Dashboard — school list ───────────────────────────────────────────── */

.home-school-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.home-school-item {
    padding: var(--sp-3) 0;
    border-bottom: 1px solid var(--color-border-light);
}
.home-school-item:last-child { border-bottom: none; }

.home-school-name {
    font-weight: 500;
    color: var(--color-text);
    margin-bottom: var(--sp-1);
}

.home-school-meta {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    font-size: 0.875rem;
    color: var(--color-muted);
}


/* ── Dashboard — sign-in history table ────────────────────────────────── */

.home-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.home-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9375rem;
}

.home-table th,
.home-table td {
    padding: var(--sp-3) var(--sp-4);
    text-align: left;
    border-bottom: 1px solid var(--color-border-light);
    white-space: nowrap;
}

.home-table th {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-muted);
    background: var(--color-bg);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.home-table tbody tr:hover { background: var(--color-primary-pale); }

.home-table-num { text-align: right; }


/* ── Utility ───────────────────────────────────────────────────────────── */

.sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}
