/*
Theme Name: sfbalcon
Theme URI: https://www.davidalegria.com
Author: David Alegria
Author URI: https://www.davidalegria.com
Description: Ubicaciones VIP para San Fermín — Balcones y Barreras para el Encierro, Pobre de Mí y Chupinazo. Desarrollado por David Alegria para Matukio.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
License: Privado
Text Domain: sfbalcon
*/

/* ============================================
   VARIABLES & BASE
   ============================================ */
:root {
  --sf-red:       #C8102E;
  --sf-red-dark:  #9e0c24;
  --sf-gold:      #C9A84C;
  --sf-gold-lt:   #e8c875;
  --sf-dark:      #1a1a1a;
  --sf-dark-alt:  #2c2c2c;
  --sf-light:     #F8F5F0;
  --sf-muted:     #6c757d;
  --sf-white:     #ffffff;
  --sf-border:    rgba(0,0,0,0.08);
  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body:    'Inter', -apple-system, sans-serif;
  --radius:       12px;
  --radius-sm:    8px;
  --shadow:       0 4px 20px rgba(0,0,0,0.08);
  --shadow-hov:   0 8px 40px rgba(0,0,0,0.15);
  --transition:   all 0.3s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--sf-white);
  color: var(--sf-dark);
  line-height: 1.7;
  font-size: 16px;
  top: 0 !important; /* Google Translate fix */
}

h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.2;
}
a { color: var(--sf-red); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--sf-red-dark); }
img { max-width: 100%; height: auto; }

/* ============================================
   TRUST BAR
   ============================================ */
#sf-trust-bar {
  background: var(--sf-red);
  color: #fff;
  padding: .5rem 0;
  font-size: .76rem;
  font-weight: 500;
  letter-spacing: .04em;
}
.sf-trust-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 1.2rem;
  border-right: 1px solid rgba(255,255,255,.3);
}
.sf-trust-item:last-child { border-right: none; }

/* ============================================
   HEADER
   ============================================ */
#sf-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(26,26,26,.97);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(200,16,46,.3);
}
#sf-header .navbar-brand img { height: 44px; width: auto; }
.sf-brand-text {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  color: var(--sf-white);
  letter-spacing: .02em;
}
.sf-brand-text span { color: var(--sf-gold); }

.navbar-nav .nav-link {
  color: rgba(255,255,255,.82) !important;
  font-size: .83rem;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .5rem 1rem !important;
  position: relative;
}
.navbar-nav .nav-link::after {
  content:'';
  position:absolute;
  bottom:0; left:1rem; right:1rem;
  height:2px;
  background: var(--sf-gold);
  transform: scaleX(0);
  transition: var(--transition);
}
.navbar-nav .nav-link:hover { color: var(--sf-gold) !important; }
.navbar-nav .nav-link:hover::after { transform: scaleX(1); }
.navbar-toggler { border-color: rgba(255,255,255,.3) !important; }
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255%2C255%2C255%2C0.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* Google Translate */
#google_translate_element { display:flex; align-items:center; }
.goog-te-gadget-simple {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,.3) !important;
  border-radius: 6px !important;
  padding: 3px 8px !important;
  font-size: .72rem !important;
}
.skiptranslate, #goog-gt-tt { display: none !important; }

/* ============================================
   HERO
   ============================================ */
#sf-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: var(--sf-dark);
  overflow: hidden;
}
#sf-hero .hero-bg {
  position: absolute;
  inset: 0;
  background-image: url('img/hero-bg.jpg');
  background-size: cover;
  background-position: center 30%;
  transform: scale(1.05);
  transition: transform 8s ease;
}
#sf-hero.loaded .hero-bg { transform: scale(1); }
#sf-hero .hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(26,26,26,.78) 0%, rgba(200,16,46,.22) 100%);
}
#sf-hero .hero-content { position: relative; z-index: 2; }
.hero-eyebrow {
  font-family: var(--font-body);
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--sf-gold);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 12px;
}
.hero-eyebrow::before,.hero-eyebrow::after {
  content:'';
  flex: 0 0 28px;
  height: 1px;
  background: var(--sf-gold);
  opacity: .6;
}
#sf-hero h1 {
  font-size: clamp(2.4rem,6vw,5rem);
  color: var(--sf-white);
  margin-bottom: 1.5rem;
  line-height: 1.1;
}
#sf-hero h1 .accent { color: var(--sf-gold); font-style: italic; }
.hero-subtitle {
  font-size: clamp(1rem,2vw,1.2rem);
  color: rgba(255,255,255,.82);
  margin-bottom: 2.5rem;
  max-width: 560px;
}
.hero-scroll {
  position: absolute;
  bottom: 2rem; left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  color: rgba(255,255,255,.4);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  animation: bounce-down 2s infinite;
}
.hero-scroll svg { width:18px; height:18px; }
@keyframes bounce-down {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(7px); }
}

/* ============================================
   BUTTONS
   ============================================ */
.btn-sf {
  padding: 13px 30px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: .85rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  transition: var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 2px solid transparent;
  cursor: pointer;
}
.btn-sf-gold    { background:var(--sf-gold);  color:var(--sf-dark);  border-color:var(--sf-gold); }
.btn-sf-red     { background:var(--sf-red);   color:#fff;            border-color:var(--sf-red); }
.btn-sf-wa      { background:#25D366;         color:#fff;            border-color:#25D366; }
.btn-sf-outline { background:transparent;     color:#fff;            border-color:rgba(255,255,255,.45); }
.btn-sf-gold:hover    { background:var(--sf-gold-lt); border-color:var(--sf-gold-lt); color:var(--sf-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(201,168,76,.4); }
.btn-sf-red:hover     { background:var(--sf-red-dark); border-color:var(--sf-red-dark); color:#fff; transform:translateY(-2px); box-shadow:0 8px 24px rgba(200,16,46,.4); }
.btn-sf-wa:hover      { background:#1da851; border-color:#1da851; color:#fff; transform:translateY(-2px); box-shadow:0 8px 24px rgba(37,211,102,.4); }
.btn-sf-outline:hover { background:rgba(255,255,255,.08); border-color:var(--sf-gold); color:var(--sf-gold); }

/* ============================================
   SECTIONS
   ============================================ */
.sf-section      { padding: 5rem 0; }
.sf-section-alt  { background: var(--sf-light); }
.sf-section-dark { background: var(--sf-dark); color: var(--sf-white); }

.sf-event-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--sf-red);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 30px;
  margin-bottom: 1rem;
}
.sf-section-title {
  font-size: clamp(1.8rem,4vw,3rem);
  margin-bottom: .5rem;
}
.sf-section-subtitle {
  color: var(--sf-muted);
  font-size: 1.05rem;
  margin-bottom: 3rem;
}
.sf-divider {
  width: 58px; height: 3px;
  background: linear-gradient(90deg,var(--sf-red),var(--sf-gold));
  border-radius: 2px;
  margin: 1rem 0 2rem;
}

/* ============================================
   CARDS
   ============================================ */
.sf-card {
  background: var(--sf-white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: var(--transition);
  height: 100%;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--sf-border);
}
.sf-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-hov); }

.sf-card-img-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
  background: var(--sf-dark);
  min-height: 200px;
}
.sf-card-img-wrap img {
  width:100%; height:100%;
  object-fit:cover;
  transition: transform .6s ease;
}
.sf-card:hover .sf-card-img-wrap img { transform: scale(1.05); }

.sf-card-badges { position:absolute; top:.9rem; left:.9rem; display:flex; flex-wrap:wrap; gap:5px; }
.sf-avail-badge {
  display:inline-flex; align-items:center; gap:4px;
  font-size:.68rem; font-weight:700; letter-spacing:.04em;
  padding:4px 10px; border-radius:20px; text-transform:uppercase;
  backdrop-filter:blur(8px);
}
.sf-avail-badge.disponible   { background:rgba(40,167,69,.9);  color:#fff; }
.sf-avail-badge.pocas_plazas { background:rgba(255,153,0,.9);  color:#fff; }
.sf-avail-badge.agotado      { background:rgba(108,117,125,.9);color:#fff; }
.sf-avail-badge.consultar    { background:rgba(13,110,253,.9); color:#fff; }

.sf-card-precio {
  position:absolute; bottom:.9rem; right:.9rem;
  background:rgba(26,26,26,.9);
  color:var(--sf-gold);
  font-family:var(--font-heading);
  font-size:1.05rem; font-weight:700;
  padding:5px 13px; border-radius:8px;
}
.sf-card-body { padding:1.4rem; flex:1; display:flex; flex-direction:column; }
.sf-card-title { font-size:1.25rem; margin-bottom:.4rem; }
.sf-card-aforo {
  font-size:.8rem; color:var(--sf-muted);
  margin-bottom:.6rem;
  display:flex; align-items:center; gap:5px;
}
.sf-card-desc { font-size:.9rem; color:#555; line-height:1.6; margin-bottom:.9rem; flex:1; }

.sf-fechas-wrap { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:1.1rem; }
.sf-fecha-pill {
  font-size:.68rem; font-weight:600;
  padding:3px 9px; border-radius:20px; border:1.5px solid;
}
.sf-fecha-pill.disponible   { border-color:#28a745; color:#28a745; background:rgba(40,167,69,.07); }
.sf-fecha-pill.pocas_plazas { border-color:#ff9900; color:#ff9900; background:rgba(255,153,0,.07); }
.sf-fecha-pill.agotado      { border-color:#6c757d; color:#6c757d; background:rgba(108,117,125,.07); text-decoration:line-through; }

.sf-card-btns { display:flex; gap:7px; flex-wrap:wrap; margin-top:auto; }
.btn-sf-card {
  flex:1; text-align:center;
  padding:9px 14px; border-radius:var(--radius-sm);
  font-weight:600; font-size:.78rem;
  letter-spacing:.04em; text-transform:uppercase;
  transition:var(--transition); border:none;
  display:inline-flex; align-items:center; justify-content:center; gap:5px;
}
.btn-sf-card-red { background:var(--sf-red);  color:#fff; }
.btn-sf-card-red:hover { background:var(--sf-red-dark); color:#fff; }
.btn-sf-card-wa  { background:#25D366; color:#fff; }
.btn-sf-card-wa:hover { background:#1da851; color:#fff; }

/* ============================================
   SINGLE UBICACION
   ============================================ */
.sf-single-hero {
  position:relative; height:52vh; min-height:320px;
  overflow:hidden; background:var(--sf-dark);
}
.sf-single-hero img { width:100%; height:100%; object-fit:cover; opacity:.7; }
.sf-single-hero-ov {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(26,26,26,.9) 0%,transparent 60%);
}
.sf-single-hero-cnt { position:absolute; bottom:2rem; left:0; right:0; }

.sf-precio-box {
  background:linear-gradient(135deg,var(--sf-dark) 0%,#2c2c2c 100%);
  border:1px solid var(--sf-gold);
  border-radius:var(--radius);
  padding:1.6rem;
  text-align:center;
  position:sticky; top:90px;
}
.sf-precio-box .precio-num {
  font-family:var(--font-heading);
  font-size:2.8rem; color:var(--sf-gold); line-height:1;
}
.sf-precio-box .precio-lbl {
  font-size:.72rem; color:rgba(255,255,255,.55);
  text-transform:uppercase; letter-spacing:.1em;
}
.sf-precio-box .aforo-row {
  font-size:.84rem; color:rgba(255,255,255,.8);
  margin:.8rem 0;
  padding:.8rem 0;
  border-top:1px solid rgba(255,255,255,.1);
  border-bottom:1px solid rgba(255,255,255,.1);
}

.sf-incluye-list { list-style:none; padding:0; margin:0; }
.sf-incluye-list li {
  padding:.5rem 0;
  border-bottom:1px solid var(--sf-border);
  display:flex; align-items:flex-start; gap:9px;
  font-size:.94rem;
}
.sf-incluye-list li::before {
  content:'✓'; color:var(--sf-red); font-weight:700;
  flex-shrink:0; margin-top:2px;
}

.sf-evento-row {
  background:#fff;
  border:1px solid var(--sf-border);
  border-radius:var(--radius-sm);
  padding:1.2rem;
  margin-bottom:.9rem;
  transition:var(--transition);
}
.sf-evento-row:hover { border-color:var(--sf-gold); box-shadow:0 3px 15px rgba(0,0,0,.07); }
.sf-evento-hdr {
  display:flex; align-items:center;
  justify-content:space-between;
  flex-wrap:wrap; gap:8px;
  margin-bottom:.75rem;
}

.sf-mapa-wrap { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.sf-mapa-wrap img { width:100%; display:block; }

.sf-gallery-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:7px;
}
.sf-gallery-item { aspect-ratio:1; overflow:hidden; border-radius:var(--radius-sm); cursor:pointer; }
.sf-gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.sf-gallery-item:hover img { transform:scale(1.08); }

.sf-accordion .accordion-button {
  font-family:var(--font-heading);
  font-size:.97rem; font-weight:600;
  background:var(--sf-light); color:var(--sf-dark);
}
.sf-accordion .accordion-button:not(.collapsed) {
  background:var(--sf-red); color:#fff; box-shadow:none;
}
.sf-accordion .accordion-button:not(.collapsed)::after { filter:invert(1); }

/* ============================================
   CONTACT
   ============================================ */
.sf-contact-card {
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius);
  padding:1.8rem;
  transition:var(--transition);
}
.sf-contact-card:hover { background:rgba(255,255,255,.09); border-color:var(--sf-gold); }
.sf-contact-lbl { font-size:.68rem; text-transform:uppercase; letter-spacing:.14em; color:rgba(255,255,255,.5); margin-bottom:.2rem; }
.sf-contact-val { font-size:1.05rem; font-weight:600; color:#fff; }
.sf-contact-val a { color:#fff; }
.sf-contact-val a:hover { color:var(--sf-gold); }

.sf-matukio-badge {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.15);
  border-radius:30px;
  padding:7px 16px;
  font-size:.79rem; color:rgba(255,255,255,.7);
  transition:var(--transition);
  text-decoration:none;
}
.sf-matukio-badge:hover { border-color:var(--sf-gold); color:var(--sf-gold); }

/* ============================================
   FOOTER
   ============================================ */
#sf-footer {
  background:#111;
  color:rgba(255,255,255,.45);
  padding:1.8rem 0;
  font-size:.8rem;
  border-top:1px solid rgba(200,16,46,.3);
}
#sf-footer a { color:rgba(255,255,255,.55); }
#sf-footer a:hover { color:var(--sf-gold); }

/* ============================================
   WHATSAPP FLOAT
   ============================================ */
.sf-wa-float {
  position:fixed; bottom:22px; right:22px;
  width:54px; height:54px;
  border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.45rem;
  box-shadow:0 4px 18px rgba(37,211,102,.5);
  z-index:999;
  transition:var(--transition);
  animation:wa-pulse 3s infinite;
}
.sf-wa-float:hover { background:#1da851; color:#fff; transform:scale(1.1); box-shadow:0 6px 28px rgba(37,211,102,.7); }
@keyframes wa-pulse {
  0%,100% { box-shadow:0 4px 18px rgba(37,211,102,.5); }
  50%      { box-shadow:0 4px 28px rgba(37,211,102,.8),0 0 0 7px rgba(37,211,102,.1); }
}

/* ============================================
   STATS STRIP
   ============================================ */
.sf-stats-strip { background:var(--sf-light); border-top:1px solid var(--sf-border); border-bottom:1px solid var(--sf-border); padding:2.5rem 0; }
.sf-stat-num { font-family:var(--font-heading); font-size:2.5rem; color:var(--sf-red); font-weight:700; line-height:1; }
.sf-stat-lbl { font-size:.78rem; color:var(--sf-muted); text-transform:uppercase; letter-spacing:.08em; margin-top:.3rem; }

/* ============================================
   ANIMATE ON SCROLL
   ============================================ */
[data-aos] { opacity:0; transform:translateY(22px); transition:opacity .6s ease,transform .6s ease; }
[data-aos].aos-in { opacity:1; transform:translateY(0); }
[data-aos-d="1"] { transition-delay:.1s; }
[data-aos-d="2"] { transition-delay:.2s; }
[data-aos-d="3"] { transition-delay:.3s; }
[data-aos-d="4"] { transition-delay:.4s; }

/* ============================================
   UTILITIES
   ============================================ */
.text-gold  { color:var(--sf-gold) !important; }
.text-sf-red{ color:var(--sf-red)  !important; }
.font-heading { font-family:var(--font-heading) !important; }

@media (max-width:768px) {
  .sf-section { padding:3rem 0; }
  .sf-precio-box { position:static; margin-bottom:2rem; }
  #sf-trust-bar { display:none; }
  .sf-stats-strip .sf-stat-num { font-size:2rem; }
}
