/* assets/css/faq.css (MOBILE-FIRST / FLUID / REVIEWS-ALIGNED) */
:root{
  --kc-font: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --kc-bg:#fff7ed;
  --kc-bg2:#fff1f2;

  --kc-text:#0b1220;
  --kc-muted: rgba(11,18,32,.70);

  --kc-aqua:#2bc4e3;
  --kc-pink:#ff2d55;
  --kc-yellow:#ffd66b;
  --kc-purple:#7c5cff;

  --kc-line: rgba(11,18,32,.10);
  --kc-line2: rgba(11,18,32,.08);

  --kc-shadow: 0 18px 60px rgba(11,18,32,.14);
  --kc-shadow2: 0 12px 34px rgba(11,18,32,.10);
  --kc-shadow3: 0 10px 22px rgba(11,18,32,.08);

  --kc-r: 22px;
  --kc-r2: 30px;

  --kc-pad: 16px;
  --kc-wrap: 1120px;
}

/* Base */
*{ box-sizing:border-box; }
html, body{ height:100%; }
html{ overflow-x:hidden; }
body{
  margin:0;
  font-family:var(--kc-font);
  color:var(--kc-text);
  overflow-x:hidden;

  background:
    radial-gradient(1100px 560px at 10% 0%, rgba(255,214,107,.28), transparent 62%),
    radial-gradient(920px 560px at 12% 100%, rgba(43,196,227,.14), transparent 64%),
    radial-gradient(960px 560px at 95% 10%, rgba(124,92,255,.14), transparent 66%),
    radial-gradient(960px 560px at 95% 95%, rgba(255,45,85,.10), transparent 66%),
    linear-gradient(180deg, var(--kc-bg), #ffffff 46%, var(--kc-bg2));
}

.kc-main{
  min-height:60vh;
  isolation:isolate;
  overflow-x:clip;
}

/* Buttons (aligned with reviews.css) */
.kc-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:12px;

  height:56px;
  padding:0 18px;
  border-radius:999px;

  border:1px solid rgba(11,18,32,.10);
  text-decoration:none;
  color:var(--kc-text);

  background:rgba(255,255,255,.80);
  box-shadow:0 12px 26px rgba(11,18,32,.08);

  transition:transform .18s ease, box-shadow .18s ease, filter .18s ease;
  -webkit-tap-highlight-color:transparent;
  user-select:none;

  font-weight:900;
  letter-spacing:-0.02em;
}

.kc-btn:hover{ transform:translateY(-1px); box-shadow:0 18px 52px rgba(11,18,32,.12); }
.kc-btn:active{ transform:translateY(0); filter:saturate(112%); }
.kc-btn:focus-visible{ outline:3px solid rgba(43,196,227,.35); outline-offset:3px; }

.kc-btn__icon{
  width:38px; height:38px;
  border-radius:999px;
  display:grid; place-items:center;
  font-weight:950;
  opacity:.95;
}

.kc-btn--primary{
  border:1px solid rgba(255,255,255,.64);
  color:#0b1220;
  background:
    radial-gradient(140px 140px at 18% 50%, rgba(255,255,255,.42), transparent 64%),
    linear-gradient(90deg, rgba(43,196,227,1) 0%, rgba(255,45,85,1) 100%);
}
.kc-btn--primary .kc-btn__icon{
  background:rgba(255,255,255,.22);
  border:1px solid rgba(255,255,255,.40);
  box-shadow:0 10px 22px rgba(11,18,32,.14);
}

.kc-btn--soft{ background:rgba(255,255,255,.78); }
.kc-btn--soft .kc-btn__icon{
  background:rgba(11,18,32,.05);
  border:1px solid rgba(11,18,32,.10);
}
.kc-btn--wide{ width:100%; }

/* =========================
   HERO (CENTERED / FLUID)
   ========================= */
.kc-faqHero{
  position:relative;
  padding:54px 0 18px;
  border-bottom:1px solid var(--kc-line);
}

.kc-faqHero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(780px 320px at 50% 16%, rgba(255,255,255,.68), transparent 72%),
    radial-gradient(980px 420px at 10% 20%, rgba(255,214,107,.26), transparent 66%),
    radial-gradient(980px 420px at 96% 18%, rgba(124,92,255,.14), transparent 66%);
  opacity:.9;
}

.kc-faqHero__inner{
  width:min(var(--kc-wrap), calc(100% - (var(--kc-pad) * 2)));
  margin:0 auto;
  text-align:center;
  position:relative;
}

.kc-faqHero__badge{
  display:inline-flex;
  align-items:center;
  gap:10px;

  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(11,18,32,.08);
  background:rgba(255,255,255,.88);
  color:rgba(11,18,32,.84);

  font-weight:900;
  font-size:13px;
  letter-spacing:.01em;

  box-shadow:0 10px 22px rgba(11,18,32,.06);
}

.kc-faqHero__dot{
  width:10px; height:10px;
  border-radius:999px;
  background:var(--kc-aqua);
  box-shadow:0 0 0 4px rgba(43,196,227,.16);
}

.kc-faqHero__title{
  margin:16px auto 10px;
  font-size:clamp(36px, 9vw, 80px);
  line-height:1.01;
  letter-spacing:-0.065em;
  font-weight:950;
  max-width:18ch;
}

.kc-faqHero__title::after{
  content:"";
  display:block;
  width:min(310px, 72vw);
  height:10px;
  margin:14px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(43,196,227,.55), rgba(255,45,85,.55));
  opacity:.72;
}

.kc-faqHero__lead{
  margin:14px auto 0;
  max-width:72ch;

  font-size:15px;
  font-weight:650;
  line-height:1.85;
  color:var(--kc-muted);

  padding:16px 16px;
  border-radius:20px;
  border:1px solid rgba(11,18,32,.08);
  background:rgba(255,255,255,.66);
  box-shadow:0 12px 28px rgba(11,18,32,.08);
}

.kc-faqHero__ctaRow{
  margin:16px auto 0;
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:stretch;
  max-width:520px;
}
.kc-faqHero__ctaRow .kc-btn{
  justify-content:space-between;
  padding-left:18px;
  padding-right:10px;
}
.kc-faqHero__ctaRow .kc-btn > span:first-child{
  text-align:left;
}

/* Chips (clean + fluid) */
.kc-faqHero__chips{
  margin:14px auto 0;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
}

.kc-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;

  padding:10px 12px;
  border-radius:999px;

  border:1px solid rgba(11,18,32,.08);
  background:rgba(255,255,255,.78);
  box-shadow:0 12px 26px rgba(11,18,32,.06);

  font-weight:900;
  letter-spacing:-0.02em;
  color:rgba(11,18,32,.78);
}

.kc-chip__dot{
  width:10px; height:10px; border-radius:999px;
}

.kc-chip__dot--a{
  background:linear-gradient(135deg, var(--kc-aqua), var(--kc-purple));
  box-shadow:0 0 0 4px rgba(43,196,227,.14);
}
.kc-chip__dot--b{
  background:linear-gradient(135deg, var(--kc-yellow), var(--kc-pink));
  box-shadow:0 0 0 4px rgba(255,214,107,.16);
}
.kc-chip__dot--c{
  background:linear-gradient(135deg, var(--kc-pink), var(--kc-purple));
  box-shadow:0 0 0 4px rgba(255,45,85,.12);
}

/* =========================
   SECTION
   ========================= */
.kc-faq{
  padding:18px 0 60px;
}

.kc-faq__inner{
  width:min(var(--kc-wrap), calc(100% - (var(--kc-pad) * 2)));
  margin:0 auto;
  display:grid;
  gap:14px;
}

/* Accordion shell (premium card) */
.kc-accordion{
  border-radius:var(--kc-r2);
  border:1px solid rgba(11,18,32,.10);
  background:
    radial-gradient(920px 360px at 12% 0%, rgba(43,196,227,.12), transparent 62%),
    radial-gradient(920px 360px at 100% 100%, rgba(255,45,85,.08), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.62));
  box-shadow:var(--kc-shadow2);
  overflow:hidden;
}

/* Item */
.kc-qa{
  border-top:1px solid rgba(11,18,32,.08);
}
.kc-qa:first-child{ border-top:none; }

/* Question button */
.kc-qa__q{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;

  padding:16px 14px;
  background:transparent;
  border:0;
  cursor:pointer;

  font-family:inherit;
  font-weight:950;
  letter-spacing:-0.03em;
  color:rgba(11,18,32,.92);
  text-align:left;
  line-height:1.25;
}

.kc-qa__q span:first-child{
  flex:1 1 auto;
}

.kc-qa__q:hover .kc-qa__icon{
  transform:translateY(-1px);
  box-shadow:0 14px 30px rgba(11,18,32,.12);
}

.kc-qa__q:focus-visible{
  outline:3px solid rgba(43,196,227,.28);
  outline-offset:-3px;
  border-radius:16px;
}

/* Plus pill */
.kc-qa__icon{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:999px;

  background:rgba(255,255,255,.88);
  border:1px solid rgba(11,18,32,.10);
  box-shadow:0 10px 22px rgba(11,18,32,.10);

  font-weight:950;
  transition:transform .22s ease, box-shadow .22s ease;
  flex:0 0 auto;
}

/* Answer (JS sets --h; we animate fluidly) */
.kc-qa__a{
  padding:0 14px;
  color:var(--kc-muted);
  font-weight:650;
  line-height:1.85;
  font-size:15px;

  max-height:0;
  opacity:0;
  transform:translateY(-4px);
  overflow:hidden;

  transition:
    max-height .34s cubic-bezier(.2,.8,.2,1),
    opacity .22s ease,
    transform .22s ease,
    padding .22s ease;
  will-change:max-height, opacity, transform;
}

.kc-qa.is-open .kc-qa__a{
  max-height:var(--h, 240px);
  opacity:1;
  transform:translateY(0);
  padding:0 14px 16px;
}

.kc-qa.is-open .kc-qa__icon{
  transform:rotate(45deg);
}

/* CTA card */
.kc-faqCta{
  border-radius:var(--kc-r2);
  border:1px solid rgba(11,18,32,.10);
  background:
    radial-gradient(900px 340px at 10% 10%, rgba(255,214,107,.20), transparent 62%),
    radial-gradient(900px 340px at 100% 90%, rgba(124,92,255,.14), transparent 62%),
    rgba(255,255,255,.80);
  box-shadow:var(--kc-shadow);
  padding:16px;
  display:grid;
  gap:12px;
}

.kc-faqCta__copy{ text-align:left; }

.kc-faqCta__title{
  margin:0;
  font-size:18px;
  letter-spacing:-0.03em;
  font-weight:950;
}

.kc-faqCta__text{
  margin:8px 0 0;
  color:var(--kc-muted);
  font-weight:650;
  line-height:1.85;
  font-size:15px;
}

.kc-faqCta__actions{
  display:grid;
  gap:10px;
}

/* Local SEO card */
.kc-localSeo{
  border-radius:var(--kc-r2);
  border:1px solid rgba(11,18,32,.08);
  background:rgba(255,255,255,.74);
  box-shadow:var(--kc-shadow3);
  padding:16px;
}

.kc-localSeo__title{
  margin:0;
  font-size:16px;
  letter-spacing:-0.03em;
  font-weight:950;
}

.kc-localSeo__text{
  margin:10px 0 0;
  color:var(--kc-muted);
  line-height:1.85;
  font-weight:650;
  font-size:15px;
}

/* =========================
   BREAKPOINTS
   ========================= */
@media (max-width: 380px){
  .kc-btn{ width:100%; }
}

@media (min-width: 560px){
  :root{ --kc-pad: 18px; }

  .kc-faqHero{ padding:66px 0 18px; }

  .kc-faqHero__ctaRow{
    flex-direction:row;
    justify-content:center;
    align-items:center;
    max-width:none;
  }

  .kc-faqHero__ctaRow .kc-btn{
    min-width:240px;
    justify-content:center;
    padding-right:16px;
  }
  .kc-faqHero__ctaRow .kc-btn > span:first-child{ text-align:center; }

  .kc-qa__q{ padding:18px 18px; }
  .kc-qa__a{ padding:0 18px; }
  .kc-qa.is-open .kc-qa__a{ padding:0 18px 18px; }

  .kc-faqCta__actions{ grid-template-columns:1fr 1fr; }
}

@media (min-width: 960px){
  :root{ --kc-pad: 22px; }

  .kc-faqHero{ padding:86px 0 22px; }
  .kc-faq__inner{ gap:16px; }

  .kc-accordion{ }
  .kc-faqCta{ padding:18px; }
  .kc-localSeo{ padding:18px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .kc-btn, .kc-qa__icon, .kc-qa__a{ transition:none !important; }
}
