/* Animation styles ported from ReactAPP/src/styles.css (.reveal pattern) */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* Optional helper: makes it easy to mark items for reveal using data attributes */
[data-reveal] { opacity: 0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
[data-reveal].in { opacity: 1; transform: none; }

/* === Base and theme variables === */
:root{color-scheme: light dark; --bg:#f7f9fc; --surface:#ffffff; --text:#0b1220; --muted:#475569; --brand:#1a5ccc; --brand-2:#081421; --brand-bg-grad: linear-gradient(160deg, rgba(8, 20, 33, 1), rgba(26, 92, 204, 0.85)); --border:#e2e8f0; --shadow:0 10px 30px rgba(2,12,27,.08)}
/* Guard against unintended horizontal scrolling site-wide */
html, body { max-width:100%; overflow-x:hidden; }
html { -webkit-text-size-adjust:100%; text-size-adjust:100%; }
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter, "Inter var", Roboto, "Segoe UI", Arial, sans-serif;color:var(--text);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;font-size:clamp(15px, 2.5vw, 17px)}
.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}
.container{max-width:1160px;margin:0 auto;padding:0 20px}
@media (max-width: 600px){ .container{padding:0 16px} }

/* Header/nav: unify look across all pages to match Home */
header.site-header{position:sticky;top:0;background:var(--brand-bg-grad, #1A5CCC) !important;color:#e5e7eb;border-bottom:1px solid #0f172a;z-index:1000;transition:box-shadow .2s ease, background .2s ease}
/* Keep optional scrolled shadow without changing color */
header.site-header.scrolled{box-shadow:var(--shadow)}
/* Shared header layout hooks (used by fragments/layout header) */
header.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-height:56px}
header.site-header .brand img{width:140px;height:40px;object-fit:contain;display:block}
.nav-toggle{width:44px;height:44px;display:inline-grid;place-items:center;color:#e5e7eb;background:transparent;border:0}
header.site-header a{color:#e5e7eb !important;text-decoration:none}
header.site-header a:hover,header.site-header a:focus{color:#ffffff !important;text-decoration:underline;outline:none}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo img{display:block}
.skip-link{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:80px;width:auto;height:auto;background:#000;color:#fff;padding:8px 12px;border-radius:8px}

.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:8px}
.main-nav a{color:var(--text);text-decoration:none;padding:10px 12px;border-radius:8px;transition:all .2s ease}
.main-nav a.active, .main-nav a:hover{background:rgba(31,111,235,0.12);color:var(--brand)}

.menu-toggle{display:none;background:transparent;border:1px solid var(--border);border-radius:10px;padding:8px;line-height:0}
.menu-toggle svg{width:24px;height:24px}

h1,h2,h3{font-family:Poppins,Roboto,Segoe UI,Arial,sans-serif;color:var(--text)}
h1{font-size:clamp(1.75rem, 4.8vw, 2.5rem);letter-spacing:.2px;font-weight:700}
h2{font-size:clamp(1.25rem, 3.2vw, 1.6rem);font-weight:700}
h3{font-weight:600;font-size:clamp(1.05rem, 2.6vw, 1.25rem)}

.hero{position:relative;padding:72px 0}
@media (min-width: 900px){ .hero{padding:96px 0} }
.hero:not(.brand){background:linear-gradient(120deg, rgba(10,26,42,0.85), rgba(31,111,235,0.55));color:#fff}
.hero h1{font-size:2.5rem;margin:0 0 8px;text-shadow:0 2px 6px rgba(0,0,0,.55),0 1px 2px rgba(0,0,0,.35)}
.hero p{margin:0 0 20px;color:#e5e7eb;text-shadow:0 2px 6px rgba(0,0,0,.45),0 1px 2px rgba(0,0,0,.3)}
.cta{display:inline-block;background:linear-gradient(90deg,var(--brand),#5aa2ff);color:#fff;padding:12px 18px;border-radius:10px;text-decoration:none;box-shadow:0 6px 20px rgba(31,111,235,.3);transition:transform .15s ease, box-shadow .2s ease}
.cta:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(31,111,235,.35)}
.cta.secondary{background:var(--brand-bg-grad, #1A5CCC);color:#fff;border:1px solid rgba(255,255,255,.2);box-shadow:0 6px 20px rgba(8,20,33,.25)}
.cta.secondary:hover{filter:brightness(1.05); box-shadow:0 10px 24px rgba(8,20,33,.3)}

.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
@media (min-width: 900px){
  .grid3{gap:24px}
  .grid2{gap:24px}
}
.card{border:1px solid var(--border);border-radius:14px;padding:16px;background:var(--surface);box-shadow:0 1px 2px rgba(2,12,27,.02);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;color:#0b1220;overflow:hidden}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 32px rgba(2,12,27,.08);border-color:#d8dde6}
.card h2,.card h3{margin:8px 0;color:#0b1220}
.card p{margin:0;color:#475569}
.card img{border-radius:10px;display:block;margin-bottom:12px;transition:transform .35s ease}
.card:hover img{transform:scale(1.02)}

.site-footer{border-top:1px solid #e5eaf0;margin-top:48px}
.footer-grid{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:28px 0}
.footer-links{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px 16px;align-items:center}
.footer-grid a{text-decoration:none;color:var(--text)}
.footer-grid a:hover{color:var(--brand)}

section{padding:32px 0}
@media (min-width: 900px){ section{padding:48px 0} }
/* Improve h2 readability on section backgrounds (typically dark) */
section h2{margin:0 0 8px;font-size:1.6rem;color: #2e3b4a;text-shadow:0 1px 3px rgba(0,0,0,.5)}
section p.lead{margin:0 0 16px;color:var(--muted)}

img{max-width:100%;height:auto}
video, iframe{max-width:100%}
/* Make tables scrollable on small screens without breaking layout */
.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
table{border-collapse:collapse}

/* Forms */
label{display:block;margin:8px 0 6px}
/* Unify text inputs, dropdowns, and textareas so text is readable in all themes */
input,textarea,select{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:12px;
  font:inherit;
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease;
  background:#fff;
  color:#1f2937; /* slate-800 */
  -webkit-text-fill-color:#1f2937; /* fix iOS Safari dark mode white text */
  color-scheme:light; /* prevent UA dark-mode theming inversion */
}
input:focus,textarea:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(31,111,235,.15)}
/* Placeholder color for better contrast against white */
input::placeholder,textarea::placeholder{color:#6b7280}
input::-webkit-input-placeholder,textarea::-webkit-input-placeholder{color:#6b7280}
button.cta{border:0;cursor:pointer}
/* Touch-friendly tap targets */
@media (pointer: coarse){
  input, textarea, select, button{min-height:44px}
  .cta{padding:14px 20px}
}

/* Reveal on scroll */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
}

/* Responsive nav */
@media (max-width: 860px){
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center}
  .main-nav{position:absolute;inset:72px 0 auto 0;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow);transform-origin:top;transition:opacity .2s ease, visibility .2s ease}
  .main-nav ul{flex-direction:column;padding:12px 16px;gap:4px}
  .main-nav a{padding:12px 14px;border-radius:10px}
  .main-nav[data-open="false"], .main-nav:not([data-open]){opacity:0;visibility:hidden}
  .main-nav[data-open="true"]{opacity:1;visibility:visible}
}

/* New primary nav panel (matches fragments/layout.html) */
@media (max-width: 899.98px){
  :root { --header-h: 56px; }
  body.nav-open{overflow:hidden;overscroll-behavior:none}
  #primary-nav{
    position:fixed;top:var(--header-h);left:0;right:0;bottom:0;background:var(--brand-bg-grad, #1A5CCC);display:block;
    padding:.5rem calc(1rem + env(safe-area-inset-right, 0px)) calc(2rem + env(safe-area-inset-bottom, 0px)) calc(1rem + env(safe-area-inset-left, 0px));
    height:calc(100vh - var(--header-h));max-height:calc(100vh - var(--header-h));
    height:calc(100dvh - var(--header-h));max-height:calc(100dvh - var(--header-h));
    box-sizing:border-box;overflow-y:auto;overflow-x:hidden;touch-action:pan-y;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
    transform:translateY(-120%);visibility:hidden;pointer-events:none;transition:transform .25s ease;z-index:1000;
    overflow-x:hidden !important;
  }
  @supports (height: 100svh){
    #primary-nav{height:calc(100svh - var(--header-h));max-height:calc(100svh - var(--header-h));}
  }
  #primary-nav.is-open{transform:none;visibility:visible;pointer-events:auto}
  header.site-header .bar{position:relative;z-index:1001}
  #primary-nav details{border:1px solid #1f2937;border-radius:.5rem;padding:.25rem .5rem;background:#0a3b8f}
  #primary-nav details + details{margin-top:.5rem}
  #primary-nav summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:.5rem}
  #primary-nav summary::-webkit-details-marker{display:none}
  #primary-nav .submenu{display:flex;flex-direction:column;gap:.35rem;padding:.5rem 0 .25rem 0;min-width:0;width:auto;overflow-x:hidden}
  #primary-nav a.with-icon, #primary-nav a.pill, #primary-nav a.cta{display:flex;width:100%;align-items:center;gap:.5rem;padding:.375rem .25rem;overflow:hidden;color:#e5e7eb}
  #primary-nav a, #primary-nav summary, #primary-nav .submenu{white-space:normal}
  #primary-nav .submenu a{display:block}
  #primary-nav summary{width:100%;min-width:0;overflow:hidden}
  #primary-nav details{min-width:0;width:auto;max-width:100%;overflow-x:hidden}
  #primary-nav > *{max-width:100%}
  #primary-nav svg.icon{flex-shrink:0}
  #primary-nav a.with-icon span, #primary-nav summary span{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis}
  #primary-nav > form{display:block;width:100%}
  #primary-nav > form button{display:flex;width:100%;align-items:center;gap:.5rem;box-sizing:border-box}
  #primary-nav, #primary-nav *{box-sizing:border-box;max-width:100%}
  #primary-nav a{overflow-wrap:anywhere;word-break:break-word}
  #primary-nav a.with-icon, #primary-nav summary{min-width:0}
  #primary-nav a.with-icon span, #primary-nav summary span{min-width:0;overflow-wrap:anywhere;word-break:break-word}
  #primary-nav .submenu a{width:100%}
  #primary-nav details[open] > .submenu{max-height:none;overflow:visible;-webkit-overflow-scrolling:auto;overscroll-behavior:auto;margin-right:0}
}

/* Desktop layout for primary nav */
@media (min-width: 900px){
  header.site-header .bar{min-height:64px}
  header.site-header .nav-toggle{display:none}
  #primary-nav{position:static;height:auto;max-height:none;transform:none;visibility:visible;pointer-events:auto;background:transparent;padding:0;display:flex;align-items:center;gap:.75rem}
  #primary-nav > a, #primary-nav > details, #primary-nav > form{margin-left:.25rem}
  #primary-nav a.with-icon, #primary-nav a.pill, #primary-nav a.cta{padding:.375rem .5rem;border-radius:.5rem}
  #primary-nav a.cta{background:#111827;border:1px solid #1f2937}
  #primary-nav a.cta:hover{background:#0f172a}
  #primary-nav details{position:relative;padding:0;border:0;background:transparent}
  #primary-nav summary{padding:.375rem .5rem;border-radius:.5rem}
  #primary-nav summary:focus{outline:2px solid #334155;outline-offset:2px}
  #primary-nav .submenu{position:absolute;top:calc(100% + 6px);left:0;min-width:260px;background:#0a1324;border:1px solid #1f2937;border-radius:.5rem;padding:.5rem;box-shadow:0 8px 24px rgba(0,0,0,.35);display:none;max-height:none;overflow:visible;margin:0}
  #primary-nav details[open] > .submenu{display:grid;gap:.35rem}
}

/* === UI Enhancements (ported) === */
/* Improved nav link interactions */
/* Solid background on hover for Download PDF button */
.cta.secondary.download-pdf:hover{background:var(--brand);color:#fff;border-color:var(--brand)}
.main-nav a{position:relative}
.main-nav a::after{content:"";position:absolute;left:12px;right:12px;bottom:6px;height:2px;background:linear-gradient(90deg,var(--brand),#5aa2ff);transform:scaleX(0);transform-origin:right;transition:transform .2s ease}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1);transform-origin:left}

/* Better focus visibility across the site */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:10px}

/* Footer refresh: dark gradient and high contrast links */
.site-footer{background:linear-gradient(180deg,var(--brand-2),#0e2236);border-top:none;margin-top:64px;color:#e5e7eb}
.site-footer .footer-grid a{color:#e5e7eb}
.site-footer .footer-grid a:hover{color:#ffffff}
.site-footer p{color:#cbd5e1}

/* Slightly punchier cards */
.card{border-color:#e2e8f0}
.card:hover{border-color:#d0d8e3;box-shadow:0 18px 38px rgba(2,12,27,.10)}

/* Footer social icons and interactions */
.footer-social{justify-self:end}
.social-list{list-style:none;margin:0;padding:0;display:flex;gap:12px}
.footer-social .social{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:9999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#e5e7eb;transition:transform .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease}
.footer-social .social:hover{background:rgba(255,255,255,.14);color:#fff;transform:translateY(-1px) scale(1.05);box-shadow:0 6px 20px rgba(0,0,0,.25)}
.footer-social .social:active{transform:translateY(0) scale(0.98)}
.footer-social svg{width:20px;height:20px;display:block}

/* Footer nav links with icons */
.footer-links a{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px}
.footer-links a svg{width:18px;height:18px;opacity:.9}

/* Partner badges */
.partner-badges{display:flex;align-items:flex-start;flex-direction:column;gap:8px;margin-top:8px}
.partner-badges img{display:block;height:64px;max-width:260px;object-fit:contain;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);padding:8px;border-radius:10px}
.partner-caption{font-size:12px;color:#cbd5e1;opacity:.95}

@media (max-width: 860px){
  .footer-grid{grid-template-columns:1fr;gap:12px;text-align:center}
  .footer-social{justify-self:center}
  .footer-links{justify-items:center}
  .partner-badges{justify-content:center;align-items:center}
  .partner-badges img{height:48px}
}

/* Utility: improve readability for text placed over photos */
.text-on-photo{ text-shadow:0 2px 8px rgba(0,0,0,.55), 0 1px 2px rgba(0,0,0,.35); }
.text-on-photo--soft{ text-shadow:0 1px 3px rgba(0,0,0,.4); }
.on-photo-chip{ display:inline-block; background:rgba(0,0,0,.35); color:#fff; padding:4px 8px; border-radius:8px; backdrop-filter:blur(2px); -webkit-backdrop-filter:blur(2px); }

/* === Adjustments to match dark background (#2E3B4A) === */
/* Keep header nav readable on light/translucent header */
.site-header .main-nav a{color:#0b1220}
.site-header .main-nav a.active, .site-header .main-nav a:hover{color:var(--brand)}

/* Ensure secondary CTAs are context-aware */
.hero .cta.secondary{color:#fff;border-color:rgba(255,255,255,.6)}
.hero .cta.secondary:hover{background:rgba(255,255,255,.1)}

/* === Utilities to centralize previously inline styles === */
.mt-0{margin-top:0}
.mt-12{margin-top:12px}
.mt-8{margin-top:8px}
.mt-auto{margin-top:auto}
.no-margin{margin:0}

.row{display:flex;gap:12px}
.row-wrap{flex-wrap:wrap}
.items-center{align-items:center}
.items-start{align-items:flex-start}
.items-stretch{align-items:stretch}
.justify-between{justify-content:space-between}
.column{display:flex;flex-direction:column}

.gap-12{gap:12px}
.gap-16{gap:16px}
.gap-24{gap:24px}

.link-plain{color:inherit;text-decoration:none}
.rounded-8{border-radius:8px}
.grid-span-2{grid-column:span 2}

/* Wrapping utilities to prevent overflow of long strings/URLs */
.break-words{word-wrap:break-word;overflow-wrap:anywhere}
.no-wrap{white-space:nowrap}

/* Safe-area padding utility for devices with notches */
.pad-safe{padding-left:calc(16px + env(safe-area-inset-left, 0px));padding-right:calc(16px + env(safe-area-inset-right, 0px))}

/* Text alignment and sizing */
.text-center{text-align:center}
.text-24{font-size:24px}
.fw-700{font-weight:700}
.opacity-80{opacity:.8}

/* Simple gallery utilities */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(260px,1fr));gap:16px}
.figure-reset{margin:0}
.photo-box{width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:8px;background:#f2f6fb}
.photo-img{width:100%;height:100%;object-fit:cover;display:block}
.placeholder-box{width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:8px;background:#f2f6fb;border:1px dashed #c8d3e3;display:flex;align-items:center;justify-content:center;color:#7687a2;font-size:14px;text-align:center;padding:12px}

/* Component helpers */
.brand-chip{background:linear-gradient(120deg, #081421, #1a5ccc);padding:6px 10px;border-radius:8px;display:inline-flex;align-items:center}
.img-36h{height:36px;width:auto;display:block}
