/* ==========================================================================
   TUNEGOCIOENCUBA.COM — CSS MAESTRO 2026
   Mobile-First, Responsive, CSS Puro, Sin librerías externas
   ========================================================================== */

/* --- VARIABLES --- */
:root {
    --primary: #0ea5e9;
    --primary-dark: #0284c7;
    --primary-light: #38bdf8;
    --primary-glow: rgba(14,165,233,0.25);
    --accent: #10b981;
    --accent-dark: #059669;
    --gradient-hero: linear-gradient(135deg, #0f172a 0%, #1e3a5f 50%, #0c4a6e 100%);
    --gradient-primary: linear-gradient(135deg, var(--primary), var(--accent));
    --text-dark: #0f172a;
    --text-mid: #475569;
    --text-light: #94a3b8;
    --text-white: #f8fafc;
    --white: #ffffff;
    --bg-page: #f1f5f9;
    --bg-card: #ffffff;
    --bg-subtle: #f8fafc;
    --border: #e2e8f0;
    --border-light: #f1f5f9;
    --shadow-sm: 0 1px 3px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 16px rgba(0,0,0,0.08);
    --shadow-lg: 0 12px 40px rgba(0,0,0,0.12);
    --shadow-xl: 0 20px 60px rgba(0,0,0,0.15);
    --shadow-glow: 0 8px 30px var(--primary-glow);
    --radius-sm: 10px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 28px;
    --radius-full: 100px;
    --transition-fast: 0.2s cubic-bezier(0.4,0,0.2,1);
    --transition-smooth: 0.35s cubic-bezier(0.4,0,0.2,1);
    --transition-bounce: 0.5s cubic-bezier(0.34,1.56,0.64,1);
}

/* --- RESET --- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:16px; scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
    font-family:'Inter',system-ui,-apple-system,sans-serif;
    background-color:var(--bg-page); color:var(--text-dark);
    line-height:1.65; -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
}
h1,h2,h3,h4,h5,h6 { font-family:'Outfit','Inter',system-ui,sans-serif; line-height:1.2; letter-spacing:-0.02em; }
a { text-decoration:none; color:inherit; transition:color var(--transition-fast),background var(--transition-fast); }
img { max-width:100%; height:auto; display:block; }
button { font-family:inherit; }

/* --- NAVBAR --- */
.navbar-pro {
    background:rgba(255,255,255,0.9);
    backdrop-filter:blur(20px) saturate(180%);
    -webkit-backdrop-filter:blur(20px) saturate(180%);
    height:65px;
    border-bottom:1px solid rgba(226,232,240,0.6);
    display:flex; align-items:center;
    position:sticky; top:0; z-index:1000;
    transition:box-shadow var(--transition-smooth);
}
.navbar-pro.scrolled { box-shadow:0 4px 30px rgba(0,0,0,0.08); }
.nav-wrapper {
    width:100%; max-width:1280px; margin:0 auto;
    padding:0 20px; display:flex; justify-content:space-between; align-items:center;
}
.nav-brand a {
    font-family:'Outfit',sans-serif; font-size:1.35rem; font-weight:800;
    letter-spacing:-0.5px; color:var(--text-dark);
    display:flex; align-items:center; gap:2px;
}
.nav-brand span {
    background:var(--gradient-primary);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
}
.nav-hamburger {
    display:none; background:none; border:none; cursor:pointer;
    padding:8px; z-index:1010; border-radius:var(--radius-sm);
    transition:background var(--transition-fast); flex-shrink:0;
}
.nav-hamburger:hover { background:var(--bg-subtle); }
.nav-hamburger .bar {
    display:block; width:22px; height:2.5px; margin:5px 0;
    background:var(--text-dark); border-radius:2px;
    transition:transform 0.3s ease, opacity 0.3s ease;
}
.nav-hamburger.active .bar:nth-child(1) { transform:translateY(7.5px) rotate(45deg); }
.nav-hamburger.active .bar:nth-child(2) { opacity:0; }
.nav-hamburger.active .bar:nth-child(3) { transform:translateY(-7.5px) rotate(-45deg); }

.nav-actions { display:flex; align-items:center; gap:6px; }
.nav-divider { width:1px; height:22px; background:var(--border); margin:0 4px; }

.nav-btn-flat {
    color:var(--text-mid); font-weight:600; font-size:0.875rem;
    padding:8px 14px; border-radius:var(--radius-sm);
    transition:all var(--transition-fast);
}
.nav-btn-flat:hover { color:var(--text-dark); background:var(--bg-subtle); }
.nav-btn-primary {
    background:var(--gradient-primary); color:var(--white);
    padding:9px 22px; border-radius:var(--radius-full);
    font-weight:700; font-size:0.875rem;
    box-shadow:var(--shadow-glow);
    transition:transform var(--transition-fast), box-shadow var(--transition-fast);
}
.nav-btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 35px var(--primary-glow); }
.nav-btn-social {
    color:var(--text-mid); font-weight:600; font-size:0.85rem;
    display:flex; align-items:center; gap:6px;
    padding:8px 14px; border-radius:var(--radius-sm);
    transition:all var(--transition-fast);
}
.nav-btn-social:hover { color:var(--text-dark); background:var(--bg-subtle); }
.nav-btn-publish {
    background:var(--gradient-primary) !important; color:#ffffff !important;
    border-radius:var(--radius-full); padding:9px 18px;
    box-shadow:var(--shadow-glow);
    font-weight:700;
}
/* Hover explícito: mantiene gradiente y texto blanco — no heredar de nav-btn-social:hover */
.nav-btn-publish:hover,
.nav-btn-publish:focus {
    background:linear-gradient(135deg,#0284c7,#059669) !important;
    color:#ffffff !important;
    transform:translateY(-2px);
    box-shadow:0 12px 35px var(--primary-glow) !important;
}
.nav-btn-admin {
    background:linear-gradient(135deg,#4f46e5,#7c3aed) !important; color:#ffffff !important;
    border-radius:var(--radius-full); padding:9px 18px;
    box-shadow:0 8px 30px rgba(79,70,229,0.25);
}
.nav-btn-admin:hover,
.nav-btn-admin:focus {
    background:linear-gradient(135deg,#4338ca,#6d28d9) !important;
    color:#ffffff !important;
    transform:translateY(-2px);
    box-shadow:0 12px 35px rgba(79,70,229,0.35) !important;
}
.nav-btn-exit {
    color:#ef4444; font-weight:600; font-size:0.85rem;
    display:flex; align-items:center; gap:6px;
    padding:8px 12px; border-radius:var(--radius-sm);
    transition:all var(--transition-fast);
}
.nav-btn-exit:hover { background:#fef2f2; color:#dc2626; }

/* Mobile nav */
@media (max-width:768px) {
    .nav-hamburger { display:block; }
    .nav-actions {
        display:none; flex-direction:column; align-items:stretch;
        position:fixed; top:65px; left:0; right:0;
        background:rgba(255,255,255,0.97);
        backdrop-filter:blur(20px);
        padding:12px 16px 20px;
        border-bottom:1px solid var(--border-light);
        box-shadow:var(--shadow-lg);
        gap:4px; z-index:999;
    }
    .nav-actions.active { display:flex; }
    .nav-btn-flat, .nav-btn-social, .nav-btn-exit { padding:12px 16px; border-radius:10px; }
    .nav-btn-primary, .nav-btn-publish, .nav-btn-admin {
        padding:12px 20px; text-align:center; justify-content:center;
    }
    .nav-divider { display:none; }
}

/* --- HERO --- */
.hero {
    position:relative; padding:70px 20px 60px;
    text-align:center; background:var(--gradient-hero); overflow:hidden;
}
.hero::before {
    content:''; position:absolute; top:-50%; left:-50%;
    width:200%; height:200%;
    background:radial-gradient(circle at 30% 50%, rgba(14,165,233,0.15) 0%, transparent 50%),
                radial-gradient(circle at 70% 60%, rgba(16,185,129,0.1) 0%, transparent 40%);
    animation:heroShimmer 15s ease-in-out infinite alternate;
}
.hero::after {
    content:''; position:absolute; bottom:0; left:0; right:0; height:70px;
    background:linear-gradient(to top, var(--bg-page), transparent);
    pointer-events:none;
}
@keyframes heroShimmer { 0%{transform:translate(0,0) scale(1);} 100%{transform:translate(-5%,3%) scale(1.1);} }
.hero h1 {
    position:relative; z-index:1;
    font-size:clamp(1.7rem,5vw,2.8rem); font-weight:800;
    color:var(--text-white); margin-bottom:12px;
    max-width:700px; margin-left:auto; margin-right:auto;
}
.hero h1 em {
    font-style:normal; background:var(--gradient-primary);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-subtitle {
    position:relative; z-index:1; color:var(--text-light);
    font-size:clamp(0.9rem,2.5vw,1.1rem); margin-bottom:28px;
    max-width:480px; margin-left:auto; margin-right:auto;
}
.search-container {
    position:relative; z-index:1; max-width:560px; margin:0 auto;
    display:flex; flex-wrap:wrap; gap:6px;
    background:rgba(255,255,255,0.12); backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,0.18); border-radius:var(--radius-full);
    padding:6px; box-shadow:0 8px 32px rgba(0,0,0,0.2);
    transition:border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.search-container:focus-within {
    border-color:rgba(14,165,233,0.5);
    box-shadow:0 8px 32px rgba(0,0,0,0.2),0 0 0 3px var(--primary-glow);
}
.search-input {
    flex:1; border:none; padding:13px 20px; outline:none;
    font-size:1rem; background:transparent; color:var(--text-white);
    min-width:150px; font-family:'Inter',sans-serif;
}
.search-input::placeholder { color:rgba(148,163,184,0.7); }
.search-btn {
    background:var(--gradient-primary); color:var(--white);
    border:none; padding:13px 24px; border-radius:var(--radius-full);
    cursor:pointer; font-weight:700; font-size:0.9rem;
    white-space:nowrap; transition:transform var(--transition-fast),box-shadow var(--transition-fast);
}
.search-btn:hover { transform:scale(1.03); box-shadow:var(--shadow-glow); }
.hero-categories {
    position:relative; z-index:1;
    display:flex; flex-wrap:wrap; justify-content:center; gap:8px; margin-top:22px;
}
.hero-cat-chip {
    display:inline-flex; align-items:center; gap:5px;
    padding:7px 14px; border-radius:var(--radius-full);
    background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.12);
    color:rgba(248,250,252,0.85); font-size:0.8rem; font-weight:500;
    transition:all var(--transition-fast); cursor:pointer; backdrop-filter:blur(8px);
}
.hero-cat-chip:hover { background:rgba(255,255,255,0.18); color:var(--text-white); transform:translateY(-1px); }

/* --- CONTAINER --- */
.container { max-width:1280px; margin:0 auto; padding:36px 20px; }
.main-wrapper { min-height:calc(100vh - 65px); }
.section-title { font-size:clamp(1.2rem,3.5vw,1.6rem); font-weight:800; margin-bottom:6px; color:var(--text-dark); }
.section-subtitle { font-size:0.9rem; color:var(--text-light); margin-bottom:24px; }

/* --- GRID DE NEGOCIOS --- */
.grid-negocios {
    display:grid;
    grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
    gap:20px;
}
.card {
    text-decoration:none; color:inherit; display:flex; flex-direction:column;
    background:var(--bg-card); border-radius:var(--radius-lg); overflow:hidden;
    border:1px solid var(--border-light);
    transition:transform var(--transition-smooth),box-shadow var(--transition-smooth),border-color var(--transition-smooth);
}
.card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--border); }
.card-img-container, .card-img-placeholder {
    width:100%; aspect-ratio:4/3;
    background-color:var(--bg-subtle); overflow:hidden;
    display:flex; align-items:center; justify-content:center;
}
.card-img-container img { width:100%; height:100%; object-fit:cover; transition:transform var(--transition-smooth); }
.card:hover .card-img-container img { transform:scale(1.06); }
.card-img-placeholder { color:var(--text-light); font-size:2rem; }
.card-info { padding:14px 16px 16px; display:flex; flex-direction:column; gap:6px; flex:1; }
.card-title { font-size:0.95rem; font-weight:700; color:var(--text-dark); }
.card-category { font-size:0.8rem; color:var(--text-light); display:flex; align-items:center; gap:5px; }
.card-plan {
    display:inline-flex; align-items:center; gap:4px;
    font-size:0.72rem; font-weight:600;
    padding:3px 10px; border-radius:var(--radius-full);
    background:var(--bg-subtle); color:var(--text-light);
    align-self:flex-start; margin-top:auto;
}
.card-plan-premium { background:var(--gradient-primary); color:var(--white); box-shadow:var(--shadow-glow); }

/* --- EMPTY STATE --- */
.empty-state {
    grid-column:1/-1; text-align:center; padding:60px 20px;
    color:var(--text-light);
}
.empty-state i { font-size:3rem; margin-bottom:12px; display:block; }
.empty-text { color:var(--text-light); font-size:0.9rem; padding:8px 0; }

/* --- BARRA DE ESTADO DE BÚSQUEDA --- */
.busqueda-status {
    margin-bottom:18px; animation:fadeInUp 0.3s ease both;
}
.busqueda-status-inner {
    display:inline-flex; align-items:center; gap:10px;
    background:rgba(14,165,233,0.09); border:1px solid rgba(14,165,233,0.25);
    border-radius:var(--radius-full); padding:9px 18px;
    font-size:0.875rem; color:var(--text-mid); flex-wrap:wrap;
}
.busqueda-status-inner i { color:var(--primary); }
.busqueda-limpiar {
    background:none; border:none; color:var(--primary); font-weight:600;
    font-size:0.82rem; cursor:pointer; padding:2px 8px; border-radius:var(--radius-full);
    transition:background var(--transition-fast); display:inline-flex; align-items:center; gap:4px;
    font-family:'Inter',sans-serif;
}
.busqueda-limpiar:hover { background:rgba(14,165,233,0.12); }

/* --- SIN RESULTADOS --- */
.sin-resultados {
    flex-direction:column; align-items:center; justify-content:center;
    padding:60px 20px; text-align:center; color:var(--text-light);
    animation:fadeInUp 0.35s ease both;
}
.sin-resultados i { font-size:2.8rem; margin-bottom:14px; color:var(--text-light); }
.sin-resultados h3 { font-family:'Outfit',sans-serif; font-size:1.2rem; font-weight:700; color:var(--text-mid); margin-bottom:6px; }
.sin-resultados p { font-size:0.875rem; color:var(--text-light); max-width:320px; line-height:1.5; }
.btn-primary-solo {
    display:inline-flex; align-items:center; gap:7px;
    background:var(--gradient-primary); color:#fff;
    padding:11px 24px; border-radius:var(--radius-full);
    font-weight:700; font-size:0.9rem; box-shadow:var(--shadow-glow);
    transition:transform var(--transition-fast),box-shadow var(--transition-fast);
    text-decoration:none; margin-top:12px;
}
.btn-primary-solo:hover { transform:translateY(-2px); box-shadow:0 12px 35px var(--primary-glow); }

/* --- MESSAGES / TOASTS --- */
.messages-container {
    position:fixed; top:75px; right:16px; z-index:9000;
    display:flex; flex-direction:column; gap:10px; max-width:340px; width:calc(100% - 32px);
}
.toast {
    display:flex; align-items:center; gap:10px;
    padding:14px 18px; border-radius:var(--radius-md);
    background:var(--white); box-shadow:var(--shadow-lg);
    border-left:4px solid var(--primary);
    font-size:0.875rem; font-weight:500; color:var(--text-dark);
    transition:opacity 0.4s ease, transform 0.4s ease;
    animation:toastIn 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.toast-success { border-left-color: var(--accent); }
.toast-error { border-left-color: #ef4444; }
.toast-warning { border-left-color: #f59e0b; }
@keyframes toastIn { from{opacity:0;transform:translateX(40px);} to{opacity:1;transform:translateX(0);} }

/* --- FOOTER --- */
.site-footer {
    background:var(--text-dark); color:rgba(255,255,255,0.7);
    padding:40px 20px 24px; margin-top:auto;
}
.footer-inner { max-width:1280px; margin:0 auto; text-align:center; }
.footer-logo { font-family:'Outfit',sans-serif; font-size:1.3rem; font-weight:800; color:#fff; display:block; margin-bottom:8px; }
.footer-logo em { font-style:normal; background:var(--gradient-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.footer-inner p { font-size:0.85rem; margin-bottom:16px; }
.footer-links { display:flex; justify-content:center; gap:20px; flex-wrap:wrap; margin-bottom:20px; }
.footer-links a { font-size:0.85rem; font-weight:500; color:rgba(255,255,255,0.6); transition:color var(--transition-fast); }
.footer-links a:hover { color:#fff; }
.footer-copy { font-size:0.78rem; color:rgba(255,255,255,0.35); margin-top:12px; }

/* --- AUTH FORMS --- */
.login-section {
    min-height:calc(100vh - 65px - 140px);
    display:flex; align-items:center; justify-content:center;
    padding:32px 16px;
}
.auth-container {
    background:var(--bg-card); border-radius:var(--radius-xl);
    padding:clamp(24px,5vw,40px); border:1px solid var(--border-light);
    box-shadow:var(--shadow-lg); width:100%; max-width:460px;
    text-align:center;
}
.auth-logo {
    width:64px; height:64px; border-radius:50%;
    background:var(--gradient-primary); color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size:1.4rem; margin:0 auto 16px;
    box-shadow:var(--shadow-glow);
}
.auth-container h2 { font-size:clamp(1.3rem,4vw,1.6rem); font-weight:800; color:var(--text-dark); margin-bottom:6px; }
.auth-container p { font-size:0.875rem; color:var(--text-light); margin-bottom:24px; }
.auth-form { text-align:left; }
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-weight:600; font-size:0.82rem; color:var(--text-mid); margin-bottom:5px; }
.login-input {
    width:100%; padding:12px 14px; border:1.5px solid var(--border);
    border-radius:var(--radius-sm); font-size:0.9rem;
    font-family:'Inter',sans-serif; background:var(--bg-subtle);
    color:var(--text-dark); transition:all var(--transition-fast); outline:none;
    -webkit-appearance:none; appearance:none;
}
.login-input:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-glow); background:#fff; }
.field-hint { font-size:0.76rem; color:var(--text-light); margin-top:4px; display:block; }
.form-error { font-size:0.8rem; color:#ef4444; margin-top:4px; display:block; }
.form-error-box {
    display:flex; align-items:center; gap:8px;
    background:#fef2f2; border:1px solid #fecaca;
    color:#dc2626; padding:10px 14px; border-radius:var(--radius-sm);
    font-size:0.85rem; margin-bottom:14px; text-align:left;
}
.auth-btn {
    width:100%; padding:14px; background:var(--gradient-primary);
    color:#fff; border:none; border-radius:var(--radius-full);
    font-weight:700; font-size:0.95rem; cursor:pointer;
    display:flex; align-items:center; justify-content:center; gap:8px;
    box-shadow:var(--shadow-glow); margin-top:20px;
    transition:transform var(--transition-fast), box-shadow var(--transition-fast);
}
.auth-btn:hover { transform:translateY(-2px); box-shadow:0 14px 40px var(--primary-glow); }
.auth-links { margin-top:20px; font-size:0.875rem; color:var(--text-light); }
.auth-links a { color:var(--primary); font-weight:600; }

/* --- SELECTION GRID (registro tipo) --- */
.selection-grid {
    display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
    gap:16px; margin-top:20px; text-align:left;
}
.select-card {
    background:#ffffff; border-radius:var(--radius-lg);
    padding:24px; border:2px solid var(--border-light);
    display:flex; flex-direction:column; gap:12px;
    text-decoration:none !important;
    color:var(--text-dark) !important;
    transition:all var(--transition-smooth); position:relative;
}
.select-card:not(.blocked):hover {
    border-color:var(--primary); transform:translateY(-4px);
    box-shadow:var(--shadow-lg);
    color:var(--text-dark) !important;
}
.select-card.blocked { opacity:0.65; cursor:not-allowed; }
.select-icon {
    font-size:2.4rem; color:var(--primary);
    line-height:1; display:block;
}
.select-card.blocked .select-icon { color:var(--text-light); }
.select-body { display:flex; flex-direction:column; gap:8px; }
.select-body h3 {
    font-size:1.1rem; font-weight:700;
    color:var(--text-dark) !important; margin-bottom:2px;
}
.select-body > p,
.select-body p {
    font-size:0.85rem; color:var(--text-mid) !important;
    line-height:1.55; margin:0;
}
.btn-select {
    display:inline-flex; align-items:center; justify-content:center;
    background:var(--gradient-primary) !important; color:#ffffff !important;
    padding:11px 20px; border-radius:var(--radius-full);
    font-weight:700; font-size:0.85rem; margin-top:4px;
    transition:all var(--transition-fast); border:none; text-decoration:none !important;
    align-self:flex-start;
}
.btn-select:hover { opacity:0.9; color:#ffffff !important; }
.btn-select.disabled {
    background:#e2e8f0 !important; color:var(--text-light) !important;
    cursor:not-allowed;
}
.badge-coming {
    position:absolute; top:12px; right:12px;
    background:#f59e0b; color:#fff !important; font-size:0.68rem;
    font-weight:700; padding:3px 8px; border-radius:var(--radius-full);
}

/* --- VALIDATED INPUT --- */
.input-validated { position:relative; }
.input-validated .login-input { padding-right:38px; }
.val-icon {
    position:absolute; right:12px; top:50%; transform:translateY(-50%);
    font-size:0.9rem; pointer-events:none;
}

/* --- AUTOCOMPLETE --- */
.autocomplete-wrapper { position:relative; }
.autocomplete-list {
    position:absolute; top:100%; left:0; right:0;
    background:#fff; border:1px solid var(--border);
    border-radius:var(--radius-sm); box-shadow:var(--shadow-md);
    list-style:none; z-index:500; max-height:200px; overflow-y:auto;
    display:none; margin-top:4px;
}
.autocomplete-list li {
    padding:10px 14px; font-size:0.875rem; cursor:pointer;
    transition:background var(--transition-fast);
}
.autocomplete-list li:hover { background:rgba(14,165,233,0.07); color:var(--primary); }

/* --- CHECKBOX GROUP --- */
.checkbox-group { margin-bottom:16px; }
.checkbox-label {
    display:flex; align-items:flex-start; gap:10px;
    font-size:0.875rem; color:var(--text-mid); cursor:pointer; line-height:1.5;
}
.checkbox-label input[type="checkbox"] { margin-top:2px; accent-color:var(--primary); width:16px; height:16px; flex-shrink:0; }

/* --- SOCIAL / PERFIL --- */
.social-wrapper { max-width:700px; margin:0 auto; padding:24px 16px; display:flex; flex-direction:column; gap:18px; }
.profile-card-pro {
    background:var(--bg-card); border-radius:var(--radius-xl);
    border:1px solid var(--border-light); overflow:hidden;
    box-shadow:var(--shadow-sm);
}
.profile-cover-gradient {
    height:90px;
    background:var(--gradient-hero);
}
.profile-avatar-section {
    display:flex; align-items:flex-start; gap:14px;
    padding:0 20px 20px; flex-wrap:wrap;
    margin-top:-36px;
}
.avatar-editor-pro { position:relative; flex-shrink:0; }
.profile-avatar-img {
    width:80px; height:80px; border-radius:50%;
    object-fit:cover; border:3px solid var(--white);
    box-shadow:var(--shadow-md); background:var(--bg-subtle);
}
.camera-edit-badge {
    position:absolute; bottom:2px; right:2px;
    width:26px; height:26px; border-radius:50%;
    background:var(--gradient-primary); color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size:0.7rem; cursor:pointer; box-shadow:var(--shadow-sm);
    border:2px solid #fff;
}
.profile-info-text { padding-top:40px; flex:1; min-width:0; }
.profile-info-text h1 { font-size:clamp(1.1rem,3vw,1.4rem); font-weight:800; color:var(--text-dark); }
.location-tag { font-size:0.82rem; color:var(--text-light); margin-top:4px; display:flex; align-items:center; gap:5px; }
.bio-text { font-size:0.85rem; color:var(--text-mid); margin-top:6px; line-height:1.5; }

/* Webmaster blinking */
.webmaster-name { color:var(--text-dark) !important; font-weight:800 !important; }
.webmaster-badge {
    color:var(--primary); font-size:0.78em; font-weight:700;
    animation:blink 1.4s ease-in-out infinite;
    display:inline;
}
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:0.35;} }

/* Verified check */
.verified-check { color:var(--primary); font-size:0.85em; margin-left:4px; }

/* Role / Group badges */
.perfil-roles, .perfil-grupos { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.badge-rol, .badge-grupo {
    display:inline-flex; align-items:center; gap:4px;
    padding:3px 10px; border-radius:var(--radius-full);
    font-size:0.72rem; font-weight:600; white-space:nowrap;
}
.badge-rol-webmaster { background:rgba(14,165,233,0.1); color:var(--primary); }
.badge-rol-staff { background:rgba(16,185,129,0.1); color:var(--accent); }
.badge-rol-empleado { background:rgba(139,92,246,0.1); color:#8b5cf6; }
.badge-grupo-verificado { background:var(--gradient-primary); color:#fff; }
.badge-grupo-cliente { background:var(--bg-subtle); color:var(--text-light); }
.webmaster-role-txt { animation:blink 1.4s ease-in-out infinite; }

/* Negocios mini grid */
.negocios-section-title {
    font-size:1rem; font-weight:700; color:var(--text-dark);
    display:flex; align-items:center; gap:8px; margin-bottom:14px;
}
.negocios-grid-mini { display:flex; flex-wrap:wrap; gap:12px; }
.negocio-mini-link { text-decoration:none; display:flex; flex-direction:column; align-items:center; gap:6px; width:80px; }
.negocio-mini-img-wrap {
    width:76px; height:76px; border-radius:var(--radius-md); overflow:hidden;
    position:relative; border:1px solid var(--border-light);
    background:var(--bg-subtle); display:flex; align-items:center; justify-content:center;
}
.negocio-mini-img { width:100%; height:100%; object-fit:cover; }
.negocio-mini-placeholder { font-size:1.5rem; color:var(--text-light); }
.premium-check { position:absolute; bottom:3px; right:3px; color:var(--primary); font-size:0.8rem; background:#fff; border-radius:50%; }
.negocio-mini-name { font-size:0.72rem; font-weight:600; color:var(--text-mid); text-align:center; line-height:1.3; }

/* Publish box */
.publish-box-pro { }
.publish-box-pro textarea {
    width:100%; border:1.5px solid var(--border); border-radius:var(--radius-md);
    padding:14px; font-size:0.9rem; font-family:'Inter',sans-serif;
    color:var(--text-dark); background:var(--bg-subtle);
    resize:vertical; min-height:90px; outline:none;
    transition:border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.publish-box-pro textarea:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-glow); background:#fff; }
.publish-actions-pro { display:flex; justify-content:space-between; align-items:center; margin-top:12px; flex-wrap:wrap; gap:8px; }
.btn-img-attach {
    display:flex; align-items:center; gap:6px;
    color:var(--text-mid); font-size:0.85rem; font-weight:600;
    padding:8px 14px; border-radius:var(--radius-sm);
    cursor:pointer; transition:all var(--transition-fast);
    border:1px solid var(--border); background:var(--bg-subtle);
}
.btn-img-attach:hover { color:var(--primary); border-color:var(--primary); background:rgba(14,165,233,0.05); }
.btn-submit-post {
    background:var(--gradient-primary); color:#fff;
    border:none; padding:10px 22px; border-radius:var(--radius-full);
    font-weight:700; font-size:0.875rem; cursor:pointer;
    display:flex; align-items:center; gap:6px;
    box-shadow:var(--shadow-glow); transition:all var(--transition-fast);
}
.btn-submit-post:hover { transform:translateY(-2px); box-shadow:0 12px 35px var(--primary-glow); }

/* Post card */
.post-card-pro { }
.post-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.post-author-pro { display:flex; align-items:center; gap:10px; }
.mini-avatar-img { width:38px; height:38px; border-radius:50%; object-fit:cover; border:2px solid var(--border-light); background:var(--bg-subtle); }
.author-meta-pro strong { display:block; font-size:0.875rem; font-weight:700; color:var(--text-dark); }
.author-meta-pro small { font-size:0.75rem; color:var(--text-light); }
.post-delete-btn { color:var(--text-light); font-size:0.85rem; padding:7px; border-radius:7px; transition:all var(--transition-fast); }
.post-delete-btn:hover { color:#ef4444; background:rgba(239,68,68,0.1); }
.post-body-pro p { font-size:0.9rem; color:var(--text-mid); line-height:1.6; }
.post-img-content { width:100%; border-radius:var(--radius-md); margin-top:12px; object-fit:cover; max-height:400px; }
.post-footer-pro { display:flex; gap:16px; margin-top:12px; padding-top:12px; border-top:1px solid var(--border-light); }
.action-item { font-size:0.82rem; color:var(--text-light); cursor:pointer; display:flex; align-items:center; gap:5px; transition:color var(--transition-fast); }
.action-item:hover { color:var(--primary); }
.empty-feed { text-align:center; padding:32px; color:var(--text-light); }
.empty-feed i { font-size:2rem; margin-bottom:8px; display:block; }

/* Social card */
.social-card {
    background:var(--bg-card); border-radius:var(--radius-lg);
    border:1px solid var(--border-light); padding:20px;
    box-shadow:var(--shadow-sm);
}
.feed-pro { display:flex; flex-direction:column; gap:16px; }

/* --- CREAR/PUBLICAR CARDS --- */
.crear-card { background:var(--bg-card); border-radius:var(--radius-xl); border:1px solid var(--border-light); padding:clamp(20px,4vw,36px); box-shadow:var(--shadow-sm); }
.crear-header { text-align:center; margin-bottom:24px; }
.crear-header i { font-size:2rem; color:var(--primary); display:block; margin-bottom:10px; }
.crear-header h2 { font-size:1.4rem; font-weight:800; color:var(--text-dark); margin-bottom:6px; }
.crear-header p { font-size:0.875rem; color:var(--text-light); }
.plan-info-banner {
    display:flex; align-items:flex-start; gap:10px;
    background:rgba(14,165,233,0.07); border:1px solid rgba(14,165,233,0.2);
    border-radius:var(--radius-sm); padding:12px 14px;
    font-size:0.85rem; color:var(--text-mid); margin-bottom:20px;
}
.plan-info-banner i { color:var(--primary); flex-shrink:0; margin-top:2px; }

/* --- DETALLE NEGOCIO --- */
.detalle-negocio-card { overflow:hidden; padding:0; }
.detalle-img-wrap { height:clamp(180px,40vw,300px); overflow:hidden; background:var(--bg-subtle); }
.detalle-logo { width:100%; height:100%; object-fit:cover; }
.detalle-body { padding:clamp(16px,4vw,28px); }
.detalle-header { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-bottom:8px; }
.detalle-nombre { font-size:clamp(1.2rem,4vw,1.6rem); font-weight:800; color:var(--text-dark); }
.detalle-categoria { font-size:0.85rem; color:var(--text-light); display:flex; align-items:center; gap:6px; margin-bottom:14px; }
.detalle-descripcion { font-size:0.9rem; color:var(--text-mid); line-height:1.65; margin-bottom:18px; }
.detalle-contactos { display:flex; flex-direction:column; gap:10px; margin-bottom:18px; }
.detalle-dato { display:flex; align-items:center; gap:8px; font-size:0.875rem; color:var(--text-mid); }
.btn-whatsapp {
    display:inline-flex; align-items:center; gap:8px;
    background:#25d366; color:#fff; padding:12px 22px;
    border-radius:var(--radius-full); font-weight:700; font-size:0.9rem;
    box-shadow:0 8px 24px rgba(37,211,102,0.3);
    transition:all var(--transition-fast); align-self:flex-start;
}
.btn-whatsapp:hover { transform:translateY(-2px); box-shadow:0 14px 32px rgba(37,211,102,0.4); }
/* Placeholder cuando no hay imagen */
.detalle-img-placeholder {
    height:140px; background:var(--bg-subtle);
    display:flex; align-items:center; justify-content:center;
    font-size:3rem; color:var(--text-light);
}

/* Badges de plan en el header */
.detalle-plan-badge {
    display:inline-flex; align-items:center; gap:5px;
    padding:5px 14px; border-radius:var(--radius-full);
    font-size:0.8rem; font-weight:700; white-space:nowrap; flex-shrink:0;
}
.detalle-plan-normal { background:var(--bg-subtle); color:var(--text-mid); border:1px solid var(--border); }
.detalle-plan-premium { background:var(--gradient-primary); color:#ffffff; box-shadow:var(--shadow-glow); }

/* Sección de información de planes */
.planes-info-section {
    background:var(--bg-subtle); border-radius:var(--radius-md);
    border:1px solid var(--border-light);
    padding:18px; margin-bottom:18px; margin-top:18px;
}
.planes-info-title {
    font-family:'Outfit',sans-serif; font-size:0.95rem; font-weight:700;
    color:var(--text-dark); margin-bottom:14px;
    display:flex; align-items:center; gap:7px;
}
.planes-info-title i { color:var(--primary); }
.planes-grid {
    display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
    gap:12px;
}
.plan-item {
    background:#fff; border-radius:var(--radius-sm);
    border:1.5px solid var(--border-light);
    padding:16px; display:flex; flex-direction:column; gap:10px;
    transition:border-color var(--transition-fast);
}
.plan-item-active { border-color:var(--primary); }
.plan-item-premium { border-color:rgba(14,165,233,0.25); }
.plan-item-header {
    display:flex; align-items:center; gap:7px; flex-wrap:wrap;
}
.plan-item-header i { font-size:1rem; color:var(--primary); }
.plan-item-premium .plan-item-header i { color:var(--primary); }
.plan-item-header strong { font-size:0.9rem; color:var(--text-dark); font-weight:700; }
.plan-actual-badge {
    background:rgba(14,165,233,0.12); color:var(--primary);
    font-size:0.68rem; font-weight:700; padding:2px 8px;
    border-radius:var(--radius-full); white-space:nowrap;
}
.plan-pago-badge {
    background:rgba(239,68,68,0.1); color:#ef4444;
    font-size:0.68rem; font-weight:700; padding:2px 8px;
    border-radius:var(--radius-full); white-space:nowrap;
    display:inline-flex; align-items:center; gap:3px;
}
.plan-features {
    list-style:none; display:flex; flex-direction:column; gap:5px;
}
.plan-features li {
    display:flex; align-items:center; gap:6px;
    font-size:0.8rem; color:var(--text-mid); line-height:1.4;
}
.plan-features li i { color:var(--accent); font-size:0.7rem; flex-shrink:0; }
.plan-precio {
    font-family:'Outfit',sans-serif; font-size:1rem; font-weight:800;
    color:var(--accent); margin-top:auto;
}
.btn-upgrade-full {
    background:linear-gradient(135deg,#f59e0b,#d97706); color:#ffffff !important;
    border:none; padding:10px 16px; border-radius:var(--radius-full);
    font-weight:700; font-size:0.8rem; cursor:not-allowed; opacity:0.75;
    display:inline-flex; align-items:center; gap:6px; margin-top:auto;
    font-family:'Inter',sans-serif;
}

.detalle-dueno {
    display:flex; align-items:center; gap:6px;
    font-size:0.82rem; color:var(--text-light);
    border-top:1px solid var(--border-light); padding-top:14px;
}
.detalle-dueno i { color:var(--text-light); }
.detalle-dueno a { color:var(--primary); font-weight:600; }

/* --- MANTENIMIENTO --- */
.mantenimiento-wrapper { min-height:calc(100vh - 65px - 140px); display:flex; align-items:center; justify-content:center; padding:32px 16px; }
.mantenimiento-card { background:var(--bg-card); border-radius:var(--radius-xl); padding:clamp(32px,6vw,56px); text-align:center; border:1px solid var(--border-light); box-shadow:var(--shadow-lg); max-width:480px; width:100%; }
.mantenimiento-icon { width:80px; height:80px; border-radius:50%; background:rgba(14,165,233,0.1); display:flex; align-items:center; justify-content:center; margin:0 auto 20px; font-size:2rem; color:var(--primary); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{box-shadow:0 0 0 0 rgba(14,165,233,0.4);} 50%{box-shadow:0 0 0 14px rgba(14,165,233,0);} }
.mantenimiento-card h1 { font-size:clamp(1.3rem,4vw,1.8rem); font-weight:800; color:var(--text-dark); margin-bottom:12px; }
.mantenimiento-msg { font-size:0.9rem; color:var(--text-mid); line-height:1.6; margin-bottom:24px; }
.mantenimiento-dots { display:flex; justify-content:center; gap:8px; }
.mantenimiento-dots span { width:8px; height:8px; border-radius:50%; background:var(--primary); animation:dot-bounce 1.2s ease-in-out infinite; }
.mantenimiento-dots span:nth-child(2) { animation-delay:0.2s; }
.mantenimiento-dots span:nth-child(3) { animation-delay:0.4s; }
@keyframes dot-bounce { 0%,100%{transform:translateY(0);opacity:0.6;} 50%{transform:translateY(-8px);opacity:1;} }

/* --- ANIMATIONS --- */
.animate-fadeInUp { animation:fadeInUp 0.6s cubic-bezier(0.4,0,0.2,1) both; }
.delay-100 { animation-delay:0.1s; }
.delay-200 { animation-delay:0.2s; }
.delay-300 { animation-delay:0.3s; }
@keyframes fadeInUp { from{opacity:0;transform:translateY(24px);} to{opacity:1;transform:translateY(0);} }
.reveal { opacity:0; transform:translateY(20px); transition:opacity 0.5s ease,transform 0.5s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* --- RESPONSIVE GENERAL --- */
@media (max-width:600px) {
    .grid-negocios { grid-template-columns:repeat(auto-fill, minmax(160px, 1fr)); gap:12px; }
    .selection-grid { grid-template-columns:1fr; }
    .auth-container { padding:24px 16px; }
    .social-wrapper { padding:16px 12px; }
    .profile-avatar-section { flex-wrap:wrap; }
    .profile-info-text { padding-top:0; margin-top:-24px; }
    .negocios-grid-mini { gap:10px; }
    .negocio-mini-link { width:70px; }
    .negocio-mini-img-wrap { width:66px; height:66px; }
    .search-container { flex-direction:column; border-radius:var(--radius-lg); }
    .search-input { min-width:0; }
    .search-btn { width:100%; justify-content:center; border-radius:var(--radius-md); }
    .messages-container { top:72px; right:12px; width:calc(100% - 24px); }
    .hero { padding:50px 16px 50px; }
}
@media (max-width:380px) {
    html { font-size:14px; }
    .nav-brand a { font-size:1.15rem; }
    .grid-negocios { grid-template-columns:1fr; }
}
