/* ============================================================
   Club de Coleccionistas de Albacete y Provincia — v2
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --rojo: #C0392B;
  --rojo-osc: #96281B;
  --rojo-cl: #E74C3C;
  --negro: #111111;
  --negro2: #1E1E1E;
  --gris-osc: #444;
  --gris: #888;
  --gris-cl: #E5E5E5;
  --gris-bg: #F5F4F2;
  --blanco: #FFFFFF;
  --sombra: 0 2px 16px rgba(0,0,0,0.08);
  --sombra-h: 0 8px 32px rgba(192,57,43,0.15);
  --r: 8px;
  --nav-h: 62px;
  --ease: cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',sans-serif;background:var(--gris-bg);color:var(--negro);min-height:100vh;display:flex;flex-direction:column;line-height:1.6;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
button{font-family:inherit;cursor:pointer}

/* ── HEADER FIJO ── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000}
.header-spacer{height:var(--nav-h)}

.navbar{
  background:var(--negro);
  border-bottom:3px solid var(--rojo);
  height:var(--nav-h);
}

.nav-inner{
  max-width:1260px;
  margin:0 auto;
  padding:0 1.5rem;
  height:100%;
  display:flex;
  align-items:center;
  gap:1.5rem;
}

/* Logo */
.nav-logo{
  text-decoration:none;
  display:flex;
  align-items:center;
  gap:0.6rem;
  flex-shrink:0;
}
.nav-logo-mark{
  width:34px;height:34px;
  background:var(--rojo);
  color:#fff;
  font-family:'Playfair Display',serif;
  font-weight:900;
  font-size:1.1rem;
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.nav-logo-text{display:flex;flex-direction:column;line-height:1}
.nav-logo-main{font-family:'Playfair Display',serif;font-weight:900;font-size:1.05rem;color:#fff;letter-spacing:0.08em}
.nav-logo-sub{font-size:0.62rem;color:#888;letter-spacing:0.03em;margin-top:2px}

/* Nav links */
.nav-links{
  display:flex;
  align-items:center;
  gap:0.1rem;
  list-style:none;
  margin-left:auto;
}
.nav-links a{
  color:#bbb;
  text-decoration:none;
  font-size:0.84rem;
  font-weight:500;
  padding:0.4rem 0.85rem;
  border-radius:var(--r);
  transition:color 0.2s,background 0.2s;
  white-space:nowrap;
}
.nav-links a:hover,.nav-links a.active{color:#fff;background:rgba(255,255,255,0.08)}

/* Nav actions */
.nav-actions{display:flex;align-items:center;gap:0.5rem;flex-shrink:0}

.nav-avatar-btn{
  display:flex;align-items:center;gap:0.5rem;
  text-decoration:none;
  color:#ddd;
  font-size:0.82rem;
  font-weight:500;
  padding:0.3rem 0.6rem;
  border-radius:var(--r);
  transition:background 0.2s;
}
.nav-avatar-btn:hover{background:rgba(255,255,255,0.08)}
.nav-avatar-img{width:28px;height:28px;border-radius:50%;object-fit:cover;border:2px solid var(--rojo)}
.nav-avatar-letter{width:28px;height:28px;border-radius:50%;background:var(--rojo);color:#fff;font-family:'Playfair Display',serif;font-weight:900;font-size:0.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-username{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.nav-btn-salir{
  display:flex;align-items:center;gap:0.35rem;
  color:#888;font-size:0.82rem;text-decoration:none;
  padding:0.4rem 0.65rem;border-radius:var(--r);
  border:1px solid rgba(255,255,255,0.12);
  transition:all 0.2s;
}
.nav-btn-salir:hover{color:#fff;border-color:rgba(255,255,255,0.3)}
.btn-salir-txt{font-size:0.8rem}

.nav-btn-login{
  color:#ccc;font-size:0.84rem;font-weight:500;text-decoration:none;
  padding:0.4rem 0.9rem;border-radius:var(--r);
  border:1px solid rgba(255,255,255,0.18);
  transition:all 0.2s;
}
.nav-btn-login:hover{color:#fff;border-color:rgba(255,255,255,0.4)}

.nav-btn-registro{
  color:#fff;font-size:0.84rem;font-weight:600;text-decoration:none;
  padding:0.4rem 1rem;border-radius:var(--r);
  background:var(--rojo);
  transition:background 0.2s,transform 0.15s;
}
.nav-btn-registro:hover{background:var(--rojo-osc);transform:translateY(-1px)}

/* Hamburger */
.hamburger{
  display:none;
  background:none;border:none;
  padding:0.4rem;
  flex-direction:column;gap:5px;
  cursor:pointer;
}
.ham-line{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all 0.28s var(--ease)}
.hamburger.open .ham-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open .ham-line:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open .ham-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Menú móvil */
.mobile-menu{
  background:var(--negro2);
  border-bottom:3px solid var(--rojo);
  max-height:0;
  overflow:hidden;
  transition:max-height 0.35s var(--ease);
}
.mobile-menu.open{max-height:600px}
.mobile-menu ul{list-style:none;padding:0.75rem 1rem 1rem}
.mobile-menu a{
  display:flex;align-items:center;gap:0.5rem;
  color:#ccc;text-decoration:none;
  padding:0.75rem 0.85rem;border-radius:var(--r);
  font-size:0.95rem;font-weight:500;
  transition:background 0.15s,color 0.15s;
}
.mobile-menu a:hover{background:rgba(255,255,255,0.07);color:#fff}
.mm-divider{height:1px;background:rgba(255,255,255,0.08);margin:0.4rem 0}
.mm-salir{color:var(--rojo-cl)!important}
.mm-registro{color:var(--rojo-cl)!important;font-weight:600!important}
.mm-login{color:#aaa}
.mm-social{display:flex;gap:1rem;padding:0.75rem 0.85rem}
.mm-social a{color:#aaa;padding:0!important;background:none!important}
.mm-social a:hover{color:#fff!important}

/* ── BOTONES ── */
.btn{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.65rem 1.4rem;
  border-radius:var(--r);
  font-family:'DM Sans',sans-serif;
  font-size:0.88rem;font-weight:600;
  text-decoration:none;
  border:2px solid transparent;
  cursor:pointer;
  transition:all 0.22s var(--ease);
  line-height:1.2;
}
.btn-primary{background:var(--rojo);color:#fff;border-color:var(--rojo)}
.btn-primary:hover{background:var(--rojo-osc);border-color:var(--rojo-osc);transform:translateY(-1px);box-shadow:var(--sombra-h)}
.btn-ghost{background:transparent;color:var(--negro);border-color:var(--gris-cl)}
.btn-ghost:hover{border-color:var(--negro);background:var(--negro);color:#fff}
.btn-ghost-w{background:transparent;color:#fff;border-color:rgba(255,255,255,0.3)}
.btn-ghost-w:hover{border-color:#fff;background:rgba(255,255,255,0.08)}
.btn-danger{background:var(--rojo);color:#fff;border-color:var(--rojo)}
.btn-sm{padding:0.4rem 0.9rem;font-size:0.8rem}
.btn-xs{padding:0.28rem 0.6rem;font-size:0.74rem}
.btn-icono{padding:0.4rem;border-radius:6px}
.btn-block{width:100%;justify-content:center}

/* ── LAYOUT ── */
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:5rem 1.5rem}
.section-sm{padding:3rem 1.5rem}

.section-hd{text-align:center;margin-bottom:3rem}
.section-hd h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;margin-bottom:0.5rem}
.section-hd h2 em{font-style:normal;color:var(--rojo)}
.section-hd p{color:var(--gris);max-width:480px;margin:0 auto;font-size:0.95rem}
.divider-r{width:40px;height:4px;background:var(--rojo);border-radius:2px;margin:0.75rem auto}

/* ── HERO ── */
.hero{
  background:var(--negro);
  color:#fff;
  padding:5rem 1.5rem 4.5rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 65% 40%,rgba(192,57,43,0.18) 0%,transparent 65%);
  pointer-events:none;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:0.4rem;
  background:rgba(192,57,43,0.2);
  border:1px solid rgba(192,57,43,0.4);
  color:var(--rojo-cl);
  font-size:0.72rem;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:0.3rem 1rem;border-radius:99px;
  margin-bottom:1.5rem;
}
.hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.4rem,6vw,4.2rem);
  font-weight:900;line-height:1.08;
  margin-bottom:1.25rem;
}
.hero h1 em{font-style:italic;color:var(--rojo-cl)}
.hero-sub{font-size:1.05rem;color:#999;max-width:540px;margin:0 auto 1rem;line-height:1.65}
.hero-club-desc{
  font-size:0.88rem;color:#777;
  max-width:480px;margin:0 auto 2.5rem;
  line-height:1.7;
}
.hero-actions{display:flex;gap:0.75rem;justify-content:center;flex-wrap:wrap}

/* Social bar del hero */
.hero-social{
  display:flex;gap:0.75rem;justify-content:center;
  margin-top:2.5rem;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,0.08);
}
.hero-social a{
  display:inline-flex;align-items:center;gap:0.5rem;
  color:#777;font-size:0.82rem;text-decoration:none;
  padding:0.4rem 0.85rem;border-radius:var(--r);
  border:1px solid rgba(255,255,255,0.1);
  transition:all 0.2s;
}
.hero-social a:hover{color:#fff;border-color:rgba(255,255,255,0.3);background:rgba(255,255,255,0.05)}

/* ── STATS ── */
.stats-strip{background:var(--negro2);border-top:1px solid rgba(255,255,255,0.06)}
.stats-inner{
  max-width:1200px;margin:0 auto;padding:2.5rem 1.5rem;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center;
}
.stat-num{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:900;color:var(--rojo-cl)}
.stat-lbl{font-size:0.78rem;color:#666;text-transform:uppercase;letter-spacing:0.07em;margin-top:0.25rem}

/* ── CATEGORÍAS ── */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:0.75rem}
.cat-card{
  background:#fff;
  border:1px solid var(--gris-cl);
  border-radius:var(--r);
  padding:1.25rem 0.75rem;
  text-align:center;
  text-decoration:none;color:var(--negro);
  transition:all 0.2s var(--ease);
  display:block;
}
.cat-card:hover{border-color:var(--rojo);transform:translateY(-3px);box-shadow:var(--sombra-h)}
.cat-card .cc-icon{font-size:1.75rem;display:block;margin-bottom:0.4rem;line-height:1}
.cat-card .cc-name{font-size:0.75rem;font-weight:600;line-height:1.2}

/* ── CARDS DE ARTÍCULO ── */
.grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.25rem}
.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem}

.art-card{
  background:#fff;border-radius:var(--r);
  border:1px solid rgba(0,0,0,0.07);
  box-shadow:var(--sombra);
  overflow:hidden;
  transition:transform 0.22s var(--ease),box-shadow 0.22s var(--ease);
  display:flex;flex-direction:column;
}
.art-card:hover{transform:translateY(-4px);box-shadow:var(--sombra-h)}

.art-card-img{
  aspect-ratio:4/3;overflow:hidden;
  background:#f0efed;
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;
  position:relative;flex-shrink:0;
}
.art-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s var(--ease)}
.art-card:hover .art-card-img img{transform:scale(1.04)}

.art-card-badges{position:absolute;top:0.6rem;left:0.6rem;display:flex;flex-direction:column;gap:0.3rem}
.badge-dest{background:var(--rojo);color:#fff;font-size:0.62rem;font-weight:700;letter-spacing:0.08em;padding:0.18rem 0.55rem;border-radius:99px}
.badge-rareza{background:rgba(0,0,0,0.65);color:#f0c040;font-size:0.62rem;font-weight:700;padding:0.18rem 0.55rem;border-radius:99px}

.art-card-body{padding:1rem;flex:1;display:flex;flex-direction:column}
.art-card-cat{font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--rojo);margin-bottom:0.3rem}
.art-card-name{font-family:'Playfair Display',serif;font-size:0.98rem;font-weight:700;line-height:1.25;margin-bottom:0.4rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.art-card-meta{display:flex;flex-wrap:wrap;gap:0.35rem;margin-top:auto;padding-top:0.5rem}
.badge-estado{display:inline-block;padding:0.15rem 0.5rem;border-radius:99px;font-size:0.68rem;font-weight:600;background:var(--gris-bg);color:var(--gris-osc)}
.art-card-valor{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--rojo);margin-top:0.4rem}
.art-card-user{font-size:0.73rem;color:var(--gris);margin-top:0.4rem}

/* ── FICHA DE ARTÍCULO ── */
.ficha-layout{display:grid;grid-template-columns:1fr 1.15fr;gap:2.5rem;max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem}

.ficha-galeria{}
.ficha-main-img{
  aspect-ratio:1;background:#f0efed;border-radius:var(--r);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-size:6rem;box-shadow:var(--sombra);margin-bottom:0.75rem;
}
.ficha-main-img img{width:100%;height:100%;object-fit:cover}
.ficha-thumbs{display:flex;gap:0.5rem;flex-wrap:wrap}
.ficha-thumb{
  width:64px;height:64px;border-radius:6px;
  border:2px solid var(--gris-cl);overflow:hidden;
  cursor:pointer;transition:border-color 0.2s;flex-shrink:0;
  background:#f0efed;display:flex;align-items:center;justify-content:center;
}
.ficha-thumb:hover,.ficha-thumb.active{border-color:var(--rojo)}
.ficha-thumb img{width:100%;height:100%;object-fit:cover}

.ficha-info{}
.ficha-cat{font-size:0.72rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--rojo);margin-bottom:0.5rem}
.ficha-nombre{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,3vw,2rem);font-weight:900;line-height:1.1;margin-bottom:0.5rem}
.ficha-marca{font-size:0.88rem;color:var(--gris);margin-bottom:1rem}
.ficha-precio-wrap{display:flex;gap:1.5rem;align-items:baseline;margin-bottom:1.25rem;padding:1rem;background:var(--negro);border-radius:var(--r)}
.ficha-valor{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:900;color:var(--rojo-cl)}
.ficha-adq{font-size:0.8rem;color:#666}
.ficha-adq span{display:block;color:#aaa;font-size:0.68rem;text-transform:uppercase;letter-spacing:0.06em}

.ficha-badges{display:flex;flex-wrap:wrap;gap:0.5rem;margin-bottom:1.25rem}
.ficha-badge{
  display:inline-flex;align-items:center;gap:0.3rem;
  padding:0.3rem 0.75rem;border-radius:99px;
  font-size:0.75rem;font-weight:600;
  background:var(--gris-bg);color:var(--gris-osc);
  border:1px solid var(--gris-cl);
}
.ficha-badge.rojo{background:rgba(192,57,43,0.08);color:var(--rojo);border-color:rgba(192,57,43,0.2)}
.ficha-badge.dorado{background:rgba(240,192,64,0.1);color:#b8860b;border-color:rgba(240,192,64,0.3)}
.ficha-badge.verde{background:rgba(39,174,96,0.08);color:#1a7a40;border-color:rgba(39,174,96,0.2)}

.ficha-desc{font-size:0.9rem;color:var(--gris-osc);line-height:1.7;margin-bottom:1.5rem}

.ficha-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.6rem;margin-bottom:1.5rem}
.ficha-campo{background:var(--gris-bg);border:1px solid var(--gris-cl);border-radius:6px;padding:0.65rem 0.85rem}
.ficha-campo-lbl{font-size:0.67rem;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;color:var(--gris);margin-bottom:0.15rem}
.ficha-campo-val{font-size:0.88rem;font-weight:600;color:var(--negro)}

.ficha-acciones{display:flex;gap:0.6rem;flex-wrap:wrap}

/* ── COMPARADOR ── */
.comparador-bar{
  position:sticky;bottom:0;z-index:900;
  background:var(--negro);border-top:3px solid var(--rojo);
  padding:0.75rem 1.5rem;
  display:none;
  align-items:center;gap:1rem;
}
.comparador-bar.visible{display:flex}
.comp-items{display:flex;gap:0.75rem;flex:1;flex-wrap:wrap}
.comp-item{
  display:flex;align-items:center;gap:0.4rem;
  background:rgba(255,255,255,0.08);
  border-radius:6px;padding:0.35rem 0.75rem;
  font-size:0.82rem;color:#ddd;
}
.comp-item button{background:none;border:none;color:#888;font-size:0.9rem;cursor:pointer;padding:0 0.2rem;line-height:1}
.comp-item button:hover{color:#fff}

/* ── PERFIL DE USUARIO ── */
.perfil-layout{display:grid;grid-template-columns:280px 1fr;gap:2rem;max-width:1100px;margin:0 auto;padding:2rem 1.5rem}
.perfil-sidebar{}
.perfil-card{background:#fff;border-radius:var(--r);padding:2rem;text-align:center;box-shadow:var(--sombra);border:1px solid var(--gris-cl)}
.perfil-avatar{width:90px;height:90px;border-radius:50%;margin:0 auto 1rem;overflow:hidden;border:3px solid var(--rojo);background:var(--rojo);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:2rem;font-weight:900;color:#fff}
.perfil-avatar img{width:100%;height:100%;object-fit:cover}
.perfil-username{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:900;margin-bottom:0.25rem}
.perfil-ciudad{font-size:0.82rem;color:var(--gris);margin-bottom:1rem}
.perfil-bio{font-size:0.85rem;color:var(--gris-osc);line-height:1.6;margin-bottom:1rem;text-align:left}
.perfil-stats{display:grid;grid-template-columns:1fr 1fr;gap:0.5rem;margin-top:1rem}
.perfil-stat{background:var(--gris-bg);border-radius:6px;padding:0.6rem;text-align:center}
.perfil-stat-n{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:900;color:var(--rojo)}
.perfil-stat-l{font-size:0.68rem;color:var(--gris);text-transform:uppercase;letter-spacing:0.06em}

.perfil-destacados{margin-top:1.5rem}
.perfil-dest-title{font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--gris);margin-bottom:0.75rem}

/* ── DASHBOARD LAYOUT ── */
.dash-layout{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - var(--nav-h))}

.dash-sidebar{
  background:var(--negro);
  border-right:3px solid var(--rojo);
  padding:1.5rem 0;
  position:sticky;top:var(--nav-h);
  height:calc(100vh - var(--nav-h));
  overflow-y:auto;
}
.dash-sidebar-user{padding:0 1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,0.08);margin-bottom:0.75rem}
.dash-avatar{width:44px;height:44px;border-radius:50%;background:var(--rojo);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:900;font-size:1.1rem;color:#fff;margin-bottom:0.5rem;overflow:hidden}
.dash-avatar img{width:100%;height:100%;object-fit:cover}
.dash-uname{font-weight:600;color:#fff;font-size:0.88rem}
.dash-usub{color:#666;font-size:0.72rem}

.dash-nav{list-style:none}
.dash-nav a{
  display:flex;align-items:center;gap:0.65rem;
  padding:0.6rem 1rem;color:#999;text-decoration:none;
  font-size:0.84rem;font-weight:500;
  border-left:3px solid transparent;
  transition:all 0.18s;
}
.dash-nav a:hover,.dash-nav a.active{color:#fff;background:rgba(192,57,43,0.12);border-left-color:var(--rojo)}
.dash-nav .dn-icon{font-size:0.95rem;width:18px;flex-shrink:0}
.dash-nav-sep{height:1px;background:rgba(255,255,255,0.07);margin:0.5rem 1rem}

.dash-main{padding:2rem;overflow-y:auto}

/* ── FORMULARIOS ── */
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:0.81rem;font-weight:600;color:var(--negro);margin-bottom:0.35rem;letter-spacing:0.01em}
.form-group small{font-size:0.74rem;color:var(--gris);display:block;margin-top:0.25rem}

.form-control{
  width:100%;padding:0.62rem 0.9rem;
  border:1.5px solid var(--gris-cl);border-radius:var(--r);
  font-family:'DM Sans',sans-serif;font-size:0.88rem;
  color:var(--negro);background:#fff;
  transition:border-color 0.2s;outline:none;
  -webkit-appearance:none;appearance:none;
}
.form-control:focus{border-color:var(--rojo)}
textarea.form-control{resize:vertical;min-height:90px}
select.form-control{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23888' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0.85rem center;padding-right:2.2rem}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}

/* Sección desplegable del form */
.form-section{border:1.5px solid var(--gris-cl);border-radius:var(--r);margin-bottom:1rem;overflow:hidden}
.form-section-hd{
  display:flex;align-items:center;justify-content:space-between;
  padding:0.85rem 1.1rem;background:var(--gris-bg);cursor:pointer;
  user-select:none;gap:0.75rem;
}
.form-section-hd h3{font-size:0.88rem;font-weight:700;color:var(--negro);display:flex;align-items:center;gap:0.5rem}
.form-section-hd .fsh-arrow{color:var(--gris);transition:transform 0.25s;font-size:0.8rem;flex-shrink:0}
.form-section-hd.open .fsh-arrow{transform:rotate(180deg)}
.form-section-body{padding:1.1rem;display:none}
.form-section-body.open{display:block}

/* Toggle */
.toggle-wrap{display:flex;align-items:center;gap:0.65rem;margin-bottom:0.75rem}
.toggle{position:relative;width:42px;height:22px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.toggle-sl{position:absolute;cursor:pointer;inset:0;background:var(--gris-cl);border-radius:22px;transition:0.25s}
.toggle-sl:before{content:'';position:absolute;width:16px;height:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:0.25s;box-shadow:0 1px 3px rgba(0,0,0,0.2)}
.toggle input:checked+.toggle-sl{background:var(--rojo)}
.toggle input:checked+.toggle-sl:before{transform:translateX(20px)}
.toggle-lbl{font-size:0.84rem;font-weight:500;color:var(--negro)}

/* Upload de imagen */
.img-upload-zone{
  border:2px dashed var(--gris-cl);border-radius:var(--r);
  padding:1.5rem;text-align:center;cursor:pointer;
  position:relative;transition:border-color 0.2s;
  background:var(--gris-bg);
}
.img-upload-zone:hover{border-color:var(--rojo)}
.img-upload-zone input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer}
.img-upload-zone img{max-height:120px;margin:0 auto;border-radius:6px;object-fit:contain}
.img-upload-txt{font-size:0.82rem;color:var(--gris)}
.img-upload-icon{font-size:1.75rem;margin-bottom:0.4rem}

/* ── ALERTAS ── */
.alert{padding:0.8rem 1rem;border-radius:var(--r);font-size:0.85rem;font-weight:500;margin-bottom:1.1rem}
.alert-err{background:#fdf2f2;color:#8b1a1a;border-left:4px solid var(--rojo)}
.alert-ok{background:#f2fdf5;color:#1a5c33;border-left:4px solid #27ae60}
.alert-info{background:#eef5fb;color:#1a3a5c;border-left:4px solid #2980b9}

/* ── TABLA ── */
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--gris-cl)}
.table{width:100%;border-collapse:collapse;background:#fff;font-size:0.84rem}
.table th{background:var(--negro);color:#fff;padding:0.75rem 0.9rem;text-align:left;font-size:0.74rem;letter-spacing:0.07em;text-transform:uppercase;white-space:nowrap}
.table td{padding:0.75rem 0.9rem;border-bottom:1px solid var(--gris-cl);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:rgba(192,57,43,0.025)}
.table-thumb{width:42px;height:42px;border-radius:5px;object-fit:cover;background:var(--gris-bg);display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.table-thumb img{width:100%;height:100%;object-fit:cover;border-radius:5px}
.col-mob-hide{}

/* ── CARDS COLECCIÓN PÚBLICA ── */
.col-card{background:#fff;border-radius:var(--r);box-shadow:var(--sombra);border:1px solid var(--gris-cl);overflow:hidden;text-decoration:none;color:var(--negro);display:block;transition:transform 0.2s,box-shadow 0.2s}
.col-card:hover{transform:translateY(-4px);box-shadow:var(--sombra-h)}
.col-card-banner{height:120px;background:var(--negro);display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative;border-bottom:3px solid var(--rojo)}
.col-card-body{padding:1.1rem}
.col-card-user{font-size:0.73rem;color:var(--gris);margin-bottom:0.2rem}
.col-card-name{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;margin-bottom:0.4rem}
.col-card-meta{font-size:0.78rem;color:var(--gris)}

/* ── VALOR BOX ── */
.valor-box{background:var(--negro);color:#fff;border-radius:var(--r);padding:1.1rem 1.4rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.vb-label{font-size:0.72rem;color:#666;text-transform:uppercase;letter-spacing:0.08em}
.vb-num{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:900;color:var(--rojo-cl)}

/* ── FILTROS ── */
.filters-bar{background:#fff;border:1px solid var(--gris-cl);border-radius:var(--r);padding:1rem;margin-bottom:1.25rem;display:flex;flex-wrap:wrap;gap:0.6rem;align-items:center}
.filters-bar .form-control{width:auto;min-width:150px;padding:0.48rem 0.8rem;font-size:0.84rem}
.search-wrap{flex:1;min-width:200px;position:relative}
.search-wrap input{width:100%;padding-left:2.4rem;font-size:0.84rem}
.search-ico{position:absolute;left:0.75rem;top:50%;transform:translateY(-50%);color:var(--gris);display:flex;align-items:center;pointer-events:none}

/* ── MODAL ── */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:2000;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(2px)}
.modal-ov.open{display:flex}
.modal-box{background:#fff;border-radius:12px;padding:1.75rem;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 24px 80px rgba(0,0,0,0.35)}
.modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:0.9rem;border-bottom:1.5px solid var(--gris-cl)}
.modal-title{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:900}
.modal-title em{font-style:normal;color:var(--rojo)}
.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--gris);padding:0.2rem;transition:color 0.15s}
.modal-close:hover{color:var(--rojo)}

/* ── PAGINACIÓN ── */
.pagination{display:flex;gap:0.3rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}
.page-btn{padding:0.48rem 0.85rem;border:1.5px solid var(--gris-cl);border-radius:6px;background:#fff;font-size:0.82rem;font-weight:600;cursor:pointer;text-decoration:none;color:var(--negro);transition:all 0.18s}
.page-btn:hover,.page-btn.active{background:var(--rojo);border-color:var(--rojo);color:#fff}

/* ── PAGE HEADER ── */
.page-hd{background:var(--negro);color:#fff;padding:2.5rem 1.5rem 2rem;border-bottom:3px solid var(--rojo)}
.page-hd h1{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:900}
.page-hd h1 em{font-style:normal;color:var(--rojo-cl)}
.page-hd p{color:#888;font-size:0.88rem;margin-top:0.4rem}
.breadcrumb{font-size:0.75rem;color:#666;margin-bottom:0.6rem;display:flex;gap:0.4rem;align-items:center;flex-wrap:wrap}
.breadcrumb a{color:#999;text-decoration:none}
.breadcrumb a:hover{color:var(--rojo-cl)}

/* ── AUTH ── */
.auth-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:3rem 1.5rem;background:linear-gradient(145deg,var(--negro) 0%,#1a0a08 100%)}
.auth-box{background:#fff;border-radius:12px;padding:2.25rem;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,0.4)}
.auth-box h1{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:900;margin-bottom:0.2rem}
.auth-box h1 em{font-style:normal;color:var(--rojo)}
.auth-sub{color:var(--gris);font-size:0.84rem;margin-bottom:1.75rem}

/* ── FOOTER ── */
.site-footer{background:var(--negro);color:#666;border-top:3px solid var(--rojo);padding:3rem 1.5rem 1.5rem;margin-top:auto}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2.5rem;margin-bottom:2rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:2rem;font-weight:900;color:#fff;margin-bottom:0.4rem}
.footer-brand p{font-size:0.82rem;color:#666;line-height:1.5}
.footer-tagline{font-style:italic;color:var(--rojo-cl)!important;margin-top:0.4rem!important;font-size:0.8rem!important}
.footer-links h4,.footer-social h4{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#555;margin-bottom:0.75rem}
.footer-links{display:flex;flex-direction:column;gap:0.4rem}
.footer-links a{color:#777;text-decoration:none;font-size:0.84rem;transition:color 0.15s}
.footer-links a:hover{color:var(--rojo-cl)}
.footer-social{display:flex;flex-direction:column;gap:0.5rem}
.footer-social-btn{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.83rem;text-decoration:none;padding:0.45rem 0.85rem;border-radius:var(--r);transition:all 0.2s;font-weight:500;width:fit-content}
.footer-wa{background:rgba(37,211,102,0.12);color:#25d366;border:1px solid rgba(37,211,102,0.25)}
.footer-wa:hover{background:rgba(37,211,102,0.2)}
.footer-ig{background:rgba(225,48,108,0.1);color:#e1306c;border:1px solid rgba(225,48,108,0.2)}
.footer-ig:hover{background:rgba(225,48,108,0.18)}
.footer-bottom{max-width:1200px;margin:0 auto;border-top:1px solid rgba(255,255,255,0.07);padding-top:1.25rem;font-size:0.78rem;text-align:center}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:4rem 2rem;color:var(--gris)}
.empty-state .ei{font-size:3rem;margin-bottom:0.75rem}
.empty-state h3{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--negro);margin-bottom:0.4rem}

/* ── ANIMACIONES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeUp 0.45s ease both}
.anim-1{animation-delay:0.08s}
.anim-2{animation-delay:0.16s}
.anim-3{animation-delay:0.24s}

/* ── RESPONSIVE ── */

@media(max-width:1024px){
  .footer-inner{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .dash-layout{grid-template-columns:200px 1fr}
}

@media(max-width:900px){
  .dash-layout{grid-template-columns:1fr}
  .dash-sidebar{
    display:none;position:fixed;
    top:var(--nav-h);left:0;bottom:0;
    width:260px;z-index:800;
    height:auto;
  }
  .dash-sidebar.open{display:block}
  .perfil-layout{grid-template-columns:1fr}
  .ficha-layout{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}

@media(max-width:700px){
  /* Nav: ocultar links, mostrar hamburger */
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-logo-sub{display:none}
  .nav-username{display:none}
  .btn-salir-txt{display:none}

  /* Hero */
  .hero{padding:3rem 1rem 2.5rem}
  .hero h1{font-size:2.1rem}
  .hero-actions{flex-direction:column;align-items:center}
  .hero-actions .btn{width:100%;max-width:260px}
  .hero-social{flex-direction:column;align-items:center;gap:0.5rem}

  /* Stats */
  .stats-inner{grid-template-columns:1fr 1fr;padding:1.75rem 1rem}
  .stat-num{font-size:1.7rem}

  /* Secciones */
  .section{padding:2.75rem 1rem}
  .section-sm{padding:2rem 1rem}
  .container{padding:0 1rem}

  /* Grids */
  .grid-4{grid-template-columns:1fr 1fr;gap:0.85rem}
  .grid-3{grid-template-columns:1fr;gap:0.85rem}
  .cat-grid{grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:0.5rem}
  .cat-card{padding:0.85rem 0.5rem}
  .cat-card .cc-icon{font-size:1.4rem}

  /* Formularios */
  .form-row,.form-row-3{grid-template-columns:1fr}

  /* Filtros apilados */
  .filters-bar{flex-direction:column;align-items:stretch;padding:0.85rem}
  .filters-bar .form-control{width:100%;min-width:unset}
  .search-wrap{flex:none;width:100%;min-width:unset}
  .filters-bar .btn{width:100%;justify-content:center}

  /* Tabla */
  .table-wrap{margin:0 -1rem;border-radius:0;border-left:none;border-right:none}
  .table{font-size:0.78rem}
  .table th,.table td{padding:0.6rem 0.7rem}
  .col-mob-hide{display:none}

  /* Dashboard */
  .dash-main{padding:1.25rem 1rem}
  .valor-box{flex-direction:column;text-align:center}

  /* Auth */
  .auth-wrap{padding:1.5rem 1rem;align-items:flex-start;padding-top:2rem}
  .auth-box{padding:1.75rem 1.25rem}

  /* Footer */
  .footer-inner{grid-template-columns:1fr}
  .footer-brand{grid-column:unset}

  /* Ficha */
  .ficha-grid{grid-template-columns:1fr}
  .ficha-precio-wrap{flex-direction:column;gap:0.5rem}

  /* Page header */
  .page-hd{padding:1.75rem 1rem 1.5rem}
  .page-hd h1{font-size:1.5rem}

  /* Modal */
  .modal-box{padding:1.5rem 1.1rem;margin:0.5rem}

  /* Perfil */
  .perfil-destacados .grid-4{grid-template-columns:repeat(3,1fr)}

  /* Touch targets */
  .btn{min-height:40px}
  .form-control{min-height:42px;font-size:16px}
  select.form-control{font-size:16px}
}

@media(max-width:400px){
  .grid-4{grid-template-columns:1fr}
  .hero h1{font-size:1.75rem}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .perfil-destacados .grid-4{grid-template-columns:1fr 1fr}
}

/* Scroll suave iOS */
.dash-sidebar,.modal-box,.table-wrap,.mobile-menu{-webkit-overflow-scrolling:touch}
html,body{overflow-x:hidden}
::placeholder{color:#bbb;opacity:1}
