/* =========================================================================
   institutions.css — styles unique to institutions.html
   ========================================================================= */

.hero{padding:56px 0 64px;background:var(--white);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-20%;right:-10%;width:60%;height:140%;background:radial-gradient(ellipse,rgba(249,115,22,0.08) 0%,transparent 55%);pointer-events:none;z-index:0}
.hero .container{position:relative;z-index:1}
.hero-eyebrow{font-size:12px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:28px;display:flex;align-items:center;gap:12px}
.hero-eyebrow::before{content:'';width:40px;height:1.5px;background:var(--grad-gold)}
.hero-h1{font-family:var(--sans);font-size:54px;line-height:1.06;color:var(--heading);font-weight:500;letter-spacing:-1px;margin-bottom:28px;max-width:760px}
.hero-p{font-size:17px;line-height:1.9;color:var(--body);max-width:600px;margin-bottom:40px}
.hero-btn{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--white);background:var(--black);padding:15px 38px;border-radius:8px;transition:all 0.3s var(--ease);box-shadow:var(--shadow-sm)}
.hero-btn:hover{background:var(--ink-soft);transform:translateY(-2px);box-shadow:var(--shadow-md)}

.capabilities{padding:100px 0;background:var(--off-white);border-top:0.5px solid var(--border)}
.cap-header{margin-bottom:64px}
.cap-eyebrow{font-size:12px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:flex;align-items:center;gap:12px}
.cap-eyebrow::before{content:'';width:24px;height:1.5px;background:var(--gold)}
.cap-headline{font-family:var(--sans);font-size:36px;color:var(--heading);font-weight:500}
.cap-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.cap-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:34px 30px;transition:all 0.35s var(--ease);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}
.cap-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--grad-gold);transform:scaleX(0);transform-origin:left;transition:transform 0.5s var(--ease)}
.cap-card:hover{border-color:transparent;transform:translateY(-3px);box-shadow:var(--shadow-md)}
.cap-card:hover::before{transform:scaleX(1)}
.cap-card:nth-child(odd){border-left:4px solid var(--brand)}
.cap-card:nth-child(even){border-left:4px solid var(--ultramarine)}
.cap-card-top{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.cap-num{font-size:12px;font-weight:700;color:var(--gold);letter-spacing:1px}
.cap-icon{width:44px;height:44px;border-radius:12px;background:var(--gold-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.35s var(--ease)}
.cap-card:hover .cap-icon{background:var(--grad-gold);transform:rotate(-4deg) scale(1.05)}
.cap-icon svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;transition:stroke 0.35s}
.cap-card:hover .cap-icon svg{stroke:#fff}
.cap-title{font-size:16px;font-weight:700;color:var(--heading)}
.cap-desc{font-size:14px;color:var(--secondary);line-height:1.7}

.timeline{padding:100px 0;background:var(--black)}
.tl-eyebrow{font-size:13px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;gap:14px}
.tl-eyebrow::before{content:'';width:36px;height:2px;background:var(--gold)}
.tl-headline{font-family:var(--sans);font-size:36px;color:var(--white);font-weight:500;margin-bottom:64px}
.tl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.tl-step{position:relative}
.tl-num{font-size:11px;font-weight:700;color:var(--brand);letter-spacing:1px;margin-bottom:12px}
.tl-title{font-size:16px;font-weight:700;color:var(--white);margin-bottom:8px}
.tl-desc{font-size:13px;color:rgba(255,255,255,0.65);line-height:1.7}
.tl-line{position:absolute;top:6px;right:-12px;width:24px;height:1px;background:rgba(255,255,255,0.15)}
.tl-step:last-child .tl-line{display:none}

.proof-prog{padding:100px 0;background:var(--white)}
.pp-eyebrow{font-size:12px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:flex;align-items:center;gap:12px}
.pp-eyebrow::before{content:'';width:24px;height:1.5px;background:var(--gold)}
.pp-headline{font-family:var(--sans);font-size:32px;color:var(--heading);font-weight:500;margin-bottom:48px}
.pp-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.pp-card{border:1px solid var(--border);border-radius:14px;padding:36px 32px;transition:all 0.35s var(--ease);display:block;position:relative;overflow:hidden;background:var(--white);box-shadow:var(--shadow-sm)}
.pp-card:hover{border-color:transparent;transform:translateY(-3px);box-shadow:var(--shadow-md)}
.pp-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--grad-gold);transform:scaleX(0);transform-origin:left;transition:transform 0.5s var(--ease);z-index:2}
.pp-card:hover::before{transform:scaleX(1)}

/* Cards with a thumbnail on top */
.pp-card--with-img{padding:0;display:flex;flex-direction:column}
.pp-card--with-img .pp-body{padding:28px 32px 34px;display:flex;flex-direction:column;flex:1}
.pp-thumb{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--navy-deep)}
.pp-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.8s var(--ease)}
.pp-card--with-img:hover .pp-thumb img{transform:scale(1.05)}
.pp-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,rgba(15,40,71,0.25) 100%);pointer-events:none}

.pp-thumb--placeholder{background:linear-gradient(135deg,var(--navy) 0%,var(--burgundy) 100%);display:flex;align-items:center;justify-content:center;text-align:center}
.pp-thumb--placeholder::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(249,115,22,0.12) 1px,transparent 1.5px);background-size:24px 24px;opacity:0.6}
.pp-thumb--placeholder::after{display:none}
.pp-thumb-label{position:relative;z-index:1;font-family:var(--sans);font-size:20px;font-weight:500;color:#fff;letter-spacing:0.3px}
.pp-uni{font-size:13px;font-weight:500;color:var(--secondary);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.pp-uni svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:1.5;flex-shrink:0}
.pp-name{font-family:var(--sans);font-size:26px;color:var(--heading);font-weight:500;margin-bottom:12px;line-height:1.2}
.pp-det{font-size:14px;color:var(--secondary);line-height:1.7;margin-bottom:20px}
.pp-link{font-size:13px;font-weight:600;color:var(--heading);display:inline-flex;align-items:center;gap:8px;transition:all 0.3s}
.pp-card:hover .pp-link{gap:14px;color:var(--gold)}
.pp-link svg{width:16px;height:16px;stroke:var(--gold);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

.why{padding:100px 0;background:var(--off-white);border-top:0.5px solid var(--border)}
.why-eyebrow{font-size:12px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;display:flex;align-items:center;gap:12px}
.why-eyebrow::before{content:'';width:24px;height:1.5px;background:var(--gold)}
.why-headline{font-family:var(--sans);font-size:32px;color:var(--heading);font-weight:500;margin-bottom:48px}
.why-grid{display:grid;grid-template-columns:1fr;gap:0}
.why-item{padding:28px 0;border-bottom:0.5px solid var(--border);display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}
.why-item:last-child{border-bottom:none}
.why-label{font-size:15px;font-weight:700;color:var(--heading)}
.why-text{font-size:15px;color:var(--body);line-height:1.8}

.cta-sec{padding:100px 0;background:var(--off-white);border-top:0.5px solid var(--border)}
.cta-card{background:var(--grad-dark);border-radius:24px;padding:72px 64px;position:relative;overflow:hidden;box-shadow:var(--shadow-xl)}
.cta-card::before{content:'';position:absolute;bottom:-200px;left:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(249,115,22,0.12) 0%,transparent 65%);filter:blur(30px);pointer-events:none}
.cta-card::after{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(242,160,95,0.10) 0%,transparent 60%);filter:blur(40px);pointer-events:none}
.cta-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start;position:relative;z-index:1}
.cta-eyebrow{font-size:13px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;gap:14px}
.cta-eyebrow::before{content:'';width:36px;height:2px;background:var(--gold)}
.cta-headline{font-family:var(--sans);font-size:32px;color:var(--white);font-weight:500;margin-bottom:16px;line-height:1.15}
.cta-sub{font-size:15px;color:rgba(255,255,255,0.65);line-height:1.8;margin-bottom:32px}
.cta-direct{font-size:14px;color:rgba(255,255,255,0.5);line-height:2}
.cta-direct a{color:var(--white);font-weight:600;border-bottom:1.5px solid var(--gold);padding-bottom:1px}
.cta-direct .label{color:rgba(255,255,255,0.8);font-weight:600;display:block;margin-bottom:4px}

.form-card{background:var(--white);border:none;border-radius:16px;padding:40px 36px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1 / -1}
.form-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.form-label .req{color:var(--error);margin-left:2px}
.form-input{border:none;border-bottom:1.5px solid var(--border);padding:12px 0;font-size:15px;font-family:var(--sans);color:var(--heading);background:transparent;outline:none;transition:border-color 0.25s;width:100%}
.form-input:focus{border-color:var(--gold)}
.form-input::placeholder{color:var(--muted)}
textarea.form-input{resize:vertical;min-height:80px;border:1.5px solid var(--border);border-radius:8px;padding:12px 16px;margin-top:4px}
textarea.form-input:focus{border-color:var(--gold)}
.form-submit{margin-top:8px;width:100%;font-size:14px;font-weight:600;color:var(--white);background:var(--black);padding:14px 40px;border-radius:6px;border:none;cursor:pointer;font-family:var(--sans);transition:all 0.25s}
.form-submit:hover{background:var(--ink-soft);transform:translateY(-1px)}
.honeypot{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

@media(max-width:1024px){
  .hero-h1{font-size:44px}
  .cap-grid{grid-template-columns:1fr 1fr}
  .tl-grid{grid-template-columns:1fr 1fr;gap:32px}
  .tl-line{display:none}
}
@media(max-width:768px){
  .hero{padding:40px 0 48px}
  .hero-h1{font-size:34px;letter-spacing:-0.5px}
  .hero-p{max-width:100%}
  .capabilities{padding:64px 0}
  .cap-grid{grid-template-columns:1fr}
  .cap-headline{font-size:28px}
  .timeline{padding:64px 0}
  .tl-grid{grid-template-columns:1fr}
  .tl-headline{font-size:28px;margin-bottom:40px}
  .proof-prog{padding:64px 0}
  .pp-grid{grid-template-columns:1fr}
  .pp-headline{font-size:26px;margin-bottom:32px}
  .why{padding:64px 0}
  .why-headline{font-size:26px;margin-bottom:32px}
  .why-item{grid-template-columns:1fr;gap:8px}
  .cta-sec{padding:64px 0}
  .cta-card{padding:40px 28px;border-radius:16px}
  .cta-headline{font-size:26px}
  .cta-inner{grid-template-columns:1fr;gap:40px}
  .form-grid{grid-template-columns:1fr}
  .form-card{padding:28px 24px}
}
@media(max-width:480px){
  .hero-h1{font-size:28px}
  .cap-card{padding:24px 20px}
  .tl-headline{font-size:24px}
  .pp-name{font-size:22px}
}
