/*
Theme Name: Padel Pro
Theme URI: https://github.com/padelclub-pro
Author: PadelClub Pro
Description: Template profesional para canchas de pádel con sistema de reservas, panel de configuración y landing page animada.
Version: 2.0.0
License: GNU General Public License v2 or later
Text Domain: padelclub2
Tags: landing-page, sports, booking, custom-colors
*/

/* ═══════════════════════════════════════════════════
   VARIABLES — se sobreescriben con PHP inline
═══════════════════════════════════════════════════ */
:root {
  --c1: #1a1a2e;   /* primario  */
  --c2: #16213e;   /* secundario*/
  --c3: #00d4aa;   /* acento    */
  --ctext: #f0f0f0;
  --cdark: #1a1a2e;
  --radius: 10px;
  --shadow: 0 8px 32px rgba(0,0,0,.35);
  --trans: all .3s ease;
}

/* ═══════════════════════════════════════════════════
   BASE
═══════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Nunito', 'Segoe UI', sans-serif;
  background: var(--c1);
  color: var(--ctext);
  overflow-x: hidden;
  line-height: 1.7;
}
a { color: var(--c3); text-decoration: none; transition: var(--trans); }
img { max-width: 100%; display: block; }
ul { list-style: none; }
h1,h2,h3,h4 { font-family: 'Bebas Neue', Impact, sans-serif; letter-spacing: .05em; line-height: 1.1; }
h1 { font-size: clamp(2.5rem,8vw,5.5rem); }
h2 { font-size: clamp(2rem,5vw,3.2rem); }
h3 { font-size: clamp(1.2rem,3vw,1.7rem); }

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

.sec-title { text-align:center; margin-bottom:.4rem; }
.sec-title span { color: var(--c3); }
.sec-line  { display:block; width:56px; height:4px; background:var(--c3); border-radius:2px; margin:.8rem auto 2rem; }
.sec-sub   { text-align:center; color:rgba(255,255,255,.55); font-size:1rem; margin-bottom:2.5rem; }

/* ═══════════════════════════════════════════════════
   BOTONES
═══════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.8rem 1.8rem; border-radius:var(--radius);
  font-family:'Nunito',sans-serif; font-weight:700; font-size:.9rem;
  letter-spacing:.05em; text-transform:uppercase;
  cursor:pointer; border:none; transition:var(--trans);
}
.btn-primary { background:var(--c3); color:var(--cdark); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,212,170,.4); color:var(--cdark); }
.btn-outline { background:transparent; border:2px solid var(--c3); color:var(--c3); }
.btn-outline:hover { background:var(--c3); color:var(--cdark); }
.btn-ghost  { background:rgba(255,255,255,.08); color:var(--ctext); }
.btn-ghost:hover { background:rgba(255,255,255,.16); color:var(--ctext); }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none !important; }

/* ═══════════════════════════════════════════════════
   PRELOADER
═══════════════════════════════════════════════════ */
#pc-preloader {
  position:fixed; inset:0; background:var(--c1); z-index:9999;
  display:flex; align-items:center; justify-content:center;
  transition:opacity .5s ease, visibility .5s ease;
}
#pc-preloader.hide { opacity:0; visibility:hidden; }
.pc-pre-logo { font-family:'Bebas Neue',Impact,sans-serif; font-size:3rem; color:var(--c3); animation:pcPulse 1s ease-in-out infinite; }
.pc-pre-bar  { width:180px; height:3px; background:rgba(255,255,255,.1); border-radius:2px; margin:.8rem auto 0; overflow:hidden; }
.pc-pre-bar::after { content:''; display:block; width:50%; height:100%; background:var(--c3); animation:pcBar 1s ease-in-out infinite; }
@keyframes pcPulse { 0%,100%{opacity:1}50%{opacity:.3} }
@keyframes pcBar   { 0%{transform:translateX(-100%)}100%{transform:translateX(300%)} }

/* ═══════════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════════ */
#pc-header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:1.1rem 0; transition:var(--trans);
}
#pc-header.scrolled {
  background:rgba(15,15,26,.96); backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.08);
  padding:.7rem 0; box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.pc-header-inner { display:flex; align-items:center; justify-content:space-between; }

.pc-logo { font-family:'Bebas Neue',Impact,sans-serif; font-size:1.9rem; color:var(--ctext); letter-spacing:.1em; }
.pc-logo span { color:var(--c3); }
.pc-logo img  { height:48px; width:auto; }

.pc-nav ul { display:flex; gap:1.8rem; align-items:center; }
.pc-nav a  {
  color:rgba(255,255,255,.8); font-weight:600; font-size:.88rem;
  letter-spacing:.08em; text-transform:uppercase; padding:.2rem 0; position:relative;
}
.pc-nav a::after {
  content:''; position:absolute; bottom:-2px; left:0; width:0; height:2px;
  background:var(--c3); transition:var(--trans);
}
.pc-nav a:hover::after, .pc-nav a.active::after { width:100%; }
.pc-nav a:hover { color:#fff; }
.pc-nav .nav-cta {
  background:var(--c3) !important; color:var(--cdark) !important;
  padding:.5rem 1.2rem !important; border-radius:var(--radius); font-weight:800 !important;
}
.pc-nav .nav-cta::after { display:none !important; }

.pc-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:4px; }
.pc-hamburger span { display:block; width:24px; height:2px; background:var(--ctext); border-radius:2px; transition:var(--trans); }
.pc-hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.pc-hamburger.open span:nth-child(2) { opacity:0; }
.pc-hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ═══════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════ */
#inicio {
  min-height:100vh; display:flex; align-items:center;
  position:relative; overflow:hidden; padding:0;
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center; background-attachment:fixed;
}
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(15,15,26,.88) 0%,rgba(15,15,26,.6) 60%,rgba(15,15,26,.78) 100%);
}
.hero-pattern {
  position:absolute; inset:0; opacity:.05;
  background-image:linear-gradient(var(--c3) 1px,transparent 1px),linear-gradient(90deg,var(--c3) 1px,transparent 1px);
  background-size:80px 80px;
  animation:patternDrift 18s linear infinite;
}
@keyframes patternDrift { from{background-position:0 0} to{background-position:80px 80px} }

.hero-content { position:relative; z-index:2; max-width:720px; }
.hero-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(0,212,170,.12); border:1px solid rgba(0,212,170,.35);
  color:var(--c3); padding:.35rem 1rem; border-radius:50px;
  font-size:.78rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
  margin-bottom:1.3rem; animation:fadeUp .8s ease both;
}
.hero-badge::before { content:''; width:6px; height:6px; background:var(--c3); border-radius:50%; animation:blink 1.5s ease infinite; }
@keyframes blink { 0%,100%{opacity:1}50%{opacity:.2} }

.hero-title   { margin-bottom:1.2rem; animation:fadeUp .8s ease .2s both; text-shadow:0 4px 20px rgba(0,0,0,.5); }
.hero-sub     { font-size:clamp(1rem,2vw,1.15rem); color:rgba(255,255,255,.78); max-width:520px; margin-bottom:2.2rem; animation:fadeUp .8s ease .4s both; }
.hero-btns    { display:flex; gap:1rem; flex-wrap:wrap; animation:fadeUp .8s ease .6s both; }
.hero-scroll  { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); z-index:2; color:rgba(255,255,255,.4); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; animation:bounce 2s ease-in-out infinite; display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.hero-scroll::after { content:''; width:1px; height:40px; background:linear-gradient(transparent,rgba(255,255,255,.4)); }
@keyframes bounce { 0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-7px)} }

.hero-stats { position:absolute; bottom:0; left:0; right:0; z-index:2; background:rgba(0,0,0,.38); backdrop-filter:blur(10px); border-top:1px solid rgba(255,255,255,.08); }
.hero-stats-inner { display:flex; justify-content:center; gap:4rem; padding:1.4rem 0; flex-wrap:wrap; }
.stat-num { font-family:'Bebas Neue',Impact,sans-serif; font-size:2rem; color:var(--c3); line-height:1; }
.stat-lbl { font-size:.78rem; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:.1em; }

@keyframes fadeUp { from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════════════════
   SECCIÓN TURNOS
═══════════════════════════════════════════════════ */
#turnos { background:var(--c2); }

/* Selector cancha */
.court-tabs { display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap; margin-bottom:2rem; }
.court-tab  {
  padding:.6rem 1.4rem; border-radius:50px;
  border:2px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.65); cursor:pointer; font-family:'Nunito',sans-serif;
  font-weight:600; font-size:.88rem; transition:var(--trans);
}
.court-tab:hover, .court-tab.active {
  border-color:var(--c3); color:var(--c3); background:rgba(0,212,170,.1);
}

/* Formulario de reserva */
.booking-box {
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius); padding:2rem; max-width:820px; margin:0 auto;
}
.booking-box h3 { color:var(--c3); font-size:1rem; margin-bottom:1.5rem; letter-spacing:.1em; text-transform:uppercase; }

.booking-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }

.f-group { display:flex; flex-direction:column; gap:.35rem; }
.f-label {
  font-size:.78rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.07em; color:rgba(255,255,255,.55);
}
.CFecha{
  grid-column: span 2 !important;
}
#bookingDate {
    text-align: center;
    font-size: 25px;
}
.f-ctrl {
  padding:.75rem 1rem; background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12); border-radius:var(--radius);
  color:var(--ctext); font-family:'Nunito',sans-serif; font-size:.95rem;
  transition:var(--trans); width:100%;
}
.f-ctrl:focus { outline:none; border-color:var(--c3); background:rgba(0,212,170,.05); box-shadow:0 0 0 3px rgba(0,212,170,.12); }
.f-ctrl::placeholder { color:rgba(255,255,255,.28); }
.f-ctrl option { background:#1a1a2e; }

.booking-divider { grid-column:1/-1; border:none; border-top:1px solid rgba(255,255,255,.07); margin:.3rem 0; }

.booking-notice {
  grid-column:1/-1; padding:.9rem 1rem;
  background:rgba(0,212,170,.07); border:1px solid rgba(0,212,170,.22);
  border-radius:var(--radius); font-size:.85rem; color:rgba(255,255,255,.75);
  display:none;
}
.booking-notice.show { display:block; }
.booking-notice strong { color:var(--c3); }

.booking-submit { grid-column:1/-1; margin-top:.5rem; }
.booking-submit .btn { width:100%; justify-content:center; font-size:1rem; padding:1rem; }

/* Mensaje resultado reserva */
.booking-result { display:none; padding:1.5rem; border-radius:var(--radius); text-align:center; margin-top:1rem; }
.booking-result.success { background:rgba(0,212,170,.1); border:1px solid rgba(0,212,170,.3); }
.booking-result.error   { background:rgba(220,53,69,.1);  border:1px solid rgba(220,53,69,.3); }
.booking-result .result-icon { font-size:2.5rem; margin-bottom:.5rem; }
.booking-result h4 { font-family:'Bebas Neue',Impact,sans-serif; font-size:1.5rem; color:var(--c3); margin-bottom:.4rem; }
.booking-result p  { font-size:.88rem; color:rgba(255,255,255,.7); }

/* Reservas existentes (tabla) */
.reservas-list { margin-top:2rem; }
.reservas-list h4 { font-size:.85rem; text-transform:uppercase; letter-spacing:.1em; color:rgba(255,255,255,.4); margin-bottom:1rem; text-align:center; }
.reservas-chips { display:flex; flex-wrap:wrap; gap:.5rem; justify-content:center; }
.reserva-chip {
  padding:.3rem .8rem; border-radius:4px;
  background:rgba(220,53,69,.15); border:1px solid rgba(220,53,69,.3);
  color:rgba(220,53,69,.8); font-size:.78rem; font-weight:600;
}

/* ═══════════════════════════════════════════════════
   SECCIÓN BLOG
═══════════════════════════════════════════════════ */
#blog { background:var(--c1); }
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(265px,1fr)); gap:1.4rem; }

.post-card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius); overflow:hidden; display:flex; flex-direction:column; transition:var(--trans); }
.post-card:hover { transform:translateY(-5px); border-color:rgba(0,212,170,.3); box-shadow:0 12px 40px rgba(0,0,0,.3); }
.post-thumb { height:195px; overflow:hidden; background:var(--c2); position:relative; }
.post-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.post-card:hover .post-thumb img { transform:scale(1.05); }
.post-thumb-ph { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; background:linear-gradient(135deg,var(--c1),var(--c2)); }
.post-cat { position:absolute; top:.8rem; left:.8rem; background:var(--c3); color:var(--cdark); font-size:.68rem; font-weight:800; padding:.2rem .6rem; border-radius:4px; text-transform:uppercase; letter-spacing:.1em; }

.post-body { padding:1.4rem; flex:1; display:flex; flex-direction:column; }
.post-meta { font-size:.75rem; color:rgba(255,255,255,.38); margin-bottom:.6rem; text-transform:uppercase; letter-spacing:.05em; }
.post-title { font-size:1.05rem; margin-bottom:.5rem; line-height:1.35; }
.post-title a { color:var(--ctext); }
.post-excerpt { font-size:.86rem; color:rgba(255,255,255,.55); line-height:1.7; flex:1; }
.post-more { display:inline-flex; align-items:center; gap:.3rem; color:var(--c3); font-size:.82rem; font-weight:700; margin-top:.9rem; text-transform:uppercase; }
.post-more::after { content:'→'; transition:var(--trans); }
.post-more:hover::after { transform:translateX(4px); }

/* ═══════════════════════════════════════════════════
   SECCIÓN CONTACTO
═══════════════════════════════════════════════════ */
#contacto { background:var(--c2); }
.contacto-grid { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:start; }
.info-item { display:flex; gap:.9rem; margin-bottom:1.3rem; align-items:flex-start; }
.info-icon { width:42px; height:42px; background:rgba(0,212,170,.1); border:1px solid rgba(0,212,170,.28); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.info-text strong { display:block; font-size:.78rem; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.1em; margin-bottom:.15rem; }
.info-text span { color:var(--ctext); font-size:.92rem; }

.social-row { display:flex; gap:.7rem; margin-top:1.5rem; flex-wrap:wrap; }
.social-btn { width:40px; height:40px; border-radius:50%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; font-size:.95rem; transition:var(--trans); color:var(--ctext); }
.social-btn:hover { background:var(--c3); border-color:var(--c3); color:var(--cdark); transform:translateY(-3px); }

/* Formulario contacto */
.contact-form-wrap h3 { color:var(--c3); font-size:1rem; text-transform:uppercase; letter-spacing:.1em; margin-bottom:1.2rem; }
#pc-contact-msg { margin-bottom:.8rem; font-size:.85rem; border-radius:6px; padding:.7rem .9rem; display:none; }
#pc-contact-msg.ok  { background:rgba(0,212,170,.1); border:1px solid rgba(0,212,170,.3); color:var(--c3); display:block; }
#pc-contact-msg.err { background:rgba(220,53,69,.1);  border:1px solid rgba(220,53,69,.3);  color:#ff6b6b;   display:block; }
textarea.f-ctrl { resize:vertical; min-height:110px; }

/* ═══════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════ */
#pc-footer { background:rgba(0,0,0,.45); border-top:1px solid rgba(255,255,255,.07); padding:2.5rem 0 1.2rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:2.5rem; margin-bottom:2rem; }
.footer-brand .pc-logo { font-size:1.55rem; margin-bottom:.7rem; }
.footer-brand p { color:rgba(255,255,255,.45); font-size:.85rem; line-height:1.7; max-width:280px; }
.footer-col h4 { font-family:'Bebas Neue',Impact,sans-serif; font-size:.82rem; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:.9rem; }
.footer-col ul li { margin-bottom:.45rem; }
.footer-col ul a { color:rgba(255,255,255,.55); font-size:.86rem; }
.footer-col ul a:hover { color:var(--c3); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding-top:1.2rem; display:flex; justify-content:space-between; font-size:.78rem; color:rgba(255,255,255,.3); flex-wrap:wrap; gap:.4rem; }

/* ═══════════════════════════════════════════════════
   ANIMACIONES SCROLL
═══════════════════════════════════════════════════ */
[data-anim] { opacity:0; transform:translateY(28px); transition:opacity .65s ease, transform .65s ease; }
[data-anim].on { opacity:1; transform:translateY(0); }
[data-anim="left"]  { transform:translateX(-28px); }
[data-anim="left"].on  { transform:translateX(0); }
[data-anim="right"] { transform:translateX(28px); }
[data-anim="right"].on { transform:translateX(0); }
[data-delay="1"] { transition-delay:.1s; }
[data-delay="2"] { transition-delay:.2s; }
[data-delay="3"] { transition-delay:.3s; }
[data-delay="4"] { transition-delay:.4s; }

/* ═══════════════════════════════════════════════════
   SCROLL TOP
═══════════════════════════════════════════════════ */
#pc-top {
  position:fixed; bottom:1.8rem; right:1.8rem;
  width:42px; height:42px; background:var(--c3); color:var(--cdark);
  border-radius:50%; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
  z-index:500; opacity:0; visibility:hidden; transform:translateY(8px);
  transition:var(--trans); box-shadow:0 4px 18px rgba(0,212,170,.4);
}
#pc-top.show { opacity:1; visibility:visible; transform:translateY(0); }
#pc-top:hover { transform:translateY(-3px); }

/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */
@media (max-width:900px) {
  .footer-grid { grid-template-columns:1fr 1fr; }
  .contacto-grid { grid-template-columns:1fr; gap:2rem; }
}
@media (max-width:700px) {
  section { padding:3.5rem 0; }
  .pc-hamburger { display:flex; }
  .CFecha{
  grid-column: span 1 !important;
}
  .pc-nav {
    position:fixed; top:0; right:-100%; width:min(290px,80vw); height:100vh;
    background:var(--c1); border-left:1px solid rgba(255,255,255,.08);
    padding:5rem 2rem 2rem; transition:.4s ease; z-index:999; overflow-y:auto;
  }
  .pc-nav.open { right:0; box-shadow:-10px 0 40px rgba(0,0,0,.4); }
  .pc-nav ul { flex-direction:column; gap:0; }
  .pc-nav a { display:block; padding:.8rem 0; border-bottom:1px solid rgba(255,255,255,.07); font-size:1rem; }
  .booking-grid { grid-template-columns:1fr; }
  .hero-stats-inner { gap:1.8rem; }
  .footer-grid { grid-template-columns:1fr; gap:1.8rem; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .hero-btns { flex-direction:column; }
  .hero-scroll { display:none; }
}

/* ═══════════════════════════════════════════════════
   ENTRY CONTENT (posts)
═══════════════════════════════════════════════════ */
.entry-content { font-size:1.02rem; line-height:1.85; color:rgba(255,255,255,.83); }
.entry-content h2,.entry-content h3 { color:var(--ctext); margin-top:1.8rem; margin-bottom:.8rem; }
.entry-content p { margin-bottom:1.1rem; }
.entry-content ul { list-style:disc; padding-left:1.4rem; margin-bottom:1.1rem; }
.entry-content ol { list-style:decimal; padding-left:1.4rem; margin-bottom:1.1rem; }
.entry-content li { margin-bottom:.35rem; }
.entry-content a { color:var(--c3); text-decoration:underline; }
.entry-content blockquote { border-left:4px solid var(--c3); padding:.8rem 1.2rem; background:rgba(0,212,170,.05); border-radius:0 8px 8px 0; margin:1.4rem 0; font-style:italic; color:rgba(255,255,255,.78); }
.entry-content img { border-radius:var(--radius); margin:1.3rem 0; }
