/* ============================================================
   InspireMarks — section styles
   ============================================================ */

/* ===== HERO ===== */
.hero {
  min-height: 100vh;
  height: 100vh;
  padding-top: var(--header-h);
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  position: relative;
}
.hero-left {
  padding: clamp(28px, 3.5vw, 56px) var(--gutter) clamp(24px, 3vw, 44px);
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; z-index: 2; min-height: 0;
}
.hero-tagline {
  align-self: flex-end; text-align: right;
  font-family: var(--display);
  font-size: clamp(18px, 1.9vw, 31px);
  line-height: 1.04; letter-spacing: -0.01em;
  max-width: 12ch;
  margin: 0 0 16px;
}
.hero-title {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(54px, 11.2vw, 168px);
  line-height: 0.82;
  letter-spacing: -0.025em;
  text-transform: uppercase;
}
.hero-title span { display: block; }
.hero-sub {
  display: flex; align-items: baseline; gap: 18px; flex-wrap: wrap;
  margin-top: clamp(16px, 2vw, 28px);
  font-family: var(--display);
  font-size: clamp(15px, 1.7vw, 26px);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.hero-sub .accentbar { width: clamp(40px, 6vw, 90px); height: 0.7em; background: var(--accent); display: inline-block; }
.hero-meta {
  display: flex; justify-content: space-between; align-items: flex-end; gap: 20px;
  margin-top: clamp(18px, 2.4vw, 34px);
  border-top: 1px solid var(--rule); padding-top: 14px;
}
.hero-meta p { margin: 0; font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); font-weight: 600; }
.hero-scrollcue { font-size: 12px; letter-spacing: 0.18em; color: var(--ink-soft); font-weight: 700; }
.hero-scrollcue .arrow { display: inline-block; margin-left: 6px; }

/* hero image (static) */
.hero-wall {
  position: relative;
  height: 100%;
  min-height: 0;
  border-left: 1px solid var(--rule);
  overflow: hidden;
  background: var(--paper-2);
}
.hero-wall img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
}

@media (max-width: 980px) {
  .hero { grid-template-columns: 1fr; min-height: auto; height: auto; }
  .hero-left { order: 1; }
  .hero-wall { order: 2; height: 60vh; border-left: none; border-top: 1px solid var(--rule); }
  .hero-tagline { align-self: flex-start; text-align: left; }
}

/* ===== CORE BUSINESS ===== */
.core-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 3.5vw, 60px);
  margin-top: clamp(40px, 5vw, 72px);
}
.svc { border-top: 2px solid var(--ink); padding-top: 22px; }
.svc .num {
  font-family: var(--display); font-size: clamp(40px, 5vw, 78px);
  line-height: 0.9; color: var(--accent); letter-spacing: -0.02em;
}
.svc h3 {
  font-family: var(--display); font-weight: 400;
  font-size: clamp(20px, 1.7vw, 27px); line-height: 1.05;
  text-transform: uppercase; letter-spacing: -0.01em;
  margin: 10px 0 20px;
}
.svc ul { list-style: none; margin: 0; padding: 0; }
.svc li {
  display: flex; gap: 11px; padding: 11px 0;
  border-top: 1px solid var(--rule); font-size: 16px; color: var(--ink);
}
.svc li::before { content: "→"; color: var(--accent); font-weight: 700; }
.core-desc { margin-top: clamp(44px, 5vw, 80px); display: grid; grid-template-columns: 1fr 1.4fr; gap: clamp(20px, 4vw, 70px); align-items: start; }
.core-desc .big-quote { font-family: var(--display); font-size: clamp(22px, 2.4vw, 40px); line-height: 1.0; text-transform: uppercase; letter-spacing: -0.01em; }
@media (max-width: 820px) {
  .core-grid { grid-template-columns: 1fr; }
  .core-desc { grid-template-columns: 1fr; }
}

/* ===== RESOURCES ===== */
.res-top { display: grid; grid-template-columns: 1.25fr 0.75fr; gap: clamp(28px, 5vw, 80px); align-items: center; }
.res-points { display: flex; flex-direction: column; gap: 26px; margin-top: 40px; }
.res-point { display: grid; grid-template-columns: auto 1fr; gap: 20px; align-items: start; padding-top: 22px; border-top: 1px solid var(--rule); }
.res-point .idx { font-family: var(--display); font-size: 22px; color: var(--ink-faint); }
.res-point .big { font-size: clamp(17px, 1.4vw, 22px); line-height: 1.5; }
.res-point .big b { background: var(--accent); color: var(--accent-ink); padding: 0 .15em; font-weight: 400; }

/* pyramid */
.pyramid { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.tier { height: 0; border-left: solid transparent; border-right: solid transparent; border-bottom-style: solid; }
.platforms { display: flex; flex-wrap: wrap; gap: 14px; margin-top: clamp(44px, 5vw, 70px); align-items: center; }
.plat {
  display: inline-flex; align-items: center; gap: 10px;
  border: 1.5px solid var(--ink); padding: 12px 20px;
  font-family: var(--display); font-size: clamp(16px, 1.5vw, 22px);
  text-transform: uppercase; letter-spacing: 0.01em;
  transition: background .25s, color .25s;
}
.plat:hover { background: var(--ink); color: var(--paper); }
.plat svg { width: 1.05em; height: 1.05em; }
@media (max-width: 820px) { .res-top { grid-template-columns: 1fr; } }

/* ===== WHY US ===== */
.why-grid { display: grid; grid-template-columns: 0.85fr 1.4fr; gap: clamp(30px, 5vw, 80px); align-items: start; }
.cmp { width: 100%; border-collapse: collapse; }
.cmp th, .cmp td { text-align: center; padding: 0; }
.cmp thead th { padding-bottom: 14px; }
.cmp .col-head { font-family: var(--display); text-transform: uppercase; font-size: clamp(15px, 1.3vw, 21px); padding: 16px; letter-spacing: -0.01em; }
.cmp .col-head.us { background: var(--ink); color: var(--paper); }
.cmp .col-head.them { background: var(--paper-2); color: var(--ink-soft); }
.cmp tbody tr { }
.cmp .metric { text-align: left; font-weight: 600; font-size: 15px; padding: 18px 16px 18px 0; color: var(--ink); width: 30%; vertical-align: middle; }
.cmp .v { padding: 14px 16px; font-size: clamp(15px, 1.3vw, 19px); vertical-align: middle; }
.cmp .v.us { background: var(--card); font-weight: 700; font-family: var(--display); font-weight: 400; }
.cmp .v.them { color: var(--ink-faint); }
.cmp tbody tr + tr .v, .cmp tbody tr + tr .metric { border-top: 8px solid var(--paper); }
@media (max-width: 820px) {
  .why-grid { grid-template-columns: 1fr; }
  .cmp .metric { font-size: 13px; }
  .cmp .v { font-size: 14px; }
}

/* ===== CASES ===== */
.cases-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; flex-wrap: wrap; }
.cases-head .lead { max-width: 44ch; }
.carousel-controls { display: flex; gap: 10px; }
.cbtn {
  width: 56px; height: 56px; border: 1.5px solid var(--ink); background: transparent;
  font-size: 20px; cursor: pointer; color: var(--ink);
  display: grid; place-items: center; transition: background .2s, color .2s, transform .1s;
}
.cbtn:hover { background: var(--ink); color: var(--paper); }
.cbtn:active { transform: scale(.94); }
.cbtn:disabled { opacity: .3; cursor: default; }
.cbtn:disabled:hover { background: transparent; color: var(--ink); }

.rail {
  display: flex; gap: 0;
  overflow-x: auto; scroll-snap-type: x mandatory;
  margin-top: clamp(30px, 4vw, 56px);
  scrollbar-width: none;
}
.rail::-webkit-scrollbar { display: none; }

.case {
  scroll-snap-align: start;
  flex: 0 0 min(1180px, 92vw);
  margin-right: 22px;
  padding: clamp(30px, 3.4vw, 60px);
  display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(26px, 3vw, 56px);
  color: var(--case-ink, #fff);
  background: var(--case-bg, #222);
  min-height: 560px;
}
.case:last-child { margin-right: 0; }
.case-info { display: flex; flex-direction: column; }
.case-logo {
  font-family: var(--display); text-transform: lowercase;
  font-size: clamp(34px, 4vw, 64px); line-height: 0.9; letter-spacing: -0.02em;
  margin-bottom: 26px;
}
.case-logo .logo-card {
  display: inline-flex; align-items: center; justify-content: center;
  background: #fff; color: #111; padding: 14px 26px; border-radius: 3px;
}
.case-desc { font-size: clamp(14.5px, 1.05vw, 17px); line-height: 1.55; opacity: 0.92; max-width: 52ch; }
.case-tag { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; opacity: 0.7; font-weight: 700; margin-bottom: 16px; }
.stats { margin-top: auto; padding-top: 30px; display: flex; flex-direction: column; gap: 12px; }
.stat {
  background: var(--card); color: var(--ink);
  border-radius: 999px; padding: 15px 28px;
  font-family: var(--display); font-weight: 400;
  font-size: clamp(15px, 1.25vw, 20px); text-align: center;
  letter-spacing: -0.01em;
}
.stat .u { font-family: var(--sans); font-weight: 600; font-size: 0.82em; }
.case-media { overflow: hidden; border-radius: 2px; min-height: 0; }
.case-media img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
@media (max-width: 860px) {
  .case { grid-template-columns: 1fr; flex-basis: 90vw; }
  .case-media { aspect-ratio: 1 / 1; }
}
.rail-progress { height: 3px; background: var(--rule); margin-top: 26px; position: relative; }
.rail-progress .bar { position: absolute; top: 0; left: 0; height: 100%; background: var(--accent); transition: left .3s, width .3s; }

/* ===== TIMELINE ===== */
.tl-grid { display: grid; grid-template-columns: 1fr 0.9fr; gap: clamp(30px, 5vw, 90px); }
.tl-steps { display: flex; flex-direction: column; }
.tl-step { display: grid; grid-template-columns: auto 1fr; gap: 22px; padding: clamp(20px, 2.4vw, 34px) 0; border-top: 1px solid var(--rule); position: relative; }
.tl-step:last-child { border-bottom: 1px solid var(--rule); }
.tl-step .step-n { font-family: var(--display); font-size: 15px; color: var(--accent); padding-top: 8px; }
.tl-step h4 { font-family: var(--display); font-weight: 400; text-transform: uppercase; font-size: clamp(22px, 2.6vw, 40px); line-height: 0.95; margin: 0 0 8px; letter-spacing: -0.01em; }
.tl-step:hover h4 { color: var(--accent); }
.tl-step p { margin: 0; color: var(--ink-soft); font-size: 15px; max-width: 40ch; }
.tl-aside .h-section { font-size: clamp(40px, 7vw, 120px); margin-bottom: 30px; }
@media (max-width: 860px) { .tl-grid { grid-template-columns: 1fr; } .tl-aside { order: -1; } }

/* ===== CONTACT ===== */
.contact { padding-bottom: clamp(50px, 7vw, 100px); }
.contact-rows { display: flex; flex-direction: column; gap: clamp(14px, 1.6vw, 26px); margin-top: clamp(30px, 4vw, 60px); }
.crow { display: flex; align-items: baseline; gap: clamp(16px, 3vw, 48px); flex-wrap: wrap; border-bottom: 1px solid var(--rule); padding-bottom: clamp(14px, 1.6vw, 26px); }
.crow .k { font-family: var(--display); font-size: clamp(32px, 7vw, 110px); line-height: 0.85; text-transform: uppercase; letter-spacing: -0.02em; }
.crow .val {
  background: var(--card); padding: 14px 26px; font-size: clamp(15px, 1.6vw, 24px);
  letter-spacing: 0.02em; transition: background .25s, color .25s;
}
.crow a.val:hover { background: var(--accent); color: var(--accent-ink); }
.contact .h-section { margin-bottom: 12px; }

footer.foot {
  border-top: 2px solid var(--ink);
  padding: 26px var(--gutter);
  display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap;
  font-size: 12px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-soft);
}
