:root{
  --brand:#007bff; --brand-600:#0a66cc;
  --fg:#222; --muted:#6b7280; --bg:#fff; --bg-soft:#f8f9fa; --border:#e5e7eb;
  --ok:#16a34a; --ko:#dc2626;
  --radius:12px; --radius-pill:999px;
  --container-max:1100px; --container-pad:16px;
  --header-h:56px; --footer-h:56px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{color:var(--fg);background:var(--bg);font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;padding-bottom:var(--footer-h)}

.container{width:100%;max-width:var(--container-max);padding:0 var(--container-pad);margin:0 auto}
.grid{display:grid;gap:1rem}
.grid.cols-2{grid-template-columns:1fr 1fr}.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}
.text-center{text-align:center}
.center-screen{min-height:calc(100vh - var(--header-h) - var(--footer-h));display:flex;align-items:center;justify-content:center}

/* Header */
.navbar{height:var(--header-h);background:var(--bg-soft);border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 var(--container-pad)}
.navbar .brand{display:flex;align-items:center;gap:.5rem;font-weight:700;color:#111;text-decoration:none}
.navbar .brand img{height:26px}
.navbar .nav-links{display:flex;gap:16px;align-items:center}
.navbar .nav-links a{color:#333;text-decoration:none;font-weight:600}
.navbar .nav-links a:hover{color:var(--brand)}

.btn-icon{background:transparent;border:0;padding:6px;cursor:pointer;color:var(--fg)}
.btn-icon:hover{opacity:.85}

/* Hamburguesa (móvil) pegada a la izquierda */
.hamburger{display:none;flex-direction:column;gap:4px;width:28px;height:24px;justify-content:center;align-items:center;cursor:pointer;background:transparent;border:0;margin-left:-4px}
@media (max-width:992px){
  .navbar .nav-links{display:none}
  .hamburger{display:flex}
}
.hamburger span{display:block;width:22px;height:2px;background:#111;border-radius:2px}

.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius-pill);color:#fff;font-size:.85rem;font-weight:600;min-width:38px;justify-content:center}
.status-badge.ok{background:var(--ok)} .status-badge.ko{background:var(--ko)}
.status-text{font-weight:700}
.environment-right{display:flex;align-items:center;gap:12px}

/* Drawer (móvil) */
.drawer{position:fixed;top:0;left:0;bottom:0;width:82%;max-width:320px;transform:translateX(-100%);transition:transform .24s ease;z-index:9998;border-right:1px solid var(--border);background:#fff}
.drawer.open{transform:translateX(0)}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:9997}
.backdrop.show{opacity:1;pointer-events:auto}
.drawer .drawer-header{padding:12px var(--container-pad);border-bottom:1px solid var(--border);font-weight:700}
.drawer nav{display:flex;flex-direction:column;padding:8px}
.drawer nav a, .drawer nav form button{ text-align:left;padding:10px 12px;border-radius:8px;border:1px solid transparent;background:#fff;color:#111;text-decoration:none;font-weight:600;cursor:pointer }
.drawer nav a:hover, .drawer nav form button:hover{background:#f3f4f6}
.drawer .logout-block{margin-top:auto;padding:8px}

/* Footer fijo */
.site-footer{position:fixed;left:0;right:0;bottom:0;height:var(--footer-h);
  border-top:1px solid var(--border);background:var(--bg-soft);
  display:flex;align-items:center;justify-content:center;color:#555;font-size:.9rem;z-index:9996}

/* Botones (no forzamos TODOS los button genéricos) */
.button,.btn,button.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.62rem 1rem;border-radius:var(--radius);background:var(--brand);color:#fff;border:1px solid var(--brand);text-decoration:none;font-weight:700;cursor:pointer}
.button.secondary,.btn.secondary,button.btn.secondary{background:#fff;color:var(--brand);border-color:var(--brand)}
.button:disabled,.btn:disabled,button.btn:disabled{opacity:.6;cursor:not-allowed}
.button:hover,.btn:hover,button.btn:hover{filter:brightness(.96)}

/* Formularios e inputs */
form .form-group,.mb-3{margin-bottom:1rem}
label{display:block;margin-bottom:.35rem;font-weight:600}
input[type="text"],input[type="email"],input[type="password"],select,textarea{
  width:100%;padding:.9rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:#fff;font-size:1.05rem}
textarea{min-height:120px}

/* Login card (sin estilos inline) */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;display:flex;flex-direction:column;align-items:center}
.login-card .logo{max-width:160px;margin-bottom:12px}
.login-card h2{margin:8px 0 12px}
.login-card .card{width:100%;max-width:820px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:0 10px 30px rgba(0,0,0,.06);padding:24px 22px}
.login-card .control{width:95%;max-width:760px;margin-left:auto;margin-right:auto}
@media (min-width:768px){ .login-card .control{width:80%} }
@media (min-width:1024px){ .login-card .control{width:70%} }

/* Tablas y paginación */
.table-responsive{overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:#fff}
.results-table{width:100%;border-collapse:collapse;min-width:520px}
.results-table th,.results-table td{padding:.6rem .7rem;border-bottom:1px solid var(--border)}
.results-table thead th{background:#f3f4f6;text-align:left;position:sticky;top:0}
.pagination{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin:1rem 0}
.pagination a,.pagination .current{padding:.35rem .6rem;border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--fg)}
.pagination .current{background:#eef2ff;border-color:#c7d2fe}

/* Quick search */
.quick-search{margin:1rem 0}
.input-wrapper{position:relative;display:inline-block;width:100%;max-width:420px}
#quickSearch{width:100%;padding:.5rem 2rem .5rem .75rem}
#clearSearch{position:absolute;right:.25rem;top:.25rem;bottom:.25rem;padding:0 .5rem;border:1px solid var(--border);background:#fff;border-radius:8px;cursor:pointer}
.suggestions{margin-top:.25rem;max-width:420px;border:1px solid var(--border);border-radius:8px;background:#fff;list-style:none;padding:0}
.suggestion-item{padding:.5rem .75rem;cursor:pointer;display:flex;gap:.5rem}
.suggestion-item:hover{background:#f6f6f6}
.d-none{display:none !important}

/* Barra de acciones (redactar) */
.action-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.75rem;margin-top:1rem}
.action-bar .left{justify-self:start}.action-bar .center{justify-self:center}.action-bar .right{justify-self:end;display:flex;align-items:center;gap:.5rem}

/* Overlay spinner */
#loading-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(255,255,255,.8);z-index:9999}
.loading-spinner{width:48px;height:48px;border:4px solid #ddd;border-top-color:var(--brand);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Responsive */
@media (max-width:992px){
  .navbar{padding-left:8px;padding-right:12px}
  .navbar .nav-links{display:none}
  .hamburger{display:flex}
}
@media (max-width:768px){
  .grid.cols-2,.grid.cols-3{grid-template-columns:1fr}
  .action-bar{grid-template-columns:1fr;gap:.75rem}
  .action-bar .left,.action-bar .center,.action-bar .right{justify-self:stretch}
  .action-bar .right{justify-content:flex-end}
  .results-table{min-width:480px}
}

/* Header: bloque izquierdo */
.nav-left{display:flex;align-items:center;gap:12px}

/* Selector idioma (desktop al lado, móvil sin etiqueta) */
.lang-switch{display:flex;align-items:center;gap:8px}
.lang-label{font-weight:600;color:#333}
.lang-select{
  appearance:none;
  border:1px solid var(--border);
  border-radius:8px;
  padding:.35rem .5rem;
  background:#fff;
  font-size:.95rem;
  min-width:64px;
}
@media (max-width:768px){
  .lang-label{display:none}
  .lang-select{font-size:.95rem;padding:.35rem .5rem}
}

/* ===== Layouts de paso ===== */
.step-header{display:flex;align-items:center;gap:.75rem}
.step-pill{background:#eef2ff;border:1px solid var(--border);color:#111;border-radius:999px;padding:.25rem .6rem;font-weight:700;font-size:.9rem}
.muted{color:#6b7280}

/* ===== Formularios ===== */
.form{max-width:880px;margin:0 auto}
.grid{display:grid}
.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.gap-md{gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.35rem}
.form-control{border:1px solid var(--border);border-radius:8px;padding:.55rem .7rem;font-size:1rem;background:#fff}
.form-control:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px rgba(79,70,229,.15)}
.hint{font-size:.85rem;color:#6b7280}
.actions{display:flex;justify-content:flex-end}

/* Checkboxes */
.form-check{display:flex;align-items:center;gap:.5rem;margin:.5rem 0}
.form-check-input{width:1.1rem;height:1.1rem;border:1px solid var(--border);border-radius:.25rem;appearance:none;display:inline-block;position:relative;background:#fff;cursor:pointer}
.form-check-input:checked{background:#4f46e5;border-color:#4f46e5}
.form-check-input:checked::after{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg stroke='white' fill='none' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke-width='3' d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/14px 14px no-repeat}
.form-check-label{cursor:pointer}
.link{color:#4f46e5;text-decoration:underline}

/* Botones */
.button.btn{background:#4f46e5;color:#fff;border:1px solid #4f46e5;border-radius:10px;padding:.55rem 1rem;font-weight:700}
.button.btn:hover{filter:brightness(.95)}
.button.secondary{background:#f3f4f6;color:#111;border:1px solid var(--border)}

/* ===== intl-tel-input integrado a la app ===== */
.iti{width:100%}
.iti--allow-dropdown .iti__flag-container{border:1px solid var(--border);border-right:none;border-radius:8px 0 0 8px;background:#fff}
.iti input#phone.form-control{border-left:none;border-radius:0 8px 8px 0}
@media (max-width:768px){
  .cols-2{grid-template-columns:1fr}
}

/* ===== Modales ===== */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:1000;padding:1rem}
.modal.open{display:flex}
.modal__dialog{background:#fff;border-radius:12px;max-width:760px;width:100%;box-shadow:0 10px 30px rgba(0,0,0,.12);display:flex;flex-direction:column}
.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1rem .5rem 1rem;border-bottom:1px solid var(--border)}
.modal__body{padding:1rem;max-height:60vh;overflow:auto}
.modal__footer{padding:1rem;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:.5rem}
.btn-icon.close{background:transparent;border:none;font-size:1.35rem;line-height:1;cursor:pointer}

/* ===== Toggle y planes (Step 3) ===== */
.billing-toggle{display:flex;align-items:center;gap:.6rem;justify-content:flex-start;margin:.5rem 0}
.switch{position:relative;display:inline-block;width:48px;height:24px}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#d1d5db;transition:.2s;border-radius:999px}
.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;top:3px;background:#fff;transition:.2s;border-radius:999px}
input:checked + .slider{background:#4f46e5}
input:checked + .slider:before{transform:translateX(24px)}
.badge{border-radius:999px;padding:.15rem .45rem;border:1px solid var(--border);font-weight:700}
.badge-success{background:#dcfce7;color:#166534;border-color:#16a34a}

.plans{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:.75rem}
.plan-card{border:1px solid var(--border);border-radius:12px;display:block;cursor:pointer;transition:box-shadow .15s,border-color .15s}
.plan-card:hover{box-shadow:0 6px 18px rgba(0,0,0,.08)}
.plan-card input{display:none}
.plan-body{padding:1rem}
.plan-card.recommended{border-color:#4f46e5;box-shadow:0 0 0 2px rgba(79,70,229,.18)}
.ribbon{background:#4f46e5;color:#fff;display:inline-block;padding:.15rem .55rem;border-radius:8px;margin-bottom:.4rem;font-size:.8rem}
.price{font-size:1.8rem;font-weight:800;margin:.35rem 0}
