@font-face {
  font-family: "Onest Local";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("/assets/fonts/onest/onest-cyrillic.woff2") format("woff2");
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
  font-family: "Onest Local";
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url("/assets/fonts/onest/onest-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --ac-navy: #1f2530;
  --ac-deep: #111823;
  --ac-ink: #222733;
  --ac-muted: #66707d;
  --ac-paper: #fffdf8;
  --ac-milk: #f4ecdf;
  --ac-soft: #faf5eb;
  --ac-gold: #cdb178;
  --ac-gold-dark: #8f682e;
  --ac-line: rgba(31, 37, 48, .13);
  --ac-light-line: rgba(255, 255, 255, .14);
  --ac-shadow: 0 18px 48px rgba(19, 24, 34, .08);
}

.arg-ciudadania-page {
  margin: 0;
  min-width: 320px;
  overflow-x: hidden;
  background: var(--ac-paper);
  color: var(--ac-ink);
  font-family: "Onest Local", Inter, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.55;
}

.arg-ciudadania-page * { box-sizing: border-box; }
.arg-ciudadania-page a { color: inherit; text-decoration: none; }
.arg-ciudadania-page button,
.arg-ciudadania-page input,
.arg-ciudadania-page textarea { font: inherit; }
.arg-ciudadania-page [hidden] { display: none !important; }

.ac-shell {
  width: min(100% - 40px, 1180px);
  margin: 0 auto;
}

.ac-section {
  padding: 56px 0;
  background: var(--ac-paper);
}

.ac-section--milk { background: var(--ac-milk); }
.ac-section--soft { background: var(--ac-soft); }
.ac-section--warning { background: #f8efe2; }
.ac-section--dark {
  background:
    radial-gradient(circle at 80% 12%, rgba(205, 177, 120, .13), transparent 34%),
    linear-gradient(180deg, var(--ac-navy), var(--ac-deep));
  color: #fff;
}

.ac-kicker {
  margin: 0 0 14px;
  color: var(--ac-gold);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.ac-hero {
  padding: 56px 0 64px;
  background:
    radial-gradient(circle at 86% 8%, rgba(205, 177, 120, .15), transparent 32%),
    linear-gradient(180deg, #252c38 0%, #111923 100%);
  color: #fff;
}

.ac-hero__grid,
.ac-form-grid,
.ac-two,
.ac-practice,
.ac-price-grid,
.ac-final__grid {
  display: grid;
  gap: 28px;
}

.ac-hero h1,
.ac-section h2 {
  margin: 0;
  font-weight: 680;
  letter-spacing: -.035em;
}

.ac-hero h1 {
  max-width: 12ch;
  font-size: clamp(40px, 11vw, 48px);
  line-height: 1.04;
}

.ac-section h2 {
  font-size: clamp(30px, 8vw, 40px);
  line-height: 1.1;
}

.ac-lead {
  max-width: 720px;
  margin: 22px 0 0;
  color: rgba(255, 255, 255, .78);
  font-size: 17px;
}

.ac-actions {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.ac-btn {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 22px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.15;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.ac-btn--primary {
  border: 1px solid var(--ac-gold);
  background: var(--ac-gold);
  color: #171b22;
}

.ac-btn--secondary {
  border: 1px solid rgba(255, 255, 255, .24);
  color: #fff;
  background: rgba(255, 255, 255, .04);
}

.ac-btn--dark {
  width: 100%;
  margin-top: 24px;
  border: 1px solid rgba(31, 37, 48, .18);
  background: var(--ac-navy);
  color: #fff !important;
}

.ac-btn--light {
  border: 1px solid rgba(31, 37, 48, .16);
  background: rgba(255, 255, 255, .68);
  color: var(--ac-navy);
}

.ac-note {
  margin: 14px 0 0;
  color: var(--ac-muted);
  font-size: 13px;
  line-height: 1.45;
}

.ac-note--hero { color: rgba(255, 255, 255, .58); }

.ac-card {
  min-width: 0;
  border: 1px solid var(--ac-line);
  border-radius: 20px;
  background: rgba(255, 255, 255, .95);
  box-shadow: var(--ac-shadow);
  padding: 22px;
}

.ac-step span {
  color: var(--ac-gold);
  font-size: 12px;
  font-weight: 700;
}

.ac-card h2,
.ac-card h3 {
  margin: 10px 0 0;
  font-size: 20px;
  line-height: 1.18;
  font-weight: 670;
}

.ac-card p,
.ac-section p {
  overflow-wrap: anywhere;
}

.ac-dark-card,
.ac-section--dark p {
  color: rgba(255, 255, 255, .76);
}

.ac-head {
  max-width: 820px;
  margin-bottom: 26px;
}

.ac-head .ac-kicker {
  margin: 0 0 14px;
}

.ac-head p:not(.ac-kicker) {
  margin: 14px 0 0;
  color: var(--ac-muted);
}

.ac-form-grid p,
.ac-two p,
.ac-price-grid p {
  color: var(--ac-muted);
}

.ac-form {
  display: grid;
  gap: 14px;
}

.ac-form > *,
.ac-form label,
.ac-form__wide {
  min-width: 0;
}

.ac-hero-form {
  border-color: rgba(255, 255, 255, .16);
  background: rgba(17, 24, 35, .82);
  color: #f7e7ce;
  box-shadow: 0 28px 70px rgba(0, 0, 0, .22);
}

.ac-hero-form h2 {
  margin: 0 0 4px;
  color: #fff;
  font-size: clamp(16px, 4.2vw, 24px);
  line-height: 1.12;
  white-space: nowrap;
  letter-spacing: -.04em;
}

.ac-hero-form .ac-btn--secondary {
  border-color: rgba(247, 231, 206, .24);
  background: rgba(255, 255, 255, .04);
  color: #f7e7ce;
}

.ac-form label {
  display: grid;
  gap: 7px;
  color: rgba(247, 231, 206, .82);
  font-size: 13px;
  font-weight: 700;
}

.ac-form input,
.ac-form textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid rgba(247, 231, 206, .22);
  border-radius: 14px;
  background: rgba(255, 255, 255, .06);
  color: #fff;
  padding: 13px 14px;
  outline: none;
}

.ac-form input::placeholder,
.ac-form textarea::placeholder {
  color: rgba(247, 231, 206, .5);
}

.ac-form textarea {
  resize: vertical;
  min-height: 132px;
}

.ac-form input:focus,
.ac-form textarea:focus {
  border-color: rgba(205, 177, 120, .72);
  box-shadow: 0 0 0 3px rgba(205, 177, 120, .18);
}

.ac-form__status {
  margin: 0;
  color: var(--ac-gold);
  font-size: 14px;
  font-weight: 700;
}

.ac-form__status.is-error {
  color: #ffcfba;
}

.ac-form button:disabled {
  opacity: .62;
  cursor: wait;
  transform: none;
}

.ac-choice {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  border: 0;
}

.ac-choice legend {
  margin: 0 0 4px;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
}

.ac-choice label {
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(247, 231, 206, .2);
  border-radius: 14px;
  background: rgba(255, 255, 255, .045);
  cursor: pointer;
}

.ac-choice input {
  width: 16px;
  min-height: 16px;
  accent-color: var(--ac-gold);
}

.ac-choice span {
  color: #f7e7ce;
}

.ac-promo-field {
  display: grid;
  gap: 10px;
}

.ac-promo-field label {
  min-width: 0;
}

.ac-promo-field .ac-btn {
  width: 100%;
  min-height: 48px;
  align-self: end;
}

.ac-form-price {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid rgba(205, 177, 120, .26);
  border-radius: 16px;
  background: rgba(205, 177, 120, .08);
}

.ac-form-price span {
  color: rgba(247, 231, 206, .62);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ac-form-price strong {
  color: #fff;
  font-size: 34px;
  line-height: 1;
  letter-spacing: -.035em;
}

.ac-form-price p {
  margin: 0;
  color: rgba(247, 231, 206, .76);
  font-size: 13px;
}

.ac-payment-options {
  display: grid;
  gap: 16px;
  padding: 16px;
  border: 1px solid rgba(247, 231, 206, .16);
  border-radius: 16px;
  background: rgba(255, 255, 255, .045);
}

.ac-payment-options[hidden] {
  display: none;
}

.ac-payment-options p {
  margin: 0;
  color: rgba(247, 231, 206, .72);
  font-size: 13px;
  line-height: 1.45;
}

.ac-payment-options > strong {
  color: #fff;
  font-size: 24px;
  line-height: 1.05;
  letter-spacing: -.025em;
}

.ac-payment-options .ac-payments--form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin: 0;
}

.ac-payment-options .ac-payments--form label {
  min-height: 44px;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(247, 231, 206, .18);
  border-radius: 14px;
  background: rgba(255, 255, 255, .055);
  color: #f7e7ce;
  cursor: pointer;
}

.ac-payment-options .ac-payments--form input {
  width: 16px;
  min-height: 16px;
  accent-color: var(--ac-gold);
}

.ac-payment-options .ac-payments--form span {
  border: 0;
  background: transparent;
  color: #f7e7ce;
  min-height: 0;
  padding: 0;
  font-size: 13px;
}

.ac-consent {
  display: flex !important;
  grid-template-columns: none !important;
  align-items: flex-start;
  gap: 10px !important;
  color: rgba(247, 231, 206, .78) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  line-height: 1.4;
}

.ac-consent input {
  width: 18px;
  min-width: 18px;
  min-height: 18px;
  margin-top: 1px;
  accent-color: var(--ac-gold);
}

.ac-consent a {
  color: var(--ac-gold);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.ac-honeypot {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.ac-grid {
  display: grid;
  gap: 14px;
}

.ac-situation,
.ac-audience {
  padding: 18px;
}

.ac-situation h3,
.ac-audience h3 {
  margin: 0 0 10px;
  color: var(--ac-navy);
  font-size: 20px;
  line-height: 1.18;
}

.ac-situation p,
.ac-audience p {
  margin: 0;
  color: #39414d;
  font-weight: 500;
}

.ac-inline-actions {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

.ac-list {
  display: grid;
  gap: 10px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

.ac-list li {
  position: relative;
  padding-left: 22px;
  color: #4f5865;
}

.ac-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .72em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ac-gold);
}

.ac-compare {
  display: grid;
  gap: 16px;
}

.ac-card--accent {
  border-color: rgba(143, 104, 46, .3);
  background: #fffaf1;
}

.ac-practice__points {
  display: grid;
  gap: 12px;
}

.ac-dark-card {
  border-color: rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .06);
  box-shadow: none;
  font-weight: 700;
}

.ac-price-card strong,
.ac-consult-card strong {
  display: block;
  margin-top: 0;
  font-size: clamp(42px, 12vw, 58px);
  font-weight: 680;
  line-height: 1;
  letter-spacing: -.04em;
}

.ac-price-card strong {
  color: var(--ac-navy);
}

.ac-price-card__top {
  display: grid;
  gap: 18px;
  align-items: start;
}

.ac-consult-card__top {
  display: grid;
  gap: 0;
  min-height: 142px;
  align-content: start;
}

.ac-price-promo {
  display: grid;
  gap: 8px;
}

.ac-price-card h3,
.ac-consult-card h3 {
  margin: 24px 0 12px;
  color: var(--ac-navy);
  font-size: 24px;
  line-height: 1.12;
  font-weight: 680;
  letter-spacing: -.025em;
}

.ac-price-promo__control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 46px;
  align-items: center;
  border: 1px solid rgba(31, 37, 48, .14);
  border-radius: 999px;
  background: #fff;
  overflow: hidden;
}

.ac-price-promo__control input {
  width: 100%;
  min-height: 46px;
  border: 0;
  background: transparent;
  color: var(--ac-ink);
  padding: 12px 4px 12px 16px;
  outline: none;
}

.ac-price-promo__control input::placeholder {
  color: #6f7784;
}

.ac-price-promo__control button {
  width: 46px;
  min-height: 46px;
  border: 0;
  border-left: 1px solid rgba(31, 37, 48, .1);
  background: var(--ac-gold);
  color: #171b22;
  font-size: 18px;
  font-weight: 800;
  cursor: pointer;
}

.ac-price-promo p {
  min-height: 0;
  margin: 0;
  color: #5b5142;
  font-size: 13px;
  line-height: 1.35;
}

.ac-price-options {
  display: grid;
  gap: 18px;
}

.ac-price-card,
.ac-consult-card {
  display: flex;
  flex-direction: column;
}

.ac-price-card .ac-btn,
.ac-consult-card .ac-btn {
  align-self: flex-start;
  margin-top: auto;
}

.ac-price-card > .ac-btn {
  margin-top: 28px;
}

.ac-price-card > span,
.ac-price-label {
  color: var(--ac-muted);
  font-weight: 600;
  min-height: 0;
  margin: 0 0 10px;
}

.ac-price-label,
.ac-price-card__top span,
.ac-consult-card__top span {
  font-size: 16px;
  line-height: 1.35;
  font-weight: 600;
}

.ac-price-card__top span,
.ac-consult-card__top span {
  color: var(--ac-muted);
}

.ac-promo {
  margin: 22px 0;
  padding: 18px;
  border: 1px solid rgba(143, 104, 46, .25);
  border-radius: 16px;
  background: #fff7e7;
}

.ac-promo summary {
  min-height: 34px;
  color: var(--ac-gold-dark);
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
}

.ac-promo__form {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.ac-promo label {
  display: grid;
  gap: 7px;
  color: #5b5142;
  font-size: 13px;
  font-weight: 700;
}

.ac-promo input {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(31, 37, 48, .16);
  border-radius: 13px;
  padding: 12px 13px;
  background: #fff;
  outline: none;
}

.ac-promo p,
.ac-promo span {
  margin: 0;
  color: #5b5142;
}

.ac-promo.is-applied {
  border-color: rgba(143, 104, 46, .55);
  background: #fff1d3;
}

.ac-consult-card {
  border-color: rgba(143, 104, 46, .28);
  background: #fffaf1;
}

.ac-consult-card strong {
  color: var(--ac-gold-dark);
}

.ac-consult-card__top span {
  margin-top: 0;
}

.ac-payments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 18px 0;
}

.ac-payments span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid rgba(31, 37, 48, .12);
  border-radius: 999px;
  background: #fff;
  color: #4f5865;
  font-size: 12px;
  font-weight: 700;
}

.ac-timeline {
  display: grid;
  gap: 14px;
  counter-reset: steps;
}

.ac-step h3 {
  margin: 8px 0 0;
}

.ac-step p {
  margin: 10px 0 0;
  color: var(--ac-muted);
}

.ac-faq-grid {
  display: grid;
  gap: 12px;
}

.ac-faq-item {
  padding: 0;
  overflow: hidden;
}

.ac-faq-item summary {
  min-height: 58px;
  display: flex;
  align-items: center;
  padding: 18px 20px;
  color: var(--ac-ink);
  font-weight: 700;
  cursor: pointer;
}

.ac-faq-item p {
  margin: 0;
  padding: 0 20px 20px;
  color: var(--ac-muted);
}

.ac-final h2 {
  max-width: 720px;
}

.ac-final .ac-btn {
  width: 100%;
  margin-top: 18px;
}

.ac-footer {
  background: var(--ac-navy);
  color: rgba(247, 231, 206, .72);
  padding: 48px 0 42px;
}

.ac-footer__grid {
  display: grid;
  gap: 30px;
}

.ac-footer__brand img {
  width: 164px;
  height: auto;
  margin-bottom: 20px;
}

.ac-footer p {
  max-width: 330px;
  margin: 0 0 13px;
  color: rgba(247, 231, 206, .62);
  font-size: 13px;
  line-height: 1.45;
}

.ac-footer strong {
  color: #f7e7ce;
}

.ac-footer a {
  color: var(--ac-gold);
  text-decoration: none;
}

.ac-footer__nav {
  display: grid;
  gap: 22px;
}

.ac-footer__col h2 {
  margin: 0 0 12px;
  color: #f7e7ce;
  font-size: 14px;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ac-footer__col ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ac-footer__col a {
  color: var(--ac-gold);
  font-size: 14px;
  line-height: 1.35;
}

.ac-footer__social {
  display: flex;
  gap: 10px;
}

.ac-footer__social a {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(205, 177, 120, .45);
  border-radius: 50%;
  color: var(--ac-gold);
}

.ac-footer__social svg,
.ac-footer__social img {
  width: 18px;
  height: 18px;
  display: block;
}

.ac-footer__social svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.ac-footer__social img {
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(76%) sepia(18%) saturate(713%) hue-rotate(356deg) brightness(89%) contrast(86%);
}

@media (hover: hover) {
  .ac-card { transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease; }
  .ac-card:hover {
    transform: translateY(-2px);
    border-color: rgba(143, 104, 46, .32);
  }
  .ac-btn:hover { transform: translateY(-1px); }
  .ac-footer a:hover { color: #f7e7ce; }
}

@media (min-width: 760px) {
  .ac-shell { width: min(100% - 64px, 1180px); }
  .ac-section { padding: 76px 0; }
  .ac-hero { padding: 86px 0 92px; }
  .ac-hero h1 { font-size: clamp(58px, 7.2vw, 72px); }
  .ac-section h2 { font-size: clamp(38px, 4vw, 48px); }
  .ac-actions { display: flex; }
  .ac-form { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
  .ac-form__wide { grid-column: 1 / -1; }
  .ac-promo-field {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
  }
  .ac-promo-field .ac-btn {
    width: auto;
    min-width: 132px;
    padding-inline: 18px;
  }
  .ac-payment-options .ac-payments--form { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ac-grid--audience { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ac-inline-actions { display: flex; }
  .ac-inline-actions .ac-btn--dark { width: auto; margin-top: 0; }
  .ac-compare,
  .ac-faq-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ac-timeline { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ac-footer__nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (min-width: 1060px) {
  .ac-hero__grid {
    grid-template-columns: minmax(0, 1.02fr) minmax(440px, .98fr);
    gap: 70px;
    align-items: center;
  }
  .ac-form-grid,
  .ac-two,
  .ac-practice,
  .ac-price-grid,
  .ac-final__grid {
    grid-template-columns: minmax(0, .9fr) minmax(420px, 1.1fr);
    gap: 58px;
    align-items: start;
  }
  .ac-price-grid {
    grid-template-columns: 1fr;
    gap: 34px;
  }
  .ac-price-grid .ac-head {
    max-width: 860px;
    margin-bottom: 0;
  }
  .ac-price-options {
    grid-template-columns: minmax(0, 1.08fr) minmax(360px, .92fr);
    gap: 24px;
    align-items: stretch;
  }
  .ac-price-card__top {
    grid-template-columns: minmax(0, 1fr) minmax(260px, .74fr);
    min-height: 142px;
  }
  .ac-price-promo {
    margin-top: 32px;
  }
  .ac-price-card > .ac-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 18px;
  }
  .ac-grid--situation-groups { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ac-grid--audience { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ac-timeline { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .ac-final .ac-btn { width: auto; }
  .ac-footer__grid {
    grid-template-columns: 250px minmax(0, 1fr) 132px;
    align-items: start;
  }
  .ac-footer__nav {
    grid-template-columns: repeat(4, minmax(110px, 1fr));
  }
}
