:root { --accent:#F68E13; --dark-bg:#111111; --dark2:#1a1a1a; }
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Roboto',sans-serif;background:#fff;color:#222;overflow-x:hidden;margin:0}
h1,h2,h3,h4,h5{font-family:'Raleway',sans-serif;font-weight:700}

/* ---- NAVBAR ---- */
#navbar{background:rgba(17,17,17,.97);backdrop-filter:blur(6px);padding:.45rem 0;transition:background .3s;z-index:1050}
#navbar.scrolled{background:rgba(10,10,10,.99)}
#navbar .navbar-brand img{height:50px}
#navbar .nav-link{color:#eee!important;font-family:'Raleway',sans-serif;font-weight:600;font-size:.86rem;text-transform:uppercase;letter-spacing:.06em;padding:.4rem .75rem!important;transition:color .2s}
#navbar .nav-link:hover,#navbar .nav-link.active{color:var(--accent)!important}
.navbar-toggler{border-color:#666}
.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,255,255,0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}

/* ---- BUTTONS ---- */
.btn-accent{background-color:var(--accent);color:#fff;border:none;font-family:'Raleway',sans-serif;font-weight:700;letter-spacing:.04em;text-transform:uppercase;transition:background .2s,transform .15s}
.btn-accent:hover{background-color:#d97d0d;color:#fff;transform:translateY(-1px)}
.btn-wa{display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;font-family:'Raleway',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:12px 24px;border-radius:50px;text-decoration:none;transition:background .2s,transform .15s;font-size:.95rem}
.btn-wa:hover{background:#1fbe5b;color:#fff;transform:translateY(-2px)}
.btn-wa i{font-size:1.3rem}

/* ---- UTILITIES ---- */
.text-accent{color:var(--accent)!important}
.divider-accent{width:60px;height:4px;background:var(--accent);border-radius:2px;margin-bottom:1.5rem}
.label-pre{color:var(--accent);font-family:'Raleway',sans-serif;font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.15em;margin-bottom:.4rem;display:block}
.section-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;text-transform:uppercase;letter-spacing:.04em}

/* ---- FADE IN ---- */
.fade-in{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ---- PAGE HERO BANNER (discipline pages) ---- */
.page-hero{position:relative;min-height:340px;display:flex;align-items:flex-end;overflow:hidden;background:var(--dark-bg)}
.page-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.65}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,rgba(0,0,0,.1) 100%)}
.page-hero-content{position:relative;z-index:2;padding-top:3rem;padding-bottom:2.5rem;color:#fff}
.page-hero-content h1{font-size:clamp(2rem,5vw,3.2rem);font-weight:900;text-transform:uppercase;letter-spacing:.04em;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.discipline-badge{display:inline-block;background:var(--accent);color:#fff;font-family:'Raleway',sans-serif;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;padding:5px 16px;border-radius:20px;margin-bottom:1rem}

/* ---- DISCIPLINE CARDS ---- */
.discipline-card{border-radius:12px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1);transition:transform .25s,box-shadow .25s;background:#fff;height:100%;display:flex;flex-direction:column}
.discipline-card:hover{transform:translateY(-6px);box-shadow:0 12px 36px rgba(0,0,0,.16)}
.discipline-card a{text-decoration:none;color:inherit}
.discipline-card-img{position:relative;height:220px;overflow:hidden;background:var(--dark-bg)}
.discipline-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.discipline-card:hover .discipline-card-img img{transform:scale(1.05)}
.discipline-card-badge{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-family:'Raleway',sans-serif;font-weight:700;font-size:.73rem;text-transform:uppercase;letter-spacing:.07em;padding:4px 12px;border-radius:20px}
.discipline-card-body{padding:1.4rem;flex:1;display:flex;flex-direction:column}
.discipline-card-body h3{font-size:1.2rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#111;margin-bottom:.6rem}
.discipline-card-body p{font-size:.9rem;line-height:1.7;color:#555;flex:1}
.discipline-card-link{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-family:'Raleway',sans-serif;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;margin-top:.8rem;text-decoration:none;transition:gap .2s}
.discipline-card-link:hover{gap:10px;color:var(--accent)}

/* ---- ORARI ---- */
.orari-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1.8rem;height:100%;transition:border-color .2s}
.orari-card:hover{border-color:var(--accent)}
.orari-card h4{font-size:1rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);margin-bottom:.2rem}
.orari-card .tag{font-size:.78rem;color:#aaa;text-transform:uppercase;letter-spacing:.07em;margin-bottom:1rem;display:block}
.orari-giorni{font-family:'Raleway',sans-serif;font-weight:700;font-size:.9rem;color:#ddd;margin-bottom:.5rem}
.orari-turno{display:flex;align-items:center;gap:8px;padding:7px 12px;background:rgba(246,142,19,.12);border-radius:6px;margin-bottom:6px;font-size:.95rem;font-weight:600}
.orari-turno i{color:var(--accent);font-size:.85rem}
.orari-apertura{background:rgba(255,255,255,.04);border-radius:10px;padding:1.2rem 1.5rem;margin-top:2.5rem;text-align:center}
.orari-apertura i{color:var(--accent);font-size:1.4rem;display:block;margin-bottom:.5rem}

/* ---- INFO CARDS ---- */
.info-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1.4rem;text-align:center;transition:border-color .2s;height:100%}
.info-card:hover{border-color:var(--accent)}
.info-card i{font-size:1.8rem;color:var(--accent);margin-bottom:.7rem;display:block}
.info-card h5{font-size:.95rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.info-card p{font-size:.87rem;opacity:.72;margin:0}

/* ---- FEATURES ---- */
.feat-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}
.feat-icon{min-width:46px;height:46px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;flex-shrink:0}
.feat-item h5{font-size:.95rem;font-weight:700;margin-bottom:.2rem}
.feat-item p{font-size:.88rem;color:#666;margin:0}

/* ---- CONTATTI ---- */
.contatto-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.4rem}
.contatto-icon{min-width:46px;height:46px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#fff;flex-shrink:0}
.contatto-item h5{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:#aaa;margin:0 0 2px}
.contatto-item p{margin:0;font-size:.98rem;font-weight:500}
.contatto-item a{color:#fff;text-decoration:none}
.contatto-item a:hover{color:var(--accent)}
.social-links a{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:50%;color:#fff;font-size:1.1rem;text-decoration:none;margin-right:8px;transition:background .2s,border-color .2s}
.social-links a:hover{background:var(--accent);border-color:var(--accent)}

/* ---- FOOTER ---- */
footer{background:#000;color:#888;padding:2rem 0;font-size:.85rem}
footer a{color:#aaa;text-decoration:none}
footer a:hover{color:var(--accent)}

/* ---- FLOAT WA ---- */
.wa-float{position:fixed;bottom:28px;right:28px;background:#25D366;color:#fff;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;box-shadow:0 4px 16px rgba(0,0,0,.3);z-index:999;text-decoration:none;transition:transform .2s,box-shadow .2s}
.wa-float:hover{transform:scale(1.1);box-shadow:0 6px 22px rgba(0,0,0,.4);color:#fff}

/* ---- COOKIE BANNER ---- */
#ks-cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#1a1a1a;color:#ccc;padding:1rem 1.4rem;box-shadow:0 -2px 16px rgba(0,0,0,.35);transform:translateY(0);transition:transform .35s ease}

@media(max-width:576px){
  .container,.container-fluid{padding-left:1.25rem!important;padding-right:1.25rem!important}
  #navbar .navbar-brand img{height:42px}
}

@media(max-width:768px){
  .page-hero{min-height:240px}
  .page-hero-content{padding-top:2rem;padding-bottom:1.5rem}
}
