
/* Tipografía DOMMA: Contax Sans para titulares (logo, h1-h3, títulos de página y sección),
   Instrument Sans para body. Cargada localmente desde /fonts/. */
@font-face{font-family:'Contax Sans';src:url('../fonts/contax-light.otf') format('opentype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Contax Sans';src:url('../fonts/contax-regular.otf') format('opentype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Contax Sans';src:url('../fonts/contax-medium.otf') format('opentype');font-weight:500;font-style:normal;font-display:swap}

:root{--bg:#F8F7F5;--navy:#101637;--blue:#1C296A;--blue-12:rgba(16,22,55,.12);--blue-07:rgba(16,22,55,.07);--text:#101637;--text-2:rgba(16,22,55,.6);--text-3:rgba(16,22,55,.35);--white:#fff;--border:rgba(16,22,55,.1);--success-bg:#E8F5EE;--success:#1A6038;--warn-bg:#FEF3E2;--warn:#92540A;--danger-bg:#FDF0F0;--danger:#8B2020;--info-bg:#EAF2FB;--info:#0C447C;--sw:240px;--hh:56px;--f:'Instrument Sans',sans-serif;--ft:'Contax Sans','Instrument Sans',sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--f);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
/* Todos los titulares en Contax Sans (DOMMA brand voice).
   Los códigos de cupón (.mono, .cupon-hero-code) y la URL del enlace mantienen monospace. */
h1,h2,h3,h4,
.page-title,
.dash-section-title,
.ct,
.cont-title,
.dash-card-value:not(.mono),
.sl,
.sb-logo-t,
.topbar-brand{font-family:var(--ft);letter-spacing:.01em}
/* Layout: ya no hay sidebar fijo lateral, es overlay */
.layout{display:flex;min-height:100vh;flex-direction:column}

/* Sidebar overlay: cerrado por defecto, abre desde la izquierda */
.sidebar-backdrop{position:fixed;inset:0;background:rgba(16,22,55,.35);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;z-index:99}
.sidebar-backdrop.open{opacity:1;visibility:visible}
.sidebar{width:var(--sw);background:white;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .28s cubic-bezier(.4,0,.2,1);transform:translateX(-100%);box-shadow:0 8px 30px rgba(16,22,55,.10);overflow-y:auto}
.sidebar.open{transform:translateX(0)}
.sb-header{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.sb-logo-t{font-size:14px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);display:inline-flex;align-items:center;gap:8px}
/* Logo DOMMA (imagen) + "PRO" (Contax) */
.brand-logo{height:18px;width:auto;display:block}
.brand-logo-lg{height:30px}
.brand-pro{font-family:var(--ft);font-weight:500;letter-spacing:.18em;color:var(--navy);font-size:.85em;line-height:1;display:inline-block;padding-left:2px;border-left:1px solid rgba(16,22,55,.18);padding-left:10px;margin-left:2px}
.brand-pro-lg{font-size:18px;letter-spacing:.22em;padding-left:14px;margin-left:4px}
.login-brand{display:inline-flex;align-items:center;gap:6px;margin-bottom:6px}
.sb-close{background:none;border:none;cursor:pointer;color:var(--text-2);padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}
.sb-close:hover{background:var(--blue-07);color:var(--text)}
.sb-close svg{width:18px;height:18px}
.nav-group{padding:6px 8px}
.nav-group + .nav-group{border-top:1px solid var(--border);padding-top:10px;margin-top:4px}
.nav-label{padding:8px 14px 4px;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3)}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 14px;font-size:13px;font-weight:500;color:var(--text-2);cursor:pointer;border-radius:8px;transition:all .15s;margin:1px 0}
.nav-item:hover{color:var(--text);background:var(--blue-07)}
.nav-item.active{color:var(--blue);background:var(--blue-07);font-weight:600}
.nav-item svg{width:16px;height:16px;opacity:.8;flex-shrink:0}
.nbadge{margin-left:auto;background:#C4784A;color:white;font-size:9px;font-weight:600;padding:2px 6px;border-radius:10px}

/* Main + topbar */
.main{flex:1;display:flex;flex-direction:column;min-height:100vh;min-width:0}
.topbar{height:60px;background:white;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;position:sticky;top:0;z-index:50;gap:16px}
.topbar-left{display:flex;align-items:center;gap:14px;flex-shrink:0}
.topbar-hamburger{background:none;border:none;cursor:pointer;color:var(--text);padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .15s}
.topbar-hamburger:hover{background:var(--blue-07)}
.topbar-hamburger svg{width:22px;height:22px}
.topbar-brand{font-size:14px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);display:inline-flex;align-items:center;gap:8px}
.topbar-brand .brand-logo{height:20px}
.topbar-center{flex:1;display:flex;justify-content:center;max-width:520px;margin:0 auto}
.topbar-search{width:100%;max-width:380px;display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;cursor:pointer;color:var(--text-2);transition:background .15s,border-color .15s;font-family:inherit;font-size:13px}
.topbar-search:hover{background:white;border-color:rgba(16,22,55,.18)}
.topbar-search svg{width:16px;height:16px;flex-shrink:0}
.topbar-search-placeholder{flex:1;text-align:left;font-size:13px}
.topbar-search-kbd,.search-kbd{font-family:var(--f);font-size:10px;font-weight:600;background:white;border:1px solid var(--border);padding:2px 6px;border-radius:4px;color:var(--text-3);box-shadow:0 1px 0 rgba(16,22,55,.05)}
.topbar-right{display:flex;align-items:center;gap:10px;flex-shrink:0;position:relative}
.topbar-user{display:flex;align-items:center;gap:8px;padding:5px 10px 5px 5px;background:white;border:1px solid var(--border);border-radius:100px;cursor:pointer;color:var(--text);transition:background .15s,border-color .15s;font-family:inherit;font-size:13px;font-weight:500}
.topbar-user:hover{background:var(--bg);border-color:rgba(16,22,55,.18)}
.topbar-user-avatar{width:28px;height:28px;border-radius:50%;background:var(--navy);color:white;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.topbar-user-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar-user-chev{width:14px;height:14px;color:var(--text-2);transition:transform .2s}
.topbar-user.open .topbar-user-chev{transform:rotate(180deg)}

/* User dropdown menu */
.user-menu{position:fixed;top:64px;right:20px;width:240px;background:white;border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 30px rgba(16,22,55,.12);padding:6px;z-index:101;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s,visibility .2s,transform .2s}
.user-menu.open{opacity:1;visibility:visible;transform:translateY(0)}
.user-menu-header{padding:12px 14px 10px}
.user-menu-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.2}
.user-menu-email{font-size:12px;color:var(--text-2);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-menu-divider{height:1px;background:var(--border);margin:4px 6px}
.user-menu-item{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:13px;color:var(--text);cursor:pointer;border-radius:8px;transition:background .15s;text-decoration:none}
.user-menu-item:hover{background:var(--blue-07)}
.user-menu-item svg{width:16px;height:16px;color:var(--text-2);flex-shrink:0}

/* Search palette modal */
.search-palette{position:fixed;inset:0;background:rgba(16,22,55,.35);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding-top:14vh;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s}
.search-palette.open{opacity:1;visibility:visible}
.search-palette-box{width:100%;max-width:560px;background:white;border-radius:14px;box-shadow:0 20px 60px rgba(16,22,55,.25);overflow:hidden;display:flex;flex-direction:column;max-height:60vh}
.search-palette-input-wrap{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--border)}
.search-palette-input-wrap input{flex:1;border:none;outline:none;font-family:inherit;font-size:15px;color:var(--text);background:transparent}
.search-palette-input-wrap input::placeholder{color:var(--text-3)}
.search-palette-results{overflow-y:auto;padding:6px;max-height:50vh}
.search-result-section{font-size:10px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--text-3);padding:10px 12px 4px}
.search-result-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .15s;color:var(--text);font-size:13px}
.search-result-item:hover,.search-result-item.active{background:var(--blue-07)}
.search-result-item svg{width:16px;height:16px;color:var(--text-2);flex-shrink:0}
.search-result-item-text{flex:1;min-width:0}
.search-result-item-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.search-result-item-desc{font-size:11px;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}
.search-result-empty{text-align:center;padding:32px 20px;color:var(--text-3);font-size:13px}

/* Page header (debajo de la topbar): título a la izq, breadcrumb a la dcha */
.page-header{padding:20px 28px 8px;background:white;border-bottom:1px solid var(--border);transition:background .25s ease,color .25s ease;display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.page-header-left{flex:1;min-width:0}
.page-title{font-size:22px;font-weight:600;color:var(--text);line-height:1.2}
.page-subtitle{font-size:13px;color:var(--text-2);margin-top:2px}
/* Breadcrumb a la derecha: "Inicio / [sección actual]" */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;font-family:var(--f);color:var(--text-2);padding-bottom:4px;flex-shrink:0}
.breadcrumb .breadcrumb-link{color:var(--text-2);cursor:pointer;text-decoration:none;transition:color .15s,text-decoration .15s}
.breadcrumb .breadcrumb-link:hover{color:var(--blue);text-decoration:underline}
.breadcrumb .breadcrumb-sep{opacity:.4;user-select:none}
.breadcrumb .breadcrumb-current{color:var(--text);font-weight:500}
/* Variante "saludo": fondo navy DOMMA con texto blanco. Se aplica solo en el dashboard PRO. */
.page-header.greeting{background:var(--navy);border-bottom-color:rgba(255,255,255,.06);padding:24px 28px}
.page-header.greeting .page-title{color:white;font-weight:500}
.page-header.greeting .page-subtitle{color:rgba(255,255,255,.65);margin-top:4px}
.page-header.greeting .breadcrumb{color:rgba(255,255,255,.7)}
.page-header.greeting .breadcrumb .breadcrumb-link{color:rgba(255,255,255,.85)}
.page-header.greeting .breadcrumb .breadcrumb-link:hover{color:white}
.page-header.greeting .breadcrumb .breadcrumb-current{color:white}
/* Logo y "DOMMA PRO" en topbar/sidebar son clicables (vuelven a Inicio) */
.topbar-brand[role="button"],.sb-logo-t[role="button"]{transition:opacity .15s}
.topbar-brand[role="button"]:hover,.sb-logo-t[role="button"]:hover{opacity:.7}

.content{padding:28px;flex:1;min-width:0;overflow-x:hidden}

@media(max-width:700px){
  .topbar{padding:0 12px;gap:8px}
  .topbar-brand{display:none}
  .topbar-center{display:none}
  .topbar-user-name{display:none}
  .page-header{padding:14px 16px 6px}
  .breadcrumb{display:none}
  .content{padding:16px}
  /* Mi perfil: en mobile el grid pasa a 1 columna (antes se solapaba) */
  .pperf-grid{grid-template-columns:1fr !important}
}
/* Mi perfil: grid responsive (2 columnas desktop, 1 mobile via media query arriba) */
.pperf-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:100px;font-family:var(--f);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:opacity .15s,transform .1s;white-space:nowrap}
.btn:active{transform:scale(.98)}
.bp{background:var(--blue);color:white}.bp:hover{opacity:.88}
.bw{background:white;color:var(--navy);border:1px solid var(--border)}.bw:hover{background:var(--bg)}
.bd{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(139,32,32,.15)}
.bs{background:var(--success-bg);color:var(--success);border:1px solid rgba(26,96,56,.15)}
.bsm{padding:6px 12px;font-size:12px}
.card{background:white;border-radius:12px;border:1px solid var(--border);overflow:hidden}
.ch{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.ct{font-size:14px;font-weight:500;flex:1}
.sg{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.sc{background:white;border:1px solid var(--border);border-radius:12px;padding:16px 18px}
.sl{font-size:11px;color:var(--text-2);font-weight:500;margin-bottom:6px;letter-spacing:.2px}
.sv{font-size:28px;font-weight:300;color:var(--text);line-height:1}
.sd{font-size:11px;margin-top:4px}
.du{color:var(--success)}.dw{color:var(--warn)}
table{width:100%;border-collapse:collapse;font-size:13px}
th{padding:10px 16px;text-align:left;font-size:10px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);background:#FAFAF8;border-bottom:1px solid var(--border)}
td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#FAFAF9}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:600}
.bg{background:var(--success-bg);color:var(--success)}
.ba{background:var(--warn-bg);color:var(--warn)}
.br{background:var(--danger-bg);color:var(--danger)}
.bb{background:var(--info-bg);color:var(--info)}
.bk{background:var(--blue-07);color:var(--text-2)}
.bdot{width:5px;height:5px;border-radius:50%;background:currentColor}
.av{width:30px;height:30px;border-radius:50%;background:var(--blue-12);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--blue);flex-shrink:0}
.cp{display:flex;align-items:center;gap:8px}
.cn{font-weight:500;font-size:13px}
.cs{font-size:11px;color:var(--text-3)}
.fi{display:flex;flex-direction:column;gap:5px}
.fl{font-size:10px;font-weight:600;letter-spacing:.7px;text-transform:uppercase;color:var(--text-2)}
.fn,.fs{padding:10px 12px;background:var(--blue-07);border:1px solid transparent;border-radius:8px;font-family:var(--f);font-size:14px;color:var(--text);outline:none;transition:border-color .15s}
.fn:focus,.fs:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(28,41,106,.08)}
.fn::placeholder{color:var(--text-3)}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tabs{display:flex;gap:2px;background:var(--blue-07);padding:3px;border-radius:10px;width:fit-content;margin-bottom:20px}
.tab{padding:7px 16px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:500;color:var(--text-2);transition:all .15s;border:none;background:none;font-family:var(--f)}
.tab.active{background:white;color:var(--navy);box-shadow:0 1px 4px rgba(0,0,0,.07)}
.module{display:none}.module.active{display:block}
.cc{font-family:monospace;font-size:12px;font-weight:600;background:var(--blue-07);padding:3px 8px;border-radius:4px;letter-spacing:1px}
.prog{height:5px;background:var(--blue-07);border-radius:3px;overflow:hidden}
.pf{height:100%;border-radius:3px;background:var(--blue)}
.ph{background:var(--navy);border-radius:12px;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.ph h2{font-size:22px;font-weight:300;color:white;margin-bottom:4px}
.ph p{font-size:13px;color:rgba(255,255,255,.55)}
/* Fila superior del dashboard PRO: saludo + enlace diagnóstico en 2 columnas iguales */
.dash-top-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;align-items:stretch}
.dash-top-row > *{margin-bottom:0}
@media(max-width:760px){.dash-top-row{grid-template-columns:1fr}}

/* === NUEVO Resumen PRO: saludo azul + 4 cards en línea + muro de novedades === */
.dash-greeting{margin-bottom:20px}
.dash-greeting h2{font-size:24px;font-weight:600;color:var(--blue);line-height:1.2;margin-bottom:4px}
.dash-greeting p{font-size:13px;color:var(--text-2)}

/* Grid de 4 cards: Cupón, Usos, Ganado, Enlace */
.dash-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.dash-card-stat{background:white;border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;justify-content:space-between;min-height:120px}
.dash-card-warm{background:linear-gradient(135deg,#FFF7F0 0%,#FFEFE0 100%);border-color:#E8C3A0}
.dash-card-link{background:linear-gradient(135deg,#F5F7FF 0%,#E8EEFF 100%);border-color:#C4D0F0}
.dash-card-label{font-size:11px;color:var(--text-2);font-weight:500;letter-spacing:.2px;margin-bottom:8px}
.dash-card-warm .dash-card-label{color:#8B5A2B}
.dash-card-value{font-size:30px;font-weight:300;color:var(--text);line-height:1}
.dash-card-value.mono{font-family:monospace;font-weight:700}
.dash-card-sub{font-size:11px;color:var(--text-3);margin-top:6px}
.dash-card-warm .dash-card-sub{color:#8B5A2B}
.dash-card-link-url{font-family:monospace;font-size:11px;font-weight:600;color:var(--text);background:white;padding:7px 10px;border-radius:6px;border:1px solid var(--border);word-break:break-all;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:1100px){.dash-overview{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.dash-overview{grid-template-columns:1fr}}

/* Muro de novedades */
.notif-list{display:flex;flex-direction:column;gap:8px}
.notif-item{background:white;border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;gap:12px;align-items:flex-start;transition:background .15s}
.notif-item.unread{background:#F8FAFF;border-color:#C4D0F0}
.notif-item.unread::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:6px}
.notif-item.read{opacity:.65}
.notif-item .notif-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}
.notif-item .notif-icon.kit{background:#FCE4EC;color:#C2185B}
.notif-item .notif-icon.recompensa{background:#FFF3E0;color:#C4784A}
.notif-item .notif-icon.canje{background:#E8F5EE;color:var(--success)}
.notif-item .notif-icon.tier{background:#EDE7F6;color:#5E35B1}
.notif-item .notif-icon.bienvenida{background:#E3F2FD;color:var(--blue)}
.notif-item .notif-icon.mensaje{background:#FFFDE7;color:#92540A}
.notif-item .notif-content{flex:1;min-width:0}
.notif-item .notif-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:2px}
.notif-item .notif-msg{font-size:12px;color:var(--text-2);line-height:1.45}
.notif-item .notif-time{font-size:10px;color:var(--text-3);margin-top:6px}
.notif-empty{background:white;border:1px solid var(--border);border-radius:10px}
.plb{background:rgba(255,255,255,.1);border-radius:8px;padding:10px 14px;display:flex;align-items:center;gap:10px}
.plt{font-family:monospace;font-size:12px;color:rgba(255,255,255,.8)}
.stl{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--text-3);margin:20px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.sbt{display:none}
.dash-section{margin-bottom:20px}
.dash-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dash-section-title{font-size:15px;font-weight:600;color:var(--text-1)}
.dash-section-link{font-size:12px;color:var(--accent);cursor:pointer;font-weight:500}
.dash-section-link:hover{text-decoration:underline}
.dash-carousel{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.dash-carousel::-webkit-scrollbar{height:4px}.dash-carousel::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.dash-card{min-width:220px;max-width:220px;scroll-snap-align:start;background:white;border-radius:12px;border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s;flex-shrink:0}
.dash-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.08)}
.dash-card-img{width:100%;height:110px;object-fit:cover;background:#f5f3f0}
.dash-card-body{padding:10px 12px}
.dash-card-tag{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:10px;display:inline-block;margin-bottom:4px}
.dash-card-title{font-size:13px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.btn-copy-sm{background:var(--accent);color:white;border:none;padding:4px 12px;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;letter-spacing:.3px}
.btn-copy-sm:hover{opacity:.85}
.cont-card{background:white;border-radius:12px;border:1px solid var(--border);overflow:hidden;cursor:pointer;transition:transform .15s,box-shadow .15s}.cont-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.08)}
.cont-img{width:100%;height:160px;object-fit:cover;background:var(--blue-07)}
.cont-body{padding:16px}
.cont-tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.cont-tag.webinar{background:#EDE7F6;color:#5E35B1}.cont-tag.guia{background:#E8F5EE;color:#1A6038}.cont-tag.producto{background:#FFF3E0;color:#E65100}.cont-tag.articulo{background:#E3F2FD;color:#1565C0}.cont-tag.herramienta{background:#FCE4EC;color:#C62828}.cont-tag.nuevo{background:#FDF0F0;color:#C62828}
.cont-title{font-size:14px;font-weight:600;line-height:1.3;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cont-desc{font-size:12px;color:var(--text-2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:10px}
.cont-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-3)}
.cont-icon{display:flex;align-items:center;justify-content:center;width:100%;height:160px;font-size:48px;background:linear-gradient(135deg,#F8F7F5 0%,#EDE7F6 100%)}.cont-prod-img{width:100%;height:180px;object-fit:cover;background:#f9f7f4}
/* HERO del cupón en "Mis cupones": el cupón como protagonista (CRO-first) */
.cupon-hero{display:grid;grid-template-columns:1.4fr 1fr;gap:0;background:linear-gradient(135deg,#0F1535 0%,#1C296A 100%);border-radius:16px;padding:0;margin-bottom:20px;overflow:hidden;box-shadow:0 10px 30px rgba(15,21,53,.15)}
.cupon-hero-left{padding:22px 26px;display:flex;flex-direction:column;gap:14px;justify-content:center}
.cupon-hero-label{font-size:11px;color:rgba(255,255,255,.65);font-weight:600;letter-spacing:.6px;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.cupon-hero-label .badge{background:rgba(93,202,165,.18);color:#5DCAA5;border:1px solid rgba(93,202,165,.35);padding:3px 9px;font-size:10px;letter-spacing:.3px;border-radius:20px;text-transform:none;font-weight:500}
.cupon-hero-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.cupon-hero-code{font-family:monospace;font-size:32px;font-weight:700;color:white;letter-spacing:1.5px;background:rgba(255,255,255,.06);padding:10px 18px;border-radius:10px;border:1px solid rgba(255,255,255,.1);flex:1;min-width:200px;word-break:break-all;line-height:1.1}
.cupon-hero-meta{font-size:13px;color:rgba(255,255,255,.75);display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.cupon-hero-meta strong{color:white}
.cupon-hero-meta .dot-sep{opacity:.4;margin:0 2px}
.cupon-hero-right{padding:22px 26px;background:rgba(255,255,255,.05);border-left:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;justify-content:center;gap:10px}
.cupon-progress-label{font-size:11px;color:rgba(255,255,255,.65);font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.cupon-progress-bar{height:8px;background:rgba(255,255,255,.1);border-radius:8px;overflow:hidden}
.cupon-progress-fill{height:100%;background:linear-gradient(90deg,#C4784A,#E8A572);border-radius:8px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.cupon-progress-text{font-size:13px;color:rgba(255,255,255,.85);font-weight:500;line-height:1.4}
.cupon-progress-text strong{color:#E8A572}
@media(max-width:760px){
  .cupon-hero{grid-template-columns:1fr}
  .cupon-hero-right{border-left:none;border-top:1px solid rgba(255,255,255,.08)}
  .cupon-hero-code{font-size:24px}
}

/* Delta indicator (comparativa vs mes anterior) */
.delta{display:inline-flex;align-items:center;gap:3px;font-weight:600;font-size:11px}
.delta.up{color:var(--success)}
.delta.down{color:var(--danger)}
.delta.flat{color:var(--text-3)}

/* Producto card v2: estilo inspirado en wearedomma.com (cálido, premium, editorial) */
.cont-prod-card-v2{background:#FAF7F2;border-radius:16px;border:1px solid rgba(16,22,55,.06);overflow:hidden;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;position:relative;display:flex;flex-direction:column}
.cont-prod-card-v2:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(16,22,55,.10);border-color:rgba(16,22,55,.12)}
.cont-prod-card-v2:hover img{transform:scale(1.04)}
.cont-prod-card-v2:hover .cont-prod-cta{opacity:1!important;transform:translateX(0)!important}
.cont-prod-card-v2:hover .cont-prod-cta span{transform:translateX(3px)}

/* Carrusel horizontal de productos: scroll + flechas + drag */
.prod-carousel-wrap{position:relative}
.prod-carousel-track{display:flex;gap:14px;overflow-x:auto;overflow-y:hidden;overscroll-behavior:contain;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:8px 4px 16px;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;user-select:none;touch-action:pan-x}
.prod-carousel-track::-webkit-scrollbar{display:none}
.prod-carousel-track:active{cursor:grabbing}
.prod-carousel-card{flex:0 0 240px;scroll-snap-align:start;min-width:0}
.prod-carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:white;border:1px solid rgba(16,22,55,.08);box-shadow:0 4px 14px rgba(16,22,55,.12);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);z-index:2;transition:opacity .2s ease,background .15s ease,transform .15s ease,box-shadow .15s ease;padding:0}
.prod-carousel-arrow:hover{background:var(--blue);color:white;transform:translateY(-50%) scale(1.06);box-shadow:0 6px 18px rgba(28,41,106,.20)}
.prod-carousel-arrow svg{width:18px;height:18px}
.prod-carousel-arrow.prev{left:8px}
.prod-carousel-arrow.next{right:8px}
@media(max-width:900px){
  .prod-carousel-card{flex-basis:200px}
  .prod-carousel-arrow{width:36px;height:36px}
}
@media(max-width:900px){.sg{grid-template-columns:1fr 1fr}.fg{grid-template-columns:1fr}.content{padding:16px}}

.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .6s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}

.ql-toolbar.ql-snow{border-radius:8px 8px 0 0;border-color:var(--border)}.ql-container.ql-snow{border-radius:0 0 8px 8px;border-color:var(--border);font-family:var(--f)}

/* Retención funnel */
.funnel-step{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.funnel-bar{height:44px;border-radius:8px;display:flex;align-items:center;padding:0 16px;font-size:13px;font-weight:600;transition:width .4s ease}
.funnel-label{font-size:12px;color:var(--text-2);min-width:0;flex-shrink:1}
.funnel-drop{font-size:11px;color:var(--text-3);padding:2px 0 6px 16px}
@media(max-width:900px){#retencionBlock .sg{grid-template-columns:1fr 1fr}#retencionBlock div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}}
