body { font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica Neue, Arial; background:#f7fafc; }
    .mono { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace; }
    .card { background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 1px 2px rgba(0,0,0,.06); }
    .container { max-width: 900px; margin: 24px auto; padding: 0 12px; }


/* ====== UI POLISH PROD ====== */

/* Domain chip — v6 (offset izquierda + WWW grueso) */
.domain-chip{
  position:relative; display:inline-flex; align-items:center; gap:10px;
  border:1.6px solid #E5E7EB; border-radius:9999px; background:#fff;
  padding:10px 16px 10px 10px;
  box-shadow: 0 1px 0 rgba(0,0,0,.03), 0 8px 16px -12px rgba(0,0,0,.12);
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
  font-feature-settings: 'tnum' 1; font-variant-numeric: tabular-nums;
}
.domain-chip.is-offset{ margin-left:-14px; } /* se mete un poco hacia la izquierda */
.domain-chip:hover{ transform: translateY(-1px); border-color:#D1D5DB; box-shadow:0 2px 0 rgba(0,0,0,.04), 0 12px 24px -14px rgba(0,0,0,.14); }

.domain-chip .prefix{
  display:inline-flex; align-items:center; justify-content:center;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Courier New', monospace;
  font-weight: 900; letter-spacing:.18em; text-transform:uppercase;
  font-size: clamp(12px, 1.08rem, 1.14rem);
  color:#0B0F19; background:#fff;
  border:3px solid #0B0F19; border-radius:9999px; padding:9px 18px; line-height:1;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85), 0 2px 0 #0B0F19;
}
.domain-chip .host{ font-weight:800; letter-spacing:.01em; color:#0B0F19; }

/* Estado pills */
.status-pill{ font-weight:700; border-radius:9999px; padding:6px 12px; display:inline-block }
.status-available{ background:#D1FAE5; color:#065F46; border:1px solid #10B981 }
.status-unavailable{ background:#FEE2E2; color:#991B1B; border:1px solid #EF4444 }

/* Precio: caja llamativa pero sobria */
.price-box{
  display:inline-flex; align-items:baseline; gap:6px;
  padding:8px 12px; border-radius:14px; border:1px solid #E5E7EB; background:#FCFEFF;
}
.price-box .amount{ font-size:1.05rem; font-weight:800; letter-spacing:.01em; }
.price-box .currency{ font-size:.8rem; color:#6B7280; font-weight:700 }
.price-box.price-ok{ box-shadow: 0 0 0 4px rgba(16,185,129,.08) inset }
.price-box.price-na{ opacity:.8 }

/* CTA buttons */
.btn-cta{ border-radius:9999px; padding:10px 16px; font-weight:800; border:1.4px solid #111; display:inline-flex; align-items:center; gap:8px; transition: transform .08s ease, box-shadow .12s ease }
.btn-cta:active{ transform: translateY(1px) }
.btn-add{ background:#ECFDF5; border-color:#10B981; color:#065F46; box-shadow: 0 0 0 3px rgba(16,185,129,.08) inset }
.btn-add:hover{ box-shadow: 0 0 0 4px rgba(16,185,129,.14) inset }
.btn-contact{ background:#EEF2FF; border-color:#6366F1; color:#1E3A8A; box-shadow: 0 0 0 3px rgba(99,102,241,.08) inset }
.btn-contact:hover{ box-shadow: 0 0 0 4px rgba(99,102,241,.14) inset }

/* Ver más / Ver menos */
.more-btn{ display:inline-flex; align-items:center; gap:10px; border:1.5px solid #D1D5DB; background:#fff; border-radius:12px; padding:10px 16px; font-weight:800 }
.more-btn:hover{ border-color:#9CA3AF }
.spinner{ width:18px; height:18px; border:3px solid #E5E7EB; border-top-color:#111; border-radius:9999px; animation:spin .8s linear infinite }
@keyframes spin{ to{ transform:rotate(360deg) } }

/* Table spacing */
table thead th{ color:#6B7280; font-weight:800; }
tbody tr td{ vertical-align: middle }



/* === Polished adjustments per specs === */

/* Bigger, heavier WWW., extra left offset */
.domain-chip.is-offset{ margin-left: -28px; } /* más a la izquierda */
.domain-chip{ gap:12px; padding:12px 20px 12px 14px; } /* chip más grande */
.domain-chip .prefix{
  border-width:3.5px; padding:10px 24px; font-size: clamp(13px, 1.18rem, 1.28rem);
}
.domain-chip .host{ font-size: clamp(14px, 1.06rem, 1.12rem); }

/* Status dots (reemplazan el texto) */
.status-dot{ display:inline-block; width:14px; height:14px; border-radius:9999px; border:2px solid rgba(0,0,0,.08); box-shadow: inset 0 1px 1px rgba(255,255,255,.6); }
.dot-available{ background:#10B981; }               /* verde */
.dot-unavailable{ background:#F97316; }             /* naranjoso-rojo */
.dot-premium{ background:#8B5CF6; }                 /* morado */

/* Accessible helper (hide but keep for screen readers) */
.sr-only{ position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0; }

/* Price: 'desde $X MXN/año' */
.price-box .label{ font-size:.78rem; color:#6B7280; font-weight:700; text-transform:uppercase; letter-spacing:.06em; }
.price-box .per{ font-size:.78rem; color:#6B7280; font-weight:700; }



/* === V3 polish: dominio más protagónico, WWW desplazado, status con tooltip === */

/* Aumentamos cápsula (x2 aprox) y movemos hacia la izquierda */
.domain-chip{ gap:14px; padding:14px 24px 14px 16px; }
.domain-chip.is-offset{ margin-left: -36px; }
.domain-chip .prefix{ border-width:4px; padding:12px 28px; font-size: clamp(14px, 1.22rem, 1.32rem); }
.domain-chip .host{ font-size: clamp(15px, 1.14rem, 1.22rem); }
.domain-chip .host .name{ font-weight:900; }
.domain-chip .host .tld{ font-weight:800; color:#374151; margin-left:2px; } /* tld sutilmente destacado */

/* Oculta fallback de texto de estado si algún build lo trae */
.status-pill{ display:none !important; }

/* Status dots con tooltip */
.status-dot{ position:relative; display:inline-block; width:14px; height:14px; border-radius:9999px; border:2px solid rgba(0,0,0,.08); box-shadow: inset 0 1px 1px rgba(255,255,255,.6); cursor:help }
.dot-available{ background:#10B981; }
.dot-unavailable{ background:#F97316; }
.dot-premium{ background:#8B5CF6; }

.status-dot .status-tip{
  position:absolute; left:50%; top:-8px; transform: translate(-50%, -100%);
  white-space:nowrap; background:#111; color:#fff; font-size:.75rem; font-weight:700;
  padding:6px 10px; border-radius:10px; box-shadow: 0 6px 24px rgba(0,0,0,.15);
  opacity:0; pointer-events:none; transition:opacity .12s ease, transform .12s ease;
}
.status-dot .status-tip a{ color:#A5B4FC; text-decoration:underline; }
.status-dot:hover .status-tip{ opacity:1; transform: translate(-50%, -110%); }
.status-dot .status-tip::after{
  content:""; position:absolute; left:50%; bottom:-6px; transform:translateX(-50%);
  width:10px; height:10px; background:#111; border-radius:2px; clip-path: polygon(50% 0, 0 100%, 100% 100%);
}

/* Precio: reforzamos “desde … /año” y separación */
.price-box{ gap:8px; padding:10px 14px; }
.price-box .amount{ font-size:1.1rem; }
.price-box .label, .price-box .per{ font-size:.8rem; }



/* ===== POLISH V4 ===== */
.domain-chip{ gap:16px; padding:16px 28px 16px 18px; }
.domain-chip.is-offset{ margin-left:-48px; } /* más a la izquierda */
.domain-chip .prefix{ border-width:4px; padding:12px 34px; font-size:clamp(14px,1.24rem,1.34rem); }
.domain-chip .host{ font-size:clamp(16px,1.22rem,1.30rem); }
.domain-chip .host .name{ font-weight:900; }
.domain-chip .host .tld{ font-weight:800; color:#374151; margin-left:3px; }

/* Estado: solo dots + tooltip */
.status-pill{ display:none !important; }
.status-dot{ position:relative; display:inline-block; width:14px; height:14px; border-radius:9999px; border:2px solid rgba(0,0,0,.08); box-shadow: inset 0 1px 1px rgba(255,255,255,.6); cursor:help }
.dot-available{ background:#10B981; }
.dot-unavailable{ background:#F97316; }
.dot-premium{ background:#8B5CF6; }

.status-dot .status-tip{
  position:absolute; left:50%; top:-8px; transform: translate(-50%, -100%);
  white-space:nowrap; background:#111; color:#fff; font-size:.75rem; font-weight:700;
  padding:6px 10px; border-radius:10px; box-shadow:0 6px 24px rgba(0,0,0,.15);
  opacity:0; pointer-events:none; transition:opacity .12s ease, transform .12s ease;
}
.status-dot:hover .status-tip{ opacity:1; transform: translate(-50%, -110%); }
.status-dot .status-tip a{ color:#A5B4FC; text-decoration:underline; }
.status-dot .status-tip::after{
  content:""; position:absolute; left:50%; bottom:-6px; transform:translateX(-50%);
  width:10px; height:10px; background:#111; border-radius:2px; clip-path: polygon(50% 0, 0 100%, 100% 100%);
}

/* Price tagline presentational tweaks */
.price-box{ gap:10px; padding:11px 16px; }
.price-box .label,.price-box .per{ font-size:.82rem; }
.price-box .amount{ font-size:1.12rem; }



/* === POLISH v4 === */

/* 1) Dominio más grande y ancho consistente (como mock) */
@media (min-width: 1024px){
  td.domain-col, th.domain-col { width: 560px; } /* ancho objetivo escritorio */
}
.domain-chip{ min-height:54px; gap:16px; padding:14px 26px 14px 16px; }
.domain-chip.is-offset{ margin-left:-34px; }

/* 2) WWW con borde gris translúcido (menos protagonista) */
.domain-chip .prefix{
  border-color: rgba(17,24,39,.55);          /* antes casi negro */
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85), 0 2px 0 rgba(17,24,39,.35);
  padding:10px 26px;
  font-size: clamp(14px, 1.18rem, 1.28rem);
}

/* 3) Dominio protagonista */
.domain-chip .host{ font-size: clamp(16px, 1.18rem, 1.26rem); }
.domain-chip .host .name{ font-weight:900; }
.domain-chip .host .tld{ font-weight:800; color:#374151; margin-left:2px; }

/* 4) Status dot con tolerancia al hover (puente) */
.status-dot{ position:relative; }
.status-dot::before{
  content:""; position:absolute; left:50%; top:-18px; transform:translateX(-50%);
  width:34px; height:20px; /* área invisible que une el dot con el tooltip */
}
.status-dot .status-tip{ pointer-events:auto; }
.status-dot:hover .status-tip, .status-dot .status-tip:hover{
  opacity:1; transform: translate(-50%, -110%);
}

/* 5) Ajuste de pills de precio */
.price-box{ padding:10px 16px; gap:10px; }
.price-box .amount{ font-size:1.12rem; }
.price-box .currency, .price-box .label, .price-box .per{ font-weight:700; }



/* === POLISH v6 — dominio GRANDE como mock (primeros 2) === */
@media (min-width: 1024px){
  td.domain-col, th.domain-col { width: 640px; } /* paso 1 */
}
@media (min-width: 1280px){
  td.domain-col, th.domain-col { width: 700px; } /* proporción grande */
}
@media (min-width: 1536px){
  td.domain-col, th.domain-col { width: 760px; } /* ultrawide */
}

/* Cápsula aún más alta/ancha en desktop */
@media (min-width: 1024px){
  .domain-chip{ min-height:66px; gap:18px; padding:18px 30px 18px 20px; }
  .domain-chip.is-offset{ margin-left:-40px; }
  .domain-chip .prefix{ border-width:4px; padding:12px 30px; font-size: clamp(15px, 1.28rem, 1.4rem); }
  .domain-chip .host{ font-size: clamp(18px, 1.4rem, 1.5rem); }
}

/* WWW borde más sutil todavía */
.domain-chip .prefix{
  border-color: rgba(17,24,39,.38);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85), 0 2px 0 rgba(17,24,39,.25);
}

/* Evitar saltos de línea dentro del dominio y mantenerlo en 1 línea */
.domain-chip{ white-space: nowrap; }



/* === POLISH v7 — proporciones obligatorias (mock) === */

/* Layout más ancho para permitir cápsula enorme */
@media (min-width: 1024px){
  td.domain-col, th.domain-col { width: 760px; }
}
@media (min-width: 1280px){
  td.domain-col, th.domain-col { width: 860px; }
}
@media (min-width: 1536px){
  td.domain-col, th.domain-col { width: 920px; }
}

/* Cápsula gigante y protagonista en desktop */
@media (min-width: 1280px){
  .domain-chip{
    min-height: 92px;
    min-width: 800px;
    gap: 22px;
    padding: 24px 42px 24px 26px;
    border-width: 1.8px;
    background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);
    box-shadow: 0 1px 0 rgba(0,0,0,.03), 0 14px 32px -18px rgba(0,0,0,.22);
  }
  .domain-chip.is-offset{ margin-left: -46px; }
  .domain-chip .prefix{
    border-width: 4px;
    padding: 16px 36px;
    font-size: 1.55rem;
    border-color: rgba(17,24,39,.32); /* borde WWW más sutil */
    box-shadow: inset 0 1px 0 rgba(255,255,255,.9), 0 2px 0 rgba(17,24,39,.22);
  }
  .domain-chip .host{
    font-size: 1.8rem;
    line-height: 1.05;
  }
}

/* Mantener una sola línea y evitar recortes */
.domain-chip{ white-space: nowrap; overflow: visible; }



/* === POLISH v8 — TLD azul + tipografía dominio 10% más grande + 33% letter-spacing === */

/* Color del TLD */
.domain-chip .host .tld{ color:#1d65f8 !important; }

/* Tipografía del dominio (host completo) — +10% size y +33% tracking */
.domain-chip .host{
  letter-spacing: .33em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Ajustes por breakpoints para subir ~10% */
.domain-chip .host{ font-size: calc(1em * 1.10); } /* base */
@media (min-width: 1024px){
  .domain-chip .host{ font-size: calc(1.1 * 1.10rem); } /* pequeño uplift en md/lg */
}
@media (min-width: 1280px){
  .domain-chip .host{ font-size: 1.98rem !important; } /* previo ~1.8rem => +10% aprox */
}



/* === POLISH v9 — botones color estado, borde WWW transparente, parpadeo dots === */

/* 1) Botones de 'Contactar' con color de estado */
.btn-contact-unavail{
  background: rgba(249, 115, 22, .08);  /* naranja-rojizo suave */
  border: 1.6px solid #F97316;
  color: #9A3412;
  box-shadow: 0 0 0 3px rgba(249, 115, 22, .10) inset;
}
.btn-contact-unavail:hover{ box-shadow: 0 0 0 4px rgba(249, 115, 22, .16) inset; }

.btn-contact-premium{
  background: rgba(139, 92, 246, .10); /* morado suave */
  border: 1.6px solid #8B5CF6;
  color: #4C1D95;
  box-shadow: 0 0 0 3px rgba(139, 92, 246, .12) inset;
}
.btn-contact-premium:hover{ box-shadow: 0 0 0 4px rgba(139, 92, 246, .18) inset; }

/* 2) Borde del WWW transparente (manteniendo forma) */
.domain-chip .prefix{
  border-color: transparent !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9); /* quitamos sombra exterior para que no parezca borde */
}

/* 3) Parpadeo lento de los puntos de estado */
@keyframes dotBlink{
  0%, 60%, 100%{ opacity: 1 }
  30%{ opacity: .7 }
}
.status-dot{
  animation: dotBlink 2.8s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce){
  .status-dot{ animation: none }
}



/* === POLISH v10 — asegurar 'Ver más' visible === */
#moreBox{ padding-top: 8px; }
.more-btn{
  display:inline-flex !important; align-items:center; gap:10px;
  border:1.5px solid #D1D5DB; background:#fff; border-radius:12px;
  padding:10px 16px; font-weight:800; cursor:pointer;
}
.more-btn span{ display:inline-block }



/* Blink/pulse muy sutil y constante (sin mover ni cambiar tamaño) */
@keyframes dotPulse {
  0%, 100% { opacity: 1 }
  40%      { opacity: .75 }
}
.status-dot{ animation: dotPulse 3.2s ease-in-out infinite !important; }
@media (prefers-reduced-motion: reduce){
  .status-dot{ animation: none !important }
}



/* === FINAL POLISH: tokens unificados === */

/* Dominio protagonista */
.domain-chip{ white-space:nowrap; }
.domain-chip .host{ letter-spacing:.33em; font-size: calc(1em * 1.10); }
@media (min-width:1280px){ .domain-chip .host{ font-size:1.98rem } }
.domain-chip .host .tld{ color:#1d65f8 !important; }
.domain-chip .prefix{ border-color: transparent !important; box-shadow: inset 0 1px 0 rgba(255,255,255,.9); }

/* Estado: puntos con pulso suave + puente hover */
@keyframes dotPulse { 0%,100%{opacity:1} 50%{opacity:.78} }
.status-dot{ position:relative; animation: dotPulse 3s ease-in-out infinite; }
.status-dot::before{ content:""; position:absolute; left:50%; top:-18px; transform:translateX(-50%); width:34px; height:20px; }
.status-dot .status-tip{ position:absolute; left:50%; top:-8px; transform:translate(-50%,-100%); background:#111; color:#fff; font-size:.75rem; font-weight:700; white-space:nowrap; padding:6px 10px; border-radius:10px; opacity:0; pointer-events:auto; }
.status-dot:hover .status-tip, .status-dot .status-tip:hover{ opacity:1; transform:translate(-50%,-110%); }
.status-dot .status-tip a{ color:#A5B4FC; text-decoration:underline; }
.status-dot .status-tip::after{ content:""; position:absolute; left:50%; bottom:-6px; transform:translateX(-50%); width:10px; height:10px; background:#111; clip-path: polygon(50% 0, 0 100%, 100% 100%); }
@media (prefers-reduced-motion: reduce){ .status-dot{ animation:none } }

/* Botones Contactar según estado */
.btn-cta{ border-radius:9999px; padding:10px 16px; font-weight:800; border:1.4px solid #111; display:inline-flex; align-items:center; gap:8px; }
.btn-add{ background:#ECFDF5; border-color:#10B981; color:#065F46; box-shadow: 0 0 0 3px rgba(16,185,129,.08) inset }
.btn-contact-unavail{ background:rgba(249,115,22,.08); border-color:#F97316; color:#9A3412; box-shadow:0 0 0 3px rgba(249,115,22,.10) inset }
.btn-contact-premium{ background:rgba(139,92,246,.10); border-color:#8B5CF6; color:#4C1D95; box-shadow:0 0 0 3px rgba(139,92,246,.12) inset }

/* Precio */
.price-box{ display:inline-flex; align-items:baseline; gap:8px; padding:10px 14px; border-radius:14px; border:1px solid #E5E7EB; background:#FCFEFF }
.price-box .amount{ font-size:1.1rem; font-weight:800 }
.price-box .currency,.price-box .label,.price-box .per{ font-size:.8rem; color:#6B7280; font-weight:700 }
.price-box.price-ok{ box-shadow:0 0 0 4px rgba(16,185,129,.08) inset }

/* Ver más / menos */
#moreBox{ padding-top:8px }
.more-btn{ display:inline-flex; align-items:center; gap:10px; border:1.5px solid #D1D5DB; background:#fff; border-radius:12px; padding:10px 16px; font-weight:800; cursor:pointer }
.spinner{ width:18px; height:18px; border:3px solid #E5E7EB; border-top-color:#111; border-radius:9999px; animation:spin .8s linear infinite }
@keyframes spin { to { transform: rotate(360deg) } }


/* === POLISH v12 — layout ancho, columnas fijas, glow sólo en disponible, botones menos redondeados === */

/* columnas: forzar ancho mínimo para evitar solapamiento */
th.price-col, td.price-col { width: 260px; }
th.action-col, td.action-col { width: 170px; }

/* contenedor: el wrapper ya es max-w-[92rem]; asegurar que la tabla no colapse */
@media (min-width: 1280px){
  table.min-w-full{ table-layout: fixed; }
}

/* botones acción menos redondeados */
.btn-cta{ border-radius: 12px; } /* antes pill total */

/* animación sólo para el punto verde (disponible) - sin alterar tamaño */
.dot-available{ position:relative; }
.dot-available::after{
  content:""; position:absolute; inset:-6px; border-radius:9999px;
  box-shadow: 0 0 0 0 rgba(16,185,129,.35);
  animation: availGlow 2.6s ease-in-out infinite;
}
@keyframes availGlow{
  0%,100% { box-shadow: 0 0 0 0 rgba(16,185,129,.35); opacity: .9; }
  50%     { box-shadow: 0 0 0 8px rgba(16,185,129,0); opacity: 1; }
}

/* respetar accesibilidad */
@media (prefers-reduced-motion: reduce){
  .dot-available::after{ animation: none; }
}



/* === POLISH v13 — precio sin spacing irregular + blink verde notorio === */

/* Evitar salto/espaciado raro en precios */
.price-box{ white-space: nowrap; letter-spacing: 0 !important; }
.price-box *{ letter-spacing: 0 !important; }
.price-box .amount{ font-variant-numeric: tabular-nums; }
.price-box .label,.price-box .currency,.price-box .per{ font-variant-numeric: tabular-nums; }
th.price-col, td.price-col { width: 280px; }  /* un poquito más */
th.action-col, td.action-col { width: 200px; } /* y más aire al botón */

/* Blink notorio SOLO en disponible (sin mover tamaño) */
.dot-available::after{ content: none !important; } /* anulamos cualquier glow previo */
@keyframes blinkStrong { 0%, 100% { opacity: 1 } 50% { opacity: .25 } }
.dot-available{ animation: blinkStrong 1.1s ease-in-out infinite !important; }
@media (prefers-reduced-motion: reduce){
  .dot-available{ animation: none !important; }
}



/* === POLISH v14 — quitar parpadeo, WWW transparente, More azul, tooltip precio === */

/* 0) Sin parpadeos ni glows en estado */
.status-dot, .dot-available{ animation: none !important; }
.dot-available::after{ content: none !important; }

/* 1) WWW capsule completamente transparente */
.domain-chip .prefix{
  background: transparent !important;
  box-shadow: none !important;
  border-color: transparent !important;
}

/* 2) Botón Ver más/menos azul corporativo */
.more-btn{
  background:#1d65f8 !important;
  border-color:#1d65f8 !important;
  color:#fff !important;
}
.more-btn:hover{ filter:brightness(.95); }
.more-btn:active{ filter:brightness(.9); }

/* 3) Tooltip en cuadro de precio (sin tolerancia, desaparece al salir) */
.price-box{ position:relative; }
.price-tip{
  position:absolute; left:50%; top:-8px; transform:translate(-50%,-100%);
  background:#111; color:#fff; font-size:.75rem; font-weight:800;
  padding:6px 10px; border-radius:10px; white-space:nowrap;
  opacity:0; transition:opacity .14s ease, transform .14s ease; pointer-events:none;
}
.price-tip::after{
  content:""; position:absolute; left:50%; bottom:-6px; transform:translateX(-50%);
  width:10px; height:10px; background:#111; clip-path: polygon(50% 0, 0 100%, 100% 100%);
}
.price-box:hover .price-tip{ opacity:1; transform:translate(-50%,-110%); }


/* === POLISH v15 — branding azul y ajustes de precio === */

/* Buscar (btn) ya es azul por clase inline; extra por si acaso */
#btnSearch{ background:#1d65f8 !important; border-color:#1d65f8 !important; color:#fff; }

/* Agregar (disponible) en azul corporativo */
.btn-add{
  background: rgba(29,101,248,.08) !important;
  border-color: #1d65f8 !important;
  color: #1d65f8 !important;
  box-shadow: 0 0 0 3px rgba(29,101,248,.10) inset;
}

/* Price coloring for sign and MXN/año */
.price-box .sign, .price-box .currency, .price-box .per{ color:#1d65f8; font-weight:800; }
.price-box .label{ color:#6B7280; font-weight:800; text-transform:uppercase; letter-spacing:.06em }

/* Price tooltip link styling */
.price-tip a{ color:#A5B4FC; text-decoration:underline; }

/* Hide table header completely (no gap) */
table thead{ display:none; }

/* v7 promo visuals */
.price-box.promo{position:relative;background:linear-gradient(135deg, rgba(16,185,129,.12), rgba(59,130,246,.08));border:1px solid rgba(16,185,129,.35);box-shadow:0 8px 18px -10px rgba(16,185,129,.35)}
.price-box.promo::before{content:"";position:absolute;inset:auto 0 0 0;height:52%;background:radial-gradient(120px 70px at 12% 90%, rgba(16,185,129,.18), transparent 60%), radial-gradient(100px 60px at 80% 100%, rgba(59,130,246,.16), transparent 60%);border-bottom-left-radius:.75rem;border-bottom-right-radius:.75rem}
.price-box .promo-badge{position:absolute;top:-10px;left:10px;background:#10B981;color:#fff;font-weight:800;font-size:.65rem;letter-spacing:.08em;padding:.2rem .45rem;border-radius:.5rem;box-shadow:0 6px 14px -8px rgba(16,185,129,.5);transform:rotate(-2deg)}
