/* ============================================
   NEWGYM CLUB — VERCEL — PRO2 REBUILD
   Mobile-first | Dark Theme | #FF5500 Accent
   ============================================ */

/* RESET */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Barlow',sans-serif;background:#0a0a0a;color:#e0e0e0;line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{border:none;background:none;cursor:pointer;font-family:inherit}
input,textarea,select{font-family:inherit;font-size:inherit}

/* SCROLL REVEAL */
[data-reveal]{opacity:0;transform:translateY(32px);transition:opacity .65s cubic-bezier(.25,.46,.45,.94),transform .65s cubic-bezier(.25,.46,.45,.94)}
[data-reveal="left"]{transform:translateX(-40px)}
[data-reveal="right"]{transform:translateX(40px)}
[data-reveal="scale"]{transform:scale(.92)}
[data-reveal].visible{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.1s}
[data-reveal-delay="2"]{transition-delay:.2s}
[data-reveal-delay="3"]{transition-delay:.25s}
[data-reveal-delay="4"]{transition-delay:.3s}
[data-reveal-delay="5"]{transition-delay:.35s}

/* ============================================
   TOPBAR
   ============================================ */
.topbar{background:#D01919;padding:0 16px;height:38px;display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:500;letter-spacing:.02em;position:relative;z-index:100}
.topbar__info{display:flex;align-items:center;gap:16px}
.topbar__item{display:flex;align-items:center;gap:6px;color:#fff}
.topbar__item svg{width:13px;height:13px;flex-shrink:0}
.topbar__item--address{display:none}
.topbar__social{display:flex;align-items:center;gap:8px}
.topbar__social a{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.15);transition:background .2s;color:#fff}
.topbar__social a:hover{background:rgba(255,255,255,.3)}
.topbar__social svg{width:13px;height:13px;fill:#fff;stroke:none}

/* ============================================
   NAVBAR
   ============================================ */
.navbar{position:sticky;top:0;z-index:200;background:rgba(10,10,10,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06);padding:0 16px;height:58px;display:flex;align-items:center;justify-content:space-between;transition:background .3s,box-shadow .3s}
.navbar.scrolled{background:rgba(10,10,10,.99);box-shadow:0 2px 20px rgba(0,0,0,.5)}
.navbar__logo img{height:40px;width:auto;object-fit:contain}
.navbar__links{display:none;align-items:center;gap:32px}
.navbar__links a{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#bbb;transition:color .2s;position:relative}
.navbar__links a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:2px;background:#FF5500;transition:width .25s cubic-bezier(.25,.46,.45,.94)}
.navbar__links a:hover{color:#fff}
.navbar__links a:hover::after{width:100%}
.navbar__links a.active{color:#FF5500}
.navbar__links a.active::after{width:100%}
.navbar__cta{display:none;background:#FF5500;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:10px 20px;border-radius:6px;transition:background .2s,transform .15s;align-items:center;gap:6px}
.navbar__cta:hover{background:#FF7733;transform:translateY(-1px)}
.navbar__cta svg{width:14px;height:14px;stroke:#fff;fill:none;stroke-width:2}
.navbar__hamburger{display:flex;flex-direction:column;gap:5px;padding:8px}
.navbar__hamburger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s}

/* ============================================
   MOBILE OVERLAY
   ============================================ */
.mobile-menu{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(10,10,10,.98);z-index:9999;flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:'Barlow Condensed',sans-serif;font-size:28px;font-weight:900;text-transform:uppercase;color:#fff;letter-spacing:.05em;transition:color .2s}
.mobile-menu a:hover{color:#FF5500}
.mobile-menu__close{position:absolute;top:18px;right:18px;color:#fff;font-size:36px;line-height:1;background:none;border:none;cursor:pointer}
.mobile-menu__cta{margin-top:16px;width:80%;max-width:280px}

/* ============================================
   HERO
   ============================================ */
.hero{position:relative;height:auto;display:flex;align-items:flex-end;padding:0;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center center;transform:scale(1.05);animation:heroZoom 14s ease-out forwards;will-change:transform}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.75) 0%,rgba(0,0,0,.5) 35%,rgba(0,0,0,.8) 100%)}
.hero__noise{position:absolute;inset:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}
.hero__content{position:relative;z-index:2;padding:120px 20px 28px;width:100%;max-width:600px}
.hero__eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#FF5500;margin-bottom:14px;animation:fadeUp .6s cubic-bezier(.25,.46,.45,.94) .3s both}
.hero__eyebrow::before{content:'';display:block;width:24px;height:2px;background:#FF5500}
.hero__title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(48px,12vw,56px);font-weight:900;line-height:.9;text-transform:uppercase;letter-spacing:-.01em;color:#fff;animation:fadeUp .7s cubic-bezier(.25,.46,.45,.94) .5s both}
.hero__title em{font-style:italic;color:#FF5500;-webkit-text-stroke:1px #FF5500}
.hero__subtitle{margin-top:16px;font-size:14px;font-weight:400;line-height:1.65;color:rgba(255,255,255,.7);max-width:440px;animation:fadeUp .7s cubic-bezier(.25,.46,.45,.94) .7s both}
.hero__subtitle strong{color:#fff;font-weight:600}
.hero__actions{margin-top:24px;display:flex;flex-direction:column;gap:10px;animation:fadeUp .7s cubic-bezier(.25,.46,.45,.94) .9s both}
.hero__stats{display:none}
.hero__scroll{display:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* BUTTONS */
.btn-primary{background:#FF5500;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:14px 28px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-align:center}
.btn-primary:hover{background:#FF7733;transform:translateY(-2px);box-shadow:0 12px 40px rgba(255,85,0,.35)}
.btn-primary--full{width:100%}
.btn-primary--desktop{display:none}
.btn-ghost{background:transparent;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:13px 24px;border-radius:6px;border:2px solid rgba(255,255,255,.3);cursor:pointer;transition:border-color .2s,background .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-align:center}
.btn-ghost:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.06)}

/* ============================================
   SECTIONS
   ============================================ */
.section{padding:56px 20px}
.section--dark{background:#111}
.section--darker{background:#0a0a0a}
.section--accent{background:#FF5500}
.section__label{display:inline-flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:#FF5500;margin-bottom:12px}
.section__label::before{content:'';display:block;width:22px;height:2px;background:currentColor}
.section__title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(32px,8vw,38px);font-weight:900;text-transform:uppercase;line-height:.95;letter-spacing:-.01em;color:#f0f0f0}
.section__title em{font-style:italic;color:#FF5500}
.section__subtitle{margin-top:12px;font-size:14px;line-height:1.7;color:#999;max-width:560px}
.divider{width:44px;height:3px;background:#FF5500;margin-top:14px;border-radius:2px}

/* ============================================
   ABOUT
   ============================================ */
.about{display:flex;flex-direction:column;gap:32px}
.about__text p{margin-top:14px;font-size:14px;line-height:1.75;color:rgba(255,255,255,.7)}
.about__text strong{color:#fff;font-weight:600}
.about__pills{margin-top:20px;display:flex;flex-wrap:wrap;gap:8px}
.about__pill{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:100px;padding:7px 14px;font-size:12px;font-weight:500;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:6px;transition:border-color .2s,background .2s}
.about__pill:hover{border-color:rgba(255,85,0,.3);background:rgba(255,85,0,.06)}
.about__pill::before{content:'';width:6px;height:6px;border-radius:50%;background:#FF5500;flex-shrink:0}
.about__visual{position:relative}
.about__image-wrapper{position:relative;border-radius:12px;overflow:hidden}
.about__image-wrapper img{width:100%;height:240px;object-fit:cover}
.about__badge{position:absolute;bottom:-12px;left:-8px;background:#FF5500;color:#fff;width:72px;height:72px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;text-transform:uppercase;text-align:center;box-shadow:0 8px 32px rgba(255,85,0,.5);z-index:2}
.about__badge-number{font-size:26px;font-weight:900;line-height:1}
.about__badge-text{font-size:8px;font-weight:700;letter-spacing:.1em;opacity:.9}

/* ============================================
   FEATURES
   ============================================ */
.features-grid{display:flex;flex-direction:column;gap:2px;margin-top:32px;background:rgba(255,255,255,.05);border-radius:12px;overflow:hidden}
.feature-card{background:#111;padding:24px 20px;transition:background .25s;position:relative;overflow:hidden}
.feature-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,#FF5500,#FF7733);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.25,.46,.45,.94)}
.feature-card:hover{background:#1a1a1a}
.feature-card:hover::before{transform:scaleX(1)}
.feature-card__icon{width:44px;height:44px;background:rgba(255,85,0,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feature-card__icon svg{width:22px;height:22px;stroke:#FF5500;fill:none;stroke-width:1.8}
.feature-card__title{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:#fff;margin-bottom:8px}
.feature-card__text{font-size:13px;line-height:1.7;color:#999}

/* ============================================
   STATS STRIP
   ============================================ */
.stats{background:linear-gradient(135deg,#FF5500 0%,#CC3300 100%);padding:36px 20px;display:grid;grid-template-columns:repeat(2,1fr);gap:0}
.stat{text-align:center;padding:14px 8px}
.stat__number{font-family:'Barlow Condensed',sans-serif;font-size:36px;font-weight:900;color:#fff;line-height:1}
.stat__number sup{font-size:20px;vertical-align:super}
.stat__label{margin-top:4px;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.75)}

/* ============================================
   SERVICE CARDS (HOME)
   ============================================ */
.services-header{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}
.services-grid{display:flex;flex-direction:column;gap:12px}
.services-mobile-cta{margin-top:24px;text-align:center}
.service-card{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;display:block}
.service-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.service-card:hover img{transform:scale(1.08)}
.service-card__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 50%,transparent 100%);transition:background .3s}
.service-card:hover .service-card__overlay{background:linear-gradient(to top,rgba(255,85,0,.85) 0%,rgba(0,0,0,.5) 60%,transparent 100%)}
.service-card__content{position:absolute;bottom:0;left:0;right:0;padding:18px}
.service-card__tag{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#FF5500;margin-bottom:4px;transition:color .2s}
.service-card:hover .service-card__tag{color:rgba(255,255,255,.8)}
.service-card__name{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:900;text-transform:uppercase;color:#fff;line-height:1;margin-bottom:6px}
.service-card__desc{font-size:12px;line-height:1.6;color:rgba(255,255,255,.7)}
.service-card::after{content:'';position:absolute;inset:0;border-radius:12px;border:1px solid transparent;transition:border-color .4s}
.service-card:hover::after{border-color:rgba(255,85,0,.4)}

/* PILL FLOAT ANIMATION */
.about__pill{transition:transform .3s,background .3s}
.about__pill:hover{transform:translateY(-3px);background:rgba(255,85,0,.2)}

/* GALLERY GLOW */
.gallery-grid__item::after{content:'';position:absolute;inset:0;border-radius:8px;box-shadow:inset 0 0 0 0 rgba(255,85,0,0);transition:box-shadow .4s}
.gallery-grid__item:hover::after{box-shadow:inset 0 0 30px rgba(255,85,0,.15)}

/* BADGE PULSE */
.gallery-grid__badge{animation:badgePulse 2.5s ease-in-out infinite}
@keyframes badgePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* FEATURE CARD LIFT */
.feature-card{transition:transform .3s,box-shadow .3s,border-color .3s}
.feature-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px rgba(0,0,0,.3);border-color:rgba(255,85,0,.3)}
.feature-card__icon{transition:transform .4s}
.feature-card:hover .feature-card__icon{transform:scale(1.15) rotate(-5deg)}

/* STAT NUMBER HOVER */
.stat__number{transition:color .3s}
.stat:hover .stat__number{color:#FF5500}

/* ABOUT BADGE FLOAT */
.about__badge{animation:badgeFloat 3s ease-in-out infinite}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* TESTIMONIAL HOVER */
.testimonial{transition:transform .3s,border-color .3s}
.testimonial:hover{transform:translateY(-4px);border-color:rgba(255,85,0,.3)}

/* ============================================
   GALLERY
   ============================================ */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:32px}
.gallery-grid__item{border-radius:8px;overflow:hidden;height:120px;position:relative}
.gallery-grid__item--large{grid-column:span 2;height:200px}
.gallery-grid__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94),filter .4s}
.gallery-grid__item:hover img{transform:scale(1.06);filter:brightness(1.1)}
.gallery-grid__badge{position:absolute;top:8px;right:8px;background:#FF5500;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;padding:4px 10px;border-radius:4px;z-index:2}

/* ============================================
   SERVICE BLOCKS (servizi page)
   ============================================ */
.srv-block{display:flex;flex-direction:column;gap:28px}
.srv-block--reverse{flex-direction:column}
.srv-block__media{position:relative}
.srv-block__image-wrapper{border-radius:12px;overflow:hidden;position:relative}
.srv-block__image-wrapper img{width:100%;height:240px;object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94)}
.srv-block__image-wrapper:hover img{transform:scale(1.04)}
.srv-block__badge{position:absolute;top:10px;right:10px;background:#FF5500;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;padding:5px 12px;border-radius:4px;z-index:2}
.srv-block__content{}
.srv-block__number{font-family:'Barlow Condensed',sans-serif;font-size:48px;font-weight:900;color:rgba(255,85,0,.12);line-height:1;margin-bottom:-8px}
.srv-block__content p{margin-top:14px;font-size:14px;line-height:1.75;color:rgba(255,255,255,.7)}
.srv-block__content strong{color:#fff;font-weight:600}
.srv-block__tags{margin-top:20px;display:flex;flex-wrap:wrap;gap:6px}
.srv-tag{background:rgba(255,85,0,.08);border:1px solid rgba(255,85,0,.15);color:#FF5500;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:100px;transition:background .2s,border-color .2s}
.srv-tag:hover{background:rgba(255,85,0,.15);border-color:rgba(255,85,0,.3)}
.srv-block__cta{margin-top:24px}

/* DUAL IMAGE LAYOUT */
.srv-block__media--dual{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.srv-block__media--dual .srv-block__image-wrapper img{height:180px}

/* TEXT-ONLY LAYOUT */
.srv-block--textonly{justify-content:center}
.srv-block__content--centered{max-width:680px;margin:0 auto;text-align:center}
.srv-block__content--centered .srv-block__tags{justify-content:center}
.srv-block__content--centered .srv-block__number{font-size:64px;color:rgba(255,85,0,.08)}
.srv-block__content--centered .divider{margin:0 auto}

/* SRV ANIMATIONS PRO2 */
.srv-block__image-wrapper{transition:box-shadow .4s ease}
.srv-block__image-wrapper:hover{box-shadow:0 0 30px rgba(255,85,0,.15)}
.srv-block__number{transition:color .4s ease}
.srv-block:hover .srv-block__number{color:rgba(255,85,0,.25)}
.srv-tag{transition:background .2s,border-color .2s,transform .2s}
.srv-tag:hover{transform:translateY(-2px)}
.srv-block__badge{animation:badgePulse 2.5s ease-in-out infinite}
@keyframes srvNumberSlide{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:none}}
.srv-block.visible .srv-block__number{animation:srvNumberSlide .5s ease-out both}
.page-header__title{animation:fadeUp .6s cubic-bezier(.25,.46,.45,.94) .2s both}
.page-header__breadcrumb{animation:fadeUp .5s cubic-bezier(.25,.46,.45,.94) .1s both}

/* PHOTO STRIP */
.srv-photo-strip{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:0 20px}
.srv-photo-strip__item{border-radius:10px;overflow:hidden;height:140px;position:relative}
.srv-photo-strip__item:first-child{grid-column:span 2;height:180px}
.srv-photo-strip__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.srv-photo-strip__item:hover img{transform:scale(1.05)}
.srv-photo-strip__badge{position:absolute;top:8px;left:8px;background:#FF5500;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:9px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;padding:4px 10px;border-radius:4px;z-index:2}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonials-grid{display:flex;flex-direction:column;gap:12px;margin-top:32px}
.testimonial{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:22px 18px;position:relative;transition:transform .25s,border-color .25s}
.testimonial:hover{transform:translateY(-4px);border-color:rgba(255,85,0,.3)}
.testimonial__stars{display:flex;gap:2px;margin-bottom:12px}
.testimonial__stars svg{width:14px;height:14px;fill:#FFCE25}
.testimonial__text{font-size:13px;line-height:1.75;color:rgba(255,255,255,.75);margin-bottom:16px}
.testimonial__text strong{color:#FFCE25;font-weight:600}
.testimonial__author{display:flex;align-items:center;gap:10px}
.testimonial__avatar{width:34px;height:34px;border-radius:50%;background:rgba(255,85,0,.15);border:2px solid rgba(255,85,0,.3);display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:800;color:#FF5500;flex-shrink:0}
.testimonial__name{font-family:'Barlow Condensed',sans-serif;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#f0f0f0}
.testimonial__source{font-size:11px;color:#777;margin-top:1px}
.testimonial--featured{background:linear-gradient(135deg,#FF5500,#CC3300);border-color:transparent}
.testimonial--featured .testimonial__text{color:rgba(255,255,255,.92)}
.testimonial--featured .testimonial__text strong{color:#fff}
.testimonial--featured .testimonial__name{color:#fff}
.testimonial--featured .testimonial__source{color:rgba(255,255,255,.6)}
.testimonial--featured .testimonial__avatar{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.3);color:#fff}

/* ============================================
   CTA BANNER
   ============================================ */
.cta-banner{position:relative;overflow:hidden;padding:56px 20px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px}
.cta-banner__bg{position:absolute;inset:0;background-size:cover;background-position:center}
.cta-banner__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.75) 100%)}
.cta-banner__content{position:relative;z-index:2}
.cta-banner__title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(30px,8vw,38px);font-weight:900;text-transform:uppercase;line-height:.95;color:#fff}
.cta-banner__title em{font-style:italic;color:#FF5500}
.cta-banner__subtitle{margin-top:10px;font-size:14px;color:rgba(255,255,255,.65);max-width:400px}
.cta-banner__actions{position:relative;z-index:2;display:flex;flex-direction:column;gap:10px;width:100%;max-width:300px}

/* ============================================
   HOURS & CONTACT
   ============================================ */
.info-grid{display:flex;flex-direction:column;gap:36px}
.hours-list{margin-top:16px}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07);font-size:14px}
.hours-row:last-child{border-bottom:none}
.hours-row__day{font-weight:600;color:#fff;font-size:13px}
.hours-row__time{color:#FF5500;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:15px}
.hours-image{margin-top:20px;border-radius:12px;overflow:hidden}
.hours-image img{width:100%;height:160px;object-fit:cover}
.contact-list{margin-top:16px;display:flex;flex-direction:column;gap:16px}
.contact-item{display:flex;align-items:flex-start;gap:12px}
.contact-item__icon{width:38px;height:38px;background:rgba(255,85,0,.1);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-item__icon svg{width:17px;height:17px;stroke:#FF5500;fill:none;stroke-width:1.8}
.contact-item__label{font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#FF5500;margin-bottom:2px}
.contact-item__value{font-size:13px;color:rgba(255,255,255,.8);line-height:1.5}
.contact-item__value a{transition:color .2s}
.contact-item__value a:hover{color:#FF5500}
.contact-item__link{color:#FF5500!important;font-size:12px;margin-top:4px;display:inline-block}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:#050505;border-top:1px solid rgba(255,255,255,.06);padding:36px 20px 24px}
.footer__top{display:flex;flex-direction:column;gap:28px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer__logo img{height:44px;object-fit:contain;margin-bottom:10px}
.footer__tagline{font-size:12px;line-height:1.7;color:#777}
.footer__social{display:flex;gap:8px;margin-top:14px}
.footer__social-btn{width:32px;height:32px;border-radius:8px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;transition:background .2s}
.footer__social-btn:hover{background:#FF5500}
.footer__social-btn svg{width:14px;height:14px;fill:#fff}
.footer__col-title{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.footer__col-links{display:flex;flex-direction:column;gap:9px}
.footer__col-links a,.footer__col-links span{font-size:12px;color:#777;transition:color .2s}
.footer__col-links a:hover{color:#FF5500}
.footer__bottom{display:flex;flex-direction:column;text-align:center;gap:4px;padding-top:20px;font-size:11px;color:#666}
.footer__piva{color:rgba(255,255,255,.2);font-size:10px}

/* ============================================
   PAGE HEADER (sub-pages)
   ============================================ */
.page-header{background:#111;padding:96px 20px 36px;text-align:left}
.page-header__breadcrumb{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#FF5500;margin-bottom:10px}
.page-header__title{font-family:'Barlow Condensed',sans-serif;font-size:32px;font-weight:900;text-transform:uppercase;color:#fff;line-height:.95}

/* ============================================
   SERVICES PAGE
   ============================================ */
.services-detail{display:flex;flex-direction:column;gap:16px}
.service-detail{background:#1a1a1a;border:1px solid rgba(255,255,255,.06);border-radius:14px;overflow:hidden;transition:border-color .3s}
.service-detail:hover{border-color:rgba(255,85,0,.2)}
.service-detail__header{display:flex;align-items:center;gap:14px;padding:18px}
.service-detail__icon{width:44px;height:44px;background:rgba(255,85,0,.12);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:900;color:#FF5500}
.service-detail__title{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;text-transform:uppercase;color:#fff}
.service-detail__subtitle{font-size:12px;color:#999;margin-top:2px}
.service-detail__body{padding:0 18px 18px;font-size:13px;line-height:1.7;color:rgba(255,255,255,.7)}
.service-detail__body strong{color:#fff;font-weight:600}
.service-detail__extras{padding:0 18px 18px;display:flex;flex-wrap:wrap;gap:6px}
.service-detail__tag{background:rgba(255,85,0,.08);color:#FF5500;font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:100px}

/* SERVICES SLIDESHOW */
.slideshow{position:relative;border-radius:12px;overflow:hidden;margin-top:32px}
.slideshow__track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.slideshow__slide{min-width:100%;height:240px}
.slideshow__slide img{width:100%;height:100%;object-fit:cover}
.slideshow__controls{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:6px}
.slideshow__dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:background .2s}
.slideshow__dot.active{background:#FF5500}
.slideshow__btn{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;transition:background .2s;z-index:5}
.slideshow__btn:hover{background:rgba(255,85,0,.8)}
.slideshow__btn--prev{left:10px}
.slideshow__btn--next{right:10px}
.slideshow__caption{position:absolute;bottom:36px;left:14px;right:14px;font-size:12px;color:rgba(255,255,255,.8);background:rgba(0,0,0,.5);padding:6px 10px;border-radius:6px;text-align:center}

/* ============================================
   PRICING PAGE
   ============================================ */
.pricing-grid{display:flex;flex-direction:column;gap:14px}
.pricing-card{background:#1a1a1a;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:22px 18px;position:relative;transition:transform .25s,border-color .3s}
.pricing-card:hover{transform:translateY(-4px);border-color:rgba(255,85,0,.25)}
.pricing-card--popular{border-color:#FF5500}
.pricing-card__badge{position:absolute;top:-1px;right:18px;background:#FF5500;color:#fff;font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;padding:5px 12px;border-radius:0 0 8px 8px}
.pricing-card__name{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;text-transform:uppercase;color:#fff;margin-bottom:4px}
.pricing-card__desc{font-size:12px;color:#999;margin-bottom:14px}
.pricing-card__price{font-family:'Barlow Condensed',sans-serif;font-size:40px;font-weight:900;color:#FF5500;line-height:1}
.pricing-card__price span{font-size:14px;font-weight:600;color:#999}
.pricing-card__features{margin-top:18px;display:flex;flex-direction:column;gap:9px}
.pricing-card__feature{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.75)}
.pricing-card__feature svg{width:15px;height:15px;stroke:#FF5500;fill:none;stroke-width:2.5;flex-shrink:0;margin-top:2px}
.pricing-card__note{margin-top:12px;font-size:11px;color:#777;line-height:1.6;padding:8px;background:rgba(255,255,255,.03);border-radius:6px}
.pricing-card__cta{margin-top:16px}

/* FAQ */
.faq{margin-top:32px}
.faq__item{border-bottom:1px solid rgba(255,255,255,.07)}
.faq__question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 0;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.03em;text-align:left;cursor:pointer}
.faq__question svg{width:18px;height:18px;stroke:#FF5500;fill:none;stroke-width:2;transition:transform .3s;flex-shrink:0}
.faq__question.open svg{transform:rotate(180deg)}
.faq__answer{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.25,.46,.45,.94)}
.faq__answer-inner{padding:0 0 16px;font-size:13px;line-height:1.7;color:rgba(255,255,255,.7)}
.faq__answer-inner strong{color:#fff;font-weight:600}
.faq__answer-inner ul{margin-top:8px;display:flex;flex-direction:column;gap:5px;padding-left:0}
.faq__answer-inner li{padding-left:14px;position:relative}
.faq__answer-inner li::before{content:'';position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:#FF5500}

/* SIDEBAR (pricing page) */
.pricing-sidebar{margin-top:28px}
.pricing-sidebar__grid{display:flex;flex-direction:column;gap:14px}
.pricing-sidebar__block{background:#1a1a1a;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:22px 18px}
.pricing-sidebar__title{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:#fff;margin-bottom:10px}
.pricing-sidebar p{font-size:13px;color:#999;line-height:1.6;margin-bottom:12px}
.pricing-sidebar .btn-primary{display:inline-flex;width:100%;color:#fff}
.pricing-sidebar .btn-ghost{display:inline-flex;width:100%;justify-content:center;color:#fff}

/* ============================================
   CALENDAR PAGE
   ============================================ */
.calendar-image{border-radius:12px;overflow:hidden;margin-top:20px}
.calendar-image img{width:100%;height:auto}
.calendar-note{margin-top:14px;font-size:12px;color:#999;line-height:1.6;padding:14px;background:rgba(255,255,255,.03);border-radius:8px}

/* ============================================
   CONTACT FORM
   ============================================ */
.contact-form{margin-top:28px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#FF5500;margin-bottom:5px}
.form-group input,.form-group textarea,.form-group select{width:100%;background:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:13px 14px;color:#fff;font-size:14px;transition:border-color .2s;outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#FF5500}
.form-group textarea{min-height:110px;resize:vertical}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23FF5500' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.form-success{display:none;text-align:center;padding:36px 18px}
.form-success svg{width:54px;height:54px;stroke:#FF5500;fill:none;stroke-width:1.5;margin-bottom:14px}
.form-success h3{font-family:'Barlow Condensed',sans-serif;font-size:22px;font-weight:800;color:#fff;text-transform:uppercase;margin-bottom:6px}
.form-success p{font-size:13px;color:#999}

/* ============================================
   MAP
   ============================================ */
.map-wrapper{border-radius:12px;overflow:hidden;margin-top:20px;height:200px}
.map-wrapper iframe{width:100%;height:100%;border:0;filter:grayscale(.8) contrast(1.1) brightness(.7)}

/* ============================================
   TABLET — min-width: 768px
   ============================================ */
@media(min-width:768px){
  .topbar{padding:0 32px;height:42px;font-size:13px}
  .topbar__item--address{display:flex}
  .topbar__info{gap:24px}

  .navbar{padding:0 32px;height:66px}
  .navbar__logo img{height:52px}

  .hero{min-height:100svh;min-height:100vh;align-items:center;padding:0}
  .hero__overlay{background:linear-gradient(105deg,rgba(0,0,0,.85) 40%,rgba(13,13,13,.4) 100%)}
  .hero__bg{background-position:center 30%}
  .hero__content{padding:0 40px;max-width:700px}
  .hero__title{font-size:72px}
  .hero__subtitle{font-size:16px}
  .hero__actions{flex-direction:row;gap:14px}

  .section{padding:72px 40px}
  .section__title{font-size:44px}

  .about{flex-direction:row;gap:48px;align-items:center}
  .about__text{flex:1}
  .about__visual{flex:1}
  .about__image-wrapper img{height:360px}
  .about__badge{width:92px;height:92px;bottom:-16px;left:-14px}
  .about__badge-number{font-size:30px}
  .about__badge-text{font-size:9px}

  .features-grid{display:grid;grid-template-columns:repeat(2,1fr)}

  .stats{padding:44px 40px}
  .stat__number{font-size:44px}

  .services-header{flex-direction:row;align-items:flex-end;justify-content:space-between}
  .btn-primary--desktop{display:inline-flex}
  .services-mobile-cta{display:none}
  .services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
  .service-card{aspect-ratio:3/4}
  .service-card__name{transition:transform .3s}
  .service-card:hover .service-card__name{transform:translateX(6px)}

  .gallery-grid{grid-template-columns:repeat(3,1fr);gap:8px}
  .gallery-grid__item{height:160px}
  .gallery-grid__item--large{grid-column:span 2;height:320px}

  .testimonials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}

  .cta-banner{flex-direction:row;text-align:left;padding:72px 40px;justify-content:space-between;align-items:center}
  .cta-banner__actions{flex-direction:column;width:auto;align-items:flex-start;max-width:240px}

  .info-grid{flex-direction:row;gap:48px}
  .info-grid>div{flex:1}
  .hours-image img{height:200px}

  .footer__top{flex-direction:row;gap:40px}
  .footer{padding:44px 40px 28px}
  .footer__bottom{flex-direction:row;justify-content:space-between;text-align:left}

  .page-header{padding:112px 40px 44px}
  .page-header__title{font-size:44px}

  .services-detail{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
  .slideshow__slide{height:340px}
  .pricing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
  .map-wrapper{height:280px}
  .contact-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .contact-form .form-group--full{grid-column:span 2}
  .contact-form .form-group--submit{grid-column:span 2}

  .pricing-sidebar__grid{flex-direction:row;gap:14px}
  .pricing-sidebar__block{flex:1}
  .pricing-sidebar .btn-primary{width:auto}
  .pricing-sidebar .btn-ghost{width:auto}

  .srv-block{flex-direction:row;gap:40px;align-items:center}
  .srv-block--reverse{flex-direction:row-reverse}
  .srv-block--textonly{flex-direction:column}
  .srv-block__media{flex:1;min-width:0}
  .srv-block__content{flex:1;min-width:0}
  .srv-block__content--centered{max-width:720px}
  .srv-block__image-wrapper img{height:320px}
  .srv-block__media--dual .srv-block__image-wrapper img{height:280px}
  .srv-block__number{font-size:64px}
  .srv-photo-strip{grid-template-columns:repeat(3,1fr);gap:10px;padding:0 40px}
  .srv-photo-strip__item:first-child{grid-column:span 1;height:200px}
  .srv-photo-strip__item{height:200px}
}

/* ============================================
   DESKTOP — min-width: 1024px
   ============================================ */
@media(min-width:1024px){
  .topbar{padding:0 48px}
  .topbar__info{gap:28px}
  .topbar__social{gap:10px}
  .topbar__social a{width:28px;height:28px}

  .navbar{padding:0 40px;height:72px}
  .navbar__logo img{height:60px}
  .navbar__links{display:flex}
  .navbar__cta{display:inline-flex}
  .navbar__hamburger{display:none}

  .hero__content{padding:0 80px;max-width:820px}
  .hero__title{font-size:clamp(80px,9vw,120px)}
  .hero__subtitle{font-size:17px;margin-top:24px}
  .hero__actions{margin-top:36px;gap:16px}
  .hero__stats{display:flex;position:absolute;bottom:40px;right:80px;gap:40px;animation:fadeUp .7s cubic-bezier(.25,.46,.45,.94) 1s both;z-index:2}
  .hero__stat-number{font-family:'Barlow Condensed',sans-serif;font-size:44px;font-weight:900;color:#FF5500;line-height:1}
  .hero__stat-number span{font-size:24px}
  .hero__stat-label{font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:4px}
  .hero__scroll{display:flex;position:absolute;bottom:36px;left:80px;align-items:center;gap:10px;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.4);animation:fadeUp .7s cubic-bezier(.25,.46,.45,.94) 1.1s both;z-index:2}
  .hero__scroll-line{width:36px;height:1px;background:rgba(255,255,255,.3);position:relative;overflow:hidden}
  .hero__scroll-line::after{content:'';position:absolute;left:-100%;top:0;width:100%;height:100%;background:#FF5500;animation:scrollLine 2s ease infinite}
  @keyframes scrollLine{to{left:100%}}

  .section{padding:90px 80px}
  .section__title{font-size:clamp(40px,5vw,58px)}

  .about{gap:72px}
  .about__text p{font-size:15px}
  .about__image-wrapper img{height:440px}
  .about__badge{width:110px;height:110px;bottom:-18px;left:-18px}
  .about__badge-number{font-size:36px}
  .about__badge-text{font-size:9px}

  .features-grid{grid-template-columns:repeat(3,1fr)}
  .feature-card{padding:36px 28px}

  .stats{padding:52px 80px;grid-template-columns:repeat(4,1fr)}
  .stat__number{font-size:52px}
  .stat__label{font-size:11px}

  .services-grid{grid-template-columns:repeat(4,1fr);gap:18px}
  .service-card{aspect-ratio:3/4}
  .service-card__desc{max-height:0;opacity:0;transition:max-height .4s,opacity .3s}
  .service-card:hover .service-card__desc{max-height:80px;opacity:1}

  .gallery-grid{grid-template-columns:repeat(4,1fr);grid-template-rows:220px 220px;gap:10px}
  .gallery-grid__item{height:auto}
  .gallery-grid__item--large{grid-column:span 2;grid-row:span 2;height:auto}

  .testimonials-grid{grid-template-columns:repeat(3,1fr);gap:18px}
  .testimonial{padding:32px}

  .cta-banner{padding:90px 80px}
  .cta-banner__title{font-size:clamp(38px,5vw,58px)}

  .info-grid{gap:72px}

  .footer{padding:56px 80px 36px}
  .footer__top{gap:56px}
  .footer__top>div:first-child{flex:1.5}
  .footer__logo img{height:52px}

  .page-header{padding:132px 80px 56px}
  .page-header__title{font-size:clamp(40px,5vw,58px)}

  .pricing-grid{grid-template-columns:repeat(3,1fr);gap:18px}
  .slideshow__slide{height:420px}
  .map-wrapper{height:340px}

  .srv-block{gap:56px}
  .srv-block__image-wrapper img{height:400px}
  .srv-block__media--dual .srv-block__image-wrapper img{height:360px}
  .srv-block__media--dual{gap:12px}
  .srv-block__content--centered{max-width:780px}
  .srv-block__content--centered .srv-block__number{font-size:96px}
  .srv-block__number{font-size:80px}
  .srv-block__content p{font-size:15px}
  .srv-photo-strip{padding:0 80px;gap:14px}
  .srv-photo-strip__item{height:240px}
  .srv-photo-strip__item:first-child{height:240px}
}

/* ============================================
   WIDE DESKTOP — min-width: 1400px
   ============================================ */
@media(min-width:1400px){
  .section{padding:110px 120px}
  .hero__content{padding:0 120px}
  .footer{padding:60px 120px 40px}
  .page-header{padding:150px 120px 60px}
  .cta-banner{padding:100px 120px}
  .stats{padding:60px 120px}
}

/* ============================================
   CALL WIDGET — Fixed bottom-right
   ============================================ */
.call-widget{position:fixed;bottom:24px;right:24px;z-index:9998;display:flex;align-items:center;gap:0}
.call-widget__btn{width:56px;height:56px;border-radius:50%;background:#FF5500;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(255,85,0,.4);transition:transform .2s,box-shadow .2s;cursor:pointer}
.call-widget__btn:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(255,85,0,.55)}
.call-widget__btn svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:2}
.call-widget__pulse{position:absolute;width:56px;height:56px;border-radius:50%;background:rgba(255,85,0,.3);animation:callPulse 2s infinite}
@keyframes callPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.8);opacity:0}}
@media(max-width:767px){
  .call-widget{bottom:16px;right:16px}
  .call-widget__btn{width:50px;height:50px}
  .call-widget__btn svg{width:22px;height:22px}
  .call-widget__pulse{width:50px;height:50px}
}

/* ============================================
   COOKIE BANNER — Fixed bottom-left
   ============================================ */
.cookie-banner{position:fixed;bottom:24px;left:24px;z-index:9997;background:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:18px 20px;max-width:340px;box-shadow:0 8px 32px rgba(0,0,0,.5);display:none;animation:cookieSlideUp .4s ease-out}
.cookie-banner.show{display:block}
.cookie-banner__text{font-size:13px;color:rgba(255,255,255,.7);line-height:1.5;margin-bottom:14px}
.cookie-banner__text a{color:#FF5500;text-decoration:underline}
.cookie-banner__actions{display:flex;gap:8px}
.cookie-banner__btn{flex:1;padding:10px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s;border:none;font-family:inherit}
.cookie-banner__btn--accept{background:#FF5500;color:#fff}
.cookie-banner__btn--accept:hover{background:#e64d00;transform:translateY(-1px)}
.cookie-banner__btn--reject{background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.12)}
.cookie-banner__btn--reject:hover{background:rgba(255,255,255,.14);transform:translateY(-1px)}
@keyframes cookieSlideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@media(max-width:767px){
  .cookie-banner{bottom:78px;left:12px;right:12px;max-width:none}
}