/* ===== Rexplore site stylesheet (restored) ===== */
:root {
  --brand-700: #ad3a0d;
  --brand-600: #c2410e;
  --brand-500: #d84810;
  --brand-400: #de6334;
  --brand-300: #e47f58;
  --brand-100: #f7dacf;

  --accent-600: #346c82;
  --accent-500: #3d7f99;
  --accent-400: #5a92a8;

  --ink-900: #1f2e36;
  --ink-700: #1a272e;
  --ink-600: #1d2a32;
  --ink-500: #4c585e;

  --paper-000: #ffffff;
  --paper-50:  #f5f7f8;
  --paper-100: #e8e8e8;

  --radius: 14px;
  --shadow-1: 0 6px 18px rgba(0,0,0,.08);
  --shadow-2: 0 12px 28px rgba(0,0,0,.12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Helvetica,Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: var(--ink-900);
  background: var(--paper-000);
  line-height: 1.55;
}

.container { width: min(1160px, 92vw); margin: 0 auto; }

.header {
  position: sticky; top: 0; z-index: 1000;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.86));
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--paper-100);
}
.header .bar { display:flex; align-items:center; justify-content:space-between; padding:12px 0; }
.logo { font-weight:800; letter-spacing:.5px; font-size:18px; color:var(--brand-600); text-decoration:none; }
.nav a { color:var(--ink-900); text-decoration:none; margin-left:22px; font-weight:600; }
.nav a:focus, .nav a:hover { color: var(--brand-600); outline: none; }

.btn { display:inline-flex; align-items:center; gap:10px; border-radius:999px; padding:12px 18px; font-weight:700; text-decoration:none; border:2px solid transparent; }
.btn.primary { background: var(--brand-600); color: #fff; }
.btn.primary:hover { background: var(--brand-700); }
.btn.ghost { border-color: var(--brand-300); color: var(--brand-600); background:#fff; }
.btn.ghost:hover { border-color: var(--brand-500); color: var(--brand-700); }

.hero {
  background: radial-gradient(1200px 600px at 20% -20%, var(--brand-100), transparent),
              radial-gradient(900px 500px at 90% 10%, var(--accent-400), transparent),
              linear-gradient(180deg, #fff, #fbfbfb 40%, #fff);
  padding: 72px 0 40px;
  border-bottom: 1px solid var(--paper-100);
}
.hero h1 { font-size: clamp(32px, 4.2vw, 48px); line-height:1.1; margin:10px 0 10px; letter-spacing:-0.4px; }
.hero p.lede { font-size: clamp(16px, 2.1vw, 20px); color: var(--ink-600); max-width: 820px; }

.kpis { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; margin:28px 0 12px; }
.kpi { background:#fff; border:1px solid var(--paper-100); border-radius:var(--radius); box-shadow:var(--shadow-1); padding:16px; }
.kpi .num { font-size:28px; font-weight:900; color:var(--brand-600); }
.kpi .cap { color:var(--ink-600); font-weight:600; }

.section { padding:64px 0; }
.section h2 { font-size:clamp(24px,3vw,34px); margin:0 0 10px; }
.section .sub { color:var(--ink-600); margin-top:0; margin-bottom:24px; }

.grid-2 { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:28px; align-items:start; }
.card { background:#fff; border:1px solid var(--paper-100); border-radius:var(--radius); box-shadow:var(--shadow-1); padding:18px; width:100%; }
.badge { display:inline-flex; align-items:center; gap:8px; background:var(--brand-100); color:var(--brand-600); font-weight:700; padding:6px 10px; border-radius:999px; font-size:12px; }

.list-check { padding-left:1.2em; }
.list-check li::marker { content:"✓ "; color:var(--brand-600); font-weight:900; }

.highlight { background: linear-gradient(180deg, rgba(255,210,196,.0), rgba(255,210,196,.5)); border-radius:6px; padding:0 4px; }

.case-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.case .title { font-weight:800; }
.case .meta { color:var(--ink-600); font-size:13px; }

.team-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:16px; }
.team-card .name { font-weight:800; }
.team-card .role { color:var(--ink-600); font-size:13px; }

.partners { display:grid; grid-template-columns: repeat(4,1fr); gap:12px; }
.partner { background:#fff; border:1px dashed var(--paper-100); border-radius:var(--radius); padding:20px; text-align:center; color:var(--ink-600); }

.callout { background: linear-gradient(0deg, var(--brand-100), #fff); border:1px solid var(--paper-100); border-radius:var(--radius); box-shadow:var(--shadow-1); padding:18px; }

.footer { background:#0f1416; color:#cfd8dc; padding:40px 0; margin-top:32px; }
.footer a { color:#e0f2f1; text-decoration:none; }
.footer small { color:#93a3aa; }

@media (max-width: 900px) {
  .kpis { grid-template-columns:1fr; }
  .grid-2 { grid-template-columns:1fr; }
  .case-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .partners { grid-template-columns: repeat(2,1fr); }
}

/* Team grid modern layout */
.team-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(110px,1fr)); gap:16px; align-items:start; }
.card.team-card { display:grid; grid-template-rows:auto auto auto; gap:4px; padding:6px; border-radius:10px; }
.card.team-card .avatar {
  width:100%;
  height:80px; /* halved from 160px */
  display:block;
  object-fit:cover;
  object-position:50% var(--y,50%);
  transform: scale(var(--scale,1)) translateY(var(--shift,0px));
  transform-origin:50% 50%;
  border-radius:8px; background: var(--paper-100);
}
@media (max-width:640px){ .card.team-card .avatar{ height:70px; } }

/* Per-person avatar tuning */
.avatar-karthik{ --scale:.84; --y:40%; }
.avatar-denis  { --scale:.80; --y:35%; }
.avatar-aaron  { --scale:.83; --y:40%; }
.avatar-isaac  { --scale:.80; --y:40%; }
.avatar-jessop { --scale:.88; --y:39%; }
.avatar-robb   { --scale:.92; --y:48%; }
.avatar-robert { --scale:.75; --y:40%; }
.avatar-jesse  { --scale:.92; --y:20%; }

.card.team-card .name { font-weight:700; font-size:11px; }
.card.team-card .role { color:var(--ink-600); font-size:10px; }

/* Team group subheadings */
.team-group { grid-column:1 / -1; margin:4px 0 2px; }
.team-group h3 { margin:0; font-size:14px; text-transform:uppercase; letter-spacing:.02em; color:var(--ink-600); }

/* Figures & image grids */
.figure { display:flex; justify-content:center; margin:12px 0; }
.figure img { max-width:100%; height:auto; border-radius:12px; box-shadow:0 2px 10px rgba(0,0,0,.06); }
.img-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap:12px; }
.img-card { border-radius:12px; overflow:hidden; background: var(--paper-50); box-shadow: 0 2px 10px rgba(0,0,0,.04); }
.img-card img { width:100%; height:auto; display:block; }
.img-caption { font-size:12px; color:var(--ink-600); padding:6px 8px; }

/* Media text + figure layout */
.media { display:flex; gap:16px; align-items:flex-start; }
@media (max-width:900px){ .media{ flex-direction:column; } }

/* Make specific elements span both columns inside .grid-2 */
.grid-2 > .full-span { grid-column:1 / -1; order:2; width:100%; margin-left:0; }

/* Opportunity image row */
#opportunity .img-grid { display:grid; grid-template-columns: repeat(3, 280px); gap:24px; max-width:912px; margin-inline:auto; }
#opportunity .img-grid .img-card { width:280px; }
@media (max-width:980px){ #opportunity .img-grid{ grid-template-columns:repeat(2,280px); max-width:584px; } }
@media (max-width:640px){ #opportunity .img-grid{ grid-template-columns:1fr; max-width:600px; } #opportunity .img-grid .img-card{ width:100%; } }

/* Execution focus vertical alignment */
@media (min-width:981px){ #opportunity .grid-2 > .card{ align-self:start; margin-top: clamp(20px,3vw,40px); } }
@media (max-width:980px){ #opportunity .grid-2 > .card{ align-self:auto; margin-top:0; } }

/* Safety: hide legacy expand button if present */
button[data-disclosure="more-team"]{ display:none !important; }