/* =====================================================
   ZIM RUNNER ATHLETICS CLUB
   FINAL WORLD-CLASS STYLESHEET
===================================================== */


/* ================= RESET ================= */
*{
margin:0;
padding:0;
box-sizing:border-box;
}

body{
font-family:'Inter',sans-serif;
background:#f5f6f8;
color:#222;
line-height:1.6;
overflow-x:hidden;
}

img{max-width:100%;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}


/* ================= CONTAINER ================= */
.container{
max-width:1250px;
margin:auto;
padding:0 20px;
}

.spad{
padding:110px 0;
}

.text-center{text-align:center;}


/* =====================================================
   HEADER
===================================================== */

.zr-header{
background:#0b0b0b;
border-bottom:3px solid #e10600;
position:sticky;
top:0;
z-index:999;
}

.zr-container{
display:flex;
align-items:center;
justify-content:space-between;
padding:14px 24px;
}

.zr-logo{
display:flex;
align-items:center;
gap:12px;
}

.zr-logo img{
height:48px;
}

.zr-brand{
font-family:'Bebas Neue',sans-serif;
font-size:32px;
letter-spacing:2px;
color:#e10600;
}

.zr-sub{
font-size:11px;
letter-spacing:3px;
color:#fff;
}

.zr-nav ul{
display:flex;
gap:26px;
align-items:center;
}

.zr-nav a{
color:#fff;
font-size:14px;
font-weight:600;
text-transform:uppercase;
transition:.3s;
}

.zr-nav a:hover{
color:#e10600;
}

.zr-cta a{
background:#e10600;
padding:10px 18px;
border-radius:6px;
color:#fff;
}


/* =====================================================
   HERO SECTION (PERFECT CENTER)
===================================================== */

.hero{
position:relative;
min-height:100vh;
display:flex;
align-items:center;
justify-content:center;
text-align:center;
overflow:hidden;
color:#fff;
}

/* Background */
.hero::before{
content:"";
position:absolute;
inset:0;
background:
linear-gradient(rgba(0,0,0,.55),
rgba(0,0,0,.9)),
url('../img/hero/slider-1.jpg');
background-size:cover;
background-position:center;
background-attachment:fixed;
transform:scale(1.05);
}

/* Cinematic overlay */
.hero-overlay{
position:absolute;
inset:0;
background:
radial-gradient(circle at center,
rgba(0,0,0,0) 15%,
rgba(0,0,0,.85) 85%);
}

/* TRUE CENTER BLOCK */
.hero-content{
position:relative;
z-index:5;
max-width:900px;

display:flex;
flex-direction:column;
align-items:center;
justify-content:center;

margin:auto;
animation:fadeHero 1.2s ease;
}

/* Tag */
.hero-tag{
background:#e10600;
padding:8px 18px;
border-radius:40px;
font-size:13px;
letter-spacing:2px;
margin-bottom:25px;
}

/* Title */
.hero h1{
font-size:72px;
font-weight:900;
line-height:1.1;
max-width:900px;
margin:auto;
}

.hero h1 span{
color:#e10600;
}

/* Subtitle */
.hero-sub{
font-size:22px;
max-width:720px;
margin:30px auto;
opacity:.9;
}

/* Buttons */
.hero-buttons{
display:flex;
justify-content:center;
align-items:center;
gap:20px;
flex-wrap:wrap;
}


/* ================= BUTTONS ================= */

.primary-btn{
background:#e10600;
padding:18px 45px;
border-radius:50px;
font-weight:700;
color:#fff;
box-shadow:0 15px 35px rgba(225,6,0,.5);
transition:.3s;
}

.primary-btn:hover{
transform:translateY(-5px);
}

.secondary-btn{
border:2px solid #fff;
padding:18px 45px;
border-radius:50px;
color:#fff;
transition:.3s;
}

.secondary-btn:hover{
background:#fff;
color:#000;
}


/* =====================================================
   FLOATING STATS
===================================================== */

.stats-wrapper{
margin-top:-80px;
position:relative;
z-index:10;
}

.stats-row{
background:#fff;
padding:45px;
border-radius:24px;
box-shadow:0 25px 60px rgba(0,0,0,.15);
}

.stat-box{
padding:20px;
}

.stat-box h2{
font-size:42px;
font-weight:900;
color:#e10600;
}


/* =====================================================
   SECTION TITLE
===================================================== */

.section-title{
margin-bottom:70px;
text-align:center;
}

.section-title h2{
font-size:42px;
font-weight:900;
}

.section-title h2::after{
content:"";
width:70px;
height:4px;
background:#e10600;
display:block;
margin:18px auto;
}


/* =====================================================
   LEADERSHIP
===================================================== */

.team{
background:#0f0f0f;
}

.team .container{
background:#141414;
padding:70px;
border-radius:24px;
}

.player__item{
background:#1c1c1c;
padding:45px 25px;
border-radius:20px;
text-align:center;
transition:.4s;
border-top:3px solid transparent;
}

.player__item:hover{
transform:translateY(-15px);
border-top:3px solid #e10600;
box-shadow:0 25px 60px rgba(0,0,0,.6);
}

.player__item h4{color:#fff;}
.player__item p{color:#bbb;font-size:14px;}


/* =====================================================
   SERVICES
===================================================== */

.offer-box{
background:#fff;
padding:45px 30px;
border-radius:20px;
box-shadow:0 15px 40px rgba(0,0,0,.08);
transition:.3s;
}

.offer-box:hover{
transform:translateY(-12px);
box-shadow:0 30px 70px rgba(0,0,0,.15);
}


/* =====================================================
   EVENTS
===================================================== */

.product__item{
background:#fff;
padding:40px;
border-radius:20px;
box-shadow:0 12px 35px rgba(0,0,0,.08);
transition:.3s;
}

.product__item:hover{
transform:translateY(-12px);
}

.highlight-event{
background:#e10600;
color:#fff;
transform:scale(1.05);
box-shadow:0 25px 60px rgba(225,6,0,.5);
}


/* =====================================================
   CTA
===================================================== */

.callto{
background:
linear-gradient(rgba(0,0,0,.75),
rgba(0,0,0,.9)),
url('../img/call-bg.jpg');
background-size:cover;
background-position:center;
color:#fff;
padding:120px 0;
text-align:center;
}

.callto h2{
font-size:48px;
font-weight:900;
margin:20px 0;
}


/* =====================================================
   FOOTER
===================================================== */

.footer{
background:#111;
color:#fff;
padding:70px 0;
text-align:center;
}


/* =====================================================
   HERO ANIMATION
===================================================== */

@keyframes fadeHero{
from{
opacity:0;
transform:translateY(40px);
}
to{
opacity:1;
transform:translateY(0);
}
}


/* =====================================================
   RESPONSIVE
===================================================== */

@media(max-width:768px){

.hero h1{
font-size:42px;
}

.hero-sub{
font-size:18px;
}

.stats-wrapper{
margin-top:-40px;
}

}
.player__item__pic{
height:260px;
background-size:cover;
background-position:center;
border-radius:18px 18px 0 0;
position:relative;
}

.player__item{
background:#1c1c1c;
border-radius:18px;
overflow:hidden;
transition:.35s;
}

.player__item:hover{
transform:translateY(-10px);
box-shadow:0 25px 60px rgba(0,0,0,.6);
}

.player__item__text{
padding:20px;
text-align:center;
color:#fff;
}

.number{
position:absolute;
top:12px;
left:12px;
background:#e10600;
padding:6px 12px;
border-radius:20px;
font-weight:700;
color:#fff;
}
/* ================= CONTACT ================= */

.contact-card{
background:#111;
color:#fff;
padding:40px;
border-radius:20px;
height:100%;
box-shadow:0 20px 50px rgba(0,0,0,.3);
}

.contact-card h3{
margin-bottom:25px;
}

.contact-list li{
margin-bottom:18px;
font-size:15px;
display:flex;
gap:12px;
align-items:flex-start;
}

.contact-list i{
color:#e10600;
font-size:18px;
margin-top:3px;
}


/* FORM */
.contact-form{
background:#fff;
padding:40px;
border-radius:20px;
box-shadow:0 15px 40px rgba(0,0,0,.1);
}

.contact-form h3{
margin-bottom:20px;
}

.contact-form input,
.contact-form textarea{
width:100%;
padding:14px;
margin-bottom:15px;
border:1px solid #ddd;
border-radius:8px;
font-size:14px;
}

.contact-form textarea{
height:150px;
resize:none;
}


/* MAP */
.contact-map iframe{
width:100%;
height:420px;
border:0;
border-radius:20px;
box-shadow:0 15px 40px rgba(0,0,0,.1);
}
/* ================= CART ================= */

.cart-wrapper{
background:#fff;
padding:40px;
border-radius:20px;
box-shadow:0 20px 50px rgba(0,0,0,.08);
overflow-x:auto;
}

.cart-table{
width:100%;
border-collapse:collapse;
}

.cart-table th{
background:#111;
color:#fff;
padding:15px;
text-align:left;
}

.cart-table td{
padding:15px;
border-bottom:1px solid #eee;
vertical-align:middle;
}

.cart-img{
width:70px;
height:70px;
object-fit:contain;
background:#f5f5f5;
padding:5px;
border-radius:10px;
}

.cart-total{
font-size:20px;
font-weight:900;
color:#e10600;
}

.remove-btn{
background:#e10600;
color:#fff;
padding:8px 12px;
border-radius:6px;
}

.remove-btn:hover{
background:#b00400;
}

.cart-actions{
margin-top:25px;
display:flex;
justify-content:space-between;
flex-wrap:wrap;
gap:15px;
}

.empty-cart{
padding:100px 0;
}
/* SUCCESS MESSAGE */
.zr-success-msg{
background:#28a745;
color:#fff;
padding:14px;
border-radius:8px;
margin-bottom:25px;
text-align:center;
font-weight:600;
box-shadow:0 10px 25px rgba(0,0,0,.15);
}
/* =====================================
   WORLD CLASS REGISTER FORM
=====================================*/

.zr-register{
min-height:100vh;
display:flex;
justify-content:center;
align-items:center;
padding:80px 20px;
background:#f4f6f9;
}

.zr-register-card{
width:100%;
max-width:900px;
background:#fff;
padding:50px;
border-radius:20px;
box-shadow:0 25px 60px rgba(0,0,0,.12);
}

/* Titles */
.zr-title{
font-size:38px;
font-weight:900;
text-align:center;
margin-bottom:10px;
}

.zr-subtitle{
text-align:center;
color:#666;
margin-bottom:40px;
}

/* Success */
.zr-success{
background:#28a745;
color:#fff;
padding:12px;
border-radius:8px;
text-align:center;
margin-bottom:25px;
}

/* Blocks */
.zr-form-block{
margin-bottom:35px;
}

.zr-form-block h3{
margin-bottom:18px;
font-weight:700;
border-left:4px solid #e10600;
padding-left:12px;
}

/* Grid Layout */
.zr-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:18px;
}

/* Inputs */
.zr-register input,
.zr-register select{
width:100%;
padding:15px;
border-radius:10px;
border:1px solid #ddd;
font-size:15px;
background:#fafafa;
transition:.3s;
}

.zr-register input:focus,
.zr-register select:focus{
border-color:#e10600;
background:#fff;
box-shadow:0 0 12px rgba(225,6,0,.2);
outline:none;
}

/* Submit */
.zr-submit-btn{
width:100%;
padding:18px;
background:#e10600;
color:#fff;
font-size:18px;
font-weight:700;
border:none;
border-radius:50px;
cursor:pointer;
transition:.3s;
}

.zr-submit-btn:hover{
transform:translateY(-3px);
box-shadow:0 15px 35px rgba(225,6,0,.4);
}

/* Mobile */
@media(max-width:768px){
.zr-grid{
grid-template-columns:1fr;
}
.zr-register-card{
padding:30px 20px;
}
}