/**
 * DH Reach — App-Specific Styles
 *
 * This file contains ONLY styles unique to the Reach app that cannot
 * live in shared CSS. Shared styles (buttons, cards, forms, tables,
 * modals, badges, alerts, utilities) are loaded via shared CSS imports.
 *
 * Sections:
 *   1. Header & Navigation (horizontal nav — replaced by sidebar in F2)
 *   2. Portal Tabs
 *   3. Auth Pages
 *   4. Loading Spinner & Toasts
 *   5. Stats Grid
 *   6. Table Extras
 *   7. Landing / Hero Page
 *   8. Portal Form UX (collapsible sections, dynamic forms)
 *   9. Quick-Select Buttons
 *  10. Call Script Panel (Twilio integration)
 *  11. Phone Type Selector & Same-as-Caller
 *  12. Form Validation
 *  13. Need Types Configuration (Admin)
 */

/* ==========================================================================
   1. Header & Navigation (Public Pages)
   --------------------------------------------------------------------------
   Horizontal nav bar used by public_base.html for unauthenticated pages
   (landing, login, register, status lookup). Authenticated pages use the
   shared sidebar via suite_base.html + admin/base.html, or top tabs via
   portal/base.html.
   ========================================================================== */

.header {
    background: white;
    border-bottom: 1px solid var(--color-gray-200);
    padding: var(--spacing-4) 0;
}

.header-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 var(--spacing-4);
}

.logo {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--color-gray-900);
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
}

.logo-img {
    height: 40px;
    width: auto;
    max-width: 200px;
    object-fit: contain;
}

.logo-text {
    white-space: nowrap;
}

.nav-links {
    display: flex;
    gap: var(--spacing-4);
    align-items: center;
}

.nav-links a {
    color: var(--color-gray-600);
    font-weight: 500;
    white-space: nowrap;
}

.nav-links a:hover {
    color: var(--color-primary);
    text-decoration: none;
}

/* --- Hamburger Menu Button --------------------------------------------- */

.hamburger-btn {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: var(--spacing-1);
    width: 32px;
    height: 32px;
    padding: var(--spacing-1);
    background: none;
    border: 1px solid var(--color-gray-300);
    border-radius: var(--radius-sm);
    cursor: pointer;
}

.hamburger-btn span {
    display: block;
    width: 100%;
    height: 2px;
    background: var(--color-gray-600);
    transition: transform 0.2s ease;
}

.hamburger-btn:hover {
    border-color: var(--color-gray-400);
}

.hamburger-btn:hover span {
    background: var(--color-gray-800);
}

.hamburger-btn:focus-visible {
    outline: var(--focus-ring);
    outline-offset: var(--focus-ring-offset);
}

/* --- Mobile Navigation ------------------------------------------------- */

@media (max-width: 768px) {
    .header-content {
        position: relative;
    }

    .hamburger-btn {
        display: flex;
    }

    .nav-links {
        display: none;
        position: absolute;
        top: 100%;
        right: 0;
        flex-direction: column;
        background: white;
        border: 1px solid var(--color-gray-200);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-lg);
        padding: var(--spacing-2) 0;
        min-width: 200px;
        z-index: 1000;
        margin-top: var(--spacing-2);
    }

    .nav-links.open {
        display: flex;
    }

    .nav-links a,
    .nav-links span {
        padding: var(--spacing-2) var(--spacing-4);
        display: block;
    }

    .nav-links .text-muted {
        display: none;
    }

    .nav-links a:hover {
        background: var(--color-gray-100);
    }
}

/* ==========================================================================
   2. Portal Tabs — Volunteer Queue Navigation
   --------------------------------------------------------------------------
   Lightweight tab navigation for volunteer portal views (Calls/SMS).
   Replaces the sidebar used by admin views with simple horizontal tabs
   for a focused, uncluttered volunteer experience.
   ========================================================================== */

.portal-tabs {
    display: flex;
    gap: var(--spacing-1);
    margin-bottom: var(--spacing-6);
    border-bottom: 2px solid var(--color-gray-200);
}

.portal-tab {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-4);
    color: var(--color-gray-600);
    text-decoration: none;
    font-weight: 500;
    font-size: var(--font-size-sm);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: color var(--transition-fast), border-color var(--transition-fast);
}

.portal-tab:hover {
    color: var(--color-primary);
    text-decoration: none;
}

.portal-tab:focus-visible {
    outline: var(--focus-ring);
    outline-offset: calc(-1 * var(--focus-ring-offset, 2px));
}

.portal-tab.active {
    color: var(--color-primary);
    border-bottom-color: var(--color-primary);
}

.portal-tab svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* ==========================================================================
   3. Auth Pages
   --------------------------------------------------------------------------
   Centered login/register pages. Could use shared .centered-page but
   has unique .auth-card max-width and .auth-footer styling.
   ========================================================================== */

.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-8) var(--spacing-4);
}

.auth-card {
    width: 100%;
    max-width: 400px;
}

.auth-footer {
    text-align: center;
    margin-top: var(--spacing-6);
    color: var(--color-gray-500);
}

/* ==========================================================================
   4. Loading Spinner & Toast Notifications
   --------------------------------------------------------------------------
   Spinner is inline loading indicator. Toasts are ephemeral messages.
   Both are Reach-specific; could be promoted to shared in future.
   ========================================================================== */

.spinner {
    display: inline-block;
    width: 1rem;
    height: 1rem;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: reach-spin 0.75s linear infinite;
}

@keyframes reach-spin {
    to {
        transform: rotate(360deg);
    }
}

.toast-container {
    position: fixed;
    top: var(--spacing-4);
    right: var(--spacing-4);
    z-index: 1000;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.toast {
    padding: var(--spacing-3) var(--spacing-4);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    max-width: 350px;
    animation: reach-slide-in 0.2s ease;
}

@keyframes reach-slide-in {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

.toast-error {
    background: var(--color-danger);
    color: white;
}

.toast-success {
    background: var(--color-success);
    color: white;
}

/* ==========================================================================
   5. Stats Grid
   --------------------------------------------------------------------------
   Reach's dashboard stats display. Different pattern from shared
   .stats-row / .stat-card (uses inline grid with labeled values).
   ========================================================================== */

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-4);
    margin-bottom: var(--spacing-6);
    padding: var(--spacing-4);
    background: var(--color-gray-50);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-gray-200);
}

.stats-item {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-1);
}

.stats-label {
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-gray-500);
}

.stats-value {
    font-size: var(--font-size-sm);
    color: var(--color-gray-700);
}

.stats-value span {
    display: inline-block;
    margin-right: var(--spacing-3);
}

/* ==========================================================================
   6. Table Extras
   --------------------------------------------------------------------------
   Table section headers and inline form elements specific to Reach's
   admin tables. Base .table styles are in shared components.css.
   ========================================================================== */

.table-section-header {
    font-size: var(--font-size-base);
    font-weight: 600;
    color: var(--color-gray-800);
    margin: var(--spacing-6) 0 var(--spacing-3) 0;
    padding-bottom: var(--spacing-2);
    border-bottom: 1px solid var(--color-gray-200);
}

.table-section-header:first-child {
    margin-top: 0;
}

/* Inline form elements in Reach tables */
.table input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
    cursor: pointer;
    accent-color: var(--color-primary);
}

.table input[type="number"],
.table input[type="text"],
.table select {
    padding: var(--spacing-1) var(--spacing-2);
    font-size: var(--font-size-sm);
    border: 1px solid var(--color-gray-300);
    border-radius: var(--radius-md);
    background: white;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.table input[type="number"]:focus-visible,
.table input[type="text"]:focus-visible,
.table select:focus-visible {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-primary) 10%, transparent);
}

.table input[type="number"] {
    width: 70px;
    text-align: center;
}

/* ==========================================================================
   7. Landing / Hero Page
   --------------------------------------------------------------------------
   Public-facing landing page for Reach. Not shared across apps.
   ========================================================================== */

.hero {
    padding: var(--spacing-16, 4rem) 0;
    text-align: center;
}

.hero-title {
    font-size: 2.5rem;
    font-weight: 700;
    margin-bottom: var(--spacing-4);
}

.hero-subtitle {
    font-size: var(--font-size-lg);
    color: var(--color-gray-600);
    margin-bottom: var(--spacing-8);
}

.hero-buttons {
    display: flex;
    gap: var(--spacing-4);
    justify-content: center;
}

@media (max-width: 640px) {
    .hero-title {
        font-size: 2rem;
    }

    .hero-buttons {
        flex-direction: column;
    }
}

/* ==========================================================================
   8. Portal Form UX — Collapsible Sections & Dynamic Forms
   --------------------------------------------------------------------------
   Reach's intake portal uses collapsible form sections with toggle
   controls, dynamic form field rendering, and enhanced typography.
   This is core Reach functionality — cannot be shared.
   ========================================================================== */

/* --- Section Controls -------------------------------------------------- */

.section-controls {
    display: flex;
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-4);
    justify-content: flex-end;
}

/* --- Collapsible Form Sections ----------------------------------------- */

.form-section {
    margin-bottom: var(--spacing-4);
    background: var(--color-gray-50);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: border-color 0.2s ease;
}

.form-section:hover {
    border-color: var(--color-gray-300);
}

.form-section.section-collapsed {
    background: white;
}

.section-header {
    margin: 0;
}

.section-toggle {
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--spacing-3) var(--spacing-4);
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    gap: var(--spacing-3);
    transition: background-color var(--transition-fast);
}

.section-toggle:hover {
    background: var(--color-gray-100);
}

.section-toggle:focus-visible {
    outline: none;
    background: var(--color-gray-100);
    box-shadow: inset 0 0 0 2px var(--color-primary);
}

.toggle-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.toggle-icon::before {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-left: 5px solid var(--color-gray-600);
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    transition: transform 0.2s ease;
}

.section-toggle:not(.collapsed) .toggle-icon::before {
    transform: rotate(90deg);
}

.section-toggle .section-title {
    margin: 0;
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-gray-800);
    flex-grow: 1;
}

.section-field-count {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    font-weight: 400;
    padding: 0.125rem var(--spacing-2);
    background: var(--color-gray-200);
    border-radius: 10px;
}

.section-content {
    padding: var(--spacing-4);
    padding-top: var(--spacing-2);
    border-top: 1px solid var(--color-gray-200);
    transition: max-height 0.3s ease, opacity 0.2s ease, padding 0.3s ease;
    max-height: 2000px;
    opacity: 1;
    overflow: hidden;
}

.section-content.collapsed {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
    border-top: none;
}

/* --- Dynamic Form Field Styles ----------------------------------------- */

.dynamic-form .form-group {
    margin-bottom: 1.25rem;
}

.dynamic-form .form-group:last-child {
    margin-bottom: var(--spacing-2);
}

.dynamic-form .form-group label {
    display: block;
    margin-bottom: var(--spacing-1);
    font-weight: 500;
    font-size: 0.9375rem;
    color: var(--color-gray-700);
}

.dynamic-form .form-control {
    width: 100%;
    padding: var(--spacing-3);
    font-size: 0.9375rem;
    border: 1px solid var(--color-gray-300);
    border-radius: var(--radius-md);
    background: white;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.dynamic-form .form-control:focus-visible {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 15%, transparent);
}

.dynamic-form .form-check {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-2) 0;
    margin-bottom: var(--spacing-1);
}

.dynamic-form .form-check:hover {
    background: var(--color-gray-100);
    margin-left: calc(-1 * var(--spacing-2));
    margin-right: calc(-1 * var(--spacing-2));
    padding-left: var(--spacing-2);
    padding-right: var(--spacing-2);
    border-radius: var(--radius-md);
}

.dynamic-form .form-check-input {
    width: 1.25rem;
    height: 1.25rem;
    margin-right: var(--spacing-2);
    flex-shrink: 0;
    cursor: pointer;
    accent-color: var(--color-primary);
}

.dynamic-form .form-check-label {
    cursor: pointer;
    font-size: 0.9375rem;
    color: var(--color-gray-700);
    user-select: none;
}

.dynamic-form .text-danger {
    color: var(--color-danger);
    font-weight: 600;
    margin-left: var(--spacing-1);
}

.dynamic-form .form-text,
.dynamic-form small.form-text {
    display: block;
    margin-top: var(--spacing-1);
    font-size: 0.8125rem;
    color: var(--color-gray-500);
    line-height: 1.4;
}

.dynamic-form .form-actions {
    display: flex;
    gap: var(--spacing-3);
    margin-top: var(--spacing-6);
    padding: var(--spacing-4);
    background: var(--color-gray-50);
    border-radius: var(--radius-md);
    border-top: none;
}

/* --- Enhanced Typography & Spacing ------------------------------------- */

.dynamic-form .form-group > label {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-gray-800);
    letter-spacing: -0.01em;
    line-height: 1.4;
}

.dynamic-form input.form-control,
.dynamic-form select.form-control {
    min-height: 2.75rem;
    font-size: var(--font-size-base);
}

.dynamic-form textarea.form-control {
    min-height: 5rem;
    font-size: var(--font-size-base);
    line-height: 1.5;
}

.section-content .form-group {
    margin-bottom: var(--spacing-6);
    padding-bottom: var(--spacing-2);
}

.section-content .form-group:last-child {
    margin-bottom: var(--spacing-3);
    padding-bottom: 0;
}

.section-content .form-group + .form-group {
    border-top: 1px solid var(--color-gray-100);
    padding-top: var(--spacing-4);
}

.dynamic-form .form-control::placeholder {
    color: var(--color-gray-400);
    opacity: 1;
}

/* Select dropdown custom arrow */
.dynamic-form select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right var(--spacing-3) center;
    background-repeat: no-repeat;
    background-size: 1.25rem;
    padding-right: 2.5rem;
}

/* --- Work Area & Incident Info ----------------------------------------- */

.work-area {
    background: white;
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    padding: var(--spacing-6);
}

.work-area h3 {
    font-size: var(--font-size-lg);
    font-weight: 600;
    color: var(--color-gray-900);
    margin-bottom: var(--spacing-4);
    padding-bottom: var(--spacing-3);
    border-bottom: 2px solid var(--color-gray-100);
}

.incident-info {
    padding: var(--spacing-4);
    background: linear-gradient(135deg, color-mix(in srgb, var(--color-info) 8%, white) 0%, color-mix(in srgb, var(--color-info) 15%, white) 100%);
    border: 1px solid color-mix(in srgb, var(--color-info) 25%, white);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-4);
}

.incident-info label {
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-gray-600);
    margin-bottom: var(--spacing-1);
}

.incident-display {
    font-size: var(--font-size-base);
    font-weight: 500;
    color: var(--color-gray-800);
}

/* --- Mobile Responsive Form Layout ------------------------------------- */

@media (max-width: 768px) {
    .dynamic-form .form-control {
        font-size: 16px; /* Prevents iOS zoom on focus */
    }

    .section-toggle {
        padding: var(--spacing-4);
    }

    .section-content {
        padding: var(--spacing-4);
    }

    .section-controls {
        flex-wrap: wrap;
        justify-content: center;
    }

    .section-controls .btn {
        flex: 1;
        min-width: 120px;
    }

    .dynamic-form .form-actions {
        flex-direction: column;
    }

    .dynamic-form .form-actions button {
        width: 100%;
    }
}

/* --- Accessibility & High Contrast ------------------------------------- */

.dynamic-form .form-control:focus-visible,
.dynamic-form .form-check-input:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

@media (prefers-contrast: high) {
    .dynamic-form .form-control {
        border-width: 2px;
    }

    .section-toggle .section-title {
        color: var(--color-gray-900);
    }

    .section-field-count {
        background: var(--color-gray-300);
        color: var(--color-gray-800);
    }
}

/* ==========================================================================
   9. Quick-Select Buttons
   --------------------------------------------------------------------------
   Grid of icon+label buttons for selecting common need types during
   intake. Reach-specific intake UI component.
   ========================================================================== */

.quick-select-buttons {
    margin-bottom: var(--spacing-4);
}

.quick-select-label {
    display: block;
    font-size: var(--font-size-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-gray-500);
    margin-bottom: var(--spacing-2);
}

.quick-select-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-2);
}

@media (max-width: 640px) {
    .quick-select-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.quick-select-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-1);
    padding: var(--spacing-3) var(--spacing-2);
    background: white;
    border: 2px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
    min-height: 4.5rem;
}

.quick-select-btn:hover {
    border-color: var(--color-primary);
    background: color-mix(in srgb, var(--color-primary) 5%, white);
}

.quick-select-btn:focus-visible {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

.quick-select-btn.selected {
    background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary) 15%, white) 0%, color-mix(in srgb, var(--color-primary) 25%, white) 100%);
    border-color: var(--color-primary);
    box-shadow: inset 0 2px 4px color-mix(in srgb, var(--color-primary) 10%, transparent);
}

.quick-select-btn.selected .quick-select-text {
    color: var(--color-primary);
    font-weight: 600;
}

.quick-select-icon {
    font-size: 1.5rem;
    line-height: 1;
}

.quick-select-text {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-gray-700);
    text-align: center;
}

.multiselect-divider {
    display: flex;
    align-items: center;
    margin: var(--spacing-4) 0 var(--spacing-3) 0;
}

.multiselect-divider::before,
.multiselect-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-gray-200);
}

.multiselect-divider span {
    padding: 0 var(--spacing-3);
    font-size: var(--font-size-xs);
    font-weight: 500;
    color: var(--color-gray-400);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ==========================================================================
   10. Call Script Panel
   --------------------------------------------------------------------------
   Side-by-side layout with call scripts panel adjacent to intake form.
   Used during Twilio-powered phone calls. Reach-specific.
   ========================================================================== */

.form-scripts-layout {
    display: flex;
    gap: var(--spacing-6);
    align-items: flex-start;
}

/* Override .form-section when inside scripts layout */
.form-scripts-layout > .form-section {
    flex: 1;
    min-width: 0;
    transition: flex 0.3s ease;
}

.form-scripts-layout.scripts-minimized .form-section {
    flex: 1 1 100%;
}

/* --- Scripts Panel ----------------------------------------------------- */

.scripts-panel,
.floating-scripts-panel {
    flex: 0 0 340px;
    width: 340px;
    max-height: calc(100vh - 200px);
    background: white;
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 80px;
    transition: opacity 0.3s ease;
}

.scripts-panel.minimized,
.floating-scripts-panel.minimized {
    display: none;
}

.scripts-panel-header,
.floating-scripts-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-3) var(--spacing-4);
    background: var(--color-gray-50);
    border-bottom: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md) var(--radius-md) 0 0;
}

.scripts-panel-header h4,
.floating-scripts-header h4 {
    margin: 0;
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-gray-800);
}

.scripts-panel-controls,
.floating-scripts-controls {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
}

.script-nav-indicator {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    padding: 0 var(--spacing-1);
    min-width: 40px;
    text-align: center;
}

.scripts-panel-body,
.floating-scripts-body {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-3);
    max-height: calc(100vh - 280px);
}

/* --- Call Script Cards ------------------------------------------------- */

.scripts-panel .call-script-card,
.floating-scripts-panel .call-script-card {
    margin-bottom: var(--spacing-3);
    border: 2px solid transparent;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.scripts-panel .call-script-card:last-child,
.floating-scripts-panel .call-script-card:last-child {
    margin-bottom: 0;
}

.scripts-panel .call-script-card.active-script,
.floating-scripts-panel .call-script-card.active-script {
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 10%, transparent);
}

.scripts-panel .script-title,
.floating-scripts-panel .script-title {
    font-size: 0.8125rem;
}

.scripts-panel .script-content,
.floating-scripts-panel .script-content {
    font-size: 0.8125rem;
    line-height: 1.5;
}

/* --- Restore Button ---------------------------------------------------- */

.scripts-restore-btn {
    display: none;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3) var(--spacing-4);
    background: var(--color-primary);
    color: white;
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-size: var(--font-size-sm);
    font-weight: 500;
    box-shadow: 0 2px 8px color-mix(in srgb, var(--color-primary) 30%, transparent);
    transition: background-color var(--transition-fast);
    align-self: flex-start;
    flex-shrink: 0;
}

.form-scripts-layout.scripts-minimized .scripts-restore-btn {
    display: flex;
}

.scripts-restore-btn:hover {
    background: var(--color-primary-dark);
}

.scripts-restore-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 40%, transparent);
}

/* --- Mobile: Stack vertically ------------------------------------------ */

@media (max-width: 1024px) {
    .form-scripts-layout {
        flex-direction: column;
    }

    .scripts-panel,
    .floating-scripts-panel {
        flex: none;
        width: 100%;
        max-height: none;
        position: relative;
        top: auto;
        order: -1;
        margin-bottom: var(--spacing-4);
    }

    .scripts-panel.minimized,
    .floating-scripts-panel.minimized {
        display: none;
    }

    .scripts-panel-body,
    .floating-scripts-body {
        max-height: 300px;
    }

    .scripts-restore-btn {
        width: 100%;
        justify-content: center;
        order: -1;
        margin-bottom: var(--spacing-4);
    }
}

/* Empty state for call scripts */
.floating-scripts-panel .call-scripts-empty {
    text-align: center;
    padding: var(--spacing-6) var(--spacing-4);
    color: var(--color-gray-500);
}

.floating-scripts-panel .call-scripts-empty p {
    margin: 0 0 var(--spacing-2) 0;
    font-size: var(--font-size-sm);
}

.floating-scripts-panel .call-scripts-empty small {
    font-size: var(--font-size-xs);
    color: var(--color-gray-400);
}

/* ==========================================================================
   11. Phone Type Selector & Same-as-Caller
   --------------------------------------------------------------------------
   Phone input with inline type radio buttons (Mobile/Home/Work) and
   "same as caller" checkbox for homeowner fields. Reach intake-specific.
   ========================================================================== */

.phone-with-type-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2);
}

.phone-with-type-container .phone-input {
    flex: 1;
}

.phone-type-selector {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-1);
}

.phone-type-label {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1);
    padding: var(--spacing-1) var(--spacing-2);
    font-size: var(--font-size-xs);
    color: var(--color-gray-600);
    background: var(--color-gray-100);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.phone-type-label:hover {
    background: var(--color-gray-200);
}

.phone-type-label input[type="radio"] {
    margin: 0;
    width: auto;
}

.phone-type-label:has(input:checked) {
    background: var(--color-primary);
    color: white;
    border-color: var(--color-primary);
}

.phone-type-label:has(input:checked) span {
    font-weight: 500;
}

/* Same as caller checkbox */
.same-as-caller-container {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-3);
    background: var(--color-gray-50);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-4);
}

.same-as-caller-container label {
    margin: 0;
    font-weight: 500;
    cursor: pointer;
}

.same-as-caller-container input[type="checkbox"] {
    width: auto;
    margin: 0;
}

.homeowner-fields-disabled {
    opacity: 0.5;
    pointer-events: none;
}

.homeowner-fields-disabled input,
.homeowner-fields-disabled select,
.homeowner-fields-disabled textarea {
    background: var(--color-gray-100);
}

@media (max-width: 480px) {
    .phone-type-selector {
        flex-wrap: wrap;
    }

    .phone-type-label {
        flex: 1;
        justify-content: center;
        min-width: calc(50% - 0.125rem);
    }
}

/* ==========================================================================
   12. Form Validation
   --------------------------------------------------------------------------
   Validation error/warning states for Reach's intake forms, including
   address validation indicator with loading/verified/warning/error states.
   ========================================================================== */

/* Error state (blocking — prevents submission) */
.form-group.has-error .form-control,
.form-control.is-invalid {
    border-color: var(--color-danger);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-danger) 20%, transparent);
}

.form-group.has-error label {
    color: var(--color-danger);
}

.validation-error {
    font-size: var(--font-size-sm);
    color: var(--color-danger);
    margin-top: var(--spacing-1);
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
}

.validation-error::before {
    content: "\2715";
    font-weight: bold;
}

/* Warning state (non-blocking — informational) */
.form-group.has-warning .form-control,
.form-control.is-warning {
    border-color: var(--color-warning);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-warning) 20%, transparent);
}

.validation-warning {
    font-size: var(--font-size-sm);
    color: var(--color-warning);
    margin-top: var(--spacing-1);
}

/* --- Address Validation Indicator -------------------------------------- */

.address-validation-indicator {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    margin-top: var(--spacing-2);
    padding: var(--spacing-2);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
}

.address-validation-indicator .validation-icon {
    font-size: var(--font-size-base);
}

.address-validation-indicator .validation-text {
    flex: 1;
}

.address-validation-indicator.status-loading {
    background: var(--color-gray-100);
    color: var(--color-gray-600);
}

.address-validation-indicator.status-loading .validation-icon {
    animation: reach-spin 1s linear infinite;
}

.address-validation-indicator.status-verified {
    background: color-mix(in srgb, var(--color-success) 10%, transparent);
    color: var(--color-success);
    border: 1px solid color-mix(in srgb, var(--color-success) 30%, transparent);
}

.address-validation-indicator.status-verified .validation-icon {
    color: var(--color-success);
    font-weight: bold;
}

.address-validation-indicator.status-warning {
    background: color-mix(in srgb, var(--color-warning) 10%, transparent);
    color: var(--color-gray-700);
    border: 1px solid color-mix(in srgb, var(--color-warning) 30%, transparent);
}

.address-validation-indicator.status-warning .validation-icon {
    color: var(--color-warning);
}

.address-validation-indicator.status-error {
    background: var(--color-gray-100);
    color: var(--color-gray-500);
    border: 1px solid var(--color-gray-200);
}

.use-standardized-btn {
    font-size: var(--font-size-xs);
    padding: 0.125rem var(--spacing-2);
    margin-left: var(--spacing-2);
}

/* Valid input state */
.form-control.is-valid {
    border-color: var(--color-success);
}

.form-control:focus.is-invalid {
    outline: none;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-danger) 30%, transparent);
}

/* ==========================================================================
   13. Need Types Configuration (Admin Settings)
   --------------------------------------------------------------------------
   Admin page for managing need type categories. Reach-specific admin UI.
   ========================================================================== */

.need-types-list {
    margin: var(--spacing-4) 0;
}

.need-type-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-2);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-2);
    background: var(--color-gray-50);
}

.need-type-fields {
    display: flex;
    flex: 1;
    gap: var(--spacing-2);
    align-items: center;
}

.need-type-fields input {
    flex: 1;
    padding: var(--spacing-1) var(--spacing-2);
    font-size: var(--font-size-sm);
}

.nt-key {
    font-family: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, monospace;
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    min-width: 120px;
}

.add-need-type {
    display: flex;
    gap: var(--spacing-2);
    margin: var(--spacing-4) 0;
}

.add-need-type input {
    flex: 1;
}

.settings-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    margin-top: var(--spacing-4);
}

#need-types-status {
    font-size: var(--font-size-sm);
    color: var(--color-gray-500);
}

.section-description {
    font-size: var(--font-size-sm);
    color: var(--color-gray-500);
    margin-bottom: var(--spacing-4);
}

.empty-message {
    color: var(--color-gray-500);
    font-style: italic;
    padding: var(--spacing-4);
    text-align: center;
}

@media (max-width: 768px) {
    .need-type-fields {
        flex-direction: column;
        align-items: stretch;
    }

    .nt-key {
        min-width: auto;
    }

    .add-need-type {
        flex-direction: column;
    }
}
