/* OIHI Landing Page — mobile-first, performance-focused */

:root{
  --navy:#004a82;
  --navy-deep:#012643;
  --navy-darker:#013c69;
  --blue:#3389ca;
  --blue-mid:#2786ce;
  --blue-light:#bfdbfe;
  --blue-50:#e5f1ff;
  --blue-bg:#f5faff;
  --ecf:#ecf4ff;
  --cyan:#47ccdb;
  --pink:#d6449f;
  --orange:#ff8328;
  --ink:#111827;
  --text:#000;
  --muted:rgba(0,0,0,.5);
  --soft:rgba(0,0,0,.75);
  --border:#cecece;
  --radius:14px;
  --radius-lg:20px;
  --hero-grad:linear-gradient(129deg,#004a82 21%,#012643 154%);
  --btn-grad:linear-gradient(161deg,#004a82 21%,#012643 154%);
}

*,*:before,*:after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Rubik',system-ui,-apple-system,sans-serif;
  font-size:16px;
  line-height:1.5;
  color:var(--text);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,p{margin:0}
input,select,textarea{font:inherit;color:inherit}

.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* ==================== BUTTONS ==================== */
.btn{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 22px;border-radius:46px;font-weight:500;font-size:16px;
  text-align:center;white-space:nowrap;letter-spacing:-.02em;
  transition:transform .25s cubic-bezier(.4,0,.2,1),
             box-shadow .3s ease,
             background-position .6s ease,
             filter .25s ease;
  background-size:200% 100%;background-position:0% 50%;
  will-change:transform;
  isolation:isolate;
}
/* Shine sweep */
.btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-120%);
  transition:transform .7s cubic-bezier(.4,0,.2,1);
  pointer-events:none;z-index:1;
}
.btn:hover::before{transform:translateX(120%)}
.btn>*{position:relative;z-index:2}
.btn:hover{
  transform:translateY(-2px) scale(1.015);
  filter:brightness(1.08);
}
.btn:active{transform:translateY(0) scale(.99);transition-duration:.1s}

.btn-primary{
  background:linear-gradient(110deg,#004a82 0%,#0a64a8 50%,#004a82 100%);
  color:#fff;
  box-shadow:0 4px 14px rgba(0,74,130,.25);
}
.btn-primary:hover{
  background-position:100% 50%;
  box-shadow:0 8px 28px rgba(0,74,130,.5),0 0 0 1px rgba(71,204,219,.3);
}

.btn-dark{
  background:linear-gradient(110deg,#004a82 0%,#0a64a8 45%,#012643 100%);
  color:#fff;padding:16px 24px;font-size:18px;
  box-shadow:0 4px 14px rgba(0,74,130,.3);
}
.btn-dark:hover{
  background-position:100% 50%;
  box-shadow:0 10px 32px rgba(0,74,130,.55),0 0 0 1px rgba(71,204,219,.35);
}
.btn-dark svg{color:var(--navy);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.btn-dark:hover svg{transform:rotate(-12deg) scale(1.08)}
.btn-submit{
  width:100%;
  background:linear-gradient(110deg,#004a82 0%,#0a64a8 45%,#012643 100%);
  background-size:200% 100%;background-position:0% 50%;
  color:#fff;padding:16px;border-radius:900px;font-size:16px;margin-top:8px;
  box-shadow:0 4px 14px rgba(0,74,130,.3);
}
.btn-submit:hover{
  background-position:100% 50%;
  box-shadow:0 10px 32px rgba(0,74,130,.5),0 0 0 1px rgba(71,204,219,.3);
}
.btn-submit[disabled]{cursor:not-allowed;opacity:.85}
.btn-submit .spinner{
  display:none;width:18px;height:18px;margin-right:10px;flex-shrink:0;
  border:2px solid rgba(255,255,255,.35);border-top-color:#fff;
  border-radius:50%;animation:spin .7s linear infinite;
}
.btn-submit.is-loading{background:linear-gradient(161deg,#3389ca,#004a82);pointer-events:none}
.btn-submit.is-loading .spinner{display:inline-block}
.btn-submit.is-success{background:#0a8754}
.btn-submit.is-success .spinner{display:none}
/* progress shimmer on loading */
.btn-submit.is-loading:before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0,rgba(255,255,255,.25) 50%,transparent 100%);
  animation:shimmer 1.4s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.icon{flex-shrink:0}

/* ==================== HEADER ==================== */
.site-header{
  position:sticky;top:12px;z-index:50;
  padding:12px 16px 0;
}
.nav-pill{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  background:#fff;border-radius:98px;
  padding:12px 16px 12px 24px;
  box-shadow:0 4px 20px rgba(0,0,0,.08);
  box-sizing:border-box;
}
.logo img{width:103px;height:auto}
.nav-links{display:none;gap:40px;align-items:center;font-size:18px}
.nav-links a{transition:color .15s}
.nav-links a:hover{color:var(--navy)}
.btn-cta{font-size:15px;padding:12px 20px;flex:1;max-width:220px;justify-content:center}
.btn-cta svg{width:18px;height:18px}
.nav-toggle{display:flex;padding:6px;color:var(--navy);flex-shrink:0}

/* ---- Mobile < 768px — pixel-perfect per Figma 2273:4676 ---- */
@media (max-width:767px){
  .site-header{
    position:static;top:0;padding:0;
    border-bottom:1px solid var(--border);background:#fff;
  }
  .nav-pill{
    border-radius:0;box-shadow:none;
    max-width:none;width:100%;
    height:83px;padding:0 16px;
    gap:12px;
  }
  .btn-cta{display:none}
  .nav-links{display:none}
  .nav-toggle{color:var(--navy)}
  .nav-toggle svg{width:32px;height:31px}

  /* HERO — mobile tuning per Figma 2273:4676 */
  .hero{margin-top:0;padding:0 0 48px;background:#013863}
  .hero-inner{gap:24px}
  .hero h1{font-size:32px;line-height:1.1}
  .hero-lead{font-size:15px;margin-top:12px}
  .badge-row{color:#bfdbfe;font-size:11px;letter-spacing:.08em}
  .badge-row svg{color:var(--cyan)}

  /* FORM CARD */
  .form-card{padding:24px 20px;border-radius:20px;gap:14px}
  .form-card h2{font-size:20px}
  .form-sub{font-size:12px;line-height:1.45}
  .hero .form-card h2,.hero .form-card .form-sub{display:none}
  .field{font-size:13px}
  .field input,.field select,.iti--separate-dial-code .iti__tel-input{
    height:44px;font-size:16px; /* 16px prevents iOS zoom on focus */
  }
  .row-2{gap:12px}
  .consent{line-height:1.45}
  .consent input{width:18px;height:18px}

  /* Section rhythm */
  .programs,.practicum,.financial,.bottom-cta{padding:48px 0}
  /* Mobile ref has no CTA button inside PSW/MOA cards */
  .program-card .btn-dark{display:none}
  .testimonial{padding:48px 0}

  /* Programs — kill decorative pseudos on small screens (they overflow) */
  .programs::before,.programs::after{display:none}

  /* Practicum tabs — compact */
  .p-tab{padding:10px 16px;font-size:14px}

  /* Financial banner — tighter padding */
  .fa-banner{padding:20px;font-size:14px;border-radius:16px}

  /* Bottom CTA image — smaller radius */
  .bc-image{border-radius:20px}

  /* Color strip — thinner on mobile */
  .color-strip{height:8px}
}

/* Tablet (768–899): still use mobile header layout — hide CTA, use static header */
@media (max-width:899px){
  .btn-cta{display:none}
  .site-header{position:relative;top:0;padding:0;border-bottom:1px solid var(--border);background:#fff;z-index:50}
  .nav-pill{border-radius:0;box-shadow:none;max-width:none;width:100%;height:83px;padding:0 16px;gap:12px;position:relative}
  .nav-links{display:none}
  .nav-toggle{display:flex;color:var(--navy)}
}
@media (min-width:900px){
  .site-header{top:32px;padding:0 20px}
  .nav-pill{padding:14px 20px 14px 32px}
  .logo img{width:116px}
  .nav-links{display:flex}
  .btn-cta{font-size:18px;padding:14px 20px}
  .nav-toggle{display:none}
}

/* ==================== HERO ==================== */
.hero{
  position:relative;
  background:#013c69;
  color:#fff;
  padding:0 0 48px;
  overflow:hidden;
}
@media (min-width:900px){
  .hero{margin-top:-90px;padding:150px 0 64px}
}
.hero-deco{display:none}
.hero-inner{position:relative;z-index:1}
/* Hide desktop hero image card on mobile (not in Figma mobile) */
.hero-image-card{display:none}
.hero-inner{
  max-width:1200px;margin:0 auto;padding:0 20px;
  display:grid;gap:40px;align-items:start;
}
.hero-copy{padding-top:0}
@media (min-width:1000px){.hero-copy{padding-top:20px}}
.badge-row{
  display:inline-flex;align-items:center;gap:10px;
  font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;
  margin-bottom:20px;color:#fff;
}
.badge-row svg{color:var(--cyan)}
.hero h1{
  font-size:clamp(34px,5vw,54px);
  font-weight:500;letter-spacing:-.01em;line-height:1.08;
  max-width:531px;
}
.hero-lead{
  margin-top:16px;font-size:18px;line-height:1.5;
  color:rgba(255,255,255,.95);max-width:531px;
}
.hero-intake{
  display:flex;gap:10px;align-items:flex-start;
  margin-top:20px;
  font-size:14px;color:var(--cyan);font-weight:500;line-height:20px;
}
.hero-intake svg{flex-shrink:0;margin-top:2px}
@media (min-width:1000px){
  .hero-lead,.hero-intake{display:none}
}

/* Hero image card (visual asset with overlay) */
.hero-image-card{
  position:relative;margin-top:32px;
  border-radius:20px;overflow:hidden;
  aspect-ratio:535/398;max-width:535px;
  box-shadow:0 20px 60px rgba(0,0,0,.25);
}
.hero-image-card>img{width:100%;height:100%;object-fit:cover;display:block}
.hero-image-overlay{
  position:absolute;left:15px;right:15px;bottom:15px;
  display:flex;gap:16px;align-items:center;
  padding:16px;border-radius:20px;
  background:rgba(0,0,0,.35);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  color:#fff;
}
.hero-image-logo{
  flex-shrink:0;width:72px;height:72px;border-radius:12px;background:#fff;
  display:flex;align-items:center;justify-content:center;
}
.hero-image-logo img{width:50px;height:50px;object-fit:contain}
.hero-image-overlay p{font-size:14px;line-height:1.45;font-weight:500;letter-spacing:-.01em;margin:0}

@media (min-width:1000px){
  .hero{
    padding:180px 0 120px;min-height:820px;
    background:url('assets/hero-bg.svg') 0 -30px/cover no-repeat;
  }
  .hero-inner{grid-template-columns:1fr minmax(460px,543px);gap:60px;align-items:stretch}
  .hero-copy{padding-top:0;display:flex;flex-direction:column}
  .hero-image-card{
    display:block;
    margin-top:56px;
    aspect-ratio:auto;
    flex:1;
    min-height:420px;
  }
  .hero-image-overlay p{font-size:15px}
}

/* ==================== FORM CARD ==================== */
.form-card{
  background:#fff;color:var(--text);
  border-radius:25px;padding:20px 24px;
  display:flex;flex-direction:column;gap:14px;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.form-card h2{font-size:22px;font-weight:600;letter-spacing:-.02em}
.form-sub{font-size:12px;color:var(--muted);line-height:20px}
.field{display:flex;flex-direction:column;gap:6px;font-size:12px;font-weight:500;flex:1}
.field input,.field select{
  height:37px;padding:0 12px;border-radius:10px;border:0;
  background:rgba(206,206,206,.25);font-size:12px;letter-spacing:-.02em;
  width:100%;color:var(--text);
}
.field input::placeholder,.field select:invalid{color:rgba(0,0,0,.35)}
.field input:focus,.field select:focus{outline:2px solid var(--navy);outline-offset:1px}
.field-help{display:block;font-size:11px;font-weight:400;color:var(--muted);margin-top:4px;line-height:1.4}
/* intl-tel-input override to match our field style */
.iti{width:100%;--iti-border-radius:10px}
.iti--separate-dial-code .iti__tel-input{
  height:37px;border-radius:10px;border:0;
  background:rgba(206,206,206,.25);font-size:12px;width:100%;
}
.iti__tel-input:focus{outline:2px solid var(--navy);outline-offset:1px}
.iti__selected-country{background:transparent!important;border-top-left-radius:10px;border-bottom-left-radius:10px}
.iti__country-list{font-size:13px;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.15);max-height:260px}
.iti__search-input{font-size:13px;padding:10px 12px}
.field.is-invalid input,.field.is-invalid select{outline:2px solid #d6449f;background:rgba(214,68,159,.06)}
.field-error{display:none;font-size:11px;font-weight:500;color:#d6449f;margin-top:4px}
.field.is-invalid .field-error{display:block}
.field.is-valid input{border-bottom:0}
.hp-field{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
.form-status{font-size:13px;margin:0}
.form-status:empty{display:none}
.form-status.is-error{color:#d6449f;margin-top:6px}
.form-status.is-success{color:#0a8754;margin-top:6px}

.select-wrap{position:relative}
.select-wrap select{appearance:none;padding-right:30px;width:100%}
.select-wrap .caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text);pointer-events:none}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.consent{display:flex;gap:12px;font-size:12px;color:var(--muted);line-height:20px;align-items:flex-start}
.consent input{
  width:20px;height:20px;flex-shrink:0;margin-top:2px;
  border-radius:5px;border:1px solid var(--border);cursor:pointer;
}
.intake-row{
  display:flex;gap:10px;align-items:flex-start;
  font-size:12px;color:var(--blue);font-weight:500;line-height:20px;
}
.intake-row svg{flex-shrink:0;margin-top:2px}

/* ==================== SECTION HEAD ==================== */
.eyebrow{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;margin:0}
.eyebrow-blue{color:var(--blue)}
.eyebrow-pink{color:var(--pink)}

.section-head{margin-bottom:40px}
.section-head h2{
  font-size:clamp(26px,3.5vw,40px);
  font-weight:500;letter-spacing:-.01em;line-height:1.15;color:var(--ink);
  margin-top:12px;
}
.head-grid{display:grid;gap:20px}
.head-grid p{font-size:16px;color:var(--text);line-height:1.5}

@media (min-width:900px){
  .head-grid{grid-template-columns:1.2fr 1fr;gap:32px;align-items:start}
  .head-grid h2{margin-top:0}
}

/* ==================== COLOR STRIP (animated) ==================== */
.color-strip{
  height:16px;width:100%;
  /* Cyclic gradient — 0% === 100% for seamless infinite loop */
  background:linear-gradient(90deg,
    #d6449f 0%,
    #ff8328 12.5%,
    #47ccdb 25%,
    #3389ca 37.5%,
    #004a82 50%,
    #3389ca 62.5%,
    #47ccdb 75%,
    #ff8328 87.5%,
    #d6449f 100%);
  background-size:200% 100%;
  animation:colorScroll 8s linear infinite;
}
@keyframes colorScroll{
  0%  {background-position:0% 50%}
  100%{background-position:-100% 50%}
}
@media (prefers-reduced-motion:reduce){
  .color-strip{animation:none}
}

/* ==================== PROGRAMS ==================== */
.programs{
  background:rgba(191,219,254,.3);
  padding:64px 0;
  position:relative;
  overflow:hidden;
}
.programs::before,
.programs::after{
  content:"";position:absolute;pointer-events:none;z-index:0;
  opacity:.35;
}
/* Left vector — narrow tall shape, anchored to top-left */
.programs::before{
  top:280px;left:-80px;
  width:280px;height:990px;
  background:url('assets/programs-deco-right.svg') no-repeat left top/contain;
  transform:rotate(-90deg) scaleY(-1);
  transform-origin:top left;
}
/* Right vector — wide shape, anchored to bottom-right */
.programs::after{
  bottom:-50px;right:-120px;
  width:840px;height:810px;
  background:url('assets/programs-deco-left.svg') no-repeat right bottom/contain;
  transform:scaleY(-1);
}
.programs .container{position:relative;z-index:1}

@media (max-width:900px){
  .programs::before,.programs::after{opacity:.2}
  .programs::before{width:180px;height:620px}
  .programs::after{width:480px;height:460px}
}
.program-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:24px;display:grid;gap:32px;
  box-shadow:3px 4px 6.3px rgba(0,0,0,.1);
  margin-bottom:32px;
}
.program-media{
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:16/10;
}
.program-media{position:relative}
.program-media img{width:100%;height:100%;object-fit:cover;position:relative;z-index:1}
.program-card-reverse .program-media::after{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 0% 100%, rgba(255,131,40,.22) 0%, transparent 55%),
    radial-gradient(ellipse 60% 45% at 100% 0%, rgba(0,74,130,.18) 0%, transparent 55%);
  mix-blend-mode:soft-light;
}
.program-card:not(.program-card-reverse) .program-media::after{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 50% at 100% 100%, rgba(214,68,159,.22) 0%, transparent 55%),
    radial-gradient(ellipse 60% 45% at 0% 0%, rgba(51,137,202,.18) 0%, transparent 55%);
  mix-blend-mode:soft-light;
}
.program-body{display:flex;flex-direction:column;gap:18px}
.tag{
  display:inline-flex;align-items:center;justify-content:center;
  padding:8px 16px;border-radius:56px;color:#fff;
  font-size:14px;font-weight:500;align-self:flex-start;
}
.tag-pink{background:var(--pink)}
.tag-orange{background:var(--orange)}
.program-title{font-size:clamp(24px,3vw,32px);font-weight:500;letter-spacing:-.02em;line-height:1.2}
.program-title.pink{color:var(--pink)}
.program-title.orange{color:var(--orange)}
.program-desc{font-size:16px;color:var(--soft);line-height:1.55}
.features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:16px}
.features li{
  display:flex;gap:10px;align-items:flex-start;
  font-size:16px;color:var(--soft);font-weight:500;line-height:1.4;
}
.features li svg{flex-shrink:0;margin-top:1px}
.feat-ic.feat-blue{color:#3389ca}
.feat-ic.feat-pink{color:#d6449f}
.feat-ic.feat-orange{color:#ff8328}
.note{font-size:14px;color:var(--muted)}

@media (min-width:900px){
  .programs{padding:100px 0}
  .program-card{grid-template-columns:1fr 1fr;gap:54px;padding:40px;align-items:center}
  .program-card-reverse{grid-template-columns:1fr 1fr}
  .program-body{gap:24px}
  .program-media{aspect-ratio:1/1}
}

/* ==================== TESTIMONIAL ==================== */
.testimonial{
  background:linear-gradient(141deg,#3389ca 32%,#2285cf 87%);
  color:#fff;padding:64px 0;
}
.t-title{font-size:clamp(26px,3vw,40px);font-weight:500;margin-bottom:40px;text-align:center}
.t-grid{display:grid;gap:32px;align-items:center}
.t-avatar{
  position:relative;border-radius:30px;overflow:hidden;
  aspect-ratio:335/215;width:100%;max-width:335px;margin:0 auto;
  flex-shrink:0;
}
.t-avatar img{
  width:100%;height:100%;object-fit:cover;object-position:center center;
  display:block;
}
.t-badge{
  position:absolute;left:50%;bottom:14px;transform:translateX(-50%);
  background:#fff;color:var(--text);
  padding:7px 14px;border-radius:28px;
  font-size:11px;font-weight:500;white-space:nowrap;
  box-shadow:0 4px 12px rgba(0,0,0,.12);
  letter-spacing:-.01em;
}
.t-body{display:flex;flex-direction:column;gap:20px}
.t-quote{font-size:48px;line-height:1;color:var(--cyan);font-weight:700}
.t-body blockquote{margin:0;font-size:18px;line-height:1.35}
.t-person{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.t-person strong{font-weight:700;font-size:18px}
.t-person span{font-size:15px;opacity:.9}
.t-arrows{display:flex;gap:16px;align-items:center;justify-content:flex-end;margin-top:32px;color:#fff}
.t-counter{margin-right:auto;font-size:14px;opacity:.85;font-variant-numeric:tabular-nums}
.t-arrow{padding:4px;transition:transform .15s,opacity .15s;border-radius:50%}
.t-arrow:hover{transform:scale(1.1)}
.t-arrow:disabled{opacity:.4;cursor:not-allowed}
.t-arrow:disabled:hover{transform:none}
#testimonial-slide{transition:opacity .3s ease}
#testimonial-slide.is-swapping{opacity:0}

@media (min-width:900px){
  .testimonial{padding:100px 0}
  .t-grid{grid-template-columns:242px 1fr;gap:32px}
  .t-avatar{width:242px;max-width:none;aspect-ratio:242/215;border-radius:30px}
  .t-body{padding:0 40px}
  /* Sem avatar: single column centralizada */
  .t-grid-no-avatar{grid-template-columns:1fr;max-width:900px;margin:0 auto}
  .t-grid-no-avatar .t-body{padding:0}
}

/* ==================== PRACTICUM ==================== */
.practicum{
  background:var(--hero-grad);
  color:#fff;padding:64px 0;
}
.practicum h2{font-size:clamp(26px,3vw,42px);font-weight:500;letter-spacing:-.01em;text-align:center;line-height:1.2}
.p-sub{text-align:center;max-width:710px;margin:20px auto 32px;font-size:16px;line-height:1.5}
.p-tabs{display:flex;gap:12px;justify-content:center;margin-bottom:36px}
.p-tab{
  flex:1;max-width:260px;
  padding:14px 24px;border-radius:56px;
  background:transparent;color:#fff;border:1px solid #fff;
  font-size:16px;font-weight:500;transition:all .2s;
}
.p-tab.active{background:#fff;color:var(--navy-deep);border-color:#fff}
.p-cards{display:grid;gap:16px}
.p-cards[hidden]{display:none}
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.p-card{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(25px);
  border:1px solid rgba(255,255,255,.6);
  border-radius:13px;padding:16px;color:var(--text);
}
.p-icon{
  width:32px;height:32px;border-radius:5px;background:#4586ff;
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.p-card h4{font-size:16px;font-weight:500;letter-spacing:-.005em;margin-bottom:8px}
.p-card p{font-size:14px;color:var(--muted);line-height:20px}

@media (min-width:900px){
  .practicum{padding:100px 0}
  .p-cards{grid-template-columns:repeat(3,1fr)}
}

/* ==================== FINANCIAL ==================== */
.financial{padding:64px 0;background:#fff}
.fa-head{text-align:center;margin-bottom:32px}
.fa-head h2{font-size:clamp(26px,3vw,40px);font-weight:500;color:var(--ink);line-height:1.15;margin-top:12px}
.fa-banner{
  background:var(--blue-50);border-radius:var(--radius-lg);
  padding:24px;font-size:16px;line-height:1.5;margin-bottom:32px;
}
.fa-grid{display:grid;gap:24px}
.fa-card{
  border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;
}
.fa-img{aspect-ratio:16/10;overflow:hidden;background:#d9d9d9}
.fa-img img{width:100%;height:100%;object-fit:cover}
.fa-body{padding:32px 24px 40px;color:#fff;display:flex;flex-direction:column;gap:20px}
.fa-dark .fa-body{background:var(--navy)}
.fa-blue .fa-body{background:var(--blue)}
.fa-body h3{font-size:20px;font-weight:600;letter-spacing:-.01em}
.fa-body p{font-size:16px;line-height:1.5}
.fa-link{
  color:#fff;font-weight:600;font-size:16px;
  display:inline-flex;align-items:center;gap:6px;
  position:relative;text-decoration:none;
  padding-bottom:3px;align-self:flex-start;
  transition:color .25s ease,gap .25s ease,transform .25s ease;
}
.fa-link::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:currentColor;
  transform:scaleX(1);transform-origin:right center;
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.fa-link:hover{color:#6fe3ef;gap:12px;transform:translateX(2px)}
.fa-link:hover::after{
  transform:scaleX(0);transform-origin:right center;
  animation:faLineSweep .6s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes faLineSweep{
  0%{transform:scaleX(1);transform-origin:right center}
  50%{transform:scaleX(0);transform-origin:right center}
  51%{transform-origin:left center}
  100%{transform:scaleX(1);transform-origin:left center}
}
.fa-link::before{
  /* glow pulse on hover */
  content:"";position:absolute;inset:-4px -8px;border-radius:6px;
  background:radial-gradient(ellipse at center,rgba(71,204,219,.25) 0%,transparent 70%);
  opacity:0;transition:opacity .3s ease;z-index:-1;
}
.fa-link:hover::before{opacity:1}

@media (min-width:900px){
  .financial{padding:100px 0}
  .fa-grid{grid-template-columns:1fr 1fr;gap:24px}
}

/* ==================== BOTTOM CTA ==================== */
.bottom-cta{background:var(--blue-bg);padding:64px 0}
.bc-grid{display:grid;gap:40px}
.bc-copy h2{
  font-size:clamp(28px,3.5vw,40px);font-weight:500;letter-spacing:-.02em;
  line-height:1.15;color:var(--text);margin-bottom:20px;
}
.bc-copy h2 span{color:#4586ff}
.bc-copy p{font-size:16px;line-height:1.5;color:#4c4c4c;margin-bottom:16px}
.bc-image{border-radius:40px;overflow:hidden;margin-top:24px;aspect-ratio:535/398;max-width:535px}
.bc-image img{width:100%;height:100%;object-fit:cover}

@media (min-width:900px){
  .bottom-cta{padding:100px 0}
  .bc-grid{grid-template-columns:1fr 543px;gap:60px;align-items:start}
  .bc-copy h2{font-size:40px}
}

/* ==================== FOOTER ==================== */
.site-footer{border-top:1px solid var(--border);padding:40px 0}
.footer-grid{
  display:grid;gap:24px;justify-items:center;text-align:center;
}
.footer-logo{width:140px;height:auto}
.socials{display:flex;gap:16px}
.socials a{padding:6px;transition:transform .15s}
.socials a:hover{transform:translateY(-2px)}
.copy{font-size:14px}
.legal{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;font-size:14px}
.legal a{text-decoration:underline}
.legal a:hover{color:var(--navy)}
.legal strong{color:#0044c2;font-weight:500}
.platty-link{color:#0044c2;font-weight:500;text-decoration:none;transition:color .15s ease}
.platty-link:hover{color:#0b5345}

@media (min-width:900px){
  .footer-grid{
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "logo   socials"
      "copy   legal";
    row-gap:64px;column-gap:40px;
    text-align:left;align-items:center;
  }
  .footer-logo{grid-area:logo;justify-self:start;width:188px}
  .socials{grid-area:socials;justify-self:end;gap:12px}
  .socials a{padding:6px}
  .copy{grid-area:copy;justify-self:start;margin:0}
  .legal{grid-area:legal;justify-self:end;gap:28px;flex-wrap:nowrap}
  .site-footer{padding:64px 0 40px}
}

/* ==================== UTILITIES / ANIMATIONS ==================== */
/* Reveal-on-scroll: never blocks visibility — only animates if class is applied via JS */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;will-change:opacity,transform}
.reveal.is-revealed{opacity:1;transform:translateY(0)}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}
