/* IPS apply form. handoff D form system applied to the multi-step flow:
   dark hero, cream form section, mono field labels, transparent rule-bordered
   inputs, orange-accented radios/checkboxes. scoped under .ips.apply. */

.ips.apply { background: var(--ips-cream); color: var(--ips-ink); }

.ips .apply-hero { background: var(--ips-hero); color: var(--ips-cream); padding: 48px 56px 56px; }
.ips .apply-hero .eyebrow { color: #a8b0bb; margin-bottom: 26px; font-family: var(--font-mono); font-size: 10.5px; }
.ips .apply-hero .eyebrow::before { background: rgba(245,234,208,.4); }
.ips .apply-hero h1 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(48px, 8vw, 92px); line-height: .95; letter-spacing: .005em; }
.ips .apply-hero h1 .pop { color: var(--ips-accent-bright); }
.ips .apply-hero .hero-body { margin-top: 22px; font-size: 14.5px; line-height: 1.7; color: #cfd4da; max-width: 620px; }

.ips .form-section { padding: 56px; background: var(--ips-cream); scroll-margin-top: 12px; }

/* step-to-step transition. the JS adds .apply-step-enter on page load so a
   new step softly fades in instead of snapping into existence after the
   server-side redirect from /Ips/StepN to /Ips/Apply?step=N+1 */
@keyframes apply-step-fade-in {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
.ips .form-section.apply-step-enter {
    animation: apply-step-fade-in 360ms ease-out both;
}
/* respect users who have asked the OS to dial down motion */
@media (prefers-reduced-motion: reduce) {
    .ips .form-section.apply-step-enter { animation: none; }
}

/* loading state for the submit button while the POST is in flight */
.ips .submit-btn.is-loading { opacity: .75; cursor: progress; }
.ips .form-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 60px; align-items: start; max-width: 1200px; }
.ips .form-side .label { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .22em; text-transform: uppercase; color: var(--ips-accent); margin-bottom: 18px; }
.ips .form-side h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(32px, 4vw, 44px); letter-spacing: .005em; line-height: 1; color: var(--ips-ink); max-width: 480px; }
.ips .form-side .body { margin-top: 22px; font-size: 13px; line-height: 1.7; color: var(--ips-ink-soft); max-width: 400px; }

/* progress */
.ips .apply-progress { margin-bottom: 28px; }
.ips .apply-progress .row-top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; }
.ips .apply-progress .step-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--ips-accent); }
.ips .apply-progress .step-name { font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--ips-muted); }
.ips .apply-progress .track { height: 4px; background: rgba(20,20,20,.12); }
.ips .apply-progress .track .bar { height: 4px; background: var(--ips-accent); transition: width .3s ease; }

/* form grid + fields */
.ips .ips-form { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.ips .ips-form .full { grid-column: span 2; }
.ips .field-label { font-family: var(--font-mono); font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ips-muted); margin-bottom: 8px; display: block; }
.ips .field-label .hint { text-transform: none; letter-spacing: .02em; font-family: var(--font-sans); color: var(--ips-muted); font-style: italic; font-size: 11px; display: block; margin-top: 3px; }
.ips .ips-form input[type=text],
.ips .ips-form input[type=email],
.ips .ips-form input[type=tel],
.ips .ips-form input[type=number],
.ips .ips-form input[type=file],
.ips .ips-form textarea {
    width: 100%;
    background: transparent;
    border: 1px solid var(--ips-rule);
    border-radius: 0;
    padding: 13px 14px;
    font-family: var(--font-sans);
    font-size: 14px;
    color: var(--ips-ink);
    outline: none;
}
.ips .ips-form input:focus, .ips .ips-form textarea:focus { border-color: var(--ips-accent); }
.ips .ips-form input::placeholder, .ips .ips-form textarea::placeholder { color: #a99c79; }
.ips .ips-form textarea { resize: vertical; min-height: 110px; }

.ips .radios, .ips .checks { display: flex; flex-direction: column; gap: 12px; padding-top: 6px; }
.ips .radios label, .ips .checks label { display: inline-flex; align-items: flex-start; gap: 10px; font-size: 13.5px; color: var(--ips-ink-soft); line-height: 1.4; }
.ips .radios input, .ips .checks input { accent-color: var(--ips-accent); margin-top: 2px; }

.ips .submit-row { margin-top: 12px; display: flex; align-items: center; gap: 18px; grid-column: span 2; flex-wrap: wrap; }
.ips .submit-btn { background: var(--ips-accent); color: #fff; border: none; padding: 18px 26px; font-size: 11.5px; letter-spacing: .22em; text-transform: uppercase; font-weight: 600; display: inline-flex; align-items: center; gap: 14px; line-height: 1; cursor: pointer; }
.ips .submit-btn:hover { background: var(--ips-accent-bright); }
.ips .submit-btn .arr { font-family: 'Bebas Neue', sans-serif; font-size: 18px; }
.ips .back-btn { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--ips-ink-soft); border: 1px solid var(--ips-rule); padding: 16px 20px; background: transparent; }
.ips .back-btn:hover { border-color: var(--ips-accent); color: var(--ips-accent); }
.ips .submit-row .note { font-style: italic; color: var(--ips-ink-soft); font-size: 13px; }

.ips .apply-alert { border-left: 2px solid var(--ips-accent); background: var(--ips-cream-2); padding: 14px 18px; font-size: 13px; margin-bottom: 20px; color: var(--ips-ink-soft); }
.ips .apply-alert.ok { border-color: #2e7d32; }
.ips .apply-alert.bad { border-color: #c0392b; }
/* in-form anchors (apply-alert links, privacy-policy link, etc.) should pick
   up the IPS accent rather than the browser default blue; submit + back
   buttons keep their explicit styling because they target their own classes */
.ips .apply-alert a,
.ips .ips-form a,
.ips .checkbox-row a { color: var(--ips-accent); text-decoration: underline; text-underline-offset: 2px; }
.ips .apply-alert a:hover,
.ips .ips-form a:hover,
.ips .checkbox-row a:hover { color: var(--ips-accent-bright); }
.ips .field-error { color: #c0392b; font-size: 12px; margin-top: 4px; display: block; }
.ips .validation-summary-errors { color: #c0392b; font-size: 13px; margin-bottom: 16px; }
.ips .validation-summary-errors ul { margin: 0; padding-left: 18px; }

@media (max-width: 991px) {
    .ips .apply-hero, .ips .form-section { padding-left: 24px; padding-right: 24px; }
    .ips .form-grid { grid-template-columns: 1fr; gap: 28px; }
    .ips .ips-form { grid-template-columns: 1fr; }
    .ips .ips-form .full { grid-column: span 1; }
    .ips .submit-row { grid-column: span 1; }
}
