
@import url('https://fonts.googleapis.com/css2?family=Libre+Bodoni:wght@700;800&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Serif:wght@400;500&display=swap');

:root{
  --blue-900:#071521;
  --blue-800:#0c2233;
  --blue-700:#12354d;
  --blue-accent:#79c8ff;
  --accent-rame:#c46a2d;
  --light:#f4f7fa;
  --ink:#0f1418;
  --muted:#5e6a75;
  --line:#e6ebf0;
  --max:1280px;
}

*{box-sizing:border-box}
body{margin:0;font-family:'IBM Plex Serif',serif;color:var(--ink);background:#fff;line-height:1.55}
a{text-decoration:none;color:inherit}
.container{max-width:var(--max);margin:0 auto;padding:0 28px}

/* HEADER tighter + Atlante Intelligence */
.topbar{background:var(--blue-900);color:#fff}
.nav{display:grid;grid-template-columns:1fr auto auto;align-items:center;padding:8px 0;font-family:'IBM Plex Sans',sans-serif}
.brand{
  font-family:'IBM Plex Sans',sans-serif;
  font-weight:700;
  font-size:22px;
  line-height:1;
}
.brand small{
  display:block;
  font-family:'IBM Plex Serif',serif;
  font-weight:400;
  font-size:14px;
  margin-top:2px;
  opacity:.9;
}
.menu{display:flex;gap:26px;font-size:14px;justify-self:center}
.actions{display:flex;gap:14px}
.btn{padding:6px 14px;border-radius:30px;border:1px solid rgba(255,255,255,.6);font-size:12px;font-weight:600;display:inline-block}
.btn.primary{background:#fff;color:var(--blue-900);border:none}



/* =========================================================
   HERO OPEN — BlackRock-like (robust, no layout side-effects)
   Image fills EXACTLY the right half (50% width, 100% height).
   Place hero-open as the first module under the header.
   ========================================================= */

.hero-open{
  background: #f6f1e8; /* avorio */
  color: var(--ink);
padding: 34px 0 18px;
}
.hero-open__inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 28px;
  position: relative;

  min-height: clamp(520px, 60vh, 760px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  gap: 0;
  overflow: hidden; /* ensures full-height image stays clean */
}

/* Right half image ALWAYS fills 50% x 100% */
.hero-open__inner::after{
  content:"";
  position:absolute;
  top:0; right:0;
  width:50%;
  height:100%;
  background: url("../img/index-hero.webp") center/cover no-repeat;
}

/* Readability / sheen */
.hero-open__inner::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    90deg,
    rgba(246,241,232,0) 0%,
    rgba(246,241,232,0) 45%,
    rgba(246,241,232,0.08) 100%
  );
  pointer-events:none;
}
.hero-open__left{
  position: relative;
  z-index: 2;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding-right: clamp(18px, 3vw, 44px);
  max-width: 680px;
}

.hero-open__kicker{margin-bottom:12px;}
.hero-open__title{
  font-family:'Libre Bodoni',serif;
  font-weight:800;
  letter-spacing:-0.02em;
  line-height:1.02;
  font-size: clamp(44px, 4.6vw, 74px);
  margin:0 0 14px;
}
.hero-open__deck{
  font-family:'IBM Plex Sans',sans-serif;
  font-size:18px;
  line-height:1.55;
  opacity:.92;
  max-width:60ch;
  margin:0 0 18px;
}
.hero-open__meta{
  display:flex;
  gap:14px;
  align-items:center;
  flex-wrap:wrap;
  font-family:'IBM Plex Sans',sans-serif;
  font-size:13px;
  opacity:.9;
  margin-bottom:18px;
}
.hero-open__meta .dot{
  width:6px;height:6px;border-radius:50%;
  background: rgba(255,255,255,.65);
}
.hero-open__cta{
  display:flex;
  gap:12px;
  align-items:center;
  flex-wrap:wrap;
}

/* Button tuning inside dark hero */
.hero-open__cta .btn.primary{
  background: var(--blue-900);
  color:#fff;
  border:none;
}
.hero-open__cta .btn{
  border:1px solid var(--line);
  background:#fff;
  color:var(--ink);
}
/* Mobile: stack + show image as top block */
@media (max-width: 980px){
  .hero-open__inner{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .hero-open__inner::after{
    position:relative;
    width:100%;
    height:320px;
  }
  .hero-open__left{padding-right:0;}
}

/* tighter gap hero → most */
.section-gap{height:10px}

/* MOST POPULAR 3-level + hint */
.most{background:var(--light);padding:70px 0}
.most h3{font-family:'IBM Plex Sans';font-size:20px;font-weight:600;margin:0 0 26px}

.scroll-wrapper{position:relative}
.scroll{display:flex;gap:22px;overflow-x:auto;padding-bottom:12px;scroll-snap-type:x mandatory}
.scroll-wrapper::after{
  content:'';
  position:absolute;
  right:0;top:0;height:100%;width:120px;
  background:linear-gradient(to right, rgba(244,247,250,0), rgba(244,247,250,1));
  pointer-events:none;
}
.card{min-width:420px;background:#fff;border:1px solid var(--line);scroll-snap-align:start}
.card img{width:100%;display:block}
.card .body{padding:16px 16px 18px}
.card .body .kicker{color:var(--accent-rame);margin-bottom:8px}
.card h4{font-family:'Libre Bodoni',serif;font-size:26px;margin:0 0 8px;line-height:1.15;letter-spacing:-0.015em}
.card p{margin:0;font-size:14px;color:var(--muted)}

/* two rows under */
.rows{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.small-card{background:#fff;border:1px solid var(--line);display:grid;grid-template-columns:96px 1fr}
.small-card img{width:96px;height:100%;object-fit:cover}
.small-card .body{padding:10px 12px}
.small-card .kicker{color:var(--blue-accent);margin-bottom:4px}
.small-card h5{font-family:'IBM Plex Sans',sans-serif;font-size:13px;margin:0 0 4px;line-height:1.2}
.small-card p{margin:0;font-size:12px;color:var(--muted)}

/* BREAKTHROUGH compact */
.breakthrough{background:var(--blue-700);padding:90px 0 0;color:#fff}
.breakthrough-box{background:#fff;color:#000;padding:48px;border:4px solid var(--accent-rame)}
.breakthrough-box img{width:100%;margin-bottom:18px}
.breakthrough-box .kicker{color:var(--accent-rame)}
.breakthrough-box h2{font-family:'Libre Bodoni',serif;font-size:54px;margin:6px 0 10px;line-height:1.05;letter-spacing:-0.02em}
.breakthrough-box p{margin:0;font-size:15px;line-height:1.35}

/* SUBLEVEL STRIP */
.sublevel{background:var(--blue-900);padding:70px 0;color:#fff}
.sub-inner{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.sub-inner .kicker{margin-bottom:10px}
.sub-inner h3{font-family:'Libre Bodoni',serif;font-size:38px;letter-spacing:-0.015em;color:var(--blue-accent);margin:0 0 10px}
.sub-inner p{margin:0;font-size:14px;color:rgba(255,255,255,.86)}
.sub-inner img{width:100%;display:block}

/* ISSUES — HBR-like layout + carousel */
.issues{padding:90px 0;border-top:1px solid var(--line)}
.issues h3{font-family:'IBM Plex Sans';font-size:20px;font-weight:600;margin:0 0 24px}
.issues-scroll{position:relative}
.issues-row{display:flex;gap:22px;overflow-x:auto;padding-bottom:12px;scroll-snap-type:x mandatory}
.issues-scroll::after{
  content:'';
  position:absolute;
  right:0;top:0;height:100%;width:120px;
  background:linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,1));
  pointer-events:none;
}
.issue-panel{
  min-width:980px;
  background:#fff;
  border:1px solid var(--line);
  scroll-snap-align:start;
  padding:22px;
}
.issue-grid{display:grid;grid-template-columns:160px 1.2fr .9fr;gap:26px;align-items:start}
.issue-left{border-right:1px solid var(--line);padding-right:18px}
.issue-left img{width:100%;box-shadow:0 16px 30px rgba(0,0,0,.18)}
.issue-left .meta{font-family:'IBM Plex Sans',sans-serif;font-size:13px;color:var(--muted);margin-top:10px}
.issue-center img{width:100%;display:block}
.issue-center h4{font-family:'Libre Bodoni',serif;font-size:26px;margin:14px 0 6px;letter-spacing:-0.01em}
.issue-center p{margin:0;color:var(--muted);font-size:14px}
.issue-right{border-left:1px solid var(--line);padding-left:18px;max-height:420px;overflow-y:auto}
.issue-right .item{padding:10px 0;border-bottom:1px solid rgba(230,235,240,.7)}
.issue-right .item:last-child{border-bottom:none}
.issue-right .kicker{color:var(--accent-rame);margin-bottom:6px}
.issue-right h5{font-family:'Libre Bodoni',serif;font-size:18px;margin:0 0 6px;line-height:1.15;letter-spacing:-0.01em}
.issue-right p{margin:0;color:var(--muted);font-size:13px;line-height:1.35}

/* FOOTER — restore v9 style + reduce vertical gap between pre-blocks and menu */
.footer-pre{background:var(--blue-900);color:#fff;padding:140px 0 20px}
.footer-pre-grid{display:grid;grid-template-columns:1fr 1fr;gap:110px}
.footer-pre h4{font-family:'Libre Bodoni',serif;font-size:34px;margin:0 0 16px}
.footer-pre p{font-family:'IBM Plex Sans',sans-serif;font-size:16px;color:#cfcfcf;margin:0}
.footer-pre .btn{margin-top:22px;background:#fff;color:var(--blue-900);border:none}

.footer-main{background:var(--blue-900);color:#fff;padding:40px 0 80px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:80px}
.footer-logo{
  font-family:'IBM Plex Sans',sans-serif;
  font-weight:700;
  font-size:88px;
  line-height:.9;
}
.footer-logo small{
  display:block;
  font-family:'IBM Plex Serif',serif;
  font-weight:400;
  font-size:18px;
  margin-top:6px;
  opacity:.9;
}
.footer-grid h5{font-family:'IBM Plex Sans',sans-serif;text-transform:uppercase;font-size:13px;letter-spacing:.1em;margin:0 0 18px}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:12px;font-size:15px;color:#ccc}

.footer-bottom{background:var(--blue-900);border-top:1px solid rgba(255,255,255,.1);padding:26px 0 70px;color:#aaa;font-family:'IBM Plex Sans',sans-serif;font-size:14px}

@media(max-width:1100px){
  .hero-grid{grid-template-columns:1fr}
  .hero-text,.hero-cover{grid-column:auto}
  .rows{grid-template-columns:1fr}
  .sub-inner{grid-template-columns:1fr}
  .footer-pre-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .issue-panel{min-width:92vw}
  .issue-grid{grid-template-columns:1fr}
  .issue-left{border-right:none;padding-right:0}
  .issue-right{border-left:none;padding-left:0;max-height:none}
}
/* ========= Typography QA (Atlante) ========= */

/* Body readability */
body{
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

p{
  line-height: 1.62;
}

/* Headings: tighter, more editorial */
h1, h2, h3, h4{
  letter-spacing: -0.01em;
}

.hero-open__title{
  letter-spacing: -0.02em;
}

/* Card titles: stronger but controlled */
.card h4{
  line-height: 1.15;
  margin: 10px 0 10px;
}

/* Kicker: consistent “occhiello” */
.kicker{
  font-size: 11px;
  letter-spacing: .14em;
  margin-bottom: 10px;
}

/* Vertical rhythm inside cards */
.card .body p{
  margin-top: 8px;
  margin-bottom: 0;
  opacity: .88;
}

/* Optional: keep paragraphs from becoming too wide */
.deck, .hero-open__deck, .card .body p{
  max-width: 62ch;
}


/* --- Atlante: header/footer harmony (from index inline) --- */
/* --- Atlante: header/footer harmony (supplement) --- */
.logo-lockup{display:flex;align-items:baseline;gap:10px;text-decoration:none;color:inherit}
.logo-lockup small{display:inline;opacity:.85;font-weight:600;letter-spacing:.04em}
.logo-lockup .logo-word{display:inline-block}

/* Make the primary CTA visually dominant (header + footer) */
.cta-dominant, .footer-cta{
  border-radius:999px;
  padding:.7rem 1.05rem;
  font-weight:700;
}
.footer-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
}

/* Clickable titles inside cards */
.card-title-link{color:inherit;text-decoration:none}
.card-title-link:hover{text-decoration:underline}

/* Make the whole footer-pre card feel clickable without changing layout */
.footer-pre .card{position:relative}
.footer-pre .card::after{
  content:"";
  position:absolute;inset:0;
  border-radius:inherit;
}
.footer-pre .card:hover{transform:translateY(-2px)}


/* --- HERO → MOST tightening & hide label --- */
.section-gap{height:6px;}
.most h3{display:none;}
.most{padding-top:8px;}

/* ===== Rhythm tweaks (v4) ===== */
.section-gap{height:18px !important;}


/* =========================================================
   ABOUT BAND (v12) — yellow stripe with floating cards
   Matches wireframe: cards sit on yellow field but the field
   extends beyond the cards (not aligned in height).
   ========================================================= */

:root{
  --about-yellow: #f6c400;
}

.about-band{
  background: var(--about-yellow);
  padding: 80px 0 80px; /* large bottom to decouple from card height */
  position: relative;
}

.about-band--spaced{
  margin-top: 32px; /* white gap between stripes (as in mock) */
  margin-bottom: 32px; /* white gap before footer */
}

.about-band__inner{
  position: relative;
}

.about-cards{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
  align-items: start;
}

.about-card{
  background: #fff;
  padding: 26px 26px 56px;
  box-shadow: 0 18px 40px rgba(0,0,0,.14);
  border: 1px solid rgba(0,0,0,.08);
  position: relative;
}

.about-card h3{
  margin: 0 0 10px;
  font-family: 'IBM Plex Sans', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: #0f1418;
}

.about-card p{
  margin: 0;
  font-family: 'IBM Plex Sans', sans-serif;
  font-size: 13px;
  line-height: 1.5;
  color: #2b343c;
}

.about-card__arrow{
  position: absolute;
  left: 16px;
  bottom: 16px;
  width: 34px;
  height: 34px;
  background: #111;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0; /* square */
}

.about-card__arrow span{
  font-size: 22px;
  transform: translateX(1px);
}

/* Responsive */
@media (max-width: 980px){
  .about-cards{ grid-template-columns: 1fr; }
  .about-band{ padding-bottom: 60px; }
}
/* ===== ABOUT HERO IMAGE override (v3) =====
   Use a dedicated hero image on about.html without changing index.html.
   Put the file here: /img/about.jpg
*/
.page-about .hero-open__inner::after{
  background-image: url("../img/about.jpg");
}

.page-landing .hero-open__inner::after{
  background-image: url("../img/capabilities-hero.jpg");
}
