/* ============================================================
   ZIN Website — Custom CSS
   Colors: Green #1B5C2E | Gold #F5C118 | Dark #0F2D17
   Fonts: Playfair Display (headings) | DM Sans (body)
   ============================================================ */
:root {
    --zin-green:       #1B5C2E;
    --zin-green-dark:  #0F2D17;
    --zin-green-mid:   #2E7D4F;
    --zin-green-light: #EBF5EF;
    --zin-gold:        #F5C118;
    --zin-gold-dark:   #C99B0A;
    --zin-text:        #1a1a1a;
    --zin-muted:       #6c757d;
    --radius-card:     14px;
    --shadow-card:     0 4px 24px rgba(27,92,46,.10);
    --shadow-hover:    0 8px 40px rgba(27,92,46,.18);
    --transition:      all .25s ease;
}
*, *::before, *::after { box-sizing: border-box; }
body { font-family: 'DM Sans', sans-serif; color: var(--zin-text); background: #fff; line-height: 1.7; }
h1,h2,h3,h4,h5,h6 { font-family: 'Playfair Display', serif; font-weight: 700; line-height: 1.25; }
a { color: var(--zin-green); text-decoration: none; }
a:hover { color: var(--zin-green-dark); }
em { font-style: normal; color: var(--zin-green); }

/* Utilities */
.py-6 { padding-top: 5rem !important; padding-bottom: 5rem !important; }
.lh-relaxed { line-height: 1.85 !important; }
.text-white-75 { color: rgba(255,255,255,.75) !important; }
.x-small { font-size: .75rem; }
.text-gold { color: var(--zin-gold) !important; }
.bg-light-green { background: var(--zin-green-light) !important; }
.hover-green:hover { color: var(--zin-green) !important; background: var(--zin-green-light); }

/* Buttons */
.zin-btn-green, .btn-zin-green {
    background: var(--zin-green); color: #fff;
    border: 2px solid var(--zin-green); border-radius: 50px;
    font-weight: 600; padding: .55rem 1.6rem; transition: var(--transition);
}
.zin-btn-green:hover, .btn-zin-green:hover {
    background: var(--zin-green-dark); border-color: var(--zin-green-dark); color: #fff;
    transform: translateY(-1px); box-shadow: 0 6px 20px rgba(27,92,46,.25);
}
.zin-btn-gold, .btn-zin-gold {
    background: var(--zin-gold); color: var(--zin-green-dark);
    border: 2px solid var(--zin-gold); border-radius: 50px;
    font-weight: 700; padding: .55rem 1.6rem; transition: var(--transition);
}
.zin-btn-gold:hover, .btn-zin-gold:hover {
    background: var(--zin-gold-dark); border-color: var(--zin-gold-dark);
    color: var(--zin-green-dark); transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(245,193,24,.35);
}
.zin-btn-outline {
    background: transparent; color: #fff;
    border: 2px solid rgba(255,255,255,.6); border-radius: 50px;
    font-weight: 600; padding: .55rem 1.6rem; transition: var(--transition);
}
.zin-btn-outline:hover {
    background: rgba(255,255,255,.1); border-color: #fff; color: #fff;
}

/* Navbar */
.zin-navbar { background: var(--zin-green-dark); padding: .75rem 0; box-shadow: 0 2px 20px rgba(0,0,0,.25); }
.zin-navbar .navbar-toggler { border-color: rgba(255,255,255,.3); }
.zin-brand-text { display: flex; flex-direction: column; line-height: 1.1; }
.zin-brand-name { font-family: 'Playfair Display', serif; font-size: 1.35rem; font-weight: 800; color: var(--zin-gold); letter-spacing: .5px; }
.zin-brand-sub { font-size: .68rem; color: rgba(255,255,255,.7); font-weight: 400; letter-spacing: .3px; }
.zin-navbar .nav-link { color: rgba(255,255,255,.85) !important; font-weight: 500; font-size: .92rem; padding: .45rem .85rem !important; border-radius: 6px; transition: var(--transition); }
.zin-navbar .nav-link:hover, .zin-navbar .nav-link.active { color: var(--zin-gold) !important; background: rgba(255,255,255,.08); }
.zin-dropdown { border: 1px solid #e8f4ec; border-radius: 10px; box-shadow: 0 8px 30px rgba(0,0,0,.12); padding: .5rem; }
.zin-dropdown .dropdown-item { border-radius: 6px; font-size: .9rem; padding: .5rem .9rem; transition: var(--transition); }
.zin-dropdown .dropdown-item:hover { background: var(--zin-green-light); color: var(--zin-green); }

/* Hero */
.zin-hero { position: relative; min-height: 100vh; display: flex; align-items: center; background: var(--zin-green-dark); overflow: hidden; }
.zin-hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; z-index: 0; }
.zin-hero::before { content: ''; position: absolute; inset: 0; z-index: 1; background-image: repeating-linear-gradient(0deg, transparent, transparent 60px, rgba(255,255,255,.012) 60px, rgba(255,255,255,.012) 61px), repeating-linear-gradient(90deg, transparent, transparent 60px, rgba(255,255,255,.012) 60px, rgba(255,255,255,.012) 61px); }
.zin-hero-overlay, .hero-overlay { position: absolute; inset: 0; z-index: 2; background: linear-gradient(135deg, rgba(8,28,14,.82) 0%, rgba(15,45,23,.65) 60%, rgba(27,92,46,.45) 100%); }
.zin-hero-badge { display: inline-block; background: rgba(245,193,24,.15); border: 1px solid rgba(245,193,24,.35); color: var(--zin-gold); font-size: .82rem; font-weight: 600; padding: .4rem 1.1rem; border-radius: 50px; letter-spacing: .3px; animation: fadeDown .6s ease both; }
.zin-hero-title { font-family: 'Playfair Display', serif; font-size: clamp(2.2rem, 5vw, 3.8rem); font-weight: 800; color: #fff; margin: 1.2rem 0 1.5rem; animation: fadeDown .7s .1s ease both; }
.zin-hero-subtitle { font-size: 1.1rem; color: rgba(255,255,255,.78); max-width: 600px; animation: fadeDown .7s .2s ease both; }
@keyframes fadeDown { from { opacity: 0; transform: translateY(-18px); } to { opacity: 1; transform: translateY(0); } }
@keyframes bounce { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(8px); } }

/* Stats Bar */
.zin-stats-bar, .stats-bar { background: var(--zin-green); padding: 2.5rem 0; }
.stat-item { padding: 1.2rem; border-right: 1px solid rgba(255,255,255,.15); }
.stat-item:last-child { border-right: none; }
.stat-number { font-family: 'Playfair Display', serif; font-size: 2.4rem; font-weight: 800; color: var(--zin-gold); line-height: 1; }
.stat-label { font-size: .78rem; color: rgba(255,255,255,.75); margin-top: .4rem; font-weight: 500; text-transform: uppercase; letter-spacing: .5px; }

/* Section Headers */
.zin-section-tag { font-size: .78rem; font-weight: 700; color: var(--zin-green); text-transform: uppercase; letter-spacing: 2px; margin-bottom: .6rem; display: block; }
.zin-section-title { font-size: clamp(1.7rem, 3vw, 2.4rem); font-weight: 800; margin-bottom: 1rem; }
.zin-divider { width: 56px; height: 4px; background: linear-gradient(90deg, var(--zin-green), var(--zin-gold)); border-radius: 2px; }

/* Feature Items */
.zin-feature-item { display: flex; align-items: flex-start; gap: .85rem; background: var(--zin-green-light); border-radius: 10px; padding: .9rem 1rem; border-left: 3px solid var(--zin-green); transition: var(--transition); }
.zin-feature-item:hover { transform: translateX(4px); }

/* Sectors Background */
.zin-sectors-bg { background: linear-gradient(135deg, #f8fdf9 0%, var(--zin-green-light) 100%); }

/* Sector Cards (home page grid) */
.zin-sector-card { display: block; background: #fff; border: 2px solid #e8f4ec; border-radius: var(--radius-card); padding: 2rem 1.5rem; text-align: center; color: var(--zin-text); transition: var(--transition); height: 100%; box-shadow: var(--shadow-card); }
.zin-sector-card:hover { border-color: var(--zin-green); box-shadow: var(--shadow-hover); transform: translateY(-4px); color: var(--zin-text); }
.zin-sector-icon { width: 72px; height: 72px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.2rem; transition: var(--transition); }
.zin-sector-title { font-size: 1.1rem; font-weight: 700; margin-bottom: .5rem; }
.zin-sector-desc { font-size: .9rem; color: var(--zin-muted); margin-bottom: 1rem; }
.zin-sector-link { font-size: .85rem; font-weight: 600; }

/* Sector Cards (full listing page) */
.zin-sector-card-full { background: #fff; border: 2px solid #e8f4ec; border-radius: var(--radius-card); padding: 2rem; text-align: center; transition: var(--transition); box-shadow: var(--shadow-card); }
.zin-sector-card-full:hover { border-color: var(--zin-green); box-shadow: var(--shadow-hover); transform: translateY(-4px); }
.zin-sector-icon-lg { width: 88px; height: 88px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto; transition: var(--transition); }

/* CTA Section */
.zin-cta-section { position: relative; overflow: hidden; background: radial-gradient(ellipse at 70% 50%, rgba(46,125,79,.5) 0%, transparent 60%), var(--zin-green-dark); padding: 5rem 0; }
.zin-cta-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(15,45,23,.5) 0%, transparent 100%); }

/* Page Hero (inner pages) */
.zin-page-hero { position: relative; overflow: hidden; background: radial-gradient(ellipse at 20% 80%, rgba(46,125,79,.4) 0%, transparent 50%), var(--zin-green-dark); padding: 4rem 0 3rem; }
.zin-page-hero-bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; z-index: 0; }
.zin-page-hero-overlay { position: absolute; inset: 0; z-index: 1; background: linear-gradient(135deg, rgba(8,28,14,.85) 0%, rgba(15,45,23,.70) 60%, rgba(27,92,46,.50) 100%); }
.zin-page-hero .container { position: relative; z-index: 2; }
.zin-page-hero-title { color: #fff; font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; margin-top: .5rem; }
.zin-page-hero-sub { color: rgba(255,255,255,.80); font-size: 1.05rem; max-width: 620px; margin: .8rem 0 0; }

/* Job Cards */
.zin-job-card { background: #fff; border-radius: var(--radius-card); border: 2px solid #e8f4ec; padding: 1.5rem; box-shadow: var(--shadow-card); transition: var(--transition); }
.zin-job-card:hover { border-color: var(--zin-green); box-shadow: var(--shadow-hover); transform: translateY(-3px); }
.zin-badge-sector { background: var(--zin-green-light); color: var(--zin-green); font-size: .72rem; font-weight: 700; padding: .25rem .7rem; border-radius: 50px; text-transform: uppercase; letter-spacing: .3px; display: inline-block; }
.zin-badge-type { background: #FFF8E1; color: #7B5800; font-size: .72rem; font-weight: 700; padding: .25rem .7rem; border-radius: 50px; display: inline-block; }
.zin-job-title { font-size: 1rem; font-weight: 700; color: var(--zin-green-dark); }
.zin-job-meta { display: inline-flex; align-items: center; gap: .3rem; font-size: .8rem; color: var(--zin-muted); background: #f5f5f5; padding: .2rem .6rem; border-radius: 50px; }
.zin-deadline { font-size: .82rem; color: #c0392b; font-weight: 600; }

/* Apply Box (job detail) */
.zin-apply-box { background: var(--zin-green-light); border-left: 4px solid var(--zin-green); border-radius: 0 12px 12px 0; padding: 1.5rem 1.8rem; }

/* Sidebar Cards */
.zin-sidebar-card { background: var(--zin-green-light); border-radius: var(--radius-card); border: 1px solid #c8e6cf; }
.zin-cta-sidebar { background: var(--zin-green); border-radius: var(--radius-card); }

/* About page */
.zin-about-stat-card { background: var(--zin-green-light); border-radius: var(--radius-card); box-shadow: var(--shadow-card); }
.stat-number-lg { font-family: 'Playfair Display', serif; font-size: 2.8rem; font-weight: 800; color: var(--zin-green); line-height: 1; }
.zin-vision-card { background: var(--zin-green-light); border-radius: 12px; padding: 2rem; height: 100%; transition: var(--transition); border: 2px solid #c8e6cf; }
.zin-vision-card:hover { border-color: var(--zin-green); }
.zin-vision-icon { width: 56px; height: 56px; background: var(--zin-green); border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; }
.zin-vision-icon i { font-size: 1.6rem; color: var(--zin-gold); }
.zin-pillar-card { background: #fff; border-radius: var(--radius-card); border: 2px solid #e8f4ec; padding: 1.8rem; height: 100%; box-shadow: var(--shadow-card); transition: var(--transition); text-align: center; }
.zin-pillar-card:hover { border-color: var(--zin-green); transform: translateY(-3px); }
.zin-pillar-icon { width: 64px; height: 64px; border-radius: 14px; display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem; }
.zin-metric-tag { background: var(--zin-green-light); color: var(--zin-green); padding: .4rem .8rem; border-radius: 6px; font-size: .78rem; display: inline-block; }

/* Services section */
.zin-services-bg { background: linear-gradient(135deg, #f0f9f3 0%, #fff 100%); }
.zin-service-item { background: #fff; border-radius: 12px; border: 1px solid #e8f4ec; transition: var(--transition); box-shadow: 0 2px 12px rgba(27,92,46,.06); }
.zin-service-item:hover { border-color: var(--zin-green); transform: translateY(-2px); }
.zin-service-icon { width: 48px; height: 48px; background: var(--zin-green-light); border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--zin-green); font-size: 1.4rem; transition: var(--transition); }
.zin-service-item:hover .zin-service-icon { background: var(--zin-green); color: #fff; }

/* How It Works */
.zin-step-num-lg { font-family: 'Playfair Display', serif; font-size: 2rem; font-weight: 800; color: var(--zin-gold); line-height: 1; width: 52px; height: 52px; background: rgba(245,193,24,.12); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto; }
.zin-step-icon-lg { width: 52px; height: 52px; background: var(--zin-green-light); border-radius: 12px; display: flex; align-items: center; justify-content: center; margin: 0 auto; color: var(--zin-green); font-size: 1.4rem; }
.zin-step-card-h { background: #fff; border: 2px solid #e8f4ec; box-shadow: var(--shadow-card); transition: var(--transition); }
.zin-step-card-h:hover { border-color: var(--zin-green); box-shadow: var(--shadow-hover); }

/* Tiers */
.zin-tiers-bg { background: var(--zin-green-dark); }
.zin-tier-card { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.15); border-radius: var(--radius-card); padding: 2rem; color: rgba(255,255,255,.9); transition: var(--transition); }
.zin-tier-card:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.3); }
.zin-tier-premium { background: rgba(245,193,24,.08); border-color: rgba(245,193,24,.4); }
.zin-tier-premium:hover { background: rgba(245,193,24,.13); }
.zin-tier-badge { display: inline-block; background: rgba(255,255,255,.15); color: rgba(255,255,255,.9); font-size: .72rem; font-weight: 700; padding: .3rem .9rem; border-radius: 50px; text-transform: uppercase; letter-spacing: .5px; }
.zin-tier-badge-gold { background: rgba(245,193,24,.25); color: var(--zin-gold); }

/* Contact */
.zin-contact-info-item { display: flex; align-items: center; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid #e8f4ec; }
.zin-contact-info-item:last-of-type { border-bottom: none; }
.zin-contact-icon { width: 44px; height: 44px; background: var(--zin-green); border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--zin-gold); font-size: 1.2rem; }
.zin-contact-form-card { background: var(--zin-green-light); border: 1px solid #c8e6cf; }
.zin-contact-form-card .form-control,
.zin-contact-form-card .form-select { border-radius: 8px; border: 2px solid #c8e6cf; padding: .6rem 1rem; transition: var(--transition); }
.zin-contact-form-card .form-control:focus,
.zin-contact-form-card .form-select:focus { border-color: var(--zin-green); box-shadow: 0 0 0 .2rem rgba(27,92,46,.12); }

/* Social Buttons */
.zin-social-btn { width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.15); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.8); font-size: 1rem; transition: var(--transition); }
.zin-social-btn:hover { background: var(--zin-gold); color: var(--zin-green-dark); }
.zin-social-btn-dark { width: 38px; height: 38px; border-radius: 50%; background: var(--zin-green-light); display: flex; align-items: center; justify-content: center; color: var(--zin-green); font-size: 1rem; transition: var(--transition); }
.zin-social-btn-dark:hover { background: var(--zin-green); color: #fff; }

/* Sector Detail */
.zin-challenge-item { background: #fff; border: 1px solid #e8f4ec; transition: var(--transition); }
.zin-challenge-item:hover { border-color: #c8e6cf; }
.zin-highlight-box { background: var(--zin-green-light); border-left: 4px solid var(--zin-green); border-radius: 0 12px 12px 0; padding: 1.5rem; }
.zin-metric-box { background: #FFF8E1; border-left: 4px solid var(--zin-gold); border-radius: 0 12px 12px 0; padding: 1rem 1.5rem; font-size: .9rem; }
.zin-list { padding-left: 1.2rem; }
.zin-list li { margin-bottom: .5rem; font-size: .95rem; }
.zin-list li::marker { color: var(--zin-green); }

/* Footer */
.zin-footer { background: var(--zin-green-dark); }
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: .45rem; }
.footer-links a { color: rgba(255,255,255,.65); font-size: .88rem; transition: var(--transition); }
.footer-links a:hover { color: var(--zin-gold); }

/* Dropdown for base.twig */
.zin-dropdown { border-radius: 10px; border: 1px solid #e8f4ec; box-shadow: 0 8px 30px rgba(0,0,0,.12); padding: .5rem; min-width: 180px; }

/* ─── Multi-Step Application Form ─── */
.zin-steps-progress { display:flex; align-items:flex-start; justify-content:center; }
.zin-step-item { display:flex; flex-direction:column; align-items:center; gap:.4rem; min-width:80px; }
.zin-step-circle {
    width:46px; height:46px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    border:2px solid #c8e6cf; background:#fff; color:var(--zin-muted);
    transition:var(--transition);
}
.zin-step-item.active   .zin-step-circle { background:var(--zin-green);       border-color:var(--zin-green);  color:#fff; }
.zin-step-item.completed .zin-step-circle { background:var(--zin-green-light); border-color:var(--zin-green);  color:var(--zin-green); }
.zin-step-label { font-size:.7rem; font-weight:700; color:var(--zin-muted); text-transform:uppercase; letter-spacing:.5px; text-align:center; }
.zin-step-item.active .zin-step-label,
.zin-step-item.completed .zin-step-label { color:var(--zin-green); }
.zin-step-connector { flex:1; height:2px; background:#c8e6cf; margin:0 .5rem 1.9rem; align-self:center; transition:background .3s; }
.zin-step-connector.completed { background:var(--zin-green); }

/* Form inputs (apply + payment) */
.zin-input {
    border:2px solid #c8e6cf; border-radius:8px;
    padding:.6rem 1rem; transition:var(--transition);
    font-family:'DM Sans',sans-serif;
}
.zin-input:focus { border-color:var(--zin-green); box-shadow:0 0 0 .2rem rgba(27,92,46,.12); outline:none; }
.zin-input.is-invalid { border-color:#dc3545 !important; }
.zin-input.is-valid   { border-color:var(--zin-green) !important; }

/* Custom radio / checkbox pill options */
.zin-radio-option,
.zin-checkbox-option {
    display:inline-flex; align-items:center; gap:.6rem;
    background:#fff; border:2px solid #c8e6cf; border-radius:8px;
    padding:.5rem 1rem; cursor:pointer; transition:var(--transition); user-select:none;
}
.zin-radio-option:hover,
.zin-checkbox-option:hover { border-color:var(--zin-green-mid); background:var(--zin-green-light); }
.zin-radio-option:has(input:checked),
.zin-checkbox-option:has(input:checked) { border-color:var(--zin-green); background:var(--zin-green-light); }
.zin-option-invalid { border-color:#dc3545 !important; background:#fff5f5 !important; }
.zin-radio-input, .zin-check-input { accent-color:var(--zin-green); width:16px; height:16px; cursor:pointer; flex-shrink:0; }
.zin-option-text { font-size:.9rem; font-weight:500; line-height:1.4; }

/* ─── Payment Page ─── */
.zin-payment-summary {
    background:var(--zin-green-dark); border-radius:var(--radius-card);
    color:#fff; padding:2.5rem; height:100%;
}
.zin-payment-amount { font-family:'Playfair Display',serif; font-size:3.5rem; font-weight:800; color:var(--zin-gold); line-height:1; }
.zin-payment-methods {
    background:#fff; border-radius:var(--radius-card);
    border:2px solid #e8f4ec; padding:2rem; box-shadow:var(--shadow-card);
}
.zin-or-divider {
    display:flex; align-items:center; gap:1rem; margin:1.5rem 0;
    color:var(--zin-muted); font-size:.8rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
}
.zin-or-divider::before, .zin-or-divider::after { content:''; flex:1; height:1px; background:#e8f4ec; }
.zin-card-badge {
    display:inline-flex; align-items:center; gap:.3rem;
    background:#f5f5f5; border:1px solid #ddd; border-radius:4px;
    padding:.2rem .6rem; font-size:.7rem; font-weight:700;
    color:var(--zin-muted); transition:var(--transition);
}
.zin-card-badge.active           { background:#1a1f71; color:#fff; border-color:#1a1f71; }
.zin-card-badge#mc-badge.active  { background:#eb001b; border-color:#eb001b; }

/* ─── Confirmation Page ─── */
.zin-confirm-icon {
    width:88px; height:88px; background:var(--zin-green);
    border-radius:50%; display:flex; align-items:center; justify-content:center;
    box-shadow:0 8px 32px rgba(27,92,46,.35);
}
.zin-ref-badge {
    font-family:'DM Sans',monospace; font-size:.9rem; font-weight:700;
    color:var(--zin-green); background:var(--zin-green-light);
    padding:.2rem .6rem; border-radius:6px; letter-spacing:.8px;
    border:1px solid #c8e6cf;
}

/* Responsive */
@media (max-width: 991px) {
    .py-6 { padding-top: 3.5rem !important; padding-bottom: 3.5rem !important; }
    .zin-hero { min-height: auto; padding: 7rem 0 4rem; }
    .zin-payment-summary { height:auto; }
}
@media (max-width: 575px) {
    .stat-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.1); }
    .stat-item:last-child { border-bottom: none; }
    .zin-steps-progress { gap:.25rem; }
    .zin-step-item { min-width:60px; }
    .zin-step-label { font-size:.6rem; }
}
