@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
/* HN-BUILD: pwfix-r2-40px */

/* ============================================================
   HAGAMOS NEGOCIOS v8 — Final
   ============================================================ */
:root {
  --p:#5B5BD6; --p2:#4747B8; --ps:rgba(91,91,214,.09); --ps2:rgba(91,91,214,.16);
  --a:#10B981; --err:#EF4444; --warn:#F59E0B;
  --bg:#EFF1F8; --s:#FFF; --s2:#F5F7FC; --s3:#ECEEF6;
  --b:#E2E5F0; --b2:#C8CCE0;
  --tx:#0F1324; --t2:#4A5268; --t3:#96A0BC;
  --sh:0 1px 2px rgba(0,0,0,.04),0 2px 8px rgba(0,0,0,.05);
  --shl:0 4px 20px rgba(0,0,0,.09);
  --grad:linear-gradient(135deg,#5B5BD6,#7C3AED);
  --r:7px; --rl:11px; --rx:14px; --rxx:18px; --rp:999px;
  --t:.13s ease; --sw:204px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--tx);min-height:100svh;font-size:13px;line-height:1.55;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}img{display:block;max-width:100%}
button,input,select,textarea{font-family:inherit}

/* fondo punteado sutil */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle at 1px 1px,rgba(91,91,214,.055) 1px,transparent 0);
  background-size:28px 28px}
.hn-wrap,body.auth-page>*{position:relative;z-index:1}

/* ── LAYOUT ── */
.hn-wrap{display:flex;min-height:100svh;position:relative;z-index:1}

/* ── SIDEBAR ── */
.hn-sb{width:var(--sw);flex-shrink:0;background:var(--s);border-right:1px solid var(--b);display:flex;flex-direction:column;position:sticky;top:0;height:100svh;overflow-y:auto;overflow-x:hidden;z-index:40;box-shadow:2px 0 10px rgba(0,0,0,.04)}
.sb-head{padding:14px 10px 10px;border-bottom:1px solid var(--b);flex-shrink:0}
.sb-logo{display:flex;align-items:center;gap:8px;text-decoration:none;min-width:0}
.sb-icon{width:28px;height:28px;border-radius:var(--r);background:var(--grad);color:#fff;font-size:10px;font-weight:800;display:grid;place-items:center;flex-shrink:0}
.sb-logo strong{font-size:12px;font-weight:700;color:var(--tx);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-logo small{font-size:9px;color:var(--t3);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-sec{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t3);padding:12px 14px 4px;flex-shrink:0}
.sb-a{display:flex;align-items:center;gap:8px;padding:7px 10px;margin:1px 7px;border-radius:var(--r);font-size:12px;font-weight:500;color:var(--t2);transition:all var(--t);text-decoration:none;white-space:nowrap;overflow:hidden}
.sb-a:hover{background:var(--s2);color:var(--tx);transform:translateX(2px)}
.sb-a.on{background:var(--ps);color:var(--p);font-weight:600}
.sb-a .ic{display:flex;align-items:center;justify-content:center;width:15px;flex-shrink:0}
.sb-a .ic svg{display:block}
/* Solo el link de salir en el footer, sin avatar del sidebar */
.sb-foot{margin-top:auto;padding:7px 7px 12px;border-top:1px solid var(--b);flex-shrink:0}
/* Ocultar sb-user completamente */
.sb-user{display:none!important}

/* ── MAIN ── */
.hn-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-x:hidden}

/* ── TOPBAR — sin título de página, solo logo + avatar ── */
.hn-top{background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--b);height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;position:sticky;top:0;z-index:100;box-shadow:var(--sh);flex-shrink:0;gap:10px}
.tb-l{display:flex;align-items:center;gap:10px}
.tb-r{display:flex;align-items:center;gap:8px}
/* Logo en topbar */
.tb-brand{display:flex;align-items:center;gap:8px;text-decoration:none}
.tb-brand-icon{width:26px;height:26px;border-radius:var(--r);background:var(--grad);color:#fff;font-size:9px;font-weight:800;display:grid;place-items:center;flex-shrink:0}
.tb-brand-img{height:22px;width:auto;object-fit:contain}
.tb-brand-name{font-size:13px;font-weight:700;color:var(--tx)}
/* Ocultar título duplicado */
.tb-ptitle{display:none}
/* Un solo avatar a la derecha */
.tb-user{display:flex;align-items:center;gap:7px;padding:5px 10px 5px 6px;background:var(--s2);border:1px solid var(--b);border-radius:var(--rp);cursor:pointer;transition:background var(--t);text-decoration:none}
.tb-user:hover{background:var(--s3)}
.tb-av{width:24px;height:24px;border-radius:50%;object-fit:cover;background:var(--grad);color:#fff;font-size:9px;font-weight:700;display:grid;place-items:center;flex-shrink:0}
.tb-uname{font-size:12px;font-weight:500;color:var(--t2)}
/* Ocultar btn y av duplicados del header antiguo */
.tb-btn,.tb-av-sm,.tb-av-i,.tb-theme{display:none!important}
/* Hamburger mobile */
.tb-ham{display:none;background:var(--s2);border:1px solid var(--b);border-radius:var(--r);width:32px;height:32px;cursor:pointer;color:var(--tx);place-items:center}

/* ── BODY ── */
.hn-body{flex:1;padding:20px 22px 56px}
.wrap{max-width:1060px;margin:0 auto}

/* ── MOBILE DRAWER ── */
.mob-drw{display:none;position:fixed;inset:0;z-index:300}
.mob-drw.on{display:block}
.mob-ov{position:absolute;inset:0;background:rgba(0,0,0,.4);backdrop-filter:blur(2px)}
.mob-pnl{position:absolute;left:0;top:0;bottom:0;width:250px;background:var(--s);border-right:1px solid var(--b);display:flex;flex-direction:column;overflow-y:auto;animation:drwIn .18s ease}
@keyframes drwIn{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.mob-top{display:flex;align-items:center;justify-content:space-between;padding:12px 10px 9px;border-bottom:1px solid var(--b);flex-shrink:0}
.mob-x{background:var(--s2);border:1px solid var(--b);border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:12px;color:var(--t2);display:grid;place-items:center}

/* ── TIPO ── */
h1{font-size:clamp(16px,2.2vw,20px);font-weight:700;color:var(--tx);line-height:1.2}
h2{font-size:clamp(14px,1.8vw,16px);font-weight:600;color:var(--tx);line-height:1.25}
h3{font-size:13px;font-weight:600;color:var(--tx)}
p{color:var(--t2);font-size:12px;line-height:1.6}
small,.small{font-size:11px;color:var(--t3)}.muted{color:var(--t3)}
.hero{margin-bottom:18px}.hero h1{margin-bottom:2px}.hero p{font-size:12px;color:var(--t3);margin:0}

/* ── CARDS ── */
.card,.acl,.admin-card-link{background:var(--s);border:1px solid var(--b);border-radius:var(--rx);padding:16px;box-shadow:var(--sh);transition:box-shadow var(--t),transform var(--t)}
.card:hover{box-shadow:var(--shl)}
.acl,.admin-card-link{display:block;cursor:pointer}
.acl:hover,.admin-card-link:hover{box-shadow:var(--shl);transform:translateY(-2px)}
.card p,.admin-card-link p{color:var(--t2);font-size:12px;margin-top:2px}

/* KPI */
.kpi,.kpi-card{background:var(--s);border:1px solid var(--b);border-radius:var(--rx);padding:14px 16px;box-shadow:var(--sh);position:relative;overflow:hidden;transition:box-shadow var(--t),transform var(--t)}
.kpi:hover,.kpi-card:hover{box-shadow:var(--shl);transform:translateY(-1px)}
.kpi::after,.kpi-card::after{content:'';position:absolute;right:-12px;top:-12px;width:56px;height:56px;border-radius:50%;background:var(--ps)}
.kpi h3,.kpi-card h3{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--t3);margin-bottom:7px}
.score,.kpi .score,.kpi-card .score{font-size:28px;font-weight:800;line-height:1;letter-spacing:-.5px;color:var(--p);display:block}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-6{grid-column:span 6}.col-8{grid-column:span 8}.col-12{grid-column:span 12}

/* ── BOTONES ── */
.btn,.db,.dash-btn,.matches-lite-refresh,.mlr,.auth-main-btn,.auth-green-btn,.geo-main-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border:none;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;line-height:1;
  border-radius:var(--rl);padding:9px 18px;transition:all var(--t);text-decoration:none;white-space:nowrap;
}
.btn,.db.primary,.dash-btn.primary,.auth-main-btn{background:var(--p);color:#fff;box-shadow:0 2px 8px rgba(91,91,214,.28)}
.btn:hover,.db.primary:hover,.dash-btn.primary:hover,.auth-main-btn:hover{background:var(--p2);transform:translateY(-2px);box-shadow:0 6px 18px rgba(91,91,214,.32)}
.btn-outline,.db.outline,.dash-btn.outline,.db.light,.dash-btn.light{background:var(--s);color:var(--t2);border:1px solid var(--b2)}
.btn-outline:hover,.db.outline:hover,.dash-btn.outline:hover,.db.light:hover,.dash-btn.light:hover{background:var(--s2);color:var(--tx);transform:translateY(-1px)}
.btn-blue{background:linear-gradient(135deg,#1E40AF,#4338CA);color:#fff}
.btn-blue:hover{opacity:.9;transform:translateY(-2px)}
.btn-full{width:100%}.btn-sm{padding:5px 11px;font-size:11px;border-radius:var(--r)}.btn-wide{min-width:130px}
.auth-green-btn,.db.accent{background:var(--a)!important;color:#fff!important;box-shadow:0 2px 8px rgba(16,185,129,.28)!important}
.auth-green-btn:hover{background:#059669!important;transform:translateY(-2px)}
.matches-lite-refresh,.mlr{background:var(--p);color:#fff;border-radius:var(--rp);padding:8px 16px;font-size:12px;box-shadow:0 2px 8px rgba(91,91,214,.28)}
.matches-lite-refresh:hover,.mlr:hover{background:var(--p2);transform:translateY(-2px)}
.geo-main-btn{width:100%;background:var(--p);color:#fff;box-shadow:0 2px 8px rgba(91,91,214,.28);padding:12px}
.geo-main-btn:hover{background:var(--p2);transform:translateY(-1px)}

/* ── INPUTS — TODOS IGUALES ── */
.inp,input[type=text],input[type=email],input[type=password],
input[type=tel],input[type=number],input[type=search],
input[type=date],input[type=datetime-local],input[type=time],
input[type=url],select,textarea{
  width:100%;background:var(--s2);border:1px solid var(--b2);
  border-radius:var(--rl);padding:10px 13px;
  font-size:13px;color:var(--tx);outline:none;
  transition:border-color var(--t),box-shadow var(--t),background var(--t);
  appearance:none;-webkit-appearance:none;
  box-sizing:border-box;display:block;font-family:inherit;
}
.inp:focus,input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,
input[type=tel]:focus,input[type=number]:focus,input[type=search]:focus,
input[type=date]:focus,input[type=datetime-local]:focus,
input[type=url]:focus,select:focus,textarea:focus{
  border-color:var(--p);background:var(--s);box-shadow:0 0 0 3px rgba(91,91,214,.10);
}
textarea{min-height:88px;resize:vertical}
label{display:block;font-size:11px;font-weight:600;color:var(--t2);margin-bottom:4px}
.fh,.field-help{font-size:10px;color:var(--t3);margin:-1px 0 6px}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%2396A0BC' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
input[type=file]{padding:9px 12px;cursor:pointer;font-size:12px;background:var(--s2);border:1.5px dashed var(--b2);border-radius:var(--rl);color:var(--t3);width:100%;box-sizing:border-box}
input[type=file]:hover{border-color:var(--p)}
input[type=file]::-webkit-file-upload-button,input[type=file]::file-selector-button{background:var(--p);color:#fff;border:none;border-radius:var(--r);padding:5px 10px;font-size:11px;font-weight:600;cursor:pointer;margin-right:9px;font-family:inherit}
input[type=checkbox]{width:14px!important;height:14px!important;accent-color:var(--p)!important;cursor:pointer!important}
input[type=color]{width:40px;height:36px;border-radius:var(--r);border:1px solid var(--b2);padding:2px;cursor:pointer;background:var(--s)}

/* ── TABLA ── */
.table-wrap,.tw{background:var(--s);border:1px solid var(--b);border-radius:var(--rx);overflow:hidden;box-shadow:var(--sh)}
.table{width:100%;border-collapse:collapse;font-size:12px}
.table th{background:var(--s2);color:var(--t3);font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:8px 13px;text-align:left;border-bottom:1px solid var(--b)}
.table td{padding:10px 13px;border-bottom:1px solid var(--b);color:var(--tx);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tbody tr:hover td{background:var(--s2)}
.table td .btn,.table td button{padding:4px 10px!important;font-size:10px!important;border-radius:var(--r)!important;margin:1px 0!important}

/* ── PILLS / BADGES / ALERTAS ── */
.status-pill,.sp{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:var(--rp);font-size:10px;font-weight:600}
.status-active,.status-open,.status-abierto{background:#ECFDF5;color:#065F46}
.status-soon,.status-proximo{background:#FFFBEB;color:#92400E}
.status-closed,.status-cerrado,.status-inactivo{background:#FEF2F2;color:#991B1B}
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:var(--rp);font-size:10px;font-weight:600;background:var(--ps);color:var(--p)}
.alert{padding:10px 13px;border-radius:var(--rl);margin-bottom:12px;font-size:12px;font-weight:500;border-left:3px solid;background:#FFFBEB;color:#92400E;border-color:var(--warn)}
.alert.success{background:#ECFDF5;color:#065F46;border-color:var(--a)}
.alert.error{background:#FEF2F2;color:#991B1B;border-color:var(--err)}
.alert.info{background:var(--ps);color:var(--p);border-color:var(--p)}

/* ── AVATARES ── */
.avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--p);background:var(--s2);flex-shrink:0}
.avatar-lg{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid var(--b2)}
.pro-chat-avatar,.admin-avatar-mini{width:30px;height:30px;border-radius:50%;object-fit:cover;background:var(--s2);flex-shrink:0}

/* ══════════════════════════════════════════════════════════
   AUTH
   ══════════════════════════════════════════════════════════ */
body.auth-page{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;min-height:100svh!important;padding:20px!important}
body.auth-page .auth-right-pg,body.auth-page .auth-rc,body.auth-page .auth-kicker,
body.auth-page .auth-big,body.auth-page .auth-desc,body.auth-page .auth-features,
body.auth-page .auth-feat{display:none!important}
.auth-pg{width:100%;max-width:420px;background:var(--s);border:1px solid var(--b);border-radius:22px;padding:36px 32px;box-shadow:0 8px 40px rgba(0,0,0,.10);position:relative;z-index:1}
.auth-left-pg{all:unset!important;display:contents!important}
.auth-logo-wrap{display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;margin-bottom:24px!important;text-align:center!important}
.auth-logo-img{max-height:64px!important;max-width:200px!important;width:auto!important;object-fit:contain!important;display:block!important;margin:0 auto!important}
.auth-logo-txt{font-size:20px!important;font-weight:800!important;color:var(--p)!important;text-align:center!important}
.auth-ttl{font-size:22px!important;font-weight:700!important;color:var(--tx)!important;margin-bottom:5px!important;text-align:center!important}
.auth-sub{font-size:13px!important;color:var(--t3)!important;margin-bottom:22px!important;text-align:center!important}
.auth-iw{position:relative;margin-bottom:10px}
.auth-ii{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:22px;text-align:center;font-size:14px;line-height:1;color:var(--t3);pointer-events:none}
.auth-in{width:100%!important;background:var(--s2)!important;border:1px solid var(--b2)!important;border-radius:var(--rl)!important;padding:10px 11px 10px 40px!important;font-size:13px!important;color:var(--tx)!important;outline:none!important;transition:all var(--t)!important;box-sizing:border-box!important}
.auth-in:focus{border-color:var(--p)!important;background:var(--s)!important;box-shadow:0 0 0 3px rgba(91,91,214,.10)!important}
.auth-in::placeholder{color:var(--t3)!important}
.auth-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:3px 0 14px;font-size:11px}
.auth-row span{color:var(--t3);display:flex;align-items:center;gap:5px}
.auth-lnk{color:var(--p)!important;font-weight:600}
.auth-btn{width:100%;background:var(--p)!important;color:#fff!important;border:none!important;border-radius:var(--rl)!important;padding:12px!important;font-size:14px!important;font-weight:600!important;box-shadow:0 4px 14px rgba(91,91,214,.28)!important;cursor:pointer;transition:all var(--t)!important;display:block!important}
.auth-btn:hover{background:var(--p2)!important;transform:translateY(-2px)!important;box-shadow:0 8px 20px rgba(91,91,214,.32)!important}
.auth-btn-g{background:var(--a)!important;box-shadow:0 4px 14px rgba(16,185,129,.28)!important}
.auth-btn-g:hover{background:#059669!important}
.auth-ft{text-align:center;font-size:12px;color:var(--t3);margin-top:16px}
.auth-ep{background:var(--ps);border:1px solid var(--ps2);border-radius:var(--rl);padding:8px 11px;margin-bottom:11px;font-size:11px;display:flex;justify-content:space-between;align-items:center;color:var(--p);font-weight:600}
.auth-footer{position:fixed;bottom:0;left:0;right:0;padding:10px 20px;display:flex;justify-content:center;gap:16px;font-size:11px;color:var(--t3);background:transparent}
.auth-footer a{color:var(--t3)}
.auth-footer a:hover{color:var(--p)}

/* ══════════════════════════════════════════════════════════
   DASHBOARD — cards clickeables con destino
   ══════════════════════════════════════════════════════════ */
.dashboard-shell{padding:0}
.dashboard-welcome-card,.dashboard-welcome-clean{background:var(--grad)!important;border-radius:var(--rxx)!important;padding:20px!important;margin-bottom:14px;border:none!important;box-shadow:0 6px 24px rgba(91,91,214,.22)!important;position:relative;overflow:hidden}
.dashboard-welcome-card::before{content:'';position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.06)}
.dashboard-welcome-card::after{content:'';position:absolute;left:-20px;bottom:-30px;width:100px;height:100px;border-radius:50%;background:rgba(255,255,255,.04)}
.dashboard-user-block{display:flex;align-items:center;gap:12px;margin-bottom:14px;position:relative;z-index:1}
.dashboard-avatar{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3);flex-shrink:0}
.dashboard-user-block h1{color:#fff!important;font-size:18px;margin:0}
.dashboard-user-block p{color:rgba(255,255,255,.7)!important;font-size:11px;margin:2px 0 0}
.dashboard-kicker{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6);display:block;margin-bottom:2px}
.dashboard-actions{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1}
.dashboard-actions .db,.dashboard-actions .dash-btn{font-size:12px!important;padding:9px 16px!important;border-radius:var(--rp)!important;transition:all .2s ease!important}
.dashboard-actions .db.primary,.dashboard-actions .dash-btn.primary{background:rgba(255,255,255,.95)!important;color:var(--p)!important;box-shadow:0 4px 14px rgba(0,0,0,.15)!important;border:none!important}
.dashboard-actions .db.primary:hover,.dashboard-actions .dash-btn.primary:hover{background:#fff!important;transform:translateY(-3px)!important;box-shadow:0 8px 22px rgba(0,0,0,.2)!important}
.dashboard-actions .db.outline,.dashboard-actions .dash-btn.outline,
.dashboard-actions .db.light,.dashboard-actions .dash-btn.light{background:rgba(255,255,255,.15)!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important}
.dashboard-actions .db.outline:hover,.dashboard-actions .dash-btn.outline:hover,
.dashboard-actions .db.light:hover,.dashboard-actions .dash-btn.light:hover{background:rgba(255,255,255,.25)!important;transform:translateY(-3px)!important}
.dashboard-grid,.dashboard-grid-clean{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
/* Cards del dashboard clickeables */
.dashboard-card{
  background:var(--s)!important;border:1px solid var(--b)!important;
  border-radius:var(--rx)!important;padding:14px!important;
  box-shadow:var(--sh)!important;transition:all var(--t)!important;
  cursor:pointer!important;text-decoration:none!important;display:block!important;
  position:relative!important;overflow:hidden!important;
}
.dashboard-card::after{content:'→';position:absolute;bottom:10px;right:13px;font-size:14px;color:var(--b2);transition:all var(--t)}
.dashboard-card:hover{box-shadow:var(--shl)!important;transform:translateY(-3px)!important;border-color:var(--ps2)!important}
.dashboard-card:hover::after{color:var(--p);transform:translateX(3px)}
.metric-card{display:flex;align-items:flex-start;gap:10px}
.metric-icon{width:36px;height:36px;border-radius:var(--rl);background:var(--ps);display:grid;place-items:center;font-size:18px;flex-shrink:0}
.dash-card-label{font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--t3);display:block;margin-bottom:2px}
.dash-number{font-size:22px;font-weight:800;color:var(--tx);display:block;line-height:1;letter-spacing:-.3px;margin-bottom:2px}
.dashboard-card strong{color:var(--tx);font-size:13px;font-weight:600;display:block}
.dashboard-card p{color:var(--t3);font-size:11px;margin-top:1px}
.profile-progress{width:100%;height:4px;background:var(--s3);border-radius:var(--rp);overflow:hidden;margin:5px 0}
.profile-progress div{height:100%;background:linear-gradient(90deg,var(--a),var(--p));border-radius:var(--rp)}

/* ══════════════════════════════════════════════════════════
   MATCHES — lista con cards más visuales
   ══════════════════════════════════════════════════════════ */
.matches-lite-shell{padding:0}
.matches-lite-hero{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:9px;flex-wrap:wrap}
.matches-lite-hero h1{font-size:18px;font-weight:700;color:var(--tx)}
.matches-lite-hero p{color:var(--t3);font-size:11px;margin:0}
.matches-lite-panel{background:var(--s);border:1px solid var(--b);border-radius:var(--rxx);overflow:hidden;box-shadow:var(--sh)}
.matches-lite-list{display:flex;flex-direction:column}
.matches-lite-empty,.empty-state{text-align:center;padding:40px 16px;color:var(--t3)}

/* Fila de match como card con foto grande */
.match-lite-row,.match-card{
  display:grid;grid-template-columns:48px 1fr auto;
  align-items:center;gap:12px;
  padding:13px 16px;border-bottom:1px solid var(--b);
  cursor:pointer;transition:all var(--t);background:var(--s);
}
.match-lite-row:last-child,.match-card:last-child{border-bottom:none}
.match-lite-row:hover,.match-card:hover{background:var(--ps)}
.match-avatar-button{cursor:pointer;position:relative;flex-shrink:0}
.match-avatar-button img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--b);transition:border-color var(--t),transform var(--t)}
.match-lite-row:hover .match-avatar-button img{border-color:var(--p);transform:scale(1.05)}
.match-avatar-button b{position:absolute;top:-3px;right:-3px;background:var(--err);color:#fff;border-radius:var(--rp);font-size:8px;font-weight:700;padding:1px 4px;min-width:14px;text-align:center}

/* Fila en una línea + botón "Por qué" */
.match-lite-profile{grid-column:1 / -1;display:flex;align-items:center;gap:12px;width:100%}
.match-lite-info{flex:1;min-width:0}
.match-why-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:5px;background:var(--ps);color:var(--p);border:1px solid var(--b);border-radius:999px;padding:7px 13px;font-size:12px;font-weight:700;cursor:pointer;transition:all var(--t);line-height:1}
.match-why-btn:hover{background:var(--p);color:#fff;border-color:var(--p)}
.match-why-txt{white-space:nowrap}
@media(max-width:600px){
  .match-why-btn{padding:9px 11px}
  .match-why-txt{display:none}
}

/* Info del match */
.match-lite-info{min-width:0}
.match-lite-top{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}
.match-lite-top h3{font-size:13px;font-weight:700;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.match-lite-top span{font-size:10px;color:var(--t3);flex-shrink:0;margin-left:auto}
.match-lite-info strong{font-size:11px;color:var(--t2);font-weight:600;display:block;margin-bottom:1px}
.match-lite-info p{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}

/* Flecha / score a la derecha */
.match-lite-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.score{font-size:15px;font-weight:800;color:var(--p);flex-shrink:0}
.match-arrow{width:26px;height:26px;border-radius:50%;background:var(--ps);display:grid;place-items:center;color:var(--p);font-size:12px;transition:all var(--t)}
.match-lite-row:hover .match-arrow{background:var(--p);color:#fff}

/* Notificación */
.notification-dot{background:var(--err);color:#fff;border-radius:var(--rp);padding:2px 5px;font-size:9px;font-weight:700;margin-left:4px;display:none}
.chat-alert{display:none;background:#ECFDF5;color:#065F46;border:1px solid rgba(16,185,129,.2);border-radius:var(--rl);padding:9px 13px;font-weight:600;font-size:12px;margin-bottom:12px}
.compatible-label{font-size:12px;font-weight:600;color:var(--p);background:var(--ps);padding:8px 12px;border-radius:var(--rl);text-align:center}

/* ══════════════════════════════════════════════════════════
   MODAL MATCH — rediseño centrado y limpio
   ══════════════════════════════════════════════════════════ */
.match-modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(15,19,36,.55);z-index:500;
  align-items:center;justify-content:center;
  backdrop-filter:blur(6px);padding:20px;
}
.match-modal-overlay.open{display:flex}
.match-modal-card{
  background:#fff;border-radius:22px;
  width:100%;max-width:412px;
  max-height:90svh;overflow-y:auto;
  position:relative;box-shadow:0 24px 70px rgba(15,19,36,.3);
  animation:modalIn .22s ease;
}
@keyframes modalIn{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
/* Header limpio (claro, sin bloque morado pesado) */
.match-modal-hero-banner{
  background:#fff;padding:24px 24px 18px;
  display:flex;align-items:center;gap:14px;
  position:relative;overflow:visible;border-radius:22px 22px 0 0;
  border-bottom:1px solid var(--b);
}
.match-modal-hero-banner::after{display:none}
.match-modal-hero-banner img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 0 0 2px var(--p);flex-shrink:0;position:relative;z-index:1}
.match-modal-hero-banner div{position:relative;z-index:1}
.match-modal-hero-banner h2{color:var(--tx)!important;font-size:17px;font-weight:700;margin-bottom:3px;line-height:1.2}
.match-modal-hero-banner p{color:var(--t3)!important;font-size:12.5px;margin:0}
.match-modal-close{position:absolute;top:14px;right:14px;background:var(--s2);border:1px solid var(--b);border-radius:50%;width:30px;height:30px;font-size:17px;cursor:pointer;color:var(--t2);display:grid;place-items:center;z-index:10;transition:all var(--t);line-height:1}
.match-modal-close:hover{background:var(--err);border-color:var(--err);color:#fff}
/* Cuerpo modal */
.match-modal-body,.match-modal-card>*:not(.match-modal-hero-banner):not(.match-modal-close):not(.match-modal-actions){padding:0}
.match-modal-card .hm-v58-type,.match-modal-card .hm-v58-question,
.match-modal-card .hm-v58-actions,
.match-modal-card .hm-ai-actions,.match-modal-card .match-modal-actions{
  padding-left:24px;padding-right:24px;
}
.match-modal-card .hm-v58-type{margin-top:22px;display:inline-flex;align-items:center;gap:5px;background:var(--ps);color:var(--p);padding:5px 12px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;margin-bottom:16px}
.match-modal-card .hm-v58-question{display:flex;align-items:center;gap:7px;font-weight:700;font-size:14px;margin-bottom:11px;color:var(--tx)}
/* Razón: texto limpio con acento, sin caja gris vacía */
.match-modal-card .hm-v58-reason{color:var(--t2);font-size:15px;line-height:1.7;background:transparent;border:none;border-left:3px solid var(--p);border-radius:0;padding:3px 0 3px 16px;margin:0 24px 22px}
/* Acciones balanceadas con separador */
.match-modal-card .hm-v58-actions,.match-modal-card .hm-ai-actions,.match-modal-card .match-modal-actions{display:flex;gap:10px;padding:18px 24px 24px;border-top:1px solid var(--b)}
.match-modal-card .match-modal-actions .dash-btn{padding:13px 18px;font-size:14px;border-radius:13px;font-weight:600}
.match-modal-card .match-modal-actions .dash-btn.outline{flex:0 0 auto;min-width:92px}
.match-modal-card .match-modal-actions .dash-btn.primary{flex:1}
/* Viejo hero style — ocultar */
.match-modal-hero{display:none!important}

/* ══════════════════════════════════════════════════════════
   CHAT — rediseño WhatsApp-like
   ══════════════════════════════════════════════════════════ */
.pro-chat-shell{display:flex;flex-direction:column;height:calc(100svh - 52px);background:#F0F2F8}
.pro-chat-header{
  background:var(--s);border-bottom:1px solid var(--b);
  padding:10px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0;
  box-shadow:0 1px 6px rgba(0,0,0,.05);
}
.pro-chat-back{
  width:32px;height:32px;border-radius:50%;
  background:var(--s2);border:1px solid var(--b);
  display:grid;place-items:center;cursor:pointer;color:var(--t2);font-size:16px;
  flex-shrink:0;transition:all var(--t);text-decoration:none;
}
.pro-chat-back:hover{background:var(--p);border-color:var(--p);color:#fff}
.pro-chat-avatar-wrap{position:relative;flex-shrink:0}
.pro-chat-avatar-wrap img,.pro-chat-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--b2)}
.pro-online-dot{position:absolute;bottom:1px;right:1px;width:9px;height:9px;border-radius:50%;background:var(--a);border:2px solid var(--s)}
.pro-chat-user{flex:1;min-width:0}
.pro-chat-user strong{font-size:13px;font-weight:600;color:var(--tx);display:block;line-height:1.2}
.pro-chat-user span{font-size:10px;color:var(--t3)}

/* Área de mensajes */
.pro-chat-messages,.chat-box{
  flex:1;overflow-y:auto;
  padding:18px 16px;
  display:flex;flex-direction:column;gap:7px;
}
/* Agrupar mensajes */
.pro-msg-row{display:flex;align-items:flex-end;gap:6px}
.pro-msg-row.mine{flex-direction:row-reverse}
.pro-msg-av-wrap{width:28px;flex-shrink:0}
.pro-msg-av{width:26px;height:26px;border-radius:50%;object-fit:cover;background:var(--s3);display:block}

/* Burbujas */
.pro-msg-bubble,.msg{
  max-width:68%;
  word-break:break-word;
  font-size:13px;line-height:1.5;
  position:relative;
}
/* Recibido */
.pro-msg-row.other .pro-msg-bubble,.msg:not(.me){
  background:var(--s);
  border:1px solid var(--b);
  color:var(--tx);
  padding:8px 12px 6px;
  border-radius:16px 16px 16px 4px;
  box-shadow:0 1px 2px rgba(0,0,0,.05);
}
/* Propio */
.pro-msg-row.mine .pro-msg-bubble,.msg.me{
  background:var(--p);
  color:#fff;
  padding:8px 12px 6px;
  border-radius:16px 16px 4px 16px;
  box-shadow:0 2px 8px rgba(91,91,214,.25);
  margin-left:auto;
}
/* Elementos internos de la burbuja (nombre / texto / hora) */
.pro-msg-bubble strong{display:block;font-size:11px;font-weight:700;margin-bottom:2px}
.pro-msg-bubble>div{font-size:13px;line-height:1.45}
.pro-msg-bubble small{display:block;text-align:right;font-size:10px;margin-top:3px;line-height:1}
.pro-msg-row.other .pro-msg-bubble strong{color:var(--p)}
.pro-msg-row.other .pro-msg-bubble small{color:var(--t3)}
.pro-msg-row.mine .pro-msg-bubble{color:#fff}
.pro-msg-row.mine .pro-msg-bubble small{color:rgba(255,255,255,.7)}
.pro-msg-time{
  font-size:9px;color:rgba(255,255,255,.65);
  display:block;text-align:right;margin-top:3px;
}
.pro-msg-time-recv{
  font-size:9px;color:var(--t3);
  display:block;text-align:left;margin-top:3px;
}
/* Nombre encima del primer mensaje del grupo */
.pro-msg-name{font-size:10px;font-weight:600;color:var(--p);margin-bottom:3px;padding-left:2px}

/* Input área */
.pro-chat-form{
  background:var(--s);border-top:1px solid var(--b);
  padding:10px 14px;display:flex;gap:8px;align-items:center;flex-shrink:0;
}
.pro-chat-input-wrap{
  flex:1;background:var(--s2);border:1px solid var(--b2);
  border-radius:22px;padding:2px 14px;display:flex;align-items:center;
  transition:border-color var(--t);
}
.pro-chat-input-wrap:focus-within{border-color:var(--p);background:var(--s)}
.pro-chat-form textarea{
  flex:1;min-height:36px;max-height:90px;resize:none;
  background:transparent!important;border:none!important;
  border-radius:0!important;padding:8px 0!important;
  font-size:13px!important;outline:none!important;box-shadow:none!important;
}
.pro-chat-send-btn{
  width:42px!important;height:42px!important;border-radius:50%!important;
  padding:0!important;min-width:0!important;
  background:var(--a);color:#fff;border:none;cursor:pointer;
  display:grid!important;place-items:center!important;flex-shrink:0;
  transition:all var(--t);box-shadow:0 4px 12px rgba(16,185,129,.4);
  font-size:16px;
}
.pro-chat-send-btn:hover{background:#0DA06E;transform:scale(1.08);box-shadow:0 6px 18px rgba(16,185,129,.5)}
.pro-chat-send-btn:disabled{background:var(--b2);box-shadow:none;cursor:not-allowed}
/* Si el PHP usa un button.btn genérico en el form */
.pro-chat-form .btn,.pro-chat-form button[type=submit]:not(.pro-chat-send-btn){
  width:40px!important;height:40px!important;border-radius:50%!important;
  padding:0!important;font-size:16px!important;min-width:0!important;
  background:var(--p)!important;color:#fff!important;
  box-shadow:0 2px 8px rgba(91,91,214,.28)!important;
  border:none!important;
}
.pro-chat-form .btn:hover,.pro-chat-form button[type=submit]:not(.pro-chat-send-btn):hover{
  background:var(--p2)!important;transform:scale(1.08)!important;
}
.pro-chat-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;color:var(--t3);font-size:13px;
  gap:8px;padding:24px;text-align:center;
}
.chat-closed-65{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:8px 12px;text-align:center;color:var(--t3);font-size:11px;margin:7px 14px}

/* ── CONVERSACIONES ── */
.conversation-card{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;border:1px solid var(--b);border-radius:var(--rx);padding:11px 13px;margin-bottom:7px;background:var(--s);cursor:pointer;transition:all var(--t)}
.conversation-card:hover{border-color:var(--p);background:var(--ps);transform:translateX(2px)}
.conversation-left{display:flex;gap:9px;align-items:flex-start}
.conversation-meta{display:flex;gap:5px;align-items:center;flex-wrap:wrap;margin:2px 0}
.last-message{color:var(--t2);font-size:11px;margin:2px 0}
.unread-badge{background:var(--err);color:#fff;border-radius:var(--rp);padding:2px 6px;font-weight:700;font-size:10px}
.active-dot{width:6px;height:6px;border-radius:50%;background:var(--a);display:inline-block}

/* ── ADMIN ── */
.admin-hero,.admin-staff-hero{background:var(--grad);border-radius:var(--rxx);padding:16px 20px;color:#fff;margin-bottom:14px;position:relative;overflow:hidden}
.admin-hero::after,.admin-staff-hero::after{content:'';position:absolute;right:-35px;top:-35px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.06)}
.admin-hero h1,.admin-staff-hero h1{color:#fff;font-size:16px;margin-bottom:2px}
.admin-hero p,.admin-staff-hero p{color:rgba(255,255,255,.65);font-size:11px;margin:0}
.eyebrow{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.55);display:block;margin-bottom:4px}
.admin-strip-v59,.admin-strip-v54{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:nowrap;border-left:3px solid var(--p);background:var(--s);border-radius:0 var(--rx) var(--rx) 0;padding:10px 14px;box-shadow:var(--sh);overflow:hidden}
.admin-strip-v59 strong,.admin-strip-v54 strong{color:var(--tx);font-weight:600;font-size:12px;white-space:nowrap}
.admin-strip-v59 span,.admin-strip-v54 span{color:var(--t3);font-size:11px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.admin-form-grid,.admin-edit-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(190px,.9fr);gap:12px;align-items:start}
.admin-staff-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;align-items:start}
.admin-staff-page{max-width:800px;margin:0 auto}
.admin-staff-form,.admin-staff-form-card{background:var(--s);border:1px solid var(--b);border-radius:var(--rx);padding:16px;box-shadow:var(--sh)}
.admin-staff-list{display:flex;flex-direction:column;gap:7px}
.admin-staff-list-card{background:var(--s);border:1px solid var(--b);border-radius:var(--rx);padding:10px;display:flex;align-items:center;gap:9px;box-shadow:var(--sh)}
.admin-person-row{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--b)}
.admin-person-row:last-child{border-bottom:none}
.admin-person-info{flex:1;min-width:0}
.admin-person-badge,.admin-role-box{display:inline-flex;align-items:center;gap:3px;background:var(--ps);color:var(--p);padding:2px 6px;border-radius:var(--rp);font-size:10px;font-weight:600}
.admin-person-phone,.admin-person-name{font-size:11px;color:var(--t2)}
.admin-grid{display:grid;gap:12px}
.admin-no-match-list{display:flex;flex-direction:column;gap:7px}
.admin-no-match-row{display:flex;align-items:center;gap:9px;padding:10px;background:var(--s);border:1px solid var(--b);border-radius:var(--rx)}
.admin-no-match-text{font-size:11px;color:var(--t2)}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:9px;margin-bottom:11px}
.section-head h2{font-size:13px;font-weight:600;color:var(--tx)}
.admin-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:9px;flex-wrap:wrap}
.admin-page-header h1{font-size:17px;font-weight:700;color:var(--tx)}

/* ── PERFIL ── */
.profile-shell{padding:0}
.profile-hero{background:var(--grad);border-radius:var(--rxx);padding:20px;display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px;box-shadow:0 4px 20px rgba(91,91,214,.2);position:relative;overflow:hidden}
.profile-hero::after{content:'';position:absolute;right:-40px;top:-40px;width:140px;height:140px;border-radius:50%;background:rgba(255,255,255,.06)}
.profile-hero-left{display:flex;align-items:center;gap:12px;position:relative;z-index:1}
.profile-hero-avatar{width:58px;height:58px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3);background:var(--s2)}
.profile-kicker{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6);display:block;margin-bottom:3px}
.profile-hero h1{color:#fff!important;font-size:clamp(14px,2.2vw,18px);margin:0}
.profile-hero p{color:rgba(255,255,255,.65)!important;font-size:11px;margin:4px 0 0}
.profile-score-card{min-width:130px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);border-radius:var(--rx);padding:12px;position:relative;z-index:1}
.profile-score-card span{display:block;color:rgba(255,255,255,.65);font-size:10px;font-weight:500;margin-bottom:3px}
.profile-score-card strong{display:block;color:#fff;font-size:24px;font-weight:800;letter-spacing:-.5px;margin-bottom:5px}
.profile-card-pro{background:var(--s);border:1px solid var(--b);border-radius:var(--rxx);padding:20px;box-shadow:var(--sh)}
.profile-section-title{margin:18px 0 11px;padding-top:14px;border-top:1px solid var(--b)}
.profile-section-title:first-child{border-top:none;padding-top:0;margin-top:0}
.profile-section-title h2{color:var(--tx);font-size:14px;margin-bottom:2px}
.profile-section-title p{color:var(--t3);font-size:11px;margin:0}
.profile-upload-clean{background:var(--s2);border:1px solid var(--b);border-radius:var(--rx);padding:14px;margin-bottom:13px;display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:center}
.profile-upload-clean label{margin:0 0 4px!important;font-size:11px!important;font-weight:600!important;color:var(--t2)!important}
.profile-upload-clean p{margin:0;color:var(--t3);font-size:10px}
.profile-two-cols{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.profile-card-pro label{color:var(--t2)!important;font-weight:600!important;font-size:11px!important;margin:12px 0 4px!important}
.profile-info-box{background:var(--ps);border:1px solid var(--ps2);border-radius:var(--rx);padding:12px 14px;margin:14px 0}
.profile-info-box strong{display:block;color:var(--p);margin-bottom:2px;font-size:12px}
.profile-info-box span{color:var(--t2);font-size:11px}
.profile-actions-pro{display:flex;justify-content:flex-start;gap:10px;margin-top:16px}
.profile-event-pill{background:var(--s2);border:1px solid var(--b);border-radius:var(--rx);padding:9px 12px;display:flex;justify-content:space-between;gap:9px;align-items:center;margin-bottom:12px}
.profile-event-pill strong{display:block;color:var(--tx);font-size:12px}
.profile-event-pill span,.profile-event-pill small{color:var(--t3);font-size:10px}
.profile-photo-row{display:grid;grid-template-columns:76px 1fr;gap:12px;align-items:center;margin-bottom:12px}
.profile-photo-preview{width:68px;height:68px;border-radius:50%;object-fit:cover;border:2px solid var(--p);background:var(--s2)}

/* ── GEO / JOIN EVENT ── */
.geo-access-shell{max-width:400px;margin:36px auto;padding:14px}
.geo-access-card{background:var(--s);border:1px solid var(--b);border-radius:22px;padding:28px 24px;text-align:center;box-shadow:var(--sh)}
.geo-access-icon{font-size:48px;margin-bottom:14px;display:block}
.geo-access-card h2{font-size:18px;font-weight:700;color:var(--tx);margin-bottom:6px}
.geo-access-card>p{font-size:13px;color:var(--t2);margin-bottom:18px}
.geo-ok{color:var(--a);font-weight:600}
.geo-missing{color:var(--t3);font-size:11px}
.geo-status{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600}
.geo-main-btn{margin-bottom:10px!important}
.geo-code-toggle{margin-top:6px}
.geo-code-toggle button,.geo-code-toggle-btn{background:transparent!important;color:var(--p)!important;border:1.5px solid var(--ps2)!important;border-radius:var(--rl)!important;padding:9px 18px!important;font-size:12px!important;font-weight:600!important;cursor:pointer!important;width:100%!important;transition:all var(--t)!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;gap:6px!important}
.geo-code-toggle button:hover,.geo-code-toggle-btn:hover{background:var(--ps)!important;border-color:var(--p)!important}
.geo-code-form{background:var(--s2);border:1px solid var(--b);border-radius:var(--rx);padding:16px;margin-top:12px;text-align:left}
.event-code-input-65{text-align:center!important;letter-spacing:.2em!important;font-size:18px!important;font-weight:700!important;text-transform:uppercase!important}
.geo-manual-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0 12px}

/* ── MATCH PROFILE ── */
.match-profile-shell{max-width:640px;margin:0 auto;padding:0}
.match-profile-hero{background:var(--grad);border-radius:var(--rxx);padding:16px;margin-bottom:11px;display:flex;align-items:center;gap:12px;color:#fff;box-shadow:0 4px 18px rgba(91,91,214,.2)}
.match-profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:11px}
.match-profile-card{background:var(--s);border:1px solid var(--b);border-radius:var(--rx);padding:12px;box-shadow:var(--sh)}
.match-profile-actions{display:flex;gap:7px;flex-wrap:wrap}

/* ── FORMS ── */
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.info-item{background:var(--s2);border:1px solid var(--b);border-radius:var(--rl);padding:10px}
.info-item strong{display:block;font-size:9px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--t3);margin-bottom:2px}
.info-item span{color:var(--tx);font-size:12px;font-weight:500}
.places-box-75{background:var(--s2);border:1px solid var(--b);border-radius:var(--rxx);padding:13px;margin:10px 0}
.places-box-75 h2{color:var(--tx);font-size:15px;margin-bottom:3px}
.places-box-75 p{color:var(--t3);font-size:11px;margin:0 0 9px}
.place-preview-75{margin:8px 0;background:var(--s);border:1px solid var(--b);border-radius:var(--rx);padding:9px 12px}
.place-preview-75 strong{display:block;color:var(--tx);font-size:13px;font-weight:700}
.place-preview-75 span{display:block;margin-top:2px;color:var(--t3);font-size:10px}
.place-preview-75 small{display:block;margin-top:2px;color:var(--p);font-weight:700}

/* ── BRANDING / CONFIG ── */
.branding-shell{max-width:700px;margin:0 auto}
.branding-preview{background:var(--grad);border-radius:var(--rxx);padding:24px;text-align:center;margin-bottom:14px;color:#fff;position:relative;overflow:hidden}
.logo-upload-area{border:2px dashed var(--b2);border-radius:var(--rx);padding:20px;text-align:center;cursor:pointer;background:var(--s2);transition:all var(--t);display:block}
.logo-upload-area:hover{border-color:var(--p);background:var(--ps)}

/* ── FOOTER ── */
.footer-note,footer{text-align:center;color:var(--t3);padding:16px;font-size:11px}

/* ── SCROLL ── */
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media(max-width:900px){
  :root{--sw:0px}
  .hn-sb{display:none}.tb-ham{display:grid!important}
  .hn-body{padding:14px 14px 48px}
  .auth-pg{padding:28px 22px!important}
  .admin-form-grid,.admin-edit-grid,.admin-staff-layout{grid-template-columns:1fr}
  .col-3,.col-4{grid-column:span 6}
  .col-6,.col-8,.col-12{grid-column:span 12}
}
@media(max-width:560px){
  .hn-body{padding:11px 11px 44px}
  .grid{grid-template-columns:1fr}
  .col-3,.col-4,.col-6,.col-8,.col-12{grid-column:span 1}
  .dashboard-grid,.dashboard-grid-clean{grid-template-columns:1fr 1fr}
  .profile-hero{flex-direction:column;align-items:flex-start}
  .profile-score-card{min-width:0;width:100%}
  .profile-two-cols,.form-grid-2,.geo-manual-grid{grid-template-columns:1fr}
  .profile-upload-clean{grid-template-columns:1fr}
  .match-profile-grid{grid-column:1fr}
  .info-grid{grid-template-columns:1fr}
  .hm-v58-actions{flex-direction:column}
  .hm-v58-actions .db,.hm-v58-actions .dash-btn{width:100%}
  .matches-lite-hero{flex-direction:column;align-items:flex-start}
  .admin-staff-layout{grid-template-columns:1fr}
  .auth-pg{padding:22px 16px!important;border-radius:16px!important}
  body.auth-page{padding:14px!important}
  .match-modal-overlay{padding:0;align-items:flex-end}
  .match-modal-card{border-radius:20px 20px 0 0;max-height:92svh}
  @keyframes modalIn{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition-duration:0ms!important;animation-duration:0ms!important}}
/* ============================================================
   MOBILE FIX v8.1 — Correcciones específicas mobile
   Se agrega AL FINAL de style.css
   ============================================================ */

/* ── INPUTS: fuerza ancho completo en TODOS ── */
input,input[type=text],input[type=email],input[type=password],
input[type=tel],input[type=number],input[type=date],
input[type=datetime-local],input[type=url],input[type=search],
select,textarea{
  width:100%!important;
  max-width:100%!important;
  box-sizing:border-box!important;
  display:block!important;
  -webkit-appearance:none!important;
  appearance:none!important;
  background:var(--s2)!important;
  border:1px solid var(--b2)!important;
  border-radius:var(--rl)!important;
  padding:10px 13px!important;
  font-size:13px!important;
  font-family:inherit!important;
  color:var(--tx)!important;
  outline:none!important;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--p)!important;
  background:var(--s)!important;
  box-shadow:0 0 0 3px rgba(91,91,214,.10)!important;
}
/* Excepciones: no tocar los auth-in, color, checkbox, file, range */
input[type=file]{background:var(--s2)!important;border:1.5px dashed var(--b2)!important;padding:9px 12px!important}
input[type=checkbox]{width:15px!important;max-width:15px!important;height:15px!important;padding:0!important;display:inline-block!important}
input[type=color]{width:40px!important;max-width:40px!important;height:36px!important;padding:2px!important}
input[type=range]{background:transparent!important;border:none!important;padding:0!important;box-shadow:none!important}

/* ── PERFIL: layout en columnas en mobile ── */
@media(max-width:700px){
  .profile-two-cols{grid-template-columns:1fr!important}
  /* Empresa y WhatsApp como columna completa */
  .profile-card-pro .profile-two-cols>div{width:100%!important}
}

/* ── BOTONES DEL PERFIL: más grandes con icono ── */
.profile-actions-pro .db,.profile-actions-pro .dash-btn,
.profile-actions-pro button[type=submit]{
  padding:12px 24px!important;
  font-size:14px!important;
  border-radius:var(--rl)!important;
  min-width:160px!important;
  font-weight:600!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:7px!important;
}
/* Botón guardar perfil genérico */
form button[type=submit]:not(.auth-btn):not(.geo-main-btn):not(.pro-chat-send-btn){
  background:var(--p)!important;
  color:#fff!important;
  padding:11px 22px!important;
  font-size:13px!important;
  font-weight:600!important;
  border:none!important;
  border-radius:var(--rl)!important;
  cursor:pointer!important;
  box-shadow:0 2px 8px rgba(91,91,214,.28)!important;
  transition:all var(--t)!important;
}
form button[type=submit]:not(.auth-btn):not(.geo-main-btn):not(.pro-chat-send-btn):hover{
  background:var(--p2)!important;
  transform:translateY(-2px)!important;
}

/* ── MATCHES MOBILE: cards más visuales ── */
@media(max-width:700px){
  .matches-lite-panel{border-radius:var(--rx)!important}
  .match-lite-row,.match-card{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
    gap:12px!important;
    padding:13px 14px!important;
  }
  .match-avatar-button img{
    width:48px!important;height:48px!important;
    border-radius:50%!important;/* círculo limpio en mobile */
    border:2px solid var(--b)!important;
  }
  .match-lite-info{flex:1!important;min-width:0!important}
  .match-lite-top{flex-wrap:nowrap!important;gap:4px!important}
  .match-lite-top h3{
    font-size:14px!important;font-weight:700!important;
    white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;
    max-width:160px!important;
  }
  .match-lite-top span{font-size:10px!important;flex-shrink:0!important}
  .match-lite-info strong{font-size:12px!important;color:var(--t2)!important;display:block!important}
  .match-lite-info p{font-size:11px!important;color:var(--t3)!important;
    white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}
  .match-lite-right,.match-arrow{display:flex!important}
  .match-arrow{
    width:28px!important;height:28px!important;
    background:var(--s2)!important;border:1px solid var(--b)!important;
    border-radius:50%!important;display:grid!important;place-items:center!important;
    color:var(--t3)!important;font-size:13px!important;flex-shrink:0!important;
    transition:all var(--t)!important;
  }
  .match-lite-row:hover .match-arrow,.match-card:hover .match-arrow{
    background:var(--p)!important;border-color:var(--p)!important;color:#fff!important;
  }

  /* Header de matches más visual */
  .matches-lite-hero{
    background:var(--s)!important;
    border:1px solid var(--b)!important;
    border-radius:var(--rx)!important;
    padding:14px!important;
    margin-bottom:10px!important;
    box-shadow:var(--sh)!important;
  }
  .matches-lite-hero h1{font-size:17px!important;margin-bottom:3px!important}
  .matches-lite-refresh,.mlr{
    width:100%!important;
    justify-content:center!important;
    padding:11px!important;
    font-size:13px!important;
    border-radius:var(--rl)!important;
    margin-top:8px!important;
  }
}

/* ── MODAL MATCH MOBILE: sube de abajo, con hero ── */
@media(max-width:700px){
  .match-modal-overlay{
    align-items:flex-end!important;
    padding:0!important;
  }
  .match-modal-card{
    border-radius:22px 22px 0 0!important;
    max-height:88svh!important;
    width:100%!important;
    max-width:100%!important;
    animation:modalUpMobile .22s ease!important;
  }
  @keyframes modalUpMobile{from{transform:translateY(100%);opacity:.5}to{transform:translateY(0);opacity:1}}
  .match-modal-hero-banner{border-radius:22px 22px 0 0!important;padding:18px!important}
  .match-modal-hero-banner img{width:42px!important;height:42px!important}
  .match-modal-hero-banner h2{font-size:15px!important}
  .match-modal-card .hm-v58-actions,.match-modal-card .hm-ai-actions,.match-modal-card .match-modal-actions{
    flex-direction:column!important;padding-bottom:28px!important;
  }
  .match-modal-card .hm-v58-actions .db,.match-modal-card .hm-ai-actions .db,
  .match-modal-card .match-modal-actions .db,
  .match-modal-card .hm-v58-actions .dash-btn,.match-modal-card .match-modal-actions .dash-btn{
    width:100%!important;padding:12px!important;font-size:14px!important;justify-content:center!important;
  }
}

/* ── CHAT MOBILE: input y botón enviar ── */
@media(max-width:700px){
  .pro-chat-shell{height:calc(100svh - 52px)!important}
  .pro-chat-header{padding:8px 12px!important}
  .pro-chat-messages,.chat-box{padding:12px 10px!important}

  /* Fix botón enviar que se superpone */
  .pro-chat-form{
    padding:8px 10px!important;
    gap:8px!important;
    align-items:center!important;
    background:var(--s)!important;
    border-top:1px solid var(--b)!important;
    display:flex!important;
  }
  .pro-chat-input-wrap{
    flex:1!important;
    background:var(--s2)!important;
    border:1px solid var(--b2)!important;
    border-radius:22px!important;
    padding:4px 14px!important;
    min-width:0!important;
  }
  .pro-chat-form textarea{
    min-height:34px!important;
    max-height:80px!important;
    font-size:14px!important;
    width:100%!important;
    background:transparent!important;
    border:none!important;
    border-radius:0!important;
    padding:8px 0!important;
    box-shadow:none!important;
    resize:none!important;
    outline:none!important;
  }
  .pro-chat-send-btn,
  .pro-chat-form .btn,
  .pro-chat-form button[type=submit]{
    width:42px!important;height:42px!important;
    border-radius:50%!important;padding:0!important;
    background:var(--a)!important;color:#fff!important;
    border:none!important;flex-shrink:0!important;
    display:grid!important;place-items:center!important;
    font-size:16px!important;
    box-shadow:0 4px 12px rgba(16,185,129,.4)!important;
    min-width:42px!important;max-width:42px!important;
  }
  /* Burbujas mobile más anchas */
  .pro-msg-bubble,.msg{max-width:82%!important;font-size:14px!important}
}

/* ── DRAWER MOBILE: mejorado ── */
.mob-pnl{background:var(--s)!important}
.mob-top{
  padding:14px 14px 12px!important;
  background:var(--grad)!important;
  border-bottom:none!important;
}
.mob-top .sb-logo strong{color:#fff!important;font-size:13px!important;font-weight:800!important}
.mob-top .sb-logo small{color:rgba(255,255,255,.65)!important}
.mob-top .sb-icon{background:rgba(255,255,255,.2)!important;color:#fff!important}
.mob-x{background:rgba(255,255,255,.2)!important;border:none!important;color:#fff!important;width:28px!important;height:28px!important}
/* Links del drawer más grandes en mobile */
.mob-pnl .sb-a{font-size:14px!important;padding:11px 14px!important;margin:2px 10px!important;border-radius:var(--rx)!important}
.mob-pnl .sb-a .ic{width:18px!important}
.mob-pnl .sb-a .ic svg{width:16px!important;height:16px!important}
.mob-pnl .sb-sec{font-size:10px!important;padding:14px 18px 5px!important}
.mob-pnl .sb-foot{padding:10px 10px 16px!important}
.mob-pnl .sb-a[href="/salir"]{
  color:var(--err)!important;
}
.mob-pnl .sb-a[href="/salir"]:hover{
  background:rgba(239,68,68,.08)!important;
}

/* ── TOPBAR MOBILE: logo a la izquierda visible ── */
@media(max-width:900px){
  .tb-ham{display:grid!important;width:32px!important;height:32px!important}
  .tb-brand{display:flex!important}
  .hn-top{padding:0 12px!important}
  .tb-uname{display:none!important}/* solo avatar en mobile */
  .tb-user{padding:4px 6px!important}
}

/* ── DASHBOARD MOBILE: cards más compactas ── */
@media(max-width:560px){
  .dashboard-welcome-card,.dashboard-welcome-clean{padding:16px!important;border-radius:var(--rx)!important}
  .dashboard-user-block h1{font-size:16px!important}
  .dashboard-user-block{gap:10px!important;margin-bottom:12px!important}
  .dashboard-avatar{width:40px!important;height:40px!important}
  .dashboard-actions{gap:7px!important}
  .dashboard-actions .db,.dashboard-actions .dash-btn{
    font-size:11px!important;padding:8px 14px!important;
    border-radius:var(--rp)!important;
  }
  .dashboard-grid,.dashboard-grid-clean{
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  .dashboard-card{padding:13px!important;border-radius:var(--rx)!important}
  .metric-icon{width:30px!important;height:30px!important;font-size:15px!important}
  .dash-card-label{font-size:8px!important}
  .dash-number{font-size:18px!important}
  .dashboard-card::after{font-size:12px!important;bottom:8px!important;right:10px!important}
}

/* ── PERFIL MOBILE ── */
@media(max-width:700px){
  .profile-hero{
    flex-direction:column!important;
    align-items:flex-start!important;
    padding:16px!important;
    border-radius:var(--rx)!important;
    gap:12px!important;
  }
  .profile-score-card{width:100%!important;min-width:0!important}
  .profile-hero-avatar{width:52px!important;height:52px!important}
  .profile-hero h1{font-size:17px!important}
  .profile-card-pro{padding:16px!important;border-radius:var(--rx)!important}
  .profile-upload-clean{grid-template-columns:1fr!important;gap:8px!important}
}

/* ── GENERAL MOBILE ── */
@media(max-width:700px){
  .hn-body{padding:12px 12px 50px!important}
  .card,.acl{padding:14px!important;border-radius:var(--rx)!important}
}

/* ============================================================
   FIX v8.2 — botón guardar, input chat, safe-area modal
   ============================================================ */

/* ── Botón "Guardar perfil": ícono + efecto al guardar ── */
.btn-guardar-perfil{position:relative;transition:transform .12s ease,box-shadow .2s ease,opacity .2s ease}
.btn-guardar-perfil:active{transform:scale(.97)}
.btn-guardar-perfil .ico-save{flex-shrink:0}
.btn-guardar-perfil.is-loading{pointer-events:none;opacity:.9}
.btn-guardar-perfil.is-loading .ico-save,
.btn-guardar-perfil.is-loading .btn-label{visibility:hidden}
.btn-guardar-perfil.is-loading::after{
  content:"";position:absolute;top:50%;left:50%;
  width:18px;height:18px;margin:-9px 0 0 -9px;
  border:2.5px solid rgba(255,255,255,.45);border-top-color:#fff;
  border-radius:50%;animation:btnspin .6s linear infinite;
}
@keyframes btnspin{to{transform:rotate(360deg)}}

/* ── Input del chat: pill estilo WhatsApp, crece al ancho ── */
.pro-chat-form .pro-chat-input{
  flex:1;min-width:0;
  background:var(--s2);border:1px solid var(--b2);
  border-radius:22px;padding:10px 16px;
  font-size:14px;color:var(--tx);outline:none;
  transition:border-color var(--t),background var(--t);
}
.pro-chat-form .pro-chat-input:focus{border-color:var(--p);background:var(--s)}
.pro-chat-form .pro-chat-input:disabled{opacity:.6}
.pro-chat-form .pro-chat-send-btn svg{display:block;transform:translate(1px,-1px)}

/* ── Modal match: respeta el área segura del iPhone (home indicator) ── */
@media(max-width:700px){
  .match-modal-card{padding-bottom:env(safe-area-inset-bottom)!important}
  .match-modal-card .hm-v58-actions,
  .match-modal-card .hm-ai-actions,
  .match-modal-card .match-modal-actions{
    padding-bottom:calc(20px + env(safe-area-inset-bottom))!important;
  }
}

/* ── LOGIN / AUTH: fondo negro ── */
body.auth-page{background:#0B0B12!important}
body.auth-page::before{
  background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.045) 1px,transparent 0)!important;
}

/* ── FIX iOS: evitar el zoom automático al enfocar inputs en móvil ──
   iOS Safari hace zoom si el input tiene font-size < 16px. Forzamos 16px. */
@media(max-width:768px){
  input,textarea,select,
  .input,.auth-in,.pro-chat-input,
  .pro-chat-form input,.pro-chat-form textarea{
    font-size:16px!important;
  }
}

/* ===== Patrocinadores ===== */
.spon-strip{margin-top:22px;background:var(--s);border:1px solid var(--b);border-radius:var(--rl);padding:18px 20px}
.spon-strip-h{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--t3);margin-bottom:14px}
.spon-row{display:flex;flex-wrap:wrap;align-items:center;gap:12px}
.spon-logo{display:flex;align-items:center;justify-content:center;height:56px;min-width:96px;padding:8px 16px;background:#fff;border:1px solid var(--b);border-radius:12px;transition:transform .15s,box-shadow .15s}
.spon-logo:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.08)}
.spon-logo img{max-height:40px;max-width:130px;object-fit:contain;display:block}
.spon-tier{margin-top:26px}
.spon-tier-t{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.spon-tier-t::after{content:"";flex:1;height:1px;background:var(--b)}
.spon-grid{display:grid;gap:14px;justify-content:center}
.spon-grid.platino{grid-template-columns:repeat(auto-fit,minmax(220px,280px))}
.spon-grid.oro{grid-template-columns:repeat(auto-fit,minmax(160px,210px))}
.spon-grid.plata{grid-template-columns:repeat(auto-fit,minmax(120px,160px))}
.spon-card{display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--b);border-radius:16px;padding:24px 16px;transition:transform .15s,box-shadow .15s,border-color .15s;text-decoration:none}
.spon-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(0,0,0,.1);border-color:var(--p)}
.spon-card img{max-width:100%;max-height:92px;object-fit:contain}
.spon-grid.oro .spon-card{padding:20px 14px}
.spon-grid.oro .spon-card img{max-height:66px}
.spon-grid.plata .spon-card{padding:16px 12px}
.spon-grid.plata .spon-card img{max-height:48px}
@media(max-width:600px){
  .spon-grid{gap:12px}
  .spon-grid.platino{grid-template-columns:1fr}
  .spon-grid.oro{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}
  .spon-grid.plata{grid-template-columns:repeat(auto-fit,minmax(96px,1fr))}
  .spon-card img{max-height:74px}
  .spon-grid.platino .spon-card img{max-height:100px}
  .spon-grid.oro .spon-card img{max-height:60px}
  .spon-grid.plata .spon-card img{max-height:44px}
  .spon-card.has-promo img{max-height:70px}
  .spon-grid.platino .spon-card.has-promo img{max-height:88px}
  .spon-grid.oro .spon-card.has-promo img{max-height:52px}
}

/* ===== Patrocinadores: promoción ===== */
.spon-card.has-promo{flex-direction:column;gap:12px;text-align:center;justify-content:flex-start}
.spon-card.has-promo img{max-height:64px}
.spon-grid.oro .spon-card.has-promo img{max-height:54px}
.spon-grid.plata .spon-card.has-promo img{max-height:44px}
.spon-promo{font-size:14px;font-weight:700;color:var(--p);line-height:1.3}
.spon-grid.plata .spon-promo{font-size:12px}
.spon-cta{display:inline-block;background:var(--p);color:#fff;font-size:12px;font-weight:700;padding:8px 16px;border-radius:999px;margin-top:2px}
.spon-card.has-promo:hover .spon-cta{filter:brightness(1.08)}
