/* ═══════════════════════════════════════
   about.css — Editorial Magazine Style
   ═══════════════════════════════════════ */

/* ─── HERO ─── */
.ab-hero{
  position:relative;overflow:hidden;
  padding:56px 0;
  background:#0c0b0a;
  color:#fff;
}
.ab-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 20%, rgba(194,59,34,.18) 0%, transparent 60%),
    radial-gradient(ellipse 50% 80% at 10% 80%, rgba(194,59,34,.08) 0%, transparent 50%);
  pointer-events:none;
}
.ab-hero-bg::after{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='40' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='.5' fill='rgba(255,255,255,0.03)'/%3E%3C/svg%3E");
  pointer-events:none;
}
.ab-hero-content{
  position:relative;z-index:1;
  text-align:center;
  max-width:640px;margin:0 auto;
}
.ab-hero-badge{
  display:inline-block;
  font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.12);border-radius:9999px;
  padding:6px 16px;margin-bottom:28px;
}
.ab-hero h1{
  font-size:clamp(2rem,5vw,3.25rem);
  font-weight:700;letter-spacing:-.04em;line-height:1.2;
}
.ab-hero h1 em{
  font-style:normal;
  background:linear-gradient(135deg,#C23B22 20%,#E8654D 80%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.ab-hero-desc{
  margin:24px auto 0;
  font-size:1rem;line-height:1.85;
  color:rgba(255,255,255,.7);
  max-width:460px;
}
.ab-hero-cta{
  display:flex;flex-wrap:wrap;gap:12px;margin-top:36px;
  justify-content:center;
}
.ab-btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:9999px;
  background:#C23B22;color:#fff;
  font-size:.875rem;font-weight:600;
  transition:all .25s;text-decoration:none;
}
.ab-btn-primary:hover{background:#D4493A;transform:translateY(-1px);box-shadow:0 8px 24px rgba(194,59,34,.35);}
.ab-btn-ghost{
  display:inline-flex;align-items:center;
  padding:14px 24px;border-radius:9999px;
  background:transparent;color:rgba(255,255,255,.75);
  border:1px solid rgba(255,255,255,.18);
  font-size:.875rem;font-weight:500;
  transition:all .25s;text-decoration:none;
}
.ab-btn-ghost:hover{border-color:rgba(255,255,255,.3);color:#fff;}

/* ─── STATS ─── */
.ab-stats-card{
  position:relative;z-index:3;
  margin-top:48px;
  display:flex;align-items:center;justify-content:center;gap:40px;
}
.ab-stat{text-align:center;}
.ab-stat-num{
  display:flex;align-items:center;justify-content:center;gap:2px;
  font-size:clamp(1.5rem,3.5vw,2rem);font-weight:700;
  letter-spacing:-.02em;line-height:1;
  color:#fff;
}
.ab-stat-num small{font-size:.75em;font-weight:700;color:#fff;margin-left:2px;}
.ab-stat-lbl{
  display:block;margin-top:10px;
  font-size:.75rem;color:rgba(255,255,255,.6);
  letter-spacing:.02em;
}

/* ─── SHARED SECTION HEAD (centered) ─── */
.ab-overline{
  display:inline-block;
  font-size:.6875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);
  margin-bottom:12px;
}
.ab-section-head{
  text-align:center;
  margin-bottom:48px;
}
.ab-section-head h2{
  font-size:clamp(1.5rem,3.5vw,2.25rem);
  font-weight:700;letter-spacing:-.04em;line-height:1.3;
  color:var(--fg);
}
.ab-section-sub{
  margin-top:14px;
  font-size:.9375rem;line-height:1.75;
  color:var(--muted);
  max-width:480px;margin-left:auto;margin-right:auto;
}

/* ─── PROBLEM ─── */
.ab-problem{
  padding:80px 0;
  background:var(--muted-bg);
}
.ab-pain-grid{
  display:grid;grid-template-columns:1fr;gap:16px;
}
.ab-pain-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  padding:32px 28px;
  transition:all .3s;
}
.ab-pain-card:hover{
  border-color:rgba(21,20,18,.12);
  box-shadow:0 8px 28px rgba(0,0,0,.05);
}
.ab-pain-num{
  display:block;
  font-size:.75rem;font-weight:700;letter-spacing:.08em;
  color:var(--accent);margin-bottom:16px;
}
.ab-pain-card h3{
  font-size:1rem;font-weight:600;letter-spacing:-.02em;
  color:var(--fg);margin-bottom:10px;
}
.ab-pain-card p{
  font-size:.8125rem;line-height:1.8;color:var(--muted);
}

/* ─── SOLUTION / FEATURES ─── */
.ab-solution{
  padding:80px 0;
  background:var(--bg);
}
.ab-features{
  display:grid;grid-template-columns:1fr;gap:16px;
}
.ab-feat{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  padding:32px 24px 28px;
  position:relative;overflow:hidden;
  transition:all .35s cubic-bezier(.23,1,.32,1);
}
.ab-feat::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),transparent 80%);
  opacity:0;transition:opacity .3s;
}
.ab-feat:hover{
  border-color:rgba(21,20,18,.12);
  box-shadow:0 16px 48px rgba(0,0,0,.07);
  transform:translateY(-4px);
}
.ab-feat:hover::before{opacity:1;}
.ab-feat-visual{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(194,59,34,.08),rgba(194,59,34,.02));
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);margin-bottom:20px;
}
.ab-feat-label{
  display:block;
  font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px;
}
.ab-feat h3{
  font-size:1rem;font-weight:700;letter-spacing:-.02em;
  line-height:1.4;color:var(--fg);margin-bottom:10px;
}
.ab-feat p{
  font-size:.8125rem;line-height:1.85;color:var(--muted);
}

/* ─── PROCESS / HOW IT WORKS ─── */
.ab-process{
  padding:80px 0;
  background:var(--muted-bg);
}
.ab-steps{
  display:grid;grid-template-columns:1fr;gap:16px;
  max-width:720px;margin:0 auto;
}
.ab-step{
  display:flex;align-items:flex-start;gap:20px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:16px;
  padding:28px 24px;
  transition:all .3s;
}
.ab-step:hover{
  border-color:rgba(21,20,18,.12);
  box-shadow:0 8px 28px rgba(0,0,0,.05);
}
.ab-step-num{
  flex-shrink:0;
  width:44px;height:44px;border-radius:12px;
  background:var(--fg);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.8125rem;font-weight:700;letter-spacing:.04em;
}
.ab-step-body h3{
  font-size:1rem;font-weight:700;letter-spacing:-.02em;
  color:var(--fg);margin-bottom:6px;
}
.ab-step-body p{
  font-size:.8125rem;line-height:1.75;color:var(--muted);
}

/* ─── PARTNERSHIP ─── */
.ab-partners{
  padding:80px 0;
  background:var(--bg);
}
.ab-partner-cards{
  display:grid;grid-template-columns:1fr;gap:16px;
  max-width:720px;margin:0 auto;
}
.ab-pcard{
  display:flex;flex-direction:column;
  background:var(--card);
  border:1px solid var(--border);border-radius:16px;
  padding:32px 28px;
  text-decoration:none;color:inherit;
  transition:all .35s cubic-bezier(.23,1,.32,1);
  position:relative;overflow:hidden;
}
.ab-pcard::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),transparent 80%);
  opacity:0;transition:opacity .3s;
}
.ab-pcard:hover{
  border-color:rgba(21,20,18,.12);
  box-shadow:0 16px 48px rgba(0,0,0,.07);
  transform:translateY(-4px);
}
.ab-pcard:hover::after{opacity:1;}
.ab-pcard-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(194,59,34,.08),rgba(194,59,34,.02));
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);margin-bottom:20px;
}
.ab-pcard h3{
  font-size:1.0625rem;font-weight:700;letter-spacing:-.02em;
  color:var(--fg);margin-bottom:10px;
}
.ab-pcard p{
  font-size:.8125rem;line-height:1.8;color:var(--muted);
  flex:1;
}
.ab-pcard-link{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:20px;
  font-size:.8125rem;font-weight:600;color:var(--accent);
  transition:gap .25s;
}
.ab-pcard:hover .ab-pcard-link{gap:10px;}

/* ─── CTA ─── */
.ab-cta{
  position:relative;overflow:hidden;
  padding:80px 0;
  background:#0c0b0a;color:#fff;
  text-align:center;
}
.ab-cta-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 50% 100%, rgba(194,59,34,.15) 0%, transparent 50%),
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(194,59,34,.06) 0%, transparent 40%);
  pointer-events:none;
}
.ab-cta-content{
  position:relative;z-index:1;
  max-width:480px;margin:0 auto;
}
.ab-cta h2{
  font-size:clamp(1.5rem,4vw,2.5rem);
  font-weight:700;letter-spacing:-.04em;line-height:1.25;
  margin-bottom:16px;
}
.ab-cta p{
  font-size:.9375rem;line-height:1.8;
  color:rgba(255,255,255,.6);
  margin-bottom:36px;
}
.ab-cta-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 36px;border-radius:9999px;
  background:#C23B22;color:#fff;
  font-size:.9375rem;font-weight:600;
  transition:all .25s;text-decoration:none;
}
.ab-cta-btn:hover{
  background:#D4493A;
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(194,59,34,.4);
}

/* ═══ RESPONSIVE ═══ */

@media(max-width:480px){
  .ab-hero{padding:40px 0;}
  .ab-hero-badge{font-size:.625rem;padding:5px 12px;margin-bottom:20px;}
  .ab-hero h1{font-size:1.75rem;letter-spacing:-.03em;}
  .ab-hero-desc{font-size:.875rem;line-height:1.75;margin-top:18px;}
  .ab-hero-cta{margin-top:24px;gap:10px;}
  .ab-btn-primary{padding:12px 22px;font-size:.8125rem;}
  .ab-btn-ghost{padding:12px 18px;font-size:.8125rem;}
  .ab-stats-card{margin-top:32px;gap:28px;}
  .ab-stat-num{font-size:1.25rem;}
  .ab-stat-lbl{font-size:.6875rem;margin-top:6px;}

  .ab-problem{padding:48px 0;}
  .ab-section-head{margin-bottom:28px;}
  .ab-section-head h2{font-size:1.25rem;}
  .ab-section-sub{font-size:.8125rem;line-height:1.7;margin-top:10px;}
  .ab-overline{font-size:.625rem;margin-bottom:8px;}
  .ab-pain-grid{gap:10px;}
  .ab-pain-card{padding:22px 20px;border-radius:12px;}
  .ab-pain-num{font-size:.6875rem;margin-bottom:10px;}
  .ab-pain-card h3{font-size:.875rem;margin-bottom:6px;}
  .ab-pain-card p{font-size:.75rem;line-height:1.7;}

  .ab-solution{padding:48px 0;}
  .ab-features{gap:10px;}
  .ab-feat{padding:22px 20px 20px;border-radius:12px;}
  .ab-feat-visual{width:44px;height:44px;border-radius:11px;margin-bottom:14px;}
  .ab-feat-visual svg{width:22px;height:22px;}
  .ab-feat-label{font-size:.625rem;margin-bottom:6px;}
  .ab-feat h3{font-size:.875rem;margin-bottom:6px;}
  .ab-feat p{font-size:.75rem;line-height:1.7;}

  .ab-process{padding:48px 0;}
  .ab-steps{gap:10px;}
  .ab-step{padding:18px 16px;gap:12px;border-radius:12px;}
  .ab-step-num{width:32px;height:32px;border-radius:8px;font-size:.6875rem;}
  .ab-step-body h3{font-size:.8125rem;margin-bottom:3px;}
  .ab-step-body p{font-size:.75rem;line-height:1.65;}

  .ab-partners{padding:48px 0;}
  .ab-partner-cards{gap:10px;}
  .ab-pcard{padding:22px 20px;border-radius:12px;}
  .ab-pcard-icon{width:44px;height:44px;border-radius:11px;margin-bottom:14px;}
  .ab-pcard-icon svg{width:22px;height:22px;}
  .ab-pcard h3{font-size:.9375rem;margin-bottom:6px;}
  .ab-pcard p{font-size:.75rem;line-height:1.7;}
  .ab-pcard-link{font-size:.75rem;margin-top:14px;}

  .ab-cta{padding:48px 0;}
  .ab-cta h2{font-size:1.375rem;margin-bottom:12px;}
  .ab-cta p{font-size:.8125rem;line-height:1.7;margin-bottom:24px;}
  .ab-cta-btn{padding:13px 28px;font-size:.8125rem;}
}

@media(min-width:768px){
  .ab-hero{padding:72px 0;}
  .ab-stats-card{margin-top:56px;gap:56px;}
  .ab-hero h1{font-size:clamp(2.25rem,5vw,3.25rem);}

  .ab-problem{padding:100px 0;}
  .ab-pain-grid{grid-template-columns:repeat(3,1fr);gap:20px;}

  .ab-solution{padding:100px 0;}
  .ab-features{grid-template-columns:repeat(3,1fr);gap:20px;}

  .ab-process{padding:100px 0;}
  .ab-steps{gap:20px;}

  .ab-partners{padding:100px 0;}
  .ab-partner-cards{grid-template-columns:repeat(2,1fr);gap:20px;}

  .ab-cta{padding:100px 0;}

  .ab-section-head{margin-bottom:56px;}
}

@media(min-width:1024px){
  .ab-hero{padding:88px 0;}
  .ab-hero-content{max-width:700px;}
  .ab-stats-card{margin-top:64px;gap:64px;}

  .ab-problem{padding:120px 0;}
  .ab-pain-grid{gap:24px;}
  .ab-pain-card{padding:36px 32px;}

  .ab-solution{padding:120px 0;}
  .ab-features{gap:24px;}
  .ab-feat{padding:36px 28px 32px;}

  .ab-process{padding:120px 0;}

  .ab-partners{padding:120px 0;}
  .ab-pcard{padding:36px 32px;}

  .ab-cta{padding:120px 0;}

  .ab-section-head{margin-bottom:64px;}
  .ab-section-head h2{font-size:clamp(1.75rem,3.5vw,2.5rem);}
}
