/* =====================================================================
   ARKLOS CMS · Diseño público estable
   Inspirado en Arklos.es, pero estructurado para CMS, SEO y captación.
   ===================================================================== */

/* Cabecera */
.topbar { background: var(--ark-black); color: rgba(255,255,255,.9); font-size: var(--step--1); font-weight: 800; }
.topbar__inner { min-height: 42px; display: flex; align-items: center; justify-content: center; gap: .8rem; text-align: center; }
.topbar a { color: var(--ark-gold); text-decoration: none; }
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,.94); backdrop-filter: blur(16px); border-bottom: 1px solid var(--ark-line); }
.site-header__inner { min-height: 84px; display: flex; align-items: center; justify-content: space-between; gap: 1.4rem; }
.site-header__logo { display: inline-flex; align-items: center; text-decoration: none; }
.site-header__logo img { width: 156px; height: auto; }
.nav { display: flex; align-items: center; gap: .55rem; font-weight: 900; }
.nav > a, .nav__item > a { position: relative; display: inline-flex; align-items: center; gap: .25rem; min-height: 40px; padding: .55rem .78rem; border-radius: 999px; text-decoration: none; color: var(--ark-black); font-size: .96rem; }
.nav > a:hover, .nav__item > a:hover, .nav [aria-current="page"] { background: var(--ark-soft); color: var(--ark-black); }
.nav__item { position: relative; }
.nav__dropdown { position: absolute; top: calc(100% + .4rem); left: 0; width: min(360px, 90vw); background: #fff; border: 1px solid var(--ark-line); border-radius: 22px; box-shadow: var(--ark-shadow); padding: .55rem; opacity: 0; visibility: hidden; transform: translateY(8px); transition: .18s ease; }
.nav__item:hover .nav__dropdown, .nav__item:focus-within .nav__dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.nav__dropdown a { display: flex; justify-content: space-between; gap: 1rem; padding: .88rem .95rem; border-radius: 14px; text-decoration: none; color: var(--ark-black); font-size: .92rem; line-height: 1.25; }
.nav__dropdown a:hover { background: var(--ark-soft); color: var(--ark-black); }
.nav__dropdown-all { background: var(--ark-gold) !important; font-weight: 900; }
.client-access-trigger { width: 48px; height: 48px; border: 0; border-radius: 999px; background: var(--ark-black); color: #fff; font-size: 1.15rem; letter-spacing: .14rem; cursor: pointer; }
.nav-toggle { display: none; border: 0; background: var(--ark-black); border-radius: 999px; width: 46px; height: 46px; padding: 0; }
.nav-toggle span { display: block; width: 18px; height: 2px; background: #fff; margin: 4px auto; border-radius: 2px; }

/* Hero */
.hero { position: relative; overflow: hidden; background: linear-gradient(180deg, var(--ark-soft), #fff 70%); }
.hero::before { content: ""; position: absolute; inset: auto -12rem -16rem auto; width: 35rem; height: 35rem; border-radius: 50%; background: radial-gradient(circle, rgba(240,190,21,.35), rgba(240,190,21,0) 68%); }
.hero__grid { position: relative; display: grid; grid-template-columns: 1.03fr .97fr; gap: clamp(2rem, 6vw, 5rem); align-items: center; padding: clamp(4rem, 9vw, 7.8rem) 0 clamp(3.6rem, 8vw, 6rem); }
.hero h1 { max-width: 12ch; font-size: clamp(3.2rem, 7vw, 6.8rem); }
.hero h1 mark, .accent { color: var(--ark-gold-deep); background: transparent; }
.hero__lead { max-width: 56ch; color: var(--ark-graphite); font-size: var(--step-1); }
.hero__actions { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; margin-top: 1.6rem; }
.hero__proof { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .8rem; margin-top: 2rem; }
.hero__proof div { background: #fff; border: 1px solid var(--ark-line); border-radius: 18px; padding: 1rem; }
.hero__proof strong { display: block; font-family: var(--ark-display); font-size: 2.2rem; line-height: 1; color: var(--ark-black); }
.hero__proof span { display: block; color: var(--ark-graphite); font-size: var(--step--1); font-weight: 800; line-height: 1.25; margin-top: .3rem; }
.hero__panel { min-height: 570px; position: relative; }
.mockup-card { position: absolute; border-radius: 32px; box-shadow: var(--ark-shadow-strong); overflow: hidden; }
.mockup-card--main { inset: 3rem 0 2rem 4rem; background: var(--ark-black); color: #fff; padding: 2.2rem; display: flex; flex-direction: column; justify-content: space-between; }
.mockup-card--main::before { content: ""; position: absolute; right: -7rem; top: -5rem; width: 20rem; height: 20rem; border-radius: 50%; background: rgba(240,190,21,.28); }
.mockup-card--main::after { content: ""; position: absolute; left: 2rem; right: 2rem; bottom: 2rem; height: 42%; border-radius: 24px; background: linear-gradient(135deg, rgba(240,190,21,.96), rgba(255,222,88,.8)); }
.mockup-kicker { position: relative; z-index: 2; display: inline-flex; width: fit-content; padding: .35rem .65rem; border: 1px solid rgba(255,255,255,.2); border-radius: 999px; font-size: .75rem; text-transform: uppercase; letter-spacing: .12em; }
.mockup-card h2 { position: relative; z-index: 2; color: #fff; max-width: 10ch; font-size: clamp(2rem, 3vw, 3rem); }
.mockup-list { position: relative; z-index: 3; display: grid; gap: .75rem; max-width: 360px; }
.mockup-list span { display: flex; gap: .65rem; align-items: center; color: rgba(255,255,255,.88); font-weight: 800; }
.mockup-list b { width: .72rem; height: .72rem; border-radius: 999px; background: var(--ark-gold); flex: 0 0 auto; }
.floating-card { position: absolute; z-index: 3; background: #fff; border: 1px solid var(--ark-line); border-radius: 18px; box-shadow: var(--ark-shadow); padding: 1rem 1.1rem; max-width: 210px; }
.floating-card strong { display: block; font-family: var(--ark-display); font-size: 1.65rem; line-height: 1; }
.floating-card span { color: var(--ark-graphite); font-size: var(--step--1); font-weight: 800; }
.floating-card--one { left: .4rem; bottom: 4.8rem; }
.floating-card--two { right: 0; top: 2.2rem; }

/* Secciones generales */
.section { padding: clamp(3.8rem, 7vw, 6.8rem) 0; }
.section--paper { background: var(--ark-paper); }
.section--soft { background: var(--ark-soft); }
.section--dark { background: var(--ark-black); color: rgba(255,255,255,.82); }
.section--dark .eyebrow { color: var(--ark-gold); }
.section--dark h2, .section--dark h3 { color: #fff; }
.section__head { max-width: 770px; margin-bottom: 2.4rem; }
.section__head--split { max-width: none; display: flex; align-items: end; justify-content: space-between; gap: 2rem; }
.section__head--split > div { max-width: 760px; }
.intro-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.intro-text { color: var(--ark-graphite); font-size: var(--step-1); }
.intro-text p:first-child { color: var(--ark-ink); }

/* Tarjetas */
.service-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.service-card { position: relative; min-height: 270px; background: #fff; border: 1px solid var(--ark-line); border-radius: var(--ark-radius); padding: 1.45rem; text-decoration: none; color: inherit; overflow: hidden; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.service-card::after { content: ""; position: absolute; right: -2rem; bottom: -2rem; width: 8rem; height: 8rem; border-radius: 50%; background: rgba(240,190,21,.13); transition: transform .2s ease; }
.service-card:hover { transform: translateY(-5px); border-color: rgba(240,190,21,.75); box-shadow: 0 28px 70px -55px rgba(0,0,0,.55); }
.service-card:hover::after { transform: scale(1.25); }
.service-card--featured { grid-column: span 2; background: var(--ark-black); color: rgba(255,255,255,.84); border-color: var(--ark-black); }
.service-card--featured h3 { color: #fff; }
.service-card--featured .card__num { color: var(--ark-gold); }
.card__num { display: inline-block; font-family: var(--ark-display); color: var(--ark-gold-deep); font-size: 1.55rem; line-height: 1; margin-bottom: 1rem; }
.service-card h3 { font-size: clamp(1.45rem, 2vw, 2.05rem); margin-bottom: .7rem; }
.service-card p { color: inherit; opacity: .84; margin: 0; }
.service-card em { display: block; margin-top: 1rem; color: var(--ark-gold-deep); font-style: normal; font-weight: 900; }
.service-card--featured em { color: var(--ark-gold); }

.values-grid { display: grid; grid-template-columns: .86fr 1.14fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.values-copy p { color: var(--ark-graphite); font-size: var(--step-1); }
.values-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.values-list article { border: 1px solid var(--ark-line); border-radius: var(--ark-radius); padding: 1.4rem; background: linear-gradient(180deg, #fff, var(--ark-soft)); }
.values-list span { color: var(--ark-gold-deep); font-weight: 900; letter-spacing: .12em; }
.values-list h3 { font-size: 1.75rem; margin: .6rem 0 .45rem; }
.values-list p { color: var(--ark-graphite); margin: 0; }
.why-section { position: relative; overflow: hidden; }
.why-section::before { content: ""; position: absolute; right: -12rem; top: -18rem; width: 38rem; height: 38rem; border-radius: 50%; background: rgba(240,190,21,.14); }
.why-grid { position: relative; display: grid; grid-template-columns: .95fr 1.05fr; gap: clamp(2rem, 5vw, 5rem); }
.why-list { display: grid; gap: 1rem; }
.why-list p { margin: 0; padding: 1.1rem 1.2rem; border-radius: var(--ark-radius-sm); background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.10); }
.why-list strong { color: #fff; }

.process-grid, .benefit-grid, .office-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.process-card, .benefit-card, .office-card { background: #fff; border: 1px solid var(--ark-line); border-radius: var(--ark-radius); padding: 1.35rem; }
.process-card strong, .benefit-card strong { display: block; color: var(--ark-gold-deep); font-weight: 900; margin-bottom: .45rem; }
.office-card p, .benefit-card p, .process-card p { color: var(--ark-graphite); margin: 0; }
.logo-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; align-items: center; }
.logo-strip div { border: 1px solid var(--ark-line); background: #fff; border-radius: var(--ark-radius); min-height: 130px; display: grid; place-items: center; padding: 1rem; text-align: center; font-weight: 900; color: var(--ark-graphite); }

/* Blog */
.post-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.2rem; }
.post-card { border: 1px solid var(--ark-line); border-radius: var(--ark-radius); overflow: hidden; background: #fff; transition: transform .2s, border-color .2s, box-shadow .2s; }
.post-card:hover { transform: translateY(-4px); border-color: var(--ark-gold); box-shadow: 0 28px 70px -55px rgba(0,0,0,.55); }
.post-card a { text-decoration: none; color: inherit; display: block; padding: 1.45rem; }
.post-card .cat { font-size: var(--step--1); font-weight: 900; letter-spacing: .12em; text-transform: uppercase; color: var(--ark-gold-deep); }
.post-card h3 { font-size: var(--step-1); margin: .65rem 0; line-height: 1.12; }
.post-card time { color: var(--ark-mute); font-size: var(--step--1); font-weight: 700; }
.article { max-width: 760px; margin-inline: auto; }
.article__meta { color: var(--ark-mute); font-size: var(--step--1); margin-bottom: 1.5rem; }
.article__body { font-size: var(--step-1); line-height: 1.75; }
.pagination { display: flex; gap: .5rem; justify-content: center; margin-top: 2.5rem; }
.pagination a, .pagination span { padding: .5rem .9rem; border: 1px solid var(--ark-line); border-radius: var(--ark-radius-sm); text-decoration: none; }
.pagination .is-active { background: var(--ark-black); color: #fff; border-color: var(--ark-black); }

/* FAQ / CTA */
.faq-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(2rem, 5vw, 5rem); }
.faq-list { display: grid; gap: .85rem; }
details { border: 1px solid var(--ark-line); border-radius: var(--ark-radius-sm); padding: 1rem 1.1rem; background: #fff; }
summary { cursor: pointer; font-weight: 900; color: var(--ark-black); }
details p { color: var(--ark-graphite); margin: .75rem 0 0; }
.final-cta { background: linear-gradient(135deg, var(--ark-black), #252525); color: rgba(255,255,255,.82); }
.final-cta__box { position: relative; overflow: hidden; border-radius: 34px; padding: clamp(2rem, 5vw, 4rem); background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.035)); border: 1px solid rgba(255,255,255,.12); text-align: center; }
.final-cta__box::before { content: ""; position: absolute; right: -8rem; bottom: -10rem; width: 26rem; height: 26rem; border-radius: 50%; background: rgba(240,190,21,.25); }
.final-cta h2 { position: relative; color: #fff; max-width: 760px; margin-inline: auto; }
.final-cta p { position: relative; max-width: 700px; margin: 0 auto 1.4rem; }
.final-cta__actions { justify-content: center; }

/* Páginas CMS */
.page-hero { background: var(--ark-soft); padding: clamp(3.6rem, 7vw, 6.5rem) 0 2.5rem; }
.page-hero__grid { display: grid; grid-template-columns: 1fr .82fr; gap: clamp(2rem, 5vw, 5rem); align-items: end; }
.page-hero p { color: var(--ark-graphite); font-size: var(--step-1); max-width: 58ch; }
.page-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem; }
.page-kpis div { background: #fff; border: 1px solid var(--ark-line); border-radius: 18px; padding: 1rem; }
.page-kpis strong { display: block; font-size: 2rem; font-family: var(--ark-display); line-height: 1; }
.page-kpis span { color: var(--ark-graphite); font-weight: 800; font-size: var(--step--1); }
.page-content { max-width: none; }
.cms-block { padding: clamp(3.5rem, 6vw, 5.6rem) 0; }
.cms-block--paper { background: var(--ark-paper); }
.cms-grid-2 { display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(2rem, 5vw, 5rem); align-items: start; }
.cms-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.cms-list { display: grid; gap: .8rem; }
.cms-list li { list-style: none; padding: .95rem 1rem; border-radius: 14px; background: #fff; border: 1px solid var(--ark-line); font-weight: 800; }
.cms-list li::before { content: "✓"; display: inline-grid; place-items: center; width: 1.35rem; height: 1.35rem; margin-right: .55rem; border-radius: 50%; background: var(--ark-gold); color: var(--ark-black); font-size: .75rem; }
.cms-card { background: #fff; border: 1px solid var(--ark-line); border-radius: var(--ark-radius); padding: 1.35rem; }
.cms-card h3 { font-family: var(--ark-sans); font-size: 1.15rem; letter-spacing: -.01em; line-height: 1.2; margin-bottom: .6rem; }
.cms-card p { color: var(--ark-graphite); }
.cms-highlight { background: var(--ark-black); color: rgba(255,255,255,.82); border-radius: 32px; padding: clamp(2rem, 5vw, 4rem); }
.cms-highlight h2 { color: #fff; }
.cms-highlight mark { background: transparent; color: var(--ark-gold); }
.cms-highlight .btn--gold:hover { background: #fff; border-color: #fff; color: var(--ark-black); }
.form-panel { margin-top: 2rem; background: var(--ark-soft); border: 1px solid var(--ark-line); border-radius: 28px; padding: clamp(1.4rem, 4vw, 2.5rem); }
.form-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: .9rem; }
.form-grid .full { grid-column: 1 / -1; }
.form-panel label { display: grid; gap: .35rem; font-weight: 800; font-size: var(--step--1); }
.form-panel input, .form-panel textarea, .newsletter input { width: 100%; border: 1px solid var(--ark-line); border-radius: 14px; padding: .95rem 1rem; font: inherit; background: #fff; }
.form-panel textarea { min-height: 140px; resize: vertical; }
.newsletter { background: var(--ark-black); color: #fff; border-radius: 32px; overflow: hidden; display: grid; grid-template-columns: 1fr .9fr; align-items: stretch; }
.newsletter__copy { padding: clamp(2rem, 5vw, 4rem); }
.newsletter h2 { color: #fff; }
.newsletter form { display: flex; gap: .7rem; flex-wrap: wrap; margin-top: 1.2rem; }
.newsletter input { max-width: 360px; }
.newsletter__visual { background: linear-gradient(135deg, rgba(240,190,21,.92), rgba(255,225,105,.82)); min-height: 280px; display: grid; place-items: center; color: var(--ark-black); font-size: clamp(4rem, 12vw, 9rem); font-family: var(--ark-display); }
.error-page { text-align: center; padding: clamp(4rem, 12vw, 8rem) 0; }
.error-page .code { font-family: var(--ark-display); font-size: clamp(5rem, 18vw, 9rem); color: var(--ark-gold); line-height: 1; }

/* Footer y acceso clientes */
.site-footer { background: #fff; color: var(--ark-ink); border-top: 1px solid var(--ark-line); }
.cta-footer { display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(2rem, 5vw, 5rem); padding: clamp(3rem, 7vw, 6rem) 0; background: var(--ark-paper); border-radius: 34px; margin-top: 2rem; padding-inline: clamp(1.5rem, 4vw, 4rem); }
.site-footer__brand { display: inline-flex; margin-bottom: 1.2rem; }
.site-footer__brand img { width: 150px; }
.cta-footer h2 { max-width: 12ch; }
.cta-footer mark { background: transparent; color: var(--ark-gold-deep); }
.footer-contact-card { background: #fff; border: 1px solid var(--ark-line); border-radius: var(--ark-radius); padding: 1.4rem; }
.footer-contact-card span { text-transform: uppercase; letter-spacing: .12em; font-size: var(--step--1); font-weight: 900; color: var(--ark-gold-deep); }
.site-footer__nav { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; padding: 1.7rem 0; border-bottom: 1px solid var(--ark-line); }
.site-footer__nav a, .site-footer__bottom a { text-decoration: none; font-weight: 800; }
.site-footer__bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; padding: 1.5rem 0 2.2rem; font-size: var(--step--1); color: var(--ark-graphite); }
.floating-access { position: fixed; z-index: 55; right: 1.4rem; bottom: 1.4rem; border: 0; background: var(--ark-black); color: #fff; border-radius: 999px; box-shadow: var(--ark-shadow); padding: .9rem 1.2rem; font-weight: 900; cursor: pointer; }
.floating-access span { display: inline-block; width: .55rem; height: .55rem; border-radius: 50%; background: var(--ark-gold); margin-right: .45rem; }
.access-modal[hidden] { display: none; }
.access-modal { position: fixed; inset: 0; z-index: 100; display: grid; place-items: center; padding: 1.2rem; }
.access-modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.58); }
.access-modal__panel { position: relative; z-index: 2; width: min(760px, 100%); background: #fff; border-radius: 28px; padding: clamp(1.4rem, 4vw, 2.5rem); box-shadow: var(--ark-shadow-strong); }
.access-modal__close { position: absolute; right: 1rem; top: 1rem; width: 40px; height: 40px; border: 0; border-radius: 999px; background: var(--ark-black); color: #fff; font-size: 1.4rem; cursor: pointer; }
.access-options { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; margin-top: 1.2rem; }
.access-options a { border: 1px solid var(--ark-line); border-radius: 20px; padding: 1.2rem; text-decoration: none; color: var(--ark-black); display: grid; gap: .5rem; }
.access-options span { color: var(--ark-graphite); }
.access-options em { color: var(--ark-gold-deep); font-style: normal; font-weight: 900; }
body.modal-open { overflow: hidden; }


/* Aviso flotante de evolución de Arklos */
.arklos-update-card {
  position: fixed;
  left: max(1rem, env(safe-area-inset-left));
  bottom: max(1rem, env(safe-area-inset-bottom));
  z-index: 70;
  width: min(340px, calc(100vw - 2rem));
  border: 1px solid rgba(17,17,17,.1);
  border-left: 5px solid var(--ark-gold);
  border-radius: 24px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 28px 80px -56px rgba(0,0,0,.75);
  padding: 1.25rem 1.25rem 1.15rem;
  backdrop-filter: blur(16px);
}
.arklos-update-card[hidden] { display: none; }
.arklos-update-card__close {
  position: absolute;
  right: .8rem;
  top: .8rem;
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 999px;
  background: var(--ark-black);
  color: #fff;
  cursor: pointer;
  font-size: 1.15rem;
  line-height: 1;
}
.arklos-update-card__eyebrow,
.arklos-update-modal__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  width: fit-content;
  border-radius: 999px;
  background: var(--ark-soft);
  color: var(--ark-black);
  padding: .42rem .7rem;
  font-size: .72rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.arklos-update-card__eyebrow::before,
.arklos-update-modal__eyebrow::before {
  content: "";
  width: .48rem;
  height: .48rem;
  border-radius: 999px;
  background: var(--ark-gold);
}
.arklos-update-card h2 {
  margin: .8rem 2.2rem .55rem 0;
  font-size: 1.25rem;
  line-height: 1.05;
  letter-spacing: -.035em;
}
.arklos-update-card p {
  margin: 0 0 1rem;
  color: var(--ark-graphite);
  font-size: .93rem;
  line-height: 1.55;
}
.arklos-update-card__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 1rem;
  border: 0;
  border-radius: 999px;
  background: var(--ark-black);
  color: #fff;
  font-weight: 950;
  cursor: pointer;
}
.arklos-update-modal[hidden] { display: none; }
.arklos-update-modal {
  position: fixed;
  inset: 0;
  z-index: 130;
  display: grid;
  place-items: center;
  padding: clamp(1rem, 3vw, 2rem);
}
.arklos-update-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.64);
}
.arklos-update-modal__panel {
  position: relative;
  z-index: 1;
  width: min(820px, 100%);
  max-height: min(86vh, 880px);
  overflow: auto;
  border-radius: 30px;
  background: linear-gradient(135deg, #fff 0%, #fff 66%, var(--ark-soft) 100%);
  box-shadow: 0 40px 120px -50px rgba(0,0,0,.8);
  padding: clamp(1.35rem, 3vw, 2rem);
  scrollbar-width: thin;
}
.arklos-update-modal__close {
  position: sticky;
  top: 0;
  float: right;
  z-index: 2;
  width: 44px;
  height: 44px;
  margin: -.4rem -.4rem .4rem .8rem;
  border: 0;
  border-radius: 999px;
  background: var(--ark-black);
  color: #fff;
  cursor: pointer;
  font-size: 1.3rem;
  line-height: 1;
}
.arklos-update-modal__head {
  max-width: 710px;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--ark-line);
}
.arklos-update-modal__head h2 {
  margin: 1rem 0 .8rem;
  font-size: clamp(2rem, 4.2vw, 3.6rem);
  line-height: .98;
  letter-spacing: -.055em;
}
.arklos-update-modal__head p,
.arklos-update-modal__current p,
.arklos-update-grid p,
.arklos-update-tax p,
.arklos-update-modal__foot p {
  color: var(--ark-graphite);
  line-height: 1.6;
}
.arklos-update-modal__current {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: start;
  margin: 1.25rem 0;
  padding: 1.1rem;
  border-radius: 22px;
  background: var(--ark-black);
  color: #fff;
}
.arklos-update-modal__current strong { color: #fff; font-size: 1.05rem; }
.arklos-update-modal__current p { margin: .25rem 0 0; color: rgba(255,255,255,.75); }
.arklos-update-modal__icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: var(--ark-gold);
  color: var(--ark-black);
  font-weight: 950;
}
.arklos-update-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
}
.arklos-update-grid article {
  border: 1px solid var(--ark-line);
  border-radius: 22px;
  background: #fff;
  padding: 1.05rem;
}
.arklos-update-grid span {
  display: inline-grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: var(--ark-soft);
  color: var(--ark-black);
  font-size: .78rem;
  font-weight: 950;
}
.arklos-update-grid h3 {
  margin: .75rem 0 .4rem;
  font-size: 1.08rem;
  letter-spacing: -.02em;
}
.arklos-update-grid p { margin: 0; font-size: .95rem; }
.arklos-update-tax {
  margin-top: 1rem;
  border-radius: 22px;
  background: var(--ark-black);
  color: #fff;
  padding: 1.25rem;
}
.arklos-update-tax h3 { color: #fff; margin: 0 0 .45rem; font-size: 1.35rem; }
.arklos-update-tax h3::after { content: ""; display: inline-block; width: .55rem; height: .55rem; margin-left: .45rem; border-radius: 999px; background: var(--ark-gold); }
.arklos-update-tax p { margin: 0; color: rgba(255,255,255,.76); }
.arklos-update-timeline {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  overflow: hidden;
  margin-top: 1rem;
  border: 1px solid var(--ark-line);
  border-radius: 18px;
  background: #fff;
}
.arklos-update-timeline div { padding: .95rem; border-right: 1px solid var(--ark-line); }
.arklos-update-timeline div:last-child { border-right: 0; background: var(--ark-soft); }
.arklos-update-timeline span {
  display: block;
  margin-bottom: .35rem;
  color: var(--ark-graphite);
  font-size: .68rem;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.arklos-update-timeline strong { display: block; font-size: .88rem; line-height: 1.25; }
.arklos-update-modal__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--ark-line);
}
.arklos-update-modal__foot p { margin: 0; font-size: .93rem; }
.arklos-update-modal__ok {
  flex: 0 0 auto;
  min-height: 44px;
  padding: 0 1.2rem;
  border: 0;
  border-radius: 999px;
  background: var(--ark-black);
  color: #fff;
  font-weight: 950;
  cursor: pointer;
}

@media (max-width: 1020px) {
  .nav { gap: .25rem; }
  .nav > a, .nav__item > a { font-size: .88rem; padding-inline: .55rem; }
  .service-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 880px) {
  .topbar__inner { flex-direction: column; gap: .2rem; padding-block: .5rem; }
  .nav-toggle { display: block; }
  .nav { position: fixed; inset: 84px 0 auto 0; flex-direction: column; align-items: flex-start; gap: 0; background: #fff; border-bottom: 1px solid var(--ark-line); padding: 1rem var(--ark-gutter) 1.5rem; transform: translateY(-130%); transition: transform .25s ease; box-shadow: var(--ark-shadow); }
  .nav[data-open="true"] { transform: translateY(0); }
  .nav > a, .nav__item, .nav__item > a { width: 100%; }
  .nav > a, .nav__item > a { padding: .85rem 0; border-bottom: 1px solid var(--ark-line); border-radius: 0; }
  .nav__dropdown { position: static; width: 100%; opacity: 1; visibility: visible; transform: none; box-shadow: none; border-radius: 14px; display: none; margin-bottom: .8rem; }
  .nav__item:focus-within .nav__dropdown, .nav__item:hover .nav__dropdown { display: block; }
  .client-access-trigger { margin-top: .8rem; }
  .hero__grid, .intro-grid, .values-grid, .why-grid, .faq-grid, .page-hero__grid, .cms-grid-2, .newsletter, .cta-footer { grid-template-columns: 1fr; }
  .hero h1 { max-width: 100%; }
  .hero__panel { min-height: 430px; }
  .mockup-card--main { inset: 1rem 0 1rem 0; }
  .floating-card--one { left: .8rem; bottom: 1rem; }
  .floating-card--two { right: .8rem; top: 1rem; }
  .section__head--split { display: block; }
  .text-link { display: inline-block; margin-top: .3rem; }
  .process-grid, .benefit-grid, .office-grid, .cms-grid-3, .page-kpis, .logo-strip { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .hero__proof, .values-list, .service-grid, .access-options, .form-grid { grid-template-columns: 1fr; }
  .form-grid .full { grid-column: auto; }
  .service-card--featured { grid-column: auto; }
  .hero__panel { display: none; }
  .site-header__logo img { width: 138px; }
  .cta-footer { border-radius: 0; width: 100%; margin-inline: 0; }
  .floating-access { left: 1rem; right: 1rem; bottom: 1rem; }
}

/* =====================================================================
   PÁGINAS DE SERVICIO · kit de diseño (réplica del estilo WordPress)
   ===================================================================== */

/* --- Hero --- */
.svc-hero { background: var(--ark-black); color: #fff; padding: clamp(2.5rem,6vw,4.5rem) 0; position: relative; overflow: hidden; }
.svc-hero::after { content:""; position:absolute; width:520px; height:520px; right:-120px; top:-160px; border-radius:50%; background:radial-gradient(circle, rgba(240,190,21,.10), transparent 70%); }
.svc-hero__grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.5rem,4vw,3.5rem); align-items:center; position:relative; z-index:1; }
.svc-hero__copy h1 { color:#fff; font-size: clamp(2.2rem,5vw,3.6rem); line-height:1.04; margin:.4rem 0 .8rem; }
.svc-badge { display:inline-flex; align-items:center; gap:.5rem; background:rgba(240,190,21,.14); color:var(--ark-gold-2); border:1px solid rgba(240,190,21,.4); padding:.4rem .9rem; border-radius:999px; font-size:.78rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; }
.svc-badge::before { content:""; width:7px; height:7px; border-radius:50%; background:var(--ark-gold); }
.svc-hero__lead { color:#c9c9c4; font-size:1.12rem; max-width:42ch; }
.svc-hero__actions { display:flex; flex-wrap:wrap; gap:.8rem; margin:1.6rem 0 1.2rem; }
.svc-hero__rating { color:#cfcfca; font-size:.92rem; }
.svc-hero__rating span { color:var(--ark-gold); letter-spacing:1px; }
.btn--ghost-light { background:transparent; border:1.5px solid rgba(255,255,255,.35); color:#fff; border-radius:999px; padding:.85rem 1.4rem; font-weight:700; text-decoration:none; display:inline-flex; align-items:center; }
.btn--ghost-light:hover { background:#fff; color:var(--ark-black); }

/* --- Tarjeta de formulario en el hero --- */
.svc-hero__card { background:#fff; color:var(--ark-ink); border-radius:24px; padding:clamp(1.4rem,3vw,2rem); box-shadow:var(--ark-shadow-strong); }
.svc-form { display:grid; gap:.85rem; }
.svc-form__eyebrow { font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ark-mute); font-weight:700; }
.svc-form__field { display:grid; gap:.3rem; font-size:.82rem; font-weight:700; color:var(--ark-graphite); }
.svc-form__field input, .svc-form__field select { width:100%; font:inherit; font-weight:500; padding:.75rem .85rem; border:1.5px solid var(--ark-line); border-radius:12px; background:#fff; }
.svc-form__field input:focus, .svc-form__field select:focus { border-color:var(--ark-gold); outline:none; }
.svc-form .is-invalid { border-color:#c0392b !important; box-shadow:0 0 0 3px rgba(192,57,43,.12); }
.svc-form__submit { width:100%; justify-content:center; margin-top:.3rem; }
.svc-form__legal { font-size:.74rem; color:var(--ark-mute); text-align:center; margin:.2rem 0 0; }

/* --- Franja de confianza (Colaborador Social / PAE) --- */
.svc-trust { display:grid; gap:.8rem; padding: clamp(1.8rem,4vw,2.6rem) 0 0; }
.svc-trust__item { display:grid; grid-template-columns:auto 1fr; gap:1rem; align-items:center; border-radius:18px; padding:1rem 1.3rem; }
.svc-trust__item--green { background:#1f5130; color:#eafaef; }
.svc-trust__item--gold  { background:var(--ark-gold-wash); color:#5a4400; }
.svc-trust__ic { width:46px; height:46px; border-radius:12px; display:grid; place-items:center; font-size:1.3rem; }
.svc-trust__item--green .svc-trust__ic { background:rgba(255,255,255,.14); }
.svc-trust__item--gold .svc-trust__ic { background:rgba(0,0,0,.06); }
.svc-trust__item b { display:block; font-size:.95rem; }
.svc-trust__item span { font-size:.95rem; opacity:.95; }

/* --- Fila rápida de ventajas --- */
.svc-quick { display:flex; flex-wrap:wrap; gap:1.2rem 2rem; justify-content:center; background:var(--ark-paper); border-radius:18px; padding:1.1rem 1.4rem; margin-top:1.4rem; }
.svc-quick li { list-style:none; display:flex; align-items:center; gap:.5rem; font-weight:600; font-size:.95rem; color:var(--ark-ink); }
.svc-quick li::before { content:"✓"; display:grid; place-items:center; width:22px; height:22px; border-radius:50%; background:var(--ark-gold); color:var(--ark-black); font-size:.8rem; font-weight:900; }

/* --- Cabecera de sección interna --- */
.svc-secthead { max-width:60ch; margin:0 0 1.8rem; }
.svc-secthead .eyebrow { color:var(--ark-gold-deep); }
.svc-section { padding: clamp(2.4rem,6vw,4rem) 0; }
.svc-section--paper { background:var(--ark-paper); }
.svc-section--dark { background:var(--ark-black); color:#e9e9e6; }
.svc-section--dark h2 { color:#fff; }

/* --- Qué incluye (checklist + imagen) --- */
.svc-includes { display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,4vw,3rem); align-items:center; }
.svc-checklist { list-style:none; padding:0; margin:0; display:grid; gap:.9rem; }
.svc-checklist li { display:grid; grid-template-columns:auto 1fr; gap:.8rem; align-items:start; font-size:1.05rem; padding-bottom:.9rem; border-bottom:1px solid var(--ark-line); }
.svc-checklist li::before { content:"✓"; display:grid; place-items:center; width:26px; height:26px; border-radius:50%; background:var(--ark-gold); color:var(--ark-black); font-weight:900; font-size:.85rem; }
.svc-note { background:#fff; border:1px solid var(--ark-line); border-radius:14px; padding:1rem 1.2rem; color:var(--ark-graphite); font-size:.95rem; margin-top:1.2rem; }
.svc-media { background:#fff; border:1px dashed var(--ark-line); border-radius:22px; min-height:340px; display:grid; place-items:center; color:var(--ark-mute); }

/* --- Precios --- */
.svc-pricing { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.4rem; align-items:start; }
.svc-plan { position:relative; background:#fff; border:1px solid var(--ark-line); border-radius:22px; padding:1.8rem; }
.svc-plan--featured { border:2px solid var(--ark-gold); box-shadow:var(--ark-shadow); }
.svc-plan__tag { position:absolute; top:-13px; left:50%; transform:translateX(-50%); background:var(--ark-gold); color:var(--ark-black); font-weight:800; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; padding:.35rem .9rem; border-radius:999px; }
.svc-plan__kicker { font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ark-mute); font-weight:700; }
.svc-plan__price { font-family:var(--ark-display); font-size:2.6rem; line-height:1; margin:.4rem 0 .2rem; }
.svc-plan__price small { font-size:.95rem; color:var(--ark-mute); font-family:var(--ark-sans); }
.svc-plan ul { list-style:none; padding:0; margin:1rem 0 1.4rem; display:grid; gap:.55rem; }
.svc-plan li { padding-left:1.5rem; position:relative; color:var(--ark-graphite); }
.svc-plan li::before { content:"✓"; position:absolute; left:0; color:var(--ark-gold-deep); font-weight:900; }

/* --- Pasos --- */
.svc-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.svc-step { position:relative; padding:1.2rem 1rem 1.2rem 0; border-left:1px solid rgba(255,255,255,.14); padding-left:1.2rem; }
.svc-section--dark .svc-step p { color:#bdbdb8; }
.svc-step__n { width:34px; height:34px; border-radius:50%; background:var(--ark-gold); color:var(--ark-black); display:grid; place-items:center; font-weight:800; margin-bottom:.8rem; }
.svc-step__ghost { position:absolute; right:.6rem; top:.4rem; font-family:var(--ark-display); font-size:3rem; color:rgba(255,255,255,.06); }
.svc-step h3 { font-size:1.15rem; margin:0 0 .4rem; }

/* --- FAQ acordeón --- */
.svc-faq { max-width:860px; margin-inline:auto; display:grid; gap:.7rem; }
.svc-faq__item { border:1px solid var(--ark-line); border-radius:16px; background:#fff; overflow:hidden; }
.svc-faq__item summary { list-style:none; cursor:pointer; padding:1.05rem 1.3rem; font-weight:700; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.svc-faq__item summary::-webkit-details-marker { display:none; }
.svc-faq__item summary::after { content:"+"; display:grid; place-items:center; width:28px; height:28px; border-radius:50%; background:var(--ark-paper); color:var(--ark-black); font-size:1.1rem; flex:0 0 auto; }
.svc-faq__item[open] { border-color:var(--ark-gold); }
.svc-faq__item[open] summary { background:var(--ark-gold); color:var(--ark-black); }
.svc-faq__item[open] summary::after { content:"×"; background:rgba(0,0,0,.12); }
.svc-faq__item .svc-faq__a { padding:0 1.3rem 1.2rem; color:var(--ark-graphite); line-height:1.65; }

/* --- CTA final --- */
.svc-final { background:var(--ark-black); color:#fff; text-align:center; padding:clamp(2.6rem,7vw,4.5rem) 0; }
.svc-final__box { max-width:680px; margin-inline:auto; }
.svc-final h2 { color:#fff; font-size:clamp(1.8rem,4vw,2.8rem); }
.svc-final p { color:#c9c9c4; }
.svc-final__actions { display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center; margin-top:1.4rem; }

/* --- Responsive --- */
@media (max-width:880px){
  .svc-hero__grid, .svc-includes { grid-template-columns:1fr; }
  .svc-steps { grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){
  .svc-steps { grid-template-columns:1fr; }
  .svc-trust__item { grid-template-columns:1fr; text-align:left; }
}

/* =====================================================================
   FASE I · blog, newsletter, colaboradores, legales, DGT, promo Signo
   ===================================================================== */

/* --- Blog: subtítulo + imagen destacada --- */
.article__subtitle { font-size:1.25rem; color:var(--ark-graphite); margin:.2rem 0 1rem; line-height:1.4; }
.article__cover { margin:1.4rem 0 1.8rem; border-radius:var(--ark-radius); overflow:hidden; }
.article__cover img { display:block; width:100%; height:auto; }
.post-card__cover { margin:-1.45rem -1.45rem 1.1rem; overflow:hidden; }
.post-card__cover img { display:block; width:100%; aspect-ratio:16/9; object-fit:cover; }

/* --- Colaboradores --- */
.partners { text-align:center; margin-top:2rem; }
.partners__label { display:block; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ark-mute); font-weight:700; margin-bottom:1rem; }
.partners__logos { display:flex; flex-wrap:wrap; gap:2.5rem; align-items:center; justify-content:center; }
.partners__logos img { height:46px; width:auto; object-fit:contain; filter:grayscale(1); opacity:.7; transition:filter .25s, opacity .25s; }
.partners__logos img:hover { filter:none; opacity:1; }

/* --- Newsletter (rediseño) --- */
.nl2 { background:var(--ark-black); border-radius:var(--ark-radius); padding:clamp(2rem,5vw,3.4rem); position:relative; overflow:hidden; }
.nl2::after { content:""; position:absolute; right:-100px; top:-100px; width:360px; height:360px; border-radius:50%; background:radial-gradient(circle, rgba(240,190,21,.18), transparent 70%); }
.nl2__inner { position:relative; z-index:1; max-width:680px; }
.nl2__eyebrow { color:var(--ark-gold-2); font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; font-weight:700; }
.nl2__title { color:#fff; font-size:clamp(1.7rem,3.6vw,2.6rem); line-height:1.08; margin:.6rem 0 .7rem; }
.nl2__title span { color:var(--ark-gold); }
.nl2__lead { color:#c9c9c4; margin:0 0 1.4rem; max-width:54ch; }
.nl2__form { display:flex; gap:.6rem; flex-wrap:wrap; max-width:520px; }
.nl2__form input[type=email] { flex:1; min-width:220px; padding:.9rem 1.1rem; border-radius:999px; border:1.5px solid #34343a; background:#161618; color:#fff; font:inherit; }
.nl2__form input[type=email]::placeholder { color:#8a8a8f; }
.nl2__form input[type=email]:focus { outline:none; border-color:var(--ark-gold); }
.nl2__form .btn { white-space:nowrap; }
.nl2__tags { list-style:none; display:flex; flex-wrap:wrap; gap:.5rem; padding:0; margin:1.3rem 0 0; }
.nl2__tags li { font-size:.78rem; color:#cfcfca; border:1px solid #34343a; border-radius:999px; padding:.3rem .8rem; }

/* --- Páginas legales (estilo Arklos Tax) --- */
.legal-wrap { width:min(880px,100% - var(--ark-gutter)*2); margin-inline:auto; }
.legal-hero { padding:clamp(2.4rem,6vw,4rem) 0 1.2rem; }
.legal-pill { display:inline-flex; align-items:center; gap:.5rem; font-size:.74rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:var(--ark-gold-deep); background:var(--ark-gold-wash); padding:.4rem .9rem; border-radius:999px; }
.legal-pill::before { content:""; width:7px; height:7px; border-radius:50%; background:var(--ark-gold); }
.legal-hero h1 { font-size:clamp(2.4rem,6vw,4rem); margin:1rem 0 .6rem; }
.legal-intro { font-size:1.1rem; color:var(--ark-graphite); max-width:70ch; }
.legal-meta { display:flex; flex-wrap:wrap; justify-content:space-between; gap:.6rem; margin-top:1.6rem; background:var(--ark-paper); border:1px solid var(--ark-line); border-radius:14px; padding:.9rem 1.2rem; font-size:.9rem; color:var(--ark-mute); }
.legal-body { padding:1.4rem 0 clamp(2.5rem,7vw,4.5rem); }
.legal-body h2 { font-size:1.5rem; margin:2.2rem 0 .8rem; padding-top:1.4rem; border-top:1px solid var(--ark-line); }
.legal-body h3 { font-size:1.15rem; margin:1.4rem 0 .5rem; }
.legal-body p, .legal-body li { color:var(--ark-graphite); line-height:1.7; }
.legal-body ul { padding-left:1.2rem; }
.legal-body a { color:var(--ark-gold-deep); }

/* --- DGT: tarjetas de trámite --- */
.svc-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.2rem; }
.svc-card { background:#fff; border:1px solid var(--ark-line); border-radius:18px; padding:1.4rem; transition:box-shadow .2s, transform .2s; }
.svc-card:hover { box-shadow:var(--ark-shadow); transform:translateY(-3px); }
.svc-card__ic { width:46px; height:46px; border-radius:12px; background:var(--ark-gold-wash); color:var(--ark-gold-deep); display:grid; place-items:center; margin-bottom:.9rem; }
.svc-card h3 { font-size:1.15rem; margin:0 0 .4rem; }
.svc-card p { color:var(--ark-graphite); font-size:.95rem; margin:0 0 1rem; }
.svc-card__price { display:inline-block; background:var(--ark-gold-wash); color:var(--ark-gold-deep); font-weight:800; font-size:.85rem; padding:.35rem .8rem; border-radius:999px; }

/* --- DGT: tabla de precios --- */
.svc-pricetable { width:100%; border-collapse:collapse; background:#fff; border-radius:18px; overflow:hidden; border:1px solid var(--ark-line); font-size:.96rem; }
.svc-pricetable thead th { background:var(--ark-black); color:#fff; text-align:right; padding:1rem 1.2rem; font-weight:700; }
.svc-pricetable thead th:first-child { text-align:left; }
.svc-pricetable .svc-pricetable__group td { background:var(--ark-paper); color:var(--ark-mute); text-transform:uppercase; letter-spacing:.12em; font-size:.74rem; font-weight:700; padding:.6rem 1.2rem; }
.svc-pricetable tbody td { padding:.85rem 1.2rem; border-top:1px solid var(--ark-line); text-align:right; color:var(--ark-graphite); }
.svc-pricetable tbody td:first-child { text-align:left; color:var(--ark-ink); }
.svc-pricetable .total { color:var(--ark-gold-deep); font-weight:800; }
.svc-pricetable tr.is-pack td { background:var(--ark-gold-wash); }
.svc-pricetable .save { display:inline-block; margin-left:.5rem; background:var(--ark-gold); color:var(--ark-black); font-size:.7rem; font-weight:800; padding:.15rem .55rem; border-radius:999px; }
.svc-tablewrap { overflow-x:auto; }

/* --- Promo Signo (gestión de riesgos) --- */
.svc-promo { display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; align-items:stretch; }
.svc-promo__left { background:var(--ark-gold); color:var(--ark-black); border-radius:22px; padding:clamp(1.6rem,4vw,2.6rem); position:relative; display:flex; flex-direction:column; }
.svc-promo__badge { position:absolute; top:1.4rem; right:1.4rem; width:46px; height:46px; border-radius:50%; background:var(--ark-black); color:var(--ark-gold); display:grid; place-items:center; }
.svc-promo__eyebrow { font-size:.74rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase; background:rgba(0,0,0,.12); border-radius:999px; padding:.35rem .9rem; align-self:flex-start; }
.svc-promo__left h3 { font-size:clamp(1.6rem,3.4vw,2.2rem); margin:1rem 0 .4rem; }
.svc-promo__sub { font-weight:700; font-size:1.1rem; margin:0 0 1rem; }
.svc-promo__left p { color:#3a2f00; margin:0 0 1.4rem; }
.svc-promo__cta { margin-top:auto; align-self:flex-start; }
.svc-promo__right { background:#eef0f7; border-radius:22px; padding:clamp(1.4rem,3vw,2rem); display:flex; flex-direction:column; gap:1.2rem; justify-content:center; }
.svc-promo__signo img { height:42px; width:auto; }
.svc-promo__offer { display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap; }
.svc-promo__free { background:#4b3bbf; color:#fff; border-radius:16px; padding:1rem 1.3rem; font-family:var(--ark-display); font-size:1.6rem; line-height:1; }
.svc-promo__free small { display:block; font-family:var(--ark-sans); font-size:.72rem; font-weight:600; opacity:.85; margin-top:.3rem; }
.svc-promo__price { color:#4b3bbf; }
.svc-promo__price b { font-family:var(--ark-display); font-size:2.4rem; }
.svc-promo__price span { display:block; font-size:.8rem; color:var(--ark-mute); }

@media (max-width:820px){ .svc-promo { grid-template-columns:1fr; } }

/* =====================================================================
   FASE J · Ajustes de portada (hero panel sólido + blog compacto) + SEO
   ===================================================================== */

/* Titular del hero un poco más contenido */
.hero h1 { font-size: clamp(2.8rem, 6vw, 5rem); }

/* Panel del hero: tarjeta autocontenida que fluye (sin posicionamiento absoluto) */
.hero__panel { min-height: auto; position: relative; }
.hero-mock { background: var(--ark-black); color: #fff; border-radius: 28px; padding: clamp(1.5rem,3vw,2.1rem); box-shadow: var(--ark-shadow-strong); position: relative; overflow: hidden; }
.hero-mock::before { content:""; position:absolute; right:-5rem; top:-4rem; width:16rem; height:16rem; border-radius:50%; background:rgba(240,190,21,.22); }
.hero-mock__kicker { position:relative; z-index:1; display:inline-flex; padding:.35rem .8rem; border:1px solid rgba(255,255,255,.22); border-radius:999px; font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:#fff; }
.hero-mock__title { position:relative; z-index:1; color:#fff; font-family:var(--ark-display); font-size:clamp(1.45rem,2.3vw,2rem); line-height:1.14; margin:1rem 0 1.1rem; max-width:20ch; }
.hero-mock__list { position:relative; z-index:1; list-style:none; padding:0; margin:0 0 1.2rem; display:grid; gap:.6rem; }
.hero-mock__list li { display:flex; gap:.6rem; align-items:flex-start; color:rgba(255,255,255,.9); font-weight:600; font-size:.95rem; }
.hero-mock__list li::before { content:""; width:.7rem; height:.7rem; margin-top:.35rem; border-radius:50%; background:var(--ark-gold); flex:0 0 auto; }
.hero-mock__cards { display:grid; grid-template-columns:1fr 1fr; gap:.7rem; }
.hero-mock__chip { background:#fff; color:var(--ark-ink); border-radius:14px; padding:.8rem .9rem; }
.hero-mock__chip strong { display:block; font-family:var(--ark-display); font-size:1.2rem; line-height:1; }
.hero-mock__chip span { display:block; margin-top:.2rem; color:var(--ark-graphite); font-size:.78rem; font-weight:600; line-height:1.25; }
@media (max-width:560px){ .hero-mock__cards { grid-template-columns:1fr; } }

/* Sección de blog en portada: más compacta y ajustada */
.home-posts .section__head { margin-bottom: 1.6rem; }
.home-posts .post-grid { gap: 1rem; }
.home-posts .post-card a { padding: 1.2rem 1.25rem; }
.home-posts .post-card h3 { font-size: 1.18rem; margin: .5rem 0 .7rem; line-height: 1.2; }

/* =====================================================================
   FASE K · Cabecera — CTA visible + menú móvil bien
   ===================================================================== */

/* El CTA "Consulta gratuita" recupera su texto blanco (lo tapaba .nav > a) */
.nav .nav__cta { color: var(--ark-white); }
.nav .nav__cta:hover { background: var(--ark-gold); border-color: var(--ark-gold); color: var(--ark-black); }
.btn--sm { padding: .6rem 1.05rem; font-size: .9rem; }

@media (max-width: 880px) {
  /* Menú anclado JUSTO debajo de la cabecera (sin offset fijo a mano) */
  .nav {
    position: absolute; top: 100%; left: 0; right: 0; inset-block-start: 100%;
    flex-direction: column; align-items: stretch; gap: 0;
    background: #fff; border-bottom: 1px solid var(--ark-line);
    padding: .6rem var(--ark-gutter) 1.2rem;
    transform: translateY(-135%); transition: transform .25s ease;
    box-shadow: var(--ark-shadow);
    max-height: calc(100dvh - 110px); overflow-y: auto;
  }
  .nav[data-open="true"] { transform: translateY(0); }

  /* CTA como botón sólido a ancho completo dentro del menú */
  .nav .nav__cta {
    width: 100%; justify-content: center; text-align: center;
    border: 0; border-radius: 14px; background: var(--ark-black); color: #fff;
    padding: .95rem; margin-top: 1rem;
  }
  .nav .nav__cta:hover { background: var(--ark-gold); color: var(--ark-black); }

  /* "Acceso clientes" a ancho completo y con etiqueta legible (en vez de •••) */
  .client-access-trigger { width: 100%; height: auto; border-radius: 14px; padding: .95rem; margin-top: .7rem; font-size: 0; }
  .client-access-trigger::after { content: "Acceso clientes"; font-size: 1rem; font-weight: 800; letter-spacing: normal; }
}

/* =====================================================================
   FASE L · Banner de campaña de la Renta (estilo dorado, como WordPress)
   ===================================================================== */
.renta-banner {
  display: flex; flex-direction: column; align-items: center; gap: .1rem;
  background: var(--ark-gold); color: #fff;
  text-decoration: none; text-align: center;
  padding: clamp(.7rem, 2vw, 1.1rem) 1rem;
  transition: background .2s ease;
}
.renta-banner:hover { background: #ffd23f; }
.renta-banner__pre { font-weight: 800; font-size: clamp(.82rem, 1.6vw, 1.05rem); }
.renta-banner__big {
  font-family: var(--ark-display); font-weight: 400; text-transform: uppercase;
  line-height: 1; letter-spacing: .005em;
  font-size: clamp(1.5rem, 4.6vw, 2.7rem);
}
.renta-banner__post { font-weight: 800; text-transform: uppercase; font-size: clamp(.8rem, 1.8vw, 1.15rem); line-height: 1.15; }
.renta-banner__note { font-size: clamp(.7rem, 1.2vw, .82rem); color: rgba(255,255,255,.9); margin-top: .2rem; }

/* =====================================================================
   FASE N · Logos de acreditación (reales), colaboradores más grandes,
            banner Signo por imagen en gestión de riesgos
   ===================================================================== */

/* Acreditaciones: se mantiene el estilo original (texto). */

/* Colaboradores: logos más grandes y a color */
.partners__logos { gap:3rem; }
.partners__logos img { height:70px; filter:none; opacity:1; }

/* Promo Signo con imagen real (gestión de riesgos) */
.svc-promo__banner { border-radius:22px; overflow:hidden; line-height:0; }
.svc-promo__banner img { display:block; width:100%; height:100%; object-fit:cover; }

@media (max-width:560px){
  .partners__logos img { height:54px; }
}

/* =====================================================================
   Bloque "¿Para quién es este servicio?" (dos columnas)
   ===================================================================== */
.svc-audience{ display:grid; grid-template-columns:1fr 1fr; gap:1.6rem; margin-top:2rem; }
.svc-audience__col{
  background:#fff; border:1px solid var(--ark-line,#ececec);
  border-radius:22px; padding:1.9rem 2rem;
}
.svc-audience__tag{
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--ark-black,#0b0b0d); color:#fff; font-weight:600;
  font-size:.85rem; letter-spacing:.02em; padding:.55rem 1.1rem;
  border-radius:999px; margin-bottom:1.3rem;
}
.svc-audience .svc-checklist{ margin:0; }
@media (max-width:760px){ .svc-audience{ grid-template-columns:1fr; } }

/* =====================================================================
   DGT: cajas de aviso + nº fantasma de pasos · Eyebrow · Reseñas (home)
   ===================================================================== */
.svc-eyebrow{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ark-gold-deep); font-weight:800; display:inline-block; margin-bottom:.4rem; }
.svc-section--dark .svc-eyebrow{ color:var(--ark-gold); }

.svc-note--gold{ background:var(--ark-gold-wash); border-color:rgba(240,190,21,.5); color:#4a3a00; }
.svc-note--info{ background:#eef2fb; border-color:#d4ddf3; color:#2a3a63; }

.svc-step{ overflow:hidden; }
.svc-step__ghost{ position:absolute; top:.5rem; right:.5rem; font-family:var(--ark-display); font-size:3rem; line-height:1; font-weight:400; color:rgba(255,255,255,.07); }
.svc-section:not(.svc-section--dark) .svc-step__ghost{ color:rgba(0,0,0,.05); }

/* Reseñas en la home */
.reviews .reviews__head{ text-align:center; }
.reviews__badge{ display:inline-flex; align-items:center; gap:.5rem; font-weight:700; margin-top:.4rem; }
.reviews__stars,.review-card__stars{ color:var(--ark-gold-deep); letter-spacing:2px; }
.reviews__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.2rem; margin:2rem 0; }
.review-card{ background:#fff; border:1px solid var(--ark-line); border-radius:18px; padding:1.5rem; }
.review-card__stars{ margin-bottom:.6rem; }
.review-card p{ color:var(--ark-graphite); margin:0 0 1rem; font-size:.96rem; line-height:1.6; }
.review-card__who{ font-weight:700; font-size:.9rem; color:var(--ark-ink); }
.reviews__cta{ text-align:center; }

/* =====================================================================
   Reseñas estilo "tarjetas crema + estrellas verdes + Google" (home)
   ===================================================================== */
.reviews .reviews__head h2{ text-align:center; font-family:var(--ark-display); font-size:clamp(1.7rem,3.4vw,2.4rem); margin:0 auto 1.8rem; max-width:24ch; }
.reviews__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; margin:1.5rem 0 1.8rem; }
.review-card{ background:#faf6ef; border:1px solid #f0ead9; border-radius:18px; padding:2rem 1.6rem; text-align:center; }
.review-card__stars,.reviews__stars{ color:#1f8a4c; letter-spacing:3px; font-size:1.05rem; }
.review-card__stars{ margin-bottom:1rem; }
.review-card p{ color:var(--ark-graphite); margin:0 0 1.2rem; font-size:.95rem; line-height:1.6; }
.review-card__who{ font-weight:800; font-size:.92rem; color:var(--ark-ink); }
.reviews__foot{ text-align:center; margin-top:.5rem; }
.reviews__foot p{ color:var(--ark-graphite); font-size:.95rem; margin:0 0 .5rem; }
.reviews__foot a{ color:var(--ark-ink); font-weight:800; text-decoration:underline; }
.reviews__google{ display:inline-block; font-family:Arial,Helvetica,sans-serif; font-weight:700; font-size:1.7rem; letter-spacing:-.5px; text-decoration:none; }
@media (max-width:820px){ .reviews__grid{ grid-template-columns:1fr; } }

/* =====================================================================
   Colaboradores estilo "título + línea + logos grandes" (home), enlazados
   ===================================================================== */
.colaboradores{ margin-top:3rem; }
.colaboradores__title{ font-family:var(--ark-display); font-size:clamp(1.4rem,2.6vw,2rem); margin:0 0 1rem; padding-bottom:1rem; border-bottom:1px solid var(--ark-line); }
.colaboradores__logos{ display:grid; grid-template-columns:1fr 1fr; gap:2rem; align-items:center; margin-top:1.5rem; }
.colaboradores__logo{ display:flex; align-items:center; justify-content:center; padding:1.5rem; border-radius:18px; transition:transform .2s, box-shadow .2s; }
.colaboradores__logo:hover{ transform:translateY(-3px); box-shadow:var(--ark-shadow); }
.colaboradores__logo img{ max-height:90px; max-width:100%; width:auto; object-fit:contain; }
.colaboradores__logo--box{ background:#f4f4f5; }
@media (max-width:680px){ .colaboradores__logos{ grid-template-columns:1fr; } }


/* ==========================================================================
   Arklos · Asesor Excelente + Código deontológico
   ========================================================================== */
.trust-ae{background:#fff;border-top:1px solid rgba(12,12,13,.08);border-bottom:1px solid rgba(12,12,13,.08)}
.trust-ae__grid{display:grid;grid-template-columns:minmax(180px,260px) 1fr;gap:clamp(1.5rem,4vw,3.2rem);align-items:center}
.trust-ae__seal{background:#fff;border:1px solid rgba(12,12,13,.10);border-radius:28px;padding:1rem;box-shadow:0 18px 50px rgba(12,12,13,.08)}
.trust-ae__seal img{display:block;width:100%;height:auto;border-radius:20px}
.trust-ae__copy h2{margin:0 0 .8rem;font-size:clamp(1.8rem,3vw,2.7rem);letter-spacing:-.035em;line-height:1.05}
.trust-ae__copy p{font-size:1.04rem;line-height:1.65;color:#343436;margin:.8rem 0;max-width:75ch}
.trust-ae__badges{display:flex;flex-wrap:wrap;gap:.65rem;margin:1.2rem 0 1.5rem;padding:0;list-style:none}
.trust-ae__badges li{display:inline-flex;align-items:center;gap:.45rem;border:1px solid rgba(12,12,13,.10);background:#faf9f6;border-radius:999px;padding:.62rem .9rem;font-weight:800;font-size:.9rem;color:#151515}
.trust-ae__badges li::before{content:"";width:.55rem;height:.55rem;border-radius:999px;background:#f0be15;box-shadow:0 0 0 4px rgba(240,190,21,.18)}
.trust-ae__actions{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
.deonto-hero-note{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.65rem .9rem;border-radius:999px;background:#fff7d8;color:#4c3800;font-weight:800;border:1px solid rgba(240,190,21,.35)}
.deonto-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.4rem 0 2rem}
.deonto-card{background:#fff;border:1px solid rgba(12,12,13,.10);border-radius:24px;padding:1.25rem;box-shadow:0 14px 35px rgba(12,12,13,.06)}
.deonto-card h3{margin:.2rem 0 .5rem;font-size:1.15rem;letter-spacing:-.02em}
.deonto-card p{margin:0;color:#555;line-height:1.55}
.pdf-viewer{margin:2rem 0 3rem;background:#fff;border:1px solid rgba(12,12,13,.12);border-radius:28px;overflow:hidden;box-shadow:0 24px 60px rgba(12,12,13,.08)}
.pdf-viewer__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:#faf9f6;border-bottom:1px solid rgba(12,12,13,.08)}
.pdf-viewer__head h2{font-size:1.1rem;margin:0;letter-spacing:-.02em}
.pdf-viewer__head a{font-weight:800;color:#0c0c0d;text-decoration:none;border-bottom:2px solid #f0be15}
.pdf-viewer iframe{display:block;width:100%;height:min(78vh,880px);border:0;background:#f4f4f4}
.deonto-final{background:#111;color:#fff;border-radius:28px;padding:clamp(1.5rem,4vw,2.8rem);margin:2rem 0}
.deonto-final h2{color:#fff;margin-top:0}
.deonto-final p{color:rgba(255,255,255,.78);max-width:78ch}
.deonto-final .btn{margin-top:.75rem}
@media(max-width:820px){
  .trust-ae__grid{grid-template-columns:1fr}.trust-ae__seal{max-width:260px}.deonto-grid{grid-template-columns:1fr}.pdf-viewer iframe{height:70vh}.pdf-viewer__head{align-items:flex-start;flex-direction:column}.trust-ae__actions{align-items:stretch}.trust-ae__actions .btn{justify-content:center;width:100%}
}

/* Arklos · Certificado ASOCIAE */
.deonto-cert{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;margin:1.35rem 0 1.2rem;padding:1.25rem;border-radius:24px;background:#111;color:#fff;box-shadow:0 18px 45px rgba(12,12,13,.12)}
.deonto-cert h3{margin:.1rem 0 .45rem;color:#fff;font-size:1.15rem;letter-spacing:-.02em}
.deonto-cert p{margin:0;color:rgba(255,255,255,.78);line-height:1.55;max-width:78ch}
.deonto-cert .btn{white-space:nowrap}
@media (max-width:760px){.deonto-cert{align-items:flex-start;flex-direction:column}.deonto-cert .btn{width:100%;justify-content:center}}

/* -------------------------------------------------------------------------
   Blog content blocks - Arklos style
   Use these classes inside CMS article HTML instead of inline styles.
   ---------------------------------------------------------------------- */
.article__body .arklos-post {
  color: var(--ark-ink, #111111);
  font-size: clamp(1.05rem, 1.2vw, 1.16rem);
  line-height: 1.78;
}
.article__body .arklos-post p {
  margin: 0 0 1.45rem;
  color: var(--ark-graphite, #333333);
}
.article__body .arklos-post strong {
  color: var(--ark-ink, #111111);
  font-weight: 800;
}
.article__body .arklos-post h2 {
  margin: 3rem 0 1.1rem;
  color: var(--ark-ink, #111111);
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(2rem, 4vw, 3.1rem);
  line-height: .98;
  letter-spacing: -.045em;
}
.article__body .arklos-post ul,
.article__body .arklos-post ol {
  margin: 0 0 1.9rem;
  padding-left: 1.55rem;
  color: var(--ark-graphite, #333333);
}
.article__body .arklos-post li { margin-bottom: .75rem; }
.article__body .arklos-table-wrap {
  overflow-x: auto;
  margin: 2.4rem 0;
  border: 1px solid var(--ark-line, #e8e2d6);
  border-radius: var(--ark-radius, 22px);
  background: #fff;
}
.article__body .arklos-table {
  width: 100%;
  min-width: 620px;
  border-collapse: collapse;
  font-size: .98rem;
}
.article__body .arklos-table th {
  padding: 1rem 1.25rem;
  background: var(--ark-ink, #111111);
  color: var(--ark-yellow, #f5c400);
  text-align: left;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .78rem;
}
.article__body .arklos-table td {
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--ark-line, #eee8dc);
  color: var(--ark-graphite, #333333);
}
.article__body .arklos-table tr:nth-child(even) td { background: var(--ark-soft, #fbf8ef); }
.article__body .arklos-note {
  margin: 2.5rem 0;
  padding: 1.55rem 1.7rem;
  border-radius: var(--ark-radius, 24px);
  background: #fbf4d7;
  border: 1px solid #f0d45c;
}
.article__body .arklos-note p {
  margin: 0;
  color: var(--ark-ink, #111111);
  font-size: 1.02rem;
  line-height: 1.65;
}
.article__body .arklos-note span {
  display: inline-block;
  margin-bottom: .5rem;
  color: #a87900;
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.article__body .arklos-cta {
  margin: 3.4rem 0 .6rem;
  padding: clamp(2rem, 5vw, 3.4rem);
  border-radius: calc(var(--ark-radius, 24px) + 8px);
  background: var(--ark-ink, #111111);
  color: #fff;
  text-align: center;
}
.article__body .arklos-cta h3 {
  margin: 0 auto 1rem;
  max-width: 760px;
  color: #fff;
  font-family: 'DM Serif Display', Georgia, serif;
  font-size: clamp(2rem, 5vw, 3.7rem);
  line-height: .96;
  letter-spacing: -.05em;
}
.article__body .arklos-cta p {
  max-width: 660px;
  margin: 0 auto 1.75rem;
  color: #e9e4d8;
  font-size: 1.06rem;
  line-height: 1.65;
}
.article__body .arklos-cta a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 1.65rem;
  border-radius: 999px;
  background: var(--ark-yellow, #f5c400);
  color: var(--ark-ink, #111111);
  text-decoration: none;
  font-weight: 900;
}
.article__body .arklos-cta a:hover { background: #ffd733; }
@media (max-width: 720px) {
  .article__body .arklos-post { font-size: 1.02rem; }
  .article__body .arklos-note { padding: 1.25rem; }
}

/* -------------------------------------------------------------------------
   Logos locales Arklos · migración desde WordPress
   ------------------------------------------------------------------------- */
.site-header__logo img,
.arkfoot__brand img {
  display: block;
  object-fit: contain;
}
.site-header__logo img {
  width: 156px;
  max-height: 42px;
}
.arkfoot__brand img {
  width: 168px;
  height: auto;
  max-height: 46px;
}
@media (max-width: 760px) {
  .site-header__logo img { width: 138px; max-height: 38px; }
}

@media (max-width: 880px) {
  .roadmap-card { grid-template-columns: 1fr; border-radius: 26px; }
  .roadmap-card__main h2 { max-width: 100%; }
  .roadmap-card__side { border-radius: 22px; }
}
@media (max-width: 560px) {
  .roadmap-card { padding: 1rem; }
  .roadmap-card__actions .btn { width: 100%; justify-content: center; }
  .roadmap-status { width: 100%; justify-content: space-between; }
}
@media (max-width: 740px) {
  .arklos-update-card {
    left: .8rem;
    right: .8rem;
    bottom: .8rem;
    width: auto;
    padding: 1rem;
  }
  .arklos-update-card h2 { font-size: 1.1rem; }
  .arklos-update-card p { font-size: .88rem; }
  .arklos-update-modal { padding: .75rem; align-items: end; }
  .arklos-update-modal__panel {
    max-height: 88vh;
    border-radius: 24px 24px 0 0;
    padding: 1.1rem;
  }
  .arklos-update-grid,
  .arklos-update-timeline { grid-template-columns: 1fr; }
  .arklos-update-timeline div { border-right: 0; border-bottom: 1px solid var(--ark-line); }
  .arklos-update-timeline div:last-child { border-bottom: 0; }
  .arklos-update-modal__foot { display: grid; }
  .arklos-update-modal__ok { width: 100%; }
}

/* Arklos · Términos y condiciones */
.terms-hero .legal-intro{max-width:760px}.terms-body .legal-wrap{max-width:920px}.terms-body h2{margin-top:2.4rem}.terms-body ul{margin:0 0 1.4rem 1.2rem;color:var(--ark-graphite);line-height:1.75}.terms-body li{margin:.45rem 0}.terms-alert{border:1px solid rgba(240,190,21,.45);background:linear-gradient(135deg,#fff7dc,#fffaf0);border-radius:22px;padding:1.25rem 1.35rem;margin:0 0 2rem;color:#191919;line-height:1.65}.terms-price{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid #e8e2d6;border-radius:24px;overflow:hidden;margin:1.4rem 0 1.7rem;background:#fff}.terms-price div{padding:1.1rem 1.2rem;border-right:1px solid #e8e2d6}.terms-price div:last-child{border-right:0;background:#111;color:#fff}.terms-price span{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:#8a6b00;margin-bottom:.35rem}.terms-price div:last-child span{color:#f0be15}.terms-price strong{font-size:1.45rem;color:inherit}.terms-closing{margin:2.8rem 0 0;padding:1.35rem 1.5rem;border-radius:24px;background:#111;color:#fff;line-height:1.65}.terms-closing strong{color:#f0be15}@media(max-width:720px){.terms-price{grid-template-columns:1fr}.terms-price div{border-right:0;border-bottom:1px solid #e8e2d6}.terms-price div:last-child{border-bottom:0}}


   ARKLOS · Sistema de citas
   ===================================================================== */
.appt-hero{background:linear-gradient(180deg,var(--ark-soft),#fff);padding:clamp(3rem,7vw,6rem) 0 3rem;border-bottom:1px solid var(--ark-line)}
.appt-hero__grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:clamp(1.5rem,4vw,4rem);align-items:center}.appt-lead{font-size:clamp(1.1rem,1.7vw,1.35rem);max-width:760px;color:var(--ark-graphite)}.appt-price{display:inline-flex;align-items:center;gap:1rem;flex-wrap:wrap;background:var(--ark-black);color:#fff;border-radius:999px;padding:.7rem 1.1rem;margin:1rem 0}.appt-price strong{color:var(--ark-gold);font-size:1.12rem}.appt-price span{color:#f4f0e5}.appt-small{color:var(--ark-mute);font-size:.92rem}.appt-hero__card,.appt-form-card,.appt-team-card,.appt-confirm__box{background:#fff;border:1px solid var(--ark-line);border-radius:var(--ark-radius);box-shadow:var(--ark-shadow);padding:clamp(1.2rem,2.4vw,2rem)}.appt-hero__card h2,.appt-form-card h2,.appt-team-card h2{font-size:clamp(1.65rem,3vw,2.4rem)}.appt-section{background:var(--ark-paper)}.appt-grid{display:grid;grid-template-columns:minmax(0,1fr) 350px;gap:1.5rem;align-items:start}.appt-form label{display:block;font-weight:800;color:var(--ark-black);margin:1rem 0 .5rem}.appt-form input:not([type=radio]):not([type=checkbox]),.appt-form select,.appt-form textarea{width:100%;border:1.5px solid var(--ark-line);border-radius:14px;padding:.92rem 1rem;background:#fff;font:inherit;color:var(--ark-ink)}.appt-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.appt-topic-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin-bottom:1rem}.appt-option{border:1.5px solid var(--ark-line);border-radius:16px;padding:1rem;display:flex;gap:.75rem;align-items:center;background:#fff;cursor:pointer;transition:.18s}.appt-option:has(input:checked){border-color:var(--ark-gold);background:var(--ark-gold-wash);box-shadow:0 14px 35px -28px rgba(0,0,0,.45)}.appt-option--blocked{background:#fff7f7}.appt-blocked{border:1.5px solid #f4b5b5;background:#fff5f5;border-radius:18px;padding:1rem 1.1rem;margin:1rem 0}.appt-blocked p{margin:.35rem 0 1rem}.appt-slots{display:flex;gap:.55rem;flex-wrap:wrap;min-height:52px;align-items:center}.appt-slot{border:1.5px solid var(--ark-black);border-radius:999px;background:#fff;padding:.75rem 1rem;font-weight:900;cursor:pointer}.appt-slot.is-selected,.appt-slot:hover{background:var(--ark-black);color:#fff}.appt-empty{color:var(--ark-mute);font-size:.95rem}.appt-privacy{font-size:.95rem!important;font-weight:500!important;color:var(--ark-graphite)!important;display:flex!important;gap:.65rem;align-items:flex-start}.appt-privacy input{margin-top:.35rem}.appt-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin:1.4rem 0}.appt-summary>div{background:var(--ark-soft);border:1px solid var(--ark-line);border-radius:16px;padding:1rem}.appt-summary span{display:block;color:var(--ark-mute);font-size:.9rem}.appt-summary strong{font-size:1.15rem;color:var(--ark-black)}.appt-member{border-top:1px solid var(--ark-line);padding-top:1.2rem;margin-top:1.2rem}.appt-member:first-of-type{border-top:0;margin-top:0;padding-top:0}.appt-avatar{width:74px;height:74px;border-radius:22px;background:var(--ark-black);color:var(--ark-gold);display:grid;place-items:center;font-family:var(--ark-display);font-size:2rem}.appt-member h3{margin-top:1rem}.appt-role{font-weight:900;color:var(--ark-gold-deep)}.appt-confirm{padding:clamp(4rem,8vw,7rem) 0;background:var(--ark-paper)}.appt-confirm__box{text-align:center;max-width:820px;margin:auto}.appt-confirm__summary{background:var(--ark-soft);border:1px solid var(--ark-line);border-radius:18px;padding:1rem;margin:1.3rem 0;text-align:left}
@media(max-width:900px){.appt-hero__grid,.appt-grid{grid-template-columns:1fr}.appt-two,.appt-topic-grid,.appt-summary{grid-template-columns:1fr}}

/* Arklos · Citas v19: formulario profesional y pagos */
.appt-hero--pro{position:relative;overflow:hidden}.appt-hero--pro:after{content:"";position:absolute;right:-10vw;top:-12vw;width:32vw;height:32vw;background:radial-gradient(circle,rgba(240,190,21,.22),transparent 62%);pointer-events:none}.appt-hero__card--checklist ul{list-style:none;padding:0;margin:1rem 0}.appt-hero__card--checklist li{position:relative;padding-left:1.65rem;margin:.65rem 0;color:var(--ark-graphite);line-height:1.55}.appt-hero__card--checklist li:before{content:"";position:absolute;left:0;top:.55rem;width:.55rem;height:.55rem;border-radius:50%;background:var(--ark-gold)}
.appt-grid--pro{grid-template-columns:minmax(0,1fr) 370px}.appt-form-card--pro{padding:0;overflow:hidden}.appt-form--steps{padding:0}.appt-step{padding:clamp(1.15rem,2.4vw,1.8rem);border-bottom:1px solid var(--ark-line)}.appt-step:last-of-type{border-bottom:0}.appt-step__head{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1rem}.appt-step__head>span{flex:0 0 38px;height:38px;border-radius:13px;background:var(--ark-black);color:var(--ark-gold);display:grid;place-items:center;font-weight:1000}.appt-step__head h2{margin:0;font-size:clamp(1.35rem,2.2vw,2rem)}.appt-step__head p{margin:.28rem 0 0;color:var(--ark-mute);line-height:1.55}.appt-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.appt-choice{align-items:flex-start}.appt-choice input{margin-top:.2rem}.appt-choice span{font-weight:900;line-height:1.25}.appt-choice em{display:block;font-style:normal;color:#b42318;font-size:.78rem;font-weight:900;margin-top:.25rem}.appt-payment-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem}.appt-pay-option{border:1.5px solid var(--ark-line);border-radius:18px;padding:1rem;background:#fff;display:flex!important;gap:.7rem;align-items:flex-start!important;margin:0!important;cursor:pointer;transition:.18s}.appt-pay-option input{margin-top:.25rem}.appt-pay-option strong{display:block;color:var(--ark-black);line-height:1.2}.appt-pay-option small{display:block;color:var(--ark-mute);font-weight:600;line-height:1.45;margin-top:.3rem}.appt-pay-option:has(input:checked){border-color:var(--ark-gold);background:var(--ark-gold-wash);box-shadow:0 18px 38px -34px rgba(0,0,0,.55)}.appt-pay-option.is-disabled{opacity:.55;cursor:not-allowed}.appt-pay-option.is-hidden{display:none!important}.appt-payment-help{margin-top:1rem;border:1px solid rgba(240,190,21,.38);background:linear-gradient(135deg,#fffaf0,#fff);border-radius:20px;padding:1.1rem 1.2rem}.appt-payment-help h3{margin:.1rem 0 .7rem;font-size:1.1rem}.appt-payment-help p{margin:.35rem 0;color:var(--ark-graphite);line-height:1.55}.appt-payment-help a{font-weight:900;color:var(--ark-black);text-decoration:underline;text-decoration-color:var(--ark-gold)}.appt-summary--sticky{margin:1.2rem clamp(1.15rem,2.4vw,1.8rem)}.appt-submit{margin:0 clamp(1.15rem,2.4vw,1.8rem) 0}.appt-form--steps>.appt-small{margin:1rem clamp(1.15rem,2.4vw,1.8rem) 1.5rem}.appt-form--steps>.appt-privacy{margin:1rem clamp(1.15rem,2.4vw,1.8rem) .5rem!important}.appt-team-card--sticky{position:sticky;top:110px}.appt-mini-summary{display:grid;gap:.7rem;margin:0 0 1.2rem}.appt-mini-summary p{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin:0;padding:.85rem 0;border-bottom:1px solid var(--ark-line)}.appt-mini-summary span{color:var(--ark-mute);font-weight:800}.appt-mini-summary strong{text-align:right;color:var(--ark-black)}
@media(max-width:980px){.appt-grid--pro{grid-template-columns:1fr}.appt-team-card--sticky{position:static}.appt-payment-grid{grid-template-columns:1fr}.appt-choice-grid{grid-template-columns:1fr}}
@media(max-width:640px){.appt-step__head{gap:.75rem}.appt-step__head>span{flex-basis:34px;height:34px}.appt-summary--sticky{grid-template-columns:1fr}.appt-mini-summary p{display:block}.appt-mini-summary strong{text-align:left;display:block;margin-top:.2rem}}

/* Citas: dirección presencial */
.appt-office-note{margin-top:1rem;padding:1rem 1.1rem;border:1px solid rgba(245,196,0,.45);background:#fff8df;border-radius:18px;color:#111}
.appt-office-note strong{display:block;font-weight:900;margin-bottom:.25rem}
.appt-office-note p{margin:0;color:#4b4b4b;line-height:1.45}
@media (max-width:680px){.appt-office-note{padding:.9rem;border-radius:16px}}
