/*
  Guerrero 108 — user.css (Cassiopeia child template)
  Paleta: Concreto oscuro + Bronce dorado + Blanco cálido + Terracota suave
  Tipografía: Playfair Display (display) + Inter (body)
  Firma visual: barra de bronce en headers y separadores horizontales
*/

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;700&family=Inter:wght@300;400;500;600&display=swap');

/* ============================================================
   TOKENS
   ============================================================ */
:root {
  --color-carbon:    #1C1C1C;
  --color-bronze:    #A8834A;
  --color-bronze-lt: #C9A96E;
  --color-cream:     #F7F4EF;
  --color-stone:     #E8E2D9;
  --color-terracota: #B05A3A;
  --color-text:      #2E2E2E;
  --color-muted:     #6B6560;
  --radius:          4px;
  --shadow:          0 2px 12px rgba(0,0,0,0.08);
  --transition:      0.25s ease;
}

/* ============================================================
   BASE
   ============================================================ */
body {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.7;
  color: var(--color-text);
  background: var(--color-cream);
}

h1, h2, h3, h4 {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
  color: var(--color-carbon);
  letter-spacing: -0.02em;
}

a {
  color: var(--color-bronze);
  text-decoration: none;
  transition: color var(--transition);
}
a:hover { color: var(--color-terracota); }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.header {
  background: var(--color-carbon) !important;
  border-bottom: 3px solid var(--color-bronze);
  padding: 0 !important;
}

.navbar {
  background: transparent !important;
  padding: 0.75rem 1.5rem;
}

.navbar-brand {
  font-family: 'Playfair Display', serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-cream) !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.navbar-brand span {
  color: var(--color-bronze);
}

.nav-item .nav-link {
  color: #C8C2B8 !important;
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 1rem 1.2rem !important;
  transition: color var(--transition), border-bottom var(--transition);
  border-bottom: 2px solid transparent;
}

.nav-item .nav-link:hover,
.nav-item.active .nav-link {
  color: var(--color-bronze-lt) !important;
  border-bottom-color: var(--color-bronze);
}

/* Dropdown nav */
.dropdown-menu {
  background: #252525;
  border: 1px solid #3a3a3a;
  border-top: 2px solid var(--color-bronze);
  border-radius: 0 0 var(--radius) var(--radius);
}
.dropdown-item {
  color: #C8C2B8;
  font-size: 0.82rem;
  letter-spacing: 0.05em;
  padding: 0.5rem 1.2rem;
}
.dropdown-item:hover {
  background: #2E2E2E;
  color: var(--color-bronze-lt);
}

/* ============================================================
   HERO BANNER (Módulo de posición "banner")
   ============================================================ */
.g108-hero {
  position: relative;
  background: var(--color-carbon);
  min-height: 420px;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.g108-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('https://placehold.co/1600x420/1C1C1C/A8834A?text=Edificio+Guerrero+108') center/cover no-repeat;
  opacity: 0.35;
}

.g108-hero-content {
  position: relative;
  z-index: 2;
  max-width: 700px;
  padding: 3rem 2rem;
}

.g108-hero-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.g108-hero-eyebrow::after {
  content: '';
  display: inline-block;
  width: 40px;
  height: 1px;
  background: var(--color-bronze);
}

.g108-hero h1 {
  color: var(--color-cream);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.15;
  margin-bottom: 1.25rem;
}

.g108-hero p {
  color: #C8C2B8;
  font-size: 1.05rem;
  margin-bottom: 1.75rem;
}

/* ============================================================
   BOTONES
   ============================================================ */
.btn-g108-primary {
  display: inline-block;
  background: var(--color-bronze);
  color: var(--color-carbon) !important;
  font-family: 'Inter', sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius);
  transition: background var(--transition);
  border: none;
}
.btn-g108-primary:hover {
  background: var(--color-bronze-lt);
  color: var(--color-carbon) !important;
}

.btn-g108-outline {
  display: inline-block;
  background: transparent;
  color: var(--color-bronze) !important;
  font-family: 'Inter', sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.7rem 1.7rem;
  border-radius: var(--radius);
  border: 1.5px solid var(--color-bronze);
  transition: all var(--transition);
}
.btn-g108-outline:hover {
  background: var(--color-bronze);
  color: var(--color-carbon) !important;
}

/* ============================================================
   CONTENIDO PRINCIPAL
   ============================================================ */
#sp-main-body {
  background: var(--color-cream);
}

.com-content-article,
.item-page {
  max-width: 860px;
}

/* Separador bronce — firma visual */
.g108-divider {
  border: none;
  height: 2px;
  background: linear-gradient(90deg, var(--color-bronze), transparent);
  margin: 2.5rem 0;
}

/* Cards de sección */
.g108-card {
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border-top: 3px solid var(--color-bronze);
  padding: 1.75rem;
  margin-bottom: 1.5rem;
  transition: box-shadow var(--transition), transform var(--transition);
}
.g108-card:hover {
  box-shadow: 0 4px 20px rgba(168,131,74,0.15);
  transform: translateY(-2px);
}
.g108-card h3 {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}
.g108-card p { color: var(--color-muted); }

/* Grid de 3 columnas para amenidades/servicios */
.g108-grid-3 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.5rem;
  margin: 2rem 0;
}

/* Etiqueta de acceso */
.g108-badge {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.2rem 0.6rem;
  border-radius: 2px;
  margin-bottom: 0.5rem;
}
.g108-badge-public  { background: #EDF7ED; color: #2D7A2D; }
.g108-badge-private { background: #EEF4FF; color: #2952B3; }
.g108-badge-vip     { background: #FFF8E7; color: #8A5D00; }

/* Aviso de sección privada */
.g108-access-notice {
  background: #FFF8E7;
  border-left: 4px solid var(--color-bronze);
  padding: 1rem 1.25rem;
  border-radius: 0 var(--radius) var(--radius) 0;
  margin: 2rem 0;
  font-size: 0.9rem;
  color: var(--color-text);
}

/* Placeholder de imagen */
.g108-img {
  width: 100%;
  border-radius: var(--radius);
  display: block;
  margin: 1.5rem 0;
}
.g108-img-caption {
  font-size: 0.78rem;
  color: var(--color-muted);
  text-align: center;
  margin-top: -0.75rem;
  margin-bottom: 1.5rem;
}

/* ============================================================
   MÓDULO DESTACADO / ANUNCIO
   ============================================================ */
.g108-notice-banner {
  background: var(--color-carbon);
  color: var(--color-cream);
  padding: 1rem 2rem;
  text-align: center;
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  border-bottom: 2px solid var(--color-bronze);
}
.g108-notice-banner strong { color: var(--color-bronze); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: var(--color-carbon) !important;
  border-top: 3px solid var(--color-bronze);
  color: #9A9490 !important;
  font-size: 0.82rem;
  padding: 2.5rem 1.5rem !important;
}

.footer a { color: var(--color-bronze-lt) !important; }
.footer a:hover { color: var(--color-cream) !important; }

.g108-footer-brand {
  font-family: 'Playfair Display', serif;
  font-size: 1.2rem;
  color: var(--color-cream);
  margin-bottom: 0.25rem;
}

.g108-footer-tagline {
  font-size: 0.75rem;
  color: var(--color-bronze);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
}

.g108-footer-cols {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 2rem;
  margin-bottom: 2rem;
}

.g108-footer-col h5 {
  font-family: 'Inter', sans-serif;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: 0.75rem;
}

.g108-footer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.g108-footer-col li { margin-bottom: 0.4rem; }

.g108-footer-bottom {
  border-top: 1px solid #333;
  padding-top: 1.25rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.75rem;
}

/* ============================================================
   FORMULARIOS
   ============================================================ */
.control-label, label {
  font-family: 'Inter', sans-serif;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-bottom: 0.35rem;
}

.form-control, input[type="text"], input[type="email"], textarea {
  border: 1.5px solid var(--color-stone);
  border-radius: var(--radius);
  background: #fff;
  padding: 0.65rem 0.9rem;
  font-family: 'Inter', sans-serif;
  color: var(--color-text);
  transition: border-color var(--transition);
}

.form-control:focus, input:focus, textarea:focus {
  border-color: var(--color-bronze);
  outline: none;
  box-shadow: 0 0 0 3px rgba(168,131,74,0.12);
}

.btn-primary {
  background: var(--color-bronze) !important;
  border-color: var(--color-bronze) !important;
  color: var(--color-carbon) !important;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: 0.08em;
}
.btn-primary:hover {
  background: var(--color-bronze-lt) !important;
  border-color: var(--color-bronze-lt) !important;
}

/* ============================================================
   LOGIN FORM
   ============================================================ */
.g108-login-wrap {
  max-width: 420px;
  margin: 3rem auto;
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border-top: 3px solid var(--color-bronze);
  padding: 2.5rem;
}

.g108-login-wrap h2 {
  font-size: 1.4rem;
  margin-bottom: 0.25rem;
}

/* ============================================================
   AVISOS / COMUNICADOS (lista de artículos)
   ============================================================ */
.g108-post-list article {
  border-bottom: 1px solid var(--color-stone);
  padding: 1.5rem 0;
}
.g108-post-list article:last-child { border-bottom: none; }

.g108-post-date {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: 0.25rem;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .g108-hero { min-height: 300px; }
  .g108-hero h1 { font-size: 1.75rem; }
  .g108-grid-3 { grid-template-columns: 1fr; }
  .g108-footer-bottom { flex-direction: column; text-align: center; }
}

/* ============================================================
   PORTAL DE RESIDENTES — estilos adicionales
   Aplican a las páginas con acceso Residente y ResidenteAlCorriente
   ============================================================ */

/* ── Shell de dos columnas (sidebar + main) ── */
.g108-portal-shell{display:flex;min-height:80vh;gap:0}
.g108-portal-sidebar{
  width:240px;flex-shrink:0;
  background:var(--color-carbon);
  border-right:3px solid var(--color-bronze);
  border-radius:var(--radius) 0 0 var(--radius);
}
.g108-portal-main{flex:1;min-width:0;padding:2rem}

/* ── Banners de estado de cuenta ── */
.g108-corriente-banner{
  background:linear-gradient(135deg,#1a1208 0%,#2A2010 100%);
  border:1px solid #4A3818;border-radius:var(--radius);
  padding:1.1rem 1.5rem;margin-bottom:1.5rem;
  display:flex;align-items:center;gap:1rem;
}
.g108-corriente-banner .label{
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--color-bronze);margin-bottom:.15rem;
}
.g108-corriente-banner .title{font-size:.9rem;font-weight:600;color:#F7F4EF}
.g108-corriente-banner .icon{font-size:1.6rem}
.g108-corriente-banner .cta{
  margin-left:auto;
  font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  background:var(--color-bronze);color:var(--color-carbon);
  padding:.4rem 1rem;border-radius:var(--radius);white-space:nowrap;
}

/* ── Aviso fijado destacado ── */
.g108-aviso-destacado{
  background:#FFF8E7;border:1px solid #E8D08A;
  border-left:4px solid var(--color-bronze);border-radius:var(--radius);
  padding:1.25rem 1.5rem;margin-bottom:1.5rem;
  display:flex;align-items:flex-start;gap:1rem;
}
.g108-aviso-destacado .icon{font-size:1.4rem;flex-shrink:0;margin-top:.1rem}
.g108-aviso-destacado .badge{
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--color-bronze);margin-bottom:.2rem;
}
.g108-aviso-destacado .title{font-size:.95rem;font-weight:600;color:var(--color-carbon);margin-bottom:.25rem}
.g108-aviso-destacado .text{font-size:.85rem;color:var(--color-muted)}
.g108-aviso-destacado .date{font-size:.72rem;color:#A89050;margin-top:.4rem}

/* ── Lista de avisos ── */
.g108-aviso-list{display:flex;flex-direction:column;gap:1rem}
.g108-aviso-card{
  background:#fff;border-radius:var(--radius);border:1px solid var(--color-stone);
  padding:1.25rem 1.5rem;
  display:flex;align-items:flex-start;gap:1.25rem;
  transition:box-shadow var(--t),border-color var(--t);
}
.g108-aviso-card:hover{box-shadow:var(--shadow);border-color:var(--color-bronze)}
.g108-aviso-icon{
  width:38px;height:38px;border-radius:var(--radius);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.g108-aviso-icon.mantenimiento{background:#EDF7ED}
.g108-aviso-icon.asamblea{background:#EEF4FF}
.g108-aviso-icon.pago{background:#FFF8E7}
.g108-aviso-icon.info{background:#F3EEF8}
.g108-aviso-body{flex:1;min-width:0}
.g108-aviso-meta{display:flex;align-items:center;gap:.6rem;margin-bottom:.3rem;flex-wrap:wrap}
.g108-aviso-tag{
  font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:.15rem .5rem;border-radius:2px;
}
.g108-aviso-tag.mantenimiento{background:#EDF7ED;color:#2D7A2D}
.g108-aviso-tag.asamblea{background:#EEF4FF;color:#2952B3}
.g108-aviso-tag.pago{background:#FFF8E7;color:#7A5800}
.g108-aviso-tag.info{background:#F3EEF8;color:#6B3FA0}
.g108-aviso-date{font-size:.72rem;color:var(--color-muted)}
.g108-aviso-title{font-size:.92rem;font-weight:600;color:var(--color-carbon);margin-bottom:.3rem}
.g108-aviso-excerpt{font-size:.83rem;color:var(--color-muted);line-height:1.55}

/* ── Calendario ── */
.g108-cal-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.g108-cal-widget{background:#fff;border-radius:var(--radius);border:1px solid var(--color-stone);overflow:hidden}
.g108-cal-header{
  background:var(--color-carbon);color:#F7F4EF;
  padding:.85rem 1.25rem;display:flex;align-items:center;justify-content:space-between;
}
.g108-cal-header h3{font-family:'Playfair Display',serif;font-size:1rem;color:#F7F4EF}
.g108-cal-days-header{display:grid;grid-template-columns:repeat(7,1fr);background:#252525}
.g108-cal-day-name{text-align:center;font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#6B6560;padding:.45rem 0}
.g108-cal-days{display:grid;grid-template-columns:repeat(7,1fr)}
.g108-cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--color-muted);cursor:pointer;position:relative;transition:background var(--t),color var(--t)}
.g108-cal-day:hover{background:var(--color-stone);color:var(--color-carbon)}
.g108-cal-day.today{background:var(--color-bronze);color:var(--color-carbon);font-weight:700;border-radius:50%}
.g108-cal-day.has-event::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--color-terracota)}
.g108-event-item{
  background:#fff;border-radius:var(--radius);border:1px solid var(--color-stone);
  padding:1rem 1.25rem;display:flex;gap:1rem;align-items:flex-start;margin-bottom:.75rem;
}
.g108-event-date{
  text-align:center;background:var(--color-carbon);
  border-radius:var(--radius);padding:.4rem .7rem;min-width:48px;flex-shrink:0;
}
.g108-event-date .day{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;line-height:1;color:var(--color-bronze-lt)}
.g108-event-date .month{font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#6B6560}
.g108-event-title{font-size:.88rem;font-weight:600;color:var(--color-carbon);margin-bottom:.15rem}
.g108-event-desc{font-size:.78rem;color:var(--color-muted)}

/* ── Directorio ── */
.g108-dir-card{
  background:#fff;border-radius:var(--radius);border:1px solid var(--color-stone);
  padding:1.1rem 1.25rem;display:flex;align-items:center;gap:1rem;
  transition:box-shadow var(--t),border-color var(--t);margin-bottom:.75rem;
}
.g108-dir-card:hover{box-shadow:var(--shadow);border-color:var(--color-bronze)}
.g108-dir-card.emergency{border-left:3px solid var(--color-terracota)}
.g108-dir-avatar{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
}
.g108-dir-name{font-size:.88rem;font-weight:600;color:var(--color-carbon)}
.g108-dir-role{font-size:.75rem;color:var(--color-muted)}
.g108-dir-phone{font-size:.8rem;font-weight:600;color:var(--color-bronze);margin-top:.2rem}
.g108-dir-tag{
  font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:.12rem .4rem;border-radius:2px;margin-left:auto;flex-shrink:0;
}
.g108-dir-tag.urgente{background:#FEE8E2;color:var(--color-terracota)}
.g108-dir-tag.horario{background:var(--color-stone);color:var(--color-muted)}

/* ── Tickets / HESK ── */
.g108-ticket-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--color-stone);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem}
.g108-ticket-stat{background:#fff;padding:1rem 1.25rem;text-align:center}
.g108-ticket-stat .n{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;line-height:1}
.g108-ticket-stat .n.open{color:var(--color-terracota)}
.g108-ticket-stat .n.pending{color:#E8A020}
.g108-ticket-stat .n.resolved{color:#2D7A2D}
.g108-ticket-stat .n.total{color:var(--color-bronze)}
.g108-ticket-stat .l{font-size:.7rem;color:var(--color-muted);margin-top:.2rem;letter-spacing:.06em;text-transform:uppercase}
.g108-ticket-status{
  display:inline-flex;align-items:center;font-size:.7rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  padding:.2rem .6rem;border-radius:10px;white-space:nowrap;
}
.g108-ticket-status.open{background:#FEE8E2;color:var(--color-terracota)}
.g108-ticket-status.pending{background:#FFF5DC;color:#8A5D00}
.g108-ticket-status.resolved{background:#EDF7ED;color:#2D7A2D}
.g108-ticket-status.new{background:#EEF4FF;color:#2952B3}

/* ── Formularios del portal ── */
.g108-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}
.g108-form-group{display:flex;flex-direction:column;gap:.3rem}
.g108-form-group.full{grid-column:1/-1}
.g108-form-label{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}
.g108-form-input,.g108-form-select,.g108-form-textarea{
  border:1.5px solid var(--color-stone);border-radius:var(--radius);
  padding:.55rem .85rem;font-family:'Inter',sans-serif;font-size:.85rem;
  color:var(--color-text);background:#fff;transition:border-color var(--t);width:100%;
}
.g108-form-input:focus,.g108-form-select:focus,.g108-form-textarea:focus{
  outline:none;border-color:var(--color-bronze);
  box-shadow:0 0 0 3px rgba(168,131,74,.1);
}
.g108-form-textarea{resize:vertical;min-height:90px}
.g108-form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}

/* Responsive portal */
@media(max-width:768px){
  .g108-portal-shell{flex-direction:column}
  .g108-portal-sidebar{width:100%}
  .g108-cal-grid,.g108-form-grid{grid-template-columns:1fr}
  .g108-ticket-stats{grid-template-columns:repeat(2,1fr)}
}
