/* Step Gym - stepgym layout */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body.sg-body{font-family:'DM Sans',sans-serif;color:#111827;background:#FFFFFF;line-height:1.6}
h1,h2,h3,h4{font-family:'Syne',serif;font-weight:700;line-height:1.2}
img{max-width:100%;height:auto;display:block}
a{color:#7C3AED;text-decoration:none}
a:hover{text-decoration:underline}

/* Header */
.sg-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#F3F4F6;box-shadow:0 2px 12px rgba(0,0,0,.08)}
.sg-header-inner{max-width:1200px;margin:0 auto;padding:1rem 5%;display:flex;align-items:center;justify-content:space-between}
.sg-logo{font-family:'Syne';font-size:1.5rem;font-weight:700;color:#111827}
.sg-nav{display:flex;align-items:center;gap:1.5rem}
.sg-nav a{color:#111827;font-weight:500}
.sg-nav-active{color:#7C3AED!important;border-bottom:2px solid #7C3AED}
.sg-nav-cta{background:#7C3AED;color:#fff!important;padding:.6rem 1.2rem;border-radius:4px;text-decoration:none!important}
.sg-nav-cta:hover{opacity:.9;transform:translateY(-2px)}
.sg-menu-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px}
.sg-menu-btn span{width:24px;height:2px;background:#111827}

/* Main */
.sg-main{padding-top:70px}
.sg-page-hero{background:#7C3AED;color:#fff;padding:4rem 5%;text-align:center}
.sg-page-hero h1{font-size:clamp(2rem,5vw,3rem)}

/* Hero layouts */
.sg-hero-bento .sg-bento{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.sg-card{border-top:4px solid #7C3AED;position:relative}.sg-card::after{content:'';position:absolute;top:0;right:0;width:24px;height:24px;background:#EAB308}

/* Cards & grids */
.sg-featured,.sg-services-home,.sg-why,.sg-testimonials,.sg-regions,.sg-split,.sg-cta-band{padding:4rem 5%}
.sg-featured h2,.sg-services-home h2,.sg-why h2,.sg-testimonials h2{margin-bottom:2rem;text-align:center}
.sg-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.sg-card{overflow:hidden;border-radius:8px;transition:transform .35s ease}
.sg-card:hover{transform:translateY(-4px)}
.sg-card img{width:100%;height:200px;object-fit:cover}
.sg-card-body{padding:1.25rem}
.sg-card-body h3{text-transform:uppercase;font-size:1rem;margin-bottom:.5rem}

/* Quote */
.sg-quote-band{background:#9CA3AF;color:#fff;padding:3rem 5%;text-align:center}
.sg-quote-band blockquote{font-size:1.5rem;font-style:italic}

/* Regions */
.sg-regions div{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.sg-regions span{background:#7C3AED;color:#fff;padding:.5rem 1.5rem;border-radius:4px;font-weight:600}

/* Services cols */
.sg-svc-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.sg-svc-col{background:#F3F4F6;padding:2rem;border-radius:8px;text-align:center}

/* Split stats */
.sg-split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;background:#F3F4F6}
.sg-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center}
.sg-stats strong{display:block;font-size:2.5rem;color:#7C3AED}

/* Features */
.sg-features{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.sg-features h3{color:#7C3AED;margin-bottom:.5rem}

/* Testimonials */
.sg-testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.sg-testi{background:#F3F4F6;padding:1.5rem;border-radius:8px}
.sg-testi cite{display:block;margin-top:1rem;font-style:normal;font-weight:600}

/* CTA */
.sg-cta-band{text-align:center;background:#7C3AED;color:#fff}
.sg-cta-band h2{margin-bottom:1.5rem;color:#fff}
.sg-cta-band .sg-btn-primary{background:#fff;color:#7C3AED}

/* Buttons */
.sg-btn{display:inline-block;padding:.75rem 1.5rem;font-weight:700;border:none;cursor:pointer;border-radius:4px;transition:all .35s ease;font-family:inherit}
.sg-btn-primary{background:#7C3AED;color:#fff}
.sg-btn-primary:hover{opacity:.9;transform:translateY(-2px)}
.sg-btn-outline{background:transparent;border:2px solid #7C3AED;color:#7C3AED}
.sg-btn-outline:hover{background:#7C3AED;color:#fff}
.sg-btn-sm{padding:.5rem 1rem;font-size:.875rem}

/* Collection */
.sg-filters{padding:2rem 5%;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}
.sg-filter{padding:.5rem 1rem;border:1px solid #7C3AED;background:transparent;color:#7C3AED;cursor:pointer;border-radius:4px;font-family:inherit}
.sg-filter-active,.sg-filter:hover{background:#7C3AED;color:#fff}
.sg-exc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;padding:2rem 5% 4rem}
.sg-exc-card{background:#F3F4F6;border-radius:8px;overflow:hidden;box-shadow:0 4px 16px rgba(0,0,0,.06)}
.sg-exc-card.hidden{display:none}
.sg-exc-body{padding:1.5rem}
.sg-exc-cat{font-size:.75rem;text-transform:uppercase;color:#7C3AED;font-weight:700}
.sg-exc-ref{font-size:.8rem;color:#666;margin:.5rem 0}
.sg-exc-meta{list-style:none;margin:1rem 0;font-size:.9rem}
.sg-exc-meta li{margin-bottom:.25rem}
.sg-exc-price{font-size:1.25rem;font-weight:700;color:#7C3AED;margin:1rem 0}

/* Services page */
.sg-services-list{padding:2rem 5% 4rem}
.sg-svc-block{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem;align-items:center}
.sg-svc-block:nth-child(even){direction:rtl}
.sg-svc-block:nth-child(even)>*{direction:ltr}

/* About */
.sg-about-split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;padding:3rem 5% 4rem;align-items:start}
.sg-about-split h2{margin:1.5rem 0 .75rem;color:#7C3AED}

/* Contact */
.sg-contact-wrap{display:grid;grid-template-columns:1fr 1.5fr;gap:3rem;padding:3rem 5% 4rem;max-width:1100px;margin:0 auto}
.sg-field{margin-bottom:1.25rem}
.sg-field label{display:block;margin-bottom:.35rem;font-weight:600}
.sg-field input,.sg-field select,.sg-field textarea{width:100%;padding:.75rem;border:1px solid #ccc;border-radius:4px;font-family:inherit;font-size:1rem}
.sg-field input:focus,.sg-field select:focus,.sg-field textarea:focus{outline:2px solid #7C3AED;border-color:#7C3AED}
.sg-error{color:#DC2626;font-size:.85rem;display:block;margin-top:.25rem}
.sg-form-box{background:#F3F4F6;padding:2rem;border-radius:8px}
.sg-success{padding:2rem;background:#7C3AED;color:#fff;border-radius:8px;text-align:center;animation:fadeIn .5s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* Legal */
.sg-legal{max-width:800px;margin:0 auto;padding:3rem 5% 4rem}
.sg-legal h2{margin:2rem 0 1rem;color:#7C3AED}
.sg-legal p{margin-bottom:1rem}

/* Footer */
.sg-footer{background:#9CA3AF;color:#fff;padding:3rem 5% 1.5rem;margin-top:4rem}
.sg-footer a{color:#EAB308}
.sg-footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:2rem}
.sg-footer h4{margin-bottom:1rem}
.sg-footer div a{display:block;margin-bottom:.5rem}
.sg-copy{text-align:center;font-size:.875rem;opacity:.8;border-top:1px solid rgba(255,255,255,.2);padding-top:1.5rem}

/* Cookie */
.sg-cookie{position:fixed;bottom:0;left:0;right:0;background:#9CA3AF;color:#fff;padding:1rem 5%;display:flex;align-items:center;justify-content:space-between;gap:1rem;z-index:9999;flex-wrap:wrap}
.sg-cookie a{color:#EAB308}
.sg-cookie[hidden]{display:none!important}

/* FAQ */
.sg-faq{padding:2rem 5% 4rem;max-width:700px;margin:0 auto}
.sg-faq details{margin-bottom:1rem;border:1px solid #ddd;border-radius:4px;padding:1rem}
.sg-faq summary{cursor:pointer;font-weight:600}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* Responsive */
@media(max-width:900px){
.sg-hero-diagonal,.sg-hero-split,.sg-split,.sg-svc-cols,.sg-features,.sg-testi-grid,.sg-about-split,.sg-contact-wrap,.sg-svc-block,.sg-footer-grid,.sg-hero-journal{grid-template-columns:1fr}
.sg-nav{display:none;position:absolute;top:100%;left:0;right:0;background:#F3F4F6;flex-direction:column;padding:1rem;box-shadow:0 4px 12px rgba(0,0,0,.1)}
.sg-nav.open{display:flex}
.sg-menu-btn{display:flex}
.sg-hero-diagonal{clip-path:none}
.sg-hero-circle img{width:280px;height:280px}
.sg-city-scroll{padding-bottom:1rem}
}

/* Site-specific animation timing */
.sg-btn{transition:background .35s ease,color .35s ease,transform .35s ease,box-shadow .35s ease}
.sg-card img{transition:transform .5s ease}
.sg-card:hover img{transform:scale(1.04)}
.sg-hero-content h1{animation:sgSlideIn .6s ease forwards}
@keyframes sgSlideIn{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:none}}

/* Hero content padding */
.sg-hero-content,.sg-hero-inner{padding:3rem 5%}
.sg-hero-content h1,.sg-hero-inner h1{font-size:clamp(2rem,5vw,3.5rem);margin-bottom:1rem}
.sg-hero-content p{margin-bottom:1.5rem;max-width:520px}
.sg-hero-img img,.sg-hero-inner img{width:100%;height:100%;object-fit:cover;min-height:400px}
.sg-counter-label{display:block;color:#EAB308;font-size:.875rem;margin-top:.5rem}

/* Parks / strips */
.sg-parks-strip,.sg-season-strip{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding:2rem 5%;background:#F3F4F6;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.sg-elev-band{background:#9CA3AF;color:#fff;padding:3rem 5%;text-align:center}

/* Newsletter mock */
.sg-newsletter{padding:3rem 5%;background:#F3F4F6;text-align:center}
.sg-newsletter input{padding:.75rem 1rem;border:1px solid #ccc;border-radius:4px;margin-right:.5rem;min-width:220px}
.sg-newsletter button{padding:.75rem 1.5rem}

/* Calendar mock */
.sg-calendar{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2rem 5%}
.sg-calendar div{background:#F3F4F6;padding:1rem;border-left:3px solid #7C3AED;font-size:.9rem}

/* Vertical stats (PullGym) */
.sg-vstats{display:flex;justify-content:space-around;padding:2rem 5%;background:#9CA3AF;color:#fff;text-align:center}
.sg-vstats strong{display:block;font-size:2rem;color:#EAB308;}

/* Safety / etiquette bands */
.sg-safety,.sg-etiquette,.sg-weather,.sg-ethics{padding:2rem 5%;background:#F3F4F6;border-left:4px solid #7C3AED;margin:2rem 5%;max-width:900px}
.sg-gear-list{padding:2rem 5%;columns:2;gap:2rem;max-width:700px;margin:0 auto}
.sg-gear-list li{margin-bottom:.5rem}

/* Corporate band */
.sg-corporate-band{background:#7C3AED;color:#fff;padding:4rem 5%;text-align:center}
.sg-corporate-band h2{color:#fff;margin-bottom:1rem}

/* Station map grid */
.sg-stations{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2rem 5%}
.sg-stations span{background:#9CA3AF;color:#fff;padding:2rem;text-align:center;font-weight:700;border:2px solid #7C3AED}

/* Skills strip */
.sg-skills{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding:2rem 5%}
.sg-skills span{border:1px solid #7C3AED;padding:.5rem 1rem;border-radius:999px;font-size:.875rem}

/* Season calendar */
.sg-season-cal{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:2rem 5%}
.sg-season-cal div{text-align:center;padding:1.5rem;background:#F3F4F6}

/* Route map placeholder */
.sg-route-map{height:300px;background:#F3F4F6;margin:2rem 5%;display:flex;align-items:center;justify-content:center;border:2px dashed #7C3AED;font-weight:600}

/* Tide strip */
.sg-tide-strip{display:flex;justify-content:center;gap:2rem;padding:1.5rem 5%;background:#9CA3AF;color:#fff;font-family:monospace}

/* Max six emphasis */
.sg-max-six{text-align:center;padding:2rem;font-size:1.25rem;font-weight:600;color:#7C3AED}

/* Itinerary */
.sg-itinerary{padding:3rem 5%;background:#F3F4F6}

/* Stamps section */
.sg-stamps{text-align:center;padding:2rem 5%}
.sg-stamps img{max-width:500px;margin:0 auto;border-radius:8px}

/* Flow steps */
.sg-flow ol{max-width:500px;margin:1rem auto;padding-left:1.5rem}
.sg-flow li{margin-bottom:.75rem}

/* Chapters sidebar layout for mire on desktop */
@media(min-width:901px){
.sg-chapters{padding:2rem 0}
}

/* Focus visible accessibility */
a:focus-visible,.sg-btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
outline:3px solid #7C3AED;outline-offset:2px}

/* Extended site-specific rules */

.sg-page-hero h1{letter-spacing:-.02em}
.sg-exc-card img{height:220px;object-fit:cover}
.sg-footer-grid a:hover{opacity:.85}
.sg-btn:active{transform:translateY(0)}
.sg-testi blockquote{font-style:italic;line-height:1.7}
.sg-legal h2{font-size:1.25rem}
.sg-contact-wrap h2{color:#fff;margin-bottom:1rem}
.sg-cookie button:hover{opacity:.9}
@media(prefers-reduced-motion:reduce){.sg-card,.reveal{transition:none!important;animation:none!important}}

/* Extended site-specific rules */

.sg-page-hero h1{letter-spacing:-.02em}
.sg-exc-card img{height:220px;object-fit:cover}
.sg-footer-grid a:hover{opacity:.85}
.sg-btn:active{transform:translateY(0)}
.sg-testi blockquote{font-style:italic;line-height:1.7}
.sg-legal h2{font-size:1.25rem}
.sg-contact-wrap h2{color:#fff;margin-bottom:1rem}
.sg-cookie button:hover{opacity:.9}
.sg-hero-content h1{max-width:640px}
.sg-card-grid{margin-top:1rem}
.sg-svc-col h3{margin-bottom:.75rem;font-size:1.1rem}
.sg-features p{font-size:.95rem;color:#555}
.sg-regions h2{margin-bottom:1.5rem}
.sg-cta-band .sg-btn{font-size:1.05rem;padding:1rem 2rem}
.sg-about-split img{border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.sg-filters{background:#fff11}
.sg-exc-price::before{content:'';display:block;width:40px;height:3px;background:#fff;margin-bottom:.5rem}
.sg-form-box h2{display:none}
.sg-success p{font-size:1.05rem;line-height:1.6}
.sg-footer strong{font-size:1.1rem}
.sg-nav a:hover{color:#fff}
.sg-page-hero p{opacity:.9;margin-top:.5rem}
@media(min-width:1200px){.sg-header-inner,.sg-featured,.sg-footer-grid{max-width:1200px;margin-left:auto;margin-right:auto}}
@media(prefers-reduced-motion:reduce){.sg-card,.reveal{transition:none!important;animation:none!important}}

/* Extended site-specific rules */

.sg-page-hero h1{letter-spacing:-.02em}
.sg-exc-card img{height:220px;object-fit:cover}
.sg-footer-grid a:hover{opacity:.85}
.sg-btn:active{transform:translateY(0)}
.sg-testi blockquote{font-style:italic;line-height:1.7}
.sg-legal h2{font-size:1.25rem}
.sg-contact-wrap h2{color:#fff;margin-bottom:1rem}
.sg-cookie button:hover{opacity:.9}
.sg-hero-content h1{max-width:640px}
.sg-card-grid{margin-top:1rem}
.sg-svc-col h3{margin-bottom:.75rem;font-size:1.1rem}
.sg-features p{font-size:.95rem;color:#555}
.sg-regions h2{margin-bottom:1.5rem}
.sg-cta-band .sg-btn{font-size:1.05rem;padding:1rem 2rem}
.sg-about-split img{border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.sg-filters{background:#fff11}
.sg-exc-price::before{content:'';display:block;width:40px;height:3px;background:#fff;margin-bottom:.5rem}
.sg-form-box h2{display:none}
.sg-success p{font-size:1.05rem;line-height:1.6}
.sg-footer strong{font-size:1.1rem}
.sg-nav a:hover{color:#fff}
.sg-page-hero p{opacity:.9;margin-top:.5rem}
.sg-bento img,.sg-tile,.sg-city-card{transition:transform .4s ease}
.sg-bento img:hover,.sg-tile:hover{transform:scale(1.02)}
.sg-quote-band blockquote{max-width:720px;margin:0 auto}
.sg-testi-grid blockquote{margin-bottom:.5rem}
.sg-svc-block h3{font-size:1.35rem;margin-bottom:.75rem}
.sg-svc-block p{margin-bottom:1rem;line-height:1.7}
.sg-legal ul{margin:1rem 0 1rem 1.5rem}
.sg-legal li{margin-bottom:.5rem}
.sg-field input.invalid,.sg-field select.invalid{border-color:#DC2626}
.sg-header{transition:box-shadow .3s ease}
.sg-main section:first-of-type{margin-top:0}
@media(min-width:1200px){.sg-header-inner,.sg-featured,.sg-footer-grid{max-width:1200px;margin-left:auto;margin-right:auto}}
@media print{.sg-cookie,.sg-menu-btn,.sg-nav-cta{display:none!important}}
@media(prefers-reduced-motion:reduce){.sg-card,.reveal{transition:none!important;animation:none!important}}
