/* ========== Internship Page ========== */
.internship-page {
    --intern-blue: #3b66f5;
    --intern-blue-soft: rgba(59, 102, 245, 0.12);
    --intern-dark: #0e0e0e;
    --intern-dark-2: #1a1a1a;
    --intern-ink: #222222;
    --intern-muted: #666666;
    --intern-white: #ffffff;
    --tpl-ff-heading: 'Archivo', sans-serif;
    background: #ffffff;
    color: var(--intern-ink);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: clip;
}

/* ---- Shared kicker ---- */
.intern-kicker {
    font-family: 'Archivo', sans-serif;
    font-size: 22px;
    font-weight: 400;
    line-height: 1.4;
    letter-spacing: 0.02em;
    color: inherit;
    margin: 0 0 clamp(0.85rem, 1.5vw, 1.25rem);
}

.intern-kicker--light {
    color: rgba(255, 255, 255, 0.72);
}

.intern-kicker--blue {
    color: var(--intern-blue);
}

/* ======================================
   HERO
====================================== */
.intern-hero {
    padding-top: clamp(4rem, 10vw, 9rem);
    padding-bottom: clamp(3rem, 6vw, 5.5rem);
    padding-left: clamp(1rem, 6vw, 3.5rem);
    padding-right: clamp(1rem, 6vw, 3.5rem);
    background: #ffffff;
    overflow: hidden;
    position: relative;
}

.intern-hero-inner {
    max-width: 1340px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: center;
    position: relative;
    z-index: 1;
}

.intern-hero-copy {
    position: relative;
    max-width: 950px;
}

.intern-hero-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(2.8rem, 6.5vw, 4.4rem);
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: 0.02em;
    color: var(--intern-ink);
    margin: 0 0 1.5rem;
    position: relative;
    z-index: 1;
}

.intern-hero-lead {
    font-family: 'Tenor Sans', sans-serif;
    font-size: clamp(1.05rem, 1.7vw, 1.22rem);
    font-weight: 500;
    line-height: 1.7;
    color: var(--intern-ink);
    margin: 0 0 2.5rem;
    max-width: 52ch;
    position: relative;
    z-index: 1;
}

.intern-hero-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    position: relative;
    z-index: 1;
}

.intern-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.82rem 1.65rem;
    font-family: 'Archivo', sans-serif;
    font-size: 0.97rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    text-decoration: none;
    transition: background 0.22s ease, color 0.22s ease, border-color 0.22s ease, transform 0.18s ease;
    cursor: pointer;
}

.intern-btn--primary {
    background: var(--intern-ink);
    color: #fff;
    border: 1.5px solid var(--intern-ink);
}

.intern-btn--primary:hover {
    background: var(--intern-blue);
    border-color: var(--intern-blue);
    color: #fff;
    transform: translateY(-2px);
}

.intern-btn--ghost {
    background: transparent;
    color: var(--intern-ink);
    border: 1.5px solid rgba(34, 34, 34, 0.35);
}

.intern-btn--ghost:hover {
    border-color: var(--intern-ink);
    transform: translateY(-2px);
}

.intern-btn-icon {
    display: inline-block;
    vertical-align: middle;
    transition: transform 0.2s ease;
}

.intern-btn:hover .intern-btn-icon {
    animation: internArrowSlide 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* Custom slide for down arrow */
.intern-btn:hover .bi-arrow-down.intern-btn-icon {
    animation: internArrowSlideDown 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* Badge cluster */
.intern-hero-visual {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 1.15rem;
    flex-shrink: 0;
    z-index: 1;
}

.intern-hero-visual-bg {
    position: absolute;
    top: 50%;
    right: -30px;
    transform: translateY(-50%);
    width: clamp(450px, 40vw, 680px);
    max-width: none;
    z-index: 0;
    pointer-events: none;
    opacity: 0.85;
}

@media (max-width: 1100px) {
    .intern-hero-visual-bg {
        display: none !important;
    }
}


.intern-hero-badge {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    background: var(--intern-ink);
    color: #fff;
    padding: 1.1rem 1.65rem;
    border-radius: 4px;
    min-width: 170px;
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.intern-hero-badge:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
}

.intern-hero-badge--2 {
    background: var(--intern-blue);
    margin-right: 1.5rem;
}

.intern-hero-badge--3 {
    background: #1a1a1a;
    margin-right: 3rem;
}

.intern-hero-badge-num {
    font-family: 'Archivo', sans-serif;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1;
}

.intern-hero-badge-label {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 0.88rem;
    line-height: 1.4;
    opacity: 0.88;
}

/* ======================================
   DOMAINS
====================================== */
.intern-domains {
    padding: clamp(3.5rem, 7vw, 6rem) clamp(1rem, 6vw, 3.5rem);
    background: #222222;
}

.intern-domains-inner {
    max-width: 1340px;
    margin: 0 auto;
}

.intern-domains-head {
    margin-bottom: clamp(2rem, 4vw, 3rem);
    max-width: 70ch;
}

.intern-domains-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.02em;
    color: #ffffff;
    margin: 0 0 0.85rem;
}

.intern-domains-lead {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1.08rem;
    font-weight: 400;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.7);
    margin: 0;
}

.intern-domain-category {
    margin-bottom: clamp(1.75rem, 3vw, 2.5rem);
    padding-bottom: clamp(1.75rem, 3vw, 2.5rem);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.intern-domain-category:last-of-type {
    border-bottom: none;
    margin-bottom: 1rem;
}

.intern-domain-cat-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(1rem, 1.6vw, 1.15rem);
    font-weight: 600;
    color: #ffffff;
    margin: 0 0 1rem;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    letter-spacing: 0.01em;
}

.intern-domain-cat-title .bi {
    color: var(--intern-blue);
    font-size: 1.1rem;
}

.intern-domain-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem 0.6rem;
}

.intern-domain-tag {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 0.92rem;
    font-weight: 400;
    color: #ffffff;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 0.38rem 0.9rem;
    border-radius: 2px;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
    cursor: default;
}

.intern-domain-tag:hover {
    background: var(--intern-blue);
    border-color: var(--intern-blue);
    color: #ffffff;
}

.intern-domain-tag--highlight {
    background: rgba(59, 102, 245, 0.08);
    border-color: rgba(59, 102, 245, 0.25);
    color: #2550d0;
}

.intern-domain-tag--highlight:hover {
    background: var(--intern-blue);
    color: #fff;
    border-color: var(--intern-blue);
}

.intern-domains-note {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1rem;
    font-weight: 400;
    color: rgba(255, 255, 255, 0.5);
    margin: 1.5rem 0 0;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    flex-wrap: wrap;
}

.intern-domains-note .bi {
    color: var(--intern-blue);
    flex-shrink: 0;
}

.intern-domains-note a {
    color: var(--intern-blue);
    text-decoration: none;
    font-weight: 500;
}

.intern-domains-note a:hover {
    text-decoration: underline;
}

/* ======================================
   WHAT YOU GAIN
====================================== */
.intern-gain {
    padding: clamp(3.5rem, 7vw, 6rem) clamp(1rem, 6vw, 3.5rem);
    background: #ffffff;
}

.intern-gain-inner {
    max-width: 1340px;
    margin: 0 auto;
}

.intern-gain-head {
    margin-bottom: clamp(2rem, 4vw, 3.25rem);
}

.intern-gain-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.02em;
    color: var(--intern-ink);
    margin: 0;
}

.intern-gain-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

.intern-gain-card {
    background: #f9f9f9;
    border: 1px solid rgba(0, 0, 0, 0.07);
    padding: clamp(1.5rem, 2.5vw, 2.1rem);
    border-radius: 2px;
    transition: box-shadow 0.25s ease, transform 0.22s ease, border-color 0.22s ease;
    position: relative;
    overflow: hidden;
}

.intern-gain-card::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--intern-blue);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.28s ease;
}

.intern-gain-card:hover {
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.09);
    transform: translateY(-4px);
    border-color: rgba(59, 102, 245, 0.2);
}

.intern-gain-card:hover::after {
    transform: scaleX(1);
}

.intern-gain-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: var(--intern-blue-soft);
    color: var(--intern-blue);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.45rem;
    margin-bottom: 1.15rem;
    flex-shrink: 0;
    transition: background 0.22s ease, color 0.22s ease;
}

.intern-gain-card:hover .intern-gain-icon {
    background: var(--intern-blue);
    color: #fff;
}

.intern-gain-card-title {
    font-family: 'Archivo', sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--intern-ink);
    margin: 0 0 0.65rem;
    letter-spacing: 0.01em;
}

.intern-gain-card-body {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.65;
    color: #555;
    margin: 0;
}

/* ======================================
   PRICING — dark section
====================================== */
.intern-pricing {
    background: #222222;
    padding: clamp(3.5rem, 7vw, 6.5rem) clamp(1rem, 6vw, 3.5rem);
}

.intern-pricing-inner {
    max-width: 1340px;
    margin: 0 auto;
}

.intern-pricing-head {
    margin-bottom: clamp(2rem, 4vw, 3.25rem);
}

.intern-pricing-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.02em;
    color: #ffffff;
    margin: 0 0 0.85rem;
}

.intern-pricing-sub {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1.08rem;
    font-weight: 400;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.68);
    margin: 0;
}

.intern-pricing-note {
    font-size: 0.93rem;
    color: rgba(255, 255, 255, 0.48);
}

/* Pricing cards in dark section — reuse home pricing card classes */
.intern-pricing-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.25rem;
    margin-top: clamp(1.75rem, 3vw, 2.5rem);
}

/* Reuse .pricing-card, .pricing-features, .pricing-btn from home pricing CSS */
.intern-plan-card {
    background: #222222;
    border: 1px solid transparent;
    border-radius: 2px;
    padding: clamp(1.5rem, 2.5vw, 2rem);
    display: flex;
    flex-direction: column;
    position: relative;
    transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.22s ease;
}

.intern-plan-card:hover {
    border-color: rgba(59, 102, 245, 0.4);
    box-shadow: 0 20px 48px rgba(0, 0, 0, 0.35);
    transform: translateY(-4px);
}

.intern-plan-card .pricing-plan-name {
    font-family: 'Archivo', sans-serif;
    font-size: 1.05rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.72);
    margin: 0 0 0.65rem;
}

.intern-plan-card .pricing-price {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(1.85rem, 3vw, 2.4rem);
    font-weight: 700;
    color: #ffffff;
    line-height: 1.1;
    margin-bottom: 0.3rem;
}

.intern-plan-card .pricing-period {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.48);
    display: block;
    margin-bottom: 1.5rem;
}

.intern-plan-card .pricing-features {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.intern-plan-card .pricing-features li {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 0.96rem;
    line-height: 1.45;
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
}

.intern-plan-card .pricing-features li.included {
    color: rgba(255, 255, 255, 0.85);
}

.intern-plan-card .pricing-features li.not-included {
    color: rgba(255, 255, 255, 0.3);
}

.intern-plan-card .pricing-features li.included .bi {
    color: #3b82f6;
    flex-shrink: 0;
}

.intern-plan-card .pricing-features li.not-included .bi {
    color: rgba(255, 255, 255, 0.2);
    flex-shrink: 0;
}

.intern-plan-card .pricing-btn {
    display: block;
    text-align: center;
    font-family: 'Archivo', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    padding: 0.82rem 1.5rem;
    background: transparent;
    color: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(255, 255, 255, 0.22);
    text-decoration: none;
    transition: background 0.22s ease, border-color 0.22s ease, color 0.22s ease;
    border-radius: 2px;
}

.intern-plan-card .pricing-btn:hover {
    background: var(--intern-blue);
    border-color: var(--intern-blue);
    color: #fff;
}

.intern-plan-card.popular {
    border-color: transparent;
    box-shadow: none;
    background: #222222;
}

.intern-plan-card.popular:hover {
    border-color: var(--intern-blue);
}

.intern-plan-card .pricing-badge {
    position: absolute;
    top: -1px;
    right: 1.25rem;
    background: var(--intern-blue);
    color: #fff;
    font-family: 'Archivo', sans-serif;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.3rem 0.75rem;
    border-radius: 0 0 4px 4px;
}

.intern-plan-card .pricing-btn-popular {
    background: var(--intern-blue);
    border-color: var(--intern-blue);
    color: #fff;
}

.intern-plan-card .pricing-btn-popular:hover {
    background: #2550d0;
    border-color: #2550d0;
}

.intern-pricing-disclaimer {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 0.9rem;
    color: rgba(255, 255, 255, 0.36);
    margin: 2rem 0 0;
    line-height: 1.6;
    max-width: 80ch;
}

/* ======================================
   HOW IT WORKS
====================================== */
.intern-process {
    padding: clamp(3.5rem, 7vw, 6rem) clamp(1rem, 6vw, 3.5rem);
    background: #ffffff;
}

.intern-process-inner {
    max-width: 1340px;
    margin: 0 auto;
}

.intern-process-head {
    margin-bottom: clamp(2rem, 4vw, 3.25rem);
}

.intern-process-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.02em;
    color: var(--intern-ink);
    margin: 0;
}

.intern-process-grid {
    display: grid;
    grid-template-columns: 1.12fr 0.88fr;
    gap: clamp(2rem, 5vw, 4.5rem);
    align-items: center;
}

.intern-process-visual {
    width: 100%;
    position: relative;
    z-index: 1;
}

.intern-process-img-frame {
    position: relative;
    border-radius: 4px;
    overflow: hidden;
    box-shadow: 0 42px 90px rgba(0, 0, 0, 0.14);
}

.intern-process-img-frame img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.intern-process-visual:hover img {
    transform: scale(1.05);
}

.intern-steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    position: relative;
}

.intern-steps::before {
    content: '';
    position: absolute;
    left: calc(clamp(2rem, 3.5vw, 2.6rem) - 1px);
    top: 0;
    bottom: 0;
    width: 1px;
    background: linear-gradient(to bottom, rgba(59, 102, 245, 0.6), rgba(59, 102, 245, 0.05));
    pointer-events: none;
}

.intern-step {
    display: grid;
    grid-template-columns: clamp(2rem, 3.5vw, 2.6rem) 1fr;
    gap: 0 clamp(1.25rem, 2.5vw, 2rem);
    padding-bottom: clamp(2rem, 4vw, 3rem);
    position: relative;
    align-items: flex-start;
}

.intern-step:last-child {
    padding-bottom: 0;
}

.intern-step-num {
    font-family: 'Archivo', sans-serif;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #fff;
    background: var(--intern-blue);
    width: clamp(2rem, 3.5vw, 2.6rem);
    height: clamp(2rem, 3.5vw, 2.6rem);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    box-shadow: 0 0 0 4px rgba(59, 102, 245, 0.14);
}

.intern-step-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(1.05rem, 1.8vw, 1.22rem);
    font-weight: 600;
    color: var(--intern-ink);
    margin: 0 0 0.55rem;
    padding-top: 0.2rem;
}

.intern-step-desc {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.7;
    color: #555;
    margin: 0;
    max-width: 62ch;
}

/* ======================================
   APPLY FORM
====================================== */
.intern-apply {
    padding: clamp(3.5rem, 7vw, 6rem) clamp(1rem, 6vw, 3.5rem);
    background: #f5f5f5;
}

.intern-apply-inner {
    max-width: 1340px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.98fr);
    gap: clamp(2rem, 4vw, 3.5rem);
    align-items: start;
}

.intern-apply-title {
    font-family: 'Archivo', sans-serif;
    font-size: clamp(2rem, 4vw, 2.85rem);
    font-weight: 500;
    line-height: 1.2;
    letter-spacing: 0.02em;
    color: var(--intern-ink);
    margin: 0 0 1.1rem;
}

.intern-apply-lead {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.7;
    color: var(--intern-ink);
    margin: 0 0 2rem;
    max-width: 46ch;
}

.intern-apply-perks {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.intern-apply-perks li {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1rem;
    font-weight: 500;
    color: var(--intern-ink);
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.intern-apply-perks li .bi {
    color: var(--intern-blue);
    font-size: 1.05rem;
    flex-shrink: 0;
}

/* FAQ in Apply Section */
.intern-faq-container {
    padding-top: 1rem;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.intern-faq-title-sm {
    font-family: 'Archivo', sans-serif;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--intern-ink);
    margin-bottom: 1.5rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.intern-faq-item {
    margin-bottom: 1.25rem;
}

.intern-faq-q {
    font-family: 'Archivo', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--intern-ink);
    margin-bottom: 0.35rem;
}

.intern-faq-a {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 0.95rem;
    line-height: 1.5;
    color: rgba(30, 30, 30, 0.7);
    margin-bottom: 0;
}

.intern-aeo-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.intern-aeo-list li {
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1rem;
    line-height: 1.6;
    color: var(--intern-ink);
    margin-bottom: 0.85rem;
    display: flex;
    flex-direction: column;
}

.intern-aeo-list li strong {
    color: var(--intern-blue);
    font-family: 'Archivo', sans-serif;
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    margin-bottom: 0.15rem;
}

.intern-apply-form-wrap {
    background: #222222;
    padding: clamp(1.9rem, 3.4vw, 2.65rem);
    border-radius: 2px;
    box-shadow: 0 24px 48px rgba(0, 0, 0, 0.18);
    align-self: start;
    width: 100%;
    margin-top: clamp(-3.5rem, -6vw, -1.5rem);
}

.intern-apply-form {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.intern-field input,
.intern-field select,
.intern-field textarea {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    padding: 1.75rem 0 1.4rem;
    font-family: 'Tenor Sans', sans-serif;
    font-size: 1.05rem;
    font-weight: 400;
    color: #fff;
    outline: none;
    transition: border-color 0.2s ease;
    -webkit-appearance: none;
    appearance: none;
    -webkit-font-smoothing: antialiased;
    box-sizing: border-box;
}

.intern-field select {
    cursor: pointer;
}

.intern-field select option {
    background: #1a1a1a;
    color: #fff;
}

.intern-field select optgroup {
    background: #1a1a1a;
    color: rgba(255, 255, 255, 0.55);
    font-family: 'Archivo', sans-serif;
    font-size: 0.88rem;
    border-top: 1px solid #2a2a2a;
}

.intern-field input::placeholder,
.intern-field textarea::placeholder {
    color: rgba(255, 255, 255, 0.48);
    font-weight: 400;
}

.intern-field select:invalid {
    color: rgba(255, 255, 255, 0.48);
}

.intern-field input:focus,
.intern-field select:focus,
.intern-field textarea:focus {
    border-bottom-color: rgba(255, 255, 255, 0.72);
}

.intern-field--textarea textarea {
    resize: none;
    line-height: 1.45;
    padding: 1.75rem 0 1.8rem;
    min-height: calc(1.75rem + 2.6em + 1.8rem);
    max-height: calc(1.75rem + 2.6em + 1.8rem);
    overflow-y: auto;
}

.intern-submit {
    align-self: flex-start;
    margin-top: 1.5rem;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.78rem 1.5rem;
    background: transparent;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.9);
    font-family: 'Archivo', sans-serif;
    font-size: 0.97rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: background 0.22s ease, color 0.22s ease, border-color 0.22s ease;
}

.intern-submit:hover {
    background: var(--intern-blue);
    border-color: var(--intern-blue);
    color: #fff;
}

.intern-submit:focus-visible {
    outline: 2px solid var(--intern-blue);
    outline-offset: 3px;
}

.intern-submit-arrow {
    font-size: 1.05rem;
    display: inline-block;
    vertical-align: middle;
}

.intern-submit:hover .intern-submit-arrow,
.intern-submit:focus-visible .intern-submit-arrow {
    animation: internArrowSlide 0.7s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes internArrowSlide {
    0% {
        transform: translate(0, 0);
        opacity: 1;
    }

    35% {
        transform: translate(14px, -14px);
        opacity: 0;
    }

    50% {
        transform: translate(-14px, 14px);
        opacity: 0;
    }

    100% {
        transform: translate(0, 0);
        opacity: 1;
    }
}

@keyframes internArrowSlideDown {
    0% {
        transform: translate(0, 0);
        opacity: 1;
    }

    35% {
        transform: translate(0, 14px);
        opacity: 0;
    }

    50% {
        transform: translate(0, -14px);
        opacity: 0;
    }

    100% {
        transform: translate(0, 0);
        opacity: 1;
    }
}

@media (prefers-reduced-motion: reduce) {

    .intern-submit:hover .intern-submit-arrow,
    .intern-submit:focus-visible .intern-submit-arrow {
        animation: none;
    }
}

/* ======================================
   RESPONSIVE
====================================== */
@media (max-width: 1100px) {
    .intern-hero-visual {
        display: none;
    }

    .intern-hero-inner {
        grid-template-columns: 1fr;
    }

    .intern-pricing-cards {
        grid-template-columns: repeat(2, 1fr);
    }

    .intern-process-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .intern-process-visual {
        display: none;
    }
}

@media (max-width: 900px) {
    .intern-gain-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .intern-apply-inner {
        grid-template-columns: 1fr;
    }

    .intern-apply-form-wrap {
        margin-top: 0;
        order: 2;
    }

    .intern-apply-info {
        order: 1;
    }
}

@media (max-width: 640px) {
    .intern-gain-grid {
        grid-template-columns: 1fr;
    }

    .intern-pricing-cards {
        grid-template-columns: 1fr;
    }

    .intern-hero-title {
        font-size: clamp(2.2rem, 9vw, 3.1rem);
    }

    .intern-btn {
        width: 100%;
        justify-content: center;
    }

    .intern-hero-actions {
        flex-direction: column;
    }

    .intern-submit {
        width: 100%;
        justify-content: center;
        box-sizing: border-box;
    }
}

@media (max-width: 480px) {
    .intern-hero-deco {
        display: none;
    }

    .intern-kicker {
        font-size: 18px;
    }
}

/* ======================================
   NEW FORM ENHANCEMENTS
   ====================================== */
.intern-form-section-title {
    font-family: 'Archivo', sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--intern-blue);
    margin: 2.5rem 0 1.25rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.intern-form-section-title:first-child {
    margin-top: 0;
}

.intern-field .form-label {
    margin-bottom: 0.25rem;
    display: block;
    color: rgba(255, 255, 255, 0.45);
    font-size: 0.78rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}

.intern-field input[type="file"],
.intern-field input[type="date"] {
    padding-top: 0.8rem;
    padding-bottom: 0.8rem;
    font-size: 0.95rem;
    color: #fff !important;
    background: transparent !important;
}

/* File button styling */
.intern-field input[type="file"]::file-selector-button {
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 0.4rem 1rem;
    border-radius: 2px;
    margin-right: 1.2rem;
    transition: 0.2s;
    cursor: pointer;
    font-family: 'Archivo', sans-serif;
    font-size: 0.85rem;
}

.intern-field input[type="file"]::file-selector-button:hover {
    background: var(--intern-blue);
    border-color: var(--intern-blue);
}

/* Autofill Hack: Prevent white/blue background in Chrome */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
textarea:-webkit-autofill:active,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus,
select:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 1000px #222222 inset !important;
    -webkit-text-fill-color: white !important;
    transition: background-color 5000s ease-in-out 0s;
}

.intern-field input,
.intern-field select,
.intern-field textarea {
    color: #fff !important;
}

/* White calendar icons for date inputs */
.intern-field input[type="date"]::-webkit-calendar-picker-indicator {
    filter: invert(1);
    cursor: pointer;
}

.text-dim {
    color: rgba(255, 255, 255, 0.45) !important;
}

/* Success Overlay - Premium Receipt Design */
.intern-success-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.9);
    backdrop-filter: blur(15px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    animation: fadeIn 0.4s ease forwards;
}

.intern-success-card {
    background: #111111;
    border: 1px solid rgba(255, 255, 255, 0.05);
    max-width: 460px;
    width: 100%;
    padding: 3rem 2.5rem;
    text-align: center;
    border-radius: 6px;
    box-shadow: 0 40px 100px rgba(0, 0, 0, 0.8), inset 0 1px 0 rgba(255, 255, 255, 0.05);
    position: relative;
    overflow: hidden;
}

.intern-success-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, transparent, #2563eb, transparent);
    opacity: 0.5;
}

.intern-success-icon {
    font-size: 3.5rem;
    color: #2ed573;
    margin-bottom: 1.5rem;
    display: block;
    line-height: 1;
    filter: drop-shadow(0 0 20px rgba(46, 213, 115, 0.3));
}

.intern-success-card h3 {
    font-family: 'Archivo', sans-serif;
    color: #fff;
    font-size: 1.7rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
}

.intern-success-card p {
    font-family: 'Tenor Sans', sans-serif;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.5;
    font-size: 0.95rem;
    margin-bottom: 1.5rem;
}

.intern-success-card .intern-success-note {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 1rem;
    background: transparent !important;
}

.intern-app-id-display {
    background: rgba(37, 99, 235, 0.05);
    border: 1px dashed rgba(37, 99, 235, 0.5);
    color: #3b82f6;
    padding: 1rem;
    font-family: 'Archivo', sans-serif;
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    border-radius: 4px;
    margin: 1.5rem 0;
}

.intern-receipt-details {
    background: rgba(255, 255, 255, 0.02);
    border-radius: 6px;
    padding: 1rem 1.25rem;
    margin-bottom: 1.5rem;
    border: 1px solid rgba(255, 255, 255, 0.05);
}

.receipt-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.5rem 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.receipt-row:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.receipt-row:first-child {
    padding-top: 0;
}

.receipt-label {
    font-family: 'Tenor Sans', sans-serif;
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.85rem;
}

.receipt-value {
    font-family: 'Archivo', sans-serif;
    color: #fff;
    font-weight: 600;
    font-size: 0.9rem;
}

.intern-success-card .btn-primary {
    background: #2563eb;
    border: none;
    font-family: 'Archivo', sans-serif;
    font-weight: 600;
    padding: 0.75rem 3rem;
    border-radius: 4px;
    transition: all 0.3s ease;
}

.intern-success-card .btn-primary:hover {
    background: #1d4ed8;
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(37, 99, 235, 0.3);
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

@media (max-width: 640px) {
    .intern-success-card {
        padding: 2.5rem 1.5rem;
    }

    .intern-app-id-display {
        font-size: 1rem;
    }
}

/* ======================================
   STATISTICS (ODOMETER) — Exact match with services.css
   ====================================== */

/* section-spacing matching services page */
.internship-page .section-spacing {
    padding-top: 70px;
    padding-bottom: 70px;
}

.internship-page .fact-area {
    background: #1F1F1F;
}

.internship-page .fact-area .container {
    width: 100%;
    padding-inline-end: var(--bs-gutter-x, 15px);
    padding-inline-start: var(--bs-gutter-x, 15px);
    margin-inline-end: auto;
    margin-inline-start: auto;
}

@media (min-width: 1441px) {
    .internship-page .fact-area .container {
        max-width: 1440px;
    }
}

.internship-page .fact-area-title-wrapper {
    padding: 40px;
    border: 1px solid #414141;
    border-bottom: 0;
}

.internship-page .fact-area-title-wrapper h2 {
    margin: 0;
}

.internship-page .fact-box-wrapper {
    border: 1px solid #414141;
}

.internship-page .fact-box-wrapper>.row>div:not(:last-child) {
    border-right: 1px solid #414141;
}

@media only screen and (min-width: 576px) and (max-width: 767px),
(max-width: 575px) {
    .internship-page .fact-box-wrapper>.row>div:not(:last-child) {
        border-right: 0;
        border-bottom: 1px solid #414141;
    }
}

@media only screen and (min-width: 992px) and (max-width: 1199px),
only screen and (min-width: 768px) and (max-width: 991px) {
    .internship-page .fact-box-wrapper>.row>div:nth-child(2n) {
        border-right: 0;
    }
}

@media only screen and (min-width: 992px) and (max-width: 1199px),
only screen and (min-width: 768px) and (max-width: 991px) {
    .internship-page .fact-box-wrapper>.row>div:not(:nth-last-child(-n+2)) {
        border-bottom: 1px solid #414141;
    }
}

.internship-page .fact-box {
    padding: 80px 40px 70px;
}

.internship-page .fact-box-content .fact__number {
    font-size: 30px;
    color: #fff;
    font-weight: 400;
    margin-bottom: 5px;
}

.internship-page .fact-box-content .fact__number span span {
    font-family: var(--tpl-ff-heading);
    font-size: 80px;
    color: var(--intern-blue);
    font-weight: 500;
    line-height: 1;
}

@media only screen and (min-width: 1200px) and (max-width: 1399px) {
    .internship-page .fact-box-content .fact__number span span {
        font-size: 70px;
    }
}

@media only screen and (min-width: 576px) and (max-width: 767px),
(max-width: 575px) {
    .internship-page .fact-box-content .fact__number span span {
        font-size: 70px;
    }
}

@media (max-width: 450px) {
    .internship-page .fact-box-content .fact__number span span {
        font-size: 60px;
    }
}

.internship-page .fact-box-content .fact__number>span {
    display: flex;
    align-items: center;
    gap: 24px;
}

.internship-page .fact__text p {
    margin-bottom: 0;
    color: #A5A5A5;
    text-transform: uppercase;
    font-size: 16px;
    font-family: var(--tpl-ff-heading);
}

/* xlarge heading — matching services */
.internship-page .xlarge {
    font-size: 80px;
    font-family: var(--tpl-ff-heading);
    font-weight: 600;
    line-height: 1.2;
    text-transform: capitalize;
}

@media only screen and (min-width: 1200px) and (max-width: 1399px) {
    .internship-page .xlarge {
        font-size: 70px;
    }
}

@media only screen and (min-width: 992px) and (max-width: 1199px) {
    .internship-page .xlarge {
        font-size: 60px;
    }
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
    .internship-page .xlarge {
        font-size: 46px;
    }
}

@media only screen and (min-width: 576px) and (max-width: 767px),
(max-width: 575px) {
    .internship-page .xlarge {
        font-size: 42px;
    }
}

@media (max-width: 450px) {
    .internship-page .xlarge {
        font-size: 36px;
    }
}

/* fw-500 helper */
.internship-page .fw-500 {
    font-weight: 500;
}

/* text-white helper for fact heading */
.internship-page .text-white,
.internship-page .text-white h2 {
    color: #eeeeee !important;
}

/* Odometer specific overrides */
.internship-page .odometer {
    display: inline-block !important;
    font-family: var(--tpl-ff-heading);
    font-weight: 500;
}

.internship-page .odometer .odometer-digit {
    display: inline-block !important;
    vertical-align: middle;
    position: relative;
}

.internship-page .odometer .odometer-digit .odometer-digit-inner {
    display: block !important;
}

.internship-page .odometer .odometer-ribbon-inner {
    transition: transform 2s !important;
}

.internship-page .odometer.odometer-auto-theme .odometer-ribbon-inner,
.internship-page .odometer.odometer-theme-default .odometer-ribbon-inner {
    transition: transform 2s !important;
}

/* Circular Badge Styles — matching services.css exactly */
.internship-page .circle-btn {
    height: 180px;
    width: 180px;
    position: relative;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
}

.internship-page .circle-btn .icon-box {
    height: 120px;
    width: 120px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    background: #1F1F1F;
    border-radius: 50%;
    position: relative;
    z-index: 2;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    color: #fff;
    font-size: 35px;
    font-weight: 400;
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
    background-size: cover !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    overflow: hidden !important;
}

.internship-page .circle-btn .image-text {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    animation: contactSpin 20s linear infinite;
    filter: invert(98%) sepia(100%) saturate(0%) hue-rotate(154deg) brightness(102%) contrast(102%);
    z-index: 1;
}

.internship-page .circle-btn:hover .icon-box {
    background: var(--intern-blue);
    transform: scale(1.1);
}

.internship-page .circle-btn:hover .icon-box svg path {
    fill: #fff;
}

.internship-page .thumb-video-btn .circle-btn {
    width: 160px;
    height: 160px;
}

.internship-page .thumb-video-btn .circle-btn .icon-box {
    width: 110px;
    height: 110px;
    background-color: #1F1F1F;
}

.internship-page .thumb-video-btn .circle-btn .image-text {
    filter: invert(98%) sepia(100%) saturate(0%) hue-rotate(154deg) brightness(102%) contrast(102%);
}

@media (max-width: 640px) {
    .internship-page .section-spacing {
        padding-top: 50px;
        padding-bottom: 50px;
    }

    .internship-page .fact-area-title-wrapper {
        padding: 20px;
        text-align: center;
    }

    .internship-page .fact-box {
        padding: 40px 20px 30px;
    }

    .internship-page .thumb-video-btn {
        justify-content: center !important;
        margin-top: 1.5rem;
    }

    .internship-page .circle-btn,
    .internship-page .thumb-video-btn .circle-btn {
        width: 130px;
        height: 130px;
    }

    .internship-page .circle-btn .icon-box,
    .internship-page .thumb-video-btn .circle-btn .icon-box {
        width: 90px;
        height: 90px;
        font-size: 30px;
    }
}
