/* assets/css/legal.css (INDEX-ALIGNED / MOBILE-FIRST) */
/* Nav + Footer are intentionally NOT styled here. */

:root{
  --kc-font: "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --kc-bg:#fff7ed;
  --kc-bg2:#fff1f2;

  --kc-ink:#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-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;
}

*{ box-sizing:border-box; }
html{ overflow-x:hidden; }
body{
  margin:0;
  font-family:var(--kc-font);
  color:var(--kc-ink);
  overflow-x:hidden;

  background:
    radial-gradient(1000px 520px at 10% 0%, rgba(255,214,107,.30), transparent 60%),
    radial-gradient(900px 520px at 10% 100%, rgba(43,196,227,.16), transparent 62%),
    radial-gradient(900px 520px at 95% 20%, rgba(124,92,255,.14), transparent 64%),
    radial-gradient(900px 520px at 95% 95%, rgba(255,45,85,.10), transparent 64%),
    linear-gradient(180deg, var(--kc-bg), #ffffff 42%, var(--kc-bg2));
}

.kc-main{
  isolation:isolate;
  overflow-x:clip;
}

/* shared button tokens (minimal) */
.kc-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  height:52px;
  padding:0 16px;
  border-radius:999px;
  border:1px solid var(--kc-line);
  text-decoration:none;
  color:var(--kc-ink);
  background:rgba(255,255,255,.78);
  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(110%); }
.kc-btn:focus-visible{ outline:3px solid rgba(43,196,227,.35); outline-offset:3px; }
.kc-btn__icon{ opacity:.9; font-weight:900; }
.kc-btn--primary{
  color:#0b1220;
  border:1px solid rgba(255,255,255,.58);
  background:
    radial-gradient(140px 140px at 14% 50%, rgba(255,255,255,.38), transparent 62%),
    linear-gradient(90deg, rgba(43,196,227,1) 0%, rgba(255,45,85,1) 100%);
}
.kc-btn--soft{ background:rgba(255,255,255,.70); }
.kc-btn--wide{ width:100%; }

/* Hero */
.kc-legalHero{
  padding:34px 0 14px;
  border-bottom:1px solid var(--kc-line);
  position:relative;
}
.kc-legalHero::before{
  content:"";
  position:absolute;
  inset:-120px -120px auto -120px;
  height:260px;
  background:
    radial-gradient(closest-side, rgba(255,255,255,.72), transparent 70%),
    radial-gradient(closest-side, rgba(43,196,227,.18), transparent 72%);
  opacity:.50;
  pointer-events:none;
}

.kc-legalHero__inner{
  width:min(var(--kc-wrap), calc(100% - (var(--kc-pad) * 2)));
  margin:0 auto;
  padding:16px;
  border-radius:var(--kc-r2);
  border:1px solid rgba(11,18,32,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.58));
  box-shadow:var(--kc-shadow2);
  position:relative;
  text-align:center;
}

.kc-legalHero__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,.86);
  color:rgba(11,18,32,.82);
  font-weight:900;
  font-size:13px;
  letter-spacing:.01em;
}

.kc-legalHero__dot{
  width:10px; height:10px; border-radius:999px;
  background:var(--kc-aqua);
  box-shadow:0 0 0 4px rgba(43,196,227,.14);
}

.kc-legalHero__title{
  margin:14px 0 10px;
  font-size:clamp(34px, 8.2vw, 58px);
  letter-spacing:-0.06em;
  line-height:1.02;
  font-weight:950;
}

.kc-legalHero__title::after{
  content:"";
  display:block;
  width:min(220px, 62vw);
  height:10px;
  margin:12px auto 0;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(43,196,227,.55), rgba(255,45,85,.55));
  opacity:.65;
}

.kc-legalHero__lead{
  margin:0 auto;
  max-width:66ch;
  font-size:15px;
  color:var(--kc-muted);
  font-weight:650;
  line-height:1.85;
  background:rgba(255,255,255,.46);
  border:1px solid rgba(11,18,32,.06);
  border-radius:18px;
  padding:14px;
  box-shadow:0 10px 26px rgba(11,18,32,.06);
}

.kc-legalHero__actions{
  margin-top:12px;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
}

.kc-legalPill{
  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,.72);
  box-shadow:0 12px 26px rgba(11,18,32,.06);
  font-weight:900;
  letter-spacing:-0.02em;
  color:rgba(11,18,32,.80);
  text-decoration:none;
}

/* Content */
.kc-legal{
  padding:18px 0 52px;
}

.kc-legal__inner{
  width:min(var(--kc-wrap), calc(100% - (var(--kc-pad) * 2)));
  margin:0 auto;
  display:grid;
  gap:14px;
}

.kc-legalCard{
  border-radius:var(--kc-r2);
  border:1px solid rgba(11,18,32,.10);
  background:rgba(255,255,255,.78);
  box-shadow:var(--kc-shadow2);
  padding:16px;
}

.kc-legalCard h2{
  margin:16px 0 8px;
  font-size:16px;
  letter-spacing:-0.03em;
  font-weight:950;
}
.kc-legalCard h2:first-child{ margin-top:0; }

.kc-legalCard p{
  margin:0;
  color:var(--kc-muted);
  font-weight:650;
  line-height:1.85;
  font-size:15px;
}
.kc-legalCard a{
  color:rgba(11,18,32,.92);
  text-decoration:underline;
  text-underline-offset:3px;
}

/* CTA */
.kc-legalCta{
  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,.78);
  box-shadow:var(--kc-shadow);
  padding:16px;
  display:grid;
  gap:12px;
}

.kc-legalCta__title{
  margin:0;
  font-size:18px;
  letter-spacing:-0.03em;
  font-weight:950;
}

.kc-legalCta__text{
  margin:8px 0 0;
  color:var(--kc-muted);
  font-weight:650;
  line-height:1.85;
  font-size:15px;
}

.kc-legalCta__actions{
  display:grid;
  gap:10px;
}

@media (max-width: 380px){
  .kc-btn{ width:100%; }
}

@media (min-width: 560px){
  :root{ --kc-pad: 18px; }
  .kc-legalHero{ padding:42px 0 16px; }
  .kc-legalHero__inner{ padding:18px; }
  .kc-legalCta__actions{ grid-template-columns:1fr 1fr; }
}

@media (min-width: 960px){
  :root{ --kc-pad: 22px; }
  .kc-legalHero{ padding:56px 0 18px; }
  .kc-legal__inner{ gap:16px; }
}
