
:root{
  --blue:#0B74B8;
  --blue2:#2AA7FF;
  --blue-deep:#074A78;

  --ink:#1B2430;
  --muted:#5A6776;

  --bg:#F7F9FC;
  --panel:#F3F5F7;
  --stroke:#D7DEE6;

  --border:rgba(16,24,40,.12);
  --shadow:0 12px 34px rgba(16,24,40,.10);
  --radius:18px;
  --max:1100px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg, #fff 0%, var(--silver2) 45%, #fff 100%);
}

a{color:inherit;text-decoration:none}
a:hover{opacity:.9}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}

.topbar{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.8);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--border);
}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:70px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.brand__logo{width:44px;height:44px;object-fit:cover;border-radius:12px;border:1px solid var(--border)}
.brand__text{letter-spacing:.2px}

.nav{display:flex;align-items:center;gap:18px}
.nav a{font-weight:500;color:rgba(11,18,32,.86)}
.nav__toggle{display:none;border:1px solid var(--border);background:#fff;border-radius:12px;padding:10px 12px;cursor:pointer}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:14px;
  padding:12px 16px;
  border:1px solid rgba(8,114,179,.25);
  background:linear-gradient(135deg,var(--blue),var(--blue2));
  color:#fff;font-weight:600;
  box-shadow:0 10px 24px rgba(8,114,179,.25);
}
.btn--ghost{
  background:transparent;color:var(--blue);
  border:1px solid rgba(8,114,179,.35);
  box-shadow:none;
}
.btn--sm{padding:10px 14px;border-radius:12px}

.hero{
  padding:48px 0 24px 0;
}
.hero__grid{
  display:grid;grid-template-columns:1.2fr .8fr;gap:22px;align-items:stretch;
}
.hero__card{
  border:1px solid var(--border);
  background:linear-gradient(135deg, #ffffff 0%, #f5f7fb 60%, #ffffff 100%);
  border-radius:calc(var(--radius) + 8px);
  padding:28px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
}
.hero__card:before{
  content:"";
  position:absolute;inset:-80px -90px auto auto;
  width:220px;height:220px;border-radius:999px;
  background:radial-gradient(circle at 30% 30%, rgba(8,114,179,.35), transparent 60%);
  filter: blur(2px);
}
.kicker{color:rgba(42,52,60,.9);font-weight:600;letter-spacing:.2px}
.h1{font-size:44px;line-height:1.05;margin:12px 0 12px 0}
.lede{font-size:16px;line-height:1.6;color:rgba(11,18,32,.78);max-width:62ch}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.hero__side{
  border:1px solid var(--border);
  background:linear-gradient(135deg, rgba(8,114,179,.08), rgba(214,216,220,.55));
  border-radius:calc(var(--radius) + 8px);
  box-shadow:var(--shadow);
  padding:22px;
  display:flex;flex-direction:column;gap:12px;
}
.side__logo{
  width:100%;
  border-radius:16px;
  border:1px solid var(--border);
  background:#fff;
  padding:14px;
}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.badge{
  font-size:13px;font-weight:600;
  padding:8px 10px;border-radius:999px;
  background:#fff;border:1px solid var(--border);
}

.section{padding:22px 0}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.card{
  border:1px solid var(--border);
  background:rgba(255,255,255,.92);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 8px 22px rgba(0,0,0,.06);
}
.card h3{margin:8px 0 8px 0}
.muted{color:rgba(11,18,32,.68)}
.p{line-height:1.7;color:rgba(11,18,32,.78)}
.hr{height:1px;background:var(--border);margin:18px 0}

.form{
  display:grid;gap:12px;
}
.input, textarea, select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  font:inherit;
}
textarea{min-height:140px;resize:vertical}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.note{font-size:13px;color:rgba(11,18,32,.62)}
.alert{
  padding:12px 14px;border-radius:16px;border:1px solid var(--border);
  background:#fff;
}
.alert--good{border-color:rgba(16,185,129,.3);background:rgba(16,185,129,.06)}
.alert--bad{border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.06)}

.footer{
  margin-top:38px;
  background:linear-gradient(135deg, rgba(8,114,179,.08), rgba(214,216,220,.55));
  border-top:1px solid var(--border);
  padding:26px 0 10px 0;
}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px}
.footer__brand{font-weight:800;margin-bottom:6px}
.footer__title{font-weight:700;margin-bottom:6px}
.footer__bottom{padding:14px 0 10px 0;border-top:1px solid var(--border);margin-top:16px}

.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px 8px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.table th{font-size:13px;color:rgba(11,18,32,.72)}
.table td{font-size:14px}
.pill{display:inline-flex;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:600;font-size:12px}
.pill--draft{opacity:.75}
.pill--pub{border-color:rgba(8,114,179,.25);background:rgba(8,114,179,.06)}

@media (max-width: 900px){
  .hero__grid{grid-template-columns:1fr}
  .h1{font-size:36px}
  .grid3{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .row{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .nav__toggle{display:inline-flex}
  .nav{display:none;flex-direction:column;align-items:flex-start;padding:10px 0}
  .nav.is-open{display:flex}
}
/* =========================
   Corporate Premium Enhancements
   ========================= */

body{
  background: var(--bg);
  color: var(--ink);
}
body::before{
  content:"";
  position:fixed; inset:0;
  background-image: radial-gradient(rgba(11,116,184,.12) 1px, transparent 1px);
  background-size: 26px 26px;
  opacity:.12;
  pointer-events:none;
}

/* Navbar polish */
.topbar{
  background: rgba(247,249,252,.78);
  backdrop-filter: blur(12px);
}
.nav a{
  padding:8px 10px;
  border-radius:12px;
  transition: background .18s ease, color .18s ease, transform .18s ease;
}
.nav a:hover{
  background: rgba(11,116,184,.08);
}
.nav a.is-active{
  color: var(--blue-deep);
  background: rgba(11,116,184,.10);
}

/* Premium buttons */
.btn{
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease;
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(11,116,184,.28);
  filter: brightness(1.02);
}
.btn:active{ transform: translateY(0); }
.btn.is-active{
  outline: 3px solid rgba(11,116,184,.18);
  outline-offset: 2px;
}

/* Silver panel cards */
.card{
  background: linear-gradient(180deg, #FFFFFF 0%, var(--panel) 100%);
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow);
  transition: transform .18s ease, box-shadow .18s ease;
}
.card:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(16,24,40,.14);
}

/* Hero “sheen” effect (classy, not cheesy) */
.hero__card{
  border: 1px solid var(--stroke);
}
.hero__card::after{
  content:"";
  position:absolute; inset:-40%;
  background: linear-gradient(120deg,
    transparent 42%,
    rgba(255,255,255,.72) 50%,
    transparent 58%
  );
  transform: translateX(-30%) rotate(12deg);
  animation: sheen 7s ease-in-out infinite;
  pointer-events:none;
  opacity:.0;
}
@keyframes sheen{
  0%{ transform: translateX(-35%) rotate(12deg); opacity:0; }
  20%{ opacity:.55; }
  55%{ transform: translateX(35%) rotate(12deg); opacity:.18; }
  100%{ opacity:0; }
}

/* Form focus ring (makes it feel premium) */
.input:focus, textarea:focus, select:focus{
  outline:none;
  border-color: rgba(11,116,184,.45);
  box-shadow: 0 0 0 4px rgba(11,116,184,.12);
}

/* Scroll reveal animation */
.reveal{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .55s ease, transform .55s ease;
  transition-delay: var(--d, 0ms);
}
.reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero__card::after{ animation:none; }
}
/* ===== Team Premium ===== */
.team__header{ margin-bottom: 10px; }
.team__grouphead{ display:flex; align-items:center; gap:14px; margin: 6px 0 14px; }
.team__h2{ margin:0; font-size:18px; letter-spacing:.2px; color: rgba(11,18,32,.86); }
.team__line{ height:1px; flex:1; background: var(--border); }

.team__grid{ align-items: stretch; }

.person{ position:relative; overflow:hidden; }
.person::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(500px 160px at 20% 10%, rgba(8,114,179,.18), transparent 55%);
  opacity:.7;
  pointer-events:none;
}

.person__top{ display:flex; gap:14px; align-items:flex-start; }
.avatar{
  width:82px; height:82px;
  border-radius:18px;
  object-fit:cover;
  border:1px solid var(--border);
  background:#fff;
  box-shadow: 0 10px 22px rgba(0,0,0,.10);
  flex:0 0 auto;
}
.avatar--initials{
  display:flex; align-items:center; justify-content:center;
  font-weight:800; letter-spacing:.5px;
  color: rgba(11,18,32,.82);
  background: linear-gradient(135deg, #fff, rgba(214,216,220,.6));
}

.person__meta{ min-width: 0; }
.role-badge{
  display:inline-flex;
  font-size:12px; font-weight:700;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.85);
}
.person__name{
  font-weight:800;
  margin-top:10px;
  font-size:18px;
}
.person__blurb{
  margin:8px 0 0 0;
  line-height:1.7;
  color: rgba(11,18,32,.76);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:hidden;
}

.linkbtn{
  margin-top:10px;
  border:none;
  background:transparent;
  color: var(--blue);
  font-weight:800;
  cursor:pointer;
  padding:0;
}
.linkbtn:hover{ color: var(--blue2); }

/* Modal */
.modal{
  position:fixed; inset:0;
  display:none;
  align-items:center; justify-content:center;
  padding: 18px;
  z-index: 999;
}
.modal.is-open{ display:flex; }
.modal__backdrop{
  position:absolute; inset:0;
  background: rgba(11,18,32,.55);
  backdrop-filter: blur(8px);
}
.modal__dialog{
  position:relative;
  width: min(720px, 100%);
  border-radius: 22px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF 0%, rgba(238,240,243,.92) 100%);
  box-shadow: 0 30px 90px rgba(0,0,0,.35);
  padding: 22px 22px 18px;
  animation: modalPop .18s ease-out;
}
@keyframes modalPop{
  from{ transform: translateY(10px); opacity: .6; }
  to{ transform: translateY(0); opacity: 1; }
}
.modal__close{
  position:absolute; top:12px; right:12px;
  border:1px solid var(--border);
  background:#fff;
  width:40px; height:40px;
  border-radius: 14px;
  cursor:pointer;
}

/* Reveal hooks (if you’re using the reveal JS) */
.reveal{ opacity:0; transform: translateY(12px); transition: opacity .55s ease, transform .55s ease; }
.reveal.is-visible{ opacity:1; transform: translateY(0); }

@media (max-width: 720px){
  .person__top{ flex-direction: column; }
  .avatar{ width:90px; height:90px; }
}
.label{
  display:block;
  font-weight:800;
  margin: 10px 0 6px;
  color: rgba(11,18,32,.78);
}
/* Footer social follow */
.follow{
  margin-top: 14px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.follow__label{
  font-weight: 800;
  color: rgba(11,18,32,.78);
  letter-spacing: .2px;
}
.follow__icons{
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

.iconbtn{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: linear-gradient(180deg, #FFFFFF 0%, rgba(243,245,247,.95) 100%);
  border: 1px solid rgba(16,24,40,.12);
  box-shadow: 0 10px 22px rgba(16,24,40,.10);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.iconbtn svg{
  width: 18px;
  height: 18px;
  fill: #074A78; /* deep corporate blue */
}
.iconbtn:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(16,24,40,.14);
  border-color: rgba(11,116,184,.35);
}


