/* ═══════════════════════════════════════════════════════════════════════════
   AnunciosVarios — Design System v13
   Un solo archivo. Una sola fuente de verdad. Sin conflictos.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── 1. FUENTES ─────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Outfit:wght@300;400;500;600;700&display=swap');

/* ── 2. VARIABLES — LIGHT MODE ──────────────────────────────────────────── */
/* Template indirection layer: cada --tpl-* puede ser sobreescrita por
   tpl-studio.css, tpl-verde.css o cualquier template futura.
   Si --tpl-X no está definida, se usa el fallback (valor Market por defecto). */
:root {
  --brand:     var(--tpl-brand,     #E8720A);
  --brand-dk:  var(--tpl-brand-dk,  #C55E06);
  --brand-lt:  var(--tpl-brand-lt,  #FF8C2A);
  --brand-xs:  var(--tpl-brand-xs,  #FEF3E8);
  --brand-glow:var(--tpl-brand-glow, rgba(232,114,10,.22));

  --n0:   #FFFFFF;
  --n50:  #F6F4EF;
  --n100: #EDEBE4;
  --n150: #E2DFD6;
  --n200: #CCC9BE;
  --n300: #A8A49A;
  --n400: #7A756A;
  --n500: #5A5550;
  --n600: #3E3A35;
  --n700: #2A2622;
  --n800: #1A1714;
  --n900: #0E0C0A;

  --bg:      var(--tpl-bg,      #F6F4EF);
  --surface: var(--tpl-surface, #FFFFFF);
  --elevated:var(--tpl-elevated,#FFFFFF);
  --overlay: rgba(0,0,0,.45);

  --border:  var(--tpl-border,  #E2DFD6);
  --border-2:var(--tpl-border-2,#EDEBE4);

  --text:    var(--tpl-text,    #1A1714);
  --text-2:  var(--tpl-text-2,  #5A5550);
  --text-3:  var(--tpl-text-3,  #A8A49A);
  --text-inv:#FFFFFF;

  --success:    #15803D;
  --success-bg: #F0FDF4;
  --danger:     #DC2626;
  --danger-bg:  #FEF2F2;
  --warning:    #D97706;
  --warning-bg: #FFFBEB;
  --info:       #2563EB;
  --info-bg:    #EFF6FF;

  --sh-xs: var(--tpl-sh-xs, 0 1px 3px rgba(26,23,20,.06));
  --sh-sm: var(--tpl-sh-sm, 0 2px 8px rgba(26,23,20,.08),0 1px 2px rgba(26,23,20,.04));
  --sh-md: var(--tpl-sh-md, 0 6px 20px rgba(26,23,20,.09),0 2px 6px rgba(26,23,20,.05));
  --sh-lg: 0 16px 40px rgba(26,23,20,.11),0 4px 12px rgba(26,23,20,.06);
  --sh-xl: 0 28px 64px rgba(26,23,20,.13),0 8px 24px rgba(26,23,20,.07);
  --sh-brand: var(--tpl-sh-brand, 0 8px 28px rgba(232,114,10,.28));

  --r-xs: var(--tpl-r-xs, 4px);
  --r-sm: var(--tpl-r-sm, 8px);
  --r-md: var(--tpl-r-md, 12px);
  --r-lg: var(--tpl-r-lg, 16px);
  --r-xl: var(--tpl-r-xl, 20px);
  --r-2xl:var(--tpl-r-2xl,28px);
  --r-pill: 999px;
  /* Compat alias */
  --radius-sm: var(--r-sm); --radius-md: var(--r-md); --radius-lg: var(--r-lg); --radius-xl: var(--r-xl);

  --f-display:var(--tpl-f-display, 'Bricolage Grotesque','Georgia',serif);
  --f-body:   var(--tpl-f-body,    'Outfit','Helvetica Neue',system-ui,sans-serif);

  --ease:     cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,0,.2,1);
  --t:        .18s cubic-bezier(.4,0,.2,1);
  --t-slow:   .35s cubic-bezier(.4,0,.2,1);
  /* Compat alias */
  --transition: all .18s cubic-bezier(.4,0,.2,1);

  --navbar-h:  var(--tpl-navbar-h, 64px);
  --navbar-bg: var(--tpl-navbar-bg, rgba(255,255,255,.92));
  --navbar-border: var(--tpl-navbar-border, rgba(226,223,214,.8));
  --container: var(--tpl-container, 1280px);

  /* Compat aliases */
  --orange:    var(--brand);
  --orange-dk: var(--brand-dk);
  --orange-lt: var(--brand-lt);
  --orange-xs: var(--brand-xs);
  --btn-radius:var(--tpl-btn-radius, 999px);
  --adm-orange:var(--brand);
}

/* ── 3. DARK MODE ────────────────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg:      var(--tpl-dark-bg,      #080B10);
  --surface: var(--tpl-dark-surface, #0F1318);
  --elevated:var(--tpl-dark-elevated,#171C24);
  --overlay: rgba(0,0,0,.7);

  --border:  var(--tpl-dark-border,  rgba(255,255,255,.08));
  --border-2:var(--tpl-dark-border-2,rgba(255,255,255,.05));

  --text:    var(--tpl-dark-text,    #F0EDE8);
  --text-2:  var(--tpl-dark-text-2,  #9B9690);
  --text-3:  var(--tpl-dark-text-3,  #5A5550);

  --n50:  #0F1318;
  --n100: #171C24;
  --n150: #1E2430;
  --n200: #28303D;
  --n300: #3A4352;
  --n400: #5A6678;
  --n500: #7A8898;

  --success-bg: rgba(21,128,61,.15);
  --danger-bg:  rgba(220,38,38,.15);
  --warning-bg: rgba(217,119,6,.15);
  --info-bg:    rgba(37,99,235,.15);

  --sh-xs: 0 1px 3px rgba(0,0,0,.3);
  --sh-sm: 0 2px 8px rgba(0,0,0,.4),0 1px 2px rgba(0,0,0,.2);
  --sh-md: 0 6px 20px rgba(0,0,0,.45),0 2px 6px rgba(0,0,0,.25);
  --sh-lg: 0 16px 40px rgba(0,0,0,.5),0 4px 12px rgba(0,0,0,.3);
  --sh-xl: 0 28px 64px rgba(0,0,0,.6),0 8px 24px rgba(0,0,0,.35);

  --navbar-bg:     var(--tpl-dark-navbar-bg,     rgba(8,11,16,.9));
  --navbar-border: var(--tpl-dark-navbar-border, rgba(255,255,255,.07));
  --brand-xs: rgba(232,114,10,.12);

  /* Admin compat */
  --adm-body-bg:#080B10; --adm-surface:#0F1318; --adm-border:rgba(255,255,255,.08);
  --adm-text:#F0EDE8; --adm-text-2:#9B9690;
}

/* ── 4. RESET ────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;text-size-adjust:100%;-webkit-text-size-adjust:100%}
body{font-family:var(--f-body);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--t-slow),color var(--t-slow)}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;background:none;border:none;font-family:inherit}
input,select,textarea{font-family:inherit}
ul,ol{list-style:none}
table{border-collapse:collapse;width:100%}

/* ── 5. TIPOGRAFÍA ──────────────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-family:var(--f-display);line-height:1.15;font-weight:700;letter-spacing:-.025em;color:var(--text)}
h1{font-size:clamp(2rem,4.5vw,3.5rem);font-weight:800}
h2{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700}
h3{font-size:clamp(1.2rem,2.2vw,1.65rem);font-weight:700}
h4{font-size:1.2rem;font-weight:700}
h5{font-size:1rem;font-weight:600}
p{line-height:1.65}
.text-xs{font-size:.72rem}
.text-sm{font-size:.875rem}
.text-lg{font-size:1.125rem}
.text-xl{font-size:1.25rem}
.fw-400{font-weight:400}.fw-500{font-weight:500}.fw-600{font-weight:600}
.fw-700{font-weight:700}.fw-800{font-weight:800}.fw-900{font-weight:900}
.text-center{text-align:center}
.text-right{text-align:right}
.text-orange{color:var(--brand)}
.text-danger{color:var(--danger)}
.text-success{color:var(--success)}
.text-muted,.muted{color:var(--text-2)}
.section-eyebrow{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--brand);font-family:var(--f-display);margin-bottom:8px}
.section-title{font-family:var(--f-display);font-size:clamp(1.35rem,2.5vw,1.9rem);font-weight:800;color:var(--text);margin-bottom:8px}

/* ── 6. LAYOUT ──────────────────────────────────────────────────────────── */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.main-wrap{flex:1}
@media(min-width:769px){.main-wrap{padding-top:calc(var(--navbar-h) + env(safe-area-inset-top))}}
.page-wrap{max-width:1100px;margin:0 auto;padding:40px 24px}
.wide-wrap{max-width:1400px;margin:0 auto;padding:40px 24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:16px}
.d-flex{display:flex}
.d-col{display:flex;flex-direction:column}
.ai-c{align-items:center}
.ai-s{align-items:flex-start}
.jc-c{justify-content:center}
.jc-sb{justify-content:space-between}
.jc-e{justify-content:flex-end}
.flex-1{flex:1}
.flex-none{flex:none}
.wrap{flex-wrap:wrap}
.g4,.g6{gap:6px}.g8{gap:8px}.g10{gap:10px}.g12{gap:12px}.g16{gap:16px}.g20{gap:20px}.g24{gap:24px}
.m0{margin:0}
.mb-4{margin-bottom:4px}.mb-6{margin-bottom:6px}.mb-8{margin-bottom:8px}.mb-10{margin-bottom:10px}
.mb-12{margin-bottom:12px}.mb-14{margin-bottom:14px}.mb-16{margin-bottom:16px}
.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-to-content{position:absolute;top:-100px;left:16px;z-index:9999;padding:10px 20px;background:var(--brand);color:#fff;border-radius:var(--r-md);font-weight:700;font-size:.875rem;transition:top .15s}
.skip-to-content:focus{top:8px}
.divider{height:1.5px;background:var(--border);margin:24px 0}
.required::after{content:" *";color:var(--danger)}
.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden}
.card-body{padding:20px 24px}
.card-header{padding:16px 24px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.ac{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden;margin-bottom:16px}
.ac-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--n50);cursor:pointer;transition:background var(--t)}
.ac-head:hover{background:var(--n100)}
.ac-title{font-weight:800;font-size:.9rem;color:var(--text);display:flex;align-items:center;gap:8px;font-family:var(--f-display)}
.ac-title svg{color:var(--brand)}
.ac-body{padding:18px}

/* ── 7. NAVBAR ──────────────────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:900;height:calc(var(--navbar-h) + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);background:var(--navbar-bg);border-bottom:1px solid var(--navbar-border);backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);transition:box-shadow var(--t);box-sizing:border-box}
.navbar.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.1)}
.nav-wrap{max-width:var(--container);margin:0 auto;padding:0 24px;height:100%}
.nav-row-1{display:flex;align-items:center;gap:20px;height:100%}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-logo-text{font-family:var(--f-display);font-size:1.2rem;font-weight:800;letter-spacing:-.04em;color:var(--text);line-height:1}
.nav-logo-text .a,.nav-logo-text .v{color:var(--brand)}
.nav-logo-text .es{font-size:.75em;color:var(--text-3);font-weight:600}
@media(max-width:768px){.nav-logo-text{display:none !important}}
@media(max-width:768px){.chat-call-text{display:none !important}.chat-call-btn{padding:6px !important;min-width:44px !important;min-height:44px !important;display:inline-flex !important;align-items:center !important;justify-content:center !important}}
.nav-search{flex:1;max-width:520px;display:flex;align-items:stretch}
.nav-search-inner{position:relative;flex:1;display:flex;align-items:center}
.nav-search-icon{position:absolute;left:14px;color:var(--text-3);pointer-events:none;width:17px;height:17px}
.nav-search-input{width:100%;padding:10px 14px 10px 42px;background:var(--n50);border:1.5px solid var(--border);border-right:none;border-radius:var(--r-xl) 0 0 var(--r-xl);font-size:.875rem;font-weight:500;color:var(--text);outline:none;transition:border-color var(--t),background var(--t);min-height:42px}
.nav-search-input::placeholder{color:var(--text-3)}
.nav-search-input:focus{border-color:var(--brand);background:var(--surface)}
.nav-search-btn{padding:0 20px;background:var(--orange);color:#fff;border:1.5px solid var(--orange);border-left:none;border-radius:0 var(--r-xl) var(--r-xl) 0;font-size:.875rem;font-weight:700;font-family:var(--f-display);transition:background var(--t);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;align-self:stretch;min-height:42px}
.nav-search-btn:hover{background:var(--brand-dk);border-color:var(--brand-dk)}
.nav-suggest-box{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-lg);z-index:200;overflow:hidden;max-height:320px;overflow-y:auto}
.suggest-item{display:flex;align-items:center;gap:12px;padding:10px 16px;font-size:.875rem;cursor:pointer;transition:background var(--t)}
.suggest-item:hover{background:var(--n50)}
.suggest-price{font-weight:700;color:var(--brand);margin-left:auto}
.nav-actions{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-icon-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 10px;border-radius:var(--r-md);color:var(--text-2);transition:all var(--t);position:relative;background:none;border:none;text-decoration:none;font-size:inherit;white-space:nowrap}
.nav-icon-wrap:hover,.nav-icon-wrap.active{color:var(--brand);background:var(--brand-xs)}
.nav-icon-label{font-size:.62rem;font-weight:600;line-height:1;font-family:var(--f-display)}
.nav-badge{position:absolute;top:4px;right:4px;background:var(--brand);color:#fff;font-size:.6rem;font-weight:800;min-width:16px;height:16px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;padding:0 4px;border:1.5px solid var(--bg)}
.nav-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}
.btn-publish{display:flex;align-items:center;gap:7px;padding:10px 20px;background:var(--brand);color:#fff;font-family:var(--f-display);font-size:.875rem;font-weight:700;border-radius:var(--r-xl);border:none;cursor:pointer;transition:all var(--t);white-space:nowrap;text-decoration:none;flex-shrink:0}
.btn-publish:hover{background:var(--brand-dk);transform:translateY(-1px);box-shadow:var(--sh-brand)}
.nav-ham{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--r-md);background:var(--brand);border:none;cursor:pointer;flex-shrink:0}
.nav-darkmode .icon-sun{display:none}
.nav-darkmode .icon-moon{display:block}
[data-theme="dark"] .nav-darkmode .icon-sun{display:block}
[data-theme="dark"] .nav-darkmode .icon-moon{display:none}
.user-menu{position:relative}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--sh-xl);z-index:500;overflow:hidden;animation:dropIn .18s var(--ease-out)}
.ud-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
@media(max-width:440px){.user-dropdown{width:calc(100vw - 24px);right:-8px}.ud-grid{grid-template-columns:1fr}}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.ud-header{padding:16px;display:flex;align-items:center;gap:12px;border-bottom:1.5px solid var(--border)}
.ud-avatar-wrap{position:relative;flex-shrink:0}
.ud-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover}
.ud-avatar-placeholder{width:42px;height:42px;border-radius:50%;background:var(--brand);color:#fff;font-size:1rem;font-weight:800;display:flex;align-items:center;justify-content:center;font-family:var(--f-display)}
.ud-verified{position:absolute;bottom:-2px;right:-2px;width:18px;height:18px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}
.ud-username{font-weight:700;font-size:.9rem;color:var(--text)}
.ud-section{padding:4px}
.ud-section+.ud-section{border-top:1.5px solid var(--border)}
.ud-section-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding:8px 10px 4px}
.ud-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-sm);color:var(--text-2);font-size:.875rem;font-weight:500;text-decoration:none;transition:all var(--t)}
.ud-row:hover{background:var(--n50);color:var(--text)}
.ud-icon{color:var(--text-3);flex-shrink:0;display:flex}
.ud-label{flex:1}
.ud-chevron{color:var(--text-3);margin-left:auto}
.ud-row--admin{color:var(--brand)}.ud-row--admin .ud-icon{color:var(--brand)}
.ud-row--logout{color:var(--danger)}.ud-row--logout .ud-icon{color:var(--danger)}
.mob-menu{position:fixed;top:calc(var(--navbar-h) + env(safe-area-inset-top));left:0;right:0;bottom:0;background:var(--surface);z-index:800;overflow-y:auto;padding:16px;border-top:1.5px solid var(--border);animation:slideDown .22s var(--ease-out)}
@keyframes slideDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
.mob-search{display:flex;margin-bottom:16px;border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.mob-search input{flex:1;padding:12px 16px;background:var(--n50);border:none;font-size:.9rem;color:var(--text);outline:none}
.mob-search button{padding:12px 18px;background:var(--brand);color:#fff;border:none;display:flex;align-items:center;justify-content:center;min-width:48px;min-height:48px}
.mob-links{display:flex;flex-direction:column;gap:4px}
.mob-link{display:flex;align-items:center;gap:14px;padding:13px 16px;border-radius:var(--r-md);font-size:.95rem;font-weight:600;color:var(--text);text-decoration:none;transition:background var(--t)}
.mob-link svg{color:var(--text-3);flex-shrink:0}
.mob-link:hover{background:var(--n50)}
.mob-link--publish{background:var(--brand-xs);color:var(--brand);margin-bottom:8px;border:1.5px solid rgba(232,114,10,.2)}
.mob-link--publish svg{color:var(--brand)}
.mob-link--admin{color:var(--brand)}
.mob-link--logout{color:var(--danger)}
.mob-badge{margin-left:auto;background:var(--brand);color:#fff;font-size:.65rem;font-weight:800;min-width:18px;height:18px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;padding:0 5px}

/* ── 8. HERO ─────────────────────────────────────────────────────────────── */
.hero{position:relative;padding:clamp(60px,10vw,100px) 0 clamp(50px,8vw,80px);background:var(--surface);overflow:hidden}
[data-theme="dark"] .hero{background:var(--bg)}
.hero-ring{position:absolute;border-radius:50%;border:1.5px solid rgba(232,114,10,.1);pointer-events:none}
.hero-ring-1{width:600px;height:600px;top:-200px;right:-150px}
.hero-ring-2{width:400px;height:400px;top:-80px;right:-60px;opacity:.6}
.hero-glow{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(232,114,10,.18) 0%,transparent 70%);pointer-events:none}
.hero-glow-1{width:400px;height:400px;top:-100px;right:-80px}
.hero-glow-2{width:200px;height:200px;top:50px;right:200px;opacity:.5}
.hero-inner{max-width:var(--container);margin:0 auto;padding:0 24px}
.hero-content{max-width:660px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;background:var(--brand-xs);border:1px solid rgba(232,114,10,.2);border-radius:var(--r-pill);font-size:.75rem;font-weight:700;color:var(--brand);font-family:var(--f-display);letter-spacing:.04em;margin-bottom:16px}
.hero-title{font-family:var(--f-display);font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800;line-height:1.08;letter-spacing:-.04em;color:var(--text);margin-bottom:16px}
.hero-title .accent{color:var(--brand)}
.hero-sub{font-size:clamp(.95rem,1.5vw,1.1rem);color:var(--text-2);line-height:1.65;margin-bottom:32px;max-width:520px}
.hero-search{display:flex;background:var(--surface);border:2px solid var(--border);border-radius:var(--r-xl);overflow:visible;box-shadow:var(--sh-md);position:relative;max-width:580px;transition:border-color var(--t),box-shadow var(--t)}
.hero-search:focus-within{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-glow),var(--sh-md)}
.hero-search-box{display:flex;flex:1}
.hero-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none;width:20px;height:20px}
.hero-search input{flex:1;padding:16px 16px 16px 52px;background:transparent;border:none;font-size:1rem;font-weight:500;color:var(--text);outline:none;min-width:0}
.hero-search input::placeholder{color:var(--text-3)}
.hero-search-sep{width:1.5px;background:var(--border);margin:10px 0;flex-shrink:0}
.hero-search select{padding:16px 14px;background:transparent;border:none;font-size:.875rem;font-weight:600;color:var(--text-2);outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;min-width:130px}
.hero-search button{padding:12px 24px;background:var(--brand);color:#fff;font-family:var(--f-display);font-size:.95rem;font-weight:700;border:none;border-radius:0 var(--r-xl) var(--r-xl) 0;cursor:pointer;transition:background var(--t);flex-shrink:0;margin:-2px -2px -2px 0}
.hero-search button:hover{background:var(--brand-dk)}
.hero-stats{display:flex;gap:32px;margin-top:32px;flex-wrap:wrap}
.h-stat-n{font-family:var(--f-display);font-size:1.4rem;font-weight:800;color:var(--brand);display:block;line-height:1}
.h-stat-l{font-size:.78rem;color:var(--text-3);font-weight:500;margin-top:3px}
.cats-section{padding:48px 0;background:var(--bg)}
.cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(140px,100%),1fr));gap:12px;margin-top:24px}
.cat-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 12px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);text-decoration:none;color:var(--text-2);font-size:.82rem;font-weight:600;text-align:center;transition:all var(--t);font-family:var(--f-display)}
.cat-card:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xs);transform:translateY(-2px);box-shadow:var(--sh-md)}
.cat-icon{width:44px;height:44px;border-radius:var(--r-md);background:var(--n50);display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.cat-card:hover .cat-icon{background:rgba(232,114,10,.1)}
[data-theme="dark"] .cat-icon{background:var(--n150)}
.featured-section{padding:48px 0}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px}
.section-link{font-size:.875rem;font-weight:700;color:var(--brand);text-decoration:none;white-space:nowrap;display:flex;align-items:center;gap:4px}
.section-link:hover{text-decoration:underline}

/* ── 9. AD CARDS ────────────────────────────────────────────────────────── */
#ads-container,.ads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(260px,100%),1fr));gap:16px}
#ads-container.view-list,.ads-grid.view-list{grid-template-columns:1fr;gap:8px}
.ad-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all var(--t);display:flex;flex-direction:column;position:relative}
.ad-card:hover{border-color:rgba(232,114,10,.35);box-shadow:var(--sh-md);transform:translateY(-2px)}
.ad-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;flex:1}
.ad-img{position:relative;overflow:hidden;background:var(--n50);aspect-ratio:4/3;flex-shrink:0}
[data-theme="dark"] .ad-img{background:var(--n150)}
.ad-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s var(--ease)}
.ad-card:hover .ad-img img{transform:scale(1.04)}
.ad-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--n300)}
.ad-body{padding:16px;flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}
.ad-title{font-size:.9rem;font-weight:600;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ad-price{font-family:var(--f-display);font-size:1.15rem;font-weight:800;color:var(--brand);letter-spacing:-.02em}
.ad-price.free{color:var(--success)}.ad-price.exchange{color:var(--info)}
.ad-meta{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--text-3);flex-wrap:wrap}
.ad-meta svg{flex-shrink:0}.ad-meta-sep{color:var(--n300)}
.ad-condition{display:inline-flex;padding:2px 8px;border-radius:var(--r-pill);font-size:.65rem;font-weight:700;background:var(--n50);color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}
.ad-condition.nuevo{background:var(--success-bg);color:var(--success)}
.ad-condition.seminuevo{background:var(--info-bg);color:var(--info)}
.ad-actions{position:absolute;top:8px;right:8px;display:flex;flex-direction:column;gap:4px;opacity:0;transition:opacity var(--t)}
.ad-card:hover .ad-actions{opacity:1}
.ad-action-btn{width:34px;height:34px;border-radius:var(--r-md);background:rgba(255,255,255,.9);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-3);cursor:pointer;transition:all var(--t);backdrop-filter:blur(4px);text-decoration:none}
.ad-action-btn:hover{border-color:var(--brand);color:var(--brand);background:#fff}
.ad-action-btn.fav-btn.active{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}
[data-theme="dark"] .ad-action-btn{background:rgba(15,19,24,.88)}
.ad-badge{position:absolute;top:8px;left:8px;padding:3px 9px;border-radius:var(--r-pill);font-size:.65rem;font-weight:800;font-family:var(--f-display);text-transform:uppercase;letter-spacing:.04em}
.ad-badge--promoted{background:var(--brand);color:#fff}
.ad-badge--top{background:linear-gradient(135deg,#FFD700,#FFA000);color:#3A2500}
.ad-badge--urgent{background:var(--danger);color:#fff}
.ad-badge--new{background:var(--success);color:#fff}
.ad-badge--reserved{background:var(--info);color:#fff}
.ad-badge--sold{background:var(--n400);color:#fff}
/* List view */
#ads-container.view-list .ad-card,.ads-grid.view-list .ad-card{flex-direction:row;transform:none!important}
#ads-container.view-list .ad-card-link,.ads-grid.view-list .ad-card-link{flex-direction:row;flex:1;min-width:0}
#ads-container.view-list .ad-img,.ads-grid.view-list .ad-img{width:170px;min-width:170px;max-width:170px;aspect-ratio:auto;flex-shrink:0;border-radius:0}
#ads-container.view-list .ad-body,.ads-grid.view-list .ad-body{padding:12px 16px;flex-direction:column;justify-content:center;align-items:flex-start;text-align:left}
#ads-container.view-list .ad-actions,.ads-grid.view-list .ad-actions{position:static;flex-direction:row;opacity:1;padding:12px;border-left:1.5px solid var(--border);justify-content:center;align-items:center;gap:8px;background:var(--n50)}
.list-action-btn{width:34px;height:34px;min-width:34px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--text-3);cursor:pointer;transition:all var(--t);text-decoration:none}
.list-action-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xs)}
.list-action-btn.fav-btn.active{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}
/* Sidebar de filtros en list */
.dp-side{position:sticky;top:calc(var(--navbar-h) + env(safe-area-inset-top) + 20px)}

/* ── 10. BOTONES ────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;font-family:var(--f-display);font-size:.875rem;font-weight:700;border-radius:var(--r-xl);border:none;cursor:pointer;transition:all var(--t);white-space:nowrap;vertical-align:middle;text-decoration:none;line-height:1.3}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn-xs{padding:5px 12px;font-size:.72rem;border-radius:var(--r-md)}
.btn-sm{padding:7px 14px;font-size:.8rem}
.btn-lg{padding:14px 28px;font-size:1rem}
.btn-xl{padding:17px 36px;font-size:1.05rem}
.btn-full{width:100%}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--brand-dk);transform:translateY(-1px);box-shadow:var(--sh-brand)}
.btn-secondary{background:var(--n50);color:var(--text);border:1.5px solid var(--border)}
.btn-secondary:hover:not(:disabled){background:var(--n100);border-color:var(--n200)}
.btn-ghost{background:transparent;color:var(--text-2);border:1.5px solid var(--border)}
.btn-ghost:hover:not(:disabled){background:var(--n50);color:var(--text);border-color:var(--n300)}
.btn-outline-brand{background:transparent;color:var(--brand);border:1.5px solid var(--brand)}
.btn-outline-brand:hover:not(:disabled){background:var(--brand-xs)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}
.btn-danger-ghost{background:transparent;color:var(--danger);border:1.5px solid var(--danger)}
.btn-danger-ghost:hover:not(:disabled){background:var(--danger-bg)}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover:not(:disabled){background:#166534;transform:translateY(-1px)}
.btn-dark{background:var(--text);color:var(--bg)}
.btn-dark:hover:not(:disabled){opacity:.85}

/* ── 11. FORMULARIOS ────────────────────────────────────────────────────── */
.field-group,.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
label,.field-label{font-size:.82rem;font-weight:700;color:var(--text-2);font-family:var(--f-display)}
.field-hint{font-size:.75rem;color:var(--text-3);margin-top:2px}
.field-error{font-size:.75rem;color:var(--danger);display:flex;align-items:center;gap:4px}
input[type="text"],input[type="email"],input[type="password"],input[type="search"],input[type="number"],input[type="tel"],input[type="url"],input[type="date"],input[type="time"],textarea,select{width:100%;padding:11px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);font-size:.9rem;font-weight:500;color:var(--text);outline:none;transition:border-color var(--t),box-shadow var(--t);appearance:none;-webkit-appearance:none}
input::placeholder,textarea::placeholder{color:var(--text-3)}
input:focus,textarea:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}
input.error,textarea.error,select.error{border-color:var(--danger)}
textarea{resize:vertical;min-height:100px;line-height:1.6}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238B8580' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}
select:focus{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23E8720A' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E")}
.input-wrap{position:relative;display:flex;align-items:stretch}
.input-wrap .input-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}
.input-wrap input{padding-left:38px}
.input-wrap .input-suffix{position:absolute;right:13px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:.82rem;font-weight:600}
.toggle-sw{display:flex;align-items:center;cursor:pointer;gap:10px;user-select:none}
.toggle-sw input{display:none}
.toggle-track{width:44px;height:24px;background:var(--n200);border-radius:var(--r-pill);position:relative;transition:background var(--t);flex-shrink:0}
.toggle-sw input:checked+.toggle-track{background:var(--brand)}
.toggle-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:transform var(--t)}
.toggle-sw input:checked+.toggle-track .toggle-knob{transform:translateX(20px)}
.toggle-lbl{font-size:.875rem;font-weight:600;color:var(--text)}

/* ── 12. CHIPS & BADGES ─────────────────────────────────────────────────── */
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--r-pill);font-size:.75rem;font-weight:700;background:var(--n50);color:var(--text-2);border:1.5px solid var(--border);cursor:default}
.chip.active{background:var(--brand-xs);color:var(--brand);border-color:rgba(232,114,10,.25)}
.chip.selected{background:var(--brand);color:#fff;border-color:transparent}
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r-pill);font-size:.65rem;font-weight:800;font-family:var(--f-display);text-transform:uppercase;letter-spacing:.04em}
.badge-orange{background:var(--brand);color:#fff}
.badge-green{background:var(--success);color:#fff}
.badge-red{background:var(--danger);color:#fff}
.badge-blue{background:var(--info);color:#fff}
.badge-gray{background:var(--n100);color:var(--text-2)}
.adm-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:.68rem;font-weight:800}

/* ── 13. FLASH ──────────────────────────────────────────────────────────── */
.flash-messages{position:fixed;top:calc(var(--navbar-h) + env(safe-area-inset-top) + 12px);right:16px;z-index:9000;display:flex;flex-direction:column;gap:8px;max-width:420px;width:calc(100% - 32px);pointer-events:none}
.flash{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--r-md);font-size:.875rem;font-weight:600;box-shadow:var(--sh-lg);border:1.5px solid;animation:flashIn .25s var(--ease-out);pointer-events:all;backdrop-filter:blur(12px)}
@keyframes flashIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.flash-success,.flash.success{background:var(--success-bg);border-color:rgba(21,128,61,.3);color:var(--success)}
.flash-error,.flash.error,.flash.danger{background:var(--danger-bg);border-color:rgba(220,38,38,.3);color:var(--danger)}
.flash-warning,.flash.warning{background:var(--warning-bg);border-color:rgba(217,119,6,.3);color:var(--warning)}
.flash-info,.flash.info{background:var(--info-bg);border-color:rgba(37,99,235,.3);color:var(--info)}
.flash svg{flex-shrink:0;width:16px;height:16px}
.flash-close{margin-left:auto;background:none;border:none;cursor:pointer;font-size:1.1rem;line-height:1;color:inherit;opacity:.6;padding:0 4px;transition:opacity var(--t)}
.flash-close:hover{opacity:1}

/* ── 14. FOOTER ─────────────────────────────────────────────────────────── */
.footer{background:#1A1F2E;color:var(--n400);padding:48px 0 24px;margin-top:auto}
[data-theme="dark"] .footer{background:#040608}
.footer-inner{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,4vw,40px)}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:32px}
.footer-logo-text{font-family:var(--f-display);font-size:1.15rem;font-weight:800;letter-spacing:-.04em;color:var(--n0)}
.footer-tld{color:var(--n400);font-size:.8em}
.footer-links{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(160px,100%),1fr));gap:32px;margin-bottom:32px}
.footer-col{display:flex;flex-direction:column;gap:8px}
.footer-col-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--n0);font-family:var(--f-display);margin-bottom:4px}
.footer-col a{font-size:.82rem;color:var(--n400);text-decoration:none;transition:color var(--t);line-height:1.4}
.footer-col a:hover{color:var(--brand)}
.footer-link-icon{display:flex;align-items:center;gap:6px}
.footer-link--danger:hover{color:var(--danger)!important}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;padding-top:24px;border-top:1.5px solid rgba(255,255,255,.06)}
.footer-copy{font-size:.78rem;color:var(--n500)}
.footer-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.footer-meta-link{font-size:.75rem;color:var(--n500);text-decoration:none;cursor:pointer;background:none;border:none;transition:color var(--t);display:flex;align-items:center;gap:4px;font-family:inherit}
.footer-meta-link:hover{color:var(--brand)}
.footer-legal-badge{display:flex;align-items:center;gap:5px;font-size:.7rem;color:var(--n500)}
.footer-status{display:flex;align-items:center;gap:5px}
.status-dot{width:6px;height:6px;border-radius:50%;display:inline-block}
.status-dot--ok{background:var(--success);box-shadow:0 0 0 3px rgba(21,128,61,.25)}
.status-dot--warn{background:var(--warning)}
.status-dot--error{background:var(--danger)}
.footer-scroll-top{background:none}

/* ── 15. MODALES ────────────────────────────────────────────────────────── */
/* hidden attr must win over any display rule */
[hidden]{display:none!important}
.glm-overlay{position:fixed;inset:0;background:var(--overlay);z-index:9500;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(4px);animation:fadeIn .2s var(--ease-out)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.glm-sheet{width:100%;max-width:800px;max-height:92vh;background:var(--surface);border-radius:var(--r-2xl) var(--r-2xl) 0 0;display:flex;flex-direction:column;overflow:hidden;animation:sheetUp .28s var(--ease-out)}
@keyframes sheetUp{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}
@media(min-width:700px){.glm-overlay{align-items:center}.glm-sheet{border-radius:var(--r-2xl);max-height:85vh}}
.glm-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1.5px solid var(--border);flex-shrink:0}
.glm-title{font-family:var(--f-display);font-size:1.05rem;font-weight:800;color:var(--text)}
.glm-header-actions{display:flex;align-items:center;gap:12px}
.glm-ext-link{font-size:.78rem;font-weight:700;color:var(--brand);text-decoration:none}
.glm-close{width:32px;height:32px;border-radius:var(--r-md);background:var(--n50);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;border:none;cursor:pointer;transition:all var(--t)}
.glm-close:hover{background:var(--danger-bg);color:var(--danger)}
.glm-body{overflow-y:auto;padding:24px;flex:1;line-height:1.75;color:var(--text-2);font-size:.9rem}
.onboarding-overlay{position:fixed;inset:0;background:var(--overlay);z-index:9600;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px);animation:fadeIn .2s var(--ease-out)}
.onboarding-card{position:relative;background:var(--surface);border-radius:var(--r-2xl);padding:40px 32px;max-width:460px;width:100%;text-align:center;box-shadow:var(--sh-xl);animation:scaleIn .28s var(--ease-out)}
@keyframes scaleIn{from{transform:scale(.94);opacity:0}to{transform:none;opacity:1}}
.onboarding-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:var(--r-md);background:var(--n50);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;border:none;cursor:pointer}
.onboarding-logo{width:60px;height:60px;background:var(--brand);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:var(--sh-brand)}
.onboarding-title{font-family:var(--f-display);font-size:1.45rem;font-weight:800;margin-bottom:8px}
.onboarding-sub{color:var(--text-2);font-size:.9rem;margin-bottom:24px}
.onboarding-actions{display:flex;flex-direction:column;gap:8px;align-items:center}
.onboarding-btn{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px 20px;border-radius:var(--r-xl);text-decoration:none;font-weight:700;transition:all var(--t);text-align:center;border:1.5px solid var(--border);width:100%}
.onboarding-btn--primary{background:var(--brand);color:#fff;border-color:transparent}
.onboarding-btn--primary:hover{background:var(--brand-dk);box-shadow:var(--sh-brand)}
.onboarding-btn--secondary{background:var(--surface);color:var(--text)}
.onboarding-btn--secondary:hover{background:var(--n50);border-color:var(--brand)}
.onboarding-btn-title{font-size:.9rem;font-weight:700}
.onboarding-btn-sub{font-size:.75rem;opacity:.75;font-weight:500}
.onboarding-btn--primary .onboarding-btn-sub{opacity:.85}
.modal-overlay{position:fixed;inset:0;background:var(--overlay);z-index:9400;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.modal{background:var(--surface);border-radius:var(--r-2xl);padding:32px;max-width:500px;width:100%;box-shadow:var(--sh-xl);animation:scaleIn .22s var(--ease-out)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-title{font-family:var(--f-display);font-size:1.2rem;font-weight:800}

/* ── 16. WIDGETS ────────────────────────────────────────────────────────── */
.chat-widget{position:fixed;bottom:80px;right:20px;z-index:8000;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
@media(max-width:768px){.chat-widget{bottom:calc(env(safe-area-inset-bottom) + 70px)}}
.chat-fab{width:52px!important;height:52px!important;border-radius:50%!important;background:var(--orange)!important;border:none!important;box-shadow:var(--sh-lg)!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;transition:all var(--t)!important;padding:0!important;color:#fff!important}
.chat-fab:hover{transform:scale(1.08);box-shadow:var(--sh-xl)}
.chat-fab-icon{display:flex}
.chat-window{width:320px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-2xl);box-shadow:var(--sh-xl);display:flex;flex-direction:column;overflow:hidden;max-height:420px;animation:scaleIn .22s var(--ease-out);transform-origin:bottom right}
.chatbot-header{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--brand);color:#fff}
.chat-header-avatar{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.chat-header-title{font-weight:700;font-size:.88rem}
.chat-header-sub{font-size:.7rem;opacity:.8}
.chat-close-btn{margin-left:auto;background:none;border:none;color:#fff;opacity:.8;cursor:pointer;padding:4px;display:flex}
.chat-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.chat-bubble{padding:9px 13px;border-radius:var(--r-lg);font-size:.82rem;line-height:1.55;max-width:85%}
.chat-bubble--bot{background:var(--n50);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px}
.chat-bubble--user{background:var(--brand);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-window .chat-input-row{display:flex;border-top:1.5px solid var(--border)}
.chat-input{flex:1;padding:11px 14px;background:transparent;border:none;font-size:.875rem;color:var(--text);outline:none}
.chat-send-btn{width:44px;background:var(--brand);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background var(--t)}
.chat-send-btn:hover{background:var(--brand-dk)}
.back-to-top{position:fixed;bottom:90px;right:20px;width:40px;height:40px;background:var(--text);color:#fff;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--sh-md);transition:all var(--t);z-index:7500}
[data-theme="dark"] .back-to-top{background:var(--n200)}
.back-to-top:hover{transform:translateY(-2px);box-shadow:var(--sh-lg)}
.page-progress{position:fixed;top:0;left:0;height:3px;background:var(--brand);border-radius:0 2px 2px 0;z-index:9999;transition:width .1s linear;pointer-events:none}

/* ── 17. BOTTOM NAV ─────────────────────────────────────────────────────── */
/* Bottom nav: Wallapop-style 5-tab bar, prominent central CTA */
/* Bottom nav */
.av-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);z-index:850;-webkit-tap-highlight-color:transparent;flex-wrap:wrap}
@supports(padding:env(safe-area-inset-bottom)){
  .av-bottom-nav{padding-bottom:env(safe-area-inset-bottom) !important}
}
/* PWA standalone: el html tiene el mismo fondo que el nav — cualquier
   hueco debajo del nav es invisible porque es del mismo color */
html{background:var(--surface)}
[data-theme="dark"] html{background:var(--surface)}
[data-theme="dark"] .av-bottom-nav{background:var(--surface);border-color:var(--border)}
.av-bottom-nav a.av-nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0 4px;flex:1;font-size:.62rem;font-weight:600;color:var(--text-3);text-decoration:none;transition:color .15s ease,transform .12s ease;position:relative;font-family:var(--f-body);letter-spacing:.02em;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.av-nav-tab svg{width:24px;height:24px;transition:transform .15s ease}
.av-nav-tab.active{color:var(--brand)}
.av-nav-tab.active svg{transform:scale(1.08)}
.av-nav-tab:active{transform:scale(.92);transition:transform .08s ease}
.av-nav-badge{position:absolute;top:2px;right:calc(50% - 22px);background:#DC2626;color:#fff;font-size:.58rem;font-weight:800;min-width:16px;height:16px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--surface);animation:badgePop .3s var(--ease-out)}
@keyframes badgePop{from{transform:scale(0)}60%{transform:scale(1.15)}to{transform:scale(1)}}
.av-nav-publish{width:44px;height:44px;background:var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;margin-top:-14px;box-shadow:var(--sh-brand);transition:all .18s ease}
.av-nav-tab--publish:active .av-nav-publish{transform:scale(.88);box-shadow:none}
.av-nav-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;border:2px solid var(--border);transition:border-color .15s ease}
.av-nav-tab.active .av-nav-avatar{border-color:var(--brand)}

/* Page transition for PWA feel */
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
main{animation:pageIn .2s ease-out}

/* ── 17b. PWA ENHANCEMENTS ─────────────────────────────────────────────── */
/* Pull-to-refresh indicator (visual only, triggers native reload) */
.av-ptr{position:fixed;top:0;left:50%;transform:translateX(-50%) translateY(-60px);z-index:9100;pointer-events:none;transition:transform .25s var(--ease-out),opacity .2s}
.av-ptr.visible{transform:translateX(-50%) translateY(12px);opacity:1}
.av-ptr-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Smooth overscroll behavior for iOS PWA */
@supports(-webkit-touch-callout:none){
  body{-webkit-overflow-scrolling:touch;overscroll-behavior-y:none}
}

/* PWA standalone mode tweaks */
@media(display-mode:standalone){
  .navbar{padding-top:env(safe-area-inset-top)}
  body{overscroll-behavior-y:none;-webkit-user-select:none;user-select:text}
  main{min-height:calc(100vh - var(--navbar-h) - 64px - env(safe-area-inset-top) - env(safe-area-inset-bottom))}
  .footer{padding-bottom:calc(24px + env(safe-area-inset-bottom))}
}

/* Haptic feedback on tap (visual) */
.av-nav-tab:active,.btn-publish:active,.btn-primary:active,.chip:active{
  opacity:.85;transition:opacity .06s,transform .06s
}

/* ── 18. COOKIE BANNER ──────────────────────────────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--n800);color:var(--n200);padding:20px 24px;z-index:9200;display:flex;align-items:center;gap:16px;flex-wrap:wrap;border-top:1.5px solid rgba(255,255,255,.08);animation:slideUp .3s var(--ease-out)}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:none}}
[data-theme="dark"] .cookie-banner{background:#020304}
.cookie-text{flex:1;font-size:.82rem;line-height:1.55;min-width:200px}
.cookie-text a{color:var(--brand);text-decoration:underline}
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ── 19. PÁGINAS ESPECIALES ─────────────────────────────────────────────── */
.pg-split{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}
.pg-right{display:flex;flex-direction:column;gap:16px}
.dp-page-hdr{padding:32px 0 24px;border-bottom:1.5px solid var(--border);margin-bottom:24px}
.dp-page-title{font-family:var(--f-display);font-size:1.6rem;font-weight:800;color:var(--text);margin-bottom:4px}
.dp-page-sub{font-size:.875rem;color:var(--text-2)}
.dp-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.dp-card+.dp-card{margin-top:16px}
.dp-card-head{padding:16px 20px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.dp-card-title{font-family:var(--f-display);font-size:.95rem;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px}
.dp-card-body{padding:20px}
.dp-page{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}
.dp-menu{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden;position:sticky;top:calc(var(--navbar-h) + env(safe-area-inset-top) + 16px)}
.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:20px;display:flex;align-items:center;gap:16px;transition:all var(--t)}
.stat-card:hover{box-shadow:var(--sh-md);border-color:rgba(232,114,10,.25)}
.stat-icon{width:48px;height:48px;border-radius:var(--r-lg);background:var(--brand-xs);display:flex;align-items:center;justify-content:center;color:var(--brand);flex-shrink:0}
.stat-val{font-family:var(--f-display);font-size:1.6rem;font-weight:800;color:var(--text);line-height:1}
.stat-lbl{font-size:.78rem;color:var(--text-2);font-weight:600;margin-top:3px}
.rep-stat-val{font-family:var(--f-display);font-size:1.6rem;font-weight:800;color:var(--text)}
.rep-stat-label{font-size:.72rem;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.step-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:24px;text-align:center;transition:all var(--t)}
.step-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.step-num{display:inline-flex;width:48px;height:48px;border-radius:50%;background:var(--brand);color:#fff;font-family:var(--f-display);font-size:1.1rem;font-weight:800;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:var(--sh-brand)}
.gstep{padding:20px}
.gnum{width:36px;height:36px;border-radius:50%;background:var(--brand-xs);color:var(--brand);font-family:var(--f-display);font-size:.95rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:12px;border:2px solid rgba(232,114,10,.2)}
.fp-section{margin-bottom:24px}
.fp-header-title{font-family:var(--f-display);font-size:1.3rem;font-weight:800;color:var(--text)}
.fp-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.fp-section-badge{padding:3px 10px;background:var(--brand-xs);color:var(--brand);border-radius:var(--r-pill);font-size:.72rem;font-weight:800;font-family:var(--f-display)}
.fp-menu-item{display:flex;align-items:center;gap:10px;padding:10px 16px;font-size:.875rem;font-weight:600;color:var(--text-2);cursor:pointer;border-radius:var(--r-sm);transition:all var(--t);text-decoration:none}
.fp-menu-item:hover,.fp-menu-item.active{background:var(--n50);color:var(--brand)}
.fp-back-btn{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:700;color:var(--text-2);margin-bottom:16px;cursor:pointer;background:none;border:none;text-decoration:none;transition:color var(--t)}
.fp-back-btn:hover{color:var(--brand)}
.s-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.s-card+.s-card{margin-top:16px}
.s-card-head{padding:16px 20px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.s-card-title{font-family:var(--f-display);font-size:.95rem;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px}
.s-card-body{padding:20px}
.auth-wrap{min-height:calc(100vh - var(--navbar-h));display:flex;align-items:center;justify-content:center;padding:32px 16px}
.auth-card{width:100%;max-width:420px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-2xl);padding:40px 32px;box-shadow:var(--sh-lg)}
.auth-logo{display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.auth-title{font-family:var(--f-display);font-size:1.6rem;font-weight:800;text-align:center;margin-bottom:8px}
.auth-sub{text-align:center;color:var(--text-2);font-size:.875rem;margin-bottom:24px;line-height:1.55}
.auth-divider{display:flex;align-items:center;gap:16px;color:var(--text-3);font-size:.75rem;font-weight:600;margin:20px 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1.5px;background:var(--border)}
.auth-footer{text-align:center;margin-top:20px;font-size:.875rem;color:var(--text-2)}
.auth-footer a{color:var(--brand);font-weight:700;text-decoration:none}
.auth-footer a:hover{text-decoration:underline}
.social-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 20px;border:1.5px solid var(--border);border-radius:var(--r-xl);background:var(--surface);color:var(--text);font-weight:700;font-size:.875rem;font-family:var(--f-display);cursor:pointer;transition:all var(--t);text-decoration:none;width:100%}
.social-btn:hover{background:var(--n50);border-color:var(--n300)}
.err-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:40px 16px;text-align:center}
.err-inner{max-width:480px;width:100%}
.err-code{font-size:clamp(5rem,15vw,9rem);font-weight:900;line-height:1;color:var(--border);font-family:var(--f-display);margin-bottom:8px;user-select:none}
.err-icon{width:80px;height:80px;border-radius:var(--r-2xl);background:var(--brand);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:var(--sh-brand)}
.err-title{font-family:var(--f-display);font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:8px}
.err-sub{font-size:.9rem;color:var(--text-2);margin-bottom:24px;line-height:1.65}
.err-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}
.err-btn{display:inline-flex;align-items:center;gap:7px;padding:11px 22px;border-radius:var(--r-xl);font-size:.875rem;font-weight:700;font-family:var(--f-display);text-decoration:none;transition:all var(--t)}
.err-btn-primary{background:var(--brand);color:#fff}
.err-btn-primary:hover{background:var(--brand-dk);transform:translateY(-1px);box-shadow:var(--sh-brand)}
.err-btn-secondary{background:var(--n50);color:var(--text);border:1.5px solid var(--border)}
.err-btn-secondary:hover{border-color:var(--brand);color:var(--brand)}
.err-suggestions{margin-top:32px;padding-top:24px;border-top:1.5px solid var(--border)}
.err-suggest-title{font-size:.72rem;font-weight:800;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px;font-family:var(--f-display)}
.err-links{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.err-link{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--n50);border:1.5px solid var(--border);border-radius:var(--r-pill);font-size:.8rem;font-weight:700;color:var(--text-2);text-decoration:none;transition:all var(--t)}
.err-link:hover{background:var(--brand);color:#fff;border-color:transparent}
.ma-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--r-md);font-size:.78rem;font-weight:700;font-family:var(--f-display);cursor:pointer;transition:all var(--t);border:1.5px solid var(--border);background:var(--n50);color:var(--text-2);text-decoration:none}
.ma-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xs)}
.ma-btn.danger:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}
.skeleton{background:linear-gradient(90deg,var(--n100) 25%,var(--n50) 50%,var(--n100) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-sm)}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.listings-wrap{display:grid;grid-template-columns:260px 1fr;gap:20px;align-items:start}
.filters-panel{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:20px;position:sticky;top:calc(var(--navbar-h) + env(safe-area-inset-top) + 16px)}
.filters-title{font-family:var(--f-display);font-size:.9rem;font-weight:800;color:var(--text);margin-bottom:16px}
.filter-group{margin-bottom:16px}
.filter-group-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:8px;font-family:var(--f-display)}
.listings-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:12px 0}
.listings-count{font-size:.875rem;color:var(--text-2);font-weight:600}
.view-toggles{display:flex;gap:4px}
.view-btn{width:34px;height:34px;border-radius:var(--r-md);background:var(--n50);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-3);cursor:pointer;transition:all var(--t)}
.view-btn.active,.view-btn:hover{background:var(--brand-xs);color:var(--brand);border-color:rgba(232,114,10,.25)}
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:32px;flex-wrap:wrap}
.page-btn{min-width:38px;height:38px;padding:0 12px;border-radius:var(--r-md);background:var(--surface);border:1.5px solid var(--border);color:var(--text-2);font-size:.875rem;font-weight:700;font-family:var(--f-display);cursor:pointer;transition:all var(--t);text-decoration:none;display:flex;align-items:center;justify-content:center}
.page-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xs)}
.page-btn.active{background:var(--brand);color:#fff;border-color:transparent}
.page-btn:disabled{opacity:.4;cursor:not-allowed}
.page-btn.dots{cursor:default;pointer-events:none;border-color:transparent;background:transparent}
.profile-header{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-2xl);padding:32px;display:flex;align-items:flex-start;gap:24px;margin-bottom:20px}
.profile-avatar-wrap{position:relative;flex-shrink:0}
.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--border)}
.profile-avatar-placeholder{width:96px;height:96px;border-radius:50%;background:var(--brand);color:#fff;font-family:var(--f-display);font-size:2rem;font-weight:800;display:flex;align-items:center;justify-content:center}
.profile-verified{position:absolute;bottom:2px;right:2px;width:26px;height:26px;background:var(--success);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2.5px solid var(--surface)}
.profile-info{flex:1;min-width:0}
.profile-name{font-family:var(--f-display);font-size:1.5rem;font-weight:800;margin-bottom:4px}
.profile-meta{font-size:.82rem;color:var(--text-2);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.chat-list-item{display:flex;align-items:center;gap:16px;padding:16px;border-radius:var(--r-lg);cursor:pointer;transition:background var(--t);text-decoration:none;color:inherit;border-bottom:1px solid var(--border)}
.chat-list-item:hover{background:var(--n50)}
.chat-list-item.unread{background:var(--brand-xs)}
.chat-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--brand);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-display);font-weight:800}
.chat-preview{flex:1;min-width:0}
.chat-username{font-weight:700;font-size:.9rem;margin-bottom:2px}
.chat-last-msg{font-size:.78rem;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chat-time{font-size:.7rem;color:var(--text-3);flex-shrink:0}
.chat-unread-badge{min-width:20px;height:20px;background:var(--brand);color:#fff;border-radius:var(--r-pill);font-size:.65rem;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 5px;flex-shrink:0}

/* ── 20. COMPAT ALIASES ─────────────────────────────────────────────────── */
.u-initials{width:32px;height:32px;border-radius:50%;background:var(--brand);color:#fff;font-size:.75rem;font-weight:800;display:flex;align-items:center;justify-content:center;font-family:var(--f-display);flex-shrink:0}
.dev-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--brand-xs);border:1px solid rgba(232,114,10,.3);border-radius:var(--r-pill);color:var(--brand);font-size:.72rem;font-weight:700;font-family:var(--f-display);text-transform:uppercase;letter-spacing:.06em}
.at{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:20px;flex-wrap:wrap}
.at-tab{padding:10px 20px;font-size:.85rem;font-weight:700;color:var(--text-2);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;background:none;transition:all .15s;white-space:nowrap;font-family:var(--f-display)}
.at-tab.on{color:var(--brand);border-bottom-color:var(--brand)}
.at-tab:hover{color:var(--text)}
.at-pane{display:none}.at-pane.on{display:block}
.ag2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ag3{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(200px,100%),1fr));gap:12px}
.astat{background:var(--n50);border:1.5px solid var(--border);border-radius:var(--r-md);padding:16px;display:flex;align-items:center;gap:14px}
.astat-val{font-size:1.8rem;font-weight:900;color:var(--text);line-height:1;font-family:var(--f-display)}
.astat-lbl{font-size:.72rem;color:var(--text-2);font-weight:700;text-transform:uppercase;margin-top:3px}
.trow{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}
.trow:last-child{border-bottom:none}
.tlbl{font-size:.85rem;font-weight:600;color:var(--text)}
.tsw{display:flex;align-items:center;gap:8px}
.tsl{font-size:.8rem;color:var(--text-2);font-weight:500}
.tsub{font-size:.75rem;color:var(--text-3);margin-top:2px}

/* ── 21. RESPONSIVE ─────────────────────────────────────────────────────── */
@media(max-width:1024px){
  .nav-icon-label{display:none}
  .nav-icon-wrap{flex-direction:row;padding:8px}
}
@media(max-width:900px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .pg-split{grid-template-columns:1fr}
  .listings-wrap{grid-template-columns:1fr}
  .filters-panel{display:none;position:static}
  .dp-page{grid-template-columns:1fr}
  .dp-menu{position:static}
}
@media(max-width:768px){
  .nav-search{display:none}
  .nav-actions{display:none}
  .nav-ham{display:flex}
  .btn-publish-label{display:none}
  .btn-publish{padding:10px}
  .av-bottom-nav{display:flex}
  main{padding-bottom:calc(100px + env(safe-area-inset-bottom))}
  .flash-messages{right:8px;left:8px;width:auto}
  .chat-widget{bottom:calc(env(safe-area-inset-bottom) + 108px)}
  .profile-header{flex-direction:column;align-items:center;text-align:center}
}
@media(max-width:640px){
  :root{--navbar-h:56px}
  .container,.page-wrap,.wide-wrap{padding:0 16px}
  .page-wrap,.wide-wrap{padding-top:24px;padding-bottom:24px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .hero-search{flex-direction:column;border-radius:var(--r-lg)}
  .hero-search-sep{display:none}
  .hero-search button{border-radius:0 0 var(--r-lg) var(--r-lg);margin:0}
  .hero-search input{border-radius:var(--r-lg) var(--r-lg) 0 0}
  .ads-grid,#ads-container{grid-template-columns:repeat(2,1fr);gap:8px}
  .auth-card{padding:32px 20px}
  .dp-page{grid-template-columns:1fr}
  .ag2{grid-template-columns:1fr}
}
@media(max-width:360px){
  .ads-grid,#ads-container{grid-template-columns:1fr}
}

/* ── 22. PRINT ──────────────────────────────────────────────────────────── */
@media print{
  .navbar,.footer,.av-bottom-nav,.chat-widget,.back-to-top,.page-progress,.cookie-banner{display:none!important}
  body{padding-top:0}
  .main-wrap{padding-top:0}
}

/* ── 23. ACCESIBILIDAD ──────────────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}
:focus-visible{outline:3px solid var(--brand);outline-offset:3px;border-radius:var(--r-sm)}

/* ═══════════════════════════════════════════════════════════════════
   FASE 2 — Componentes de páginas públicas
   ═══════════════════════════════════════════════════════════════════ */

/* ── LAYOUT ALIASES ─────────────────────────────────────────────── */
.wrap{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(16px,3vw,32px)}
.section{padding-block:56px}
.section-sm{padding-block:36px}
.section-tinted{background:var(--n50)}
.section-reveal{opacity:0;transform:translateY(14px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
.section-reveal.visible{opacity:1;transform:none}
.see-all,.section-link{font-size:.82rem;font-weight:700;color:var(--brand);padding:6px 14px;border-radius:var(--r-pill);background:var(--brand-xs);transition:all var(--t);white-space:nowrap;flex-shrink:0;text-decoration:none}
.see-all:hover,.section-link:hover{background:var(--brand);color:#fff}

/* ── HERO ADDITIONS ──────────────────────────────────────────────── */
.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:var(--container);margin:0 auto;padding:0 24px}
.hero-text-col{display:flex;flex-direction:column;gap:20px}
.hero-visual-col{display:flex;justify-content:center}
.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;background:var(--brand-xs);border:1px solid rgba(232,114,10,.2);border-radius:var(--r-pill);font-size:.72rem;font-weight:700;color:var(--brand);font-family:var(--f-display);letter-spacing:.06em;margin-bottom:4px}
.hero-pill-dot{width:7px;height:7px;border-radius:50%;background:var(--brand);animation:blink 1.4s ease infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero-h1{font-family:var(--f-display);font-size:clamp(1.8rem,4.5vw,3.2rem);font-weight:900;line-height:1.06;letter-spacing:-.045em;color:var(--text);margin:0}
.hero-h1 em{font-style:normal;color:var(--brand)}
.hero-sub{font-size:.95rem;color:var(--text-2);line-height:1.65;max-width:480px;margin:0}
.hero-ctas{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.hero-cta-primary{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:var(--brand);color:#fff;border-radius:var(--r-pill);font-family:var(--f-display);font-size:.95rem;font-weight:800;text-decoration:none;box-shadow:var(--sh-brand);transition:all var(--t)}
.hero-cta-primary:hover{background:var(--brand-dk);transform:translateY(-2px);box-shadow:0 10px 32px rgba(232,114,10,.38)}
.hero-cta-note{font-size:.75rem;color:var(--text-3);font-weight:600}
.hero-popular{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.hero-popular-label{font-size:.72rem;color:var(--text-3);font-weight:700;white-space:nowrap;flex-shrink:0}
.hero-popular-chips{display:flex;gap:6px;flex-wrap:wrap}
.hero-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--r-pill);border:1.5px solid var(--border);color:var(--text-2);font-size:.78rem;font-weight:600;font-family:var(--f-display);background:var(--surface);transition:all var(--t);cursor:pointer;white-space:nowrap;flex-shrink:0}
.hero-chip:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xs);transform:translateY(-2px)}
.hero-cities{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.hero-city-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:var(--r-pill);border:1.5px solid var(--border);color:var(--text-2);font-size:.72rem;font-weight:600;background:var(--surface);text-decoration:none;transition:all var(--t)}
.hero-city-chip:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xs)}

/* ── HERO VISUAL (floating cards) ───────────────────────────────── */
.hero-visual{position:relative;height:400px;width:100%}
.hv-card{position:absolute;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-lg);overflow:hidden;width:190px;border:1.5px solid var(--border);transition:transform .3s ease}
.hv-card:hover{transform:translateY(-4px) scale(1.02)}
.hv-card-1{top:20px;left:20px;z-index:3;animation:hvFloat1 4s ease-in-out infinite}
.hv-card-2{top:80px;right:10px;z-index:2;animation:hvFloat2 4.5s ease-in-out infinite}
.hv-card-3{bottom:30px;left:60px;z-index:1;animation:hvFloat3 5s ease-in-out infinite}
@keyframes hvFloat1{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes hvFloat2{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes hvFloat3{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hv-card-img{height:110px;background:linear-gradient(135deg,var(--n100),var(--n50))}
.hv-card-img-1{background:linear-gradient(135deg,#3B82F6,#1D4ED8)}
.hv-card-img-2{background:linear-gradient(135deg,#F59E0B,#D97706)}
.hv-card-img-3{background:linear-gradient(135deg,#10B981,#059669)}
.hv-card-body{padding:10px 12px;text-align:center}
.hv-card-price{font-family:var(--f-display);font-weight:900;font-size:1.05rem;color:var(--brand)}
.hv-price-free{color:var(--success)}
.hv-card-title{font-size:.78rem;font-weight:700;color:var(--text);margin:2px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}
.hv-card-meta{font-size:.65rem;color:var(--text-3)}
.hv-badge{position:absolute;background:var(--surface);border-radius:var(--r-pill);padding:6px 12px;font-size:.72rem;font-weight:700;color:var(--text);box-shadow:var(--sh-md);display:flex;align-items:center;gap:6px;white-space:nowrap;border:1.5px solid var(--border);animation:hvBadge .5s ease-out both}
.hv-badge-1{top:10px;right:30px;animation-delay:.8s}
.hv-badge-2{bottom:20px;right:10px;animation-delay:1.2s}
@keyframes hvBadge{from{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:none}}
.hv-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--success)}

/* ── HERO TICKER ─────────────────────────────────────────────────── */
.hero-ticker-wrap{margin-top:24px}
.hero-ticker-row{overflow:hidden;mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent)}
.hero-ticker-track{display:flex;gap:8px;width:max-content;animation:htickL 32s linear infinite}
.hero-ticker-row:hover .hero-ticker-track{animation-play-state:paused}
@keyframes htickL{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.hero-chip--ticker{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border-radius:var(--r-pill);border:1.5px solid var(--brand);color:var(--brand);background:transparent;text-decoration:none;font-size:.78rem;font-weight:700;white-space:nowrap;flex-shrink:0;transition:all var(--t)}
.hero-chip--ticker:hover{background:var(--brand);color:#fff}

/* ── TRUST STRIP ─────────────────────────────────────────────────── */
.trust-strip{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:22px 0}
.trust-inner{max-width:var(--container);margin:0 auto;padding:0 clamp(16px,3vw,32px);display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:12px}
.trust-icon-wrap,.trust-icon{width:44px;height:44px;border-radius:var(--r-lg);background:var(--brand-xs);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trust-icon-wrap svg,.trust-icon svg{color:var(--brand);width:22px;height:22px}
.trust-label strong,.trust-text strong{display:block;font-family:var(--f-display);font-size:.84rem;font-weight:700;color:var(--text)}
.trust-label span,.trust-text span{font-size:.73rem;color:var(--text-3)}

/* ── AD TYPE CARDS (atc) ─────────────────────────────────────────── */
.atc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));gap:12px}
.atc-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--surface);border:2px solid var(--border);border-radius:var(--r-lg);text-decoration:none;color:var(--text);transition:all var(--t);position:relative;overflow:hidden}
.atc-card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--sh-md)}
.atc-icon-box{width:46px;height:46px;min-width:46px;border-radius:var(--r-md);background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--t)}
.atc-card:hover .atc-icon-box{transform:scale(1.1) rotate(-4deg)}
.atc-info{flex:1;min-width:0}
.atc-name{font-family:var(--f-display);font-weight:800;font-size:.9rem;color:var(--text);margin-bottom:2px}
.atc-sub{font-size:.74rem;color:var(--text-2);transition:color var(--t)}
.atc-chevron{opacity:.4;transition:opacity var(--t);flex-shrink:0}
.atc-card:hover .atc-chevron{opacity:1}

/* ── CATEGORY CARDS (catrev) ─────────────────────────────────────── */
.catrev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(120px,100%),1fr));gap:10px}
.catrev-card{display:flex;flex-direction:column;align-items:center;gap:9px;padding:20px 10px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);text-align:center;transition:all var(--t);cursor:pointer;text-decoration:none;position:relative;overflow:hidden}
.catrev-card:hover{border-color:var(--c-color,var(--brand));box-shadow:var(--sh-md);transform:translateY(-4px)}
.catrev-icon-wrap{width:50px;height:50px;border-radius:var(--r-md);background:var(--c-bg,var(--brand-xs));display:flex;align-items:center;justify-content:center;transition:transform var(--t)}
.catrev-card:hover .catrev-icon-wrap{transform:scale(1.12) rotate(-5deg)}
.catrev-icon svg{color:var(--c-color,var(--brand));width:26px;height:26px}
.catrev-name{font-size:.76rem;font-weight:700;font-family:var(--f-display);color:var(--text);line-height:1.3}
.catrev-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.catrev-dot{position:absolute;border-radius:50%;background:var(--c-color,var(--brand));opacity:.5;animation:catDot var(--ad,600ms) var(--ease-out) both}
.catrev-hidden{opacity:0;transform:translateY(14px)}
.catrev-visible{opacity:1;transform:none;transition:opacity .4s var(--ease-out),transform .4s var(--ease-out)}
@keyframes catDot{from{opacity:.6;transform:translate(0,0) scale(1)}to{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0)}}

/* ── PERSONAL SECTION ────────────────────────────────────────────── */
.personal-section{background:var(--n50);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.personal-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.personal-avatar-wrap{width:30px;height:30px;border-radius:8px;background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.personal-title{font-family:var(--f-display);font-size:1rem;font-weight:900;margin:0;color:var(--text);flex:1}
.personal-msg-badge{display:inline-flex;align-items:center;gap:5px;background:var(--brand);color:#fff;padding:5px 12px;border-radius:var(--r-pill);font-size:.72rem;font-weight:800;text-decoration:none}
.personal-grid{display:grid;gap:16px}
.personal-grid--2{grid-template-columns:1fr 1fr}
.personal-col-label{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:8px;font-family:var(--f-display)}
.personal-list{display:flex;flex-direction:column;gap:6px}
.personal-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface);border-radius:var(--r-md);border:1.5px solid var(--border);text-decoration:none;transition:border-color var(--t)}
.personal-item:hover{border-color:var(--brand)}
.personal-thumb{width:36px;height:36px;border-radius:7px;background:var(--n100);flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}
.personal-thumb img{width:100%;height:100%;object-fit:cover}
.personal-info{flex:1;min-width:0}
.personal-item-title{font-size:.78rem;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.personal-item-meta{font-size:.68rem;color:var(--text-3)}
.personal-item-price{font-size:.82rem;font-weight:800;color:var(--brand);white-space:nowrap}
.personal-see-all{font-size:.75rem;color:var(--brand);font-weight:700;text-decoration:none;padding:4px 0;display:block}

/* ── ACTIVITY BAR ────────────────────────────────────────────────── */
.activity-bar{background:var(--n800);padding:10px 0;overflow:hidden}
[data-theme="dark"] .activity-bar{background:#040608}
.activity-mask{mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,#000 8%,#000 92%,transparent)}
.activity-track{display:flex;gap:32px;width:max-content;animation:actScroll 40s linear infinite}
.activity-bar:hover .activity-track{animation-play-state:paused}
@keyframes actScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.activity-item{display:inline-flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap;flex-shrink:0}
.activity-dot{width:6px;height:6px;border-radius:50%;background:var(--success);flex-shrink:0}
.activity-time{font-size:.72rem;color:rgba(255,255,255,.4);font-weight:500}
.activity-title{font-size:.72rem;color:rgba(255,255,255,.8);font-weight:700}
.activity-city{font-size:.72rem;color:rgba(255,255,255,.3)}
.activity-price{font-size:.72rem;color:var(--brand);font-weight:800}

/* ── COMPARADOR CALLOUT ──────────────────────────────────────────── */
.comparador-callout{background:var(--brand-xs);border-top:1px solid rgba(232,114,10,.15);border-bottom:1px solid rgba(232,114,10,.15);padding:16px 0}
.comparador-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.comparador-text{display:flex;align-items:center;gap:12px}
.comparador-icon-wrap{width:40px;height:40px;border-radius:var(--r-md);background:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.comparador-title{font-family:var(--f-display);font-size:.9rem;font-weight:800;color:var(--text)}
.comparador-sub{font-size:.78rem;color:var(--text-2);margin-top:2px}
.comparador-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--brand);color:#fff;border-radius:var(--r-pill);font-family:var(--f-display);font-size:.82rem;font-weight:800;text-decoration:none;white-space:nowrap;transition:all var(--t)}
.comparador-btn:hover{background:var(--brand-dk);transform:scale(1.03)}

/* ── HOW IT WORKS ────────────────────────────────────────────────── */
.how-section{background:var(--surface);border-top:1px solid var(--border)}
.how-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(240px,100%),1fr));gap:20px}
.how-step{display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:24px;background:var(--surface);border-radius:var(--r-xl);border:1.5px solid var(--border);position:relative;transition:all var(--t)}
.how-step:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--brand)}
.how-step-num{position:absolute;top:-13px;left:22px;width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-family:var(--f-display);font-weight:900;font-size:.78rem;display:flex;align-items:center;justify-content:center}
.how-step-icon{width:52px;height:52px;border-radius:var(--r-md);background:var(--brand-xs);display:flex;align-items:center;justify-content:center;transition:transform var(--t)}
.how-step:hover .how-step-icon{transform:scale(1.1) rotate(-4deg)}
.how-step-title{font-family:var(--f-display);font-size:1rem;font-weight:800;color:var(--text);margin:0}
.how-step-desc{font-size:.82rem;color:var(--text-2);line-height:1.6;margin:0;flex:1}
.how-step-link{font-size:.78rem;color:var(--brand);font-weight:700;text-decoration:none;margin-top:auto}
.how-step-link:hover{text-decoration:underline}

/* ── SEO PARAGRAPH ───────────────────────────────────────────────── */
.seo-paragraph{border-top:1px solid var(--border)}
.seo-paragraph p{font-size:.88rem;color:var(--text-2);line-height:1.8;max-width:820px;margin:0 auto;text-align:center}

/* ── CTA SECTION ─────────────────────────────────────────────────── */
.cta-section{background:var(--brand-xs);border-top:1px solid rgba(232,114,10,.15);border-bottom:1px solid rgba(232,114,10,.15)}
.cta-inner{max-width:600px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.cta-sub{font-size:.92rem;color:var(--text-2);margin:0;line-height:1.6}
.cta-btn{display:inline-flex;align-items:center;gap:8px;padding:13px 32px;background:var(--brand);color:#fff;border:none;border-radius:var(--r-pill);font-family:var(--f-display);font-size:.98rem;font-weight:800;text-decoration:none;transition:all var(--t)}
.cta-btn:hover{background:var(--brand-dk);transform:translateY(-2px);box-shadow:var(--sh-brand)}
.city-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.city-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-pill);font-size:.82rem;font-weight:600;color:var(--text-2);text-decoration:none;transition:all var(--t)}
.city-chip:hover{border-color:var(--brand);color:var(--brand)}
.city-chip-count{font-size:.7rem;color:var(--text-3);font-weight:700}

/* ── AV-CARD (alias → ad-card classes) ──────────────────────────── */
.av-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;transition:all var(--t);position:relative}
.av-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:rgba(232,114,10,.35)}
.av-card--promoted{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand)}
.av-card-img-wrap{display:block;flex-shrink:0}
.av-card-img{position:relative;width:100%;padding-top:75%;overflow:hidden;background:var(--n50)}
[data-theme="dark"] .av-card-img{background:var(--n150)}
.av-card-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s var(--ease)}
.av-card:hover .av-card-photo{transform:scale(1.04)}
.av-card-nophoto{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;background:linear-gradient(135deg,var(--brand-xs),var(--n50))}
.av-card-nophoto-label{font-size:.65rem;color:var(--text-3);font-weight:700}
.av-card-sold-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--f-display);font-weight:800;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase}
.av-card-zoom{position:absolute;top:7px;right:7px;width:28px;height:28px;background:rgba(0,0,0,.45);border:none;border-radius:7px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;backdrop-filter:blur(2px);opacity:0;transition:opacity var(--t)}
.av-card:hover .av-card-zoom{opacity:1}
.av-card-prev,.av-card-next{position:absolute;top:50%;transform:translateY(-50%);width:26px;height:26px;background:rgba(0,0,0,.45);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;color:#fff;backdrop-filter:blur(2px);opacity:0;transition:opacity var(--t);font-size:1rem;line-height:1}
.av-card:hover .av-card-prev,.av-card:hover .av-card-next{opacity:1}
.av-card-prev{left:5px}
.av-card-next{right:5px}
.av-card-dots{position:absolute;bottom:5px;left:50%;transform:translateX(-50%);display:flex;gap:3px;z-index:3}
.card-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.45);transition:background var(--t);border:none;padding:0;cursor:pointer}
.card-dot--active{background:#fff}
.av-card-img-link{position:absolute;inset:0;z-index:1}
.av-card-body{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 14px 14px;flex:1;text-decoration:none;color:inherit;min-width:0}
.av-card-title{font-family:var(--f-display);font-size:.9rem;font-weight:800;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px;max-width:100%}
.av-card-price{font-family:var(--f-display);font-size:1.05rem;font-weight:900;color:var(--brand);margin-bottom:3px;white-space:nowrap}
.price-free{color:var(--success)!important}
.price-swap{color:var(--info)!important}
.av-card-city{display:flex;align-items:center;justify-content:center;gap:3px;font-size:.74rem;color:var(--text-2);margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.av-card-city svg{width:11px;height:11px;color:var(--brand);flex-shrink:0}
.av-card-dist{display:flex;align-items:center;justify-content:center;gap:3px;font-size:.65rem;font-weight:700;color:var(--text-3);margin-bottom:3px}
.av-card-dist svg{flex-shrink:0;color:var(--text-3)}
.av-card-top-seller{display:inline-flex;align-items:center;gap:4px;background:var(--brand-xs);color:var(--brand);border:1px solid rgba(232,114,10,.25);border-radius:6px;padding:2px 7px;font-size:.65rem;font-weight:800;margin-bottom:3px;width:fit-content}
.av-card-desc{font-size:.74rem;color:var(--text-2);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0 0 4px}
.av-card-time{font-size:.68rem;color:var(--text-3);margin-top:auto}
.av-card-fav{position:absolute;top:8px;left:8px;z-index:5;background:var(--surface);border:1.5px solid var(--brand);cursor:pointer;padding:5px;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all var(--t);box-shadow:var(--sh-xs)}
.av-card-fav:hover{background:var(--brand-xs);transform:scale(1.1)}
.av-card-fav.active{background:var(--brand-xs)}
.av-card-actions{display:flex;align-items:center;justify-content:space-around;padding:7px 10px;border-top:1px solid var(--border);background:var(--surface)}
.av-action-btn{background:none;border:none;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;color:var(--text-3);border-radius:6px;transition:all var(--t)}
.av-action-btn:hover{color:var(--brand);background:var(--n50)}
.av-action-btn.active{color:var(--danger)}
.alert-group,.contact-group{display:inline-flex;align-items:center;gap:0;flex-shrink:0}
.mob-filter-badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;border-radius:50%;background:var(--brand);color:#fff;font-size:.58rem;font-weight:900;text-align:center;line-height:16px;padding:0 3px;pointer-events:none;z-index:2}
.mob-filter-clear{position:absolute;top:-5px;left:-5px;width:16px;height:16px;border-radius:50%;background:#dc2626;color:#fff;font-size:.6rem;font-weight:900;text-decoration:none;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2}
.contact-chat-btn{color:var(--brand) !important}
.contact-chat-btn svg{stroke:var(--brand) !important}
.alert-eye-btn{display:none;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px 0 0 4px;background:rgba(34,197,94,.1);border:1px solid #22c55e;border-right:none;color:#22c55e;text-decoration:none;cursor:pointer;flex-shrink:0}
.alert-eye-btn.visible{display:flex}
.alert-toggle-btn.alert-active{color:#22c55e}
.alert-toggle-btn.alert-active svg{stroke:#22c55e}
.alert-group .alert-toggle-btn.alert-active{border-radius:0 4px 4px 0;background:rgba(34,197,94,.1);border:1px solid #22c55e;border-left:none}
.av-action-btn--chat:hover{color:var(--info)}
.av-list-actions{display:none;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:8px 10px;border-left:1px solid var(--border);flex-shrink:0}
.av-card-skeleton .sk-img{height:180px;background:var(--n100)}
.av-card-skeleton .sk-body{padding:12px;display:flex;flex-direction:column;gap:8px}
.sk-img{height:180px;background:linear-gradient(90deg,var(--n100) 25%,var(--n50) 50%,var(--n100) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:0}
.sk-line{background:var(--n100);border-radius:4px}
.sk-line--price{height:18px;width:40%}
.sk-line--title{height:14px;width:80%}
.sk-line--city{height:11px;width:55%}
.sk-line--time{height:10px;width:30%;margin-top:4px}

/* List view for av-card */
#ads-container.view-list .av-card,.listings-grid.view-list .av-card{flex-direction:row!important;min-height:120px;transform:none!important}
#ads-container.view-list .av-card-img-wrap{width:180px!important;min-width:180px!important;flex-shrink:0;overflow:hidden}
#ads-container.view-list .av-card-img{padding-top:0!important;height:100%!important;min-height:120px}
#ads-container.view-list .av-card-body{flex:1;min-width:0;overflow:hidden;align-items:flex-start;text-align:left}
#ads-container.view-list .av-list-actions{display:flex!important}
#ads-container.view-list .av-card-actions{display:none!important}

/* ── LISTINGS PAGE ─────────────────────────────────────────────── */
.listings-page-wrap{max-width:var(--container);margin:0 auto;padding:20px 24px}
.listings-content{display:flex;flex-direction:column;gap:0}
.cat-chips-strip{display:flex;gap:7px;overflow-x:auto;padding:0 0 10px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.cat-chips-strip::-webkit-scrollbar{display:none}
.cat-chip-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-pill);border:1.5px solid var(--border);color:var(--text-2);font-size:.8rem;font-weight:600;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:all var(--t);background:var(--surface)}
.cat-chip-pill:hover{border-color:var(--brand);color:var(--brand)}
.cat-chip-pill.is-active{border-color:var(--brand);background:var(--brand-xs);color:var(--brand);font-weight:700}
.listings-topbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:14px}
.listings-title{font-family:var(--f-display);font-size:1.05rem;font-weight:800;color:var(--text);margin:0}
.listings-count-label{font-size:.8rem;color:var(--text-2);font-weight:600}
.listings-controls{display:flex;align-items:center;gap:8px}
.listings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(240px,100%),1fr));gap:14px}
.breadcrumb{font-size:.76rem;color:var(--text-3);display:flex;align-items:center;gap:5px;flex-wrap:wrap;padding:14px 0 6px}
.breadcrumb a{color:var(--text-3);text-decoration:none;transition:color var(--t)}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb-sep{opacity:.4}
.breadcrumb-current{color:var(--text);font-weight:600}
.inline-filters{display:flex;align-items:center;gap:16px;padding:10px 0;flex-wrap:wrap;border-bottom:1px solid var(--border);margin-bottom:14px}
.inl-filter{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.inl-filter-lbl{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);white-space:nowrap;font-family:var(--f-display)}
.inl-filter-opts{display:flex;gap:5px;flex-wrap:wrap}
.inl-opt{padding:4px 10px;border-radius:var(--r-pill);font-size:.78rem;font-weight:600;color:var(--text-2);border:1.5px solid var(--border);text-decoration:none;transition:all var(--t);white-space:nowrap;background:var(--surface)}
.inl-opt:hover{border-color:var(--brand);color:var(--brand)}
.inl-opt--on{background:var(--brand);color:#fff;border-color:var(--brand)}
.inl-price-input{width:70px;padding:5px 8px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:.8rem;background:var(--surface);outline:none;color:var(--text)}
.inl-price-input:focus{border-color:var(--brand)}
.inl-apply-btn{padding:5px 10px;border-radius:var(--r-sm);background:var(--brand);color:#fff;font-size:.75rem;font-weight:700;border:none;cursor:pointer;font-family:var(--f-display)}
.inl-city-sel{padding:5px 28px 5px 10px;border-radius:var(--r-sm);border:1.5px solid var(--border);font-size:.8rem;background:var(--surface);outline:none;cursor:pointer;color:var(--text)}
.inl-city-sel:focus{border-color:var(--brand)}
.inl-filter+.inl-filter{padding-left:16px;border-left:1px solid var(--border)}
.sort-dropdown{position:relative;display:inline-block}
.sort-trigger{display:flex;align-items:center;gap:6px;padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--t);white-space:nowrap;min-width:140px}
.sort-trigger:hover{border-color:var(--brand)}
.sort-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);padding:4px;min-width:200px;z-index:500;box-shadow:var(--sh-lg);animation:dropIn .15s var(--ease-out)}
.sort-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r-sm);font-size:.84rem;font-weight:500;color:var(--text);text-decoration:none;transition:background var(--t);white-space:nowrap}
.sort-item:hover{background:var(--n50)}
.sort-item--on{background:var(--brand-xs);color:var(--brand);font-weight:700}
.active-chips{display:flex;flex-wrap:wrap;gap:6px;padding:8px 0;margin-bottom:6px}
.filter-chip-tag{display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--brand-xs);color:var(--brand);font-size:.75rem;font-weight:700;border-radius:var(--r-pill);transition:all var(--t);border:1.5px solid rgba(232,114,10,.2)}
.filter-chip-tag:hover{background:var(--danger);color:#fff;border-color:transparent}
.listings-empty{text-align:center;padding:60px 20px;max-width:440px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.listings-empty-icon{width:72px;height:72px;border-radius:50%;background:var(--n50);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.listings-empty h3{font-family:var(--f-display);font-size:1.05rem;font-weight:800;color:var(--text);margin:0 0 7px}
.listings-empty p{font-size:.85rem;color:var(--text-2);margin:0 0 18px;line-height:1.6}
.load-more-wrap{text-align:center;margin-top:28px;padding-bottom:8px}
.load-more-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 32px;background:var(--surface);border:2px solid var(--brand);color:var(--brand);border-radius:var(--r-pill);font-family:var(--f-display);font-size:.88rem;font-weight:800;cursor:pointer;transition:all var(--t)}
.load-more-btn:hover{background:var(--brand);color:#fff;transform:translateY(-1px)}
.alert-banner{display:flex;align-items:center;gap:12px;background:var(--brand-xs);border:1px solid rgba(232,114,10,.2);border-radius:var(--r-md);padding:10px 14px;margin-bottom:12px;font-size:.8rem}
.alert-banner-text{flex:1;color:var(--text-2)}
.alert-banner-btn{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:5px 12px;font-size:.75rem;font-weight:700;cursor:pointer;transition:background var(--t);font-family:inherit}
.alert-banner-btn:hover{background:var(--brand-dk)}
.alert-banner-close{background:none;border:none;cursor:pointer;color:var(--text-3);opacity:.5;padding:4px;flex-shrink:0}

/* ── FILTER PANEL (fp) ───────────────────────────────────────────── */
.fp-overlay{display:none;position:fixed;inset:0;background:var(--overlay);z-index:800}
.fp-panel{display:none;position:fixed;top:0;right:0;width:320px;max-width:100vw;height:100vh;background:var(--surface);z-index:801;flex-direction:column;box-shadow:var(--sh-xl);overflow:hidden}
.fp-panel.is-open{display:flex}
.fp-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.fp-header-title{font-family:var(--f-display);font-weight:800;font-size:.95rem;color:var(--text)}
.fp-close-btn{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-2);display:flex}
.fp-body{flex:1;overflow-y:auto}
.fp-footer{padding:14px 18px;border-top:1px solid var(--border)}
.fp-submit-btn{width:100%;padding:12px;background:var(--brand);color:#fff;border:none;border-radius:var(--r-md);font-weight:800;font-size:.9rem;cursor:pointer;font-family:var(--f-display);transition:background var(--t)}
.fp-submit-btn:hover{background:var(--brand-dk)}
.fp-clear-btn{display:block;text-align:center;padding:11px;background:var(--n50);color:var(--text-2);border-radius:var(--r-md);font-weight:700;font-size:.875rem;text-decoration:none;margin-top:8px;transition:all var(--t)}
.fp-clear-btn:hover{background:var(--n100)}
.fp-menu-item{display:flex!important;align-items:center!important;justify-content:space-between!important;width:100%!important;padding:15px 20px!important;background:none!important;border:none!important;border-bottom:1px solid var(--border)!important;font-size:.9rem!important;font-weight:600!important;color:var(--text)!important;cursor:pointer!important;text-align:left!important;transition:background var(--t)!important}
.fp-menu-item:hover{background:var(--n50)!important}
.fp-section-badge{color:var(--brand);font-size:.75rem}
.fp-section{display:none;flex-direction:column;height:100%}
.fp-section.is-active{display:flex}
.fp-section-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.fp-back-btn{background:none;border:none;cursor:pointer;padding:4px;color:var(--text-2);display:flex}
.fp-section-clear{color:var(--brand);font-size:.82rem;font-weight:700;text-decoration:none}
.fp-radio-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;transition:background var(--t)}
.fp-radio-row:hover{background:var(--n50)}
.fp-radio-row-label{font-size:.9rem;font-weight:600}
.fp-radio-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color var(--t)}
.fp-radio-dot.is-selected{border-color:var(--brand)}
.fp-radio-dot.is-selected::after{content:'';width:10px;height:10px;border-radius:50%;background:var(--brand)}
.fp-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;cursor:pointer}
.fp-toggle-label{font-size:.9rem;font-weight:600;color:var(--text)}
.fp-toggle-switch{width:44px;height:24px;border-radius:var(--r-pill);background:var(--n200);position:relative;transition:background var(--t)}
.fp-toggle-switch.is-on{background:var(--success)}
.fp-toggle-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform var(--t)}
.fp-toggle-switch.is-on .fp-toggle-knob{transform:translateX(20px)}

/* ── PHASE 2 RESPONSIVE ──────────────────────────────────────────── */
@media (max-width:900px){
  .hero-content{grid-template-columns:1fr}
  .hero-visual-col{display:none}
  .trust-inner{gap:24px}
  .personal-grid--2{grid-template-columns:1fr}
}
@media (max-width:640px){
  .hero-ctas{flex-direction:column;align-items:flex-start}
  .trust-inner{flex-direction:column;gap:16px;align-items:flex-start;padding:0 16px}
  .comparador-inner{flex-direction:column}
  .catrev-grid{grid-template-columns:repeat(3,1fr)}
  .listings-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .inline-filters{gap:10px}
  .inl-filter+.inl-filter{border-left:none;padding-left:0}
  #ads-container{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}
}
@media (max-width:400px){
  .catrev-grid{grid-template-columns:repeat(2,1fr)}
  .listings-grid{grid-template-columns:1fr}
  #ads-container{grid-template-columns:1fr!important}
}

/* ── INDEX MISSING CLASSES ───────────────────────────────────────── */
.catrev-icon svg{color:var(--c-color,var(--brand));width:24px;height:24px}
.cta-text{font-family:var(--f-display);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:900;color:var(--text);margin:0}
.empty{text-align:center;padding:48px 20px;display:flex;flex-direction:column;align-items:center;gap:12px}
.empty-icon{width:64px;height:64px;border-radius:var(--r-xl);background:var(--n50);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center}
.empty h3{font-family:var(--f-display);font-size:1.05rem;font-weight:800;color:var(--text);margin:0}
.empty p{color:var(--text-2);max-width:300px;font-size:.875rem;margin:0}
.h-sep{width:1px;height:36px;background:var(--border);flex-shrink:0}
.hero-cat-select{padding:0 14px;background:transparent;border:none;font-size:.875rem;font-weight:600;color:var(--text-2);outline:none;cursor:pointer;min-width:130px;appearance:none;-webkit-appearance:none}
.hero-search-btn{padding:12px 22px;background:var(--brand);color:#fff;font-family:var(--f-display);font-size:.9rem;font-weight:700;border:none;cursor:pointer;transition:background var(--t);flex-shrink:0;border-radius:0 var(--r-xl) var(--r-xl) 0}
.hero-search-btn:hover{background:var(--brand-dk)}
.hero-stat{text-align:center}
.trust-label strong{display:block;font-family:var(--f-display);font-size:.84rem;font-weight:700;color:var(--text)}
.trust-label span{font-size:.73rem;color:var(--text-3)}
/* Recently viewed cards */
.rv-card{text-decoration:none;display:flex;flex-direction:column;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all var(--t)}
.rv-card:hover{box-shadow:var(--sh-md);border-color:var(--brand);transform:translateY(-2px)}
.rv-card-img{width:100%;height:130px;object-fit:cover}
.rv-card-placeholder{width:100%;height:130px;background:var(--n100)}
.rv-card-body{padding:10px 12px}
.rv-price{font-family:var(--f-display);font-weight:900;color:var(--brand);font-size:.92rem;margin-bottom:2px}
.rv-title{font-size:.8rem;color:var(--text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* Section headings */
.wrap .section-title,.wrap h2.section-title{font-family:var(--f-display);font-size:clamp(1.2rem,2.5vw,1.6rem);font-weight:800;color:var(--text);margin:0 0 20px}

/* ── LISTINGS MISSING ────────────────────────────────────────────── */
.btn-filter-toggle{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--brand);color:#fff;border:none;border-radius:var(--r-pill);font-size:.84rem;font-weight:700;font-family:var(--f-display);cursor:pointer;transition:all var(--t)}
.btn-filter-toggle:hover{background:var(--brand-dk)}
.listings-info{display:flex;align-items:center;gap:10px;flex:1}
.listings-empty-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:8px}
.load-more-count{opacity:.6;font-weight:600;font-size:.78rem}
.load-more-done{font-size:.82rem;color:var(--text-3);padding:8px;text-align:center}
.load-more-page{font-size:.75rem;color:var(--text-3);margin-top:10px;text-align:center}
.load-more-spinner{display:none;margin:14px auto}
.fp-divider{height:1px;background:var(--border);margin:6px 0}
.sort-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:var(--r-pill);border:1.5px solid var(--border);color:var(--text-2);font-size:.75rem;font-weight:600;text-decoration:none;white-space:nowrap;flex-shrink:0;transition:all var(--t);background:var(--surface)}
.sort-pill:hover{border-color:var(--brand);color:var(--brand)}
.sort-pill.is-active{border-color:var(--brand);background:var(--brand-xs);color:var(--brand)}
.chat-voice-btn,.chat-msg-system{display:none}

/* ── LISTINGS LAYOUT FIX ─────────────────────────────────────────── */
/* listings.html usa full-width (sin sidebar), filtros en panel flotante */
.listings-wrap{display:block!important;max-width:var(--container);margin:0 auto;padding:0 24px}
.listings-content{display:flex;flex-direction:column;gap:0}
.listings-grid.view-grid,#ads-container.view-grid{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(min(240px,100%),1fr))!important;gap:14px!important}
.listings-grid.view-list,#ads-container.view-list{display:flex!important;flex-direction:column!important;gap:8px!important}
@media(max-width:768px){
  .listings-wrap{padding:0 3px !important;max-width:100% !important;width:100% !important;box-sizing:border-box !important;margin:0 !important}
  .listings-page-wrap{padding:0 3px !important;max-width:100% !important;width:100% !important;box-sizing:border-box !important}
  .listings-content{padding-left:0 !important;padding-right:0 !important;margin:0 !important}
  #main-content{padding-left:0 !important;padding-right:0 !important}
  #ads-container,.listings-grid,.ads-grid,
  .listings-grid.view-grid,#ads-container.view-grid{grid-template-columns:repeat(2,1fr)!important;gap:4px !important;padding:0 !important}
}
@media(max-width:360px){
  .listings-grid.view-grid,#ads-container.view-grid{grid-template-columns:1fr!important}
}
/* Skeleton cards inside listings grid */
.listings-grid .av-card-skeleton,#ads-container .av-card-skeleton{animation:skeleton-pulse 1.5s ease-in-out infinite}
@keyframes skeleton-pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* ═══════════════════════════════════════════════════════════════
   AD DETAIL PAGE
   ═══════════════════════════════════════════════════════════════ */

/* ── LAYOUT ─────────────────────────────────────────────────── */
.detail-layout{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:flex-start;max-width:var(--container);margin:0 auto;padding:20px 24px}
.detail-left{display:flex;flex-direction:column;gap:16px;min-width:0}
.detail-sidebar{display:flex;flex-direction:column;gap:14px;position:sticky;top:calc(var(--navbar-h) + env(safe-area-inset-top) + 14px)}
.ads-grid--4{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));gap:14px}

/* ── GALLERY ─────────────────────────────────────────────────── */
.gal-wrap{background:var(--n50);border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--border);position:relative;max-width:100%}
.gal-main{aspect-ratio:4/3;overflow:hidden;position:relative;background:var(--n100);cursor:pointer}
.gal-main img{width:100%;height:100%;object-fit:contain;display:block;transition:transform .3s var(--ease)}
.gal-main:hover img{transform:scale(1.02)}
.gal-sold{position:absolute;top:12px;left:12px;background:rgba(0,0,0,.72);color:#fff;font-size:.72rem;font-weight:800;font-family:var(--f-display);padding:4px 12px;border-radius:var(--r-pill);pointer-events:none}
.gal-nav{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;background:rgba(255,255,255,.92);border:none;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm);transition:all var(--t);z-index:2;backdrop-filter:blur(4px)}
.gal-nav:hover{background:var(--surface);box-shadow:var(--sh-md)}
.gal-prev{left:10px}
.gal-next{right:10px}
.gal-zoom-btn{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.55);border:none;border-radius:var(--r-pill);color:#fff;padding:5px 14px;font-size:.72rem;font-weight:700;font-family:var(--f-display);cursor:pointer;display:flex;align-items:center;gap:5px;backdrop-filter:blur(4px);transition:background var(--t);z-index:2}
.gal-zoom-btn:hover{background:rgba(0,0,0,.75)}
.gal-count{position:absolute;bottom:10px;right:12px;background:rgba(0,0,0,.5);color:#fff;font-size:.7rem;font-weight:700;font-family:var(--f-display);padding:3px 9px;border-radius:var(--r-pill);pointer-events:none}
.gal-thumbs{display:flex;gap:6px;padding:8px;background:var(--n50);overflow-x:auto;scrollbar-width:thin}
.gal-thumb{width:68px;height:50px;border-radius:var(--r-sm);overflow:hidden;border:2.5px solid transparent;cursor:pointer;flex-shrink:0;padding:0;background:none;transition:border-color var(--t);display:block}
.gal-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.gal-thumb.on{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand)}
.gal-thumb:hover:not(.on){border-color:var(--n300)}
.gal-placeholder{aspect-ratio:4/3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--n300);background:var(--n50);border-radius:var(--r-xl)}
.gal-placeholder svg{width:48px;height:48px;opacity:.4}

/* ── LIGHTBOX ─────────────────────────────────────────────────── */
#lightbox{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.94);align-items:center;justify-content:center;flex-direction:column}
#lightbox.open{display:flex}
#lightbox-img{max-width:90vw;max-height:82vh;object-fit:contain;border-radius:8px;user-select:none}
.lb-close{position:fixed;top:16px;right:16px;width:42px;height:42px;background:rgba(255,255,255,.12);border:none;border-radius:50%;color:#fff;font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.lb-close:hover{background:rgba(255,255,255,.25)}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);width:48px;height:48px;background:rgba(255,255,255,.12);border:none;border-radius:50%;color:#fff;font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--t)}
.lb-nav:hover{background:rgba(255,255,255,.28)}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-count{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.8rem;font-weight:700;font-family:var(--f-display)}

/* ── PRICE CARD (pc) ──────────────────────────────────────────── */
.pc{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:18px}
.pc-price{font-family:var(--f-display);font-weight:900;font-size:1.8rem;color:var(--brand);line-height:1;margin-bottom:8px;display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.pc-neg{background:var(--brand-xs);color:var(--brand);font-size:.65rem;font-weight:800;font-family:var(--f-display);padding:3px 10px;border-radius:var(--r-pill);border:1px solid rgba(232,114,10,.25)}
.pc-title{font-family:var(--f-display);font-weight:800;font-size:1.05rem;line-height:1.3;color:var(--text);margin-bottom:12px}
.pc-city{font-size:.82rem;color:var(--text-2);display:flex;align-items:center;gap:5px;margin-bottom:14px;font-weight:600}
.pc-city svg{width:13px;height:13px;color:var(--brand);flex-shrink:0}
.pc-sold{background:var(--danger-bg);color:var(--danger);border-radius:var(--r-md);padding:10px 14px;font-size:.85rem;font-weight:700;text-align:center;margin-bottom:12px}
.pc-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:8px;margin-bottom:10px}
.pc-action-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;background:var(--n50);border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;text-decoration:none;color:var(--text-2);font-size:.72rem;font-weight:700;font-family:var(--f-display);transition:all var(--t)}
.pc-action-btn:hover{background:var(--n100);transform:translateY(-1px)}
.pc-action-btn svg{flex-shrink:0}
.pc-action-btn--call{color:var(--success);background:var(--success-bg);border-color:rgba(21,128,61,.2)}
.pc-action-btn--call:hover{background:#dcfce7}
.pc-action-btn--voice{background:var(--brand);border-color:var(--brand);color:#fff}
.pc-action-btn--voice:hover{background:var(--brand-dk)}
.pc-action-btn--disabled{background:var(--n50);border-color:var(--border);color:var(--n300);cursor:not-allowed}
.pc-ref{display:flex;justify-content:flex-end;margin-bottom:4px;font-size:.68rem;color:var(--text-3);font-family:var(--f-display);font-weight:600}

/* ── SELLER CARD (sc) ─────────────────────────────────────────── */
.sc{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:16px}
.sc h3{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-family:var(--f-display);margin:0 0 12px}
.sc-profile{display:flex;align-items:center;gap:10px;margin-bottom:12px;text-decoration:none;color:inherit}
.sc-av{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--brand);color:#fff;font-family:var(--f-display);font-weight:800;font-size:1rem;display:flex;align-items:center;justify-content:center}
.sc-name{font-weight:800;font-family:var(--f-display);font-size:.9rem;color:var(--text)}
.sc-city{font-size:.74rem;color:var(--text-3);display:flex;align-items:center;gap:3px;margin-top:2px}
.sc-stats{display:flex;gap:0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:12px}
.sc-stat{flex:1;padding:8px;text-align:center;border-right:1px solid var(--border)}
.sc-stat:last-child{border-right:none}
.sc-stat strong{display:block;font-family:var(--f-display);font-weight:800;font-size:.9rem;color:var(--brand)}
.sc-stat span{font-size:.68rem;color:var(--text-3)}
.btn-all-ads{display:block;text-align:center;padding:10px;background:var(--brand);color:#fff;font-family:var(--f-display);font-weight:800;font-size:.83rem;border-radius:var(--r-md);text-decoration:none;transition:background var(--t)}
.btn-all-ads:hover{background:var(--brand-dk)}
.btn-contact-main{display:block;background:var(--brand);color:#fff;font-family:var(--f-display);font-weight:800;font-size:.95rem;text-align:center;padding:13px;border-radius:var(--r-md);border:none;width:100%;cursor:pointer;text-decoration:none;transition:all var(--t);margin-bottom:10px}
.btn-contact-main:hover{background:var(--brand-dk);transform:translateY(-1px)}
.btn-contact-edit{background:var(--n50)!important;border:1.5px solid var(--border)!important;color:var(--text)!important}
.btn-contact-confirm{background:var(--success)!important}
.btn-fav{width:100%;display:flex;align-items:center;justify-content:center;gap:7px;padding:10px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text-2);font-size:.83rem;font-weight:700;font-family:var(--f-display);cursor:pointer;transition:all var(--t)}
.btn-fav:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-xs)}
.btn-fav.active{background:var(--brand-xs);border-color:var(--brand);color:var(--brand)}
.btn-fav svg{width:16px;height:16px;flex-shrink:0}
.btn-fav.active svg{fill:var(--brand);stroke:var(--brand)}
.seller-name-center{text-align:center;font-size:.8rem;font-weight:800;font-family:var(--f-display);color:var(--text-2);margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:5px}
.seller-name-center::after{content:'✓';color:var(--brand)}

/* ── DESCRIPTION CARD ─────────────────────────────────────────── */
.desc-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:18px}
.desc-card h2{font-size:.88rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-family:var(--f-display);margin:0 0 10px}
.desc-text{font-size:.9rem;line-height:1.7;color:var(--text);white-space:pre-wrap;word-break:break-word}
.spec-table{width:100%;margin-top:14px;border-collapse:collapse}
.spec-table tr{border-bottom:1px solid var(--border)}
.spec-table tr:last-child{border-bottom:none}
.spec-table td{padding:7px 0;font-size:.83rem}
.spec-table td:first-child{color:var(--text-3);font-weight:700;width:110px;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
.condition-pill{display:inline-block;padding:3px 10px;border-radius:var(--r-pill);font-size:.72rem;font-weight:800;font-family:var(--f-display)}
.condition-pill--nuevo,.condition-pill--como_nuevo{background:var(--success-bg);color:var(--success)}
.condition-pill--muy_bueno,.condition-pill--bueno{background:var(--info-bg);color:var(--info)}
.condition-pill--aceptable{background:var(--danger-bg);color:var(--danger)}

/* ── MINI MAP ─────────────────────────────────────────────────── */
.mini-map-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.mini-map-header{padding:10px 14px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.mini-map-header h4{font-size:.82rem;font-weight:700;font-family:var(--f-display);margin:0;display:flex;align-items:center;gap:5px;color:var(--text)}
.mini-map-link{font-size:.75rem;color:var(--brand);font-weight:700;text-decoration:none}

/* ── SHARE & SAFETY ───────────────────────────────────────────── */
.share-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:14px 16px;text-align:center;margin-top:12px}
.share-label{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);font-family:var(--f-display);margin-bottom:10px;text-align:center}
.share-row{display:flex;gap:7px;flex-wrap:wrap;justify-content:center}
.sh-btn{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;border:none;flex-shrink:0;transition:transform var(--t),opacity var(--t);text-decoration:none}
.sh-btn:hover{transform:translateY(-2px);opacity:.9}
.sh-wa{background:#25D366}.sh-tg{background:#0088cc}.sh-x{background:#000}.sh-fb{background:#1877F2}.sh-copy{background:var(--n400)}
.sh-copy.ok{background:var(--success)}
.safety-card{background:var(--n50);border:1.5px solid var(--border);border-radius:var(--r-xl);padding:14px 16px}
.safety-card h4{font-size:.78rem;font-weight:800;font-family:var(--f-display);margin:0 0 8px;color:var(--text-2);text-transform:uppercase;letter-spacing:.07em}
.safety-card ul{padding-left:14px;margin:0;display:flex;flex-direction:column;gap:4px}
.safety-card li{font-size:.78rem;color:var(--text-2)}

/* ── SIMILAR ADS SECTION ──────────────────────────────────────── */
.section-block{margin-top:32px;padding-top:20px;border-top:1.5px solid var(--border)}
.section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-bottom:10px;border-bottom:1.5px solid var(--border)}
.section-hdr h2{font-family:var(--f-display);font-weight:800;font-size:1rem;margin:0;color:var(--text)}
.section-hdr a{font-size:.82rem;color:var(--brand);font-weight:700;text-decoration:none}

/* ── AD STICKY CTA (mobile) ───────────────────────────────────── */
#ad-sticky-cta{display:none}
@media(max-width:768px){
  .detail-layout{grid-template-columns:1fr!important;padding:14px}
  .detail-sidebar{position:static!important;top:auto!important}
  #ad-sticky-cta{display:flex!important;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1.5px solid var(--border);padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom));z-index:200;gap:10px;box-shadow:0 -4px 20px rgba(0,0,0,.1)}
}
@media(max-width:640px){
  .gal-thumbs{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding:6px 8px}
  .gal-thumb{width:56px;height:44px;flex-shrink:0}
  .ads-grid--4{grid-template-columns:repeat(2,1fr)}
}

/* ── REMAINING MISSING CLASSES ───────────────────────────────────── */
/* fav-btn (grid) */
.fav-btn{cursor:pointer;background:none;border:none;display:flex;align-items:center;justify-content:center;transition:all var(--t)}
/* compare toggle */
.compare-toggle-btn.in-compare{color:var(--brand)!important}
/* view toggle */
.view-toggle{display:flex;gap:2px;background:var(--n50);border-radius:var(--r-md);padding:3px}
/* trust-label (already in trust-strip section, alias) */
/* mt-8 */
.mt-8{margin-top:8px}
/* pc owner actions */
.pc-owner-actions{display:flex;flex-direction:column;gap:8px;margin-top:10px}
/* pc reserved */
.pc-reserved-badge{display:flex;align-items:center;gap:10px;padding:10px 13px;background:var(--warning-bg);border:1.5px solid rgba(217,119,6,.25);border-radius:var(--r-md);margin-top:8px}
.pc-reserved-title{font-weight:800;color:var(--warning);font-size:.83rem;font-family:var(--f-display)}
.pc-reserved-countdown{font-size:.72rem;color:var(--warning);margin-top:1px}
/* pc voice */
.pc-voice-zone{margin-bottom:10px}
/* reserve btn */
.reserve-btn{flex:1;padding:9px 6px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text);font-weight:700;font-size:.8rem;font-family:var(--f-display);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:all var(--t)}
.reserve-btn:hover{border-color:var(--brand);color:var(--brand)}
/* seller profile link */
.seller-profile-link{text-decoration:none;color:inherit}

/* ════════════════════════════════════════════════════════════════════
   FASE 3 — USER TEMPLATES
   auth · errors · dashboard · profile · my-ads · favorites · wallet
   chat · post-ad · auctions · map · subscriptions · transactions · rep
   ════════════════════════════════════════════════════════════════════ */

/* ── AUTH (login / register / password reset) ────────────────────── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 16px;background:var(--bg)}
.auth-card{width:100%;max-width:440px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:40px 36px;box-shadow:var(--shadow-md)}
.auth-logo{display:flex;justify-content:center;margin-bottom:28px}
.auth-logo img{height:38px}
.auth-title{font-family:var(--f-display);font-size:1.5rem;font-weight:800;color:var(--text);text-align:center;margin:0 0 4px}
.auth-subtitle{text-align:center;color:var(--text-muted);font-size:.875rem;margin:0 0 28px}
.auth-form{display:flex;flex-direction:column;gap:16px}
.auth-field{display:flex;flex-direction:column;gap:6px}
.auth-label{font-size:.82rem;font-weight:700;color:var(--text-secondary);font-family:var(--f-display)}
.auth-input{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-size:.9rem;font-family:var(--f-body);transition:border-color var(--t)}
.auth-input:focus{outline:none;border-color:var(--brand)}
.auth-input.error{border-color:var(--error)}
.auth-error-msg{font-size:.78rem;color:var(--error);margin-top:2px}
.auth-btn{padding:11px;border-radius:var(--r-md);background:var(--brand);color:#fff;font-weight:800;font-family:var(--f-display);font-size:.95rem;border:none;cursor:pointer;transition:background var(--t)}
.auth-btn:hover{background:var(--brand-hover)}
.auth-divider{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:.8rem}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-social{display:flex;flex-direction:column;gap:10px}
.auth-social-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:10px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-weight:600;font-size:.88rem;cursor:pointer;transition:all var(--t)}
.auth-social-btn:hover{border-color:var(--brand);background:var(--n50)}
.auth-social-btn img{width:18px;height:18px}
.auth-footer{text-align:center;font-size:.83rem;color:var(--text-muted);margin-top:20px}
.auth-footer a{color:var(--brand);font-weight:700;text-decoration:none}
.auth-footer a:hover{text-decoration:underline}
.auth-alert{padding:10px 14px;border-radius:var(--r-md);font-size:.85rem;margin-bottom:8px}
.auth-alert.success{background:var(--success-bg);color:var(--success);border:1px solid rgba(22,163,74,.2)}
.auth-alert.danger{background:var(--error-bg);color:var(--error);border:1px solid rgba(220,38,38,.2)}
.auth-forgot{font-size:.8rem;color:var(--brand);text-align:right;text-decoration:none;font-weight:600}
.auth-forgot:hover{text-decoration:underline}
.auth-terms{font-size:.76rem;color:var(--text-muted);text-align:center;line-height:1.5}
.auth-terms a{color:var(--brand);text-decoration:none}
@media(max-width:480px){.auth-card{padding:28px 20px}}

/* ── ERROR PAGES (404 · 500 · 403) ──────────────────────────────── */
.error-page{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 24px}
.error-code{font-family:var(--f-display);font-size:7rem;font-weight:900;color:var(--brand);line-height:1;letter-spacing:-4px}
.error-title{font-family:var(--f-display);font-size:1.6rem;font-weight:800;color:var(--text);margin:8px 0 12px}
.error-desc{color:var(--text-muted);max-width:420px;line-height:1.6;margin:0 auto 28px}
.error-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.error-btn-home{padding:11px 24px;background:var(--brand);color:#fff;border-radius:var(--r-md);font-weight:800;font-family:var(--f-display);font-size:.9rem;text-decoration:none;transition:background var(--t)}
.error-btn-home:hover{background:var(--brand-hover)}
.error-btn-back{padding:11px 24px;border:1.5px solid var(--border);border-radius:var(--r-md);font-weight:700;font-family:var(--f-display);font-size:.9rem;text-decoration:none;color:var(--text);transition:all var(--t)}
.error-btn-back:hover{border-color:var(--brand);color:var(--brand)}
.error-illustration{font-size:5rem;margin-bottom:16px;opacity:.8}

/* ── DASHBOARD LAYOUT (dp-*) ─────────────────────────────────────── */
.dp-layout{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 64px);max-width:1280px;margin:0 auto;padding:32px 24px;gap:32px}
.dp-sidebar{position:sticky;top:80px;align-self:start}
.dp-sidebar-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.dp-user-block{padding:20px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}
.dp-user-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--brand)}
.dp-user-name{font-family:var(--f-display);font-weight:800;font-size:.95rem;color:var(--text)}
.dp-user-role{font-size:.75rem;color:var(--text-muted);margin-top:1px}
.dp-nav{padding:10px 0}
.dp-nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:all var(--t);border-left:3px solid transparent;font-family:var(--f-display)}
.dp-nav-item:hover{color:var(--text);background:var(--n50)}
.dp-nav-item.active{color:var(--brand);background:var(--brand-bg);border-left-color:var(--brand)}
.dp-nav-item i,.dp-nav-item svg{width:16px;opacity:.7}
.dp-nav-separator{height:1px;background:var(--border);margin:6px 16px}
.dp-nav-label{padding:8px 16px 4px;font-size:.7rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-family:var(--f-display)}
.dp-main{min-width:0}
.dp-header{margin-bottom:24px}
.dp-page-title{font-family:var(--f-display);font-size:1.5rem;font-weight:900;color:var(--text);margin:0}
.dp-page-subtitle{color:var(--text-muted);font-size:.875rem;margin:4px 0 0}
.dp-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.dp-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 18px}
.dp-stat-value{font-family:var(--f-display);font-size:1.6rem;font-weight:900;color:var(--text)}
.dp-stat-label{font-size:.78rem;color:var(--text-muted);margin-top:2px}
.dp-stat-badge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:700;padding:2px 7px;border-radius:20px;margin-top:6px}
.dp-stat-badge.up{background:var(--success-bg);color:var(--success)}
.dp-stat-badge.down{background:var(--error-bg);color:var(--error)}
.dp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin-bottom:24px}
.dp-card-title{font-family:var(--f-display);font-size:1rem;font-weight:800;color:var(--text);margin:0 0 16px;display:flex;align-items:center;justify-content:space-between}
.dp-card-link{font-size:.8rem;color:var(--brand);text-decoration:none;font-weight:600}
@media(max-width:900px){
  .dp-layout{grid-template-columns:1fr;padding:16px}
  .dp-sidebar{position:static}
  .dp-stats-row{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){.dp-stats-row{grid-template-columns:1fr}}

/* ── PROFILE / PROFILE-EDIT ──────────────────────────────────────── */
.prof-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px;display:flex;align-items:flex-start;gap:24px;margin-bottom:24px}
.prof-avatar-wrap{position:relative;flex-shrink:0}
.prof-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--brand)}
.prof-avatar-edit{position:absolute;bottom:2px;right:2px;width:28px;height:28px;background:var(--brand);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.7rem;border:2px solid var(--surface)}
.prof-info{flex:1;min-width:0}
.prof-name{font-family:var(--f-display);font-size:1.4rem;font-weight:900;color:var(--text);margin:0 0 4px}
.prof-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.8rem;color:var(--text-muted);margin-bottom:12px}
.prof-meta-item{display:flex;align-items:center;gap:5px}
.prof-badges{display:flex;flex-wrap:wrap;gap:8px}
.prof-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:700;background:var(--n50);color:var(--text-secondary);border:1px solid var(--border)}
.prof-badge.verified{background:var(--success-bg);color:var(--success);border-color:rgba(22,163,74,.2)}
.prof-badge.pro{background:var(--brand-bg);color:var(--brand);border-color:rgba(232,114,10,.2)}
.prof-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.prof-stat-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;text-align:center}
.prof-stat-num{font-family:var(--f-display);font-size:1.3rem;font-weight:900;color:var(--text)}
.prof-stat-lbl{font-size:.75rem;color:var(--text-muted);margin-top:2px}
.prof-section-title{font-family:var(--f-display);font-size:1rem;font-weight:800;color:var(--text);margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
/* edit form */
.prof-edit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.prof-edit-grid .full{grid-column:1/-1}
.prof-field{display:flex;flex-direction:column;gap:6px}
.prof-field label{font-size:.82rem;font-weight:700;color:var(--text-secondary);font-family:var(--f-display)}
.prof-field input,.prof-field textarea,.prof-field select{padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-size:.88rem;font-family:var(--f-body);transition:border-color var(--t)}
.prof-field input:focus,.prof-field textarea:focus,.prof-field select:focus{outline:none;border-color:var(--brand)}
.prof-field textarea{resize:vertical;min-height:80px}
.prof-save-bar{display:flex;justify-content:flex-end;gap:10px;padding-top:16px;border-top:1px solid var(--border);margin-top:8px}
@media(max-width:640px){
  .prof-hero{flex-direction:column;align-items:center;text-align:center}
  .prof-meta{justify-content:center}
  .prof-badges{justify-content:center}
  .prof-stats-grid{grid-template-columns:repeat(3,1fr)}
  .prof-edit-grid{grid-template-columns:1fr}
}

/* ── MY ADS (ma-*) ───────────────────────────────────────────────── */
.ma-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:20px}
.ma-search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);padding:7px 12px;min-width:220px}
.ma-search input{border:none;background:none;color:var(--text);font-size:.875rem;outline:none;flex:1;font-family:var(--f-body)}
.ma-filters{display:flex;gap:6px;flex-wrap:wrap}
.ma-filter-btn{padding:6px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text-secondary);font-size:.8rem;font-weight:700;cursor:pointer;transition:all var(--t);font-family:var(--f-display)}
.ma-filter-btn.active,.ma-filter-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-bg)}
.ma-table{width:100%;border-collapse:collapse}
.ma-table th{padding:10px 12px;text-align:left;font-size:.78rem;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border);font-family:var(--f-display)}
.ma-table td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}
.ma-table tr:last-child td{border-bottom:none}
.ma-table tr:hover td{background:var(--n50)}
.ma-thumb{width:52px;height:42px;border-radius:var(--r-sm);object-fit:cover;border:1px solid var(--border)}
.ma-ad-title{font-weight:700;color:var(--text);font-size:.88rem;text-decoration:none;display:block}
.ma-ad-title:hover{color:var(--brand)}
.ma-ad-meta{font-size:.75rem;color:var(--text-muted);margin-top:2px}
.ma-price{font-family:var(--f-display);font-weight:800;font-size:.95rem;color:var(--text)}
.ma-status{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:.75rem;font-weight:700}
.ma-status.active{background:var(--success-bg);color:var(--success)}
.ma-status.paused{background:var(--n50);color:var(--text-muted)}
.ma-status.sold{background:var(--brand-bg);color:var(--brand)}
.ma-status.expired{background:var(--error-bg);color:var(--error)}
.ma-actions{display:flex;gap:6px}
.ma-action-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--t);text-decoration:none;font-size:.8rem}
.ma-action-btn:hover{border-color:var(--brand);color:var(--brand)}
.ma-action-btn.danger:hover{border-color:var(--error);color:var(--error)}
.ma-row-mobile{display:none}
.ma-batch-bar{display:none;align-items:center;gap:10px;padding:10px 16px;background:var(--brand-bg);border:1px solid rgba(232,114,10,.2);border-radius:var(--r-md);margin-bottom:14px}
.ma-batch-bar.visible{display:flex}
.ma-batch-count{font-size:.85rem;font-weight:700;color:var(--brand);font-family:var(--f-display)}
.ma-batch-actions{display:flex;gap:8px;margin-left:auto}
.ma-empty{text-align:center;padding:60px 24px;color:var(--text-muted)}
.ma-empty-icon{font-size:3rem;opacity:.4;margin-bottom:12px}
.ma-empty-text{font-family:var(--f-display);font-weight:700;font-size:1rem;color:var(--text-secondary)}
@media(max-width:768px){
  /* Header */
  .dp-header{flex-direction:column !important;align-items:stretch !important;gap:8px !important}
  .dp-header .btn{width:100%;text-align:center}

  /* Toolbar */
  .ma-toolbar{flex-direction:column !important;gap:8px !important}
  .ma-search{min-width:0 !important;width:100% !important}
  .ma-filters{overflow-x:auto;flex-wrap:nowrap !important;padding-bottom:4px;gap:4px !important}
  .ma-filter-btn{flex-shrink:0;font-size:.72rem !important;padding:5px 10px !important}

  /* Mis anuncios: card layout en móvil */
  .ma-ad-row{
    flex-direction:column !important;
    align-items:stretch !important;
    gap:0 !important;
    padding:0 !important;
  }
  .ma-ad-thumb{width:100% !important}
  .ma-ad-thumb img{width:100% !important;height:140px !important;object-fit:cover !important;display:block !important;border-radius:0 !important}
  .ma-ad-nophoto{width:100%;height:140px;background:var(--n100);display:flex;align-items:center;justify-content:center}
  .ma-ad-info{padding:8px 10px 4px !important}
  .ma-ad-line1{flex-wrap:nowrap !important;gap:4px !important}
  .ma-ad-name{font-size:.82rem !important;flex:1 !important;min-width:0 !important}
  .ma-ad-line2{margin-top:4px !important}
  /* Acciones en fila separada al final */
  .ma-ad-row > div:last-child{
    width:100% !important;
    padding:6px 10px 8px !important;
    border-top:1px solid var(--border) !important;
    display:flex !important;
    justify-content:space-around !important;
    flex-wrap:wrap !important;
    gap:4px !important;
  }

  /* Batch bar */
  .ma-batch-bar{flex-direction:column !important;gap:8px !important;text-align:center}
  .ma-batch-actions{margin-left:0 !important;justify-content:center}
}

/* ── MY FAVORITES ────────────────────────────────────────────────── */
.fav-page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.fav-remove-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;background:rgba(0,0,0,.45);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:background var(--t)}
.fav-remove-btn:hover{background:var(--error)}
.fav-empty{text-align:center;padding:80px 24px;grid-column:1/-1}
.fav-empty-icon{font-size:4rem;opacity:.3;margin-bottom:16px}
.fav-empty-msg{font-family:var(--f-display);font-size:1.1rem;font-weight:800;color:var(--text-secondary);margin-bottom:8px}
.fav-empty-sub{font-size:.875rem;color:var(--text-muted)}

/* ── WALLET (w-*) ────────────────────────────────────────────────── */
.w-balance-card{background:linear-gradient(135deg,var(--brand) 0%,#c45c00 100%);border-radius:var(--r-lg);padding:28px 32px;color:#fff;margin-bottom:24px;display:flex;align-items:center;justify-content:space-between}
.w-balance-label{font-size:.85rem;font-weight:600;opacity:.85;margin-bottom:4px}
.w-balance-amount{font-family:var(--f-display);font-size:2.4rem;font-weight:900;letter-spacing:-1px}
.w-balance-sub{font-size:.78rem;opacity:.7;margin-top:4px}
.w-balance-actions{display:flex;gap:10px;flex-wrap:wrap}
.w-btn{padding:9px 18px;border-radius:var(--r-md);font-weight:800;font-family:var(--f-display);font-size:.85rem;cursor:pointer;transition:all var(--t);text-decoration:none;display:inline-flex;align-items:center;gap:7px}
.w-btn-primary{background:#fff;color:var(--brand);border:none}
.w-btn-primary:hover{background:rgba(255,255,255,.88)}
.w-btn-ghost{background:rgba(255,255,255,.15);color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.w-btn-ghost:hover{background:rgba(255,255,255,.25)}
.w-tx-list{display:flex;flex-direction:column;gap:0}
.w-tx-item{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}
.w-tx-item:last-child{border-bottom:none}
.w-tx-icon{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.95rem}
.w-tx-icon.in{background:var(--success-bg);color:var(--success)}
.w-tx-icon.out{background:var(--error-bg);color:var(--error)}
.w-tx-icon.pending{background:var(--warning-bg);color:var(--warning)}
.w-tx-desc{flex:1;min-width:0}
.w-tx-title{font-weight:700;font-size:.875rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.w-tx-date{font-size:.75rem;color:var(--text-muted);margin-top:1px}
.w-tx-amount{font-family:var(--f-display);font-weight:800;font-size:.95rem}
.w-tx-amount.in{color:var(--success)}
.w-tx-amount.out{color:var(--error)}
.w-tx-amount.pending{color:var(--warning)}
/* cartera layout (cw-*) */
.cw-layout{display:grid;grid-template-columns:1fr 320px;gap:24px}
.cw-methods{display:flex;flex-direction:column;gap:10px}
.cw-method-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all var(--t)}
.cw-method-card:hover,.cw-method-card.selected{border-color:var(--brand);background:var(--brand-bg)}
.cw-method-logo{width:42px;height:28px;object-fit:contain}
.cw-method-name{font-weight:700;font-size:.88rem;color:var(--text);font-family:var(--f-display)}
.cw-method-desc{font-size:.75rem;color:var(--text-muted)}
.cw-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;position:sticky;top:80px}
.cw-summary-title{font-family:var(--f-display);font-weight:800;font-size:1rem;margin:0 0 16px}
.cw-summary-row{display:flex;justify-content:space-between;font-size:.875rem;color:var(--text-secondary);margin-bottom:10px}
.cw-summary-row.total{font-weight:800;color:var(--text);font-size:1rem;border-top:1px solid var(--border);padding-top:10px;margin-top:6px}
@media(max-width:768px){.cw-layout{grid-template-columns:1fr}}
@media(max-width:600px){
  .w-balance-card{flex-direction:column;align-items:flex-start;gap:18px}
  .w-balance-amount{font-size:1.8rem}
}

/* ── SUBSCRIPTIONS ───────────────────────────────────────────────── */
.subs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.subs-plan{background:var(--surface);border:2px solid var(--border);border-radius:var(--r-lg);padding:28px 24px;text-align:center;transition:all var(--t);position:relative}
.subs-plan:hover{border-color:var(--brand)}
.subs-plan.featured{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-bg)}
.subs-plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--brand);color:#fff;font-size:.72rem;font-weight:800;padding:3px 12px;border-radius:20px;font-family:var(--f-display);white-space:nowrap}
.subs-plan-name{font-family:var(--f-display);font-size:1rem;font-weight:800;color:var(--text);margin:0 0 8px}
.subs-plan-price{font-family:var(--f-display);font-size:2rem;font-weight:900;color:var(--text);margin:0}
.subs-plan-period{font-size:.8rem;color:var(--text-muted)}
.subs-plan-features{list-style:none;padding:0;margin:20px 0;text-align:left;display:flex;flex-direction:column;gap:8px}
.subs-plan-features li{font-size:.85rem;color:var(--text-secondary);display:flex;align-items:center;gap:8px}
.subs-plan-features li::before{content:'✓';color:var(--success);font-weight:900;flex-shrink:0}
.subs-plan-features li.no::before{content:'✕';color:var(--n200);color:var(--border)}
.subs-plan-features li.no{color:var(--text-muted)}
.subs-cta{width:100%;padding:10px;border-radius:var(--r-md);font-weight:800;font-family:var(--f-display);font-size:.88rem;cursor:pointer;transition:all var(--t);border:2px solid var(--brand);background:transparent;color:var(--brand)}
.subs-cta:hover,.subs-plan.featured .subs-cta{background:var(--brand);color:#fff}
.subs-current-badge{display:inline-flex;align-items:center;gap:6px;background:var(--success-bg);color:var(--success);padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:700;margin-bottom:16px}
@media(max-width:768px){.subs-grid{grid-template-columns:1fr;max-width:360px;margin-inline:auto}}

/* ── CHAT ────────────────────────────────────────────────────────── */
.chat-layout{display:grid;grid-template-columns:320px 1fr;height:calc(100vh - 64px);max-width:1200px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.chat-sidebar{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.chat-sidebar-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.chat-sidebar-title{font-family:var(--f-display);font-weight:800;font-size:1rem;margin:0}
.chat-search-bar{padding:10px 12px;border-bottom:1px solid var(--border);flex-shrink:0}
.chat-search-input{width:100%;padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg);color:var(--text);font-size:.85rem;outline:none;transition:border-color var(--t);font-family:var(--f-body);box-sizing:border-box}
.chat-search-input:focus{border-color:var(--brand)}
.chat-list{overflow-y:auto;flex:1}
.chat-conv-item{display:flex;align-items:center;gap:11px;padding:12px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background var(--t);text-decoration:none}
.chat-conv-item:hover{background:var(--n50)}
.chat-conv-item.active{background:var(--brand-bg)}
.chat-conv-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--border)}
.chat-conv-info{flex:1;min-width:0}
.chat-conv-name{font-weight:700;font-size:.875rem;color:var(--text);display:flex;align-items:center;justify-content:space-between}
.chat-conv-time{font-size:.72rem;color:var(--text-muted);font-weight:400;flex-shrink:0;margin-left:8px}
.chat-conv-preview{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px;display:flex;align-items:center;justify-content:space-between}
.chat-conv-unread{background:var(--brand);color:#fff;font-size:.65rem;font-weight:800;min-width:17px;height:17px;border-radius:20px;display:flex;align-items:center;justify-content:center;padding:0 4px;flex-shrink:0}
/* thread */
.chat-thread{display:flex;flex-direction:column;overflow:hidden}
.chat-thread-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}
.chat-thread-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}
.chat-thread-user{font-family:var(--f-display);font-weight:800;font-size:.9rem;color:var(--text)}
.chat-thread-ad{font-size:.75rem;color:var(--text-muted);margin-top:1px}
.chat-thread-ad a{color:var(--brand);text-decoration:none}
.chat-messages{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px}
.chat-msg{display:flex;flex-direction:column;max-width:72%}
.chat-msg.mine{align-self:flex-end;align-items:flex-end}
.chat-msg.theirs{align-self:flex-start;align-items:flex-start}
.chat-bubble{padding:9px 13px;border-radius:16px;font-size:.875rem;line-height:1.5;word-break:break-word}
.chat-msg.mine .chat-bubble{background:var(--brand);color:#fff;border-bottom-right-radius:4px}
.chat-msg.theirs .chat-bubble{background:var(--n50);color:var(--text);border-bottom-left-radius:4px}
.chat-msg-time{font-size:.68rem;color:var(--text-muted);margin-top:2px;padding:0 4px}
.chat-input-bar{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:flex-end;gap:10px;flex-shrink:0}
.chat-textarea{flex:1;padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-size:.875rem;font-family:var(--f-body);resize:none;outline:none;max-height:120px;transition:border-color var(--t)}
.chat-textarea:focus{border-color:var(--brand)}
.chat-send-btn{width:40px;height:40px;background:var(--brand);color:#fff;border:none;border-radius:var(--r-md);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--t)}
.chat-send-btn:hover{background:var(--brand-hover)}
.chat-ad-banner{display:flex;align-items:center;gap:12px;padding:10px 18px;background:var(--n50);border-bottom:1px solid var(--border);flex-shrink:0}
.chat-ad-thumb{width:44px;height:36px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border)}
.chat-ad-name{font-weight:700;font-size:.83rem;color:var(--text);text-decoration:none}
.chat-ad-name:hover{color:var(--brand)}
.chat-ad-price{font-family:var(--f-display);font-weight:800;font-size:.88rem;color:var(--brand)}
@media(max-width:768px){
  .chat-layout{grid-template-columns:1fr;height:auto}
  .chat-sidebar{height:auto;max-height:320px}
}

/* ── POST AD FORM ────────────────────────────────────────────────── */
.post-layout{display:grid;grid-template-columns:1fr 300px;gap:28px;max-width:1100px;margin:0 auto;padding:28px 16px}
.post-steps{display:flex;align-items:center;gap:0;margin-bottom:28px;counter-reset:step}
.post-step{display:flex;align-items:center;gap:0;flex:1}
.post-step-dot{width:30px;height:30px;border-radius:50%;background:var(--n50);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:var(--text-muted);flex-shrink:0;transition:all var(--t);font-family:var(--f-display)}
.post-step.done .post-step-dot{background:var(--success);border-color:var(--success);color:#fff}
.post-step.active .post-step-dot{background:var(--brand);border-color:var(--brand);color:#fff}
.post-step-label{font-size:.75rem;font-weight:700;color:var(--text-muted);margin-left:8px;white-space:nowrap;font-family:var(--f-display)}
.post-step.active .post-step-label{color:var(--brand)}
.post-step-line{flex:1;height:2px;background:var(--border);margin:0 8px}
.post-step.done .post-step-line{background:var(--success)}
.post-form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px}
.post-section-title{font-family:var(--f-display);font-size:1rem;font-weight:800;color:var(--text);margin:0 0 18px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.post-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}
.post-fields .full{grid-column:1/-1}
.post-field{display:flex;flex-direction:column;gap:6px}
.post-field label{font-size:.82rem;font-weight:700;color:var(--text-secondary);font-family:var(--f-display)}
.post-field label span.req{color:var(--error)}
.post-field input,.post-field textarea,.post-field select{padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-size:.88rem;font-family:var(--f-body);transition:border-color var(--t)}
.post-field input:focus,.post-field textarea:focus,.post-field select:focus{outline:none;border-color:var(--brand)}
.post-field textarea{resize:vertical;min-height:100px}
.post-hint{font-size:.75rem;color:var(--text-muted);margin-top:2px}
.post-img-upload{border:2px dashed var(--border);border-radius:var(--r-md);padding:28px;text-align:center;cursor:pointer;transition:all var(--t);margin-bottom:14px}
.post-img-upload:hover,.post-img-upload.drag{border-color:var(--brand);background:var(--brand-bg)}
.post-img-upload-icon{font-size:2rem;opacity:.4;margin-bottom:8px}
.post-img-upload-text{font-size:.875rem;color:var(--text-muted)}
.post-img-upload-text strong{color:var(--brand)}
.post-img-preview{display:flex;flex-wrap:wrap;gap:8px}
.post-img-thumb{width:80px;height:64px;border-radius:var(--r-sm);object-fit:cover;border:2px solid var(--border);position:relative}
.post-img-thumb.main-img{border-color:var(--brand)}
.post-img-remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--error);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;cursor:pointer;border:2px solid var(--surface)}
.post-sidebar-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;position:sticky;top:80px}
.post-sidebar-title{font-family:var(--f-display);font-weight:800;font-size:.9rem;margin:0 0 14px}
.post-tip{display:flex;gap:10px;margin-bottom:12px;font-size:.8rem;color:var(--text-secondary)}
.post-tip-icon{flex-shrink:0;opacity:.6}
.post-nav-bar{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--border);margin-top:8px}
@media(max-width:768px){
  .post-layout{grid-template-columns:1fr}
  .post-sidebar-card{display:none}
  .post-fields{grid-template-columns:1fr}
}

/* ── SECURITY PAGE ───────────────────────────────────────────────── */
.sec-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin-bottom:16px}
.sec-section-title{font-family:var(--f-display);font-weight:800;font-size:1rem;color:var(--text);margin:0 0 16px;display:flex;align-items:center;gap:10px}
.sec-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}
.sec-row:last-child{border-bottom:none;padding-bottom:0}
.sec-row-info{flex:1}
.sec-row-label{font-weight:700;font-size:.875rem;color:var(--text);font-family:var(--f-display)}
.sec-row-desc{font-size:.78rem;color:var(--text-muted);margin-top:2px}
.sec-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:.75rem;font-weight:700}
.sec-badge.ok{background:var(--success-bg);color:var(--success)}
.sec-badge.warn{background:var(--warning-bg);color:var(--warning)}
.sec-badge.off{background:var(--n50);color:var(--text-muted)}
.sec-toggle{position:relative;width:44px;height:24px;flex-shrink:0}
.sec-toggle input{opacity:0;width:0;height:0}
.sec-toggle-slider{position:absolute;inset:0;background:var(--n100);border-radius:24px;cursor:pointer;transition:background var(--t)}
.sec-toggle input:checked+.sec-toggle-slider{background:var(--brand)}
.sec-toggle-slider::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform var(--t)}
.sec-toggle input:checked+.sec-toggle-slider::before{transform:translateX(20px)}
.sec-sessions{display:flex;flex-direction:column;gap:0}
.sec-session-item{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}
.sec-session-item:last-child{border-bottom:none}
.sec-session-icon{width:36px;height:36px;background:var(--n50);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sec-session-device{font-weight:700;font-size:.85rem;color:var(--text)}
.sec-session-meta{font-size:.75rem;color:var(--text-muted);margin-top:1px}
.sec-session-current{font-size:.72rem;font-weight:700;color:var(--success);background:var(--success-bg);padding:2px 7px;border-radius:20px;margin-left:6px}

/* ── AUCTIONS ────────────────────────────────────────────────────── */
.auct-hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;display:grid;grid-template-columns:1fr auto;gap:24px;margin-bottom:24px;align-items:start}
.auct-title{font-family:var(--f-display);font-size:1.3rem;font-weight:900;color:var(--text);margin:0 0 8px}
.auct-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.8rem;color:var(--text-muted)}
.auct-countdown{background:var(--n50);border:1.5px solid var(--border);border-radius:var(--r-md);padding:16px 20px;text-align:center;min-width:180px}
.auct-countdown-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px;font-family:var(--f-display)}
.auct-countdown-digits{display:flex;gap:6px;justify-content:center}
.auct-digit{display:flex;flex-direction:column;align-items:center;gap:2px}
.auct-digit-num{font-family:var(--f-display);font-size:1.6rem;font-weight:900;color:var(--text);line-height:1;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 8px;min-width:40px;text-align:center}
.auct-digit-lbl{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.auct-digit-sep{font-family:var(--f-display);font-size:1.4rem;font-weight:900;color:var(--text-muted);align-self:center;margin-bottom:12px}
.auct-bid-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px;margin-bottom:24px}
.auct-current-bid{margin-bottom:16px}
.auct-bid-label{font-size:.78rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-family:var(--f-display)}
.auct-bid-amount{font-family:var(--f-display);font-size:2rem;font-weight:900;color:var(--brand)}
.auct-bid-count{font-size:.78rem;color:var(--text-muted);margin-top:2px}
.auct-bid-input-row{display:flex;gap:8px;margin-bottom:10px}
.auct-bid-input{flex:1;padding:10px 14px;border:2px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-family:var(--f-display);font-size:1rem;font-weight:700;outline:none;transition:border-color var(--t)}
.auct-bid-input:focus{border-color:var(--brand)}
.auct-bid-btn{padding:10px 20px;background:var(--brand);color:#fff;border:none;border-radius:var(--r-md);font-weight:800;font-family:var(--f-display);font-size:.9rem;cursor:pointer;white-space:nowrap;transition:background var(--t)}
.auct-bid-btn:hover{background:var(--brand-hover)}
.auct-bid-note{font-size:.75rem;color:var(--text-muted)}
.auct-bids-history{display:flex;flex-direction:column;gap:0;margin-top:12px}
.auct-bid-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.83rem}
.auct-bid-row:last-child{border-bottom:none}
.auct-bid-row.winner{color:var(--brand);font-weight:700}
.auct-bid-user{flex:1;color:var(--text-secondary)}
.auct-bid-val{font-family:var(--f-display);font-weight:800;color:var(--text)}
.auct-bid-time{color:var(--text-muted);font-size:.75rem}
.auct-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.auct-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:box-shadow var(--t),transform var(--t)}
.auct-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.auct-card-img{width:100%;height:160px;object-fit:cover}
.auct-card-body{padding:14px}
.auct-card-title{font-family:var(--f-display);font-weight:800;font-size:.9rem;color:var(--text);margin:0 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.auct-card-bid{font-family:var(--f-display);font-size:1.1rem;font-weight:900;color:var(--brand)}
.auct-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;font-size:.75rem;color:var(--text-muted)}
.auct-live-badge{display:inline-flex;align-items:center;gap:5px;background:var(--error-bg);color:var(--error);font-size:.72rem;font-weight:800;padding:2px 8px;border-radius:20px;font-family:var(--f-display)}
.auct-live-dot{width:6px;height:6px;border-radius:50%;background:var(--error);animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
@media(max-width:640px){.auct-hero{grid-template-columns:1fr}.auct-countdown{text-align:left}}

/* ── MAP PAGE ────────────────────────────────────────────────────── */
.map-layout{display:grid;grid-template-columns:360px 1fr;height:calc(100vh - 64px);overflow:hidden}
.map-panel{display:flex;flex-direction:column;border-right:1px solid var(--border);overflow:hidden;background:var(--surface)}
.map-panel-header{padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.map-panel-title{font-family:var(--f-display);font-weight:800;font-size:.95rem;margin:0 0 10px}
.map-panel-search{display:flex;gap:8px}
.map-panel-search input{flex:1;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg);color:var(--text);font-size:.85rem;outline:none;font-family:var(--f-body);transition:border-color var(--t)}
.map-panel-search input:focus{border-color:var(--brand)}
.map-results{overflow-y:auto;flex:1}
.map-result-item{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t);text-decoration:none}
.map-result-item:hover{background:var(--n50)}
.map-result-item.active{background:var(--brand-bg)}
.map-result-thumb{width:60px;height:48px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border);flex-shrink:0}
.map-result-info{flex:1;min-width:0}
.map-result-title{font-weight:700;font-size:.85rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-result-price{font-family:var(--f-display);font-weight:800;color:var(--brand);font-size:.9rem}
.map-result-dist{font-size:.72rem;color:var(--text-muted);margin-top:2px}
#map-container{flex:1;background:var(--n50)}
.map-popup{min-width:180px}
.map-popup-title{font-weight:700;font-size:.85rem;margin:0 0 4px}
.map-popup-price{font-family:var(--f-display);font-weight:800;color:var(--brand);font-size:.9rem}
.map-popup-link{font-size:.75rem;color:var(--brand);text-decoration:none}
@media(max-width:768px){
  .map-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr}
  .map-panel{max-height:300px}
  #map-container{height:400px}
}

/* ── TRANSACTION DETAIL ──────────────────────────────────────────── */
.tx-layout{display:grid;grid-template-columns:1fr 300px;gap:24px;max-width:960px;margin:0 auto;padding:28px 16px}
.tx-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;margin-bottom:16px}
.tx-card-title{font-family:var(--f-display);font-weight:800;font-size:1rem;color:var(--text);margin:0 0 16px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.tx-status-banner{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--r-md);margin-bottom:20px}
.tx-status-banner.completed{background:var(--success-bg);border:1px solid rgba(22,163,74,.2)}
.tx-status-banner.pending{background:var(--warning-bg);border:1px solid rgba(217,119,6,.2)}
.tx-status-banner.cancelled{background:var(--error-bg);border:1px solid rgba(220,38,38,.2)}
.tx-status-icon{font-size:1.6rem}
.tx-status-text{font-family:var(--f-display);font-weight:800;font-size:.95rem}
.tx-status-banner.completed .tx-status-text{color:var(--success)}
.tx-status-banner.pending .tx-status-text{color:var(--warning)}
.tx-status-banner.cancelled .tx-status-text{color:var(--error)}
.tx-status-sub{font-size:.78rem;color:var(--text-muted);margin-top:2px}
.tx-ad-row{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:14px}
.tx-ad-img{width:72px;height:58px;object-fit:cover;border-radius:var(--r-sm);border:1px solid var(--border)}
.tx-ad-title{font-weight:700;font-size:.9rem;color:var(--text);text-decoration:none}
.tx-ad-title:hover{color:var(--brand)}
.tx-ad-price{font-family:var(--f-display);font-weight:800;color:var(--brand);font-size:.95rem}
.tx-detail-rows{display:flex;flex-direction:column;gap:8px}
.tx-detail-row{display:flex;justify-content:space-between;font-size:.875rem}
.tx-detail-row .lbl{color:var(--text-muted)}
.tx-detail-row .val{color:var(--text);font-weight:600}
.tx-detail-row.total{font-weight:800;font-size:1rem;border-top:1px solid var(--border);padding-top:10px;margin-top:4px}
.tx-timeline{display:flex;flex-direction:column;gap:0}
.tx-tl-item{display:flex;gap:12px;padding-bottom:16px;position:relative}
.tx-tl-item::before{content:'';position:absolute;left:11px;top:24px;bottom:0;width:2px;background:var(--border)}
.tx-tl-item:last-child::before{display:none}
.tx-tl-dot{width:24px;height:24px;border-radius:50%;background:var(--n50);border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.6rem;z-index:1}
.tx-tl-dot.done{background:var(--success);border-color:var(--success);color:#fff}
.tx-tl-dot.active{background:var(--brand);border-color:var(--brand);color:#fff}
.tx-tl-text{font-weight:700;font-size:.85rem;color:var(--text)}
.tx-tl-date{font-size:.75rem;color:var(--text-muted);margin-top:1px}
@media(max-width:768px){.tx-layout{grid-template-columns:1fr}}

/* ── REPUTATION / RATINGS ────────────────────────────────────────── */
.rep-summary{display:flex;align-items:center;gap:28px;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:24px;flex-wrap:wrap}
.rep-score{text-align:center;flex-shrink:0}
.rep-score-num{font-family:var(--f-display);font-size:3rem;font-weight:900;color:var(--text);line-height:1}
.rep-score-stars{display:flex;gap:3px;justify-content:center;color:var(--brand);font-size:1rem;margin:4px 0}
.rep-score-count{font-size:.78rem;color:var(--text-muted)}
.rep-bars{flex:1;min-width:200px;display:flex;flex-direction:column;gap:6px}
.rep-bar-row{display:flex;align-items:center;gap:10px;font-size:.78rem}
.rep-bar-label{width:40px;text-align:right;color:var(--text-muted)}
.rep-bar-track{flex:1;height:7px;background:var(--n50);border-radius:4px;overflow:hidden}
.rep-bar-fill{height:100%;background:var(--brand);border-radius:4px;transition:width .5s ease}
.rep-bar-pct{width:32px;color:var(--text-muted);text-align:right}
.rep-list{display:flex;flex-direction:column;gap:0}
.rep-item{padding:16px 0;border-bottom:1px solid var(--border)}
.rep-item:last-child{border-bottom:none}
.rep-item-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.rep-item-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1.5px solid var(--border)}
.rep-item-name{font-weight:700;font-size:.875rem;color:var(--text)}
.rep-item-date{font-size:.72rem;color:var(--text-muted);margin-top:1px}
.rep-item-stars{display:flex;gap:2px;color:var(--brand);font-size:.85rem;margin-left:auto}
.rep-item-text{font-size:.875rem;color:var(--text-secondary);line-height:1.5}
.rep-item-ad{font-size:.75rem;color:var(--text-muted);margin-top:6px}
.rep-item-ad a{color:var(--brand);text-decoration:none}
.rep-write-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--brand);color:#fff;border-radius:var(--r-md);font-weight:800;font-family:var(--f-display);font-size:.875rem;text-decoration:none;transition:background var(--t);border:none;cursor:pointer}
.rep-write-btn:hover{background:var(--brand-hover)}

/* ── GLOBAL UTILITIES ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r-md);font-weight:800;font-family:var(--f-display);font-size:.875rem;cursor:pointer;transition:all var(--t);text-decoration:none;border:none}
.btn-primary{background:var(--brand);color:#fff}
.btn-primary:hover{background:var(--brand-hover)}
.btn-secondary{background:var(--surface);color:var(--text);border:1.5px solid var(--border)}
.btn-secondary:hover{border-color:var(--brand);color:var(--brand)}
.btn-danger{background:var(--error);color:#fff}
.btn-danger:hover{background:#b91c1c}
.btn-sm{padding:6px 12px;font-size:.8rem}
.btn-lg{padding:12px 24px;font-size:1rem}
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:.72rem;font-weight:800;font-family:var(--f-display)}
.badge-success{background:var(--success-bg);color:var(--success)}
.badge-warning{background:var(--warning-bg);color:var(--warning)}
.badge-error{background:var(--error-bg);color:var(--error)}
.badge-brand{background:var(--brand-bg);color:var(--brand)}
.badge-neutral{background:var(--n50);color:var(--text-secondary)}
.form-control{padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-size:.875rem;font-family:var(--f-body);transition:border-color var(--t);width:100%;box-sizing:border-box}
.form-control:focus{outline:none;border-color:var(--brand)}
.form-label{font-size:.82rem;font-weight:700;color:var(--text-secondary);display:block;margin-bottom:6px;font-family:var(--f-display)}
.divider{height:1px;background:var(--border);margin:20px 0}
.text-muted{color:var(--text-muted)}
.text-brand{color:var(--brand)}
.text-success{color:var(--success)}
.text-error{color:var(--error)}
.fw-800{font-weight:800}
.fw-700{font-weight:700}
.d-flex{display:flex}
.align-center{align-items:center}
.justify-between{justify-content:space-between}
.gap-8{gap:8px}
.gap-12{gap:12px}
.gap-16{gap:16px}
.mt-0{margin-top:0}
.mt-4{margin-top:4px}
.mt-16{margin-top:16px}
.mt-24{margin-top:24px}
.mb-0{margin-bottom:0}
.mb-8{margin-bottom:8px}
.mb-16{margin-bottom:16px}
.mb-24{margin-bottom:24px}
.p-16{padding:16px}
.p-24{padding:24px}
.w-full{width:100%}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}


/* ════════════════════════════════════════════════════════════════
   DARK MODE — COMPREHENSIVE OVERRIDES v13
   Overrides hardcoded !important values from templates-extra.css
   Using maximum specificity: [data-theme="dark"] + element/class
   ════════════════════════════════════════════════════════════════ */

/* ── Base ─────────────────────────────────────────── */
[data-theme="dark"] html,
[data-theme="dark"] body {
  background: var(--bg) !important;
  color: var(--text) !important;
}

/* ── Navbar ───────────────────────────────────────── */
[data-theme="dark"] .navbar,
[data-theme="dark"] .nav-row-1,
[data-theme="dark"] .nav-row-2 {
  background: #0D111A !important;
  border-color: rgba(255,255,255,.08) !important;
}
[data-theme="dark"] .nav-logo-text { color: var(--text) !important; }
[data-theme="dark"] .nav-logo-text .a,
[data-theme="dark"] .nav-logo-text .v { color: var(--orange) !important; }
[data-theme="dark"] .nav-logo-text .es { color: var(--n400) !important; }

[data-theme="dark"] .nav-search-inner {
  background: var(--n100) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .nav-search-input {
  color: var(--text) !important;
  background: transparent !important;
}
[data-theme="dark"] .nav-search-input::placeholder { color: var(--n400) !important; }
[data-theme="dark"] .nav-search-icon { color: var(--n400) !important; }

[data-theme="dark"] .nav-icon-wrap {
  color: var(--n500) !important;
  background: transparent !important;
}
[data-theme="dark"] .nav-icon-wrap svg { color: var(--n500) !important; }
[data-theme="dark"] .nav-icon-wrap:hover,
[data-theme="dark"] .nav-icon-wrap.active {
  background: var(--n100) !important;
  color: var(--orange) !important;
}
[data-theme="dark"] .nav-icon-wrap:hover svg,
[data-theme="dark"] .nav-icon-wrap.active svg,
[data-theme="dark"] .nav-icon-wrap:hover .nav-icon-label,
[data-theme="dark"] .nav-icon-wrap.active .nav-icon-label { color: var(--orange) !important; }
[data-theme="dark"] .nav-icon-label { color: var(--n500) !important; }

[data-theme="dark"] .user-trigger {
  background: var(--n100) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}
[data-theme="dark"] .u-name { color: var(--text) !important; }

[data-theme="dark"] .nav-btn-entrar {
  color: var(--text) !important;
  border-color: var(--border) !important;
  background: transparent !important;
}
[data-theme="dark"] .nav-btn-registro {
  background: var(--orange) !important;
  color: #fff !important;
}

/* ── Category bar ─────────────────────────────────── */
[data-theme="dark"] .category-bar {
  background: #0D111A !important;
  border-color: rgba(255,255,255,.08) !important;
}
[data-theme="dark"] .category-bar-item { color: var(--n500) !important; }
[data-theme="dark"] .category-bar-item.active,
[data-theme="dark"] .category-bar-item:hover { color: var(--orange) !important; }
[data-theme="dark"] .category-bar-toggle { color: var(--text) !important; }

/* ── Surfaces: cards, panels, forms ──────────────── */
[data-theme="dark"] .card,
[data-theme="dark"] .form-card,
[data-theme="dark"] .dp-card,
[data-theme="dark"] .dp-card-plain,
[data-theme="dark"] .adm-card,
[data-theme="dark"] .stat-card,
[data-theme="dark"] .sec-kpi,
[data-theme="dark"] .astat,
[data-theme="dark"] .bc-card,
[data-theme="dark"] .seller-card,
[data-theme="dark"] .desc-card,
[data-theme="dark"] .share-card,
[data-theme="dark"] .safety-card,
[data-theme="dark"] .price-card,
[data-theme="dark"] .pe-card,
[data-theme="dark"] .auth-card {
  background: var(--elevated, #171C24) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}
[data-theme="dark"] .dp-card-hdr {
  background: var(--n100) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .dp-card-title,
[data-theme="dark"] .dp-page-title { color: var(--text) !important; }
[data-theme="dark"] .dp-page-sub { color: var(--text-2) !important; }

/* ── Text hierarchy ───────────────────────────────── */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 { color: var(--text) !important; }
[data-theme="dark"] p { color: var(--text-2) !important; }
[data-theme="dark"] label,
[data-theme="dark"] .form-label { color: var(--n500) !important; }
[data-theme="dark"] .form-hint { color: var(--n400) !important; }

/* ── Inputs ───────────────────────────────────────── */
[data-theme="dark"] input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]),
[data-theme="dark"] select,
[data-theme="dark"] textarea,
[data-theme="dark"] .field input,
[data-theme="dark"] .field select,
[data-theme="dark"] .field textarea,
[data-theme="dark"] .field-group input,
[data-theme="dark"] .field-group select,
[data-theme="dark"] .field-group textarea,
[data-theme="dark"] .pe-input {
  background: var(--n100) !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
}
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder { color: var(--n400) !important; }
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus {
  border-color: var(--orange) !important;
  background: var(--elevated, #171C24) !important;
  box-shadow: 0 0 0 3px rgba(232,114,10,.15) !important;
}

/* ── Buttons ──────────────────────────────────────── */
[data-theme="dark"] button:not(.btn-primary):not(.btn-orange):not(.btn-publish):not(.btn-cta):not(.btn-auth):not([class*="btn-"]) {
  color: var(--text) !important;
}
/* Reset base button background in dark mode for non-CTA buttons */
[data-theme="dark"] .nav-icon-wrap,
[data-theme="dark"] .nav-darkmode,
[data-theme="dark"] #dark-mode-toggle {
  background: transparent !important;
  color: var(--n500) !important;
}
[data-theme="dark"] #dark-mode-toggle:hover { color: var(--text) !important; }
[data-theme="dark"] #dark-mode-toggle svg { stroke: currentColor !important; }

/* ── Dashboard sidebar ────────────────────────────── */
[data-theme="dark"] .dp-side,
[data-theme="dark"] .dp-wrap {
  background: var(--n50) !important;
}
[data-theme="dark"] .dp-nav-item { color: var(--n500) !important; }
[data-theme="dark"] .dp-nav-item:hover { background: var(--n100) !important; color: var(--text) !important; }
[data-theme="dark"] .dp-nav-item.active {
  background: rgba(232,114,10,.15) !important;
  color: var(--orange) !important;
}
[data-theme="dark"] .dp-user-name { color: var(--text) !important; }
[data-theme="dark"] .dp-user-since { color: var(--n400) !important; }
[data-theme="dark"] .dp-nav-sep { border-color: var(--border) !important; }
[data-theme="dark"] .dash-sidebar,
[data-theme="dark"] .dashboard-nav {
  background: var(--n50) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .dash-link { color: var(--n500) !important; }
[data-theme="dark"] .dash-link:hover { background: var(--n100) !important; color: var(--text) !important; }
[data-theme="dark"] .dash-link.on { color: var(--orange) !important; background: rgba(232,114,10,.12) !important; }
[data-theme="dark"] .dash-uname { color: var(--text) !important; }
[data-theme="dark"] .dash-ucity { color: var(--n400) !important; }

/* ── Page body areas ──────────────────────────────── */
[data-theme="dark"] main,
[data-theme="dark"] .dp-content,
[data-theme="dark"] .dp-inner,
[data-theme="dark"] .pg-right,
[data-theme="dark"] .pg-right-body,
[data-theme="dark"] .post-wrap,
[data-theme="dark"] .wrap {
  background: transparent !important;
  color: var(--text) !important;
}

/* ── Ad cards ─────────────────────────────────────── */
[data-theme="dark"] .ad-card,
[data-theme="dark"] .av-card {
  background: var(--elevated, #171C24) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .ad-title,
[data-theme="dark"] .ad-card-title,
[data-theme="dark"] .av-card-title { color: var(--text) !important; }
[data-theme="dark"] .ad-meta,
[data-theme="dark"] .ad-card-meta { border-color: var(--border) !important; color: var(--n400) !important; }

/* ── User dropdown ────────────────────────────────── */
[data-theme="dark"] .user-dropdown {
  background: var(--elevated, #171C24) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .ud-row { color: var(--text) !important; }
[data-theme="dark"] .ud-row:hover { background: var(--n100) !important; }
[data-theme="dark"] .ud-icon { background: var(--n100) !important; }
[data-theme="dark"] .ud-header { background: var(--n50) !important; }
[data-theme="dark"] .ud-username { color: var(--text) !important; }

/* ── Mobile menu ──────────────────────────────────── */
[data-theme="dark"] .mob-menu {
  background: var(--n50) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .mob-link { color: var(--text) !important; border-color: var(--border) !important; }
[data-theme="dark"] .mob-link:hover { background: var(--n100) !important; }

/* ── Footer ───────────────────────────────────────── */
[data-theme="dark"] footer,
[data-theme="dark"] .footer {
  background: #080B10 !important;
  border-color: rgba(255,255,255,.06) !important;
  color: var(--n500) !important;
}
[data-theme="dark"] .footer a,
[data-theme="dark"] .footer-col a { color: var(--n400) !important; }
[data-theme="dark"] .footer a:hover { color: var(--orange) !important; }
[data-theme="dark"] .footer-col-title { color: var(--n400) !important; }
[data-theme="dark"] .footer-copy { color: var(--n400) !important; }

/* ── Misc UI elements ─────────────────────────────── */
[data-theme="dark"] .filter-bar,
[data-theme="dark"] .filter-sidebar {
  background: var(--elevated, #171C24) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .filter-opt { color: var(--n500) !important; }
[data-theme="dark"] .filter-opt:hover { background: var(--n100) !important; color: var(--text) !important; }
[data-theme="dark"] .filter-section { border-color: var(--border) !important; }

[data-theme="dark"] .wizard-step-dot {
  background: var(--n200) !important;
  color: var(--n400) !important;
}
[data-theme="dark"] .wizard-step-line { background: var(--border) !important; }
[data-theme="dark"] .wizard-step--active .wizard-step-dot {
  background: var(--orange) !important;
  color: #fff !important;
}
[data-theme="dark"] .wizard-step-label { color: var(--n400) !important; }
[data-theme="dark"] .wizard-step--active .wizard-step-label { color: var(--orange) !important; }

[data-theme="dark"] .cat-pick {
  border-color: var(--border) !important;
  background: var(--n100) !important;
}
[data-theme="dark"] .cat-pick:hover,
[data-theme="dark"] .cat-pick.on {
  border-color: var(--orange) !important;
  background: rgba(232,114,10,.12) !important;
}
[data-theme="dark"] .cat-pick-name { color: var(--text) !important; }

[data-theme="dark"] .cond-opt {
  border-color: var(--border) !important;
  color: var(--n500) !important;
}
[data-theme="dark"] .cond-opt:hover { border-color: var(--orange) !important; color: var(--orange) !important; }
[data-theme="dark"] .cond-opt.on { background: var(--orange) !important; color: #fff !important; border-color: var(--orange) !important; }

[data-theme="dark"] .flash--success { background: var(--success-bg) !important; color: #6ee7b7 !important; border-color: rgba(16,185,129,.2) !important; }
[data-theme="dark"] .flash--error   { background: var(--danger-bg)  !important; color: #fca5a5 !important; border-color: rgba(220,38,38,.2)  !important; }
[data-theme="dark"] .flash--warning { background: var(--warning-bg) !important; color: #fcd34d !important; border-color: rgba(217,119,6,.2)  !important; }

[data-theme="dark"] .seg-btn { color: var(--n500) !important; }
[data-theme="dark"] .seg-btn.seg-active { color: #fff !important; }

[data-theme="dark"] .photo-add {
  background: var(--n100) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .photo-add:hover { border-color: var(--orange) !important; background: rgba(232,114,10,.08) !important; }

[data-theme="dark"] .status-tab { color: var(--n500) !important; }
[data-theme="dark"] .status-tab--active { background: var(--elevated) !important; color: var(--orange) !important; }

[data-theme="dark"] .ia-btn-photo,
[data-theme="dark"] .ia-btn-complete,
[data-theme="dark"] .ia-btn-spell,
[data-theme="dark"] .ia-btn-rewrite,
[data-theme="dark"] .ia-btn-title {
  background: var(--n100) !important;
  color: var(--n500) !important;
  border-color: var(--border) !important;
}
[data-theme="dark"] .ia-btn-photo:hover:not(:disabled),
[data-theme="dark"] .ia-btn-complete:hover:not(:disabled) {
  background: var(--n200) !important;
  color: var(--text) !important;
}

[data-theme="dark"] .tabs-wrap,
[data-theme="dark"] .dp-tabs { border-color: var(--border) !important; }
[data-theme="dark"] .dp-tab { color: var(--n400) !important; }
[data-theme="dark"] .dp-tab.active { color: var(--orange) !important; border-color: var(--orange) !important; }

[data-theme="dark"] .notif-panel { background: var(--elevated) !important; border-color: var(--border) !important; }
[data-theme="dark"] .notif-item { border-color: var(--border) !important; color: var(--text) !important; }
[data-theme="dark"] .notif-item:hover { background: var(--n100) !important; }
[data-theme="dark"] .notif-item.unread { background: rgba(232,114,10,.08) !important; }

[data-theme="dark"] .my-ad-row { background: var(--elevated) !important; border-color: var(--border) !important; }
[data-theme="dark"] .my-ad-title { color: var(--text) !important; }
[data-theme="dark"] .my-ad-meta { color: var(--n400) !important; }

[data-theme="dark"] .rep-card { color: #fff !important; }
[data-theme="dark"] .err-code { color: var(--n200) !important; }


/* ── Button hardening — ensure these survive any reset ────────── */
.view-btn{width:34px!important;height:34px!important;border-radius:var(--r-md)!important;background:var(--n50)!important;border:1.5px solid var(--border)!important;display:flex!important;align-items:center!important;justify-content:center!important;color:var(--text-3)!important;cursor:pointer!important;padding:0!important;flex-shrink:0!important}
.view-btn.active,.view-btn:hover{background:var(--brand-xs,var(--orange-xs))!important;color:var(--orange)!important;border-color:rgba(232,114,10,.3)!important}

.list-action-btn{width:34px!important;height:34px!important;border-radius:var(--r-md)!important;border:1.5px solid var(--border)!important;background:var(--surface)!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;padding:0!important;color:var(--n500)!important;flex-shrink:0!important;text-decoration:none!important;transition:all .15s!important}
.list-action-btn:hover{border-color:var(--orange)!important;color:var(--orange)!important;background:var(--orange-xs)!important}
.list-action-btn.active{color:var(--danger)!important;border-color:var(--danger)!important;background:#fef2f2!important}

.fp-close-btn,.fp-back-btn{width:32px!important;height:32px!important;padding:0!important;background:transparent!important;border:none!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;color:var(--n500)!important}
.fp-close-btn:hover,.fp-back-btn:hover{color:var(--text)!important}
.fp-submit-btn{width:100%!important;padding:12px!important;background:var(--orange)!important;color:#fff!important;border:none!important;border-radius:10px!important;font-weight:800!important;font-size:.9rem!important;cursor:pointer!important}
.fp-submit-btn:hover{background:var(--orange-dk)!important}
.fp-menu-item{display:flex!important;align-items:center!important;justify-content:space-between!important;width:100%!important;padding:16px 20px!important;background:transparent!important;color:var(--text)!important;border:none!important;border-bottom:1px solid var(--n100)!important;font-size:.9rem!important;font-weight:600!important;cursor:pointer!important;text-align:left!important}
.fp-menu-item:hover{background:var(--n50)!important}

.fav-btn{position:absolute!important;top:9px!important;right:9px!important;width:34px!important;height:34px!important;border-radius:50%!important;background:rgba(255,255,255,.95)!important;border:none!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;padding:0!important;box-shadow:0 2px 8px rgba(0,0,0,.14)!important;z-index:5!important;transition:all .15s!important}
.fav-btn:hover{transform:scale(1.1)!important}
.fav-btn.active{background:rgba(254,242,242,.95)!important}

.compare-toggle-btn{width:34px!important;height:34px!important;border-radius:var(--r-md)!important;border:1.5px solid var(--border)!important;background:var(--surface)!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;padding:0!important;color:var(--n500)!important;transition:all .15s!important}
.compare-toggle-btn:hover{border-color:var(--orange)!important;color:var(--orange)!important;background:var(--orange-xs)!important}
.compare-toggle-btn.in-compare{background:var(--orange-xs)!important;color:var(--orange)!important;border-color:var(--orange)!important}

#dark-mode-toggle{width:auto!important;height:auto!important;padding:6px!important;background:transparent!important;border:none!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;border-radius:8px!important;color:var(--n500)!important}
#dark-mode-toggle:hover{background:var(--n100)!important;color:var(--text)!important}

.btn-send,.chat-send-btn{width:42px!important;height:42px!important;border-radius:50%!important;background:var(--orange)!important;border:none!important;display:flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;padding:0!important;color:#fff!important;flex-shrink:0!important}
.btn-send:hover:not(:disabled){background:var(--orange-dk)!important}
.btn-send:disabled{background:var(--n200)!important;cursor:not-allowed!important}

.photo-rm{position:absolute!important;top:4px!important;right:4px!important;width:22px!important;height:22px!important;background:rgba(0,0,0,.6)!important;color:#fff!important;border:none!important;border-radius:50%!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;font-size:.9rem!important;z-index:2!important}
.photo-rm:hover{background:var(--danger)!important}

.ham{display:none!important;flex-direction:column!important;gap:4.5px!important;width:38px!important;height:38px!important;padding:8px!important;background:transparent!important;border:none!important;cursor:pointer!important;border-radius:var(--r-md)!important}
@media(max-width:768px){.ham{display:flex!important}}

@media(min-width:769px){.btn-filter-toggle{display:inline-flex!important;align-items:center!important;gap:6px!important;padding:8px 14px!important;background:var(--orange)!important;color:#fff!important;border:none!important;border-radius:99px!important;font-size:.84rem!important;font-weight:700!important;cursor:pointer!important;width:auto!important}
.btn-filter-toggle:hover{background:var(--orange-dk)!important}}

/* ════════════════════════════════════════════════════════════════
   GLOBAL BUTTON SAFETY NET v13 — prevents any rogue rule from
   breaking interactive elements. High-specificity, minimal reset.
   ════════════════════════════════════════════════════════════════ */

/* Chat FAB — orange circle, always visible */
#help-fab,
.chat-fab {
  width: 52px !important;
  height: 52px !important;
  min-width: 52px !important;
  border-radius: 50% !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  box-shadow: 0 4px 20px rgba(232,114,10,.4) !important;
  transition: transform .2s, box-shadow .2s !important;
}
#help-fab:hover { transform: scale(1.08) !important; }
#help-fab svg { width: 24px !important; height: 24px !important; color: #fff !important; }
.chat-fab-icon { display: flex !important; align-items: center !important; justify-content: center !important; }

/* View toggle buttons */
#view-grid-btn,
#view-list-btn,
.view-btn {
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  border-radius: 8px !important;
  background: var(--surface) !important;
  border: 1.5px solid var(--border) !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  color: var(--n500) !important;
  transition: all .15s !important;
}
#view-grid-btn:hover, #view-list-btn:hover, .view-btn:hover,
#view-grid-btn.active, #view-list-btn.active, .view-btn.active {
  background: var(--orange-xs) !important;
  border-color: var(--orange) !important;
  color: var(--orange) !important;
}

/* Filter panel toggle */
#filter-fab,
.filter-fab {
  position: fixed !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  z-index: 200 !important;
  box-shadow: 0 4px 16px rgba(232,114,10,.4) !important;
}

/* Ad card action buttons (compare, chat, alert) */
.av-action-btn,
.av-card-zoom,
.av-card-fav,
.av-nav, .av-nav--prev, .av-nav--next {
  padding: 0 !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.av-action-btn {
  width: 34px !important;
  height: 34px !important;
  border-radius: 8px !important;
  background: var(--n50) !important;
  color: var(--n500) !important;
  transition: all .15s !important;
}
.av-action-btn:hover { background: var(--orange-xs) !important; color: var(--orange) !important; }
.av-action-btn.active { color: var(--danger) !important; background: #fef2f2 !important; }

/* Filter panel close/back buttons */
.fp-close-btn, .fp-back-btn {
  width: 32px !important; height: 32px !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  color: var(--n500) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 6px !important;
}
.fp-close-btn:hover, .fp-back-btn:hover { background: var(--n100) !important; color: var(--text) !important; }

/* Fav button on cards */
.fav-btn, .av-card-fav {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.95) !important;
  border: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.12) !important;
  transition: transform .15s !important;
}
.fav-btn:hover, .av-card-fav:hover { transform: scale(1.1) !important; }
.fav-btn.active, .av-card-fav.active { background: rgba(254,242,242,.95) !important; }

/* Dark mode toggle */
#dark-mode-toggle {
  width: auto !important;
  height: auto !important;
  min-width: 36px !important;
  min-height: 36px !important;
  background: transparent !important;
  border: none !important;
  padding: 6px !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  color: var(--n500) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#dark-mode-toggle:hover { background: var(--n100) !important; color: var(--text) !important; }

/* Nav hamburger */
#ham, .nav-ham {
  padding: 8px !important;
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  border-radius: 8px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Search button */
/* nav-search-btn — handled by base rules at line 220, no override needed */

/* Scroll to top button */
.back-to-top {
  width: 44px !important; height: 44px !important;
  border-radius: 50% !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Photo add label (not button, but acts like one) */
.photo-add {
  cursor: pointer !important;
}

/* Sort trigger */
.sort-trigger {
  display: flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 8px 13px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  background: var(--surface) !important;
  color: var(--text) !important;
  font-size: .875rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  height: auto !important;
  width: auto !important;
}

/* Flash close */
.flash-x {
  background: transparent !important;
  border: none !important;
  cursor: pointer !important;
  font-size: 1.3rem !important;
  opacity: .5 !important;
  padding: 0 4px !important;
  line-height: 1 !important;
  color: inherit !important;
}
.flash-x:hover { opacity: 1 !important; }

/* Tab buttons */
.dp-tab, .s-tab, .tab-btn, .status-tab, .wallet-tab {
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  padding: 8px 16px !important;
  font-size: .84rem !important;
  font-weight: 700 !important;
  color: var(--n500) !important;
  white-space: nowrap !important;
  height: auto !important;
  width: auto !important;
}

/* FP menu items inside filter panel */
.fp-menu-item {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100% !important;
  padding: 16px 20px !important;
  background: transparent !important;
  color: var(--text) !important;
  border: none !important;
  border-bottom: 1px solid var(--n100) !important;
  border-radius: 0 !important;
  font-size: .9rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  text-align: left !important;
  height: auto !important;
}
.fp-menu-item:hover { background: var(--n50) !important; }

/* Submit buttons in fp */
.fp-submit-btn {
  width: 100% !important;
  padding: 12px !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 800 !important;
  font-size: .9rem !important;
  cursor: pointer !important;
  height: auto !important;
}
.fp-submit-btn:hover { background: var(--orange-dk) !important; }

/* Chat send button */
.btn-send, .chat-send-btn, #map-chat-send {
  width: 42px !important; height: 42px !important; min-width: 42px !important;
  border-radius: 50% !important;
  background: var(--orange) !important;
  color: #fff !important;
  border: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  transition: background .15s !important;
}
.btn-send:hover:not(:disabled), .chat-send-btn:hover:not(:disabled) { background: var(--orange-dk) !important; }
.btn-send:disabled { background: var(--n200) !important; cursor: not-allowed !important; }

/* Voice button */
.voice-btn {
  width: 38px !important; height: 38px !important;
  border-radius: 50% !important;
  background: var(--n50) !important;
  border: 1.5px solid var(--border) !important;
  padding: 0 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--n500) !important;
  flex-shrink: 0 !important;
}

/* Photo remove button */
.photo-rm {
  position: absolute !important;
  top: 4px !important; right: 4px !important;
  width: 22px !important; height: 22px !important;
  border-radius: 50% !important;
  background: rgba(0,0,0,.6) !important;
  color: #fff !important;
  border: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  font-size: .85rem !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  z-index: 3 !important;
}
.photo-rm:hover { background: var(--danger) !important; }

/* Gallery nav buttons */
.gal-nav, .gallery-nav, .lb-nav, .lb-close {
  background: rgba(255,255,255,.9) !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.lb-nav, .lb-close {
  background: rgba(255,255,255,.15) !important;
  color: #fff !important;
  width: 44px !important; height: 44px !important;
  border-radius: 50% !important;
  padding: 0 !important;
}

body{overflow-x:hidden}

/* ── Segmented control buttons ── */
.seg-btn {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  padding: 10px 6px !important;
  background: transparent !important;
  border: none !important;
  border-radius: 10px !important;
  cursor: pointer !important;
  position: relative !important;
  z-index: 1 !important;
  color: var(--n500) !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  font-family: var(--f-display) !important;
  transition: color .2s !important;
  -webkit-tap-highlight-color: transparent !important;
  min-width: 0 !important;
  width: auto !important;
}
.seg-btn span { font-size: .72rem; font-weight: 800; white-space: nowrap; line-height: 1; }
.seg-btn svg { display: block; }
.seg-btn.seg-active { color: #fff !important; }
.seg-btn.seg-active svg { stroke: #fff !important; }
#seg-indicator { pointer-events: none; z-index: 0; }

/* ── Condition options ── */
.cond-opt {
  display: inline-flex !important;
  align-items: center !important;
  padding: 8px 16px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 99px !important;
  cursor: pointer !important;
  font-size: .82rem !important;
  font-weight: 700 !important;
  color: var(--n600) !important;
  background: var(--surface) !important;
  transition: all .15s !important;
  user-select: none !important;
}
.cond-opt input[type="radio"] { display: none !important; }
.cond-opt:hover { border-color: var(--orange) !important; color: var(--orange) !important; }
.cond-opt.on { border-color: var(--orange) !important; background: var(--orange) !important; color: #fff !important; }

/* ════════════════════════════════════════════════════════
   POST_AD — submit row, post-wrap, card spacing
   ════════════════════════════════════════════════════════ */
.post-wrap {
  max-width: 860px;
  margin: 0 auto;
  padding: 24px 0 40px;
  width: 100%;
}
.submit-row {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 12px !important;
  padding: 20px 0 8px !important;
  margin-top: 8px !important;
}
.submit-row .btn,
.submit-row a,
.submit-row button {
  flex-shrink: 0 !important;
  min-width: 120px !important;
  text-align: center !important;
}
/* btn-ghost needs padding/border since button reset may strip it */
.btn-ghost {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 11px 20px !important;
  border-radius: 10px !important;
  font-weight: 600 !important;
  font-size: .9rem !important;
  cursor: pointer !important;
  text-decoration: none !important;
  background: transparent !important;
  color: var(--text-2) !important;
  border: 1.5px solid var(--border) !important;
  width: auto !important;
  transition: all .15s !important;
}
.btn-ghost:hover {
  background: var(--n50) !important;
  color: var(--text) !important;
  border-color: var(--n300) !important;
}
.btn-lg {
  padding: 13px 28px !important;
  font-size: .95rem !important;
  border-radius: 12px !important;
}

/* ════════════════════════════════════════════════════════
   CHATBOT FAB — fix icon colour (was orange on orange)
   ════════════════════════════════════════════════════════ */
#help-fab svg,
.chat-fab svg,
#help-fab .chat-fab-icon svg {
  stroke: #fff !important;
  color: #fff !important;
}
.chat-fab-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
}

/* ════════════════════════════════════════════════════════
   FOOTER — ensure full width and consistent max-width
   ════════════════════════════════════════════════════════ */
.footer {
  width: 100% !important;
}
.footer-inner {
  max-width: var(--container) !important;
  margin: 0 auto !important;
  padding: 0 clamp(20px, 4vw, 40px) !important;
  width: 100% !important;
}

/* ════════════════════════════════════════════════════════
   GLOBAL PAGE CONTAINERS — all pages same max-width
   ════════════════════════════════════════════════════════ */
.wrap {
  width: 100% !important;
  max-width: var(--container) !important;
  margin-inline: auto !important;
  padding-inline: clamp(16px, 3vw, 32px) !important;
}
/* Dashboard inner content */
.dp-inner {
  max-width: 1100px;
  padding: 28px 32px;
  width: 100%;
}
@media (max-width: 768px) {
  .dp-inner { padding: 16px; }
  .post-wrap { padding: 16px 0 24px; }
  .submit-row { flex-direction: column; }
  .submit-row .btn, .submit-row button { width: 100% !important; min-width: 0 !important; }
}

/* ════════════════════════════════════════════════════════
   form-card last child — no margin collapse into footer
   ════════════════════════════════════════════════════════ */
.form-card:last-of-type {
  margin-bottom: 0;
}
.post-wrap > .submit-row:last-child {
  padding-bottom: 32px;
}

/* ════════════════════════════════════════════════════════
   LAYOUT SYSTEM v13 — DEFINITIVE STANDARDIZATION
   All pages use the same width system:
   
   Public pages:     .wrap → max-width:1280px
   Dashboard pages:  .dp-inner → max-width:1100px  
   Auth pages:       .auth-card → max-width:460px
   Narrow content:   .content-narrow → max-width:860px
   Form-only pages:  .dp-form-wrap → max-width:600px
   ════════════════════════════════════════════════════════ */

/* ── Canonical .wrap (all public pages) ── */
.wrap {
  width: 100% !important;
  max-width: var(--container) !important;
  margin-inline: auto !important;
  padding-inline: clamp(16px, 3vw, 32px) !important;
  box-sizing: border-box !important;
}

/* ── Canonical .container (alias for .wrap) ── */
.container {
  width: 100% !important;
  max-width: var(--container) !important;
  margin-inline: auto !important;
  padding-inline: clamp(16px, 3vw, 32px) !important;
  box-sizing: border-box !important;
}

/* ── Dashboard content area ── */
.dp-inner {
  max-width: 1100px !important;
  padding: 28px 32px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
@media (max-width: 768px) {
  .dp-inner { padding: 16px !important; }
}

/* ── Auth card (login, register, forgot pwd, reset pwd) ── */
.auth-page {
  min-height: calc(100vh - var(--navbar-h, 64px)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(20px, 4vw, 48px) 16px !important;
  background: var(--bg) !important;
}
.auth-card {
  width: 100% !important;
  max-width: 460px !important;
  background: var(--surface) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-2xl) !important;
  padding: clamp(24px, 4vw, 40px) clamp(20px, 5vw, 36px) !important;
  box-shadow: var(--sh-lg) !important;
}

/* ── Register has wider card (more fields) ── */
.auth-card--wide {
  max-width: 600px !important;
}

/* ── Narrow content pages (help, legal, articles) ── */
.content-narrow {
  max-width: 860px;
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 32px);
  width: 100%;
}

/* ── Dashboard form-only pages (notification settings, security, etc) ── */
.dp-form-wrap {
  max-width: 680px;
  margin: 0 auto;
  width: 100%;
}

/* ── Dashboard page header (standardized) ── */
.dp-page-hdr {
  padding: 0 0 24px !important;
  border-bottom: 1.5px solid var(--border) !important;
  margin-bottom: 28px !important;
}
.dp-page-title {
  font-family: var(--f-display) !important;
  font-size: clamp(1.3rem, 2.5vw, 1.6rem) !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  margin: 0 0 4px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.dp-page-sub {
  font-size: .875rem !important;
  color: var(--text-2) !important;
  margin: 0 !important;
}

/* ── Post-wrap (publicar/editar anuncio) ── */
.post-wrap {
  max-width: 860px !important;
  margin: 0 auto !important;
  padding: 24px 0 48px !important;
  width: 100% !important;
}

/* ── Sidebar dashboard responsive ── */
@media (max-width: 900px) {
  .dp-side { display: none !important; }
  .dp-content { width: 100% !important; }
}
@media (max-width: 768px) {
  .dp-inner { padding: 16px !important; }
  .post-wrap { padding: 16px 0 32px !important; }
  .auth-card { margin: 0 16px !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   GLOBAL LAYOUT SYSTEM — DEFINITIVE
   ──────────────────────────────────────────────────────────────────────────
   ⚠ FUTURE DEVELOPERS: READ BEFORE MODIFYING ⚠

   The navbar is position:fixed at height var(--navbar-h).
   Desktop: 64px | Mobile (≤768px): 56px

   Rule 1: <main id="main-content"> ALWAYS has padding-top:var(--navbar-h).
           This is set globally here. NEVER add it per-template.

   Rule 2: Dashboard sidebar (dp-side) is ALWAYS 220px wide.
           NEVER override this per-template. It uses var(--navbar-h) for
           sticky positioning — no hardcoded pixel values.

   Rule 3: dp-wrap always fills full viewport minus navbar height.
           NEVER use hardcoded 100px — always var(--navbar-h).

   Rule 4: Container widths:
           Public pages:    .wrap       → max-width: 1280px (var(--container))
           Dashboard pages: .dp-inner   → max-width: 1100px
           Auth pages:      .auth-card  → max-width: 460px
           Form pages:      .dp-form-wrap → max-width: 680px
           Editorial:       .content-narrow → max-width: 860px
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── 1. MAIN CONTENT AREA — global navbar offset (desktop only, mobile uses fixed positioning) ── */
@media(min-width:769px){
  main#main-content {
    padding-top: calc(var(--navbar-h) + env(safe-area-inset-top)) !important;
    min-height: calc(100vh - var(--navbar-h) - env(safe-area-inset-top)) !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
  }
}

/* ── 2. DASHBOARD LAYOUT ── */
/* dp-wrap: flex container for sidebar + content (ALL dashboard pages) */
.dp-wrap {
  display: flex !important;
  flex: 1 !important;
  min-height: calc(100vh - var(--navbar-h)) !important;
  background: var(--n50) !important;
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
}

/* dp-side: sidebar — ALWAYS 220px, ALWAYS visible when logged in */
/* ⚠ NEVER change this width per-template — it must be uniform across all pages */
.dp-side {
  width: 220px !important;
  min-width: 220px !important;
  max-width: 220px !important;
  flex-shrink: 0 !important;
  background: var(--n50) !important;
  border-right: 1px solid var(--border) !important;
  padding: 20px 0 40px !important;
  position: sticky !important;
  /* ⚠ Always use var(--navbar-h) — never hardcode px values here */
  top: calc(var(--navbar-h) + env(safe-area-inset-top)) !important;
  height: calc(100vh - var(--navbar-h) - env(safe-area-inset-top)) !important;
  overflow-y: auto !important;
  scrollbar-width: none !important;
  align-self: flex-start !important;
}
.dp-side::-webkit-scrollbar { display: none !important; }

/* dp-content: main content area — always fills remaining space */
.dp-content {
  flex: 1 !important;
  min-width: 0 !important;
  background: var(--n50) !important;
  overflow: visible !important;
}

/* dp-inner: inner padding wrapper inside dp-content */
/* ⚠ max-width:1100px ensures content doesn't stretch too wide on large screens */
.dp-inner {
  max-width: 1100px !important;
  padding: 28px 32px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* ── 3. RESPONSIVE ── */
/* ⚠ Sidebar hides at ≤900px — content goes full width automatically */
@media (max-width: 900px) {
  .dp-side {
    display: none !important;
  }
  .dp-content {
    width: 100% !important;
  }
  .dp-inner {
    padding: 20px 16px !important;
  }
}
@media (max-width: 768px) {
  main#main-content {
    padding-top: 0 !important;
  }
  .dp-wrap {
    min-height: auto !important;
    overflow: visible !important;
    display: block !important;
  }
  .dp-side {
    display: none !important;
  }
  .dp-inner {
    padding: 16px !important;
  }
}

/* ── 4. PUBLIC PAGE CONTAINERS ── */
/* ⚠ All public pages use .wrap — do NOT use inline max-width overrides */
.wrap {
  width: 100% !important;
  max-width: var(--container) !important;
  margin-inline: auto !important;
  padding-inline: clamp(16px, 3vw, 32px) !important;
  box-sizing: border-box !important;
}

/* ── 5. AUTH PAGES ── */
/* ⚠ Auth pages offset navbar with min-height — no manual padding-top needed */
.auth-page {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: calc(100vh - var(--navbar-h)) !important;
  padding: clamp(20px, 4vw, 48px) 16px !important;
  background: var(--bg) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   DEFINITIVE DASHBOARD LAYOUT FIXES
   ────────────────────────────────────────────────────────────────────────
   ⚠ ROOT CAUSE FIXES — READ BEFORE MODIFYING:

   Problem 1: dp-inner needed width:100% to fill dp-content fully.
              Without it, max-width:1100px collapses to content width.

   Problem 2: pg-split was defined as grid 1fr + 340px (two columns).
              Most dashboard pages only use ONE column (pg-right).
              The empty 340px column created dead white space on the right.
              Fix: pg-split inside dashboard is always 1 column (100% width).
              Use pg-split--aside ONLY when you have a real right panel.

   Problem 3: dp-page-hdr subtitle (dp-page-sub) overflowed on narrow viewports.
              Fix: overflow:hidden + text-overflow:ellipsis on dp-page-sub.

   Problem 4: dp-page-hdr was flex row but subtitle should be BELOW title.
              Fix: flex-direction:column, gap:4px.

   ⚠ FUTURE DEVELOPERS:
   - NEVER use pg-split as a single-column wrapper in dashboard pages.
   - If you need a real left+right split, use pg-split--aside class.
   - dp-inner always fills 100% of dp-content. Max-width is 1100px.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── dp-inner: always fills dp-content, max-width caps on wide screens ── */
.dp-inner {
  width: 100% !important;
  max-width: 1100px !important;
  padding: 28px 32px !important;
  box-sizing: border-box !important;
}
@media (max-width: 900px) {
  .dp-inner { padding: 20px 16px !important; }
}

/* ── dp-page-hdr: vertical stack, no overflow ── */
/* ⚠ ALWAYS column layout — title on top, subtitle below */
.dp-page-hdr {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 4px !important;
  padding: 0 0 20px !important;
  border-bottom: 1.5px solid var(--border) !important;
  margin-bottom: 24px !important;
  width: 100% !important;
}
.dp-page-title {
  font-family: var(--f-display) !important;
  font-size: clamp(1.3rem, 2.5vw, 1.7rem) !important;
  font-weight: 900 !important;
  color: var(--text) !important;
  margin: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  line-height: 1.2 !important;
}
.dp-page-sub {
  font-size: .88rem !important;
  color: var(--text-2) !important;
  margin: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  max-width: 100% !important;
}

/* ── pg-split inside dashboard: ALWAYS single column (no dead right space) ── */
/* ⚠ DO NOT add two columns here. Use pg-split--aside for real two-column layouts */
.dp-inner .pg-split,
.pg-split {
  display: block !important;
  width: 100% !important;
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  overflow: visible !important;
}
.dp-inner .pg-right,
.pg-right {
  display: block !important;
  width: 100% !important;
  background: transparent !important;
}
.dp-inner .pg-right-body,
.pg-right-body {
  padding: 0 !important;
  overflow: visible !important;
}

/* ── pg-split--aside: ONLY for pages with a real right panel (e.g. chat) ── */
/* ⚠ Only use this class when you have BOTH pg-left AND pg-right populated */
.pg-split--aside {
  display: grid !important;
  grid-template-columns: 1fr 320px !important;
  gap: 24px !important;
  align-items: start !important;
  width: 100% !important;
}
@media (max-width: 900px) {
  .pg-split--aside { grid-template-columns: 1fr !important; }
}

/* ═══════════════════════════════════════════════════════════════
   HELP CENTER — Hero, Search, FAQ, AI chip
   ═══════════════════════════════════════════════════════════════ */
.help-hero{background:linear-gradient(135deg,#c45c00 0%,#E87800 60%,#b35000 100%);padding:56px 24px 48px;text-align:center}
.help-search-box{display:flex;align-items:center;gap:10px;background:#fff;border-radius:50px;padding:8px 8px 8px 18px;max-width:600px;margin:0 auto;box-shadow:0 4px 24px rgba(0,0,0,.18)}
.help-search-box input{flex:1;border:none;outline:none;font-size:.95rem;color:#1a1a1a;background:transparent;min-width:0}
.help-search-box button{background:#E87800;color:#fff;border:none;border-radius:40px;padding:10px 22px;font-size:.9rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .18s}
.help-search-box button:hover{background:#c45c00}
.ai-chip{border:1.5px solid rgba(255,255,255,.25);border-radius:20px;padding:6px 14px;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .18s;background:rgba(255,255,255,.1);color:rgba(255,255,255,.85)}
.ai-chip:hover{background:rgba(255,255,255,.22);color:#fff}

/* FAQ — estilos compartidos para ambas secciones */
.faq-item{border:1.5px solid var(--border);border-radius:var(--r-xl);margin-bottom:10px;overflow:hidden;background:var(--surface)}
.faq-question,.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;background:none;border:none;text-align:left;font-size:.9rem;font-weight:600;color:var(--text);cursor:pointer;transition:background .15s}
.faq-question:hover,.faq-q:hover{background:var(--n50)}
.faq-question[aria-expanded="true"]{color:var(--brand)}
.faq-answer,.faq-a{display:none;padding:0 20px 18px;font-size:.875rem;color:var(--text-2);line-height:1.65}
.faq-answer.is-open,.faq-item.open .faq-a{display:block}
.faq-chevron{flex-shrink:0;transition:transform .22s;color:var(--n400)}
.faq-question[aria-expanded="true"] .faq-chevron{transform:rotate(180deg)}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
@media(max-width:640px){.av-card-img-wrap,.av-card-img{height:auto !important;max-height:none !important}.av-card-img{padding-top:75% !important;height:0 !important}}

.mob-icon-bar{display:none}
.pf-tabs-mobile{display:none}
.mob-cat-dropdown{display:none}
.mob-icon-label{display:none}
.mob-nav-ai-btn{display:none}
/* Ocultar barra global cuando hay local (listings) — via JS class */
body.has-local-iconbar #mob-icon-bar-global{display:none !important}

/* PWA mobile: 2 columns for ad listings */
@media(max-width:768px){
  #ads-container,.ads-grid,.listings-grid,.fav-page-grid,.av-product-grid{grid-template-columns:1fr 1fr !important;gap:8px !important}
  #ads-container.view-list,.ads-grid.view-list,.listings-grid.view-list{grid-template-columns:1fr !important}
  .ads-grid--4{grid-template-columns:1fr 1fr !important;gap:8px !important}

  /* Ocultar categorías, trending, sort pills, botón filtros grande, FAB en móvil */
  .cat-grid-desktop{display:none !important}
  .home-cats-section{display:none !important}
  .home-trending{display:none !important}
  .sort-strip{display:none !important}
  .mob-hide{display:none !important}
  .mob-nav-hide{display:none !important}
  #av-ai-fab{display:none !important}
  #av-ai-fab+*{display:none !important}
  #av-ai{position:fixed !important;bottom:0 !important;right:0 !important;z-index:9000 !important}

  /* Ocultar iconos redundantes en navbar móvil (ya están en bottom-nav o menú) */
  .nav-user-mobile{display:none !important}
  .nav-darkmode{display:none !important}

  /* Navbar iconos móvil: compactos */
  .mob-nav-ai-btn,
  .btn-camara-ia,
  .nav-ham,
  .nav-mob-search-btn,
  .nav-mob-back-btn {
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:30px !important;
    height:30px !important;
    padding:0 !important;
    border:1.5px solid var(--border) !important;
    border-radius:6px !important;
    background:var(--n50) !important;
    color:var(--text-3) !important;
    cursor:pointer !important;
    flex-shrink:0 !important;
    box-shadow:none !important;
    margin:0 !important;
  }
  .mob-nav-ai-btn:hover,
  .btn-camara-ia:hover,
  .nav-ham:hover,
  .nav-mob-search-btn:hover,
  .nav-mob-back-btn:hover {
    background:var(--brand-xs) !important;
    color:var(--brand) !important;
    border-color:rgba(232,114,10,.25) !important;
  }
  .mob-nav-ai-btn svg,
  .btn-camara-ia svg,
  .nav-ham svg,
  .nav-mob-search-btn svg,
  .nav-mob-back-btn svg {
    width:14px !important;
    height:14px !important;
    stroke:currentColor !important;
  }
  .mob-nav-ai-btn svg {
    stroke:#fff !important;
  }
  .mob-nav-ai-btn {
    background:var(--brand) !important;
    color:#fff !important;
    border-color:var(--brand) !important;
  }
  /* Agrupar iconos a la derecha */
  .nav-row-1 {
    display:flex !important;
    align-items:center !important;
    gap:3px !important;
    justify-content:flex-end !important;
  }
  .nav-row-1 .nav-logo {
    margin-right:auto !important;
  }
  .nav-wrap {
    padding:0 6px !important;
  }
  .btn-filter-toggle,.btn-filter-toggle.mob-hide,#filter-toggle-btn{display:none !important}
  .view-toggle.mob-hide{display:none !important}
  #filter-fab{display:none !important}
  #alert-banner{display:none !important}

  /* Header: reducir espacio */
  .listings-sticky-header .breadcrumb{padding:6px 0 2px !important;margin:0 !important}
  .listings-sticky-header .listings-topbar{padding:4px 0 8px !important;margin-bottom:0 !important}
  .listings-sticky-header .listings-title{font-size:.85rem !important}

  /* Icon bar fija al pie, encima del bottom-nav */
  .mob-icon-bar{display:flex !important;position:static !important;width:100%;gap:2px;align-items:center;padding:2px 4px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:none;box-sizing:border-box;overflow:hidden}
  .mob-icon-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 4px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--n50);color:var(--text-3);cursor:pointer;flex:1;min-width:0}
  .mob-icon-btn svg{width:16px;height:16px;flex-shrink:0}
  .mob-icon-btn.active{background:var(--brand-xs);color:var(--brand);border-color:rgba(232,114,10,.25)}
  .mob-icon-label{display:block !important;font-size:.52rem;font-weight:700;line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  /* Espacio para que el contenido no quede tapado por las dos barras */
  .listings-content{padding-bottom:110px !important}

  /* Cards compactas móvil */
  .av-card-body{padding:8px 10px 6px !important}
  .av-card-title{font-size:.78rem !important;margin-bottom:2px !important}
  .av-card-price{font-size:.9rem !important;margin-bottom:2px !important}
  .av-card-city{font-size:.68rem !important;margin-bottom:2px !important}
  .av-card-desc{display:none !important}
  .av-card-top-seller{display:none !important}
  .av-card-time{display:none !important}
  .av-card-actions{padding:4px 6px !important}
  .av-action-btn{padding:4px !important}
  .av-action-btn svg{width:14px !important;height:14px !important}
  .av-card-fav{width:26px !important;height:26px !important;padding:4px !important;top:5px !important;left:5px !important}
  .av-card-fav svg{width:13px !important;height:13px !important}

  /* Ocultar flechas slider y zoom en móvil */
  .av-card-prev,.av-card-next{display:none !important}
  .av-card-zoom{display:none !important}
  /* Dots grandes y pulsables */
  .av-card-dots{gap:6px !important;bottom:6px !important}
  .card-dot{width:10px !important;height:10px !important;border:1.5px solid rgba(255,255,255,.8) !important;background:rgba(0,0,0,.3) !important}
  .card-dot--active{background:#fff !important;border-color:#fff !important}

  /* Ocultar chat en action bar móvil (ya hay acceso desde detalle) */
  /* Chat visible en móvil dentro de contact-group */

  /* Mob icon bar: dropdown categorías (se abre hacia arriba) */
  .mob-cat-dropdown{display:none;position:absolute;bottom:calc(100% + 8px);left:0;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;box-shadow:0 -4px 24px rgba(0,0,0,.15);z-index:1000;min-width:180px;max-height:50vh;overflow-y:auto;padding:6px 0}
  .mob-cat-dropdown.open{display:block}
  .mob-cat-item{display:block;padding:9px 16px;font-size:.8rem;font-weight:600;color:var(--text-2);text-decoration:none;white-space:nowrap}
  .mob-cat-item:hover,.mob-cat-item.is-active{background:var(--brand-xs);color:var(--brand)}
}

/* ══════════════════════════════════════════════════════════════════════════
   PWA NATIVE APP FEEL — Mobile + Standalone mode
   Fixed bars, scrollable content, no bounce, centered, app-like
══════════════════════════════════════════════════════════════════════════ */

/* ── 1. Kill rubber-band bounce on iOS ── */
@media(max-width:768px){
  html,body{
    overscroll-behavior:none;
    -webkit-overflow-scrolling:auto;
    overflow-x:hidden;
  }
  body{
    position:fixed;
    width:100%;
    height:100%;
    overflow:hidden;
  }
  main#main-content{
    position:fixed !important;
    top:var(--navbar-h);
    left:0;right:0;
    bottom:calc(58px + env(safe-area-inset-bottom));
    overflow-y:auto !important;
    overflow-x:hidden !important;
    -webkit-overflow-scrolling:touch;
    padding-top:0 !important;
    padding-bottom:0 !important;
    min-height:auto !important;
    background:var(--bg) !important;
    z-index:1;
  }

  /* ── 2. Navbar always fixed, no shift ── */
  .navbar{
    position:fixed !important;
    top:0 !important;
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
    transform:translateZ(0);
  }

  /* ── 3. Bottom nav always fixed, no shift ── */
  .av-bottom-nav{
    position:fixed !important;
    bottom:0 !important;
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
    transform:translateZ(0);
  }

  /* ── 4. Content centered by default ── */
  .container,.page-wrap,.wide-wrap,.wrap,.home-wrap{
    box-sizing:border-box !important;
  }

  /* ── 5. Footer, back-to-top & AI close btn hidden on mobile ── */
  .footer{
    display:none !important;
  }
  .back-to-top{
    display:none !important;
  }
  #av-ai-close{
    display:none !important;
  }
  #av-ai{
    display:none !important;
  }

  /* ── 6. Flash messages below navbar ── */
  .flash-messages{
    top:calc(var(--navbar-h) + env(safe-area-inset-top) + 8px) !important;
  }
}

/* ── Standalone PWA enhancements ── */
@media(display-mode:standalone){
  /* No text selection on UI elements (app-like) */
  .navbar,.av-bottom-nav,.btn,.nav-logo,.dp-page-title{
    -webkit-user-select:none;
    user-select:none;
  }

  /* Smooth transitions between sections */
  main#main-content{
    scroll-behavior:smooth;
  }

  /* Prevent pull-to-refresh on iOS */
  body{
    overscroll-behavior-y:contain;
  }
}
