/* IMMI PDF Forms — Page Styles */

.ipf-hero-anim { display: flex; align-items: center; justify-content: center; padding: 20px; width: 100%; }
.ipf-pdf-stack { display: flex; gap: 14px; }
.ipf-pdf { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 18px 16px; background: #fff; border-radius: 10px; box-shadow: 0 2px 12px rgba(0,0,0,0.06); opacity: 0; transform: translateY(12px); }
.ipf-pdf i { font-size: 2rem; color: #ef4444; }
.ipf-pdf span { font-size: 0.65rem; font-weight: 700; color: #64748b; }
.ipf-p1 { animation: ipfPop 0.4s 0.2s ease both; }
.ipf-p2 { animation: ipfPop 0.4s 0.45s ease both; }
.ipf-p3 { animation: ipfPop 0.4s 0.7s ease both; }
@keyframes ipfPop { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }

/* Stepper — reuse imf-stepper classes from immi-online */
.imf-stepper { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; position: relative; }
.imf-step { text-align: center; padding: 28px 20px; position: relative; }
.imf-step-icon { width: 56px; height: 56px; border-radius: 50%; background: color-mix(in srgb, var(--step-c) 12%, white); color: var(--step-c); display: flex; align-items: center; justify-content: center; font-size: 1.2rem; margin: 0 auto 16px; position: relative; z-index: 1; transition: transform 0.3s ease, box-shadow 0.3s ease; }
.imf-step:hover .imf-step-icon { transform: scale(1.1); box-shadow: 0 4px 20px color-mix(in srgb, var(--step-c) 25%, transparent); }
.imf-step-connector { position: absolute; top: 54px; right: -50%; width: 100%; height: 2px; background: linear-gradient(to right, var(--step-c), color-mix(in srgb, var(--step-c) 30%, #e2e8f0)); z-index: 0; }
.imf-step:last-child .imf-step-connector { display: none; }
.imf-step h4 { font-family: var(--font-heading); font-size: 1.05rem; font-weight: 700; color: var(--color-text-dark); margin-bottom: 8px; }
.imf-step p { font-size: 0.85rem; color: var(--color-text-light); line-height: 1.6; }

/* Distribution animation */
.ipf-dist-anim { display: flex; align-items: center; justify-content: center; gap: 24px; padding: 30px; width: 100%; }
.ipf-da-template, .ipf-da-client { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 20px; background: #fff; border-radius: 12px; box-shadow: 0 2px 10px rgba(0,0,0,0.06); }
.ipf-da-template i { font-size: 2rem; color: #ef4444; }
.ipf-da-client i { font-size: 2rem; color: #639BF1; }
.ipf-da-template span, .ipf-da-client span { font-size: 0.7rem; font-weight: 700; color: #64748b; }
.ipf-da-arrow { font-size: 1.3rem; color: #e67e22; animation: ipfArrow 2s ease-in-out infinite; }
@keyframes ipfArrow { 0%,100% { transform:translateX(0); opacity:0.4; } 50% { transform:translateX(8px); opacity:1; } }

@media (max-width: 768px) {
    .imf-stepper { grid-template-columns: 1fr 1fr; gap: 16px; }
    .imf-step-connector { display: none; }
    .ipf-pdf-stack { flex-direction: column; }
}
@media (max-width: 480px) { .imf-stepper { grid-template-columns: 1fr; } }
@media (prefers-reduced-motion: reduce) { .ipf-pdf, .ipf-da-arrow { animation: none !important; opacity: 1; transform: none; } }
