/* =========================================================
   APPLE-STYLE INDUSTRIES PAGE
   Detailed per-industry sections — light theme
   ========================================================= */

/* Industry palette tokens */
.ap-detail-cyan{--accent:#0071e3;--accent-soft:rgba(0,113,227,.10);--accent-tint:rgba(0,113,227,.04)}
.ap-detail-amber{--accent:#f59e0b;--accent-soft:rgba(245,158,11,.10);--accent-tint:rgba(245,158,11,.04)}
.ap-detail-emerald{--accent:#10b981;--accent-soft:rgba(16,185,129,.10);--accent-tint:rgba(16,185,129,.04)}
.ap-detail-violet{--accent:#8b5cf6;--accent-soft:rgba(139,92,246,.10);--accent-tint:rgba(139,92,246,.04)}
.ap-detail-rose{--accent:#f43f5e;--accent-soft:rgba(244,63,94,.10);--accent-tint:rgba(244,63,94,.04)}
.ap-detail-teal{--accent:#14b8a6;--accent-soft:rgba(20,184,166,.10);--accent-tint:rgba(20,184,166,.04)}
.ap-detail-indigo{--accent:#6366f1;--accent-soft:rgba(99,102,241,.10);--accent-tint:rgba(99,102,241,.04)}
.ap-detail-gold{--accent:#eab308;--accent-soft:rgba(234,179,8,.10);--accent-tint:rgba(234,179,8,.04)}

/* Active nav state */
.ap-nav-links a.active{color:var(--ink);font-weight:500}

/* Hero chip row — single line with horizontal scroll fallback */
.ap-chip-row{
  display:flex;flex-wrap:nowrap;justify-content:center;
  gap:6px;
  margin:22px auto 56px;
  max-width:100%;
  overflow-x:auto;
  scrollbar-width:none;
  -ms-overflow-style:none;
  padding-bottom:4px;
}
.ap-chip-row::-webkit-scrollbar{display:none}
.ap-chip-link{
  display:inline-flex;align-items:center;gap:9px;
  padding:8px 14px 8px 12px;border-radius:999px;
  background:#fff;border:1px solid var(--hairline);
  font-size:12.5px;font-weight:500;color:var(--ink);
  letter-spacing:-.005em;white-space:nowrap;flex-shrink:0;
  transition:all .25s ease;
}
.ap-chip-link svg{
  width:13px;height:13px;flex-shrink:0;
  opacity:.65;
  transition:opacity .25s ease;
}
.ap-chip-link:hover{
  background:var(--blue);color:#fff;border-color:var(--blue);
  transform:translateY(-2px);
  box-shadow:0 8px 18px -6px rgba(0,113,227,.4);
}
.ap-chip-link:hover svg{opacity:1}

/* Allow horizontal scroll on narrower screens — chips wider than viewport scroll instead of wrapping */
@media (max-width:900px){
  .ap-chip-row{
    justify-content:flex-start;
    padding-left:22px;padding-right:22px;
    margin-bottom:40px;
  }
}

/* =========================================================
   DETAIL SECTION (per-industry)
   ========================================================= */
.ap-detail{
  position:relative;
  padding:120px 0;
  background:#fff;
}
.ap-detail-grey{background:var(--bg-grey)}
.ap-detail::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 40% at 50% 0%,var(--accent-tint),transparent 70%);
}
.ap-detail .ap-container{position:relative;z-index:1}

.ap-detail-head{
  max-width:880px;margin:0 auto 70px;text-align:center;
}
.ap-detail-tag{
  display:inline-block;padding:6px 14px;border-radius:8px;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:12px;font-weight:600;letter-spacing:.06em;
  background:#fff;border:1px solid var(--hairline);
  color:var(--accent);
  margin-bottom:22px;
}
.ap-detail-grey .ap-detail-tag{background:#fff}
.ap-detail-h{
  font-size:clamp(34px,5vw,60px);
  font-weight:600;letter-spacing:-.035em;line-height:1.07;
  color:var(--ink);
}

.ap-detail-body{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.ap-detail-body-rev .ap-detail-copy{order:2}
.ap-detail-body-rev .ap-detail-visual{order:1}

.ap-detail-copy h3{
  font-size:13px;font-weight:600;color:var(--ink);
  text-transform:uppercase;letter-spacing:.1em;
  margin:32px 0 10px;
}
.ap-detail-copy p{
  color:var(--ink-2);font-size:16px;line-height:1.6;letter-spacing:-.005em;
}

/* Big stat */
.ap-bigstat{
  display:flex;align-items:center;gap:22px;
  padding:24px;border-radius:18px;
  background:#fff;border:1px solid var(--hairline);
  margin-bottom:8px;
}
.ap-detail-grey .ap-bigstat{background:#fff}
.ap-bignum{
  font-size:clamp(48px,5.5vw,68px);
  font-weight:600;letter-spacing:-.035em;line-height:1;
  color:var(--accent);
  font-variant-numeric:tabular-nums;flex-shrink:0;
}
.ap-bignum-suffix{color:var(--accent);font-size:.7em;margin-left:1px;font-weight:600}
.ap-bignum-label{color:var(--ink-2);font-size:14px;line-height:1.5;letter-spacing:-.005em}

/* Bullets */
.ap-bullets{display:flex;flex-direction:column;gap:10px;margin-top:6px}
.ap-bullets li{
  padding-left:28px;position:relative;
  color:var(--ink-2);font-size:15.5px;line-height:1.55;letter-spacing:-.005em;
}
.ap-bullets li::before{
  content:'';position:absolute;left:0;top:6px;
  width:18px;height:18px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 4px 10px -2px var(--accent-soft);
}
.ap-bullets li::after{
  content:'';position:absolute;left:5px;top:11px;
  width:8px;height:4px;
  border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg);
}
.ap-bullets strong{color:var(--ink);font-weight:600}

/* Cost callout */
.ap-callout{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  margin-top:30px;padding:20px 24px;border-radius:16px;
  background:linear-gradient(135deg,var(--accent-soft),var(--accent-tint));
  border:1px solid var(--accent-soft);
  flex-wrap:wrap;
}
.ap-callout-label{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  color:var(--grey-2);margin-bottom:4px;
}
.ap-callout-num{
  font-size:15px;color:var(--ink);font-weight:500;line-height:1.5;
  letter-spacing:-.005em;
}
.ap-callout-num span{font-weight:600;color:var(--accent)}
.ap-callout-tag{
  padding:7px 14px;border-radius:999px;font-size:13px;font-weight:600;
  background:var(--accent);color:#fff;white-space:nowrap;flex-shrink:0;
  box-shadow:0 6px 14px -4px var(--accent-soft);
}

/* Visual wrap */
.ap-detail-visual{position:relative;perspective:1400px;min-height:420px}

/* Floating stat chips */
.ap-float-stat{
  position:absolute;padding:14px 18px;border-radius:14px;
  background:#fff;border:1px solid var(--hairline);
  box-shadow:0 14px 30px -10px rgba(0,0,0,.12);
  animation:ap-float-y 6s ease-in-out infinite;
  font-size:12.5px;color:var(--grey-2);font-weight:500;
  display:flex;flex-direction:column;gap:2px;z-index:3;
}
.ap-float-stat strong{
  display:block;font-size:22px;color:var(--accent);font-weight:600;
  letter-spacing:-.02em;
}
.ap-float-stat-1{top:-15px;left:-25px}
.ap-float-stat-2{bottom:-15px;right:-25px;animation-delay:2s}
@keyframes ap-float-y{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}

/* =========================================================
   PHONE MOCK (Real Estate)
   ========================================================= */
.ap-detail-phone{
  background:#fff;border-radius:24px;padding:24px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(0,113,227,.2);
  max-width:420px;margin:0 auto;
  transform:rotateY(-5deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
}
.ap-detail-phone-bar{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:14px;border-bottom:1px solid var(--hairline);
  margin-bottom:14px;font-size:12px;font-weight:500;color:var(--grey-2);
}
.ap-detail-phone-status{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-weight:500}
.ap-detail-phone-tag{
  background:var(--accent-soft);color:var(--accent);padding:3px 9px;border-radius:5px;
  font-weight:500;
}
.ap-detail-phone-name{font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.02em}
.ap-detail-phone-meta{font-size:13px;color:var(--grey);margin:2px 0 16px}
.ap-detail-phone-wave{
  display:flex;justify-content:center;align-items:center;
  gap:3px;height:46px;margin-bottom:16px;
}
.ap-detail-phone-wave span{
  display:block;width:3px;border-radius:2px;
  background:var(--accent);
  animation:ap-wave 1.2s ease-in-out infinite;
}
.ap-detail-phone-wave span:nth-child(1){height:30%;animation-delay:0s}
.ap-detail-phone-wave span:nth-child(2){height:55%;animation-delay:.05s}
.ap-detail-phone-wave span:nth-child(3){height:80%;animation-delay:.1s}
.ap-detail-phone-wave span:nth-child(4){height:65%;animation-delay:.15s}
.ap-detail-phone-wave span:nth-child(5){height:90%;animation-delay:.2s}
.ap-detail-phone-wave span:nth-child(6){height:50%;animation-delay:.25s}
.ap-detail-phone-wave span:nth-child(7){height:75%;animation-delay:.3s}
.ap-detail-phone-wave span:nth-child(8){height:95%;animation-delay:.35s}
.ap-detail-phone-wave span:nth-child(9){height:60%;animation-delay:.4s}
.ap-detail-phone-wave span:nth-child(10){height:80%;animation-delay:.45s}
.ap-detail-phone-wave span:nth-child(11){height:45%;animation-delay:.5s}
.ap-detail-phone-wave span:nth-child(12){height:70%;animation-delay:.55s}
.ap-detail-phone-wave span:nth-child(13){height:55%;animation-delay:.6s}
.ap-detail-phone-wave span:nth-child(14){height:85%;animation-delay:.65s}

.ap-detail-phone-msg{
  background:var(--accent-soft);border:1px solid var(--accent-soft);
  border-radius:14px;padding:12px 14px;
  font-size:14px;color:var(--ink);line-height:1.5;
  margin-bottom:14px;
}
.ap-detail-phone-route{display:flex;flex-direction:column;gap:8px}
.ap-detail-route-step{
  padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;
  background:var(--bg-grey);color:var(--grey-2);
  display:flex;align-items:center;gap:10px;
}
.ap-route-pip{
  width:10px;height:10px;border-radius:50%;
  background:var(--hairline);flex-shrink:0;
}
.ap-detail-route-step.done{color:var(--ink)}
.ap-detail-route-step.done .ap-route-pip{
  background:#10b981;box-shadow:0 0 6px rgba(16,185,129,.5);
}
.ap-detail-route-step.active{
  background:linear-gradient(135deg,var(--accent),#7e57ff);
  color:#fff;
}
.ap-detail-route-step.active .ap-route-pip{
  background:#fff;animation:ap-pulse 1.5s infinite;
}

/* =========================================================
   SOLAR CARD
   ========================================================= */
.ap-solar-card{
  background:#fff;border-radius:24px;padding:30px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(245,158,11,.2);
  transform:rotateY(-4deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
  max-width:420px;margin:0 auto;
}
.ap-solar-sun{
  position:relative;width:120px;height:120px;margin:0 auto 22px;
}
.ap-solar-core{
  position:absolute;inset:35%;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,#fef3c7,#f59e0b 60%,#b45309);
  box-shadow:0 0 30px rgba(245,158,11,.6);
  animation:ap-sun-glow 3s ease-in-out infinite;
}
@keyframes ap-sun-glow{
  0%,100%{box-shadow:0 0 24px rgba(245,158,11,.5)}
  50%{box-shadow:0 0 50px rgba(245,158,11,.8)}
}
.ap-solar-ring{
  position:absolute;inset:0;border-radius:50%;
  border:1.5px solid rgba(245,158,11,.4);
  animation:ap-ring-pulse 4s ease-out infinite;
}
.ap-solar-ring.r2{animation-delay:1.3s}
.ap-solar-ring.r3{animation-delay:2.6s}
@keyframes ap-ring-pulse{
  0%{transform:scale(.5);opacity:0}
  20%{opacity:.7}
  100%{transform:scale(1.7);opacity:0}
}

.ap-solar-bill{
  background:var(--bg-grey);border-radius:14px;padding:18px;
}
.ap-solar-bill-label{
  font-size:11.5px;color:var(--grey);text-transform:uppercase;
  letter-spacing:.08em;font-weight:600;
}
.ap-solar-bill-num{
  font-size:36px;font-weight:600;color:var(--ink);letter-spacing:-.03em;
  font-variant-numeric:tabular-nums;line-height:1.2;
  display:flex;align-items:baseline;gap:3px;
}
.ap-solar-bill-num::before{display:none}
.ap-solar-bill-num .suffix{font-size:13px;color:var(--grey);font-weight:500;margin-left:4px}
.ap-solar-bars{
  display:flex;align-items:flex-end;gap:5px;height:50px;margin:12px 0;
}
.ap-solar-bars span{
  flex:1;background:linear-gradient(180deg,#f59e0b,#dc2626);
  border-radius:3px 3px 0 0;height:var(--h);
  animation:ap-bar-grow 1.6s cubic-bezier(.2,.7,.3,1) backwards;
}
.ap-solar-bars span:nth-child(1){animation-delay:.1s}
.ap-solar-bars span:nth-child(2){animation-delay:.2s}
.ap-solar-bars span:nth-child(3){animation-delay:.3s}
.ap-solar-bars span:nth-child(4){animation-delay:.4s}
.ap-solar-bars span:nth-child(5){animation-delay:.5s}
.ap-solar-bars span:nth-child(6){animation-delay:.6s}
.ap-solar-bars span:nth-child(7){animation-delay:.7s}
.ap-solar-bars span:nth-child(8){animation-delay:.8s}
@keyframes ap-bar-grow{from{height:0}}
.ap-solar-trigger{
  padding:9px 14px;border-radius:10px;font-size:13px;font-weight:500;
  background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(244,63,94,.1));
  border:1px solid rgba(245,158,11,.3);color:#92400e;
}

/* =========================================================
   SHIELD CARD (Insurance)
   ========================================================= */
.ap-shield-card{
  background:#fff;border-radius:24px;padding:30px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(16,185,129,.2);
  display:flex;align-items:center;gap:24px;
  transform:rotateY(-5deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
  flex-wrap:wrap;max-width:480px;margin:0 auto;
}
.ap-shield-svg{width:120px;height:auto;flex-shrink:0}
.ap-shield-path{
  stroke-dasharray:1000;stroke-dashoffset:1000;
  animation:ap-draw 2.5s ease-out forwards;
}
.ap-shield-check{
  stroke-dasharray:200;stroke-dashoffset:200;
  animation:ap-draw 1.2s ease-out 1.6s forwards;
}
@keyframes ap-draw{to{stroke-dashoffset:0}}
.ap-shield-rows{flex:1;min-width:170px;display:flex;flex-direction:column;gap:8px}
.ap-shield-row{
  padding:9px 12px;border-radius:9px;font-size:13px;font-weight:500;
  color:var(--grey-2);background:var(--bg-grey);
  display:flex;align-items:center;gap:8px;
}
.ap-shield-row span{color:#10b981;font-weight:700;font-size:14px}
.ap-shield-row.active{
  background:linear-gradient(135deg,rgba(16,185,129,.12),rgba(0,113,227,.08));
  border:1px solid rgba(16,185,129,.3);color:var(--ink);
}
.ap-shield-row.active span{color:var(--blue)}

/* =========================================================
   RATE CARD (Mortgage)
   ========================================================= */
.ap-rate-card{
  background:#fff;border-radius:24px;padding:26px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(139,92,246,.2);
  transform:rotateY(-4deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
  max-width:420px;margin:0 auto;
}
.ap-rate-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.ap-rate-label{
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--grey-2);
}
.ap-rate-change{
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:13px;font-weight:600;color:#10b981;
  background:rgba(16,185,129,.1);padding:4px 10px;border-radius:6px;
  border:1px solid rgba(16,185,129,.25);
}
.ap-rate-chart{margin-bottom:18px}
.ap-rate-svg{width:100%;height:auto}
.ap-rate-line{
  stroke-dasharray:600;stroke-dashoffset:600;
  animation:ap-draw 2s ease-out forwards;
}
.ap-rate-area{opacity:0;animation:ap-fade-in 1s ease-out 1.5s forwards}
@keyframes ap-fade-in{to{opacity:1}}
.ap-rate-dot{opacity:0;animation:ap-fade-in .4s ease 2s forwards}

.ap-rate-trigger{
  display:flex;align-items:center;gap:14px;
  padding:14px;border-radius:12px;
  background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(99,102,241,.08));
  border:1px solid rgba(139,92,246,.25);
  color:var(--ink);font-size:13px;margin-bottom:14px;
}
.ap-rate-trigger-icon{
  font-size:22px;width:38px;height:38px;border-radius:10px;
  background:rgba(139,92,246,.15);display:grid;place-items:center;
  animation:ap-pulse 1.8s infinite;
}
.ap-rate-sub{font-size:12px;color:var(--grey);margin-top:2px}
.ap-rate-progress{display:flex;flex-direction:column;gap:8px}
.ap-prog-row{
  display:flex;justify-content:space-between;
  padding:9px 12px;border-radius:9px;
  background:var(--bg-grey);
  font-size:13px;color:var(--grey-2);
}
.ap-prog-row span:last-child{
  font-weight:600;color:var(--ink);
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
.ap-prog-row.hot{
  background:linear-gradient(135deg,rgba(139,92,246,.12),rgba(0,113,227,.08));
  border:1px solid rgba(139,92,246,.25);
}
.ap-prog-row.hot span:last-child{color:#8b5cf6}

/* =========================================================
   AUTO CARD
   ========================================================= */
.ap-auto-card{
  background:#fff;border-radius:24px;padding:24px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(244,63,94,.2);
  transform:rotateY(-4deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
  max-width:440px;margin:0 auto;
}
.ap-auto-header{
  font-size:12px;font-weight:600;color:var(--grey);
  text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--hairline);
}
.ap-auto-list{display:flex;flex-direction:column;gap:8px}
.ap-auto-item{
  display:flex;align-items:center;gap:14px;
  padding:12px;border-radius:12px;
  background:var(--bg-grey);
  transition:.3s ease;
}
.ap-auto-item.active{
  background:linear-gradient(135deg,rgba(244,63,94,.12),rgba(245,158,11,.06));
  border:1px solid rgba(244,63,94,.3);
}
.ap-auto-icon{
  font-size:20px;width:36px;height:36px;border-radius:9px;
  background:#fff;display:grid;place-items:center;flex-shrink:0;
}
.ap-auto-grow{flex:1;min-width:0}
.ap-auto-title{font-size:14px;font-weight:600;color:var(--ink)}
.ap-auto-meta{font-size:12px;color:var(--grey)}
.ap-auto-status{
  font-size:11px;font-weight:600;padding:5px 10px;border-radius:6px;
  background:#fff;color:var(--grey-2);
  text-transform:uppercase;letter-spacing:.05em;
}
.ap-auto-status.hot{
  background:linear-gradient(135deg,#f43f5e,#f59e0b);color:#fff;
  animation:ap-hot-pulse 1.6s ease-in-out infinite;
}
@keyframes ap-hot-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(244,63,94,.4)}
  50%{box-shadow:0 0 0 6px rgba(244,63,94,0)}
}

/* =========================================================
   CALENDAR CARD (Healthcare)
   ========================================================= */
.ap-cal-card{
  background:#fff;border-radius:24px;padding:24px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(20,184,166,.2);
  transform:rotateY(-4deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
  max-width:380px;margin:0 auto;
}
.ap-cal-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:16px;color:var(--ink);font-weight:600;font-size:15px;
}
.ap-cal-status{
  font-size:11px;font-weight:600;color:#0d9488;
  background:rgba(20,184,166,.12);padding:4px 10px;border-radius:6px;
  border:1px solid rgba(20,184,166,.25);
}
.ap-cal-grid{
  display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:16px;
}
.ap-cal-day{
  font-size:10.5px;font-weight:600;color:var(--grey);
  text-align:center;padding:4px 0;
}
.ap-cal-cell{
  aspect-ratio:1;border-radius:7px;
  display:grid;place-items:center;
  font-size:12px;font-weight:500;color:var(--grey-2);
  background:var(--bg-grey);
  transition:.3s ease;
}
.ap-cal-cell.booked{
  background:linear-gradient(135deg,#14b8a6,#0d9488);
  color:#fff;font-weight:600;
  animation:ap-cal-pop .5s ease-out backwards;
}
.ap-cal-cell.booked:nth-child(2n){animation-delay:.1s}
.ap-cal-cell.booked:nth-child(3n){animation-delay:.2s}
.ap-cal-cell.booked:nth-child(4n){animation-delay:.3s}
.ap-cal-cell.booked:nth-child(5n){animation-delay:.4s}
@keyframes ap-cal-pop{
  from{transform:scale(.6);opacity:0}
  to{transform:scale(1);opacity:1}
}
.ap-cal-cell.today{
  background:linear-gradient(135deg,#0071e3,#7e57ff);color:#fff;font-weight:700;
}
.ap-cal-confirm{
  display:flex;align-items:center;gap:12px;
  padding:13px;border-radius:12px;
  background:linear-gradient(135deg,rgba(20,184,166,.12),rgba(0,113,227,.06));
  border:1px solid rgba(20,184,166,.3);
}
.ap-cal-pulse{
  width:10px;height:10px;border-radius:50%;background:#14b8a6;flex-shrink:0;
  box-shadow:0 0 8px #14b8a6;
  animation:ap-pulse 1.5s infinite;
}
.ap-cal-name{font-size:13px;font-weight:600;color:var(--ink)}
.ap-cal-sub{font-size:12px;color:var(--grey);margin-top:1px}
.ap-cal-tag{
  margin-left:auto;padding:4px 10px;border-radius:6px;
  background:rgba(20,184,166,.18);color:#0d9488;font-size:10.5px;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;
}

/* =========================================================
   FUNNEL CARD (Education)
   ========================================================= */
.ap-funnel-card{
  background:#fff;border-radius:24px;padding:28px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(99,102,241,.2);
  transform:rotateY(-4deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
  max-width:440px;margin:0 auto;
}
.ap-funnel-row{
  display:grid;grid-template-columns:60px 1fr 100px;align-items:center;gap:12px;
  padding:12px 0;border-bottom:1px solid var(--hairline);
}
.ap-funnel-row:last-of-type{border-bottom:none}
.ap-funnel-num{
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-.02em;
}
.ap-funnel-row > span:nth-child(2){
  font-size:13.5px;color:var(--grey-2);font-weight:500;
}
.ap-funnel-bar{
  height:8px;border-radius:4px;background:var(--bg-grey);overflow:hidden;
}
.ap-funnel-bar div{
  height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:4px;
  animation:ap-funnel-grow 1.4s cubic-bezier(.2,.7,.3,1) backwards;
  transform-origin:left;
}
.ap-funnel-row:nth-child(1) .ap-funnel-bar div{animation-delay:.1s}
.ap-funnel-row:nth-child(2) .ap-funnel-bar div{animation-delay:.3s}
.ap-funnel-row:nth-child(3) .ap-funnel-bar div{animation-delay:.5s}
.ap-funnel-row:nth-child(4) .ap-funnel-bar div{animation-delay:.7s;background:linear-gradient(90deg,#0071e3,#10b981)}
@keyframes ap-funnel-grow{from{transform:scaleX(0)}}
.ap-funnel-row.hot .ap-funnel-num{color:var(--blue)}
.ap-funnel-row.hot > span:nth-child(2){color:var(--ink);font-weight:600}
.ap-funnel-result{
  margin-top:14px;padding:11px 14px;border-radius:10px;
  background:rgba(0,113,227,.06);border:1px solid rgba(0,113,227,.25);
  font-size:13px;color:var(--blue);font-weight:600;text-align:center;
}

/* =========================================================
   LEGAL CARD
   ========================================================= */
.ap-legal-card{
  background:#fff;border-radius:24px;padding:28px;
  border:1px solid var(--hairline);
  box-shadow:0 30px 70px -20px rgba(234,179,8,.25);
  transform:rotateY(-4deg) rotateX(3deg);
  transition:transform .3s cubic-bezier(.2,.7,.3,1);
  max-width:420px;margin:0 auto;
}
.ap-scale{
  position:relative;height:160px;display:flex;justify-content:center;
  margin-bottom:16px;
}
.ap-scale-pillar{
  position:absolute;left:50%;top:30px;transform:translateX(-50%);
  width:6px;height:90px;
  background:linear-gradient(180deg,#eab308,#b45309);border-radius:3px;
}
.ap-scale-base{
  position:absolute;left:50%;bottom:0;transform:translateX(-50%);
  width:90px;height:8px;
  background:linear-gradient(90deg,#b45309,#eab308,#b45309);border-radius:4px;
}
.ap-scale-bar{
  position:absolute;left:50%;top:30px;transform:translateX(-50%) rotate(-8deg);
  width:220px;height:5px;
  background:linear-gradient(90deg,#b45309,#eab308,#b45309);border-radius:3px;
  transform-origin:center;
  animation:ap-scale-tip 4s ease-in-out infinite;
}
@keyframes ap-scale-tip{
  0%,100%{transform:translateX(-50%) rotate(-8deg)}
  50%{transform:translateX(-50%) rotate(-12deg)}
}
.ap-scale-tray{
  position:absolute;top:60px;width:80px;text-align:center;
  padding:9px;border-radius:10px;
  background:var(--bg-grey);border:1px solid var(--hairline);
}
.ap-scale-tray.l{left:14px;animation:ap-tray-l 4s ease-in-out infinite}
.ap-scale-tray.r{right:14px;animation:ap-tray-r 4s ease-in-out infinite}
@keyframes ap-tray-l{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(12px)}
}
@keyframes ap-tray-r{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}
.ap-tray-label{font-size:9.5px;color:var(--grey);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.ap-tray-num{
  font-size:20px;font-weight:600;color:#92400e;
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  margin-top:2px;
}
.ap-scale-tray.r .ap-tray-num{color:var(--blue)}

.ap-legal-stat{
  text-align:center;font-size:11.5px;font-weight:600;color:var(--grey-2);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;
}
.ap-legal-list{display:flex;flex-direction:column;gap:7px}
.ap-legal-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 12px;border-radius:9px;
  background:var(--bg-grey);font-size:13px;color:var(--grey-2);
}
.ap-legal-row span:first-child{
  font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  color:#92400e;font-weight:600;
}
.ap-legal-row span:last-child{font-weight:500}
.ap-legal-row .hot{color:var(--blue);font-weight:600}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .ap-detail{padding:80px 0}
  .ap-detail-body{grid-template-columns:1fr;gap:60px}
  .ap-detail-body-rev .ap-detail-copy{order:0}
  .ap-detail-body-rev .ap-detail-visual{order:0}
  .ap-float-stat{display:none}
  .ap-detail-phone,.ap-solar-card,.ap-shield-card,
  .ap-rate-card,.ap-auto-card,.ap-cal-card,
  .ap-funnel-card,.ap-legal-card{transform:none}
}
@media (max-width:600px){
  .ap-detail{padding:60px 0}
  .ap-detail-body{gap:40px}
  .ap-detail-head{margin-bottom:40px}
  .ap-detail-h{font-size:clamp(28px,7.5vw,38px);line-height:1.1}
  .ap-detail-tag{font-size:11px;padding:5px 12px;margin-bottom:16px}
  .ap-detail-copy h3{font-size:12px;margin:24px 0 8px}
  .ap-detail-copy p{font-size:15px;line-height:1.55}
  .ap-bigstat{flex-direction:column;align-items:flex-start;text-align:left;gap:12px;padding:18px;border-radius:14px}
  .ap-bignum{font-size:42px}
  .ap-bignum-label{font-size:13.5px}
  .ap-callout{flex-direction:column;align-items:flex-start;gap:14px;padding:16px 18px;margin-top:24px}
  .ap-callout-num{font-size:14px}
  .ap-callout-tag{align-self:flex-start;font-size:12px;padding:6px 12px}
  .ap-shield-card{flex-direction:column;align-items:stretch;text-align:center;padding:22px;gap:18px}
  .ap-shield-svg{margin:0 auto;width:96px}
  .ap-shield-rows{width:100%}
  .ap-bullets li{font-size:14.5px;padding-left:26px}
  .ap-bullets li::before{width:16px;height:16px;top:5px}
  .ap-bullets li::after{left:4px;top:10px;width:7px;height:3.5px}
  /* Detail visual cards: tighten padding and let them fit */
  .ap-detail-visual{min-height:auto}
  .ap-detail-phone,.ap-solar-card,.ap-rate-card,
  .ap-auto-card,.ap-cal-card,.ap-funnel-card,
  .ap-legal-card{padding:20px;border-radius:20px;max-width:100%}
  .ap-detail-phone-name{font-size:19px}
  .ap-detail-phone-msg{font-size:13px;padding:10px 12px}
  .ap-detail-route-step{font-size:12.5px;padding:9px 12px}
  .ap-solar-sun{width:96px;height:96px;margin-bottom:18px}
  .ap-solar-bill-num{font-size:30px}
  .ap-rate-trigger{padding:12px;font-size:12.5px}
  .ap-prog-row{font-size:12.5px;padding:8px 10px}
  .ap-auto-item{padding:10px;gap:10px}
  .ap-auto-title{font-size:13.5px}
  .ap-auto-meta{font-size:11.5px}
  .ap-cal-card{padding:18px;max-width:100%}
  .ap-cal-cell{font-size:11px;border-radius:6px}
  .ap-cal-day{font-size:10px}
  .ap-funnel-row{grid-template-columns:48px 1fr 76px;gap:10px;padding:10px 0}
  .ap-funnel-num{font-size:16px}
  .ap-funnel-row > span:nth-child(2){font-size:12.5px}
  .ap-scale{height:140px}
  .ap-scale-bar{width:180px}
  .ap-scale-tray{width:70px;padding:7px}
  .ap-tray-num{font-size:18px}
  /* Chip row narrower padding */
  .ap-chip-row{margin:18px auto 36px;padding:0 14px 4px}
  .ap-chip-link{font-size:12px;padding:7px 12px 7px 10px}
}
@media (max-width:380px){
  .ap-detail{padding:48px 0}
  .ap-detail-h{font-size:26px}
  .ap-bignum{font-size:36px}
  .ap-detail-phone-name{font-size:17px}
  .ap-solar-bill-num{font-size:26px}
  .ap-shield-svg{width:80px}
}
