:root{
  --ink-900:#100C1E;
  --ink-850:#1B1432;
  --ink-800:#241A43;
  --ink-700:#453C5F;
  --ink-600:#665F7B;
  --ink-500:#878198;

  --cream-50:#F7F0E6;
  --gold-500:#F9D849;

  --text-on-dark:rgba(247,240,230,.92);
  --text-on-dark-muted:rgba(247,240,230,.72);
  --text-on-light:rgba(16,12,30,.92);
  --text-on-light-muted:rgba(16,12,30,.62);

  --h1:clamp(2.15rem,4vw,3.4rem);
  --h2:clamp(1.6rem,2.6vw,2.25rem);
  --h3:1.25rem;
  --body:1rem;
  --body-lg:1.0625rem;

  --tracking-tight:-0.02em;
  --tracking-normal:-0.01em;
  --leading-tight:1.15;
  --leading-normal:1.55;

  --container:1120px;
  --gutter:clamp(1rem,4vw,2rem);
  --section-y:clamp(3.2rem,6vw,5.5rem);

  --r-sm:12px;
  --r-md:16px;
  --r-lg:20px;   /* ✅ un poco más rectangular/clean */
  --r-xl:28px;

  --glass-dark-bg:rgba(247,240,230,.06);
  --glass-dark-border:rgba(249,216,73,.16);
  --glass-dark-blur:18px;

  --glass-light-bg:rgba(255,255,255,.58);
  --glass-light-border:rgba(36,26,67,.10);
  --glass-light-blur:14px;

  --nav-bg:rgba(16,12,30,.46);
  --nav-border:rgba(255,255,255,.10);
  --nav-blur:16px;

  --shadow-1:0 10px 30px rgba(0,0,0,.35);
  --shadow-soft:0 12px 35px rgba(16,12,30,.12);
  --rim-light:inset 0 1px 0 rgba(255,255,255,.10);

  --t-mid:260ms;
  --t-slow:520ms;
  --ease:cubic-bezier(.2,.8,.2,1);

  --btn-h:46px;
  --btn-h-lg:52px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text-on-dark);
  background:var(--ink-900);
  line-height:var(--leading-normal);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
img{max-width:100%;display:block}
.container{
  width:min(var(--container), calc(100% - (var(--gutter) * 2)));
  margin-inline:auto;
}
.section{padding:var(--section-y) 0}
.section--light{
  background:linear-gradient(180deg, rgba(247,240,230,.95), rgba(247,240,230,.92));
  color:var(--text-on-light);
}
.section--light .muted{color:var(--text-on-light-muted)}
.muted{color:var(--text-on-dark-muted)}
.fine{font-size:.85rem;color:var(--text-on-dark-muted);margin:12px 0 0}
.section--light .fine{color:var(--text-on-light-muted)}

/* Typography */
.h1{
  font-family:Sora, Inter, sans-serif;
  font-size:var(--h1);
  letter-spacing:var(--tracking-tight);
  line-height:var(--leading-tight);
  margin:.35rem 0 1rem;
}
.h2{
  font-family:Sora, Inter, sans-serif;
  font-size:var(--h2);
  letter-spacing:var(--tracking-tight);
  line-height:1.2;
  margin:0 0 .6rem;
}
.h3{
  font-family:Sora, Inter, sans-serif;
  font-size:var(--h3);
  letter-spacing:var(--tracking-normal);
  margin:0;
}
.lead{font-size:var(--body-lg);margin:0 0 1.25rem;color:var(--text-on-dark-muted)}
.sub{margin:0;max-width:62ch}
.section--light .sub{color:var(--text-on-light-muted)}
.section__head{margin-bottom:1.6rem}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  font-size:.9rem;
  color:var(--text-on-dark-muted);
}
.kicker__dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--gold-500);
  box-shadow:0 0 0 6px rgba(249,216,73,.10);
}

/* Background */
.bg{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(249,216,73,.10), transparent 60%),
    radial-gradient(900px 500px at 110% 20%, rgba(135,129,152,.16), transparent 60%),
    linear-gradient(180deg, var(--ink-900), var(--ink-800));
}
.blob{
  position:absolute;
  width:min(520px, 75vw);
  aspect-ratio:1/1;
  border-radius:999px;
  filter:blur(40px);
  opacity:.55;
  mix-blend-mode:screen;
  animation:float 28s var(--ease) infinite;
}
.blob--a{left:-10%;top:10%;background:radial-gradient(circle at 30% 30%, rgba(249,216,73,.35), transparent 55%)}
.blob--b{right:-15%;top:22%;background:radial-gradient(circle at 30% 30%, rgba(135,129,152,.42), transparent 55%);animation-duration:34s}
.blob--c{left:25%;bottom:-25%;background:radial-gradient(circle at 30% 30%, rgba(70,55,115,.40), transparent 55%);animation-duration:40s}
@keyframes float{
  0%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(6%, -5%, 0) scale(1.04)}
  100%{transform:translate3d(0,0,0) scale(1)}
}
.noise{
  position:absolute;inset:0;
  opacity:.035;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.65) 0 1px, transparent 1px 2px),
    repeating-linear-gradient(90deg, rgba(0,0,0,.45) 0 1px, transparent 1px 3px);
  mix-blend-mode:overlay;
  pointer-events:none;
}
.top-rim{
  position:fixed;left:0;right:0;top:0;height:120px;
  background:linear-gradient(180deg, rgba(249,216,73,.08), transparent);
  z-index:-1;
  pointer-events:none;
}

/* Glass */
.glass-card{
  background:var(--glass-dark-bg);
  border:1px solid var(--glass-dark-border);
  border-radius:var(--r-xl);
  backdrop-filter:blur(var(--glass-dark-blur));
  -webkit-backdrop-filter:blur(var(--glass-dark-blur));
  box-shadow:var(--shadow-1);
  position:relative;
}
.glass-card::before{
  content:"";
  position:absolute;inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(120deg, rgba(255,255,255,.10), transparent 35%, rgba(255,255,255,.06));
  opacity:.55;
  mix-blend-mode:overlay;
}
.glass-light{
  background:var(--glass-light-bg);
  border:1px solid var(--glass-light-border);
  border-radius:var(--r-lg); /* ✅ más rectangular */
  backdrop-filter:blur(var(--glass-light-blur));
  -webkit-backdrop-filter:blur(var(--glass-light-blur));
  box-shadow:var(--shadow-soft);
  position:relative;
}
.glass-light::before{
  content:"";
  position:absolute;inset:0;border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(120deg, rgba(255,255,255,.55), transparent 45%, rgba(255,255,255,.25));
  opacity:.35;
}

/* Nav */
.nav-wrap{position:sticky;top:0;z-index:50}
.glass-nav{
  margin-top:14px;
  background:var(--nav-bg);
  border:1px solid var(--nav-border);
  border-radius:var(--r-xl);
  backdrop-filter:blur(var(--nav-blur));
  -webkit-backdrop-filter:blur(var(--nav-blur));
  box-shadow:var(--shadow-1);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;
  gap:14px;
}
.brand{display:flex;align-items:center;gap:.75rem}
.brand__mark{
  width:40px;height:40px;border-radius:14px;
  display:grid;place-items:center;
  background:rgba(249,216,73,.10);
  border:1px solid rgba(249,216,73,.22);
  box-shadow:var(--rim-light);
}
.brand__name{font-family:Sora, Inter, sans-serif;font-weight:700;letter-spacing:var(--tracking-normal)}
.nav__links{
  display:flex;align-items:center;gap:14px;
  color:var(--text-on-dark-muted);
}
.nav__links a{
  padding:10px 10px;border-radius:12px;
  transition:background var(--t-mid) var(--ease), color var(--t-mid) var(--ease);
}
.nav__links a:hover{background:rgba(255,255,255,.06);color:var(--text-on-dark)}
.nav__toggle{
  display:none;
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
}
.nav__toggle span{
  display:block;height:2px;background:rgba(247,240,230,.9);
  margin:6px 10px;border-radius:999px;
}

/* Logo slots */
.brand__logo{
  width:40px;height:40px;
  border-radius:14px;
  object-fit:contain;
  background:rgba(249,216,73,.10);
  border:1px solid rgba(249,216,73,.18);
  box-shadow:var(--rim-light);
}
.brand__logo--footer{ width:36px;height:36px;border-radius:14px; }

/* ✅ NAV association */
.nav__right{
  display:flex;
  align-items:center;
  gap:12px;
}
.nav__assoc{
  width:170px;
  height:44px;
  border-radius:16px;
  overflow:hidden;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:var(--rim-light);
}
.nav__assocLogo{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:8px 10px;
  display:block;
}
.nav__assocPlaceholder{
  font-size:.85rem;
  font-weight:800;
  color:rgba(247,240,230,.78);
  letter-spacing:-0.01em;
}

/* Hero */
.hero{padding-top:28px}
.hero__grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:24px;
  align-items:stretch;
}
.hero__copy{padding:18px 0}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 14px}
.badges{display:flex;gap:10px;flex-wrap:wrap}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(249,216,73,.14);
  color:var(--text-on-dark);
  font-size:.9rem;
}

.hero__panel{padding:18px}
.panel__head .muted{margin:.35rem 0 0}
.panel__list{
  list-style:none;padding:0;margin:16px 0 18px;
  display:grid;gap:10px;
  color:var(--text-on-dark);
}
.panel__list li{display:flex;align-items:center;gap:10px}
.ico{color:var(--gold-500)}
.panel__foot{
  display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap
}
.mini{display:grid;gap:2px}
.mini__label{font-size:.85rem;color:var(--text-on-dark-muted)}
.mini__value{font-weight:600}

/* Buttons */
.btn{
  border:none;
  height:var(--btn-h);
  padding:0 16px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;justify-content:center;
  gap:10px;
  transition:transform var(--t-mid) var(--ease), box-shadow var(--t-mid) var(--ease), background var(--t-mid) var(--ease), border-color var(--t-mid) var(--ease);
  user-select:none;
}
.btn--sm{height:40px;padding:0 14px;border-radius:14px}
.btn--lg{height:var(--btn-h-lg);padding:0 18px;border-radius:18px;font-weight:700}
.btn--primary{
  background:linear-gradient(180deg, rgba(249,216,73,1), rgba(212,184,62,1));
  color:var(--ink-900);
  box-shadow:0 16px 40px rgba(249,216,73,.16), 0 10px 30px rgba(0,0,0,.25);
}
.btn--primary:hover{transform:translateY(-2px)}
.btn--glass{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  color:var(--text-on-dark);
  box-shadow:var(--rim-light);
}
.btn--glass:hover{transform:translateY(-2px);background:rgba(255,255,255,.085)}

/* ✅ Mejor contraste en secciones claras */
.section--light .btn--glass{
  background:rgba(16,12,30,.06);
  border:1px solid rgba(16,12,30,.12);
  color:rgba(16,12,30,.92);
  box-shadow:var(--shadow-soft);
}
.section--light .btn--glass:hover{
  background:rgba(16,12,30,.085);
}

/* Cards grid */
.grid.cards{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}
.card{
  padding:18px;
  min-height:210px;
  display:flex;flex-direction:column;
  position:relative;
}
.card__icon{
  width:46px;height:46px;border-radius:16px;
  display:grid;place-items:center;
  background:rgba(36,26,67,.06);
  border:1px solid rgba(36,26,67,.10);
  margin-bottom:12px;
}
.card__title{margin:0 0 8px;font-family:Sora, Inter, sans-serif}
.card__text{margin:0 0 14px;color:var(--text-on-light-muted)}
.link{
  margin-top:auto;
  background:transparent;border:none;padding:0;
  color:rgba(36,26,67,.86);
  font-weight:700;
}
.link:hover{text-decoration:underline}

/* Servicios como imagen */
.card__icon--img{
  width:58px;height:58px;
  border-radius:18px;
  overflow:hidden;
  background:
    radial-gradient(70% 70% at 30% 20%, rgba(249,216,73,.22), transparent 60%),
    radial-gradient(80% 80% at 80% 80%, rgba(70,55,115,.18), transparent 65%),
    rgba(36,26,67,.06);
  border:1px solid rgba(36,26,67,.12);
}
.service__img{width:100%;height:100%;object-fit:cover;display:block}
.card__icon--img.is-empty{
  display:grid;
  place-items:center;
}
.card__icon--img.is-empty::after{
  content:"Imagen";
  font-weight:800;
  font-size:.72rem;
  letter-spacing:.02em;
  color:rgba(16,12,30,.68);
  background:rgba(255,255,255,.40);
  border:1px solid rgba(36,26,67,.10);
  padding:6px 9px;
  border-radius:999px;
}

/* Steps */
.steps{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:12px;
}
.step{padding:16px}
.step__num{
  display:inline-flex;
  font-family:Sora, Inter, sans-serif;
  font-weight:800;
  color:rgba(249,216,73,.92);
  letter-spacing:-0.02em;
}
.step__title{margin:10px 0 6px}
.step__text{margin:0;color:var(--text-on-dark-muted);font-size:.95rem}
.note{
  margin-top:14px;
  display:flex;gap:10px;align-items:flex-start;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
}
.note__icon{color:var(--gold-500);font-weight:800}

/* About */
.about{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:start;
}

/* ✅ stack vertical (pro) */
.lawyerStack{
  display:grid;
  gap:14px;
}

/* ✅ rectangular clean photo cards */
.lawyerShot{
  border-radius:var(--r-lg);
  overflow:hidden;
  position:relative;
  min-height:260px;
  padding:0;
}
.lawyerShot__img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.lawyerShot__placeholder{
  height:100%;
  padding:18px;
  place-items:center;
  text-align:center;
  gap:6px;
  color:rgba(16,12,30,.78);
}
.lawyerShot__label{
  position:absolute;
  left:14px;
  bottom:14px;
}
.glass-tag{
  padding:8px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(36,26,67,.12);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  color:rgba(16,12,30,.92);
  font-weight:800;
  font-size:.85rem;
}
.about__contactBtn{
  width:100%;
}

/* ✅ CTA en vertical */
.about__cta{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:14px;
}
.about__cta .btn{
  width:100%;
}

/* Copy */
.ticks{list-style:none;padding:0;margin:14px 0 16px;display:grid;gap:10px}
.ticks li{display:flex;gap:10px;align-items:flex-start}
.ticks span{color:rgba(249,216,73,1);font-weight:900}
.info-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:10px 0 16px}
.info{padding:12px 14px;border-radius:18px}
.info__label{display:block;font-size:.85rem;color:rgba(16,12,30,.60)}
.info__value{display:block;font-weight:800;color:rgba(16,12,30,.90)}

/* CTA */
.cta{
  padding:20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.cta__actions{display:flex;gap:12px;flex-wrap:wrap}

/* FAQ */
.faq{display:grid;gap:12px}
.faq__item{
  padding:14px 16px;
  border-radius:18px;
}
.faq__item summary{
  cursor:pointer;
  font-family:Sora, Inter, sans-serif;
  font-weight:700;
  outline:none;
}
.faq__item p{margin:10px 0 0;color:var(--text-on-light-muted)}

/* Contact */
.contact{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:18px;
  align-items:start;
}
.contact__form{padding:18px}
.field{display:grid;gap:8px;margin:12px 0}
label{font-size:.9rem;color:var(--text-on-dark-muted)}
.section--light label{color:var(--text-on-light-muted)}
input, select, textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:var(--text-on-dark);
  outline:none;
  transition:border-color var(--t-mid) var(--ease), background var(--t-mid) var(--ease);
}
.section--light input, .section--light select, .section--light textarea{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(36,26,67,.12);
  color:rgba(16,12,30,.92);
}
input:focus, select:focus, textarea:focus{
  border-color:rgba(249,216,73,.55);
}
.check{display:flex;gap:10px;align-items:flex-start;margin:12px 0;color:var(--text-on-dark-muted)}
.section--light .check{color:var(--text-on-light-muted)}
.check input{width:18px;height:18px;margin-top:2px}

.contact__info .info-panel{padding:18px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.kv__k{color:var(--text-on-dark-muted)}
.kv__v{font-weight:700}
.info-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

/* Equipo legal cards */
.lawyers{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  margin:14px 0 4px;
}
.lawyer-card{padding:14px;border-radius:22px}
.lawyer-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.lawyer-avatar{
  width:42px;height:42px;border-radius:16px;
  display:grid;place-items:center;
  font-weight:900;
  background:rgba(249,216,73,.10);
  border:1px solid rgba(249,216,73,.18);
  color:var(--text-on-dark);
}
.lawyer-meta{display:grid;gap:2px}
.lawyer-name{font-family:Sora, Inter, sans-serif}
.lawyer-kv{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,.08)
}
.lawyer-kv:last-of-type{ border-bottom:none; }
.lawyer-val{ font-weight:800; }
.lawyer-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

/* Footer */
.footer{padding:26px 0}
.footer__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.footer__brand{display:flex;gap:12px;align-items:center}
.footer__links{display:flex;gap:14px;flex-wrap:wrap}
.footer__links a{padding:8px 10px;border-radius:12px}
.footer__links a:hover{background:rgba(36,26,67,.06)}

/* Drawer */
.drawer{
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  display:none;
  padding:20px;
}
.drawer__panel{
  max-width:420px;
  margin:72px auto 0;
  padding:16px;
}
.drawer__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.drawer__title{font-family:Sora, Inter, sans-serif;font-weight:800}
.drawer__close{
  width:44px;height:44px;border-radius:16px;border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);color:var(--text-on-dark);
}
.drawer__links{display:grid;gap:10px;margin:10px 0 14px}
.drawer__links a{padding:12px 12px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.10)}
.drawer__links a:hover{background:rgba(255,255,255,.07)}

/* Bottom bar */
.bottom-bar{
  position:fixed;
  left:12px;right:12px;bottom:12px;
  display:none;
  gap:10px;
  z-index:60;
}
.btn--bar{flex:1}

/* Modal */
.modal{
  position:fixed;inset:0;
  display:none;
  z-index:80;
}
.modal__backdrop{
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);
}
.modal__panel{
  position:relative;
  width:min(560px, calc(100% - 24px));
  margin:10vh auto 0;
  padding:16px;
}
.modal__head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  margin-bottom:10px;
}
.modal__close{
  width:44px;height:44px;border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  color:var(--text-on-dark);
}
.modal__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

/* WhatsApp modal */
.wa-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}

/* Reveal */
.reveal{opacity:0;transform:translateY(14px);transition:opacity var(--t-slow) var(--ease), transform var(--t-slow) var(--ease)}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* Responsive */
@media (max-width: 980px){
  .hero__grid{grid-template-columns:1fr}
  .grid.cards{grid-template-columns:repeat(2, 1fr)}
  .steps{grid-template-columns:repeat(2, 1fr)}
  .about{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .nav__links{display:none}
  .nav__toggle{display:block}
  .grid.cards{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .bottom-bar{display:flex}
  .wa-grid{grid-template-columns:1fr}
  .nav__assoc{width:132px;}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .blob{animation:none}
  .reveal{transition:none;opacity:1;transform:none}
  .btn{transition:none}
}
/* =========================
   DESPIDO / RESERVA INFORMATIVA
   ========================= */
.dismissal{
  display:grid;
  gap:16px;
}

.dismissal__header{
  padding:18px;
  border-radius:24px;
  border:1px solid rgba(249,216,73,.14);
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  box-shadow: var(--shadow-1);
}

.dismissal__eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  color:var(--text-on-dark-muted);
  font-size:.9rem;
  margin-bottom:8px;
}

.dismissal__dot{
  width:9px;height:9px;border-radius:999px;
  background:var(--gold-500);
  box-shadow:0 0 0 5px rgba(249,216,73,.10);
}

.dismissal__title{
  margin-bottom:.45rem;
}

.dismissal__lead{
  margin:0;
  color:var(--text-on-dark-muted);
  font-size:1.03rem;
  max-width:70ch;
}
.dismissal__lead strong{
  color:var(--text-on-dark);
}

/* Steps */
.dismissal__steps{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}
.dismissalStep{
  padding:16px;
  border-radius:22px;
}
.dismissalStep__num{
  display:inline-flex;
  font-family:Sora, Inter, sans-serif;
  font-weight:800;
  color:var(--gold-500);
  letter-spacing:-0.02em;
}
.dismissalStep__title{
  margin:8px 0 6px;
  font-family:Sora, Inter, sans-serif;
  font-size:1rem;
}
.dismissalStep__text{
  margin:0;
  color:var(--text-on-dark-muted);
  font-size:.95rem;
  line-height:1.5;
}

/* Reserve box */
.dismissal__reserve{
  padding:16px;
  border-radius:24px;
}
.dismissal__reserveHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:12px;
}
.dismissal__reserveSub{
  margin:.25rem 0 0;
}

.dismissal__reserveText{
  white-space:pre-wrap;
  line-height:1.65;
  font-size:.98rem;
  color:var(--text-on-dark);
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:14px;
  max-height:320px;
  overflow:auto;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}

.dismissal__reserveText::-webkit-scrollbar{
  width:10px;
}
.dismissal__reserveText::-webkit-scrollbar-thumb{
  background:rgba(249,216,73,.24);
  border-radius:999px;
  border:2px solid transparent;
  background-clip:padding-box;
}
.dismissal__reserveText::-webkit-scrollbar-track{
  background:transparent;
}

.dismissal__disclaimer{
  margin:10px 0 0;
  color:var(--text-on-dark-muted);
  font-size:.9rem;
}

/* Topics summary */
.dismissal__topics{
  padding:16px;
  border-radius:22px;
}
.dismissal__topicsTitle{
  margin:0 0 10px;
  font-family:Sora, Inter, sans-serif;
  font-size:1rem;
  color:var(--text-on-light);
}
.dismissal__chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.dismissalChip{
  display:inline-flex;
  align-items:center;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(16,12,30,.05);
  border:1px solid rgba(16,12,30,.10);
  color:rgba(16,12,30,.90);
  font-weight:600;
  font-size:.86rem;
}

/* CTA and contacts */
.dismissal__ctaWrap{
  display:grid;
  gap:12px;
}
.dismissal__cta{
  padding:18px;
  border-radius:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.dismissal__ctaCopy p{
  margin:.35rem 0 0;
}
.dismissal__ctaActions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.dismissal__contacts{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.dismissalContact{
  display:grid;
  gap:4px;
  padding:14px 16px;
  border-radius:18px;
  transition:transform var(--t-mid) var(--ease), box-shadow var(--t-mid) var(--ease);
}
.dismissalContact:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-soft);
}
.dismissalContact__label{
  font-size:.85rem;
  color:var(--text-on-light-muted);
}
.dismissalContact__value{
  font-family:Sora, Inter, sans-serif;
  color:var(--text-on-light);
  letter-spacing:-0.01em;
}

.dismissal__offices{
  padding:16px;
  border-radius:18px;
}
.dismissal__officesTitle{
  margin:0 0 10px;
  font-family:Sora, Inter, sans-serif;
  font-size:1rem;
  color:var(--text-on-light);
}
.dismissal__officesList{
  margin:0;
  padding-left:18px;
  display:grid;
  gap:8px;
  color:var(--text-on-light-muted);
}
.dismissal__officesList strong{
  color:var(--text-on-light);
}

/* Responsive */
@media (max-width: 980px){
  .dismissal__steps{
    grid-template-columns:1fr;
  }
  .dismissal__contacts{
    grid-template-columns:1fr;
  }
}

@media (max-width: 720px){
  .dismissal__header,
  .dismissal__reserve,
  .dismissal__cta{
    padding:14px;
  }

  .dismissal__reserveText{
    max-height:260px;
    font-size:.94rem;
    line-height:1.55;
  }

  .dismissal__ctaActions{
    width:100%;
  }
  .dismissal__ctaActions .btn{
    width:100%;
  }
}
/* =========================
   UBICACIÓN / GOOGLE MAPS
   ========================= */
.locationsGrid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.locationCard{
  padding:16px;
  border-radius:22px;
  display:grid;
  gap:12px;
}

.locationCard__top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.locationCard__title{
  margin:0 0 6px;
  font-family:Sora, Inter, sans-serif;
  font-size:1.05rem;
  color:rgba(16,12,30,.92);
}

.locationCard__address{
  margin:0;
  color:rgba(16,12,30,.66);
  line-height:1.5;
}

.locationBadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 10px;
  border-radius:999px;
  background:rgba(16,12,30,.05);
  border:1px solid rgba(16,12,30,.10);
  color:rgba(16,12,30,.85);
  font-weight:700;
  font-size:.8rem;
  white-space:nowrap;
}

.locationCard__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.mapFrameWrap{
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(16,12,30,.10);
  background:rgba(255,255,255,.55);
  box-shadow:0 8px 24px rgba(16,12,30,.08);
}

.mapFrame{
  display:block;
  width:100%;
  height:280px;
  border:0;
}

@media (max-width: 980px){
  .locationsGrid{ grid-template-columns:1fr; }
}

@media (max-width: 720px){
  .locationCard{ padding:14px; }
  .locationCard__top{
    flex-direction:column;
    align-items:flex-start;
  }
  .locationCard__actions .btn{ width:100%; }
  .mapFrame{ height:240px; }
}