/* ============================================================
   HOME PAGE STYLES
   ============================================================ */

/* HERO */
.home-hero {
  color: #fff;
  padding-top: clamp(var(--space-20), 10vw, var(--space-24));
  position: relative;
  overflow: hidden;
  background: url('img/hero-bg.png') center center / cover no-repeat;
}
.home-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(7,21,41,0.92) 0%, rgba(13,45,82,0.80) 55%, rgba(15,58,110,0.55) 100%);
  z-index: 0;
}
.home-hero-bg { display: none; }
.home-hero-inner { position: relative; z-index: 1; padding-bottom: clamp(var(--space-16), 8vw, var(--space-20)); }
.home-hero-top { margin-bottom: var(--space-8); }
.hero-sector-pills { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.hsp { padding: .3em .9em; border-radius: var(--radius-full); font-size: var(--text-xs); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; border: 1px solid; }
.hsp-it { background: rgba(37,99,235,.2); border-color: rgba(96,165,250,.4); color: #93c5fd; }
.hsp-dc { background: rgba(109,40,217,.2); border-color: rgba(167,139,250,.4); color: #c4b5fd; }
.hsp-re { background: rgba(4,120,87,.2);   border-color: rgba(52,211,153,.4); color: #6ee7b7; }
.home-hero-h1 { font-size: var(--text-hero); font-weight: 900; line-height: 1.05; margin-bottom: var(--space-6); max-width: 14ch; }
.hero-accent { color: var(--color-accent); }
.home-hero-sub { font-size: var(--text-lg); color: rgba(255,255,255,.7); max-width: 52ch; line-height: 1.65; margin-bottom: var(--space-10); }
.home-hero-cta { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* Hero sector strip */
.home-hero-sectors { position: relative; z-index: 1; border-top: 1px solid rgba(255,255,255,.1); background: rgba(0,0,0,.25); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.hhs-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0; }
.hhs-card { display: flex; align-items: center; gap: var(--space-4); padding: var(--space-6) var(--space-5); border-right: 1px solid rgba(255,255,255,.08); transition: background var(--trans); cursor: pointer; }
.hhs-card:last-child { border-right: none; }
.hhs-card:hover { background: rgba(255,255,255,.06); }
.hhs-icon { width: 40px; height: 40px; border-radius: var(--radius-md); flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.hhs-name { font-family: var(--font-display); font-weight: 700; font-size: var(--text-sm); color: #fff; margin-bottom: 2px; }
.hhs-desc { font-size: var(--text-xs); color: rgba(255,255,255,.45); }
.hhs-arrow { color: rgba(255,255,255,.3); margin-left: auto; flex-shrink: 0; transition: transform var(--trans), color var(--trans); }
.hhs-card:hover .hhs-arrow { transform: translateX(4px); color: var(--color-accent); }

/* STATS BAR */
.stats-bar { background: var(--color-primary); color: #fff; padding-block: clamp(var(--space-8), 4vw, var(--space-12)); }
.stats-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--space-8); }
.stat-item { text-align: center; }
.stat-big { font-family: var(--font-display); font-size: clamp(2rem, 3vw, 3rem); font-weight: 900; color: var(--color-accent); display: block; line-height: 1; margin-bottom: var(--space-2); }
.stat-desc { font-size: var(--text-sm); color: rgba(255,255,255,.65); line-height: 1.4; }

/* WHY SECTION */
.why-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(var(--space-12), 8vw, var(--space-24)); align-items: start; }
.why-grid h2 { font-size: var(--text-2xl); font-weight: 900; margin-bottom: var(--space-5); }
.why-grid > div > p { font-size: var(--text-base); color: var(--color-text-muted); max-width: 50ch; line-height: 1.7; }
.why-points { display: flex; flex-direction: column; gap: var(--space-5); }
.why-point { display: flex; gap: var(--space-5); align-items: flex-start; padding: var(--space-5); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); transition: box-shadow var(--trans); }
.why-point:hover { box-shadow: var(--shadow-md); }
[data-theme=dark] .why-point { background: var(--color-surface-2); }
.why-point h4 { font-size: var(--text-base); font-weight: 700; margin-bottom: var(--space-2); }
.why-point p  { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.6; }

/* SECTORS STRIP */
.sectors-strip { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-6); }
.sector-strip-card { background: var(--color-surface); border-radius: var(--radius-xl); padding: var(--space-8); border: 1px solid var(--color-border); box-shadow: var(--shadow-sm); display: flex; flex-direction: column; gap: var(--space-4); transition: box-shadow var(--trans), transform var(--trans); }
.sector-strip-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.sector-strip-card h3 { font-size: var(--text-lg); font-weight: 800; }
.sector-strip-card p  { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; flex-grow: 1; }
.ssc-top { display: flex; align-items: center; gap: var(--space-4); }
.ssc-img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  margin-top: var(--space-2);
}

/* CASE STUDIES */
.cs-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-6); }
.cs-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-sm); transition: box-shadow var(--trans), transform var(--trans); display: flex; flex-direction: column; }
.cs-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-4px); }
[data-theme=dark] .cs-card { background: var(--color-surface-2); }
.cs-header { padding: var(--space-6); display: flex; align-items: center; justify-content: space-between; }
.cs-tag { font-size: var(--text-xs); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.cs-outcome-pill { padding: .3em .8em; border-radius: var(--radius-full); font-size: var(--text-xs); font-weight: 700; }
.cs-body { padding: 0 var(--space-6) var(--space-6); flex-grow: 1; display: flex; flex-direction: column; gap: var(--space-4); }
.cs-title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 800; line-height: 1.2; }
.cs-challenge-label { font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--color-text-faint); margin-bottom: var(--space-2); }
.cs-challenge { font-size: var(--text-sm); color: var(--color-text-muted); line-height: 1.65; }
.cs-results { display: flex; gap: var(--space-4); margin-top: auto; padding-top: var(--space-5); border-top: 1px solid var(--color-border); }
.cs-result { display: flex; flex-direction: column; gap: 2px; }
.cs-result-num { font-family: var(--font-display); font-weight: 900; font-size: var(--text-lg); }
.cs-result-label { font-size: var(--text-xs); color: var(--color-text-faint); }

/* LOGO STRIP */
.logo-strip { padding-block: clamp(var(--space-10), 5vw, var(--space-16)); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.logo-strip-label { text-align: center; font-size: var(--text-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--color-text-faint); margin-bottom: var(--space-8); }
.logo-grid { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: var(--space-6) var(--space-10); }
.industry-badge { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-5); border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); font-size: var(--text-sm); font-weight: 600; color: var(--color-text-muted); white-space: nowrap; transition: border-color var(--trans), color var(--trans); }
.industry-badge:hover { border-color: var(--color-primary); color: var(--color-text); }

/* TESTIMONIALS */
.testimonials-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-6); }
.tcard { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: var(--space-7); display: flex; flex-direction: column; gap: var(--space-5); box-shadow: var(--shadow-sm); transition: box-shadow var(--trans); }
.tcard:hover { box-shadow: var(--shadow-md); }
[data-theme=dark] .tcard { background: var(--color-surface-2); }
.tcard-stars { display: flex; gap: 3px; }
.tcard-stars span { color: var(--color-accent); font-size: 1rem; }
.tcard-quote { font-size: var(--text-base); color: var(--color-text); line-height: 1.7; font-style: italic; flex-grow: 1; }
.tcard-author { display: flex; align-items: center; gap: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--color-border); }
.tcard-avatar { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 800; font-size: var(--text-sm); color: #fff; flex-shrink: 0; }
.tcard-name { font-weight: 700; font-size: var(--text-sm); margin-bottom: 2px; }
.tcard-role { font-size: var(--text-xs); color: var(--color-text-faint); }
.tcard-sector { display: inline-block; padding: .2em .6em; border-radius: var(--radius-full); font-size: 10px; font-weight: 700; margin-top: 3px; }

/* CTA BANNER */
.cta-banner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-8); flex-wrap: wrap; }
.cta-banner h2 { font-size: var(--text-xl); font-weight: 900; color: #fff; margin-bottom: var(--space-3); }
.cta-banner p  { font-size: var(--text-base); color: rgba(255,255,255,.7); }
.cta-banner-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; flex-shrink: 0; }

@media(max-width:900px) {
  .hhs-grid { grid-template-columns: 1fr; }
  .hhs-card { border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); }
  .hhs-card:last-child { border-bottom: none; }
  .stats-grid { grid-template-columns: repeat(2,1fr); }
  .why-grid { grid-template-columns: 1fr; }
  .sectors-strip { grid-template-columns: 1fr; }
  .cs-grid { grid-template-columns: 1fr; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .cta-banner { flex-direction: column; align-items: flex-start; }
}
@media(max-width:600px) {
  .home-hero-h1 { max-width: none; }
  .stats-grid { grid-template-columns: repeat(2,1fr); }
}
