@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ═══════════════════════════════════════════════════════════════
   MisiónAduanas.css — CSS único para MPA
   Versión 2.0 — Rediseño Premium
   ═══════════════════════════════════════════════════════════════ */

/* ─── Design Tokens ─── */
:root,
[data-theme="light"] {
  --ma-amber-400: #fbbf24; --ma-amber-500: #f59e0b; --ma-amber-600: #d97706;
  --ma-slate-50: #f8fafc; --ma-slate-900: #0f172a; --ma-slate-950: #020617;
  --ma-accent: var(--ma-amber-500); --ma-accent-hover: var(--ma-amber-600);
  --ma-accent-glow: rgba(245,158,11,0.12);
  --ma-bg-primary: #f8fafc; --ma-bg-main: #ffffff; --ma-bg-card: rgba(255,255,255,0.7); --ma-bg-secondary: #f1f5f9;
  --ma-text-primary: #0f172a; --ma-text-main: #0f172a; --ma-text-secondary: #475569; --ma-text-muted: #64748b;
  --ma-border: rgba(0,0,0,0.06);
  --ma-glass-blur: blur(20px); --ma-glass-bg: rgba(255,255,255,0.75); --ma-glass-border: rgba(0,0,0,0.06);
  --ma-radius-sm: 0.75rem; --ma-radius-md: 1.25rem; --ma-radius-lg: 1.75rem; --ma-radius-xl: 2.5rem;
  --ma-font-sans: 'Inter', sans-serif;
  --ma-font-serif: 'Lora', Georgia, serif;
  --ma-shadow-card: 0 8px 30px rgba(0,0,0,0.04);
}
.dark,
[data-theme="dark"] {
  --ma-bg-primary: #030712; --ma-bg-main: #0b1528; --ma-bg-card: rgba(15,23,42,0.65); --ma-bg-secondary: #111827;
  --ma-text-primary: #f9fafb; --ma-text-main: #f3f4f6; --ma-text-secondary: #9ca3af; --ma-text-muted: #6b7280;
  --ma-border: rgba(255,255,255,0.06);
  --ma-accent-glow: rgba(245,158,11,0.2); --ma-glass-bg: rgba(15,23,42,0.7); --ma-glass-border: rgba(255,255,255,0.06);
  --ma-shadow-card: 0 10px 40px rgba(0,0,0,0.3);
}

/* ─── Base ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ma-font-sans);letter-spacing:0.01em;background:var(--ma-bg-primary);color:var(--ma-text-primary);display:flex;flex-direction:column;min-height:100vh;margin:0;transition:background .4s,color .4s}
h1, h2, h3, h4, h5, h6 { font-family: var(--ma-font-serif); font-weight: 700; letter-spacing: -0.02em; }
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}

/* ─── Header ─── */
header{background:var(--ma-glass-bg);border-bottom:1px solid var(--ma-border);position:sticky;top:0;z-index:9999;backdrop-filter:var(--ma-glass-blur)}
#header-tabs-container:empty { display: none !important; }
.header-nav-btn{display:flex;align-items:center;gap:4px 8px;padding:8px 12px;border-radius:12px;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:0.15em;transition:all .2s;color:var(--ma-text-primary);background:transparent;border:none;cursor:pointer;white-space:nowrap}
.header-nav-btn:hover{background:var(--ma-accent-glow);color:var(--ma-text-primary)}
.header-nav-btn.active-tab,.header-nav-btn.text-amber-500{color:var(--ma-accent);background:var(--ma-accent-glow);border-color:var(--ma-accent)}

/* ─── Dropdown menus ─── */
.nav-dropdown-group{position:relative}
#user-nav-group .dropdown-menu { left: auto; right: 0; }
.dropdown-menu{position:absolute;top:100%;left:0;margin-top:8px;width:224px;opacity:0;visibility:hidden;transition:all .3s;z-index:2147483647}
.dropdown-menu.opacity-100,.dropdown-menu.visible{opacity:1;visibility:visible}
.dropdown-menu>div{background:rgba(255,255,255,0.94);backdrop-filter:var(--ma-glass-blur);border-radius:16px;border:1px solid var(--ma-border);padding:8px;box-shadow:var(--ma-shadow-card)}
.dark .dropdown-menu>div,
[data-theme="dark"] .dropdown-menu>div{background:rgba(15,23,42,0.9)}
.dropdown-item,.mpa-nav-link{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:0.08em;transition:all .2s;color:var(--ma-text-muted);background:transparent;border:none;cursor:pointer;text-decoration:none;text-align:left}
.dropdown-item:hover,.mpa-nav-link:hover{background:var(--ma-accent-glow);color:var(--ma-accent)}
.dropdown-item.bg-amber-600,.mpa-nav-link.bg-amber-600{background:var(--ma-accent-hover);color:#fff;box-shadow:0 4px 12px var(--ma-accent-glow)}

/* ─── Footer ─── */
footer{background:var(--ma-glass-bg);border-top:1px solid var(--ma-border);padding:1.5rem 0;text-align:center;margin-top:auto}
footer p{color:var(--ma-text-muted);font-size:0.75rem;margin-bottom:.75rem}
footer a{color:var(--ma-text-muted);text-decoration:none;transition:color .2s}
footer a:hover{color:var(--ma-accent)}

/* ─── Banner Cards (portada) ─── */

/* ─── Glass Panel ─── */
.glass-panel{background:var(--ma-bg-card);backdrop-filter:var(--ma-glass-blur);border:1px solid var(--ma-border);border-radius:16px}

/* ─── Buttons ─── */
.ma-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:12px;font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.15em;border:none;cursor:pointer;transition:all .2s}
.ma-btn-primary{background:linear-gradient(135deg,var(--ma-accent),var(--ma-accent-hover));color:#000}
.ma-btn-primary:hover{transform:scale(1.02);box-shadow:0 8px 25px var(--ma-accent-glow)}
.ma-btn-glass{background:var(--ma-border);border:1px solid var(--ma-glass-border);color:var(--ma-text-secondary)}
.ma-btn-glass:hover{background:var(--ma-glass-border);color:var(--ma-text-primary)}

/* ─── Inputs ─── */
.ma-input{width:100%;background:var(--ma-bg-secondary);border:1px solid var(--ma-border);border-radius:12px;padding:14px 16px;color:var(--ma-text-primary);font-size:14px;outline:none;transition:all .2s;box-sizing:border-box}
.ma-input:focus{border-color:var(--ma-accent);box-shadow:0 0 0 3px var(--ma-accent-glow)}
.ma-input::placeholder{color:var(--ma-text-muted)}

/* ─── Forms ─── */

/* ─── Legal Pages ─── */

/* ─── Animations ─── */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes scaleIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.animate-in{animation:fadeIn .3s ease,slideUp .4s ease}
.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1)infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}

/* ─── Admin ─── */

/* ─── Auth (login) ─── */
.auth-card{max-width:420px;width:100%}
.auth-input{width:100%;background:var(--ma-bg-secondary);border:1px solid var(--ma-border);border-radius:12px;padding:14px 16px;color:var(--ma-text-primary);font-size:14px;outline:none;transition:all .2s;box-sizing:border-box}
.auth-input:focus{border-color:var(--ma-accent);box-shadow:0 0 0 3px var(--ma-accent-glow)}
.auth-input::placeholder{color:var(--ma-text-muted)}
.auth-btn{width:100%;background:linear-gradient(135deg,var(--ma-accent),var(--ma-accent-hover));color:#000;font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.15em;padding:16px;border-radius:14px;border:none;cursor:pointer;transition:all .2s}
.auth-btn:hover{transform:scale(1.02);box-shadow:0 8px 25px var(--ma-accent-glow)}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--ma-border)}
.auth-divider span{color:var(--ma-text-muted);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.2em}
.google-btn{width:100%;background:var(--ma-border);border:1px solid var(--ma-glass-border);color:var(--ma-text-primary);font-weight:700;font-size:12px;padding:14px;border-radius:12px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}
.google-btn:hover{background:var(--ma-glass-border);border-color:var(--ma-border)}
.auth-error{background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.2);color:#fca5a5;border-radius:12px;padding:12px 16px;font-size:12px;margin-bottom:16px;display:none;text-align:center}
.auth-success{background:rgba(34,197,94,0.1);border:1px solid rgba(34,197,94,0.2);color:#86efac;border-radius:12px;padding:12px 16px;font-size:12px;margin-bottom:16px;display:none;text-align:center}

/* ─── Scrollbar ─── */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--ma-accent-glow);border-radius:20px}
::-webkit-scrollbar-thumb:hover{background:var(--ma-accent)}

/* ─── Utilities ─── */
.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}
.items-center{align-items:center}.items-start{align-items:flex-start}
.justify-center{justify-content:center}.justify-between{justify-content:space-between}
.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}
.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}
.grid-cols-2{grid-template-columns:repeat(2,1fr)}
.text-center{text-align:center}
.text-white{color:var(--ma-text-primary)}.text-amber-500{color:var(--ma-accent)}.text-slate-300{color:var(--ma-text-secondary)}.text-slate-400{color:var(--ma-text-secondary)}.text-slate-500{color:var(--ma-text-muted)}.bg-amber-600{background:var(--ma-accent-hover)}
.bg-slate-900{background:var(--ma-bg-secondary)}.bg-slate-950{background:var(--ma-slate-950)}
.border{border:1px solid rgba(255,255,255,0.08)}
.rounded-2xl{border-radius:1rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}
.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}
.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}
.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}
.mx-auto{margin-left:auto;margin-right:auto}.mx-1{margin-left:.25rem;margin-right:.25rem}
.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}
.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}
.max-w-7xl{max-width:1280px}.max-w-4xl{max-width:896px}.max-w-lg{max-width:512px}.w-full{width:100%}.w-px{width:1px}
.h-6{height:1.5rem}.h-px{height:1px}
.shrink-0{flex-shrink:0}.no-underline{text-decoration:none}
.relative{position:relative}.absolute{position:absolute}.sticky{position:sticky}.top-0{top:0}.z-50{z-index:50}
.hidden{display:none !important}.block{display:block}
.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}
.cursor-pointer{cursor:pointer}.pointer-events-none{pointer-events:none}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}
.font-bold{font-weight:700}.font-black{font-weight:900}.font-medium{font-weight:500}
.uppercase{text-transform:uppercase}.tracking-widest{letter-spacing:.15em}.tracking-tighter{letter-spacing:-.05em}
.transition-all{transition:all .2s}.backdrop-blur-md{backdrop-filter:blur(12px)}
.border-b{border-bottom:1px solid var(--ma-border)}
.space-y-2>*+*{margin-top:.5rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.animate-spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
.shadow-xl{box-shadow:0 20px 60px rgba(0,0,0,0.3)}.shadow-lg{box-shadow:0 10px 40px rgba(0,0,0,0.2)}

/* --- Admin Components --- */
.premium-header {
    background: linear-gradient(135deg, var(--ma-slate-950) 0%, var(--ma-bg-secondary) 100%) !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    padding: 6rem 5rem 8rem;
    border-radius: 2rem;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    margin-bottom: 4rem; 
    position: relative;
    overflow: hidden;
    z-index: 10;
}
.premium-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 80%;
    height: 150%;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.25) 0%, transparent 70%);
    filter: blur(80px);
    pointer-events: none;
    animation: pulse-slow 10s infinite alternate;
}
.premium-header::after {
    content: '';
    position: absolute;
    bottom: -50%;
    left: -20%;
    width: 60%;
    height: 120%;
    background: radial-gradient(circle, rgba(251, 191, 36, 0.1) 0%, transparent 70%);
    filter: blur(80px);
    pointer-events: none;
}
.admin-header-badge {
    display: inline-block;
    padding: 0.6rem 1.5rem;
    background: var(--ma-border);
    color: var(--ma-accent);
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.4em;
    border-radius: 9999px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(12px);
    margin-bottom: 2.5rem;
}
.admin-page-header h1 {
    font-size: clamp(2.5rem, 8vw, 5rem);
    font-weight: 950;
    letter-spacing: -0.05em;
    color: var(--ma-text-primary);
    line-height: 0.9;
    margin-bottom: 1.5rem;
    text-transform: uppercase;
    background: linear-gradient(to bottom, #ffffff 60%, rgba(255,255,255,0.7));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 4px 12px rgba(0,0,0,0.4));
}
.admin-page-header p {
    color: var(--ma-text-secondary);
    font-size: 1.25rem;
    font-weight: 600;
    max-width: 900px;
    line-height: 1.6;
    letter-spacing: -0.01em;
}
.admin-header-premium {
    padding: 2rem 1.5rem;
    border-radius: 1.5rem;
}
.admin-card {
    background: var(--ma-bg-card);
    border: 1px solid var(--ma-border);
    border-radius: 1rem;
    padding: 2.5rem;
    box-shadow: var(--ma-shadow-card);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}
.admin-card:hover {
    border-color: var(--ma-accent);
    transform: translateY(-2px);
    box-shadow: 0 10px 30px var(--ma-accent-glow);
}
.admin-section {
    background: var(--ma-bg-card) !important;
    border: 1px solid var(--ma-border);
    border-radius: 2rem;
    margin-bottom: 2rem;
    overflow: hidden;
    box-shadow: var(--ma-shadow-card);
    transition: all 0.4s ease;
}
.admin-section:hover {
    box-shadow: 0 20px 25px -5px rgba(15, 23, 42, 0.1), 0 8px 10px -6px rgba(15, 23, 42, 0.1);
    border-color: rgba(0, 0, 0, 0.04);
}
.admin-table-container {
    overflow-x: auto;
    border-radius: 0 0 1.5rem 1.5rem;
}
.modal-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-bottom: 2.5rem;
}
.admin-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
}
.admin-table th {
    background: var(--ma-bg-secondary);
    padding: 1.5rem 2rem;
    text-align: left;
    font-weight: 950;
    text-transform: uppercase;
    font-size: 0.65rem;
    letter-spacing: 0.2em;
    color: var(--ma-text-primary);
    border-bottom: 2px solid var(--ma-accent);
    white-space: nowrap;
}
.admin-table td {
    padding: 1.25rem 2rem;
    border-bottom: 1px solid var(--ma-border);
    color: var(--ma-text-main);
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.2s ease;
}
.admin-table tr {
    background: var(--ma-bg-card);
    transition: all 0.2s ease;
}
.admin-table tr:last-child td {
    border-bottom: none;
}
.admin-table tr:hover td {
    background: var(--ma-bg-secondary) !important;
    color: var(--ma-accent) !important;
}
.stats-pill-group {
    display: inline-flex;
    align-items: center;
    gap: 0;
    background: var(--ma-bg-primary);
    border: 1px solid var(--ma-border);
    border-radius: 12px;
    padding: 2px;
    width: fit-content;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.02);
}
.stats-pill-item {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.75rem;
    font-weight: 850;
    padding: 4px 10px;
    color: var(--ma-text-main);
}
.stats-pill-item.score {
    font-weight: 950;
    font-family: 'Outfit', sans-serif;
}
.stats-pill-divider {
    width: 1px;
    height: 14px;
    background: var(--ma-border);
    opacity: 0.5;
}
.admin-table td strong {
    font-weight: 950;
    color: var(--ma-text-main) !important;
}
.premium-header {
    background: linear-gradient(135deg, var(--ma-slate-950) 0%, var(--ma-bg-secondary) 50%, var(--ma-slate-950) 100%);
    padding: 4rem 3rem;
    border-radius: 2rem;
    margin-bottom: 3rem;
    position: relative;
    overflow: hidden;
    box-shadow: 0 20px 25px -5px rgba(15, 23, 42, 0.1), 0 8px 10px -6px rgba(15, 23, 42, 0.1);
    border: 1px solid rgba(0, 0, 0, 0.08);
}
.premium-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -25%;
    width: 80%;
    height: 150%;
    background: radial-gradient(circle, rgba(59, 130, 246, 0.2) 0%, transparent 70%);
    filter: blur(80px);
    pointer-events: none;
    animation: pulse-slow 8s infinite alternate;
}
.premium-header .header-badge {
    display: inline-block;
    padding: 0.5rem 1.5rem;
    background: var(--ma-border);
    color: var(--ma-accent);
    font-size: 0.65rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.3em;
    border-radius: 9999px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    margin-bottom: 2rem;
    backdrop-filter: blur(10px);
}
.premium-header h1 {
    font-size: 4.5rem;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 1rem;
}
.premium-header {
    background: linear-gradient(135deg, var(--ma-slate-950) 0%, var(--ma-bg-secondary) 100%);
    color: var(--ma-text-primary);
    padding: 4rem 3.5rem 5rem;
    border-radius: 2rem;
    position: relative;
    overflow: hidden;
    margin-bottom: 4rem;
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 20px 25px -5px rgba(15, 23, 42, 0.1), 0 8px 10px -6px rgba(15, 23, 42, 0.1);
}
.premium-header h1 {
    font-size: 3.5rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.05em;
    margin-bottom: 1rem;
}
.premium-header p {
    color: var(--ma-text-secondary);
    font-size: 1.1rem;
    font-weight: 500;
    max-width: 700px;
    line-height: 1.6;
}
.activity-item {
    display: flex;
    gap: 1.25rem;
    padding: 1rem;
    border-radius: 1.25rem;
    background: var(--ma-bg-secondary);
    border: 1px solid var(--ma-border);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    position: relative;
    overflow: hidden;
}
.activity-item:hover {
    transform: translateX(4px);
    background: var(--ma-bg-card);
    border-color: var(--ma-accent);
    box-shadow: 0 1px 3px 0 rgba(15, 23, 42, 0.05);
}
.activity-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: transparent;
    transition: all 0.3s ease;
}
.activity-item:hover::before {
    background: var(--ma-accent);
}
.activity-content {
    flex: 1;
    min-width: 0;
}
.activity-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.25rem;
}
.activity-time {
    font-size: 0.625rem;
    font-weight: 700;
    color: var(--ma-text-muted);
    font-family: monospace;
}

/* --- Tailwind Utilities (purged) --- */
.fixed{position:fixed}.inset-0{inset:0}.top-full{top:100%}.right-0{right:0}.left-0{left:0}.bottom-0{bottom:0}.right-4{right:1rem}
.flex-grow{flex:1}
.bg-white{background:#fff}.bg-slate-200{background:#e2e8f0}.bg-slate-800{background:var(--ma-bg-secondary)}.bg-blue-50{background:#eff6ff}
.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-amber-500{--tw-gradient-from:var(--ma-accent)}.to-orange-600{--tw-gradient-to:#ea580c}
.border-slate-100{border-color:#f1f5f9}.border-slate-200{border-color:#f1f5f9}.border-slate-800{border-color:var(--ma-bg-secondary)}.border-blue-100{border-color:#dbeafe}
.duration-300{transition-duration:.3s}.duration-400{transition-duration:.4s}.duration-700{transition-duration:.7s}.duration-1000{transition-duration:1s}
.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-20{height:5rem}.h-24{height:6rem}.h-48{height:12rem}.h-64{height:16rem}.h-full{height:100%}.min-h-screen{min-height:100vh}
.w-3{width:.75rem}.w-5{width:1.25rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-20{width:5rem}.w-24{width:6rem}.w-48{width:12rem}.w-56{width:14rem}.w-64{width:16rem}.max-w-2xl{max-width:672px}.max-w-3xl{max-width:768px}.max-w-5xl{max-width:1024px}.max-w-sm{max-width:384px}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.mt-8{margin-top:2rem}.mt-20{margin-top:5rem}.mb-1{margin-bottom:.25rem}.mb-10{margin-bottom:2.5rem}.mb-16{margin-bottom:4rem}
.p-1{padding:.25rem}.p-5{padding:1.25rem}.p-10{padding:2.5rem}.p-12{padding:3rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-8{padding-left:2rem;padding-right:2rem}.px-12{padding-left:3rem;padding-right:3rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}
.gap-5{gap:1.25rem}
.leading-none{line-height:1}.leading-tight{line-height:1.25}
.text-4xl{font-size:2.25rem}.text-5xl{font-size:3rem}
.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.opacity-100{opacity:1}
.visible{visibility:visible}.invisible{visibility:hidden}
.object-contain{-o-object-fit:contain;object-fit:contain}
.rotate-3{transform:rotate(3deg)}
.scale-95{transform:scale(.95)}.scale-105{transform:scale(1.05)}
.shadow-2xl{box-shadow:0 25px 50px rgba(0,0,0,0.25)}.shadow-inner{box-shadow:inset 0 2px 4px rgba(0,0,0,0.05)}.blur-3xl{filter:blur(48px)}
.whitespace-nowrap{white-space:nowrap}
@media(min-width:640px){.sm\:p-2\.5{padding:.625rem}.sm\:p-6{padding:1.5rem}.sm\:p-8{padding:2rem}.sm\:p-10{padding:2.5rem}.sm\:p-20{padding:5rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-8{padding-top:2rem;padding-bottom:2rem}.sm\:gap-2{gap:.5rem}.sm\:gap-4{gap:1rem}.sm\:text-\[12px\]{font-size:12px}}
@media(min-width:768px){.md\:flex{display:flex}.md\:hidden{display:none}.md\:justify-end{justify-content:flex-end}.md\:justify-start{justify-content:flex-start}.md\:gap-2{gap:.5rem}.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:grid-cols-4{grid-template-columns:repeat(4,1fr)}.md\:p-8{padding:2rem}.md\:p-12{padding:3rem}.md\:py-12{padding-top:3rem;padding-bottom:3rem}.md\:text-base{font-size:1rem}.md\:text-4xl{font-size:2.25rem}.md\:text-5xl{font-size:3rem}}
@media(min-width:1024px){.lg\:left-auto{left:auto}.lg\:flex-row{flex-direction:row}.lg\:w-64{width:16rem}.lg\:sticky{position:sticky}.lg\:top-24{top:6rem}.lg\:hidden{display:none}}


/* --- Responsive Mobile --- */
@media (max-width: 767px) {
  .header-nav-btn { font-size: 10px; padding: 6px 8px; }
  header .max-w-7xl { padding-left: 0.5rem; padding-right: 0.5rem; }
  .dropdown-menu { width: 200px; }
  .text-center.py-8.md\:py-12 { padding-top: 2rem; padding-bottom: 2rem; }
  .text-3xl.md\:text-5xl { font-size: 1.5rem; }
  .grid-cols-1.sm\:grid-cols-2 { grid-template-columns: 1fr; }
  .stat-card .num { font-size: 1.25rem; }
  .auth-card { padding: 1.5rem; }
  .w-px.h-6 { display: none; }
}

/* --- Dashboard --- */
.dashboard-topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.75rem;background:var(--ma-bg-card);backdrop-filter:var(--ma-glass-blur);border:1px solid var(--ma-border);border-radius:var(--ma-radius-md);margin-bottom:1.5rem;flex-wrap:wrap;box-shadow:var(--ma-shadow-card)}
.oposicion-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.2em;color:var(--ma-text-muted)}
.opp-selector-container{display:flex;flex-direction:column;gap:8px}
.opp-cards-grid{display:flex;flex-wrap:wrap;gap:0.75rem;align-items:center}
.opp-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;width:80px;height:80px;background:var(--ma-bg-secondary);border:1px solid var(--ma-border);border-radius:14px;cursor:pointer;transition:all 0.25s cubic-bezier(0.4, 0, 0.2, 1);overflow:hidden;padding:8px}
.opp-card:hover{border-color:var(--ma-accent);transform:translateY(-3px);box-shadow:0 8px 20px var(--ma-accent-glow)}
.opp-card-img{width:40px;height:40px;object-fit:contain;transition:transform 0.25s}
.opp-card:hover .opp-card-img{transform:scale(1.1)}
.opp-card-name{font-size:9px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:var(--ma-text-secondary);margin-top:4px;text-align:center}
.opp-card-active{border-color:var(--ma-accent);background:var(--ma-accent-glow);box-shadow:0 0 12px var(--ma-accent-glow)}
.opp-card-active:hover{box-shadow:0 0 18px var(--ma-accent-glow)}
.opp-card-locked{opacity:.5;filter:grayscale(0.4)}
.opp-card-locked:hover{opacity:.75;border-color:rgba(245,158,11,.3);box-shadow:none}
.opp-card-lock-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,0.6);backdrop-filter:blur(1px)}
.opp-card-lock-overlay svg{color:var(--ma-accent);filter:drop-shadow(0 2px 4px rgba(0,0,0,0.5))}
.trial-banner{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(217,119,6,.1));border:1px solid rgba(245,158,11,.3);border-radius:12px;color:var(--ma-accent);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;text-decoration:none;transition:all 0.2s;cursor:pointer}
.trial-banner:hover{background:linear-gradient(135deg,rgba(245,158,11,.25),rgba(217,119,6,.15));transform:translateY(-2px);box-shadow:0 6px 20px var(--ma-accent-glow)}
.section-title{font-family:var(--ma-font-serif);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--ma-text-secondary);margin-bottom:1.25rem}
.modules-section{margin-bottom:2.5rem}
.modules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.module-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:1.75rem 1rem;background:var(--ma-bg-card);backdrop-filter:var(--ma-glass-blur);border:1px solid var(--ma-border);border-radius:var(--ma-radius-md);cursor:pointer;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1);position:relative;overflow:hidden;text-align:center;box-shadow:var(--ma-shadow-card)}
.module-tile:hover{border-color:var(--ma-accent);transform:translateY(-4px);box-shadow:0 12px 32px var(--ma-accent-glow)}
.module-tile:hover .module-emoji{transform:scale(1.18)}
.module-icon{position:relative;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--ma-bg-secondary);border-radius:14px;transition:all 0.3s}
.module-tile:hover .module-icon{background:var(--ma-accent-glow)}
.module-emoji{font-size:2rem;transition:transform .3s cubic-bezier(0.4, 0, 0.2, 1)}
.module-name{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ma-text-primary)}
.module-locked{opacity:.65}
.module-locked:hover{border-color:rgba(245,158,11,.3);opacity:.85}
.lock-overlay{position:absolute;inset:-2px;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,0.45);backdrop-filter:blur(1.5px);border-radius:14px}
.lock-overlay svg{color:var(--ma-accent);filter:drop-shadow(0 2px 6px rgba(0,0,0,0.3))}
.activity-section{background:var(--ma-bg-card);backdrop-filter:var(--ma-glass-blur);border:1px solid var(--ma-border);border-radius:var(--ma-radius-md);padding:1.5rem;box-shadow:var(--ma-shadow-card)}
.activity-list{display:flex;flex-direction:column;gap:.75rem}
.activity-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--ma-bg-secondary);border:1px solid transparent;transition:all 0.25s cubic-bezier(0.4, 0, 0.2, 1)}
.activity-item:hover{transform:translateX(6px);border-color:var(--ma-accent-glow);background:var(--ma-bg-card)}
.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--ma-accent);flex-shrink:0;box-shadow:0 0 8px var(--ma-accent)}
.activity-content{display:flex;justify-content:space-between;align-items:center;flex:1;min-width:0}
.activity-text{font-size:13px;font-weight:600;color:var(--ma-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.activity-time{font-size:11px;color:var(--ma-text-muted);white-space:nowrap;margin-left:12px}
.activity-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:2rem;color:var(--ma-text-muted)}
.activity-empty p{font-size:13px;text-align:center}
.dashboard-page{max-width:1000px;margin:0 auto;padding:2.5rem 1.5rem;width:100%}

@media(max-width:1023px){.modules-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:639px){.modules-grid{grid-template-columns:1fr}.dashboard-topbar{flex-direction:column;align-items:stretch;text-align:center}.trial-banner{justify-content:center}.dashboard-page{padding:1rem}}

/* --- Hamburger Menu --- */
.mobile-hamburger { display: none; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 12px; font-weight: 800; font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--ma-text-primary); background: transparent; border: 1px solid var(--ma-border); cursor: pointer; transition: all 0.2s ease; z-index: 10000; }
.mobile-hamburger:hover { background: var(--ma-accent-glow); border-color: var(--ma-accent); color: var(--ma-accent); }
.mobile-hamburger .close-icon { display: none !important; }
.mobile-hamburger .hamburger-icon { display: block !important; }
body.mobile-menus-open .mobile-hamburger .hamburger-icon { display: none !important; }
body.mobile-menus-open .mobile-hamburger .close-icon { display: block !important; }

body.mobile-menus-open { overflow: hidden; }

@media (max-width: 767px) {
  .mobile-hamburger { display: flex !important; position: absolute; top: 14px; right: 12px; }
  .desktop-menus { display: none; }
  .mobile-menus-open .desktop-menus { 
    display: flex !important; 
    position: absolute; top: 100%; left: 0; right: 0; 
    height: calc(100vh - 100%);
    background: var(--ma-glass-bg); backdrop-filter: var(--ma-glass-blur); z-index: 9998; 
    overflow-y: auto; padding: 1rem; 
    flex-direction: column; align-items: stretch;
  }
  .mobile-menus-open .desktop-menus > div {
    flex-direction: column !important; align-items: stretch !important;
  }
  .mobile-menus-open .desktop-menus .nav-dropdown-group { width: 100%; }
  .mobile-menus-open .desktop-menus .nav-dropdown-group > button {
    width: 100%; justify-content: space-between; padding: 12px 16px;
    border-bottom: 1px solid var(--ma-border); border-radius: 0;
  }
  .mobile-menus-open .desktop-menus .dropdown-menu {
    position: static; width: 100%; opacity: 1; visibility: visible;
    margin-top: 0; box-shadow: none;
  }
  .mobile-menus-open .desktop-menus .dropdown-menu > div {
    background: transparent !important; border: none !important; padding: 0 !important; box-shadow: none !important; border-radius: 0 !important;
  }
  .mobile-menus-open .desktop-menus .w-px { display: none; }
}

@media (min-width: 768px) {
  .mobile-hamburger { display: none !important; }
}

/* ═══════════════════════════════════════════════════════════════
   PEPPER ADDITIONS — Component Classes, Responsive, Animations
   ═══════════════════════════════════════════════════════════════ */

/* ─── Container ─── */
.container {
  max-width: 1400px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

/* ─── Card ─── */
.card {
  background: var(--ma-bg-card);
  border: 1px solid var(--ma-border);
  border-radius: var(--ma-radius-md);
  padding: 1.5rem;
  box-shadow: var(--ma-shadow-card);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
.card:hover {
  border-color: var(--ma-accent);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.12);
}

/* ─── Buttons ─── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: linear-gradient(135deg, var(--ma-accent), var(--ma-accent-hover));
  color: #000;
  font-weight: 800;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  border: none;
  border-radius: 0.75rem;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.btn-primary:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 8px 24px var(--ma-accent-glow);
}
.btn-primary:active {
  transform: translateY(0) scale(0.98);
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: var(--ma-bg-secondary);
  color: var(--ma-text-primary);
  font-weight: 700;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border: 1px solid var(--ma-border);
  border-radius: 0.75rem;
  cursor: pointer;
  transition: all 0.25s;
}
.btn-secondary:hover {
  background: var(--ma-border);
  transform: translateY(-1px);
}

.btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
  font-weight: 700;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 0.75rem;
  cursor: pointer;
  transition: all 0.25s;
}
.btn-danger:hover {
  background: rgba(239, 68, 68, 0.25);
  border-color: rgba(239, 68, 68, 0.5);
  transform: translateY(-1px);
}

/* ─── Badge ─── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.2rem 0.6rem;
  font-size: 0.6rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border-radius: 999px;
  line-height: 1.4;
}
.badge-accent {
  background: var(--ma-accent-glow);
  color: var(--ma-accent);
  border: 1px solid var(--ma-accent);
}
.badge-success {
  background: rgba(34, 197, 94, 0.12);
  color: #22c55e;
  border: 1px solid rgba(34, 197, 94, 0.3);
}
.badge-danger {
  background: rgba(239, 68, 68, 0.12);
  color: #ef4444;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

/* ─── Input Field ─── */
.input-label {
  display: block;
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--ma-text-muted);
  margin-bottom: 0.5rem;
}

/* ─── Table ─── */
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.table th {
  background: var(--ma-bg-secondary);
  padding: 1rem 1.25rem;
  text-align: left;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  color: var(--ma-text-muted);
  border-bottom: 2px solid var(--ma-accent);
  white-space: nowrap;
}
.table td {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--ma-border);
  color: var(--ma-text-primary);
  font-size: 0.875rem;
  transition: all 0.2s;
}
.table tr:hover td {
  background: var(--ma-bg-secondary);
}
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--ma-radius-sm);
}

/* ─── Modal ─── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  padding: 1rem;
  animation: fadeIn 0.2s ease;
}
.modal-content {
  background: var(--ma-bg-primary);
  border: 1px solid var(--ma-border);
  border-radius: var(--ma-radius-lg);
  padding: 2rem;
  max-width: 560px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 25px 50px rgba(0, 0, 0, 0.25);
  animation: scaleIn 0.25s cubic-bezier(0.16, 1, 0.3, 1);
}
.modal-title {
  font-size: 1.25rem;
  font-weight: 900;
  color: var(--ma-text-primary);
  margin-bottom: 1rem;
}
.modal-body {
  color: var(--ma-text-secondary);
  font-size: 0.9rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
}
.modal-footer {
  display: flex;
  gap: 0.75rem;
  justify-content: flex-end;
}

/* ─── Toast ─── */
.toast {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.5rem;
  background: var(--ma-bg-primary);
  border: 1px solid var(--ma-border);
  border-radius: var(--ma-radius-sm);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--ma-text-primary);
  z-index: 10001;
  animation: slideUpToast 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  transition: all 0.3s;
}
.toast.toast-success { border-left: 4px solid #22c55e; }
.toast.toast-error { border-left: 4px solid #ef4444; }
.toast.toast-info { border-left: 4px solid var(--ma-accent); }
.toast.hiding {
  opacity: 0;
  transform: translateY(1rem);
}
@keyframes slideUpToast {
  from { transform: translateY(2rem); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

/* ─── Loading Spinner ─── */

/* ═══════════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════════ */
.fade-in {
  animation: fadeIn 0.4s ease forwards;
}
@keyframes slideUpCustom {
  from { transform: translateY(2rem); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

/* Staggered animation delays */

/* Initially hidden for animation */
.animate-target {
  opacity: 0;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — Comprehensive Breakpoints
   ═══════════════════════════════════════════════════════════════ */

/* ─── Mobile First (<640px) ─── */
@media (max-width: 639px) {
  .container { padding-left: 1rem; padding-right: 1rem; }
  .modal-content { padding: 1.5rem; margin: 0.5rem; border-radius: var(--ma-radius-md); }
  .modal-stats-grid { grid-template-columns: 1fr; }
  .premium-header { padding: 2rem 1.5rem; border-radius: var(--ma-radius-md); }
  .admin-table th, .admin-table td { padding: 0.75rem 1rem; font-size: 0.75rem; }
  .modules-grid { grid-template-columns: 1fr; }
  .card { padding: 1rem; }
  .btn-primary, .btn-secondary, .btn-danger { padding: 0.6rem 1rem; font-size: 0.65rem; }
  .toast { left: 1rem; right: 1rem; bottom: 1rem; font-size: 0.8rem; }
  .hide-mobile { display: none !important; }
  .stats-pill-group { flex-wrap: wrap; }
}

/* ─── Tablet (640px–1023px) ─── */
@media (min-width: 640px) and (max-width: 1023px) {
  .container { padding-left: 1.5rem; padding-right: 1.5rem; }
  .modules-grid { grid-template-columns: repeat(2, 1fr); }
  .modal-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .premium-header { padding: 3rem 2.5rem; }
  .hide-tablet { display: none !important; }
  .show-tablet { display: block !important; }
}

/* ─── Desktop (≥1024px) ─── */
@media (min-width: 1024px) {
  .modules-grid { grid-template-columns: repeat(4, 1fr); }
  .modal-stats-grid { grid-template-columns: repeat(3, 1fr); }
  .premium-header { padding: 4rem 3.5rem 5rem; }
}

/* ─── Print ─── */
@media print {
  body { background: #fff !important; color: #000 !important; }
  header, footer, .toast, .modal-overlay { display: none !important; }
  .card, .admin-card { box-shadow: none; border: 1px solid #ccc; break-inside: avoid; }
}
