@charset "UTF-8";
/* Bulma Utilities */
#mhwudk { /* Section */ padding: 0; margin: 0; }

#jnaify { /* Simple Element */ }

#jnaify .navbar-item.vz-nav-link, #jnaify a.navbar-item { color: var(--soft); font-weight: 600; font-size: .95rem; }

#jnaify .navbar-item.vz-nav-link:hover, #jnaify a.navbar-item:hover { color: var(--charcoal); background: transparent; }

#vaarjg { /* Element */ /* ---- BAR: ivory background, taller height ---- */ background-color: var(--greige, #F4EEDF); border-bottom: 1px solid var(--line, rgba(47, 46, 41, 0.16)); /* taller bar — tune 5–6.5rem to taste */ /* ---- LOGO: override Bulma's 1.75rem image cap ---- */ /* ---- NAV LINKS: colour + grey→dark hover (Bulma only hovers background by default) ---- */ /* ---- BOOK A CLASS button ---- */ }

#vaarjg.navbar { min-height: 5.5rem; }

#vaarjg .navbar-brand, #vaarjg .navbar-menu { align-items: center; }

#vaarjg .navbar-menu .navbar-item { padding-top: 1rem; padding-bottom: 1rem; }

#vaarjg .navbar-brand .navbar-item { padding-top: 0; padding-bottom: 0; }

#vaarjg .navbar-brand .navbar-item img { max-height: none; height: 64px; width: auto; }

#vaarjg .navbar-item { color: var(--soft, rgba(47, 46, 41, 0.62)); font-weight: 600; font-size: .95rem; transition: color .15s; }

#vaarjg .navbar-item:hover, #vaarjg .navbar-item:focus { color: var(--charcoal, #2F2E29); background: transparent; }

#vaarjg .navbar-item.is-active { color: var(--charcoal, #2F2E29); background: transparent; }

#vaarjg .navbar-item .button { background: var(--olive, #687050); color: var(--on-dark, #E9E6DC); border: none; font-weight: 700; padding-left: 1.4em; padding-right: 1.4em; }

#vaarjg .navbar-item .button:hover { background: var(--olive-deep, #4A5138); }

#byypqg { /* Section */ background: var(--olive-deep); color: var(--on-dark-soft); padding: 3.5rem 1.5rem 1.8rem; }

#byypqg h4 { font-family: var(--font-display); color: var(--on-dark); font-size: 1rem; margin: 0 0 .8rem; letter-spacing: .04em; }

#byypqg a { color: var(--on-dark-soft); text-decoration: none; display: block; padding: .22rem 0; font-size: .92rem; }

#byypqg a:hover { color: var(--on-dark); }

#byypqg p { font-size: .92rem; max-width: 23rem; }

#byypqg .foot-bottom { border-top: 1px solid rgba(233, 230, 220, 0.18); margin-top: 2.6rem; padding-top: 1.3rem; font-size: .8rem; display: flex; flex-wrap: wrap; justify-content: space-between; gap: .5rem; }

#byypqg .socials a { display: inline-flex; margin-right: 1rem; font-size: 1.05rem; }

#hfksmi { /* Section */ background: var(--greige); }

#hfksmi .hero-body { padding: 4.5rem 1.5rem 4rem; }

#hfksmi h1 { font-size: clamp(2.5rem, 5.4vw, 4rem); margin: 1.1rem 0 0; }

#hfksmi h1 em { font-style: normal; color: var(--olive); }

#hfksmi .lede { font-size: 1.12rem; color: var(--soft); max-width: 30rem; margin: 1.3rem 0 1.9rem; }

#hfksmi .vz-cta-row { display: flex; flex-wrap: wrap; gap: .8rem; }

#hfksmi .vz-meta { margin-top: 2rem; font-size: .95rem; color: var(--soft); }

#hfksmi .vz-meta span { display: inline-flex; align-items: center; gap: .6em; }

#hfksmi .vz-meta i { color: var(--olive); width: 1.1em; text-align: center; }

#hfksmi .vz-photo { aspect-ratio: 4/5; }

#hfksmi .reveal { opacity: 0; transform: translateY(14px); animation: vz-rise .7s ease forwards; }

#hfksmi .d1 { animation-delay: .05s; }

#hfksmi .d2 { animation-delay: .15s; }

#hfksmi .d3 { animation-delay: .25s; }

#hfksmi .d4 { animation-delay: .35s; }

#dtcfpn { /* Element */ }

#dtcfpn .vz-photo { position: relative; overflow: hidden; border-radius: 6px; aspect-ratio: 4/5; }

#dtcfpn .vz-photo img { display: block; width: 100%; height: 100%; object-fit: cover; filter: saturate(0.72) sepia(0.14) brightness(0.94) contrast(1.03); transition: filter .55s ease; }

#dtcfpn .vz-photo::after { content: ""; position: absolute; inset: 0; background: var(--olive-deep); mix-blend-mode: multiply; opacity: .58; transition: opacity .55s ease; pointer-events: none; }

@media (hover: hover) { #dtcfpn .vz-photo:hover img { filter: none; } #dtcfpn .vz-photo:hover::after { opacity: 0; } }

#hxskzw { /* Section */ padding: 5.5rem 1.5rem; background: var(--paper); border-top: 1px solid var(--line); }

#hxskzw .vz-photo { aspect-ratio: 4/5; position: relative; overflow: hidden; border-radius: 6px; }

#hxskzw .vz-photo img { display: block; width: 100%; height: 100%; object-fit: cover; filter: saturate(0.72) sepia(0.14) brightness(0.94) contrast(1.03); transition: filter .55s ease; }

#hxskzw .vz-photo::after { content: ""; position: absolute; inset: 0; background: var(--olive-deep); mix-blend-mode: multiply; opacity: .58; transition: opacity .55s ease; pointer-events: none; }

@media (hover: hover) { #hxskzw .vz-photo:hover img { filter: none; } #hxskzw .vz-photo:hover::after { opacity: 0; } }

#hxskzw h2 { font-size: clamp(1.9rem, 3.4vw, 2.7rem); margin: .8rem 0 0; }

#hxskzw .body p { margin: 1.05rem 0; color: var(--soft); font-size: 1.04rem; }

#hxskzw .body p:first-child { color: var(--charcoal); font-size: 1.15rem; }

#hxskzw .sign { font-family: var(--font-display); font-size: 1.5rem; color: var(--olive); margin-top: .6rem; }

#hxskzw .qual { margin-top: 1.4rem; padding-top: 1.2rem; border-top: 1px solid var(--line); font-size: .9rem; color: var(--soft); display: flex; flex-wrap: wrap; gap: 1.4rem; }

#hxskzw .qual span { display: inline-flex; align-items: center; gap: .5em; }

#hxskzw .qual i { color: var(--olive); }

#mvjvzd { /* Element */ }

#mvjvzd .qual { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }

#mvjvzd .qual p, #mvjvzd .qual span { margin: 0; display: inline-flex; align-items: center; gap: .5em; }

#mvjvzd .qual img { vertical-align: middle; flex: 0 0 auto; }

#pbcdrp { /* Section */ padding: 5.5rem 1.5rem; background: var(--olive-deep); color: var(--on-dark); }

#pbcdrp h2 { font-size: clamp(1.9rem, 3.6vw, 2.8rem); margin: .9rem 0 1.6rem; color: var(--on-dark); }

#pbcdrp p { color: var(--on-dark-soft); font-size: 1.1rem; margin: 1.1rem 0; }

#pbcdrp p strong { color: var(--on-dark); font-weight: 600; }

#pbcdrp .pull { font-family: var(--font-display); font-size: clamp(1.25rem, 2.2vw, 1.6rem); color: var(--on-dark); border-left: 2px solid rgba(233, 230, 220, 0.4); padding-left: 1.2rem; margin: 1.8rem 0; line-height: 1.4; }

#vqxqht { /* Element */ }

#vqxqht .ntx-gallery-item .card-image figure.image { aspect-ratio: 4/5; overflow: hidden; position: relative; margin: 0; border-radius: 6px; }

#vqxqht .ntx-gallery-item .card-image figure.image img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.72) sepia(0.14) brightness(0.94) contrast(1.03); transition: filter .55s ease; }

#vqxqht .ntx-gallery-item .card-image figure.image::after { content: ""; position: absolute; inset: 0; background: var(--olive-deep); mix-blend-mode: multiply; opacity: .58; transition: opacity .55s ease; pointer-events: none; }

@media (hover: hover) { #vqxqht .ntx-gallery-item .card-image figure.image:hover img { filter: none; } #vqxqht .ntx-gallery-item .card-image figure.image:hover::after { opacity: 0; } }

#haydst { /* Section */ padding: 5.5rem 1.5rem; background: var(--paper); border-top: 1px solid var(--line); }

#haydst .head { max-width: 38rem; margin-bottom: 2.6rem; }

#haydst h2 { font-size: clamp(1.9rem, 3.6vw, 2.8rem); margin: .8rem 0 .7rem; }

#haydst .head p { color: var(--soft); }

#haydst .tt-card { border: 1px solid var(--line); border-radius: 6px; padding: 1.5rem 1.4rem; height: 100%; }

#haydst .tt-card .day { font-family: var(--font-display); font-size: 1.35rem; }

#haydst .tt-card .sessions { margin: .7rem 0 .8rem; display: flex; flex-direction: column; gap: .25rem; }

#haydst .tt-time { font-weight: 700; font-size: 1rem; color: var(--charcoal); }

#haydst .tt-card .venue { display: flex; align-items: flex-start; gap: .5em; color: var(--soft); font-size: .93rem; }

#haydst .tt-card .venue i { color: var(--olive); margin-top: .25em; }

#haydst .tt-level { display: inline-block; margin-top: .95rem; font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: .35em 0; border-top: 2px solid var(--olive); color: var(--olive); }

#haydst .tt-level.adv { border-color: var(--charcoal); color: var(--charcoal); }

#haydst .tt-footnote { margin-top: 2.2rem; color: var(--soft); font-size: .95rem; }

#haydst .tt-footnote strong { color: var(--charcoal); }

#haydst .venues-legend { margin-top: 1.2rem; display: flex; flex-wrap: wrap; gap: .8rem 2rem; font-size: .85rem; color: var(--soft); }

#haydst .venues-legend span { display: inline-flex; gap: .5em; }

#haydst .venues-legend i { color: var(--olive); margin-top: .25em; }

#zwrtpi { /* Row */ }

#zwrtpi .column { display: flex; }

#zwrtpi .column > .element { display: flex; width: 100%; }

#zwrtpi .tt-card { flex: 1; }

#ohzdis { /* Section */ padding: 5.5rem 1.5rem; background: var(--greige-2); }

#ohzdis .head { max-width: 38rem; margin-bottom: 2.6rem; }

#ohzdis h2 { font-size: clamp(1.9rem, 3.6vw, 2.8rem); margin: .8rem 0 .7rem; }

#ohzdis .head p { color: var(--soft); }

#ohzdis .fee-card { background: var(--paper); border: 1px solid var(--line); border-radius: 6px; padding: 2rem 1.7rem; height: 100%; }

#ohzdis .fee-card.noted { border-color: var(--olive); border-width: 1.5px; }

#ohzdis .fee-card .nm { font-weight: 700; font-size: .8rem; letter-spacing: .16em; text-transform: uppercase; color: var(--soft); }

#ohzdis .fee-card .price { font-family: var(--font-display); font-size: 2.7rem; line-height: 1.1; margin: .5rem 0 .1rem; }

#ohzdis .fee-card .per { font-size: .92rem; color: var(--olive); font-weight: 600; }

#ohzdis .fee-card p { margin: .9rem 0 0; font-size: .95rem; color: var(--soft); }

#ohzdis .fine { margin-top: 1.8rem; color: var(--soft); font-size: .9rem; }

#ohzdis .fine i { color: var(--olive); }

#bthreg { /* Row */ }

#bthreg .column { display: flex; }

#bthreg .column > .element { display: flex; width: 100%; }

#bthreg .tt-card { flex: 1; }

#yzpnxj { /* Section */ padding: 5.5rem 1.5rem; background: var(--paper); border-top: 1px solid var(--line); }

#yzpnxj .head { display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 2.4rem; }

#yzpnxj h2 { font-size: clamp(1.9rem, 3.4vw, 2.7rem); margin: .7rem 0 0; }

#yzpnxj .head .link { color: var(--olive); font-weight: 700; text-decoration: none; border-bottom: 1.5px solid transparent; }

#yzpnxj .head .link:hover { border-bottom-color: var(--olive); }

#yzpnxj .rev-card { border-left: 2px solid var(--olive); padding: 0 0 0 1.4rem; height: 100%; }

#yzpnxj .rev-card p { font-family: var(--font-display); font-size: 1.12rem; line-height: 1.5; margin: 0 0 1rem; }

#yzpnxj .rev-card .who { font-size: .9rem; color: var(--soft); }

#yzpnxj .rev-card .who strong { color: var(--charcoal); }

#efiyzw { /* Section */ padding: 5.5rem 1.5rem; background: var(--greige); }

#efiyzw h2 { font-size: clamp(1.9rem, 3.4vw, 2.7rem); margin: .8rem 0 1.5rem; }

#efiyzw .howto-step { display: flex; gap: 1.1rem; padding: 1.05rem 0; border-top: 1px solid var(--line); }

#efiyzw .howto-step:last-of-type { border-bottom: 1px solid var(--line); }

#efiyzw .howto-step .n { flex: 0 0 auto; font-family: var(--font-display); font-size: 1.3rem; color: var(--olive); width: 1.6rem; }

#efiyzw .howto-step h3 { font-weight: 700; font-size: 1.05rem; margin: 0 0 .25rem; font-family: var(--font-body); }

#efiyzw .howto-step p { margin: 0; color: var(--soft); font-size: .97rem; }

#efiyzw .cancel-card { background: var(--olive-deep); color: var(--on-dark); border-radius: 6px; padding: 2rem 1.8rem; height: 100%; }

#efiyzw .cancel-card h3 { font-family: var(--font-display); font-size: 1.4rem; margin: 0 0 .8rem; color: var(--on-dark); }

#efiyzw .cancel-card p { color: var(--on-dark-soft); font-size: .97rem; margin: 0; }

#irtjjt { /* Row */ }

#irtjjt .column { display: flex; }

#irtjjt .column > .element { display: flex; flex-direction: column; width: 100%; }

#irtjjt .cancel-card { flex: 1; }

#aoczmf { /* Section */ padding: 5.5rem 1.5rem; background: var(--paper); border-top: 1px solid var(--line); /* form styling (targets the Form element's generated markup) */ }

#aoczmf h2 { font-size: clamp(2rem, 3.8vw, 2.9rem); margin: .9rem 0 .7rem; }

#aoczmf .lede { color: var(--soft); font-size: 1.05rem; max-width: 28rem; }

#aoczmf .contact-routes { margin-top: 1.8rem; display: flex; flex-direction: column; gap: .7rem; }

#aoczmf .route { display: flex; align-items: center; gap: 1rem; padding: .95rem 1.1rem; border-radius: 6px; border: 1px solid var(--line); text-decoration: none; color: var(--charcoal); transition: border-color .18s; }

#aoczmf .route:hover { border-color: var(--olive); }

#aoczmf .route .ico { width: 40px; height: 40px; border-radius: 6px; background: var(--olive); color: var(--on-dark); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex: 0 0 auto; }

#aoczmf .route .lbl { font-size: .78rem; color: var(--soft); }

#aoczmf .route .val { font-weight: 700; font-size: 1rem; }

#aoczmf .form-card { background: var(--greige); border: 1px solid var(--line); border-radius: 6px; padding: 2rem 1.8rem; }

#aoczmf .form-card h3 { font-family: var(--font-display); font-size: 1.35rem; margin: 0 0 .3rem; }

#aoczmf .form-card .sub { color: var(--soft); font-size: .92rem; margin-bottom: 1.2rem; }

#aoczmf .form-card label { display: block; font-weight: 700; font-size: .84rem; margin: .9rem 0 .3rem; }

#aoczmf .form-card input, #aoczmf .form-card textarea { width: 100%; padding: .75em .95em; border-radius: 4px; border: 1px solid var(--line); font-family: var(--font-body); font-size: 1rem; background: var(--paper); color: var(--charcoal); }

#aoczmf .form-card input:focus, #aoczmf .form-card textarea:focus { outline: none; border-color: var(--olive); }

#aoczmf .form-card .vz-btn { width: 100%; justify-content: center; margin-top: 1.2rem; }

#xmgoza { /* Section */ padding: 4.5rem 1.5rem; background: var(--greige); text-align: center; /* TRUE COLOUR — no olive grade on IG tiles */ }

#xmgoza h2 { font-family: var(--font-display); font-size: clamp(1.7rem, 2.8vw, 2.3rem); margin: .7rem 0 .2rem; }

#xmgoza .handle { color: var(--olive); font-weight: 700; text-decoration: none; }

#xmgoza .handle:hover { text-decoration: underline; }

#xmgoza .insta-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: .6rem; margin-top: 1.8rem; }

#xmgoza .insta-grid .vz-photo { aspect-ratio: 1/1; border-radius: 4px; position: relative; overflow: hidden; }

#xmgoza .insta-grid .vz-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

#xmgoza .insta-grid .vz-photo .ig { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: var(--on-dark); opacity: 0; background: rgba(74, 81, 56, 0.55); transition: opacity .2s; font-size: 1.3rem; }

#xmgoza .insta-grid .vz-photo:hover .ig { opacity: 1; }

@media (max-width: 768px) { #xmgoza .insta-grid { grid-template-columns: repeat(3, 1fr); } }

#hfcorg { /* Simple Element */ }

#hfcorg .ig-head { text-align: center; }

#hfcorg .ig-head .handle { color: var(--olive, #687050); font-weight: 700; text-decoration: none; }

#hfcorg .ig-head .handle:hover { text-decoration: underline; }

#hfcorg .insta-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: .6rem; margin-top: 1.8rem; }

#hfcorg .insta-grid .vz-photo { position: relative; aspect-ratio: 1/1; border-radius: 4px; overflow: hidden; display: block; }

#hfcorg .insta-grid .vz-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }

#hfcorg .insta-grid .ig-link { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: var(--on-dark, #E9E6DC); background: rgba(74, 81, 56, 0.55); opacity: 0; transition: opacity .2s; font-size: 1.3rem; text-decoration: none; }

#hfcorg .insta-grid .vz-photo:hover .ig-link { opacity: 1; }

@media (max-width: 768px) { #hfcorg .insta-grid { grid-template-columns: repeat(3, 1fr); } }

/*# sourceMappingURL=page.css.map */