/* ==================== UruPromos Public CSS ==================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#08080c;--bg-card:rgba(255,255,255,0.03);--bg-card-hover:rgba(255,255,255,0.06);
  --bg-elevated:#111118;--bg-dropdown:#16161e;
  --border:rgba(255,255,255,0.06);--border-hover:rgba(255,255,255,0.12);
  --text:#fff;--text2:rgba(255,255,255,0.5);--text3:rgba(255,255,255,0.25);--text4:rgba(255,255,255,0.12);
  --accent:#f6c444;--accent2:#f8d36a;--accent-bg:rgba(246,196,68,0.1);--accent-text:#1a1a1a;
  --danger:#f87171;--success:#34d399;--warning:#fb923c;
  --radius:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;
  --font:'DM Sans',-apple-system,sans-serif;
  --font-display:'Playfair Display',Georgia,serif;
  --max-w:1140px;--header-h:56px;
}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;font-size:14px}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}
@media(min-width:640px){.container{padding:0 28px}}

/* Header */
.header{position:sticky;top:0;z-index:100;background:rgba(8,8,12,0.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:var(--header-h)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:100%}
.logo{font-family:var(--font-display);font-size:22px;font-weight:700}
.logo span{color:var(--accent)}
.btn-alert{display:flex;align-items:center;gap:6px;background:var(--accent);color:var(--accent-text);padding:8px 18px;border-radius:50px;font-size:13px;font-weight:700;transition:background 0.2s}
.btn-alert:hover{background:var(--accent2)}

/* Hero */
.hero{padding:40px 0;border-bottom:1px solid var(--border)}
@media(min-width:640px){.hero{padding:52px 0}}
.hero h1{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.2;margin-bottom:8px}
@media(min-width:640px){.hero h1{font-size:38px}}
.hero h1 em{color:var(--accent);font-style:italic}
.hero p{color:var(--text3);font-size:16px;max-width:480px}
.search-wrap{position:relative;max-width:420px;margin-top:24px}
.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:14px;pointer-events:none}
.search-input{width:100%;padding:12px 16px 12px 42px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text);font-size:14px;outline:none;transition:all 0.2s}
.search-input::placeholder{color:var(--text3)}
.search-input:focus{border-color:rgba(246,196,68,0.4);box-shadow:0 0 0 3px rgba(246,196,68,0.1)}

/* Filter bar */
.filter-bar{position:sticky;top:var(--header-h);z-index:90;background:rgba(8,8,12,0.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:12px 0}
.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:nowrap;overflow-x:auto}
.filter-dropdown{position:relative}
.filter-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:50px;font-size:13px;font-weight:600;background:rgba(255,255,255,0.05);border:1px solid var(--border);color:var(--text2);transition:all 0.2s;white-space:nowrap}
.filter-btn:hover{border-color:var(--border-hover);color:var(--text)}
.filter-btn.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);box-shadow:0 2px 12px rgba(246,196,68,0.2)}
.filter-btn .arrow{font-size:10px;opacity:0.5;transition:transform 0.2s}
.filter-btn.open .arrow{transform:rotate(180deg)}
.filter-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;background:var(--bg-dropdown);border:1px solid var(--border-hover);border-radius:var(--radius-md);min-width:200px;box-shadow:0 12px 40px rgba(0,0,0,0.5);padding:6px;z-index:200;animation:dropIn 0.15s ease-out}
.filter-menu.open{display:block}
@keyframes dropIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.filter-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:var(--radius);font-size:13px;color:var(--text2);transition:all 0.15s;text-align:left}
.filter-option:hover{background:rgba(255,255,255,0.05);color:var(--text)}
.filter-option.selected{color:var(--accent);font-weight:600}
.filter-option .dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--text3);flex-shrink:0}
.filter-option.selected .dot{background:var(--accent);border-color:var(--accent)}
.filter-sep{width:1px;height:24px;background:var(--border);flex-shrink:0;margin:0 4px}
.filter-clear{padding:8px 14px;border-radius:50px;font-size:13px;font-weight:600;color:var(--accent);white-space:nowrap}

/* Grid */
.promo-grid{display:grid;gap:16px;padding:24px 0 60px;grid-template-columns:1fr}
@media(min-width:640px){.promo-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.promo-grid{grid-template-columns:repeat(3,1fr)}}

/* Card */
.promo-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;transition:all 0.3s;position:relative;animation:fadeUp 0.45s ease-out both}
.promo-card:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,0.3)}
.promo-card.pinned::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),#f8d36a,var(--accent));z-index:2}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

.card-image{height:120px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center}
.card-image-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg) 0%,transparent 70%)}
.card-discount-badge{position:absolute;top:10px;right:10px;z-index:2;background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);border-radius:var(--radius-md);padding:6px 12px;display:flex;align-items:baseline;gap:4px}
.card-discount-big{font-size:22px;font-weight:900;color:#fff;line-height:1}
.card-discount-label{font-size:10px;font-weight:700;color:rgba(255,255,255,0.5)}
.card-badges{position:absolute;bottom:10px;left:12px;z-index:2;display:flex;gap:5px}
.badge{display:inline-block;padding:2px 8px;border-radius:50px;font-size:10px;font-weight:700;letter-spacing:0.3px}

.card-body{padding:16px}
.card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}
.card-logo{width:40px;height:40px;border-radius:var(--radius);background:rgba(255,255,255,0.07);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text3);flex-shrink:0;overflow:hidden}
.card-logo img{width:100%;height:100%;object-fit:cover}
.card-title-area{flex:1;min-width:0}
.card-comercio{font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-meta{font-size:12px;color:var(--text3);margin-top:2px}
.card-banco{padding:3px 8px;border-radius:6px;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;align-self:flex-start}

.card-discount-inline{display:flex;align-items:baseline;gap:8px;margin-bottom:12px}
.card-discount-inline .big{font-size:32px;font-weight:900;line-height:1}
.card-discount-inline .label{font-size:13px;font-weight:700;color:var(--text3)}
.card-discount-inline .tope{font-size:11px;color:var(--text3);margin-left:auto}

.days{display:flex;gap:3px}
.day{width:24px;height:24px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}
.day.active{background:var(--accent);color:var(--accent-text)}
.day.inactive{background:rgba(255,255,255,0.04);color:var(--text4)}
.day-sm{width:20px;height:20px;font-size:9px}
.days-row{display:flex;align-items:center;justify-content:space-between}
.card-coverage{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.5px}
.card-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--text3)}

/* Detail page */
.detail-content{max-width:720px;margin:0 auto;padding:32px 20px 80px}
.detail-hero-image{height:200px;border-radius:var(--radius-xl);overflow:hidden;margin-bottom:32px;position:relative;background-size:cover;background-position:center}
@media(min-width:640px){.detail-hero-image{height:260px}}
.detail-hero-image .overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg) 0%,transparent 60%)}
.detail-badges{display:flex;gap:6px;margin-bottom:16px}
.detail-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:32px}
.detail-logo{width:56px;height:56px;border-radius:var(--radius-md);background:rgba(255,255,255,0.07);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--text3);flex-shrink:0;overflow:hidden}
.detail-logo img{width:100%;height:100%;object-fit:cover}
.detail-comercio{font-size:28px;font-weight:800;margin-bottom:4px}
.detail-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

.variante-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;align-items:flex-start;gap:20px;margin-bottom:12px}
.variante-valor{background:var(--accent);color:var(--accent-text);border-radius:var(--radius-md);padding:12px 16px;text-align:center;min-width:80px;flex-shrink:0}
.variante-valor .big{font-size:24px;font-weight:900;line-height:1}
.variante-valor .label{font-size:10px;font-weight:700;opacity:0.6;margin-top:2px}
.variante-info{flex:1}
.variante-segmento{font-size:14px;font-weight:600;margin-bottom:8px}

.section-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.detail-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}
.detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border)}
.detail-row:last-child{border-bottom:none}
.detail-row-label{font-size:14px;color:var(--text2)}
.detail-row-value{font-size:14px;font-weight:600}

.detail-conditions{background:var(--accent-bg);border:1px solid rgba(246,196,68,0.1);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px}
.detail-conditions p{font-size:13px;color:rgba(246,196,68,0.5);line-height:1.6}

.btn-primary{background:var(--accent);color:var(--accent-text);padding:14px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:700;text-align:center;transition:background 0.2s;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn-primary:hover{background:var(--accent2)}
.btn-secondary{padding:14px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;background:rgba(255,255,255,0.05);border:1px solid var(--border);color:var(--text2);transition:all 0.2s;display:inline-flex;align-items:center;justify-content:center}
.btn-secondary:hover{background:rgba(255,255,255,0.08);color:var(--text)}

/* Related */
.related-grid{display:grid;gap:10px;grid-template-columns:1fr}
@media(min-width:640px){.related-grid{grid-template-columns:repeat(2,1fr)}}
.related-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all 0.2s}
.related-item:hover{background:var(--bg-card-hover)}

/* Page header for entity pages */
.page-header{padding:32px 0;border-bottom:1px solid var(--border)}
.page-header h1{font-family:var(--font-display);font-size:28px;font-weight:700}
.page-header p{color:var(--text3);margin-top:4px}

/* Footer */
.footer{border-top:1px solid var(--border);padding:32px 0}
.footer-inner{display:flex;flex-direction:column;align-items:center;gap:12px}
@media(min-width:640px){.footer-inner{flex-direction:row;justify-content:space-between}}
.footer p{font-size:12px;color:var(--text3);text-align:center}

/* Empty */
.empty-state{text-align:center;padding:80px 20px}
.empty-state .icon{font-size:48px;margin-bottom:16px}
.empty-state h3{font-size:18px;font-weight:700;margin-bottom:4px}
.empty-state p{font-size:14px;color:var(--text3)}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:4px;padding:24px 0}
.pagination a,.pagination span{padding:8px 14px;border-radius:var(--radius);font-size:13px;font-weight:600;color:var(--text2);transition:all 0.2s}
.pagination a:hover{background:rgba(255,255,255,0.05)}
.pagination .current{background:var(--accent);color:var(--accent-text)}
