*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --black:#080a0f;--dark:#0e1117;--card:#151921;--gray:#8a8f9c;--light:#dde0e7;--white:#f2f3f5;
  --accent:#d4a843;--accent2:#1a3a6b;--accent-light:#e8c76a;--accent-dark:#a07e2e;
  --blue:#1e4d8c;--blue-light:#2a6cb8;
  --radius:16px;
}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',sans-serif;background:var(--black);color:var(--light);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
h1,h2,h3,h4{font-family:'Bebas Neue',sans-serif;font-weight:400;letter-spacing:.04em;line-height:1.1}
a,button{-webkit-tap-highlight-color:transparent}
img{max-width:100%;height:auto}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.2rem 2.5rem;display:flex;align-items:center;justify-content:space-between;backdrop-filter:blur(20px);background:rgba(8,10,15,.75);border-bottom:1px solid rgba(255,255,255,.06);transition:all .4s;gap:.8rem}
nav.scrolled{padding:.8rem 2.5rem;background:rgba(8,10,15,.92);border-bottom-color:rgba(212,168,67,.1);box-shadow:0 4px 30px rgba(0,0,0,.3)}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.08em;color:var(--white);text-decoration:none}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{color:var(--gray);text-decoration:none;font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;transition:color .3s}
.nav-links a:hover{color:var(--accent)}
.nav-cta{background:var(--accent);color:var(--black);padding:.65rem 1.6rem;border-radius:50px;font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;text-decoration:none;transition:all .3s}
.nav-cta:hover{background:var(--white);transform:scale(1.05)}
.nav-info-btn{display:flex;align-items:center;gap:.4rem;border:1.5px solid rgba(212,168,67,.5);color:var(--accent);padding:.58rem 1.2rem;border-radius:50px;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;text-decoration:none;transition:all .3s;white-space:nowrap;background:rgba(212,168,67,.06)}
.nav-info-btn:hover{background:rgba(212,168,67,.15);border-color:var(--accent);transform:scale(1.04)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none}
.hamburger span{width:24px;height:2px;background:var(--white);transition:.3s}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:8rem 2.5rem 4rem}
.hero-bg{position:absolute;inset:0;background:url('images/padel1.jpg') center/cover no-repeat}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(8,10,15,.92),rgba(8,10,15,.7) 50%,rgba(8,10,15,.85))}
.hero::before{content:'';position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at 20% 80%,rgba(212,168,67,.07),transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(30,77,140,.06),transparent 50%)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:1300px;margin:0 auto;align-items:center;width:100%;position:relative;z-index:2}
.hero-content{z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(212,168,67,.1);border:1px solid rgba(212,168,67,.25);border-radius:50px;padding:.4rem 1rem;font-size:.75rem;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:2rem;font-weight:600}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-size:clamp(3.5rem,8vw,7rem);color:var(--white);margin-bottom:1rem}
.hero h1 em{font-style:normal;color:var(--accent);display:block}
.hero-sub{font-size:1.15rem;color:var(--gray);max-width:420px;margin-bottom:2.5rem;line-height:1.7}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn-primary{background:var(--accent);color:var(--black);padding:.9rem 2.2rem;border-radius:50px;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;text-decoration:none;transition:all .3s;display:inline-flex;align-items:center;gap:.5rem;position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.15),transparent 60%);opacity:0;transition:opacity .4s}
.btn-primary:hover{background:var(--white);transform:translateY(-2px);box-shadow:0 10px 40px rgba(212,168,67,.25)}
.btn-primary:hover::after{opacity:1}
.btn-outline{border:1px solid rgba(255,255,255,.15);color:var(--white);padding:.9rem 2.2rem;border-radius:50px;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;text-decoration:none;transition:all .3s;backdrop-filter:blur(10px)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}

/* HERO VISUAL */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center}
.hero-img{width:100%;max-width:500px;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.08);transition:transform .15s ease-out}
.hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.hero-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(8,10,15,.5));pointer-events:none}
.hero-stat{position:absolute;background:rgba(21,25,33,.92);backdrop-filter:blur(12px);border:1px solid rgba(212,168,67,.15);border-radius:12px;padding:.8rem 1.2rem;z-index:3}
.hero-stat.s1{top:8%;right:-8%}
.hero-stat.s2{bottom:12%;left:-6%}
.hero-stat .num{font-family:'Bebas Neue';font-size:1.8rem;color:var(--accent);line-height:1}
.hero-stat .label{font-size:.7rem;color:var(--gray);text-transform:uppercase;letter-spacing:.06em}

/* SECTIONS */
section{padding:6rem 2.5rem}
.section-header{text-align:center;margin-bottom:4rem}
.section-header h2{font-size:clamp(2.5rem,5vw,4rem);color:var(--white);margin-bottom:.8rem}
.section-header p{color:var(--gray);max-width:500px;margin:0 auto;font-size:1rem}
.section-tag{color:var(--accent);font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;font-weight:600;margin-bottom:.5rem;background:linear-gradient(90deg,var(--accent),var(--accent-light),var(--accent));background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
[data-reveal].visible .section-tag{animation:shimmer 3s linear infinite}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}

/* FEATURES */
.features{background:var(--dark)}
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:1000px;margin:0 auto}
.feat-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:2.5rem 2rem;transition:all .4s;position:relative;overflow:hidden}
.feat-card:hover{border-color:rgba(212,168,67,.2);transform:translateY(-4px)}
.feat-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:.4s}
.feat-card:hover::after{opacity:1}
.feat-card::before{content:'';position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--accent);transition:width .5s cubic-bezier(.16,1,.3,1),left .5s cubic-bezier(.16,1,.3,1)}
.feat-card:hover::before{width:100%;left:0}
.feat-icon{width:50px;height:50px;border-radius:12px;background:rgba(212,168,67,.1);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:1.5rem}
.feat-card h3{font-size:1.5rem;color:var(--white);margin-bottom:.6rem}
.feat-card p{color:var(--gray);font-size:.9rem;line-height:1.7}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:1200px;margin:0 auto;align-items:center}
.about-img{aspect-ratio:4/3;border-radius:var(--radius);border:1px solid rgba(255,255,255,.05);overflow:hidden;position:relative}
.about-img img{width:100%;height:100%;object-fit:cover;display:block}
.about-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(30,77,140,.15),transparent);pointer-events:none}
.about-content .section-tag{text-align:left}
.about-content h2{font-size:clamp(2rem,4vw,3.2rem);color:var(--white);margin-bottom:1.2rem;text-align:left}
.about-content p{color:var(--gray);margin-bottom:1.2rem;font-size:.95rem;line-height:1.8}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.about-stat{text-align:center;padding:1rem;background:var(--card);border-radius:12px;border:1px solid rgba(255,255,255,.05)}
.about-stat .num{font-family:'Bebas Neue';font-size:2.2rem;color:var(--accent)}
.about-stat .label{font-size:.7rem;color:var(--gray);text-transform:uppercase;letter-spacing:.08em}

/* SERVICES */
.services{background:var(--dark)}
.serv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:1000px;margin:0 auto}
.serv-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:2rem;display:flex;gap:1.5rem;align-items:flex-start;transition:all .3s}
.serv-card:hover{border-color:rgba(212,168,67,.15);transform:translateX(4px)}
.serv-num{font-family:'Bebas Neue';font-size:2.5rem;color:rgba(212,168,67,.2);line-height:1}
.serv-card h3{font-size:1.2rem;color:var(--white);margin-bottom:.4rem;font-family:'Bebas Neue';letter-spacing:.04em}
.serv-card p{font-size:.85rem;color:var(--gray);line-height:1.6}

/* PRICING */
.pricing{background:var(--dark)}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto}
.price-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:2.5rem 2rem;text-align:center;transition:all .3s;position:relative}
.price-card.featured{border-color:var(--accent);background:linear-gradient(180deg,rgba(212,168,67,.04),var(--card))}
.price-card.featured:hover{box-shadow:0 0 60px rgba(212,168,67,.08)}
.price-card.featured::before{content:'POPULAIR';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:var(--black);padding:.2rem 1rem;border-radius:20px;font-size:.65rem;font-weight:700;letter-spacing:.1em}
.price-card h3{font-size:1.6rem;color:var(--white);margin-bottom:.3rem}
.price-card .desc{color:var(--gray);font-size:.8rem;margin-bottom:1.5rem}
.price-card .price{font-family:'Bebas Neue';font-size:3rem;color:var(--accent);line-height:1;margin-bottom:.2rem}
.price-card .per{color:var(--gray);font-size:.75rem;margin-bottom:1.5rem}
.price-features{list-style:none;text-align:left;margin-bottom:2rem}
.price-features li{padding:.4rem 0;color:var(--gray);font-size:.85rem;display:flex;align-items:center;gap:.5rem}
.price-features li::before{content:'✓';color:var(--accent);font-weight:700;font-size:.8rem}

/* BOOKING - full width for desktop schedule */
.booking{background:var(--black);position:relative;overflow:hidden;padding:6rem 2.5rem 4rem}
.booking::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(212,168,67,.03),transparent 70%);pointer-events:none}
.booking-top{display:flex;align-items:flex-end;justify-content:space-between;max-width:1200px;margin:0 auto 2rem;flex-wrap:wrap;gap:1rem}
.booking-top-left h2{font-size:clamp(2rem,4vw,3.2rem);color:var(--white);margin-bottom:.4rem}
.booking-top-left p{color:var(--gray);font-size:.95rem}
.booking-perks{display:flex;gap:1.5rem;flex-wrap:wrap;list-style:none}
.booking-perks li{display:flex;align-items:center;gap:.5rem;color:var(--light);font-size:.8rem;background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:50px;padding:.45rem 1rem}
.booking-perks li::before{content:'✓';color:var(--accent);font-weight:700;font-size:.7rem}
.booking-frame{max-width:1200px;margin:0 auto;background:var(--card);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);overflow:hidden;position:relative}
.booking-frame iframe{width:100%;height:700px;border:none;display:block}
.booking-frame-top{display:none}
.booking-fallback{text-align:center;padding:3rem 2rem;background:var(--card);border-radius:var(--radius);max-width:600px;margin:2rem auto 0;display:none}
.booking-fallback p{color:var(--gray);margin-bottom:1.2rem;font-size:.95rem}
.booking-note{text-align:center;margin-top:1.5rem;max-width:1200px;margin-left:auto;margin-right:auto}
.booking-note p{color:var(--gray);font-size:.8rem}
.booking-note a{color:var(--accent);text-decoration:none}

/* TOURNAMENTS SLIDER */
.tournaments{background:var(--dark);overflow:hidden}
.tournaments .section-header{margin-bottom:2rem}
.tourney-slider{position:relative;max-width:1000px;margin:0 auto;overflow:hidden}
.tourney-track{display:flex;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.tourney-card{flex:0 0 100%;padding:0 2.5rem;box-sizing:border-box;text-decoration:none;color:inherit;display:block;cursor:pointer}
.tourney-card:hover .tourney-card-inner{border-color:rgba(212,168,67,.35);transition:border-color .3s}
.tourney-card-inner{background:var(--card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:2.5rem;display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:center}
.tourney-card-inner.has-poster{grid-template-columns:180px 1fr;gap:2rem}
.tourney-poster{width:100%;border-radius:10px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.4)}
.tourney-poster img{width:100%;height:auto;display:block;border-radius:10px}
.tourney-date-block{text-align:center;background:rgba(212,168,67,.08);border:1px solid rgba(212,168,67,.15);border-radius:14px;padding:1.2rem 1.5rem;min-width:90px}
.tourney-date-block .day{font-family:'Bebas Neue';font-size:2.8rem;color:var(--accent);line-height:1}
.tourney-date-block .month{font-size:.7rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}
.tourney-date-block .year{font-size:.65rem;color:var(--gray)}
.tourney-info h3{font-size:1.5rem;color:var(--white);margin-bottom:.4rem}
.tourney-info p{color:var(--gray);font-size:.9rem;line-height:1.6;margin-bottom:.8rem}
.tourney-tags{display:flex;gap:.5rem;flex-wrap:wrap}
.tourney-tags span{font-size:.7rem;color:var(--light);background:rgba(255,255,255,.06);border-radius:50px;padding:.3rem .8rem;display:flex;align-items:center;gap:.3rem}
.tourney-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:2rem}
.tourney-btn{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--light);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s}
.tourney-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(212,168,67,.05)}
.tourney-dots{display:flex;gap:.5rem}
.tourney-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.15);border:none;cursor:pointer;transition:all .3s;padding:0}
.tourney-dot.active{background:var(--accent);width:24px;border-radius:4px}
.tourney-card.past .tourney-card-inner{opacity:.4}
.tourney-card-inner--tba{grid-template-columns:auto 1fr;gap:2rem;border:1px dashed rgba(212,168,67,.25);background:rgba(212,168,67,.03);position:relative;overflow:hidden}
.tourney-card-inner--tba::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(135deg,transparent,transparent 18px,rgba(212,168,67,.025) 18px,rgba(212,168,67,.025) 19px);pointer-events:none}
.tourney-card--tba:hover .tourney-card-inner--tba{border-color:rgba(212,168,67,.45)}
.tba-icon{font-size:2.8rem;opacity:.6;display:flex;align-items:center;justify-content:center;width:90px;min-width:90px}
.tba-badge{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:rgba(212,168,67,.1);border:1px solid rgba(212,168,67,.3);border-radius:20px;padding:.3rem .9rem;margin-bottom:.8rem}
.tba-sub{color:var(--gray);font-size:.9rem;margin:.5rem 0 1rem}

/* NAV BUTTONS — Find Us */
.find-us{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:2.5rem;position:relative;z-index:1}

/* COUNTDOWN */
.tourney-countdown{display:flex;gap:.8rem;margin:.8rem 0;flex-wrap:wrap}
.cd-unit{display:flex;flex-direction:column;align-items:center;background:rgba(212,168,67,.08);border:1px solid rgba(212,168,67,.2);border-radius:10px;padding:.6rem .8rem;min-width:56px}
.cd-num{font-family:'Bebas Neue';font-size:2rem;color:var(--accent);line-height:1}
.cd-label{font-size:.6rem;color:var(--gray);text-transform:uppercase;letter-spacing:.1em;margin-top:.2rem}
.tourney-date-small{font-size:.78rem;color:var(--gray);margin-top:.3rem}
.tourney-date-inline{font-size:.8rem;color:var(--gray);margin-bottom:.4rem}
.find-btn{display:inline-flex;align-items:center;gap:.6rem;padding:.7rem 1.4rem;border-radius:50px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);color:var(--light);text-decoration:none;font-size:.8rem;font-weight:500;transition:all .3s;backdrop-filter:blur(8px)}
.find-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(212,168,67,.05)}
.find-btn svg{width:18px;height:18px;flex-shrink:0}

/* PHOTO BANNER */
.photo-banner{height:400px;position:relative;overflow:hidden}
.photo-banner img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease-out;will-change:transform}
.photo-banner::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,var(--dark),transparent 25%,transparent 75%,var(--black))}
.photo-banner-text{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center}
.photo-banner-text span{font-family:'Bebas Neue';font-size:clamp(2rem,5vw,4rem);color:var(--white);letter-spacing:.15em;text-shadow:0 2px 20px rgba(0,0,0,.6)}

/* REVIEWS */
.reviews{background:var(--dark)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1200px;margin:0 auto}
.review-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:var(--radius);padding:2rem;transition:all .4s cubic-bezier(.16,1,.3,1)}
.review-card:hover{transform:translateY(-6px) rotate(-.5deg);box-shadow:0 20px 40px rgba(0,0,0,.2);border-color:rgba(212,168,67,.15)}
.review-stars{color:var(--accent);font-size:1rem;margin-bottom:1rem;letter-spacing:2px}
.review-text{color:var(--gray);font-size:.9rem;line-height:1.7;margin-bottom:1.5rem;font-style:italic}
.review-author{display:flex;align-items:center;gap:.8rem}
.review-avatar{width:36px;height:36px;border-radius:50%;background:rgba(212,168,67,.15);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--accent)}
.review-name{font-weight:600;color:var(--white);font-size:.85rem}
.review-meta{font-size:.7rem;color:var(--gray)}
.review-score{text-align:center;margin-bottom:3rem}
.review-score .big{font-family:'Bebas Neue';font-size:5rem;color:var(--accent);line-height:1}
.review-score .src{color:var(--gray);font-size:.8rem;margin-top:.3rem}

/* CTA */
.cta-section{text-align:center;padding:5rem 2.5rem;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(212,168,67,.06),transparent 70%)}
.cta-section h2{font-size:clamp(2.5rem,6vw,5rem);color:var(--white);margin-bottom:1rem;position:relative;z-index:1}
.cta-section h2 em{font-style:normal;color:var(--accent)}
.cta-section p{color:var(--gray);max-width:500px;margin:0 auto 2.5rem;font-size:1.05rem;position:relative;z-index:1}

/* FOOTER */
footer{background:var(--dark);border-top:1px solid rgba(255,255,255,.05);padding:4rem 2.5rem 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto}
.footer-brand{font-family:'Bebas Neue';font-size:1.8rem;color:var(--white);margin-bottom:.8rem}
.footer-brand span{color:var(--accent)}
footer p{color:var(--gray);font-size:.85rem;line-height:1.7}
footer h4{color:var(--white);font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem}
footer ul{list-style:none}
footer ul li{margin-bottom:.5rem}
footer ul a{color:var(--gray);text-decoration:none;font-size:.85rem;transition:color .3s}
footer ul a:hover{color:var(--accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.05);margin-top:3rem;padding-top:1.5rem;text-align:center;color:var(--gray);font-size:.75rem;max-width:1200px;margin-left:auto;margin-right:auto}
.socials{display:flex;gap:.8rem;margin-top:1rem}
.socials a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--gray);text-decoration:none;font-size:.8rem;transition:all .3s}
.socials a:hover{border-color:var(--accent);color:var(--accent)}

/* SCROLL REVEAL */
[data-reveal]{opacity:0;transform:translateY(40px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
[data-reveal="left"]{transform:translateX(-60px)}
[data-reveal="right"]{transform:translateX(60px)}
[data-reveal="scale"]{transform:scale(.92)}
[data-reveal].visible{opacity:1;transform:translate(0) scale(1)}
[data-stagger]>*{opacity:0;transform:translateY(30px);transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1)}
[data-stagger].visible>*{opacity:1;transform:translateY(0)}
[data-stagger].visible>*:nth-child(1){transition-delay:0s}
[data-stagger].visible>*:nth-child(2){transition-delay:.1s}
[data-stagger].visible>*:nth-child(3){transition-delay:.15s}
[data-stagger].visible>*:nth-child(4){transition-delay:.25s}
[data-stagger].visible>*:nth-child(5){transition-delay:.35s}
[data-stagger].visible>*:nth-child(6){transition-delay:.45s}

/* HERO ANIMS */
@keyframes heroUp{from{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroLeft{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes heroPop{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-content{animation:heroUp .9s cubic-bezier(.16,1,.3,1) .2s both}
.hero-visual{animation:heroUp 1s cubic-bezier(.16,1,.3,1) .4s both}
.hero-badge{animation:heroLeft .7s cubic-bezier(.16,1,.3,1) .5s both}
.hero-stat.s1{animation:heroPop .6s cubic-bezier(.34,1.56,.64,1) .9s both,float 4s ease-in-out 2s infinite}
.hero-stat.s2{animation:heroPop .6s cubic-bezier(.34,1.56,.64,1) 1.1s both,float 4s ease-in-out 2.5s infinite}
body{animation:pageIn .5s ease-out}
@keyframes pageIn{from{opacity:0}to{opacity:1}}

/* MOBILE - TABLET */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-links.show{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(8,10,15,.97);padding:1.5rem 2rem;gap:.5rem;border-bottom:1px solid rgba(212,168,67,.1);backdrop-filter:blur(20px)}
  .nav-links.show a{padding:.7rem 0;font-size:1rem;color:var(--light)}
  .hamburger{display:flex}
  .nav-info-btn{display:none}
  /* On mobile: logo left, CTA+hamburger right */
  .nav-cta{margin-left:auto}
  .hero-grid,.about-grid{grid-template-columns:1fr}
  .hero-visual{order:-1}
  .feat-grid,.reviews-grid,.price-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  section{padding:3.5rem 1.2rem}
  nav{padding:.8rem 1.2rem}
  .booking{padding:3rem 1rem}
  .booking-frame iframe{height:500px}
  .booking-perks{gap:.5rem}
  .booking-top{flex-direction:column;align-items:flex-start}
}

/* MOBILE - PHONE */
@media(max-width:600px){
  /* Typography scaling */
  html{font-size:15px}
  .hero h1{font-size:3.2rem;letter-spacing:.02em}
  .hero h1 em{font-size:3.2rem}
  .section-header h2{font-size:2rem}
  .about-content h2{font-size:1.8rem}
  .booking-info h2,.booking-top-left h2{font-size:1.8rem}
  .cta-section h2{font-size:2.5rem}
  
  /* Nav mobile */
  nav{padding:.7rem 1rem;gap:.5rem}
  .nav-logo{font-size:1.3rem;flex-shrink:0}
  .nav-cta{padding:.55rem 1.2rem;font-size:.7rem;margin-left:auto;margin-right:.5rem;white-space:nowrap}
  
  /* Hero mobile */
  .hero{min-height:auto;padding:6rem 1.2rem 3rem}
  .hero-img{max-width:100%;aspect-ratio:16/10;border-radius:12px}
  .hero-badge{font-size:.65rem;padding:.35rem .8rem;margin-bottom:1.2rem}
  .hero-sub{font-size:1rem;margin-bottom:2rem}
  .hero-actions{flex-direction:column;gap:.8rem}
  .hero-actions .btn-primary,
  .hero-actions .btn-outline{width:100%;justify-content:center;text-align:center;padding:.85rem 1.5rem}
  .hero-stat{padding:.6rem 1rem;border-radius:10px}
  .hero-stat .num{font-size:1.4rem}
  .hero-stat .label{font-size:.6rem}
  .hero-stat.s1{right:3%;top:3%}
  .hero-stat.s2{left:3%;bottom:8%}
  /* Disable float on mobile for performance */
  .hero-stat.s1,.hero-stat.s2{animation:heroPop .6s cubic-bezier(.34,1.56,.64,1) .6s both}
  
  /* Sections */
  section{padding:3rem 1rem}
  .section-header{margin-bottom:2.5rem}
  .section-header p{font-size:.9rem}
  .section-tag{font-size:.7rem;letter-spacing:.1em}
  
  /* Features */
  .feat-grid{gap:1rem}
  .feat-card{padding:1.8rem 1.5rem}
  .feat-card h3{font-size:1.3rem}
  .feat-card p{font-size:.85rem}
  .feat-icon{width:44px;height:44px;font-size:1.2rem;margin-bottom:1rem}
  
  /* About */
  .about-grid{gap:2rem}
  .about-img{aspect-ratio:16/10;border-radius:12px}
  .about-content p{font-size:.9rem}
  .about-stats{gap:.8rem}
  .about-stat{padding:.8rem .5rem}
  .about-stat .num{font-size:1.8rem}
  
  /* Photo banner */
  .photo-banner{height:200px}
  .photo-banner-text span{font-size:1.5rem;letter-spacing:.1em}
  
  /* Tournaments */
  .tourney-card{padding:0 1rem}
  .tourney-card-inner{grid-template-columns:1fr;gap:1.2rem;padding:1.5rem 1.2rem}
  .tourney-card-inner.has-poster{grid-template-columns:1fr;gap:1.2rem}
  .tourney-poster{max-width:200px;margin:0 auto}
  .tourney-date-block{display:flex;align-items:center;gap:1rem;padding:.8rem 1rem;justify-self:start}
  .tourney-date-block .day{font-size:2rem}
  .tourney-info h3{font-size:1.2rem}
  .tourney-info p{font-size:.82rem}
  .tourney-btn{width:38px;height:38px;font-size:.9rem}
  .cd-unit{min-width:48px;padding:.5rem .6rem}
  .cd-num{font-size:1.6rem}
  .cd-label{font-size:.55rem}

  /* Find us buttons */
  .find-us{gap:.5rem;margin-top:1.5rem}
  .find-btn{padding:.6rem 1rem;font-size:.72rem}
  .find-btn svg{width:15px;height:15px}
  
  /* Pricing */
  .price-grid{gap:1rem}
  .price-card{padding:2rem 1.5rem;border-radius:12px}
  .price-card .price{font-size:2.5rem}
  .price-card h3{font-size:1.4rem}
  .price-features li{font-size:.82rem}
  .price-card .btn-primary{padding:.8rem 1.5rem}
  
  /* Booking */
  .booking{padding:2.5rem .8rem}
  .booking-frame{border-radius:12px}
  .booking-frame iframe{height:480px;border-radius:12px}
  .booking-perks{flex-direction:column;gap:.4rem}
  .booking-perks li{font-size:.75rem;padding:.4rem .8rem}
  .booking-note p{font-size:.75rem}
  .booking-top-left p{font-size:.85rem}
  
  /* Reviews */
  .reviews-grid{gap:1rem}
  .review-card{padding:1.5rem 1.2rem;border-radius:12px}
  .review-text{font-size:.85rem}
  .review-score .big{font-size:4rem}
  .review-score .src{font-size:.75rem}
  .review-card:hover{transform:none;box-shadow:none}
  
  /* CTA */
  .cta-section{padding:3.5rem 1.2rem}
  .cta-section p{font-size:.95rem}
  .cta-section .btn-primary,
  .cta-section .btn-outline{width:100%;justify-content:center;text-align:center}
  
  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .footer-brand{font-size:1.5rem}
  footer p{font-size:.8rem}
  footer h4{font-size:.7rem;margin-bottom:.6rem}
  footer ul a{font-size:.8rem}
  .footer-bottom{font-size:.7rem}
  .socials{margin-top:.8rem}
  
  /* Buttons general */
  .btn-primary{padding:.8rem 1.8rem;font-size:.8rem;border-radius:50px}
  .btn-outline{padding:.8rem 1.8rem;font-size:.8rem}
  
  /* Disable hover effects on touch */
  .feat-card:hover{transform:none}
  .feat-card:hover::after{opacity:0}
  .feat-card:hover::before{width:0;left:50%}
  .price-card.featured:hover{box-shadow:none}
  
  /* Smoother scroll reveal on mobile */
  [data-reveal]{transition-duration:.6s}
  [data-stagger]>*{transition-duration:.5s}
}

/* MOBILE - SMALL PHONE */
@media(max-width:380px){
  html{font-size:14px}
  .hero h1{font-size:2.6rem}
  .hero{padding:5.5rem 1rem 2.5rem}
  .nav-logo{font-size:1.15rem}
  .nav-cta{padding:.5rem 1rem;font-size:.65rem}
  .section-header h2{font-size:1.7rem}
  .price-card .price{font-size:2.2rem}
  .booking-frame iframe{height:420px}
  .cta-section h2{font-size:2rem}
}
/* SUBPAGES */
.page-hero{padding:8rem 2.5rem 3rem;text-align:center;position:relative;background:var(--dark)}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center bottom,rgba(212,168,67,.06),transparent 70%)}
.page-hero h1{font-size:clamp(2.5rem,6vw,4.5rem);color:var(--white);margin-bottom:.5rem;position:relative}
.page-hero p{color:var(--gray);font-size:1rem;max-width:500px;margin:0 auto;position:relative}
.page-hero .section-tag{position:relative}
.back-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--gray);text-decoration:none;font-size:.8rem;margin-bottom:1.5rem;transition:color .3s;position:relative}
.back-link:hover{color:var(--accent)}

/* ACCORDION */
.accordion{max-width:900px;margin:0 auto}
.acc-item{border-bottom:1px solid rgba(255,255,255,.06)}
.acc-item:last-child{border-bottom:none}
.acc-btn{width:100%;background:none;border:none;padding:1.5rem 0;display:flex;align-items:center;justify-content:space-between;cursor:pointer;color:var(--white);font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:.04em;text-align:left;transition:color .3s}
.acc-btn:hover{color:var(--accent)}
.acc-btn::after{content:'+';font-size:1.5rem;color:var(--accent);transition:transform .3s}
.acc-item.open .acc-btn::after{transform:rotate(45deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.16,1,.3,1)}
.acc-item.open .acc-body{max-height:2000px}
.acc-content{padding:0 0 2rem;color:var(--gray);font-size:.9rem;line-height:1.8}
.acc-content h3{color:var(--white);font-size:1.2rem;margin:1rem 0 .5rem;font-family:'Bebas Neue',sans-serif;letter-spacing:.03em}
.acc-content p{margin-bottom:.8rem}
.acc-content ul{list-style:none;margin-bottom:1rem}
.acc-content ul li{padding:.3rem 0;display:flex;align-items:baseline;gap:.5rem}
.acc-content ul li::before{content:'•';color:var(--accent);flex-shrink:0}
.acc-content .info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin:1rem 0}
.acc-content .info-card{background:var(--card);border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:1.2rem}
.acc-content .info-card .label{font-size:.7rem;color:var(--gray);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem}
.acc-content .info-card .value{font-family:'Bebas Neue';font-size:1.4rem;color:var(--accent)}
.acc-content table{width:100%;border-collapse:collapse;margin:1rem 0}
.acc-content table th,.acc-content table td{text-align:left;padding:.6rem .8rem;border-bottom:1px solid rgba(255,255,255,.05)}
.acc-content table th{color:var(--accent);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}
.page-section{padding:4rem 2.5rem;background:var(--black)}

/* CONTACT PAGE */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1000px;margin:0 auto;align-items:start}
.contact-card{background:var(--card);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:2rem}
.contact-card h3{font-size:1.3rem;color:var(--white);margin-bottom:1rem}
.contact-card p{color:var(--gray);font-size:.9rem;line-height:1.8;margin-bottom:.5rem}
.contact-card a{color:var(--accent);text-decoration:none}
.contact-card a:hover{text-decoration:underline}
.contact-map{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,.06)}
.contact-map iframe{width:100%;height:350px;border:none;filter:grayscale(.7) brightness(.8);transition:filter .3s}
.contact-map:hover iframe{filter:grayscale(.3) brightness(.9)}

@media(max-width:600px){
  .page-hero{padding:6rem 1.2rem 2rem}
  .page-hero h1{font-size:2.2rem}
  .page-section{padding:3rem 1.2rem}
  .acc-btn{font-size:1.2rem;padding:1.2rem 0}
  .acc-content .info-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
.pt-active{
  display:inline-block;
  background:rgba(212,168,67,.12);
  border:1px solid rgba(212,168,67,.4);
  color:var(--accent);
  padding:.4rem 1rem;
  border-radius:20px;
  font-weight:700;
  font-size:.82rem;
  letter-spacing:.05em;
  margin:.6rem 0;
  animation:ptpulse 2s infinite;
}
@keyframes ptpulse{
  0%,100%{box-shadow:0 0 0 0 rgba(212,168,67,.3)}
  50%{box-shadow:0 0 0 8px rgba(212,168,67,0)}
}
.cd-past{display:inline-block;color:var(--gray);font-size:.8rem;font-style:italic;margin:.4rem 0;}
