/* ATX Decon — home + section layouts */

/* ---------- Hero (full-bleed background image) ---------- */
.hero-bg { position: relative; padding: 96px 0 110px; overflow: hidden; isolation: isolate; min-height: 640px; display: flex; align-items: center; }
.hero-bg-img {
  position: absolute; inset: 0; z-index: -3;
  background-image: url("assets/hero-ba.png");
  background-size: cover;
  background-position: center;
}
.hero-scrim {
  position: absolute; inset: 0; z-index: -2;
  background:
    linear-gradient(90deg, rgba(8,26,48,.92) 0%, rgba(8,26,48,.80) 42%, rgba(8,26,48,.40) 70%, rgba(8,26,48,.30) 100%),
    linear-gradient(180deg, rgba(8,26,48,.45) 0%, rgba(8,26,48,0) 30%, rgba(8,26,48,.55) 100%);
}
.hero-bg-inner { position: relative; width: 100%; }
.hero-bg .hero-copy { max-width: 660px; }
.hero-bg .display { color: #fff; }
.hero-bg .lead { color: rgba(238,244,252,.92); }
.hero-bg .eyebrow { color: var(--violet-bright); }
.hero-bg .chip { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.22); color: #fff; }
.hero-bg .chip i { color: #fff; }
.hero-bg .btn-outline { color: #fff; border-color: var(--violet-bright); }
.hero-bg .btn-outline:hover { background: rgba(138,95,176,.2); border-color: var(--violet-bright); }
.phero .btn-outline { color: #fff; border-color: var(--violet-bright); }
.phero .btn-outline:hover { background: rgba(138,95,176,.2); border-color: var(--violet-bright); }
.hero-actions { display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
.hero-trust { margin-top: 28px; }
.hero-badge {
  position: absolute; right: 0; bottom: 0;
  display: flex; align-items: center; gap: 13px;
  padding: 16px 20px; background: #fff;
  box-shadow: var(--shadow-lg);
  border-left: 3px solid var(--violet);
}
.hero-badge-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--safe); box-shadow: 0 0 0 4px var(--safe-soft); flex-shrink: 0; }
.hero-badge-strong { font-family: var(--font-display); font-size: 18px; font-weight: 600; color: var(--ink); }
.hero-badge-strong span { font-family: var(--font-sans); font-size: 13px; font-weight: 400; color: var(--slate); }
@media (max-width: 760px){
  .hero-bg { padding: 72px 0 96px; min-height: 0; }
  .hero-scrim { background: linear-gradient(180deg, rgba(8,26,48,.78) 0%, rgba(8,26,48,.62) 50%, rgba(8,26,48,.82) 100%); }
  .hero-badge { position: static; margin-top: 36px; display: inline-flex; }
}

/* ---------- Section head ---------- */
.sec-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; }
.sec-head-aside { max-width: 380px; margin-bottom: 4px; }
@media (max-width: 820px){ .sec-head { flex-direction: column; align-items: flex-start; gap: 16px; } }

/* ---------- Services "also" tags ---------- */
.svc-more { margin-top: 36px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding-top: 30px; border-top: 1px solid var(--line); }
.svc-more-tag { background: none; border: 1px solid var(--line-2); border-radius: var(--radius-pill); padding: 8px 16px; font-size: 14px; font-weight: 500; color: var(--ink); transition: border-color .15s, color .15s; }
.svc-more-tag:hover { border-color: var(--violet); color: var(--violet); }

/* ---------- Why ---------- */
.why-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.why-points { margin-top: 30px; display: flex; flex-direction: column; gap: 16px; }
.why-point { display: flex; align-items: center; gap: 14px; font-size: 16px; color: var(--on-dark); font-weight: 500; }
.why-point i { width: 38px; height: 38px; border-radius: 10px; background: rgba(138,95,176,.22); color: var(--violet-bright); display: grid; place-items: center; flex-shrink: 0; }
.why-stats { padding-left: 20px; }
@media (max-width: 900px){ .why-inner { grid-template-columns: 1fr; gap: 40px; } .why-stats { padding-left: 0; } }

/* ---------- Restore / before-after ---------- */
.restore-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.restore-media { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.restore-media image-slot:last-child { margin-top: 36px; }
.check-list { list-style: none; padding: 0; margin: 28px 0 0; display: flex; flex-direction: column; gap: 14px; }
.check-list li { display: flex; align-items: flex-start; gap: 13px; font-size: 16px; color: var(--ink); }
.check-list i { color: var(--safe); font-size: 18px; margin-top: 2px; flex-shrink: 0; }
@media (max-width: 900px){ .restore-inner { grid-template-columns: 1fr; gap: 36px; } }

/* ---------- Testimonial ---------- */
.quote-stars { display: flex; gap: 6px; justify-content: center; color: var(--accent); font-size: 17px; }
.quote { font-family: var(--font-display); font-size: clamp(23px, 3vw, 32px); font-weight: 400; line-height: 1.32; color: var(--ink); margin: 22px 0 26px; text-wrap: balance; }
.quote-by { display: flex; flex-direction: column; gap: 6px; align-items: center; }
.quote-name { font-weight: 700; font-size: 16px; color: var(--ink); }
.quote-meta { color: var(--slate-2); }

/* ---------- Area ---------- */
.area-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.area-tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.area-tag { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 500; color: var(--ink); background: var(--paper-soft); border: 1px solid var(--line); border-radius: var(--radius-pill); padding: 7px 14px; }
.area-tag i { color: var(--violet); font-size: 11px; }
@media (max-width: 900px){ .area-inner { grid-template-columns: 1fr; gap: 36px; } }

/* ---------- FAQ layout ---------- */
.faq-wrap { display: grid; grid-template-columns: .85fr 1.15fr; gap: 56px; align-items: start; }
.faq-head { position: sticky; top: 100px; }
.faq-call { margin-top: 26px; }
@media (max-width: 900px){ .faq-wrap { grid-template-columns: 1fr; gap: 28px; } .faq-head { position: static; } }

/* ---------- Page hero (interior) ---------- */
/* ---------- Page hero (interior) — full-bleed image ---------- */
.phero { position: relative; overflow: hidden; isolation: isolate; color: var(--on-dark); padding: 88px 0 96px; min-height: 460px; display: flex; align-items: center; }
.phero > .wrap { width: 100%; }
.phero-img { position: absolute; inset: 0; z-index: -3; background-size: cover; background-position: center; }
.phero-scrim {
  position: absolute; inset: 0; z-index: -2;
  background:
    linear-gradient(90deg, rgba(8,26,48,.94) 0%, rgba(8,26,48,.82) 44%, rgba(8,26,48,.46) 72%, rgba(8,26,48,.34) 100%),
    linear-gradient(180deg, rgba(8,26,48,.42) 0%, rgba(8,26,48,0) 34%, rgba(8,26,48,.5) 100%);
}
.phero-inner { position: relative; width: 100%; max-width: 660px; }
.phero h1 { color: #fff; margin-top: 20px; }
.phero .lead { color: rgba(238,244,252,.92); margin-top: 18px; }
.phero-actions { display: flex; gap: 14px; margin-top: 30px; flex-wrap: wrap; }
.crumb { font-family: var(--font-mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--on-dark-mute); display: flex; align-items: center; gap: 10px; }
.crumb button { background: none; border: 0; color: var(--on-dark-mute); font-family: inherit; font-size: inherit; letter-spacing: inherit; }
.crumb button:hover { color: var(--violet-bright); }
.crumb i { font-size: 9px; }
@media (max-width: 760px){ .phero { padding: 64px 0 72px; min-height: 0; } }
.phero-contact { align-items: center; }
.phero-contact .phero-contact-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 48px; align-items: center; width: 100%; max-width: none; position: relative; }
@media (max-width: 880px){ .phero-contact .phero-contact-grid { grid-template-columns: 1fr; gap: 32px; } }

/* ---------- Service detail blocks ---------- */
.svc-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 880px){ .svc-intro { grid-template-columns: 1fr; gap: 36px; } }
.incl-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 44px; }
@media (max-width: 680px){ .incl-grid { grid-template-columns: 1fr; } }
.incl { display: flex; gap: 16px; padding: 24px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); }
.incl i { width: 44px; height: 44px; border-radius: 11px; background: var(--violet-soft); color: var(--violet); display: grid; place-items: center; font-size: 17px; flex-shrink: 0; }
.incl h4 { font-family: var(--font-display); font-size: 18px; font-weight: 500; margin-bottom: 6px; }
.incl p { font-size: 14.5px; color: var(--slate); }

/* ---------- Signs / list cards ---------- */
.signs { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 44px; }
@media (max-width: 760px){ .signs { grid-template-columns: 1fr; } }
.sign { padding: 26px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--paper-soft); }
.sign i { color: var(--violet); font-size: 20px; }
.sign h4 { font-family: var(--font-display); font-size: 19px; font-weight: 500; margin: 14px 0 8px; }
.sign p { font-size: 15px; color: var(--slate); }
