/* =====================================================================
   CyberX legal pages v9
   Единый стиль юридических страниц + подробные документы.
===================================================================== */

.legal-page{
  position:relative;
  overflow:hidden;
  padding:clamp(90px, 10vw, 140px) 0 clamp(78px, 8vw, 118px);
}

.legal-page::before,
.legal-page::after{
  content:"";
  position:absolute;
  pointer-events:none;
  border-radius:50%;
  filter:blur(42px);
  opacity:.45;
}

.legal-page::before{
  width:380px;
  height:380px;
  right:-130px;
  top:70px;
  background:rgba(255,0,51,.32);
}

.legal-page::after{
  width:300px;
  height:300px;
  left:-130px;
  bottom:38px;
  background:rgba(255,255,255,.055);
}

.legal-layout{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:minmax(0, 1fr) 280px;
  gap:24px;
  align-items:start;
}

.legal-card,
.legal-nav{
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:
    radial-gradient(520px 240px at 100% 0, rgba(255,0,51,.14), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.018)),
    var(--surface);
  box-shadow:var(--shadow-card);
}

.legal-card{
  padding:clamp(26px, 4vw, 48px);
}

.legal-nav{
  position:sticky;
  top:98px;
  padding:18px;
}

.legal-nav h3{
  margin:0 0 12px;
  font-family:var(--font-display);
  font-size:.86rem;
  line-height:1.2;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.legal-nav a{
  display:block;
  padding:10px 12px;
  border-radius:12px;
  color:var(--muted);
  font-size:.9rem;
  line-height:1.35;
  text-decoration:none;
  transition:background .2s var(--ease), color .2s var(--ease), transform .2s var(--ease);
}

.legal-nav a:hover{
  color:var(--text);
  background:rgba(255,0,51,.10);
  transform:translateX(2px);
}

.legal-card .eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:16px;
  padding:7px 12px;
  border:1px solid rgba(255,0,51,.45);
  border-radius:999px;
  color:var(--red);
  background:rgba(255,0,51,.08);
  font-family:var(--font-display);
  font-size:.76rem;
  font-weight:800;
  letter-spacing:.13em;
  text-transform:uppercase;
}

.legal-card h1{
  margin:0 0 16px;
  font-family:var(--font-display);
  font-size:clamp(2rem, 5vw, 4rem);
  line-height:1.04;
  font-weight:800;
  letter-spacing:-.055em;
  text-wrap:balance;
}

.legal-card .lead{
  max-width:830px;
  margin:0 0 28px;
  color:var(--text-soft);
  font-size:clamp(1rem, 1.2vw, 1.12rem);
  line-height:1.72;
}

.legal-meta{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
  margin:0 0 28px;
}

.legal-meta__item{
  padding:14px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(255,255,255,.04);
}

.legal-meta__item span{
  display:block;
  color:var(--muted-2);
  font-size:.74rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.legal-meta__item b{
  display:block;
  margin-top:5px;
  color:var(--text);
  font-size:.95rem;
}

.legal-section{
  scroll-margin-top:110px;
  padding:28px 0;
  border-top:1px solid rgba(255,255,255,.09);
}

.legal-section h2{
  margin:0 0 14px;
  font-family:var(--font-display);
  font-size:clamp(1.22rem, 2.2vw, 1.72rem);
  line-height:1.18;
  font-weight:800;
  letter-spacing:-.04em;
}

.legal-section h3{
  margin:18px 0 8px;
  font-family:var(--font-display);
  font-size:1.02rem;
  font-weight:800;
  line-height:1.25;
}

.legal-section p,
.legal-section li{
  color:var(--muted);
  font-size:var(--fs-base);
  line-height:1.76;
}

.legal-section p{
  margin:0 0 12px;
}

.legal-section ul,
.legal-section ol{
  margin:12px 0 0;
  padding-left:20px;
}

.legal-section li + li{
  margin-top:8px;
}

.legal-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:16px;
}

.legal-mini-card{
  padding:18px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(255,255,255,.04);
}

.legal-mini-card h3{
  margin-top:0;
}

.legal-callout{
  margin:22px 0 0;
  padding:18px 18px 18px 20px;
  border:1px solid rgba(255,0,51,.28);
  border-left:3px solid var(--red);
  border-radius:18px;
  background:rgba(255,0,51,.075);
  color:var(--text-soft);
}

.legal-callout b{
  display:block;
  margin-bottom:6px;
  font-family:var(--font-display);
  color:var(--text);
  font-size:.92rem;
  letter-spacing:-.02em;
}

.legal-table-wrap{
  overflow:auto;
  margin-top:16px;
  border:1px solid var(--line);
  border-radius:18px;
}

.legal-table{
  width:100%;
  min-width:620px;
  border-collapse:collapse;
}

.legal-table th,
.legal-table td{
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
  vertical-align:top;
  text-align:left;
}

.legal-table th{
  background:rgba(255,255,255,.045);
  color:var(--text);
  font-family:var(--font-display);
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.legal-table td{
  color:var(--muted);
  line-height:1.6;
}

.legal-table tr:last-child td{
  border-bottom:0;
}

.legal-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:34px;
}

.legal-muted{
  color:var(--muted-2) !important;
  font-size:.92rem !important;
}

@media (max-width:980px){
  .legal-layout{
    grid-template-columns:1fr;
  }

  .legal-nav{
    position:relative;
    top:auto;
    order:-1;
  }

  .legal-nav__links{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }

  .legal-nav a{
    border:1px solid var(--line);
  }
}

@media (max-width:720px){
  .legal-meta,
  .legal-grid{
    grid-template-columns:1fr;
  }

  .legal-card{
    border-radius:24px;
  }
}

/* =====================================================================
   v10 — компактные юридические страницы без вылезания длинных строк
===================================================================== */
.legal-page{
  padding:clamp(76px, 8vw, 116px) 0 clamp(62px, 7vw, 96px);
}

.legal-layout{
  grid-template-columns:minmax(0, 1fr) 260px;
  gap:20px;
}

.legal-card{
  padding:clamp(22px, 3.4vw, 40px);
}

.legal-nav{
  padding:16px;
}

.legal-card h1{
  font-size:clamp(1.65rem, 4vw, 3rem);
  line-height:1.06;
  letter-spacing:-.05em;
}

.legal-card .lead{
  font-size:clamp(.9rem, 1.02vw, 1rem);
  line-height:1.6;
}

.legal-card .eyebrow,
.legal-nav h3,
.legal-table th,
.legal-meta__item span{
  font-size:.68rem;
}

.legal-nav a{
  font-size:.82rem;
  line-height:1.32;
  padding:9px 10px;
}

.legal-meta{
  gap:10px;
}

.legal-meta__item{
  padding:12px;
}

.legal-meta__item b{
  font-size:.86rem;
  line-height:1.32;
}

.legal-section{
  padding:23px 0;
}

.legal-section h2{
  font-size:clamp(1.06rem, 1.75vw, 1.42rem);
  line-height:1.2;
}

.legal-section h3{
  font-size:.94rem;
  line-height:1.24;
}

.legal-section p,
.legal-section li,
.legal-table td{
  font-size:.88rem;
  line-height:1.62;
}

.legal-mini-card{
  padding:15px;
}

.legal-callout{
  padding:15px 15px 15px 17px;
  font-size:.88rem;
  line-height:1.58;
}

.legal-callout b{
  font-size:.86rem;
}

.legal-table th,
.legal-table td{
  padding:12px 14px;
}

.legal-muted{
  font-size:.82rem !important;
}

@media (max-width:980px){
  .legal-layout{
    grid-template-columns:1fr;
  }
}

@media (max-width:720px){
  .legal-card{
    border-radius:22px;
  }

  .legal-card h1{
    font-size:clamp(1.5rem, 8vw, 2.25rem);
  }
}
