/* ============================
   Enzo Capital Investments — styles.css
   ============================ */

:root {
  --navy:#0d1e4a;
  --navy-ink:#e8f0ff;
  --ink:#0b1422;
  --muted:#4c5a67;
  --brand:#3aa0ff;
  --brand-ink:#072a49;
  --border:#e6edf3;
  --panel:#f6f9fc;
  --white:#ffffff;

  --fs-h1:clamp(30px,4.2vw,48px);
  --fs-h2:clamp(22px,3vw,32px);
  --fs-h3:clamp(18px,2vw,22px);
  --fs-body:18px;
  --lh:1.65;
  --radius:12px;
}

/* Base */
* { box-sizing:border-box; }
html,body {
  margin:0;
  padding:0;
  background:var(--white);
  color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,Arial,sans-serif;
}
img { max-width:100%; display:block; }
a { color:var(--brand); text-decoration:none; }
a:hover { text-decoration:underline; }
.container { width:min(1140px,92vw); margin:0 auto; }

/* ============================
   Header
   ============================ */
.site-header {
  position:sticky;
  top:0;
  z-index:100;
  background:linear-gradient(180deg,#f4f8ff 0%, #ffffff 100%);
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 8px rgba(13,30,74,.08);
  padding:8px 0;
}
.site-header::after {
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:3px;
  background:var(--brand);
}
.nav-wrap {
  display:flex;
  align-items:center;
  justify-content:space-between;
}

/* Logo */
.brand { display:flex; align-items:center; }
.logo-main { height:49px; width:auto; }

/* Navigation */
.nav {
  display:flex;
  align-items:center;
  gap:26px;
}
.nav a {
  position:relative;
  color:var(--ink);
  font-weight:500;
  padding-bottom:6px;
}
.nav a::after {
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:3px;
  background:var(--brand);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .2s ease;
  border-radius:2px;
}
.nav a:hover::after,
.nav a:focus-visible::after {
  transform:scaleX(1);
}

/* Contact link same style as others */
.nav-cta {
  color:var(--ink);
  font-weight:500;
  background:none;
  border:none;
  padding-bottom:6px;
}
.nav-cta:hover { color:var(--brand); }
.nav-cta:focus { outline:none; }
.nav-cta:focus-visible {
  box-shadow:0 2px 0 0 var(--brand);
}

/* Hamburger (mobile) */
.nav-toggle { position:absolute; opacity:0; pointer-events:none; }
.hamburger {
  display:none;
  cursor:pointer;
  width:42px;
  height:34px;
  border-radius:8px;
  border:1px solid #7a8590;
  background:rgba(255,255,255,0.95);
  align-items:center;
  justify-content:center;
  gap:5px;
  padding:6px;
}
.hamburger span {
  display:block;
  width:22px;
  height:3px;                 /* thicker for clarity */
  background:#111827;          /* darker bars */
  border-radius:2px;
  transition:transform .25s ease, opacity .2s ease, background .2s ease;
}
@media (max-width:900px) {
  .hamburger { display:flex; }
  .nav {
    position:absolute;
    top:100%;
    right:4vw;
    left:4vw;
    background:#fff;
    border:1px solid var(--border);
    border-radius:12px;
    box-shadow:0 16px 40px rgba(7,17,27,.16);
    display:flex;
    flex-direction:column;
    gap:0;
    padding:8px 0;
    transform:translateY(-10px);
    opacity:0;
    pointer-events:none;
  }
  .nav a {
    display:block;
    padding:12px 14px;
    border-top:1px solid var(--border);
  }
  .nav a:first-child { border-top:none; }
  .nav-toggle:checked ~ .nav {
    transform:translateY(0);
    opacity:1;
    pointer-events:auto;
  }
  .nav-toggle:checked + .hamburger {
    background:#111827;
    border-color:#111827;
  }
  .nav-toggle:checked + .hamburger span:nth-child(1) {
    transform:translateY(7px) rotate(45deg);
    background:#ffffff;
  }
  .nav-toggle:checked + .hamburger span:nth-child(2) {
    opacity:0;
  }
  .nav-toggle:checked + .hamburger span:nth-child(3) {
    transform:translateY(-7px) rotate(-45deg);
    background:#ffffff;
  }
}

/* ============================
   Sections / general
   ============================ */
.section {
  padding:64px 0;
  border-top:1px solid var(--border);
}
.section--neutral { background:#fbfdff; }
.section--cta { background:var(--panel); }

h1 {
  font-size:var(--fs-h1);
  margin:0 0 12px;
}
h2 {
  margin:0;
  font-size:var(--fs-h2);
  font-weight:800;
}
h3 {
  margin:0 0 8px;
  font-size:var(--fs-h3);
}
p {
  font-size:var(--fs-body);
  line-height:var(--lh);
  color:var(--muted);
}
.lead { font-weight:500; }

.underline {
  width:84px;
  height:3px;
  background:var(--brand);
  margin:12px 0 24px;
  border-radius:2px;
}

/* Buttons */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 22px;
  border-radius:999px;
  border:none;
  cursor:pointer;
  font-weight:600;
  font-size:16px;
}
.btn--brand {
  background:var(--brand);
  color:#fff;
}
.btn--brand:hover {
  background:#1789f5;
  text-decoration:none;
}

/* ============================
   Split panels / hero / case rows
   ============================ */
.split-panel,
.case-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:380px;
}
@media (max-width:980px) {
  .split-panel,
  .case-row {
    grid-template-columns:1fr;
  }
}

.panel {
  position:relative;
}

/* Generic dark panel (used in portfolio rows) */
.panel--dark {
  background:var(--navy);
  color:var(--navy-ink);
  display:flex;
  align-items:center;
}
.panel--dark .panel-inner {
  padding:48px;
  width:min(700px,92%);
  margin:auto;
}
.panel--dark h3 {
  margin:0 0 10px;
  color:#fff;
}
.panel--dark p {
  color:#dbe7ff;
}

/* Panel images */
.panel--image img {
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Case rows */
.case-row {
  margin:24px 0;
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
}
.case-row.reverse .panel--dark { order:2; }
.case-row.reverse .panel--image { order:1; }

/* Uniform image sizes in portfolio rows */
.case-row .panel--image img,
.case-row .panel--image.logo-panel img,
img.portfolio-img {
  width:100%;
  display:block;
  aspect-ratio:16 / 9;     /* consistent height across all cards */
  object-fit:cover;
  object-position:center;
}

/* Hero-specific overrides */
.hero-banner .panel--dark {
  background:#ffffff;      /* white hero box */
  color:#000000;
}
.hero-banner .panel--dark h1,
.hero-banner .panel--dark h3 {
  color:#000000;
}
.hero-banner .panel--dark p {
  color:#333333;
}

/* Tick list in hero on white */
.hero-banner ul.tick.light li {
  color:#333333;
}
.hero-banner ul.tick.light li::before {
  color:var(--brand);
}

/* Hero image & watermark */
.hero-banner .hero-image {
  position:relative;
}
.hero-banner .hero-logo {
  position:absolute;
  top:clamp(10px,2vw,28px);
  right:clamp(10px,2vw,28px);
  z-index:3;
  color:rgba(255,255,255,.55);  /* translucent white */
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:clamp(24px,6vw,72px);
  line-height:1;
  text-shadow:0 2px 8px rgba(0,0,0,.25);
  pointer-events:none;
}

/* Slight overlay for busy hero images */
.hero-banner .hero-image::before {
  content:"";
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(180deg,rgba(0,0,0,.06),rgba(0,0,0,.12));
  pointer-events:none;
}
.hero-banner .hero-image img {
  position:relative;
  z-index:1;
}

/* ============================
   Cards (Focus section)
   ============================ */
.cards {
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.card {
  background:#ffffff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 20px 22px;
  box-shadow:0 4px 14px rgba(7,17,27,.04);
}
.card p { margin:0; }

@media (max-width:900px) {
  .cards { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:600px) {
  .cards { grid-template-columns:1fr; }
}

/* ============================
   Tick lists
   ============================ */
ul.tick {
  list-style:none;
  padding:0;
  margin:12px 0 18px;
}
ul.tick li {
  position:relative;
  padding-left:22px;
  margin:6px 0;
  color:var(--muted);
}
ul.tick li::before {
  content:"✓";
  position:absolute;
  left:0;
  color:var(--brand);
  font-weight:700;
}
ul.tick.light li {
  color:#dce8ff;
}

/* ============================
   Team / About grid
   ============================ */
.about-grid {
  display:grid;
  grid-template-columns:1.1fr 1.2fr;
  gap:40px;
  align-items:flex-start;
}
@media (max-width:900px) {
  .about-grid {
    grid-template-columns:1fr;
  }
}

.team-intro p { max-width:520px; }

.team-members {
  display:grid;
  gap:24px;
}

.leader {
  background:#ffffff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:0 4px 16px rgba(7,17,27,.04);
}
.leader-wrap {
  display:grid;
  grid-template-columns:auto 1fr;
  gap:18px;
  align-items:flex-start;
}
.leader-photo img {
  width:120px;
  height:120px;
  border-radius:999px;
  object-fit:cover;
}
.leader-bio p { margin:0 0 10px; }

.linkedin-link {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:15px;
}
.linkedin-icon {
  width:18px;
  height:18px;
}

/* ============================
   Contact + footer
   ============================ */
.cta-bar {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
@media (max-width:800px) {
  .cta-bar {
    flex-direction:column;
    align-items:flex-start;
  }
}

.footer {
  background:#f3f6f8;
  border-top:1px solid var(--border);
  padding:18px 0;
}
.footer p {
  margin:0;
  text-align:center;
  color:#6c7b86;
  font-size:14px;
}

/* ============================
   Responsive typography tweaks
   ============================ */
@media (max-width:700px) {
  :root {
    --fs-h1:28px;
    --fs-h2:22px;
    --fs-h3:18px;
    --fs-body:16px;
  }
  .case-row {
    grid-template-columns:1fr;
  }
  .case-row .panel--image {
    order:1;
    min-height:220px;
  }
  .case-row .panel--dark {
    order:2;
  }
}

/* === Force hero text to dark colours === */
.hero-banner .panel--dark p,
.hero-banner .panel--dark .lead {
  color:#333333 !important;
}

.hero-banner .panel--dark span {
  color:#333333 !important;
}


/* ============================
   HERO – Blue box and white button
   ============================ */

/* Blue section containing tick list + CTA */
.hero-blue-box {
  background:#0d1e4a;            /* Enzo navy */
  padding:28px;
  border-radius:12px;
  margin-top:24px;
}

/* Tick list inside blue box */
.hero-blue-box .hero-ticks li {
  color:#ffffff !important;      /* white text */
}
.hero-blue-box .hero-ticks li::before {
  color:#3aa0ff !important;      /* brand blue ticks */
}

/* White button on blue background */
.btn--white-hero {
  display:inline-block;
  margin-top:14px;
  background:#ffffff;
  color:#0d1e4a;                 /* navy text */
  padding:12px 22px;
  font-weight:600;
  border-radius:999px;
  text-decoration:none;
}
.btn--white-hero:hover {
  background:#f0f4ff;
  color:#072a49;
}

/* Bottom blue strip */
.hero-bottom-strip {
  margin-top:20px;
  background:#0d1e4a;
  color:#ffffff;
  padding:16px 22px;
  border-radius:10px;
  font-weight:500;
}




