:root{
  --navy: #0b1f3a;
  --navy-ink: #0a1c33;
  --blue-50: #f3f7ff;
  --blue-100: #e6f0ff;
  --line: #e6e8ee;
  --white: #ffffff;

  --text: var(--navy);
  --muted: #50607a;

  --radius: 16px;
  --container: 1120px;
}

*{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(--text);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.container{max-width:var(--container);margin-inline:auto;padding:0 24px}
.narrow{max-width:820px;margin-inline:auto}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;background:var(--navy);color:#fff;padding:8px 12px;border-radius:8px}

/* Header */
.site-header{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:72px}
.brand{font-weight:800;letter-spacing:.5px;text-transform:uppercase}
.nav{display:flex;gap:24px;align-items:center}
.nav a{color:var(--text);text-decoration:none;font-weight:500;opacity:.85}
.nav a[aria-current="page"]{opacity:1}
.nav a:hover{opacity:1}
.nav .btn{margin-left:8px}
.nav-toggle{display:none;background:none;border:0;padding:8px}
.nav-toggle .bar{display:block;width:24px;height:2px;background:var(--text);margin:5px 0}

.site-header { position: sticky; top: 0; z-index: 10; background: rgba(255,255,255,.9); border-bottom: 1px solid var(--line); backdrop-filter: saturate(180%) blur(8px); }
.header-inner { display: flex; align-items: center; justify-content: space-between; min-height: 72px; }
.nav { display: flex; gap: 24px; align-items: center; }
.nav a { color: var(--text); text-decoration: none; font-weight: 500; opacity: .85; }
.nav a[aria-current="page"] { opacity: 1; }
.nav a:hover { opacity: 1; }

.brand img {
  height: 75px; /* adjust as needed */
  width: auto;
  display: block;
}

/* Brand link: always black, never underlined */
a.brand,
a.brand:link,
a.brand:visited,
a.brand:hover,
a.brand:active { color: #000; text-decoration: none; }

/* Hero */
.hero-minimal{padding:96px 0 56px;border-bottom:1px solid var(--line);background:var(--white)}
.headline{
  font-size:clamp(34px, 5.5vw, 60px);
  line-height:1.06;
  letter-spacing:-0.02em;
  margin:0 0 16px;
  color:var(--navy-ink);
}
.lede{max-width:60ch;color:var(--muted);margin:0}

/* Sections */
.section{padding:64px 0}
.section-title{
  font-size:clamp(22px, 3vw, 32px);
  margin:0 0 12px;
  position:relative;
}
.section-title::after{
  content:"";
  display:block;
  width:56px;height:3px;
  margin-top:10px;
  background:var(--blue-100);
  border-radius:2px;
}
.section-about p{margin:0;}

/* Practice areas */
.section-practice .cols-2{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start
}
.bullet-list{margin:0;padding-left:20px;color:var(--muted)}
.bullet-list li{margin:8px 0}

/* Numbers */
.section-numbers{
  background:var(--blue-50);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat{padding:20px;border:1px solid var(--line);border-radius:12px;background:#fff;text-align:center}
.stat-number{font-size:28px;font-weight:800;color:var(--navy)}
.stat-label{color:var(--muted);font-size:14px}

/* CTA band */
.section-cta{background:var(--blue-100);border-top:1px solid var(--line)}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.cta-title{margin:0 0 6px}
.cta-text{margin:0;color:var(--muted)}

/* Hamburger button (hidden on desktop by default) */
.nav-toggle {
  display: none;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  width: 40px; height: 40px;
  align-items: center; justify-content: center;
  cursor: pointer;
}
.nav-toggle .bar {
  display: block;
  width: 22px; height: 2px;
  background: var(--text);
  margin: 3px 0;
}

/* Talent roster grid */
.section-roster .talent-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.talent-card{
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 16px;
  text-align: center;
  transition: transform .2s ease, box-shadow .2s ease;
}
.talent-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

/* Photo uses a consistent aspect ratio so tiles line up cleanly */
.talent-photo{
  width: 100%;
  aspect-ratio: 4 / 5;      /* nice portrait ratio */
  object-fit: cover;
  border-radius: 10px;
  background: #f2f4f8;      /* fallback if image missing */
  display: block;
  margin-bottom: 12px;
}

.talent-name{
  margin: 8px 0 4px;
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
}

.talent-email,
.talent-link{
  display: block;
  text-decoration: none;
  font-weight: 500;
  margin-top: 2px;
}

/* Email: darker, YouTube link: subtle accent underlined */
.talent-email{ color: var(--text); }
.talent-link{
  color: var(--muted);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Contact */
.section-contact .contact-form{max-width:640px;display:grid;gap:16px}
.form-row{display:flex;flex-direction:column;gap:6px}
input, textarea{
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 14px;
  font:inherit;
  width:100%;
}
input:focus, textarea:focus{outline:2px solid var(--blue-100);outline-offset:2px}
.note{margin-top:12px;color:var(--muted);font-size:14px}

/* Flash banner */
.banner{
  margin: 16px auto;
  max-width: var(--container);
  padding: 12px 16px;
  border-radius: 10px;
  border: 1px solid var(--line);
}

.banner-success{
  background: var(--blue-100);
  color: var(--text);
  border-left: 4px solid var(--navy);
}

/* Buttons & links */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;border:1px solid var(--navy);text-decoration:none;font-weight:700}
.btn-primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-primary:hover{transform:translateY(-1px)}
.btn-lg{padding:12px 20px;font-size:16px}

/* Footer */
/* Footer base */
.site-footer {
  border-top: 1px solid var(--line);
  padding: 32px 0;
  margin-top: 32px;
  color: #000;
  text-align: center;
}

/* Make ALL footer links black and not underlined */
.site-footer a,
.site-footer a:link,
.site-footer a:visited,
.site-footer a:hover,
.site-footer a:active {
  color: #000 !important;
  text-decoration: none !important;
}

/* Optional: show underline on hover only */
.site-footer a:hover {
  text-decoration: underline !important;
}

.captcha-image input,
.captcha-image .captcha-input,
.captcha-image [type="text"] {
  display: none !important;
}

/* Responsive */
@media (max-width: 1024px){
  .section-practice .cols-2 { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); }
}

/* Mobile */
@media (max-width: 768px){
  /* Hamburger + collapsed menu */
  .nav-toggle { display: inline-flex; }
  .site-header .nav { display: none; }
  .site-header .nav.open{
    display: flex;
    position: absolute;
    top: 72px; right: 16px;
    flex-direction: column;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px;
    gap: 12px;
    min-width: 220px;
    box-shadow: 0 8px 24px rgba(0,0,0,.08);
  }
  
  .section-roster .talent-grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  
  .cta-inner { flex-direction: column; align-items: flex-start; }
  .stats { grid-template-columns: 1fr; }
}

/* Accessible helper */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}


/* ===== Home Page CSS ===== */
:root {
  --hover-gray: #6f7a8a;
}

html {
  height: -webkit-fill-available;
  background: #030432; /* updated navy */
  overflow-x: hidden;
}

body.home.home-navy {
  position: fixed;
  inset: 0;
  overflow: hidden;
  background: #030432; /* updated navy */
  color: #fff;
  height: 100dvh;
  height: -webkit-fill-available;
}

/* bleed to hide any seam/white line */
body.home.home-navy::before {
  content: "";
  position: fixed;
  inset: -2px;
  background: #030432; /* updated navy */
  pointer-events: none;
}

.home .site-header {
  display: none !important;
}

.home #content > .brand-logo {
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 20;
}

.home #content > .brand-logo img {
  height: 200px;
  width: auto;
  display: block;
}

.home .home-stack {
  width: min(820px, 90vw);
  margin-inline: auto;
  min-height: 100%;
  display: grid;
  align-content: center;
  justify-items: start;
  text-align: left;
  gap: clamp(16px, 3vh, 28px);
  padding: 24px;
  transform: translate(2vw, 24vh); /* left & down */
}

@media(max-width:768px){.home .home-stack{transform:translate(4vw,34vh);}}

/* Primary links (Talent, Brands) */
.home .home-primary{
  display:block;color:#fff;text-decoration:none;font-weight:800;
  letter-spacing:-.02em;line-height:1.02;
  font-size:clamp(38px,7vw,80px);
  transition:transform .18s ease,opacity .18s ease;
  opacity:0;transform:translateY(24px);
}
.home .home-primary:hover,
.home .home-primary:focus-visible{
  color:var(--hover-gray);text-decoration:none;transform:translateY(-2px);
}

/* Secondary links (About, Team, Contact) */
.home .home-secondary{display:grid;grid-auto-flow:row;gap:8px;opacity:1;transform:none;}
.home .home-secondary-link{
  color:#fff;text-decoration:none;font-weight:700;
  font-size:clamp(14px,2vw,20px);line-height:1.2;
  transition:transform .18s ease,opacity .18s ease;
  opacity:0;transform:translateY(24px);
}
.home .home-secondary-link:hover,
.home .home-secondary-link:focus-visible{
  color:var(--hover-gray);text-decoration:none;transform:translateY(-2px);
}

/* Entrance animation & stagger */
@keyframes fly-up{from{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}
.home.animate .home-primary:nth-of-type(1){animation:fly-up .90s cubic-bezier(.2,.7,.2,1) both .10s;}
.home.animate .home-primary:nth-of-type(2){animation:fly-up .90s cubic-bezier(.2,.7,.2,1) both .34s;}
.home.animate .home-secondary-link:nth-of-type(1){animation:fly-up .90s cubic-bezier(.2,.7,.2,1) both 1s;}
.home.animate .home-secondary-link:nth-of-type(2){animation:fly-up .90s cubic-bezier(.2,.7,.2,1) both 1.10s;}
.home.animate .home-secondary-link:nth-of-type(3){animation:fly-up .90s cubic-bezier(.2,.7,.2,1) both 1.20s;}

/* Reduced motion */
@media(prefers-reduced-motion:reduce){
  .home .home-primary,.home .home-secondary-link{
    animation:none!important;transform:none!important;opacity:1!important;transition:none!important;
  }
}

/* Mobile: move stack up and enlarge Talent/Brands */
@media (max-width: 768px){
  .home .home-stack{
    transform: translate(4vw, 20vh); /* was 34vh */
  }
  .home .home-primary{
    font-size: clamp(42px, 12vw, 72px); /* larger on mobile */
  }
  
/* 48px logo mobile */
  .home #content > .brand-logo img {
    height: 150px;
    width: auto;
    display: block;
  }
  
  
}


.section-cta {
  border-bottom: 1px solid var(--line);
}

.site-footer { 
  border-top: 0;  /* leave this off so you don't get two lines */
}

.portrait{margin:0;display:flex;justify-content:center}
.portrait-img{
  width:100%;max-width:420px;aspect-ratio:4/5;object-fit:cover;border-radius:20px;
  box-shadow:0 14px 40px rgba(0,0,0,.12);
  outline:6px solid #fff; /* bright edge */
}

/* Split layout */
.split {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: center;
}

.split-text { max-width: 60ch; }

.split-list {
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
}
.split-list li {
  position: relative;
  padding-left: 18px;
  margin: 6px 0;
  color: var(--muted);
}
.split-list li::before {
  content: "–";
  position: absolute;
  left: 0;
  top: 0;
  line-height: 1.65;
  color: var(--muted);
}

/* Desktop: two columns, image on the right */
@media (min-width: 900px) {
  .split {
    grid-template-columns: 1.1fr 0.9fr;
    gap: 48px;
  }
  /* push image to the right nicely */
  .portrait { justify-content: flex-end; }
  .portrait-img { max-width: 520px; }
}

/* Optional: tighten spacing above stats after the split */
.team-split + .section .stats { margin-top: 0; }

/* ===== Moving logo marquee ===== */

/* Section heading */
.section-ticker { padding-block: 2rem 2.5rem; }
.ticker-title { font-size: clamp(1.125rem, 1.8vw, 1.5rem); font-weight: 600; margin: 0 0 0.75rem; }

/* Viewport (holds two moving tracks) */
.ticker-viewport {
  /* Tunables (override inline on the element if desired) */
  --speed: 30s;       /* lower = faster */
  --gap: 56px;        /* space between logos */
  --item-w: 168px;    /* tile width */
  --item-h: 64px;     /* tile height (shared midline at half this) */
  --pad: 10px;        /* inner padding */
  
  position: relative;
  overflow: hidden;
  display: flex;               /* will contain the original track + its clone */
  gap: var(--gap);
  padding-block: 0.25rem;
  
  /* Subtle edge fade; remove if you want hard edges */
  -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}

/* The moving strip */
.ticker-track {
  display: inline-flex;
  align-items: center;
  gap: var(--gap);
  flex-shrink: 0;              /* width equals content; do not shrink */
  animation: ticker var(--speed) linear infinite;
}
@keyframes ticker { to { transform: translateX(-100%); } }

/* Pause when user hovers/focuses */
.ticker-viewport:hover .ticker-track,
.ticker-viewport:focus-within .ticker-track { animation-play-state: paused; }

/* Each logo tile (fixed size) */
.ticker-item {
  position: relative;
  list-style: none;
  width: var(--item-w);
  height: var(--item-h);
  padding: var(--pad);
  box-sizing: border-box;
  overflow: visible;
  /* Optional tile styling:
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 12px; */
}

/* Image: center on the tile’s middle y; scale to fit without cropping */
.ticker-item img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: calc(100% - 2 * var(--pad));
  max-height: calc(100% - 2 * var(--pad));
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

/* Optional optical tweaks for extreme aspect ratios */
.ticker-item.is-wide img { max-height: calc(100% - 2 * var(--pad) * 0.86); }
.ticker-item.is-tall img { max-width:  calc(100% - 2 * var(--pad) * 0.78); }

/* Respect reduced motion: stop animation, allow manual scroll */
@media (prefers-reduced-motion: reduce) {
  .ticker-track { animation: none; }
  .ticker-viewport { overflow-x: auto; -webkit-mask-image: none; mask-image: none; }
}