/* ============================================================
   OLD COUNTRY AI — Main Stylesheet
   Matching WordPress/Elementor look & feel
   ============================================================ */

/* --- RESET & VARIABLES --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:         #f7f8fa;
  --bg-alt:     #ffffff;
  --text:       #1a1a2e;
  --text-light: #ffffff;
  --muted:      #5a6272;
  --accent:     #48abd9;
  --accent-hover:#3a97c3;
  --accent2:    #0693e3;
  --accent-dark:#1a1a2e;
  --gradient:   linear-gradient(135deg, #0693e3 0%, #9b51e0 100%);
  --gradient-warm: linear-gradient(135deg, #48abd9 0%, #0693e3 100%);
  --card:       #ffffff;
  --border:     #e8eaef;
  --shadow:     0 2px 8px rgba(0,0,0,.06);
  --shadow-md:  0 5px 20px rgba(0,0,0,.08);
  --shadow-lg:  0 5px 30px rgba(0,0,0,.12);
  --radius:     12px;
  --radius-sm:  8px;
  --radius-lg:  16px;
  /* Fonts matching WP site */
  --font-display:  'Cormorant', serif;
  --font-heading:  'Rajdhani', sans-serif;
  --font-body:     'Poppins', sans-serif;
  --font-accent:   'Red Hat Display', sans-serif;
  --max-w:      1120px;
  --nav-h:      80px;
}

html{
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

body{
  font-family:var(--font-body);
  font-size:1rem;
  font-weight:300;
  line-height:1.75;
  color:var(--text);
  background:var(--bg);
}

a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-hover)}

img{max-width:100%;display:block}
address{font-style:normal}

/* --- CONTAINER --- */
.container{
  width:100%;
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 2rem;
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:var(--nav-h);
}

.nav__logo{display:flex;align-items:center;text-decoration:none}
.nav__logo-img{height:42px;width:auto}

.nav__menu{
  display:flex;
  align-items:center;
  gap:2.5rem;
}

.nav__links{
  list-style:none;
  display:flex;
  gap:2rem;
}

.nav__link{
  font-family:var(--font-heading);
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:var(--muted);
  transition:color .2s;
  position:relative;
}
.nav__link:hover,
.nav__link--active{color:var(--text)}
.nav__link--active::after{
  content:'';
  position:absolute;
  bottom:-6px;left:0;right:0;
  height:2px;
  background:var(--accent);
  border-radius:1px;
}

.nav__toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:4px;
}
.nav__toggle-bar{
  display:block;
  width:24px;height:2px;
  background:var(--text);
  border-radius:2px;
  transition:transform .3s, opacity .3s;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-family:var(--font-heading);
  font-weight:600;
  font-size:.9rem;
  letter-spacing:.03em;
  text-transform:uppercase;
  border-radius:var(--radius-sm);
  padding:.75rem 1.75rem;
  transition:all .25s;
  cursor:pointer;
  text-decoration:none;
  border:2px solid transparent;
}

.btn--primary{
  background:var(--accent);
  color:#fff;
  border-color:var(--accent);
  box-shadow:0 4px 14px rgba(72,171,217,.3);
}
.btn--primary:hover{
  background:var(--accent-hover);
  border-color:var(--accent-hover);
  color:#fff;
  box-shadow:0 6px 20px rgba(72,171,217,.4);
  transform:translateY(-1px);
}

.btn--secondary{
  background:transparent;
  color:var(--accent);
  border-color:var(--accent);
}
.btn--secondary:hover{
  background:var(--accent);
  color:#fff;
}

.btn--outline-light{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.4);
}
.btn--outline-light:hover{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.7);
  color:#fff;
}

.btn--text{
  background:none;
  padding:.75rem 0;
  color:var(--accent);
  border:none;
  text-transform:none;
}
.btn--text:hover{color:var(--accent-hover)}

.btn--sm{padding:.5rem 1.2rem;font-size:.82rem}
.btn--lg{padding:.9rem 2.25rem;font-size:.95rem}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding:clamp(5rem,12vw,10rem) 0 clamp(4rem,8vw,7rem);
  overflow:hidden;
}
.hero--page{
  padding:clamp(4rem,8vw,7rem) 0 clamp(3rem,6vw,5rem);
}
.hero--compact{
  padding:clamp(3.5rem,7vw,6rem) 0;
}

.hero__bg-wrap{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero__bg-img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 30%;
}
.hero__bg-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(26,26,46,.75) 0%, rgba(6,147,227,.45) 100%);
}
.hero__bg-overlay--dark{
  background:linear-gradient(135deg, rgba(26,26,46,.82) 0%, rgba(6,147,227,.35) 100%);
}

.hero__inner{
  position:relative;
  z-index:1;
}

.hero__headline{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(2.25rem,5vw,3.75rem);
  line-height:1.1;
  max-width:820px;
  letter-spacing:-.01em;
  color:#fff;
}

.hero__sub{
  margin-top:1.5rem;
  font-size:clamp(1rem,1.6vw,1.15rem);
  font-weight:300;
  color:rgba(255,255,255,.8);
  max-width:680px;
  line-height:1.8;
}
.hero__sub--light{
  color:rgba(255,255,255,.75);
}

.hero__bullets{
  list-style:none;
  margin-top:1.75rem;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.hero__bullets li{
  position:relative;
  padding-left:1.5rem;
  font-weight:400;
  font-size:.95rem;
  color:rgba(255,255,255,.9);
}
.hero__bullets li::before{
  content:'';
  position:absolute;
  left:0;top:.55em;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 8px rgba(72,171,217,.5);
}

.hero__actions{
  margin-top:2.25rem;
  display:flex;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
}

/* ============================================================
   PROOF BAR
   ============================================================ */
.proof-bar{
  border-bottom:1px solid var(--border);
  padding:1.1rem 0;
  background:var(--card);
}
.proof-bar .container{
  display:flex;
  align-items:center;
  gap:1.25rem;
  flex-wrap:wrap;
}
.proof-bar__label{
  font-family:var(--font-heading);
  font-size:.75rem;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
  white-space:nowrap;
}
.proof-bar__chips{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
}
.chip{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.78rem;
  font-weight:500;
  padding:.35rem .85rem;
  background:rgba(72,171,217,.08);
  color:var(--accent2);
  border-radius:100px;
  white-space:nowrap;
}
.chip i{font-size:.7rem}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{
  padding:clamp(4rem,9vw,7rem) 0;
}
.section--alt{
  background:var(--bg-alt);
}

.section__eyebrow{
  display:inline-block;
  font-family:var(--font-heading);
  font-size:.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:var(--accent);
  margin-bottom:.75rem;
}
.section__eyebrow--light{
  color:rgba(255,255,255,.6);
}

.section__header{
  margin-bottom:2.5rem;
}

.section__title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(1.6rem,3.2vw,2.5rem);
  line-height:1.15;
  max-width:720px;
  letter-spacing:-.01em;
  color:var(--text);
}

.section__subtitle{
  margin-top:.75rem;
  color:var(--muted);
  font-size:1.05rem;
  max-width:600px;
  font-weight:300;
}

.section__body{
  margin-top:1rem;
  color:var(--muted);
  font-size:1.05rem;
  max-width:640px;
  font-weight:300;
}

/* ============================================================
   SCENE BANNER (full-bleed image)
   ============================================================ */
.scene-banner{
  width:100%;
  max-height:420px;
  overflow:hidden;
}
.scene-banner--short{
  max-height:340px;
}
.scene-banner img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 25%;
}

/* ============================================================
   SPLIT (2 COLUMN)
   ============================================================ */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3.5rem;
  align-items:start;
}
.split__left p{
  margin-top:1rem;
  color:var(--muted);
  line-height:1.85;
  font-weight:300;
}
.split__right{
  display:flex;
  flex-direction:column;
  gap:1.25rem;
}

/* ============================================================
   GRID
   ============================================================ */
.grid{
  display:grid;
  gap:1.5rem;
  margin-top:2rem;
}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}

/* ============================================================
   CARDS
   ============================================================ */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem;
  transition:box-shadow .3s, transform .3s;
}
.card:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-3px);
}

.card--accent-border{
  border-left:3px solid var(--accent);
}

.card__icon-wrap{
  width:44px;height:44px;
  border-radius:10px;
  background:rgba(72,171,217,.1);
  color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
  margin-bottom:1rem;
}
.card__icon-wrap--lg{
  width:56px;height:56px;
  font-size:1.4rem;
}

.card__title{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:1.1rem;
  margin-bottom:.5rem;
  letter-spacing:.01em;
}

.card--pillar{
  text-align:center;
  padding:2.5rem 2rem;
}
.card--pillar .card__icon-wrap{
  margin:0 auto 1.25rem;
}

.card p{
  color:var(--muted);
  font-weight:300;
  font-size:.95rem;
  line-height:1.7;
}

/* PROFILE CARDS (home) */
.card--profile{
  text-align:center;
  padding:2.5rem 2rem;
}
.card--profile .card__headshot{
  width:120px;height:120px;
  border-radius:50%;
  object-fit:cover;
  object-position:center top;
  margin:0 auto 1.25rem;
  border:3px solid var(--border);
}
.card--profile .card__title{
  color:var(--accent);
  font-family:var(--font-display);
  font-size:1.3rem;
}

/* TEAM CARDS (team page — featured) */
.team-grid--featured{
  display:flex;
  flex-direction:column;
  gap:2rem;
  margin-top:2rem;
}
.card--team{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:2.5rem;
  padding:2.5rem;
  align-items:center;
}
.card__team-media{
  display:flex;
  justify-content:center;
}
.card--team .card__headshot{
  width:220px;height:220px;
  border-radius:var(--radius);
  object-fit:cover;
  object-position:center top;
}
.card__team-body{}
.card__name{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.5rem;
  color:var(--text);
}
.card__role{
  display:inline-block;
  font-family:var(--font-heading);
  font-size:.8rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--accent);
  margin:.25rem 0 .75rem;
}
.card__team-body p{
  color:var(--muted);
  font-size:.95rem;
  font-weight:300;
  line-height:1.8;
}
.card__social{
  display:inline-flex;
  align-items:center;justify-content:center;
  width:36px;height:36px;
  border-radius:50%;
  background:var(--accent);
  color:#fff;
  font-size:.9rem;
  margin-top:.75rem;
  transition:background .2s, transform .2s;
}
.card__social:hover{
  background:var(--accent-hover);
  color:#fff;
  transform:scale(1.1);
}

/* TEAM CARDS (compact grid) */
.team-grid--compact{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.5rem;
  margin-top:3rem;
}
.card--team-sm{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem 1.5rem;
  text-align:center;
  transition:box-shadow .3s, transform .3s;
}
.card--team-sm:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-3px);
}
.card__headshot-sm{
  width:100px;height:100px;
  border-radius:50%;
  object-fit:cover;
  object-position:center top;
  margin:0 auto 1rem;
  border:3px solid var(--border);
}
.card--team-sm .card__name{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.15rem;
}
.card--team-sm .card__role{
  display:block;
  margin:.15rem 0 .75rem;
}
.card--team-sm p{
  color:var(--muted);
  font-size:.85rem;
  font-weight:300;
  line-height:1.7;
}

/* ============================================================
   TIMELINE
   ============================================================ */
.timeline{
  margin-top:2.5rem;
  position:relative;
  padding-left:3.5rem;
}
.timeline::before{
  content:'';
  position:absolute;
  left:17px;top:0;bottom:0;
  width:2px;
  background:var(--border);
}

.timeline__step{
  display:flex;
  gap:1.5rem;
  padding-bottom:2.25rem;
  position:relative;
}
.timeline__step:last-child{padding-bottom:0}

.timeline__num{
  position:absolute;
  left:-3.5rem;
  width:36px;height:36px;
  border-radius:50%;
  background:var(--gradient-warm);
  color:#fff;
  font-family:var(--font-heading);
  font-weight:700;
  font-size:.9rem;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  z-index:1;
  box-shadow:0 3px 10px rgba(72,171,217,.3);
}

.timeline__title{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:1.05rem;
  margin-bottom:.25rem;
}

.timeline__step p{
  color:var(--muted);
  font-size:.95rem;
  font-weight:300;
}

/* ============================================================
   CALLOUT
   ============================================================ */
.callout{
  margin-top:3rem;
  background:linear-gradient(135deg, rgba(72,171,217,.06) 0%, rgba(155,81,224,.06) 100%);
  border:1px solid rgba(72,171,217,.15);
  border-radius:var(--radius);
  padding:2.25rem;
}
.callout__title{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:1.15rem;
  color:var(--accent);
  margin-bottom:.5rem;
  display:flex;
  align-items:center;
  gap:.5rem;
}
.callout p{
  color:var(--muted);
  font-weight:300;
}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{
  padding:clamp(3.5rem,7vw,6rem) 0;
  background:var(--text);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-band::before{
  content:'';
  position:absolute;
  top:-50%;right:-20%;
  width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(72,171,217,.15) 0%,transparent 70%);
  pointer-events:none;
}
.cta-band__headline{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(1.5rem,3vw,2.15rem);
  color:#fff;
  position:relative;
}
.cta-band__body{
  margin-top:.75rem;
  color:rgba(255,255,255,.6);
  font-size:1.05rem;
  font-weight:300;
  position:relative;
}
.cta-band__actions{
  margin-top:1.75rem;
  display:flex;
  justify-content:center;
  gap:1rem;
  flex-wrap:wrap;
  position:relative;
}

/* ============================================================
   CHECK LIST
   ============================================================ */
.check-list{
  list-style:none;
  margin-top:1.5rem;
  display:flex;
  flex-direction:column;
  gap:.85rem;
  max-width:600px;
}
.check-list li{
  padding-left:2rem;
  position:relative;
  font-size:1.05rem;
  font-weight:300;
}
.check-list li::before{
  content:'\f00c';
  font-family:'Font Awesome 6 Free';
  font-weight:900;
  position:absolute;
  left:0;
  color:var(--accent);
  font-size:.85rem;
}

/* ============================================================
   ACCORDION
   ============================================================ */
.accordion{
  margin-top:1.5rem;
  max-width:700px;
}
.accordion__item{
  border-bottom:1px solid var(--border);
}
.accordion__trigger{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:none;
  border:none;
  padding:1.25rem 0;
  font-size:1.05rem;
  font-weight:500;
  font-family:var(--font-body);
  color:var(--text);
  cursor:pointer;
  text-align:left;
  transition:color .2s;
}
.accordion__trigger i{
  color:var(--accent);
  margin-right:.6rem;
}
.accordion__trigger:hover{color:var(--accent)}
.accordion__icon{
  font-size:1.3rem;
  font-weight:300;
  transition:transform .3s;
  color:var(--muted);
}
.accordion__item.is-open .accordion__icon{
  transform:rotate(45deg);
}
.accordion__content{
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease, padding .35s ease;
}
.accordion__item.is-open .accordion__content{
  max-height:200px;
  padding-bottom:1.25rem;
}
.accordion__content p{
  color:var(--muted);
  font-weight:300;
  padding-left:1.6rem;
}

/* ============================================================
   SLIDER WIDGET
   ============================================================ */
.slider-widget{
  max-width:600px;
  margin:2rem auto 0;
  text-align:center;
}
.slider-widget__labels{
  display:flex;
  justify-content:space-between;
  font-family:var(--font-heading);
  font-size:.78rem;
  font-weight:600;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.03em;
  margin-bottom:1rem;
}
.slider-widget__input{
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height:6px;
  border-radius:3px;
  background:var(--border);
  outline:none;
  cursor:pointer;
}
.slider-widget__input::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width:26px;height:26px;
  border-radius:50%;
  background:var(--gradient-warm);
  cursor:pointer;
  box-shadow:0 3px 10px rgba(72,171,217,.35);
  transition:transform .15s;
}
.slider-widget__input::-webkit-slider-thumb:hover{
  transform:scale(1.15);
}
.slider-widget__input::-moz-range-thumb{
  width:26px;height:26px;
  border-radius:50%;
  background:var(--accent);
  cursor:pointer;
  border:none;
  box-shadow:0 3px 10px rgba(72,171,217,.35);
}
.slider-widget__desc{
  margin-top:1.5rem;
  min-height:3.5rem;
}
.slider-widget__desc p{
  color:var(--muted);
  font-size:.95rem;
  font-weight:300;
  transition:opacity .2s;
}

/* ============================================================
   COMPARISON TABLE
   ============================================================ */
.comparison-table{
  margin-top:2rem;
  overflow-x:auto;
}
.comparison-table table{
  width:100%;
  border-collapse:collapse;
  font-size:.95rem;
}
.comparison-table th,
.comparison-table td{
  padding:1rem 1.5rem;
  text-align:left;
  border-bottom:1px solid var(--border);
}
.comparison-table thead th{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--muted);
  background:var(--bg);
}
.comparison-table__highlight{
  color:var(--accent) !important;
}
.comparison-table tbody td:first-child{
  font-weight:500;
  font-size:.85rem;
  color:var(--muted);
  font-family:var(--font-heading);
  text-transform:uppercase;
  letter-spacing:.03em;
}
.comparison-table tbody td:last-child{
  font-weight:600;
  color:var(--accent);
}
.comparison-table tbody tr:hover{
  background:rgba(72,171,217,.03);
}

/* ============================================================
   CONTACT GRID
   ============================================================ */
.contact-grid .card{
  text-align:center;
  padding:2.5rem 2rem;
}
.contact-grid .card__icon-wrap{
  margin:0 auto 1rem;
}
.contact-grid .card__title{
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  color:var(--muted);
  margin-bottom:.75rem;
}

.link{
  color:var(--accent);
  font-weight:500;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--text);
  color:rgba(255,255,255,.65);
  padding:4rem 0 1.5rem;
  font-size:.9rem;
}

.footer__grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;
}

.footer__logo-link{display:inline-block}
.footer__logo-img{
  height:48px;
  width:auto;
  filter:brightness(0) invert(1);
}

.footer__tagline{
  margin-top:1rem;
  font-size:.9rem;
  font-weight:300;
  color:rgba(255,255,255,.4);
}

.footer__social{
  display:flex;
  gap:.75rem;
  margin-top:1rem;
}
.footer__social a{
  width:36px;height:36px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.6);
  display:flex;align-items:center;justify-content:center;
  font-size:.85rem;
  transition:all .2s;
}
.footer__social a:hover{
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}

.footer__heading{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:rgba(255,255,255,.35);
  margin-bottom:1.25rem;
}

.footer__links ul{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.footer__links a{
  color:rgba(255,255,255,.6);
  font-size:.9rem;
  font-weight:300;
}
.footer__links a:hover{color:#fff}

.footer__contact a{
  color:rgba(255,255,255,.6);
  font-weight:300;
}
.footer__contact a:hover{color:#fff}
.footer__contact p{margin-bottom:.25rem}
.footer__contact address{
  margin-top:.5rem;
  line-height:1.7;
}

.footer__bottom{
  margin-top:3rem;
  padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.08);
  font-size:.78rem;
  color:rgba(255,255,255,.3);
}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .7s cubic-bezier(.23,1,.32,1), transform .7s cubic-bezier(.23,1,.32,1);
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

@media (prefers-reduced-motion: reduce){
  .reveal{
    opacity:1;
    transform:none;
    transition:none;
  }
}

/* ============================================================
   FEATURE SHOWCASE (Platform page — alternating 2-col layouts)
   ============================================================ */
.feature-showcase{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}
.feature-showcase--reverse{
  direction:rtl;
}
.feature-showcase--reverse > *{
  direction:ltr;
}
.feature-showcase__content{
  display:flex;
  flex-direction:column;
}
.feature-showcase__content .section__body{
  max-width:none;
}
.feature-showcase__list{
  list-style:none;
  margin-top:1.75rem;
  display:flex;
  flex-direction:column;
  gap:.85rem;
}
.feature-showcase__list li{
  display:flex;
  align-items:flex-start;
  gap:.75rem;
  font-size:.95rem;
  font-weight:300;
  color:var(--muted);
  line-height:1.6;
}
.feature-showcase__list li i{
  color:var(--accent);
  font-size:.85rem;
  margin-top:.3rem;
  flex-shrink:0;
}
.feature-showcase__list li strong{
  font-weight:600;
  color:var(--text);
}
.feature-showcase__visual{
  display:flex;
  align-items:center;
  justify-content:center;
}

/* ============================================================
   PIPELINE FLOW (CI/CD visual)
   ============================================================ */
.pipeline-flow{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0;
  width:100%;
  max-width:280px;
}
.pipeline-flow__step{
  display:flex;
  align-items:center;
  gap:1rem;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1rem 1.5rem;
  width:100%;
  font-size:.9rem;
  font-weight:500;
  color:var(--text);
  transition:box-shadow .3s, transform .3s;
}
.pipeline-flow__step:hover{
  box-shadow:var(--shadow-md);
  transform:translateX(4px);
}
.pipeline-flow__step--final{
  background:var(--text);
  color:#fff;
  border-color:var(--text);
}
.pipeline-flow__icon{
  width:40px;
  height:40px;
  border-radius:10px;
  background:rgba(72,171,217,.1);
  color:var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1rem;
  flex-shrink:0;
}
.pipeline-flow__step--final .pipeline-flow__icon{
  background:rgba(72,171,217,.25);
  color:#fff;
}
.pipeline-flow__connector{
  display:flex;
  align-items:center;
  justify-content:center;
  height:28px;
  color:var(--accent);
  font-size:.7rem;
  opacity:.5;
}

/* ============================================================
   DOC PREVIEW (Documentation visual)
   ============================================================ */
.doc-preview{
  background:var(--text);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  max-width:380px;
  width:100%;
}
.doc-preview__header{
  display:flex;
  align-items:center;
  gap:6px;
  padding:.75rem 1.25rem;
  background:rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.doc-preview__dot{
  width:10px;
  height:10px;
  border-radius:50%;
}
.doc-preview__dot--red{background:#ff5f57}
.doc-preview__dot--yellow{background:#ffbd2e}
.doc-preview__dot--green{background:#28c840}
.doc-preview__title{
  margin-left:.5rem;
  font-family:var(--font-heading);
  font-size:.75rem;
  color:rgba(255,255,255,.5);
  letter-spacing:.02em;
}
.doc-preview__badge{
  margin-left:auto;
  font-size:.65rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.05em;
  padding:.2rem .6rem;
  border-radius:100px;
  background:rgba(72,171,217,.2);
  color:var(--accent);
}
.doc-preview__body{
  padding:1.25rem;
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
.doc-preview__line{
  font-family:'Poppins', monospace;
  font-size:.78rem;
  color:rgba(255,255,255,.6);
  font-weight:300;
  padding-left:.5rem;
}
.doc-preview__line--heading{
  font-weight:600;
  color:#fff;
  font-size:.9rem;
  padding-left:0;
  margin-bottom:.25rem;
}
.doc-preview__line--sub{
  font-weight:500;
  color:rgba(255,255,255,.8);
  font-size:.82rem;
  padding-left:0;
  margin-top:.5rem;
}
.doc-preview__line--muted{
  color:rgba(255,255,255,.3);
  font-size:.72rem;
  margin-top:.5rem;
}
.doc-preview__line--accent{
  color:var(--accent);
  font-weight:500;
}

/* ============================================================
   MODERNIZATION VISUAL (Tech debt)
   ============================================================ */
.modernization-visual{
  display:flex;
  align-items:center;
  gap:1.5rem;
  width:100%;
  justify-content:center;
}
.modernization-visual__before,
.modernization-visual__after{
  display:flex;
  flex-direction:column;
  gap:.75rem;
  align-items:center;
}
.modernization-visual__label{
  font-family:var(--font-heading);
  font-size:.7rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--muted);
}
.modernization-visual__block{
  border-radius:var(--radius-sm);
  padding:1.25rem;
  text-align:center;
  font-size:.8rem;
  font-weight:500;
}
.modernization-visual__block--mono{
  background:rgba(220,53,69,.08);
  border:1px solid rgba(220,53,69,.2);
  color:#dc3545;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.5rem;
  padding:1.5rem 2rem;
}
.modernization-visual__block--mono i{
  font-size:1.8rem;
  opacity:.7;
}
.modernization-visual__block--mono small{
  font-size:.7rem;
  font-weight:300;
  color:var(--muted);
}
.modernization-visual__arrow{
  font-size:1.5rem;
  color:var(--accent);
  flex-shrink:0;
}
.modernization-visual__services{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.5rem;
}
.modernization-visual__block--svc{
  background:rgba(72,171,217,.08);
  border:1px solid rgba(72,171,217,.2);
  color:var(--accent2);
  display:flex;
  align-items:center;
  gap:.5rem;
  padding:.75rem 1rem;
  font-size:.78rem;
}
.modernization-visual__block--svc i{
  font-size:.9rem;
}

/* ============================================================
   COVERAGE METER (Testing visual)
   ============================================================ */
.coverage-meter{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2rem;
  width:100%;
  max-width:320px;
}
.coverage-meter__ring{
  position:relative;
  width:160px;
  height:160px;
}
.coverage-meter__ring svg{
  width:100%;
  height:100%;
}
.coverage-meter__value{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-heading);
  font-size:2rem;
  font-weight:700;
  color:var(--text);
}
.coverage-meter__breakdown{
  width:100%;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.coverage-meter__item{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:.75rem;
  align-items:center;
  font-size:.82rem;
  font-weight:500;
  color:var(--muted);
}
.coverage-meter__bar{
  height:6px;
  border-radius:3px;
  background:var(--gradient-warm);
  display:block;
}

/* ============================================================
   CARD VARIANTS (Platform page)
   ============================================================ */
.card--feature{
  padding:2.25rem;
}
.card--feature .card__feature-list{
  list-style:none;
  margin-top:1.25rem;
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
.card--feature .card__feature-list li{
  font-size:.85rem;
  font-weight:400;
  color:var(--muted);
  padding-left:1.4rem;
  position:relative;
}
.card--feature .card__feature-list li::before{
  content:'\f00c';
  font-family:'Font Awesome 6 Free';
  font-weight:900;
  position:absolute;
  left:0;
  color:var(--accent);
  font-size:.7rem;
}

.card--outcome{
  padding:2.25rem;
}
.card--outcome .card__highlights{
  margin-top:1.25rem;
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
}
.card__highlight-item{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  font-size:.78rem;
  font-weight:500;
  padding:.35rem .85rem;
  background:rgba(72,171,217,.06);
  color:var(--accent2);
  border-radius:100px;
  white-space:nowrap;
}
.card__highlight-item i{
  font-size:.65rem;
}

/* ============================================================
   TRUST TIERS (Destruction protection)
   ============================================================ */
.trust-tiers{
  display:flex;
  flex-direction:column;
  gap:1rem;
  margin-top:1.75rem;
}
.trust-tier{
  display:flex;
  align-items:flex-start;
  gap:1rem;
}
.trust-tier__icon{
  width:36px;
  height:36px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.85rem;
  flex-shrink:0;
}
.trust-tier__icon--green{
  background:rgba(40,200,64,.12);
  color:#28c840;
}
.trust-tier__icon--yellow{
  background:rgba(255,189,46,.12);
  color:#e6a800;
}
.trust-tier__icon--red{
  background:rgba(255,95,87,.12);
  color:#ff5f57;
}
.trust-tier__title{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:.9rem;
  margin-bottom:.15rem;
}
.trust-tier p{
  font-size:.85rem;
  font-weight:300;
  color:var(--muted);
}

/* ============================================================
   PROTECTION GRID (Infrastructure safety visual)
   ============================================================ */
.protection-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.75rem;
  width:100%;
  max-width:360px;
}
.protection-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:1.25rem;
  text-align:center;
  transition:box-shadow .3s, transform .3s;
}
.protection-card:hover{
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}
.protection-card i{
  font-size:1.3rem;
  color:var(--accent);
  margin-bottom:.5rem;
  display:block;
}
.protection-card h4{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:.82rem;
  margin-bottom:.25rem;
  letter-spacing:.01em;
}
.protection-card p{
  font-size:.72rem;
  font-weight:300;
  color:var(--muted);
  line-height:1.5;
}

/* ============================================================
   INTEGRATION VISUAL (Project management hub-spoke)
   ============================================================ */
.integration-visual{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:280px;
}
.integration-visual__hub{
  position:relative;
  width:280px;
  height:280px;
}
.integration-visual__center{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:90px;
  height:90px;
  border-radius:50%;
  background:var(--gradient);
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.25rem;
  font-size:1.4rem;
  box-shadow:0 5px 25px rgba(6,147,227,.35);
  z-index:2;
}
.integration-visual__center span{
  font-family:var(--font-heading);
  font-size:.65rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.integration-visual__spoke{
  position:absolute;
  width:56px;
  height:56px;
  border-radius:50%;
  background:var(--card);
  border:2px solid var(--border);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:.15rem;
  font-size:1.1rem;
  color:var(--accent);
  z-index:1;
  box-shadow:var(--shadow);
  transition:box-shadow .3s, transform .3s;
}
.integration-visual__spoke:hover{
  box-shadow:var(--shadow-lg);
  transform:scale(1.1);
}
.integration-visual__spoke span{
  font-family:var(--font-heading);
  font-size:.5rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.03em;
  color:var(--muted);
}
.integration-visual__spoke--1{top:8%;left:50%;transform:translateX(-50%)}
.integration-visual__spoke--2{top:50%;right:4%;transform:translateY(-50%)}
.integration-visual__spoke--3{bottom:8%;left:50%;transform:translateX(-50%)}
.integration-visual__spoke--4{top:50%;left:4%;transform:translateY(-50%)}

.integration-visual__spoke--1:hover{transform:translateX(-50%) scale(1.1)}
.integration-visual__spoke--2:hover{transform:translateY(-50%) scale(1.1)}
.integration-visual__spoke--3:hover{transform:translateX(-50%) scale(1.1)}
.integration-visual__spoke--4:hover{transform:translateY(-50%) scale(1.1)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px){
  .team-grid--compact{grid-template-columns:repeat(2,1fr)}
}

@media (max-width: 900px){
  .split{grid-template-columns:1fr;gap:2.5rem}
  .grid--3{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr 1fr;gap:2rem}
  .card--team{grid-template-columns:180px 1fr;gap:2rem}
  .feature-showcase,
  .feature-showcase--reverse{
    grid-template-columns:1fr;
    direction:ltr;
    gap:2.5rem;
  }
  .feature-showcase__visual{
    order:2;
  }
  .feature-showcase__content{
    order:1;
  }
  .modernization-visual{flex-direction:column;gap:1rem}
  .modernization-visual__arrow{transform:rotate(90deg)}
  .protection-grid{max-width:none}
  .integration-visual__hub{width:240px;height:240px}
  .integration-visual__center{width:76px;height:76px;font-size:1.2rem}
  .integration-visual__spoke{width:48px;height:48px;font-size:.95rem}
}

@media (max-width: 640px){
  .container{padding:0 1.25rem}

  .nav__toggle{display:flex}
  .nav__menu{
    position:fixed;
    top:var(--nav-h);
    left:0;right:0;
    bottom:0;
    background:var(--bg);
    flex-direction:column;
    align-items:flex-start;
    padding:2rem 1.5rem;
    gap:1.5rem;
    transform:translateX(100%);
    transition:transform .3s ease;
    z-index:99;
  }
  .nav__menu.is-open{
    transform:translateX(0);
  }
  .nav__links{
    flex-direction:column;
    gap:1.25rem;
  }
  .nav__link{font-size:1.1rem}

  .nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(1){
    transform:rotate(45deg) translate(5px,5px);
  }
  .nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(2){
    opacity:0;
  }
  .nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(3){
    transform:rotate(-45deg) translate(5px,-5px);
  }

  .grid--2,
  .grid--3{grid-template-columns:1fr}

  .footer__grid{grid-template-columns:1fr}

  .card--team{grid-template-columns:1fr;text-align:center}
  .card--team .card__headshot{margin:0 auto}

  .team-grid--compact{grid-template-columns:1fr}

  .comparison-table table{font-size:.85rem}
  .comparison-table th,
  .comparison-table td{padding:.75rem .9rem}

  .scene-banner{max-height:220px}
  .scene-banner--short{max-height:180px}

  .pipeline-flow{max-width:100%}
  .pipeline-flow__step{padding:.85rem 1.15rem;font-size:.82rem}
  .pipeline-flow__icon{width:34px;height:34px;font-size:.9rem}

  .doc-preview{max-width:100%}

  .coverage-meter{max-width:100%}
  .coverage-meter__ring{width:130px;height:130px}
  .coverage-meter__value{font-size:1.6rem}

  .protection-grid{grid-template-columns:1fr 1fr;max-width:100%}

  .integration-visual{min-height:220px}
  .integration-visual__hub{width:200px;height:200px}
  .integration-visual__center{width:64px;height:64px;font-size:1rem}
  .integration-visual__center span{font-size:.55rem}
  .integration-visual__spoke{width:42px;height:42px;font-size:.85rem}
  .integration-visual__spoke span{font-size:.45rem}

  .trust-tier{gap:.75rem}
  .trust-tier__icon{width:30px;height:30px;font-size:.75rem}
  .trust-tier__title{font-size:.82rem}

  .card__highlights{gap:.4rem}
  .card__highlight-item{font-size:.72rem;padding:.3rem .7rem}
}

/* ============================================================
   NAVIGATION DROPDOWN
   ============================================================ */
.nav__dropdown{
  position:relative;
}
.nav__link--dropdown{
  background:none;
  border:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  font-family:var(--font-heading);
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.03em;
  text-transform:uppercase;
  color:var(--muted);
  transition:color .2s;
  padding:0;
}
.nav__link--dropdown:hover{color:var(--text)}
.nav__dropdown-icon{
  font-size:.55rem;
  transition:transform .2s;
}
.nav__dropdown.is-open .nav__dropdown-icon{
  transform:rotate(180deg);
}

.nav__dropdown-panel{
  position:absolute;
  top:calc(100% + 12px);
  left:50%;
  transform:translateX(-50%) translateY(6px);
  min-width:240px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  padding:.5rem;
  opacity:0;
  visibility:hidden;
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
  z-index:50;
}
.nav__dropdown.is-open .nav__dropdown-panel{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
}

.nav__dropdown-item{
  display:block;
  padding:.6rem .85rem;
  border-radius:var(--radius-sm);
  font-family:var(--font-heading);
  font-size:.85rem;
  font-weight:600;
  letter-spacing:.02em;
  color:var(--text);
  text-decoration:none;
  transition:background .15s;
}
.nav__dropdown-item:hover,
.nav__dropdown-item:focus{
  background:var(--bg);
  color:var(--text);
}

.nav__dropdown-footer{
  border-top:1px solid var(--border);
  margin-top:.35rem;
  padding-top:.35rem;
}
.nav__dropdown-all{
  display:block;
  padding:.5rem .85rem;
  font-size:.8rem;
  font-weight:500;
  color:var(--accent);
  text-decoration:none;
}
.nav__dropdown-all:hover{color:var(--accent-hover)}

/* ============================================================
   PRODUCT HUB CARDS
   ============================================================ */
.card--product-hub{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:var(--text);
  padding:2rem;
}
.card--product-hub:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-3px);
}
.card--product-hub .card__tagline{
  color:var(--muted);
  font-size:.9rem;
  font-weight:400;
  margin-top:.25rem;
}
.card--product-hub .card__cta{
  margin-top:auto;
  padding-top:1rem;
  font-family:var(--font-heading);
  font-size:.85rem;
  font-weight:600;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:.35rem;
}

/* ============================================================
   AGENT GRID
   ============================================================ */
.agent-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.25rem;
  margin-top:2rem;
}
.agent-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.5rem;
  display:grid;
  grid-template-columns:64px 1fr;
  gap:1rem;
  align-items:center;
  transition:box-shadow .3s, transform .3s;
}
.agent-card:hover{
  box-shadow:var(--shadow-md);
  transform:translateY(-2px);
}
.agent-avatar img{
  width:64px;
  height:64px;
  object-fit:cover;
  border-radius:50%;
  background:var(--bg);
}
.agent-avatar__placeholder{
  width:64px;
  height:64px;
  border-radius:50%;
  background:rgba(72,171,217,.1);
  color:var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.4rem;
}
.agent-meta h3{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:1.05rem;
  margin:0;
}
.agent-domain{
  display:inline-block;
  font-size:.78rem;
  font-weight:600;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:.04em;
  margin-top:.15rem;
}
.agent-desc{
  margin-top:.35rem;
  color:var(--muted);
  font-size:.9rem;
  font-weight:300;
  line-height:1.6;
}

/* ============================================================
   KPI GRID
   ============================================================ */
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}
.kpi{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.25rem;
  text-align:center;
}
.kpi strong{
  display:block;
  font-family:var(--font-display);
  font-size:1.6rem;
  font-weight:700;
  color:var(--text);
  line-height:1.2;
}
.kpi span{
  display:block;
  margin-top:.25rem;
  color:var(--muted);
  font-size:.85rem;
  font-weight:400;
}

/* ============================================================
   PIPELINE STEPS
   ============================================================ */
.pipeline{
  display:grid;
  gap:0;
  margin-top:2rem;
  counter-reset:step;
}
.pipeline__step{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:1.25rem;
  padding:1.5rem 0;
  border-bottom:1px solid var(--border);
  align-items:start;
}
.pipeline__step:last-child{border-bottom:none}
.pipeline__number{
  width:48px;
  height:48px;
  border-radius:50%;
  background:var(--gradient);
  color:#fff;
  font-family:var(--font-heading);
  font-size:1.1rem;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
}
.pipeline__content h4{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:1.05rem;
  margin-bottom:.35rem;
}
.pipeline__content p{
  color:var(--muted);
  font-weight:300;
  font-size:.95rem;
  line-height:1.7;
}

/* ============================================================
   TIER LIST
   ============================================================ */
.tier-list{
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
.tier-item{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:.75rem;
  align-items:center;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:.65rem .85rem;
}
.tier-label{
  font-family:var(--font-heading);
  font-size:.75rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--accent);
  text-align:center;
}
.tier-info strong{
  font-family:var(--font-heading);
  font-weight:600;
  font-size:.92rem;
}
.tier-desc{
  display:block;
  color:var(--muted);
  font-size:.82rem;
  font-weight:300;
}

/* ============================================================
   CASE STUDY
   ============================================================ */
.case-study{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2.5rem;
  margin-bottom:2rem;
}
.case-study__header{
  display:flex;
  align-items:center;
  gap:1.25rem;
  margin-bottom:2rem;
}
.case-study__body{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}
.case-study__section h3{
  font-family:var(--font-heading);
  font-weight:700;
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:var(--accent);
  margin-bottom:.5rem;
}
.case-study__section p{
  color:var(--muted);
  font-weight:300;
  font-size:.95rem;
  line-height:1.7;
}
.case-study__metrics{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
}
.case-study__metrics .kpi{
  flex:1;
  min-width:100px;
  padding:1rem;
}
.case-study__quote{
  margin:1.5rem 0 0;
  padding:1rem 1.5rem;
  border-left:3px solid var(--accent);
  background:var(--bg);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.case-study__quote p{
  font-style:italic;
  font-size:1rem;
  color:var(--text);
  line-height:1.7;
  margin:0;
}

/* ============================================================
   CHECKLIST
   ============================================================ */
.checklist{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.checklist li{
  position:relative;
  padding-left:1.75rem;
  font-weight:400;
  font-size:.95rem;
  color:var(--text);
  line-height:1.6;
}
.checklist li::before{
  content:'\f00c';
  font-family:'Font Awesome 6 Free';
  font-weight:900;
  position:absolute;
  left:0;
  top:.15em;
  font-size:.75rem;
  color:var(--accent);
}

/* ============================================================
   CTA SECTION
   ============================================================ */
.section--cta{
  background:var(--gradient);
  margin:0 2rem;
  border-radius:var(--radius-lg);
  padding:clamp(3rem,6vw,5rem) 0;
}
.section--cta .section__title{
  color:#fff;
}
.section--cta .section__subtitle{
  color:rgba(255,255,255,.75);
}
.section--cta .btn--primary{
  background:#fff;
  color:var(--text);
  border-color:#fff;
}
.section--cta .btn--primary:hover{
  background:rgba(255,255,255,.9);
  border-color:rgba(255,255,255,.9);
  box-shadow:0 6px 20px rgba(0,0,0,.15);
}
.section--cta .btn--secondary{
  color:#fff;
  border-color:rgba(255,255,255,.4);
}
.section--cta .btn--secondary:hover{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.7);
  color:#fff;
}

/* ============================================================
   RESPONSIVE — NEW COMPONENTS
   ============================================================ */
@media(max-width:1024px){
  .agent-grid{grid-template-columns:repeat(2,1fr)}
  .case-study__body{grid-template-columns:1fr}
}

@media(max-width:900px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .section--cta{margin:0 1rem;border-radius:var(--radius)}
}

@media(max-width:640px){
  /* --- Mobile dropdown: flat list inside hamburger menu --- */
  .nav__dropdown-panel{
    position:static;
    min-width:auto;
    box-shadow:none;
    border:none;
    border-radius:0;
    padding:0;
    transform:none;
    opacity:1;
    visibility:visible;
    background:transparent;
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease;
  }
  .nav__dropdown.is-open .nav__dropdown-panel{
    max-height:500px;
    transform:none;
  }
  .nav__dropdown-item{
    padding:.75rem 0 .75rem 1.25rem;
    font-size:1rem;
    border-bottom:1px solid var(--border);
  }
  .nav__dropdown-item:last-child{
    border-bottom:none;
  }
  .nav__dropdown-footer{display:none}
  .nav__link--dropdown{
    font-size:1.1rem;
    width:100%;
    justify-content:space-between;
    padding:.15rem 0;
  }
  .nav__dropdown-icon{
    font-size:.7rem;
    margin-right:.25rem;
  }

  /* --- New component mobile fixes --- */
  .agent-grid{grid-template-columns:1fr}
  .agent-card{grid-template-columns:48px 1fr;gap:.75rem;padding:1rem}
  .agent-avatar img,.agent-avatar__placeholder{width:48px;height:48px}
  .kpi-grid{grid-template-columns:1fr}
  .pipeline__step{grid-template-columns:40px 1fr;gap:.75rem}
  .pipeline__number{width:40px;height:40px;font-size:.95rem}
  .case-study{padding:1.25rem}
  .case-study__header{flex-direction:column;align-items:flex-start;gap:.75rem}
  .case-study__quote{padding:.75rem 1rem}
  .section--cta{margin:0 .5rem}
  .card--product-hub{padding:1.5rem}
  .tier-item{grid-template-columns:44px 1fr;padding:.5rem .65rem}
  .tier-label{font-size:.7rem}
  .tier-desc{font-size:.78rem}
  .feature-showcase{flex-direction:column;gap:1.5rem}
  .feature-showcase--reverse{flex-direction:column}
  .browser-frame__img{min-height:auto}
}

/* --- BROWSER FRAME SCREENSHOT SHOWCASE --- */
.feature-showcase{
  display:flex;
  align-items:center;
  gap:3rem;
  margin-bottom:3rem;
}
.feature-showcase--reverse{
  flex-direction:row-reverse;
}
.feature-showcase__content{
  flex:1;
  min-width:0;
}
.feature-showcase__content .section__body{
  font-size:1.05rem;
  color:var(--muted);
  line-height:1.7;
}
.feature-showcase__visual{
  flex:1.2;
  min-width:0;
}
.browser-frame{
  border-radius:var(--radius);
  border:1px solid var(--border);
  overflow:hidden;
  background:var(--card);
  box-shadow:var(--shadow-lg);
}
.browser-frame__bar{
  display:flex;
  align-items:center;
  gap:6px;
  padding:10px 14px;
  background:#f0f1f3;
  border-bottom:1px solid var(--border);
}
.browser-frame__dot{
  width:10px;
  height:10px;
  border-radius:50%;
  display:inline-block;
}
.browser-frame__dot:nth-child(1){background:#ff5f57}
.browser-frame__dot:nth-child(2){background:#ffbd2e}
.browser-frame__dot:nth-child(3){background:#28c840}
.browser-frame__img{
  width:100%;
  height:auto;
  display:block;
  min-height:200px;
  object-fit:cover;
  background:#f7f8fa;
}
