:root{--color-primary:#050505;--color-surface:#111111;--color-surface-alt:#1a1a1a;--color-accent:#f5c518;--color-text:#f7f7f7;--color-text-light:#c7c7c7;--color-muted:#0b0b0b;--color-white:#ffffff;--color-dark:#000000;--shadow-soft:0 18px 40px rgba(0, 0, 0, 0.45);--hero-image:url('https://evolutionbjj.s3.ca-central-1.amazonaws.com/S3+Photos/Evolution-BJJ-Logo-St-John_webImage16-9.png')}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Lato,system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--color-text);background-color:var(--color-primary);line-height:1.65}a{color:var(--color-accent);text-decoration:none}a:focus,a:hover{text-decoration:underline;color:var(--color-white)}img{display:block;max-width:100%}.container{width:min(1080px,92vw);margin:0 auto}.site-header{position:sticky;top:0;z-index:1000;backdrop-filter:blur(10px);background:rgba(0,0,0,.92);color:var(--color-white);border-bottom:1px solid rgba(245,197,24,.2)}.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:.85rem 0}.brand{display:inline-flex;align-items:center;gap:.75rem;color:inherit;font-weight:600;letter-spacing:.04em}.brand-mark{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:var(--color-accent);color:#111;font-family:Oswald,sans-serif;font-size:1.4rem;text-shadow:none}.brand-text{font-family:Oswald,sans-serif;font-size:1.05rem;text-transform:uppercase}.nav-toggle{background:0 0;border:none;color:inherit;width:46px;height:46px;display:grid;place-items:center;cursor:pointer;border-radius:50%;transition:background .2s ease}.nav-toggle:focus,.nav-toggle:hover{background:rgba(245,197,24,.15)}.nav-toggle-bar,.nav-toggle-bar::after,.nav-toggle-bar::before{display:block;width:20px;height:2px;border-radius:999px;background:currentColor;position:relative;transition:transform .3s ease,opacity .3s ease}.nav-toggle-bar::after,.nav-toggle-bar::before{content:'';position:absolute;left:0}.nav-toggle-bar::before{top:-6px}.nav-toggle-bar::after{top:6px}.nav-toggle[aria-expanded=true] .nav-toggle-bar{background:0 0}.nav-toggle[aria-expanded=true] .nav-toggle-bar::before{transform:translateY(6px) rotate(45deg)}.nav-toggle[aria-expanded=true] .nav-toggle-bar::after{transform:translateY(-6px) rotate(-45deg)}.site-nav{position:absolute;inset:calc(100% + 1px) 0 auto;background:rgba(5,5,5,.96);backdrop-filter:blur(12px);transform-origin:top;transform:scaleY(0);transition:transform .24s ease}.site-nav ul{list-style:none;padding:1rem;margin:0;display:grid;gap:.4rem}.site-nav a{display:block;padding:.55rem .75rem;color:var(--color-white);font-weight:500;border-radius:6px;transition:background .2s ease,color .2s ease}.site-nav a:focus,.site-nav a:hover{background:rgba(245,197,24,.15);color:var(--color-accent);text-decoration:none}.site-nav.is-open{transform:scaleY(1)}@media (min-width:960px){.nav-toggle{display:none}.site-nav{position:static;transform:none!important;background:0 0}.site-nav ul{display:flex;gap:1.5rem;align-items:center}.site-nav a{padding:.25rem 0;border-radius:0;border-bottom:2px solid transparent}.site-nav a:focus,.site-nav a:hover{background:0 0;border-color:rgba(255,255,255,.6)}}.hero{position:relative;color:var(--color-white);padding-block:clamp(4.5rem,12vw,8.5rem);background:linear-gradient(180deg,rgba(0,0,0,.58),rgba(0,0,0,.72)),var(--hero-image) center/cover no-repeat;overflow:hidden}.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(130deg,rgba(0,0,0,.65) 15%,rgba(0,0,0,.25) 55%,rgba(0,0,0,.65) 90%);pointer-events:none}.hero .container{position:relative;z-index:1}.hero-content{position:relative;display:grid;align-content:center;gap:1.2rem;color:var(--color-white);max-width:640px;z-index:1}.hero h1{font-family:Oswald,sans-serif;font-size:clamp(2.6rem, 4.2vw, 3.6rem);letter-spacing:.08em;margin:0}.hero p{max-width:620px;font-size:1.05rem;margin:0}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}.hero-actions--center{justify-content:center}.button{display:inline-flex;align-items:center;justify-content:center;font-weight:600;padding:.65rem 1.5rem;border-radius:999px;border:2px solid transparent;text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.button.primary{background:var(--color-accent);color:#111;box-shadow:var(--shadow-soft)}.button.primary:focus,.button.primary:hover{transform:translateY(-2px)}.button.outline{border-color:rgba(255,255,255,.7);color:var(--color-white)}.button.outline:focus,.button.outline:hover{background:rgba(245,197,24,.15)}.ribbon{background:var(--color-accent);color:#111;padding:.85rem 0;text-align:center;font-weight:600}#hero-email,#hero-email:active,#hero-email:hover,#hero-email:link,#hero-email:visited{color:#000!important;text-decoration:none;font-weight:700}.section{padding:clamp(3.5rem,8vw,5.5rem) 0}.section--alt{background:var(--color-surface-alt)}.section-header{text-align:center;margin-bottom:clamp(2rem,5vw,3.5rem)}.section-header h1,.section-header h2{font-family:Oswald,sans-serif;font-size:clamp(2rem, 3.2vw, 2.6rem);margin:0 0 .6rem;letter-spacing:.04em}.section-header p{margin:0;color:var(--color-text-light);font-size:1.05rem}.cards{display:grid;gap:1.5rem}@media (min-width:860px){.cards{grid-template-columns:repeat(3,1fr)}}.card{background:var(--color-surface);border-radius:18px;padding:2rem;box-shadow:var(--shadow-soft);border:1px solid rgba(245,197,24,.12);display:grid;grid-template-rows:auto auto 1fr auto;gap:1.25rem;height:100%}.card__header{display:grid;gap:.35rem}.card__eyebrow{margin:0;font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700;color:var(--color-accent)}.card h3{font-family:Oswald,sans-serif;font-size:1.5rem;margin:0;color:var(--color-white)}.card__description{margin:0;color:var(--color-text-light);line-height:1.55}.card__highlights{list-style:none;padding:0;margin:0;display:grid;gap:.5rem;color:var(--color-text-light)}.card__highlights li{position:relative;padding-left:1.25rem}.card__highlights li::before{content:'';position:absolute;left:0;top:.45em;width:.55rem;height:.55rem;border-radius:999px;background:var(--color-accent)}.card__footer{margin-top:auto}.card__cta{width:100%}.merch-card{background:var(--color-surface);border-radius:18px;box-shadow:var(--shadow-soft);border:1px solid rgba(245,197,24,.12);overflow:hidden;display:flex;flex-direction:column}.merch-card img{width:100%;height:240px;object-fit:cover}.merch-card-body{padding:1.5rem 1.75rem 1.75rem;display:flex;flex-direction:column;gap:.75rem}.merch-card h3{font-family:Oswald,sans-serif;font-size:1.4rem;color:var(--color-white);margin:0}.merch-card .price{font-size:1.2rem;font-weight:600;color:var(--color-accent);margin:0}.merch-card .price span{margin-left:.35rem;font-size:.9rem;color:var(--color-text-light)}.events{display:grid;gap:1.5rem}@media (min-width:960px){.events{grid-template-columns:repeat(3,minmax(0,1fr))}}.event-card{background:var(--color-surface);border-radius:18px;padding:1.8rem;box-shadow:var(--shadow-soft);border:1px solid rgba(245,197,24,.12);display:grid;gap:.75rem}.event-date{font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent);font-size:.85rem}.event-card h3{font-family:Oswald,sans-serif;margin:0;font-size:1.35rem;color:var(--color-white)}.event-card p{margin:0;color:var(--color-text-light)}.event-card .event-meta{margin:0;font-size:.9rem;color:rgba(255,255,255,.65)}.schedule-week{display:grid;gap:1.25rem}@media (min-width:640px){.schedule-week{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:1024px){.schedule-week{grid-template-columns:repeat(3,minmax(0,1fr))}}.schedule-day{background:var(--color-surface);border-radius:18px;padding:1.6rem 1.4rem 1.8rem;box-shadow:var(--shadow-soft);border:1px solid rgba(245,197,24,.16);display:grid;gap:1.2rem;text-align:center}.schedule-day h3{margin:0;font-size:1.1rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--color-accent)}.schedule-day ul{list-style:none;margin:0;padding:0;display:grid;gap:.85rem}.schedule-class{display:grid;gap:.15rem}.schedule-class time{display:block;font-family:Oswald,sans-serif;font-size:1.05rem;letter-spacing:.04em;color:var(--color-white)}.schedule-class span{display:block;margin-top:.2rem;font-size:.95rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light)}.schedule-class--empty{font-style:italic;color:rgba(255,255,255,.7)}.lead-instructor{display:grid;gap:2rem;align-items:start}@media (min-width:900px){.lead-instructor{grid-template-columns:minmax(0,320px) minmax(0,1fr);align-items:center}}.lead-instructor__media{margin:0}.lead-instructor__photo{width:100%;height:auto;display:block;border-radius:24px;box-shadow:var(--shadow-soft);border:2px solid rgba(245,197,24,.4);background:radial-gradient(circle at 30% 30%,rgba(245,197,24,.35),rgba(17,17,17,.85))}.lead-instructor__content h3{font-family:Oswald,sans-serif;font-size:1.6rem;margin:0 0 .8rem;color:var(--color-white)}.lead-instructor__content p{margin:0;color:var(--color-text-light)}.team-roster{margin-top:3rem;display:grid;gap:1.5rem}.team-roster h3{font-family:Oswald,sans-serif;font-size:1.8rem;margin:0;color:var(--color-white)}.team-groups{display:grid;gap:1.5rem}@media (min-width:780px){.team-groups{grid-template-columns:repeat(3,minmax(0,1fr))}}.team-group{padding:2rem;border-radius:18px;background:linear-gradient(135deg,rgba(245,197,24,.22),rgba(17,17,17,.8));color:var(--color-white);box-shadow:var(--shadow-soft);border:1px solid rgba(245,197,24,.18)}.team-group h4{font-family:Oswald,sans-serif;margin:0 0 .8rem;font-size:1.3rem;color:var(--color-white)}.team-group ul{list-style:none;margin:0;padding:0;display:grid;gap:.4rem}.team-group li{color:var(--color-text-light)}.pricing{display:grid;gap:1.5rem}@media (min-width:900px){.pricing{grid-template-columns:repeat(3,1fr);align-items:stretch}}.pricing-card{background:var(--color-surface);border-radius:18px;padding:2.4rem 2rem;text-align:center;box-shadow:var(--shadow-soft);border:1px solid rgba(245,197,24,.12);display:grid;grid-template-rows:auto auto 1fr auto;gap:1.3rem}.pricing-card__header{display:grid;gap:.5rem}.pricing-card--highlight{background:linear-gradient(145deg,rgba(245,197,24,.25),rgba(17,17,17,.85));border-color:rgba(245,197,24,.35)}.pricing-card h3{font-family:Oswald,sans-serif;font-size:1.5rem;margin:0;color:var(--color-white)}.price{font-size:2.4rem;font-weight:700;margin:0;color:var(--color-white)}.price span{font-size:.8rem;margin-left:.25rem;color:var(--color-text-light)}.pricing-card__description{margin:0;color:var(--color-text-light);line-height:1.55}.pricing-card__features{list-style:none;padding:0;margin:0;display:grid;gap:.5rem;color:var(--color-text-light)}.pricing-card__features li{position:relative;padding-left:1.25rem}.pricing-card__features li::before{content:'';position:absolute;left:0;top:.45em;width:.55rem;height:.55rem;border-radius:999px;background:var(--color-accent)}.pricing-card__footer{margin-top:auto}.pricing-card__cta{width:100%}.testimonials{background:radial-gradient(circle at top left,rgba(245,197,24,.18),rgba(0,0,0,.9));color:var(--color-white);padding:clamp(3.5rem,8vw,5rem) 0}.testimonials .container{display:grid;gap:2rem}.testimonials h2{font-family:Oswald,sans-serif;font-size:clamp(2rem, 3vw, 2.6rem);margin:0}.quote{background:rgba(17,17,17,.85);border-radius:18px;padding:1.75rem;box-shadow:var(--shadow-soft);position:relative;border:1px solid rgba(245,197,24,.16)}.quote::before{content:'\201C';position:absolute;inset:0.75rem auto auto 1.1rem;font-family:Georgia,'Times New Roman',serif;font-size:3rem;line-height:1;color:rgba(245,197,24,.35)}.quote p{margin:0 0 1rem;font-size:1.1rem;color:var(--color-white)}.quote cite{font-style:normal;font-weight:600;color:var(--color-text-light)}.contact{display:grid;gap:2.5rem}@media (min-width:960px){.contact{grid-template-columns:1.1fr 1fr;align-items:start}}.contact-list{list-style:none;margin:1.5rem 0 0;padding:0;color:var(--color-text-light);display:grid;gap:.6rem}.contact-form{background:var(--color-surface);border-radius:18px;padding:2rem;box-shadow:var(--shadow-soft);border:1px solid rgba(245,197,24,.12);display:grid;gap:1.1rem}.form-row{display:grid;gap:.35rem}label{font-weight:600;color:var(--color-white)}input,select,textarea{font:inherit;padding:.65rem .75rem;border-radius:10px;border:1px solid rgba(245,197,24,.18);background:var(--color-surface-alt);color:var(--color-white);transition:border-color .2s ease,box-shadow .2s ease}input::placeholder,textarea::placeholder{color:rgba(255,255,255,.6)}input:focus,select:focus,textarea:focus{outline:0;border-color:var(--color-accent);box-shadow:0 0 0 4px rgba(245,197,24,.18)}textarea{resize:vertical}.form-note{margin:0;font-size:.85rem;color:var(--color-text-light)}.map iframe{width:100%;height:360px;border:0;display:block;filter:grayscale(10%);border-radius:0}.site-footer{background:var(--color-dark);color:rgba(255,255,255,.8);padding:2rem 0}.site-footer .container{display:flex;flex-direction:column;gap:1rem;align-items:center;text-align:center}.site-footer ul{list-style:none;display:flex;gap:1.4rem;padding:0;margin:0}.site-footer a{color:inherit}.site-footer a:focus,.site-footer a:hover{color:var(--color-accent)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width:600px){.hero{padding-block:clamp(3.5rem,14vw,6rem)}.schedule-heading,.schedule-row{grid-template-columns:1fr;text-align:center}.schedule-heading{display:none}.schedule-row span:first-child{font-size:1.1rem;margin-bottom:.4rem}.map iframe{height:280px}.site-footer ul{flex-wrap:wrap}}.will-animate{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.is-visible{opacity:1;transform:translateY(0)}body.nav-open{overflow:hidden}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:48px;height:48px;background-color:var(--color-accent);color:var(--color-dark);border:none;border-radius:50%;font-size:24px;font-weight:700;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(20px);transition:opacity .3s ease,visibility .3s ease,transform .3s ease,background-color .2s ease;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:1000;display:flex;align-items:center;justify-content:center}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:focus,.back-to-top:hover{background-color:var(--color-white);transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,.4)}.back-to-top:active{transform:translateY(0)}@media (max-width:768px){.back-to-top{width:56px;height:56px;bottom:1.5rem;right:1.5rem;font-size:28px}}.form-status{margin-top:1rem;padding:1rem;border-radius:6px;font-size:.95rem;line-height:1.5}.form-status--success{background-color:rgba(34,197,94,.1);color:#22c55e;border:1px solid rgba(34,197,94,.3)}.form-status--error{background-color:rgba(239,68,68,.1);color:#ef4444;border:1px solid rgba(239,68,68,.3)}#submit-btn:disabled{opacity:.6;cursor:not-allowed}