@charset "UTF-8";
@font-face {font-display:swap;unicode-range:U+000-5FF;font-family:'heading';font-style:normal;src:url('/fonts/poppinsBold.woff2') format('woff2')}
@font-face {font-display:swap;unicode-range:U+000-5FF;font-family:'text';font-style:normal;src:url('/fonts/poppins.woff2') format('woff2')}
@font-face {font-display:swap;unicode-range:U+000-5FF;font-family:'bold';font-style:normal;src:url('/fonts/poppinsMedium.woff2') format('woff2')}
@font-face {font-display:swap;unicode-range:U+000-5FF;font-family:'pf';font-style:normal;src:url('/fonts/PianoFactor.woff2') format('woff2')}
:root {--h2:#dcd5d0;--pink:#ca1660;--purp:#723068;--blue:#0a6eb4;--back:rgb(54, 48, 57);--backHov:rgb(70, 62, 71);--black:#28242a;--white:rgb(250,249,249);--green:#28a745;--shadow:-3px 3px 10px rgba(40,36,42,0.3)}
html,body {max-width:100%;margin:0;padding:0;background:var(--black)}
html { overflow-y: auto; overflow-x: hidden; }
html.nav-locked { overflow: hidden; }
body { overflow: visible;overscroll-behavior-x: none;}
main {
  overflow-x: clip;
}
main, #mainContainer {background:var(--white)!important}
.carousel-3way,
.carousel-3way_v2,
#reviewCarousel,
.pf-reviews,
.carousel-3way__viewport,
.carousel-3way_v2__viewport,
.pf-reviews__viewport {
  overflow-x: hidden;
}
html {font-size:clamp(15px,calc(1vw + 10px),17px);}
*,*::before,*::after {box-sizing:border-box;}
html,body {-webkit-text-stroke:0!important;-webkit-text-shadow:0 0 0 rgba(0,0,0,0)!important;text-shadow:0 0 0 rgba(0,0,0,0)!important;-webkit-font-smoothing:subpixel-antialiased!important;font-family:'text';line-height:1.6;color:var(--back);letter-spacing:0;}

/* =========================================================
   HEADINGS / TYPOGRAPHY
   ========================================================= */

/* Shared horizontal padding */
h1,
h2,
h3,
h4,
.h3,
.heroSub,
.goldSub {
  padding: 0 20px;
}

/* Default light-on-dark heading colour */
h1,
h2,
h3,
h4,
.dark h2, .dark h3, .dark, .dark span,
.h3,
.heroSub {
  color: var(--white);
}

/* Dark text sections */
.light,
.light h2,
.light h3,
.light p, .lightContainer p,
.lightContainer h2,
.lightContainer h3,
.events-grid h3,
.contact-lite h3,
.clientGroup h3 {
  color: var(--back);
}

/* Heading font family */
h1,
h2,
h3,
h5,
h6,
.column ul,
.column li,
.heading,
.cta-title {
  font-family: 'heading';
  font-weight: normal;
}

/* Shared centred heading treatment */
h1,
h2,
h3,
h4,
.h3,
.noHero h2,
.heroSub {
  text-align: center;
  margin-inline: auto;
  text-wrap: balance;
  letter-spacing: -0.02em;
  line-height: 1.2
}
p.heroSub, .noHero h2 {margin-top:16px!important}
/* Main heading widths */
h1,
h2,
h3,
h4,
.h3 {
  max-width: 24ch;margin-inline: auto;
}

/* Hero / no-hero subheading widths */
.noHero h2,
.heroSub,
.goldSub {
  max-width: 48ch;
  margin: 0 auto 1.6rem;
}

/* Main title sizing */
h1,
.cta-title {
  font-size: clamp(2.2rem, 6vw, 4.2rem);
  line-height: .98;
  margin: 0 auto;
}
h2,
.cta-title {
  font-size: clamp(2.4rem, 6vw, 3rem);
  line-height: 1.15;
  margin: 0 auto 1.6rem;
}

/* Secondary intro / hero subheads */
.noHero h2,
.heroSub {
  color: var(--h2);
  font-family: 'text';
  font-size: clamp(1.4rem, 4vw, 1.8rem);
}

/* Gold subheading */
.goldSub {
  text-align: center;
  color: var(--h2) !important;
  font-family: 'text';
  font-size: clamp(1.1rem, 4vw, 1.4rem);
}
.light .goldSub {
  text-align: center;
  color: var(--back) !important;
  font-family: 'bold';opacity:0.8;
  font-size: clamp(1.1rem, 4vw, 1.4rem);
}

/* Smaller heading styles */
h3,
h4,
.h3 {
  font-size: 1.35rem;
  line-height: 1.3;
  margin: 2.2rem auto 0.4rem;
  letter-spacing: 0.01em;
}

/* h4 override */
h4 {
  font-family: 'bold';
  font-weight: normal;
}

/* Specific local override */
.aboutGrid h3, .events-grid h3 {
  padding: 0;text-align:left
}
.space {height:80px}
.underline {text-decoration:underline;text-decoration-thickness: 1px;text-decoration-color: rgba(255,255,255,0.6)}
.underline:hover {color:white;text-decoration-color: white}
.centerBlock {display:block;margin:auto;max-width:100%;width:100%;text-align:center}
.linkActs {display:block;padding:20px;width:100%}
.h3 {color:var(--h2)}
.sectionLabel {display:block;color:var(--h2);margin-bottom:20px;font-size:1.6em;opacity:0.5}
.stave {background:repeating-linear-gradient( to bottom,transparent 0,transparent calc(100%/5 - 2px),color-mix(in srgb,var(--white) 50%,transparent) calc(100%/5 - 2px),color-mix(in srgb,var(--white) 50%,transparent) calc(100%/5) );}

li {font-size:1rem;line-height:1.7;margin-bottom:0.6em;}
p {margin-bottom:1.6rem;font-size:1rem;line-height:1.65;margin:0 auto 0.9em;max-width:800px}
.lead {font-family:'text';font-size:clamp(1.1rem,1.5vw,1.3rem);line-height:1.55;letter-spacing:0;margin-bottom:1.4em}
.small,.about-box li {font-family:'text';font-size:clamp(0.85rem,1vw,0.9rem);line-height:1.45}
button,.btn {font-family:'bold';font-size:clamp(1rem,1.3vw,1.1rem);letter-spacing:-0.2px;line-height:1}
nav a {font-family:'text';font-size:clamp(0.95rem,1.1vw,1rem);letter-spacing:0.1px}
body {-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
b,strong,.bold {font-family:'heading';font-weight:normal}
a {text-decoration:none;color:var(--blue)}
.intro-text-div a, .intro-text-div {color:var(--white)}
.outro-text-div a, .outro-text-div {color:var(--white);max-width:48ch}
 iframe {max-width:100%} 
.text,#footer ul li,#nav ul li {font-family:'text';color:var(--black);letter-spacing:-0.02rem}
li {list-style:none}
ul {margin:0;padding:0}
.center {margin:auto;text-align:center;justify-self:center;}
section {display:block;margin:0}
p.intro-lead  {max-width:70ch}
.inlinePad {padding:4rem}
.gold {color:var(--h2)!important}
.caps {text-transform: uppercase;letter-spacing:2px}

.capitalize {text-transform: capitalize}
.schemaFlag {position:fixed;bottom:0;left:0;width:50vw;height:80px;background:green;color:white;display:none;z-index:9999999}
.heroCtaContainer,
.duoCtaContainer,
.soloCtaContainer
 {padding:0;max-width:calc(100vw - 40px);margin:auto;margin-top:40px;box-sizing: content-box}
.heroCtaContainer h2,   .heroCtaContainer p, 
.duoCtaContainer h2,    .duoCtaContainer p, 
.soloCtaContainer h2,   .soloCtaContainer p 
{margin:0 auto;padding:0}

.ctaGrid,
.heroCtaGrid,
.soloCtaGrid,
.duoCtaGrid  {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px; /* adjust spacing here */
  margin: 20px auto;max-width:800px;}
.soloCtaGrid {display:block;padding-bottom:40px}


.ctaGrid a,
.heroCtaGrid a,
.soloCtaGrid a,
.duoCtaGrid a
 {
  display: block;
  text-align: center;	
}

/* Mobile: stack */
@media (max-width: 740px) {
  .ctaGrid, .heroCtaGrid, .duoCtaGrid {
  grid-template-columns: 1fr;
  }
  .duoCtaContainer,
  .heroCtaContainer,
  .soloCtaContainer {max-width:calc (100vw - 40px);padding:20px}
  .ctaGreen2 {width:100%}
}

.ctaGreen2 {filter:brightness(1);color:var(--white);display:inline-block;gap:12px;padding:12px 22px;font-size:1rem;font-family:'text';letter-spacing:0.5px;border-radius:5px;box-shadow:var(--shadow);transition:all 0.3s ease;opacity:1;background:var(--green);text-align:center;transition:transform(translate) 0.25s ease;outline:2px solid var(--green);margin-top:8px}
.ctaGreen2:hover {filter:brightness(1.1);box-shadow:-10px 10px 20px rgba(0, 0, 0, 0.3);transform:translateY(-2px)}
.ctaGreenVariant {outline:2px solid var(--green);background:rgba(255,255,255,0.9);color:var(--green)}
.ctaLeft {margin-left:0!important;text-align:left;padding-left:0}
/* ===============================
     NAVIGATION NAV
================================ */

nav {position:absolute;top:0px;z-index:9999}
#mainNav {display:block}
#menuToggle {position:relative;cursor: pointer}
#navContainer {position:fixed;width:100vw;display:block;height:80px;display:inline-block;opacity:1;transition:opacity 0.3s ease}
#navContainer.nav-visible {opacity:1}
#navFadeIn {position:absolute;top:0;width:100vw;height:80px;background:rgb(54, 48, 57);opacity:0;z-index:-1;box-shadow:0 0 40px rgba(0,0,0,0.7);transition:opacity 0.5s ease}
#navFadeIn.nav-visible {opacity:1;transition:opacity 0.5s ease}
#navMenu .column {display:flex;flex-direction:column;margin:0}
#navMenu .column ul {list-style:none}
#navMenu .column ul li {margin-bottom:2px;}
#navMenu .column ul li a {background:var(--back);display:block;padding:10px 16px;color:var(--white);border-radius:5px;font-size:0.9rem}
#navMenu .column ul li a:hover {transition:all 0.3s ease;background:var(--blue)}
#navMenu .columns {max-width:1640px;margin:auto;width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;padding:16px}
#navMenu .nav-section-title {color:var(--white);padding:0;font-size:1.2rem;margin:20px 16px 10px 16px;font-family:'bold'}
#navMenu {padding-bottom:0px;position:fixed;top:-120vh;z-index:0;padding-top:80px;transition:top 0.3s ease;background:var(--black);width:100vw;max-width:100vw;overflow:hidden}
#navMenu {overflow-y:auto;max-height:100dvh;-webkit-overflow-scrolling:touch}
#navMenu h2.nav-section-title {text-align:left;width:100%;max-width:100%}
#navOverlay {position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,0.2);opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:2;display:block}
#navOverlay.visible {opacity:1;pointer-events:all}
.avail-cont, .book-cont, .heading {font-family:'heading'}
.logo-size {width:100%;max-width:300px;height:auto;margin:auto;margin-bottom:-20px}
.logo-size img {width:100%}
.logoText {font-size:40px;font-family:'pf'}
.logoTextFoot {font-size:40px;font-family:'pf'}
.menu-cont {background:var(--back)}
.menu-cont {border:1px solid rgba(255,255,255,0.3);border-radius:4px;background:none}
.menuContainer {height:100%;width:calc(100%);display:inline-block;padding-top:5px}
.menuFoot {line-height:2;width:100%;display:block;color:var(--black);padding:50px 0 0 0}
.nav-icon-toggle {text-align:center}
.navLogo {display:inline-flex;align-items:center;gap:5px;height:60px;line-height:1;white-space:nowrap;margin:10px 0 0 5px;}
.navLogo__icon {display:block;height:100%;width:auto;max-height:40px;}
.navLogo__text {font-family:'pf';color:var(--white);font-size:3rem;font-weight:normal;line-height:1;display:inline-block;padding-bottom:8px;}
.opacity1 {opacity:1!important}
.quickLinks {border-radius:3px;height:70px;width:160px;z-index:3;padding-top:12px;display:inline-block;float:right;margin-right:5px;z-index:9999999;color:rgba(255,255,255,0.75);line-height:1.2;font-size:0.8rem;border:1px solid rgba(255,255,255,0.35);font-family:'text'}
.quickLinkChangeOn {background-color:var(--green);border-color:transparent;transition:background-color 0.25s ease}
.purple {background:var(--purp)}
.quickLinks span {color:var(--white)}
.quickLinks span.nav-icon-toggle {color:rgba(255,255,255,0.75)}
.quickLinks.menu-cont {padding-top:0}
.quickLinks:hover {background:var(--blue);transition:all 0.5s ease;}
.quickLinks:hover #cross::after,.quickLinks:hover #cross::before {background:var(--white)}
.quo {font-size:1.4rem;text-transform: uppercase}
.switchMenu {position:fixed;left:0;z-index:1;box-shadow:0 100px 50px rgba(0,0,0,0.5);top:0!important}
a.logoContainer {max-height:80px;position:fixed;top:0;bottom:0;left:0;right:calc(100% - 406px);z-index:1!important;max-width:10px}
a.logoContainer span.brand-decorative {margin-top:0}
a.logoContainer span.brand-decorative {position:absolute;left:20px;top:20px;}
a.logoContainer span.brand-decorative::before {position:absolute;top:0;right:0;bottom:0;left:0}
.soc-icon-svg {width:50px;height:50px;fill:var(--white);display:block;transition:transform .2s ease, opacity .2s ease;}
.soc-icon:hover .soc-icon-svg {transform:scale(1.1);opacity:.85;}
.nav-section-title p, a.whiteLink { 
font-size:1.2rem;font-weight:100;
letter-spacing:.2px;
color:var(--white)}

/* ===============================
     INLINE VIMEO VIDEO
================================ */
.vimeo-bg{position:relative;overflow: hidden;z-index: 1;width: 100vw;height: 56.25vw; aspect-ratio: 16 / 9;background-size:cover;background-repeat:no-repeat;background-position:  center;}
.vimeo-bg iframe{position: relative;width:100%;height:100%;pointer-events:none;}
.vimeo-overlay{position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;background:linear-gradient( to bottom,rgba(40,38,42,0.4),rgba(40,38,42,0.7) );cursor:pointer;transition:background 0.4s ease;}
.vimeo-bg:after{content:'';display:block;position:absolute;left:0;right:0;top:0;bottom:0;background-image:radial-gradient(rgba(0,0,0,0.1) 33%,transparent 33%);background-size:3px 3px;}
.vimeo-overlay.is-transparent{background:transparent;cursor:url("/assets/icons/pause.svg") 64 64,pointer;}
.vimeo-cta{color:#fff;font-size:clamp(1.4rem,2.8vw,2.4rem);text-transform:uppercase;letter-spacing:0.05em; opacity: 0;animation: ctaFadeIn 1s ease forwards;animation-delay: 0.5s;font-family:'text';text-align:center}
.vimeo-overlay.is-transparent .vimeo-cta{opacity:0!important;}
.play-cursor{cursor:url("/assets/icons/play.svg") 64 64,pointer;}
.vimeo-cta span {display:block;opacity:0.75;font-size:10pt}
.vimeo-fullscreen {position:absolute;right:0px;bottom:0px;z-index:5;background:rgba(0,0,0,.25);border:0;color:#fff;width:84px;height:84px;border-radius:999px;font-size:40px;cursor:pointer;backdrop-filter:blur(4px);opacity:.9;transition:opacity .25s ease,transform .25s ease;}
.vimeo-fullscreen:hover {opacity:1;transform:scale(1.08);}
.vimeo-fullscreen-wrap {position:absolute;right:20px;bottom:20px;z-index:5;}
.vimeo-fullscreen-note {position:absolute;right:80px;bottom:24px;font-size:16px;color:#fff;padding:6px 18px;border-radius:999px;opacity:0;transition:opacity .2s ease;white-space:nowrap;backdrop-filter:blur(9px);pointer-events:none;}
.vimeo-fullscreen-wrap:hover .vimeo-fullscreen-note {opacity:1;}
.vimeo-bg.is-mobile-preview iframe {visibility:hidden!important;pointer-events:none!important;}
@media (hover:none) and (pointer:coarse){
.vimeo-fullscreen-note {display:none}
.vimeo-fullscreen {width:63px;height:63px;font-size:30px;}
.vimeo-fullscreen-wrap {opacity:0;pointer-events:none;transition:opacity .25s ease;}
.vimeo-overlay.is-transparent .vimeo-fullscreen-wrap {opacity:1;pointer-events:auto;}
}

/* ===============================
      HERO CSS
  ================================ */
#heroSpacer {z-index:-1;height: calc(100svh - 30vh);}
  #mainImageContainer {position:absolute;overflow:hidden;width:100%;top:0px;height: calc(100svh - 25vh);z-index:0;}
  #mainImage::before { content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;background-image: radial-gradient( rgba(0,0,0,0.12) 33%, transparent 33% ); background-size: 3px 3px;} 
  #mainImage::after { content: ''; position: absolute; left: 0; right: 0; bottom: 0; height: 50%; pointer-events: none; background: linear-gradient( to bottom, rgba(40,36,42,0), var(--black) 100% );}
.heroContent-new p, .intro-text-div p {padding:0 20px!important}
  .heroImage-new{
    position:relative;
  background:var(--black);
    box-sizing: border-box;
    display:grid;
    align-items:end;    
  }
  
  .heroImage-new img{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    object-fit:cover;
    z-index:0;
  }
  .objectPositionCenter{object-position: center top}
  .objectPositionLeft{object-position: left top}
  .objectPositionRight{object-position: right top}

  
 
  .heroContent-new{
    position:relative;
    justify-self: start;
    z-index:2;
    color:var(--white);
    height:auto;
    align-self:end;           /* belt & braces */
    padding:45svh 0 0 0;
    width:100%;}
  
.heroContent-new:after{content:'';position:absolute;inset:0;height:60%;top:40%;z-index:-1;
  background:
    linear-gradient(
      to top,
      rgba(40,36,42,1.00) 0%,
      rgba(40,36,42,0.95) 10%,
      rgba(40,36,42,0.85) 22%,
      rgba(40,36,42,0.70) 38%,
      rgba(40,36,42,0.50) 55%,
      rgba(40,36,42,0.30) 72%,
      rgba(40,36,42,0.15) 86%,
      rgba(40,36,42,0.05) 94%,
      rgba(40,36,42,0.00) 100%
    ),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='1' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.015'/%3E%3C/svg%3E");}
    
    .heroContent-new p.heroSub {color:var(--h2)}
   
    .hero-includes  {
      width: 100vw;
      margin: 16px 0 24px;
      margin-left: 50%;
      transform: translateX(-50%);
      font-family:'text';
      font-size: 1.05rem;
      letter-spacing: 0.02em;
      opacity: 0.9;
      color: rgba(255,255,255,0.95);
      text-align: center;
    
  }
  
  .hero-includes span {border-radius:30px;display:inline-block;margin:3px 10px;padding:10px 20px;color:var(--h2)}
  .hero-includes span a{border-radius:30px;display:inline-block;color:var(--h2)}
  .hero-includes span:before{content:'★ ';opacity:0.25}
  .hero-includes span:after{content:' ★';opacity:0.25}
  @media (max-width:920px){.hero-includes span {border-radius:0;display:inline-block;margin: 0;padding:10px;width:100%}
.heroContent-new{
         /* belt & braces */
  padding:100px 0 0 0;}
  .heroImage-new img{ height:100%;object-fit:contain;top:80px;position:relative }
#navFadeIn {opacity:1}



}
    
    #mainImage video {object-fit:cover;width:100%;height:calc(100svh - 30vh);position:absolute;top:0;left:0;z-index:0}
    #mainImage img {width:100%;height:100%;object-fit:cover;position:absolute;bottom:0px;left:0;opacity:1;z-index:-1;transform:scale(1);transform-origin:bottom left}
    #backgroundVid {opacity: 0;transition: opacity 0.6s ease;}
    #backgroundVid.ready {opacity: 1;} */
    /* ---------- ANIMATION TEXT OVERLAY ---------------- */
  
     #homeHero {position:fixed;top:0;left:0;right:0;bottom:0;z-index:0}
    #heroAnimation { position: absolute;z-index:99; width: 100%; height: 100%; overflow: hidden;
    }
    
  .animated-title {z-index:10;animation-delay:0s;animation:fadeAway 3s;height:100px;left:50%;opacity:0;position:absolute;text-align:center;top:calc(50%);transform:translate(-50%,-50%);width:100%;max-width: 100%;overflow: hidden;}
  .titleFX {opacity:1;font-size:4rem;left:50%;position:absolute;top:calc(50% - 30px);transform:translate(-50%,-50%);display:block;font-family:'pf';color:var(--white)}
  
  @keyframes ctaFadeIn {  to   {opacity: 1;}   }
  @keyframes fadeAway {   0% {opacity:1;}   25% {opacity:1}   50% {opacity:1;}    100% {opacity:0;}   }
  @keyframes showHide {   0% {opacity:1}    99% {opacity:1}   100% {opacity:0}    }


/* ===============================
   Social Icons
================================ */
.soc-icon {display:inline-grid;fill:var(--black);transition:transform 0.4s ease-out;}
.soc-icon:hover,.soc-icon:focus-visible {transform:translateY(-5px);transition-timing-function:ease-in;}
.soc-icon:focus {outline:none;}
.soc-icon-container {margin:auto;width:300px;position:relative;display:grid;grid-template-columns:repeat(6,1fr);gap:20px;}

.privacyLinks {background:var(--back);position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%;padding:15px calc(50% - 400px);margin:auto}
.privacyLinks a {color:var(--white);text-align:center}
.privacyLinks a:hover {text-decoration:underline;}

.servicesContainer {text-align:center;position:relative;}
.servicesHover {color:var(--white);padding:15px;margin-top:-15px;margin-bottom:-15px;box-sizing:border-box;cursor: pointer}
.servicesHover:hover {background:var(--blue);}
.service-links {position:absolute;bottom:calc(100% + 14px);left:0px;z-index:1;width:100%;margin:0;padding: 0;background:var(--back);opacity:0;visibility:hidden;transform:scaleY(30%);transform-origin:bottom;transition:transform 0.25s ease;overflow:hidden;border-radius:5px 5px 0 0;box-shadow:0 0 30px black}
.servicesHover:hover .service-links {opacity:1;visibility:visible;transform:scaleY(100%);}
.service-links li {padding:0.8rem;display:block;background:var(--h2);margin:1px 0}
.service-links li a {display:block;width:100%;height:100%;font-size:0.9rem;text-decoration:none;color:var(--black);white-space:nowrap;}
.service-links li:hover {background:var(--white)}
.service-links li a:hover {background:transparent;text-decoration:none}
#mobile-nav-footer {display:none}
footer .hide-in-footer {display:none}
@media (max-width:800px) {
  .privacyLinks {display:none}

 
 #mobile-nav-footer {display:block}
  #mobile-nav-footer .accordion-header {background:var(--black);color:var(--white);width:22ch;margin:0;padding:0}
  #mobile-nav-footer .accordion-header:hover {}
  #mobile-nav-footer .accordion-header::after, #mobile-nav-footer .accordion-item::after {display:none}
  #mobile-nav-footer .accordion-content {;color:var(--white);padding:0}
  #mobile-nav-footer .accordion-content span {display:block;padding:14px;font-size:1.2rem;border-radius:5px}
  #mobile-nav-footer .accordion-content ul {margin:0;padding-top:15px;background:var(--black)}
  #mobile-nav-footer .accordion-content ul li{list-style: none;padding:12px 0 12px 15px;margin:0 0 3px 0;background:var(--back);border-radius:4px}
  #mobile-nav-footer .accordion-content ul li a {color:var(--white);   display: block;font-size:15px;width: 100%;height: 100%;}
  #mobile-nav-footer .accordion-content ul li:hover {background:var(--blue)}
}
  
#body-container {z-index:10;width:100vw;overflow-x:hidden}
#topofpage {width:100%;height:80px;max-height:80px;display:block}
.topofpage {width:100%;height:80px;max-height:80px;display:block}
#topofpage-nav {width:100%;height:80px;display:block}
.toggle-opacity {opacity:1}
.opacity0 {opacity:0;transition:ease-in 0s}
.opacity1 {opacity:1;transition:ease-in 0s}
#cross {position:absolute;top:35px;right:50%;width:40px;height:40px;transform:rotate(45deg) translate(0,-70%);cursor:pointer;}
#cross:after,#cross:before {content:"";position:absolute;z-index:-1;background:var(--white)}
#cross:before {top:0;left:50%;transform: translateX(-50%);width:20%;height:100%}
#cross:after {left:0;top:50%;transform: translateY(-50%);height:20%;width:100%;}

/* ---------- FOOTER ---------- */
footer {position:relative;z-index:99;background:var(--back)}
footer nav {position:relative}
footer address {font-style:normal;padding-bottom:40px}
#site-footer {background:var(--back);color:var(--white);padding:20px 20px 60px 20px}

.footer-menu{max-width:1080px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:center;text-align:left;column-gap:100px;row-gap:28px;padding:40px 20px 0}
.footer-menu>div{flex:0 0 150px;min-width:150px}
p.footer-heading{font-size:1.4rem;font-family:'heading';padding:0;margin:0 0 14px}
ul.footer-list{list-style:none;padding:0;margin:0}
.footer-list li{margin:0 0 10px}
.footer-list li a{color:var(--h2);text-decoration:none;display:block}
.footer-list li a:hover{color:white}

@media (max-width:900px){
  .footer-menu{column-gap:10px;row-gap:28px;padding:40px 0 0}
  .footer-menu>div{flex:0 0 220px;min-width:220px}
}
@media (max-width:720px){
  .footer-menu{display:none}
}


.footer-bottom {text-align:center;padding-top:20px;margin-top:60px;}
.logoFooter img {width:80px;height:80px;margin:auto}
.no-js-warning {background:#ffeb3b;color:#000;padding:10px;text-align:center;font-size:0.9rem}

.phone-number a,.phone-number{color:var(--white);font-size:1.8rem;margin:10px  auto;line-height:30px;display:inline-block;vertical-align:middle;height:30px}
.phone-number img {width:25px;height:25px;display:inline-block;position:relative;bottom:-2px;}
.phoneBlack {filter: brightness(0) invert(20%);}
.emailIcon {position:relative;bottom:-6px;margin-right:5px;}
.keyword {display:inline-block;background:rgba(0,0,0, 0.3);color:var(--white);padding:5px 10px;margin:10px 5px;text-align:center;border-radius:5px}
.copyrightMessage {font-size:0.7em;font-family:text;max-width:80ch;color:rgba(218, 218, 218, 1)g:20px 20px 80px!important}
.footer-service-links {width:100%;display:block;text-align:center;margin-top:80px}
 ul.footerLink{ display: inline-flex;flex-wrap: wrap;justify-content: center}
 ul.footerLink li a{font-size:0.8em;margin:10px;color:rgb(214, 210, 210); white-space: nowrap}
 ul.footerLink li a:hover{text-decoration:underline;color:var(--white)}

 .footer-services {border-top:1px solid rgba(255,255,255,0.235);border-bottom:1px solid rgba(255,255,255,0.235);}
 .footer-services summary {cursor:pointer;text-align:center;padding:14px 0;list-style:none;}
 .footer-services summary::-webkit-details-marker {display:none;}
 .footer-services summary::after {content:"+";}
 .footer-services[open] summary::after {content:" −";}
 .footer-services__content {opacity:0;display:grid;grid-template-rows:0fr;transition: opacity 900ms ease;}
 .footer-services__content > * {overflow:hidden;}
 .footer-services[open] .footer-services__content {opacity:1;grid-template-rows:1fr;}
 .footer-services__content ul {margin:0;padding:12px 0;}
 .footer-services summary {color:var(--white)}
 .sitemapLink {display:block;font-size:0.9rem;color:rgba(255,255,255,0.8);margin-top:20px}

/* ------------------------------ */
/* Footer Contact Form Container  */
/* ------------------------------ */


#contact-form-card {box-sizing:border-box ;padding:40px 20px;margin:auto;background:transparent;text-align:center;max-width:767px;color:var(--black)}
#contact-form-card input,#contact-form-card textarea {background:rgba(0,0,0, 0.03);border:1px solid var(--black)}


#contact-form-card form {width:100%;margin:0 auto;padding:40px 0}
#contact-form-card input,#contact-form-card textarea {width:100%;padding:14px 16px;margin-bottom:16px;border-radius:7px;color:var(--black);font-size:1rem;transition:border-color 0.25s ease,box-shadow 0.25s ease,background 0.25s ease}
#contact-form-card textarea {min-height:120px;resize:vertical}
#contact-form-card input:focus,#contact-form-card textarea:focus {background:white;color:var(--black);box-shadow:var(--shadow);outline:none}
#contact-form-card button.cta-btn {width:100%;margin:0 auto;display:block;box-shadow:var(--shadow)}
#footerContactResponse {margin-top:20px}
.form-success:before {content:url('/assets/icons/thumb.svg');display:block;margin:20px auto;height:75px;width:75px;fill:var(--black);opacity:0.9}



/* ------------------------------
   Intent-gated contact styles
------------------------------ */
.hideMe {display:none}
.contact-lite {text-align:center;padding:40px 20px;}
.contact-actions {display:flex;gap:12px;justify-content:center;margin:24px 0;flex-wrap:wrap;}
.small-note {font-size:0.9rem;opacity:0.75;}
.link-btn {background:none;border:none;padding:0;color:var(--black);text-decoration:underline;cursor:pointer;font-size:inherit;}
#contact-form-card.is-hidden,#contact-intro.is-hidden {display:none;}

/* --------------------------- STATUS BAR SOCIAL NETWORKS --------------------------- */
#social{margin:auto;text-align:center;padding-top:8px;z-index:999999999}



.logoHome {width:100px;margin:auto;max-width:100px;top:-40px;position:absolute;z-index:9;left:50%;transform: translateX(-50%)}
 .logoHome img {width:100%;height:100%;}
 .contentBorder {position:relative;
     height:0px;
     width:100%;
     display:block;
     background:linear-gradient(90deg, var(--blue) 25%, var(--purp) 50%, var(--pink) 75%);
     z-index:100;
     position:relative;
     top:0px;
     box-shadow:var(--shadow)}
     
#mainContainer {background:var(--black);min-width:100vw;max-width:100vw;display:block;width:100vw;position:relative;z-index:1}

#homepage-intro header {max-width:1200px;margin:auto;color:var(--white)}
#homepage-intro  {color:var(--white);padding:20px}
#threeSteps p.goldSub {line-height:1.3em;color:var(--h2)}

.darkContainer {background-color:var(--black);width:100%;padding:0;padding-top:1px;margin:0;color:var(--white)}
.introCopy {padding-bottom:40px;}
.lightContainer {background-color:var(--white);width:100%;padding:0;margin:0;color:var(--black)}
.dark {position:relative;background-color:var(--black);width:100%;padding-bottom:0;z-index:0;border:0px dotted lightgreen}
.light {background-color:var(--white);width:100%;padding-bottom:0}
/* .led::before {z-index:-1;content:'';filter:blur(5px);position:absolute;top:0;right:0;bottom:0;left:0;background:url('/images/graphics/led2.jpg');background-size:100% 100%;background-repeat:no-repeat;background-position:bottom;display:block;overflow:hidden; } */

.noHero {margin-top:80px;background:var(--black);text-align:center;padding:40px 20px 60px 20px;color:var(--white)}
.contentContainer {z-index:1;background:transparent;margin:auto;max-width:1600px;width:100%;padding:0 }

details summary {list-style: none;color:var(--blue);cursor: pointer;}
details summary::-webkit-details-marker {display: none;}

.from:before {content:"FROM:";background:none;font-size:12pt}
.drop {margin-top:10px}
.noshadow {text-shadow:none}
.white {color:var(--white)}
.britewhite {color:var(--white)}
.black {color:var(--black)}
.blue {color:var(--blue)}
.pink {color:var(--white)}
.purpletext {color:var(--purp)}
.bluetext {color:var(--blue)}
.pinktext {color:var(--pink)}
.link {text-decoration:underline}
.greyback {background-color:var(--black)}
.blackback {background-color:var(--black)}
.whiteback {background-color:var(--white)}
.fullheight {min-height:100vh;min-height:100svh;}
.noshadow {text-shadow:none}
.cryptedmail:after {content:attr(data-name) "@" attr(data-domain) "." attr(data-tld)}
.my404-text {color:var(--white);text-align:center;zoom:1.5;padding:100px 20px}
.absolute {position:absolute}
.blueBack {background:var(--blue)}
.pinkBack {background:var(--pink)}
.purpBack {background:var(--purp)}
.darkBack {background:var(--back)}
.pinkBack.pfBack::after,
.blueBack.pfBack::after,
.purpBack.pfBack::after,
.darkBack.pfBack::after {position:absolute;top:0;left:0;right:0;bottom:0;content:'';background:radial-gradient(circle at 50% 35%,
  rgba(42, 40, 50, 0.1) 0%,
  rgba(21, 20, 25, 0.9) 
);background-size:100%}
.brandbackBlue {background:linear-gradient(15deg,rgba(42,36,40,0.1),rgba(42,36,40,0.2)),var(--blue)}
.brandbackPink {background:linear-gradient(15deg,rgba(42,36,40,0.6),rgba(42,36,40,0.2)),var(--pink)}
.brandbackPurp {background:linear-gradient(15deg,rgba(42,36,40,0.8),rgba(42,36,40,0.2)),var(--purp)}
.brandbackGrey {background:linear-gradient(15deg,rgba(42,36,40,0.8),rgba(42,36,40,0.2)),var(--back)}
.brandbackBlend {background:linear-gradient(0deg,rgba(42,36,40,0.2),rgba(42,36,40,0.5)),url('/images/brandback.svg');background-size:cover}
.slant {clip-path:polygon(0 40px,100% 0,100% calc(100% - 40px),0 100% )}
.slantTop {clip-path:polygon( 0 40px,100% 0,100% 100%,0 100% )}
.slant0 {clip-path:polygon(0 0px,100% 0,100% 100%,0 100% )}

.z0 {z-index:0}
.z1 {z-index:1}
.z2 {z-index:2}
.z3 {z-index:3}
.z4 {z-index:4}
.z5 {z-index:5}

.howTo {box-sizing: border-box;max-width:800px;margin:auto;padding:20px;padding-bottom:80px;;background:var(--white);color:var(--black)}
.howTo p, .howTo  span, .howTo  h3 {max-width:100%}
.howTo span {font-family:'heading';font-size:1.3rem}
.howTo .cta-btn {margin:15px auto}

/* ================================
   CTA BITTON
================================ */
a.gaq {	min-width:250px;display:inline-block;padding:14px 32px;font-size:1.3rem;font-family:'bold';letter-spacing:0.5px;color:white;border-radius:10px;border:2px solid transparent;background-image:linear-gradient(rgba(30,30,30,0.75),rgba(30,30,30,0.75)),linear-gradient(25deg,var(--blue),var(--pink),var(--blue));background-size:100% 100%,200% 100%;background-position:0 0,0% 50%;animation:borderShift 4s linear infinite;background-origin:border-box;background-clip:padding-box,border-box;transition:transform 0.25s ease, box-shadow 0.25s ease, background-position 0.6s ease, background-image 0.6s}
a.gaq:hover {animation:borderShift 2s;transform:translateY(-2px);box-shadow:0 6px 28px rgba(0,0,0,0.5);background-position:100% 50%,100% 50%;background-image:linear-gradient(rgba(30,30,30,0.1),rgba(30,30,30,0.6)),linear-gradient(25deg,var(--blue),var(--pink),var(--blue))}
/* ================================
   CTA BUTTON
================================ */
.cta-btn {text-transform:captalize;min-width:250px;display:inline-block;padding:12px 22px;font-size:1rem;font-family:'text';letter-spacing:0.5px;border-radius:5px;box-shadow:var(--shadow);transition:all 0.3s ease;opacity:0.85}
.cta-btn:hover {cursor:pointer;opacity:1;transform:translate(0,-2px);}
.ctaDark, .load-reviews-btn {border:2px solid var(--white);color:var(--white);background-color:rgba(0,0,0,0.2)}
.ctaLight, .invert {border:2px solid var(--back);color:var(--back);background:rgba(220,200,200,0.1)}
.ctaDark:hover, .load-reviews-btn:hover {background-color:rgba(0,0,0,0.3);box-shadow:-8px 8px 7px rgba(0,0,0,0.3)}
.ctaLight:hover, .invert:hover {background-color:white;border:2px solid black;color:black;box-shadow:-3px 3px 5px rgba(0,0,0,0.3)}
.ctaShadow {color:var(--white);backdrop-filter: blur(30px);box-shadow:-15px 15px 3px rgba(0,0,0,0.3);border:2px solid var(--white)}
.ctaShadow:hover {background:rgba(0,0,0,0.2)} 
.ctaGreen {filter:brightness(1);color:var(--white);display:block;width:100%;max-width:32ch;margin:16px auto;padding:12px 22px;font-size:1rem;font-family:'text';letter-spacing:0.5px;border-radius:5px;box-shadow:var(--shadow);transition:all 0.3s ease;opacity:1;background:var(--green);text-align:center;transition:transform(translate) 0.25s ease}
.ctaGreen:hover {filter:brightness(1.1);box-shadow:-10px 10px 20px rgba(0, 0, 0, 0.3);transform:translateY(-2px)}
.ctaSubline {font-size:0.9rem;color:var(--back);opacity:0.8;width:100%;text-align:center}
.ctaPreline {margin-top:70px;margin-bottom:10px;font-size:1.6rem;color:var(--black)!important;text-align:center;font-family:'heading';max-width:31ch;line-height:1.35;letter-spacing: -0.01em}
.ctaDrop {margin-top:36px}
/* ================================
   CTA STATS SECTION
================================ */
.cta-stats-container {width:100%;margin:auto;position:relative;max-width:800px}
.cta-stats-section {position:relative;padding:40px 20px;margin:0;margin-bottom:0px;text-align:center;color:var(--white)}
.cta-stats-section .cta-title {margin:0 auto}
.cta-stats-section .cta-subtitle {font-family:'text';font-size:clamp(1rem,1.5vw,1.2rem);margin-bottom:40px}
.cta-stats-section .goldSub {font-family:'text';font-size:clamp(1rem,1.5vw,1.4rem);max-width:38ch;margin-top:1rem}
.cta-stats-row {display:flex;justify-content:center;gap:0;margin-bottom:60px}
.cta-stat {flex:1;}
.stat-number {font-family:'heading';color:var(--white);font-size:clamp(2rem,4vw,3rem);margin-bottom:6px;transition:opacity 0.4s ease-out;font-variant-numeric:tabular-nums;text-shadow:0.25em 0.25em 2px rgba(0,0,0,0.8);opacity:0}

.stat-label,.stat-label2 {font-family:'text';text-transform:capitalize;margin-top:0;letter-spacing:1px;line-height:1.5em;font-size:1.1em;text-shadow:-10px 10px 10px rgba(0, 0, 0, 0.04)}
.stat-label.ctaSmall {font-size:0.9em}
.cta-stat {position:relative;padding:0 30px}

.cta-subtitle {font-size:clamp(1.2rem,1.4vw,2rem)!important;max-width:60ch;color:var(--h2)}
.cta-stat:not(:last-child)::after {content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:4px;height:120px;background:var(--h2);border-radius:4px;opacity:0.2;}

#CTA-light .stat-number {color:var(--back);text-shadow:0.25em 0.25em 2px rgba(0,0,0,0.1)}
#CTA-light .cta-stats-row {padding:30px 0;border-radius:8px;margin-bottom:0;background:white);box-shadow:var(--shadow);color:var(--back)}
#CTA-light .ctaFooter {margin-top:2rem;font-family:'text';letter-spacing:0.07rem;font-size:1rem}
.cta-stat:not(:last-child)::after {opacity:0.4;}

.ctaFooter {margin-top:3rem;font-family:'text';letter-spacing:0.1rem;font-size:1rem}
.ctaFooter p {font-size:1rem;font-family:'text';font-weight:normal}
.mainFaq {padding:0 20px 20px 20px}
.technicalFaq {padding-top:80px}
.faqContainer {display:block;margin:0 auto;padding:20px 20px 20px 20px}
h2.faq-section-title {margin:80px auto }
h3.faq-section-title {margin:40px auto;max-width:100%;padding-left:10px}
.accordion {margin: auto;max-width:1000px}
.accordion-item {position:relative}
.accordion-header {font-family:'heading';position:relative;width:100%;padding:15px 0 15px 10px;background:var(--white);color:var(--black);border:none;text-align:left;cursor:pointer;display:flex;line-height:1.5;justify-content:space-between;align-items:center}
.accordion-header .icon {transition:transform 0.3s ease}
.accordion-header span {padding-right:20px}
.accordion-content {position:relative;max-height:0;overflow:hidden;padding:0;transition:max-height 0.35s ease,padding 0.35s ease}
.accordion-header::after {content:"";display:block;position:absolute;left:0;top:-2px;width:100%;height:2px;background:linear-gradient(90deg,var(--blue) 25%,var(--purp) 50%,var(--pink) 75%)}
.accordion-item::after {content:"";display:block;position:absolute;left:0;bottom:0px;width:100%;height:2px;background:linear-gradient(90deg,var(--blue) 25%,var(--purp) 50%,var(--pink) 75%)}
.accordion-item.active .accordion-content {padding:15px 0}
.accordion-item.active .icon {transform:rotate(180deg)}
.accordion-content p {margin:10px 15px 20px 25px}
.accordion-content a {color:var(--blue);text-decoration: underline;text-decoration-thickness: 1px}
.accordion-content ul {padding-bottom:15px}
.accordion-content ul li {list-style-type:disc;margin-left:40px;font-family:"bold"}
.accordion-content ul {columns:2;column-gap:2rem;-webkit-columns:2;-moz-columns:2;margin-bottom:15px}
.accordion-content p:last-child {padding-bottom:15px;}
.accordion-content ul li {break-inside:avoid}
.accordion-content ul li .note {color:#666}
.accordion-content .subnote {display:block;color:#777;font-size:0.8rem;padding-top:5px}

video.fadelogo,#vidgrid.homepage {animation:signup-response 1s 1;-webkit-animation:signup-response 1s 1;animation-fill-mode:forwards;animation-delay:2s;-webkit-animation-delay:2s;-webkit-animation-fill-mode:backwards}
.visually-hidden {position: absolute;left: -9999px;top: auto;width: 1px;height: 1px;overflow: hidden;}
.faq-spacer-bottom {height:0px;display:block}
.one-piano-only, .popup-only, .duelling-only {padding-bottom:100px}

/* ----------------------- PF-Columns with brand back colour ------------------------- */

.pf-columns {width:calc(100% - 30px);margin:auto;color:var(--white)}
.pf-columns h2 {line-height:1.4;max-width:60ch}
.pf-columns .goldSub {text-align:center;margin-bottom:2rem}
.pf-readmore .pf-content {max-height: 0;overflow: hidden;transition:max-height 2s ease}
.pf-readmore[open] .pf-content {max-height: 4000px;transition:max-height 2s ease}
.pf-content {display:flex;flex-basis:0;gap:15px;margin-bottom:20px;margin:0 auto;text-align:left}
.pf-col {box-shadow:var(--shadow);flex-basis:0;flex-grow:1;overflow:hidden;padding:0 15px 15px 15px;position:relative;border-radius:10px}
.pf-col {}
.pf-col img {display:block;margin:0;width:calc(100% + 30px);object-fit:cover;max-height:250px;position:relative;z-index:2;margin:0  -15px;object-position:center top}
.pf-content h3 {font-family:'bold';font-size:1.6rem;color:var(--white);margin:0 auto;position:relative;text-align:center;z-index:2;padding-top:30px}
summary {padding-bottom:24px;text-align:center}
.pf-columns p {color:var(--white);position:relative;z-index:2;margin:30px auto}
.rmPAd {padding:25px}
.contentSpacer {margin:80px auto}
/* ---------- Gradient Overlay for coloured backgrounds ---------- */
.pfBack {position:relative}
#actBlock .pfBack:before {content:"";height:100%;left:0;opacity:0.6;position:absolute;top:0;width:100%;z-index:0;margin:0;padding:0;z-index:0;box-shadow:0 0 0px black}
.actSubHead {min-width:100%;display:block;margin:0;background:rgba(24, 0, 0, 0.1);padding:1rem 15px;text-align:center;border-radius:5px;box-shadow:inset 0px 10px 30px rgba(0, 0, 0, 0.2);margin-top:15px}
 .actSubHead p {margin-top:1rem;margin-bottom:0}
.actSubHead h3  {max-width:100%;text-align:center;padding:0;margin:0;height:3rem;border-bottom:1px solid rgba(255, 255, 255, 0.25)}


.hColumns {width:calc(100% - 30px);max-width:1200px;margin:auto;display:flex;gap:15px;align-items:stretch;padding-bottom:15px;justify-content: center; /* ← key line */}
.hColumn {margin-bottom:0px;overflow:hidden;box-shadow:var(--shadow);flex-basis:0;flex-grow:1;display:flex;flex-direction:column;max-width:600px;border-radius:10px}
.hColumn h3 {font-size:160%;display:block;color:var(--white);padding-top:20px;border-radius:0px;text-align:center;position:relative;z-index:2;padding-bottom:10px}
.hColumn p {display:block;padding-bottom:5px;color:var(--white);z-index:2}
.hColumn a {color:var(--white);z-index:2}
.hColumn img {display:block;width:100%;object-fit:cover;height:230px;object-position:center;line-height:0;z-index:0;box-shadow:0 5px 100px var(--black);position:relative;}

.hColumn ul {z-index:2;padding-top:25px;padding-bottom:25px;list-style:disc;padding-left:30px;color:var(--white)}
.hColumn ul li {list-style:inherit;font-size:1rem;margin-bottom:1rem;}
.hColumn li::marker {
  color: rgba(255,255,255,0.5);
}
.hColumn .price {display:block;width:calc(100%);text-align:center;margin-bottom:1rem;}
.hColumn p:last-child {margin-top:auto;line-height:1.1}
.hColumn .pfBack {top:-2px;margin:0;padding:0;line-height:0}
.hColumn .pfBack h3 {margin:0;line-height:1.2;font-family:'bold'}
.hColumn .actSummary {text-align:center;margin-top:auto;}
.v2 {background:none;box-shadow:none;color:var(--black);}
.v2 ul {color:var(--black);}
.v2 ul a {color:var(--blue)}
.v2 h3 {color:var(--black);text-align:left;padding:0}
.v2a {margin: auto;max-width:1200px;gap:3vw}
.zzTop {display:block;z-index:3}

#image-blocks {color:var(--white);padding:8rem 0 10rem 0}
#image-blocks .short {display:block;max-width:60ch;padding:60px}	 
.chooseActHeader {padding-bottom:2rem}	
#actBlock .price {font-size:2rem;padding-top:5px;}
#actBlock .fakeLink {padding:20px 15px;border-radius:5px;transition:all 0.35s ease;background:rgba(0,0,0,0.15);border:1px solid rgba(255, 255, 255, 0.532);display:inline-block;width:calc(100% - 40px);text-align:center;margin:auto}
#actBlock .fakeLink:hover {background:rgba(0,0,0,0.4);box-shadow:-5px 5px 10px rgba(0, 0, 0, 0.393);cursor: pointer}
#actBlock h2 {text-align:center!important}

#actBlock .marginBottom {margin-bottom:40px}
#actBlock span.price {display:block}
#image-blocks h2 {margin-bottom:0;color:var(--white);max-width:calc(100vw - 20px)!important}
#image-blocks h3.goldSub {font-size:1.1rem;text-align:center;color:var(--white);width:70ch!important;max-width:calc(100vw - 40px)!important;margin-top:10px;}


  


/* ---------- What to expect - Bullet point blocks ---------- */
#about-our-shows .about-box ul {padding:0}
#about-our-shows ul li {list-style:none;position:relative;font-family:'bold'}
#about-our-shows ul li::before {padding-right:10px;font-size:1.3rem;font-family:'heading';content:'\2713 ';color:var(--pink)}
#about-our-shows .new-version .hColumn ul {padding:0;margin:auto;width:100%;display:block}
#about-our-shows .new-version .hColumn ul li {list-style:none;list-style-type:none;padding:25px 0;margin: 0;font-size:clamp(1rem, 4vw, 1.4rem);text-align:center;transition: filter 0.2s ease-in-out}
#about-our-shows .new-version .hColumn ul li:nth-child(1) {background:#1366b0}
#about-our-shows .new-version .hColumn ul li:nth-child(2) {background:#2d5ba5}
#about-our-shows .new-version .hColumn ul li:nth-child(3) {background:#474f99}
#about-our-shows .new-version .hColumn ul li:nth-child(4) {background:#61448e}
#about-our-shows .new-version .hColumn ul li:nth-child(5) {background:#7c3882}
#about-our-shows .new-version .hColumn ul li:nth-child(6) {background:#962d77}
#about-our-shows .new-version .hColumn ul li:nth-child(7) {background:#b0216b}
#about-our-shows .new-version .hColumn ul li:nth-child(8) {background:#ca1660}
#about-our-shows .new-version .hColumn ul li {z-index:1;position:relative;color:var(--white);box-shadow:var(--shadow)}
#about-our-shows .new-version .hColumn ul li::before {z-index:-1;position:absolute;top:0;right:0;left:0;bottom:0;content:'';background:var(--black);opacity:0.3}
#about-our-shows .new-version .hColumn ul li::after {padding-left:10px;content:'\2713 '}
#about-our-shows .new-version .hColumn ul li:hover {filter:brightness(1.2)}

/* ================================
   ABOUT PAGE
================================ */
#aboutGridContainer {display:grid; gap:0px; grid-template-columns:repeat(2, minmax(0,1fr)); margin:20px auto; max-width:1400px; width:100%;padding:15px;}
#aboutPhoto {height:clamp(300px,30vw,800px); position:relative}
#aboutPhoto::after {background:linear-gradient(to right, var(--pink), rgba(0,0,0,0)); bottom:32px; box-sizing:border-box; color:var(--white); content:"Moments before performing\Ato 86, 000 at Wembley Stadium"; display:block; font-family:'heading'; font-size:clamp(1.1rem, 1.8vw, 1.4rem); left:32px; line-height:1.35; max-width:50%; padding:16px 20px; position:absolute; white-space:pre-line; width:50%}
#mainContainerAbout {background:var(--black)}
.aboutGrid {box-sizing:border-box; padding:15px}
.aboutGrid h3 {max-width:100%; text-align:left}
.aboutImage {margin:25px auto}
.lazy {display:block; height:200px; position:relative; width:100%}
.lazy img {height:100%; object-fit:cover; width:100%}
.picInfo {position:relative}
.picInfo::after {background:linear-gradient(to right, rgba(35,33,37,1), rgba(0, 0, 0, 0) ); bottom:0; box-sizing:border-box; color:var(--white); content:''; font-family:'bold'; font-size:1rem; left:0; line-height:1.35; padding:16px 20px 16px; position:absolute; white-space:pre-line; width:100%;height:54px}
.picInfo::before {background:linear-gradient(to right, var(--blue), rgba(0, 0, 0, 0) ); bottom:54px; box-sizing:border-box; color:var(--white); content:''; font-family:'heading'; font-size:1.6rem;  left:0; letter-spacing:0.04em; padding:0px 20px 0px; position:absolute; width:30%}
.build::before { content: '2009'; } .build::after  { content: 'Building the first PianoFactor pianos'; }
.early::before { content: '2010'; } .early::after  { content: 'The first PianoFactor performance'; }
.now::before   { content: '2025'; } .now::after    { content: 'Duelling pianos as it looks today'; }
.lazy, .squareImage img, .teamCard {box-shadow:-10px 10px 15px rgba(0,0,0,0.3)}
.meetTeam {padding:40px 0px}
.teamCard {display:flex; margin-bottom:20px; max-width:100%;  text-align:center}
.squareImage {margin:25px auto; max-width:100%}
.squareImage img {max-width:100%}
.subTeam {font-size:9pt;color:var(--h2)}
.teamBio {all:unset; background:var(--back); display:block; padding-bottom:20px; width:100%}
.teamBio .heading {color:var(--white); font-family:'bold'; font-size:1.3rem; padding-top:20px}
.teamColumns {-moz-column-count:4; -webkit-column-count:4; column-count:4; padding:20px}
.teamPhoto img.imgRefit {-moz-object-fit:cover; -o-object-fit:cover; -webkit-object-fit:cover; bottom:0; height:100%; left:0; margin:auto; max-height:100%; max-width:100%; min-height:100%; min-width:100%; object-fit:cover; overflow:auto; right:0; top:0; width:100%}
.trustGrid {margin:20px auto; padding:0 20px 80px 20px}
.trustGrid, .trustGrid h3 {text-align:center; width:100%}
.teamName {color:var(--h2);font-size:1.3rem;padding-top:10px}
.teamRole {color:var(--white)}

@media (max-width:1080px) {
.teamColumns {-moz-column-count:2; -webkit-column-count:2; column-count:2}
}
@media (max-width:768px) {
.teamBlock {height:80px}
.teamColumns {-moz-column-count:1; -webkit-column-count:1; column-count:1}
}
@media (max-width:800px) {
#aboutGridContainer {gap:0; grid-template-columns:repeat(1,1fr); max-width:100%}
#aboutPhoto::after {bottom:0px; left:0px;max-width:100%;width:100%}
.teamColumns {-moz-column-count:1; -webkit-column-count:1; column-count:1}
.cta-btn {width:100%}
.ctaShadow, .load-reviews-btn {max-width:250px}
}
#founderContent {color:var(--black);}
#founderContent.lightContainer {padding:80px 25px;}
#founderContent {padding:70px 20px;margin-bottom:60px;}
#founderContent .contentContainer {max-width:900px;margin:0 auto;}
.founderQuote {max-width:760px;margin:0 auto 34px auto;display:grid;grid-template-columns:18px 1fr;gap:18px;padding:0;border:0;}
.founderQuote::before {content:"";width:5px;border-radius:5px;background:var(--blue);display:block;}
.founderQuote p {margin:0;font-size:clamp(1.05rem,2vw,1.25rem);line-height:1.65;font-style:italic;color:var(--black);position:relative;}
.founderQuote p::before {content:"“";position:absolute;left:-0.4em;top:-0.25em;font-size:2.8rem;line-height:1;color:var(--blue);font-family:Georgia,serif;}
.founderQuote p::after {content:"”";margin-left:0.12em;color:var(--blue);font-family:Georgia,serif;}
#founderContent .founderBody {max-width:760px;margin:0 auto;}
#founderContent .founderBody p {margin:0 0 18px 0;line-height:1.7;}
.founderSignature {display:flex;align-items:center;gap:16px;margin-top:36px;max-width:520px;}
.founderSignature img {width:72px;height:72px;object-fit:cover;border-radius:8px;box-shadow:var(--shadow);}
.founderMeta {line-height:1.3;}
.founderMeta strong {display:block;font-size:1.6rem;line-height:0;color:var(--back);margin-top:12px;}
.founderMeta span {display:block;font-size:0.9rem;opacity:0.75;}
#mainContainerAbout .aboutGrid a {color:var(--white);}
#mainContainerAbout .trustGrid a {color:var(--white);}

@media (max-width:600px) {
.founderSignature {margin-top:28px;}
.founderSignature img {width:64px;height:64px;}
}
/* ---------- Downloads and Documents ---------- */
#downloadContainer.docGrid {max-width:1000px;margin:auto;display:grid;grid-template-columns:repeat(3,1fr)}
#downloadContainer.docGrid a {color:var(--white)}
img.pdf {transition:all 0.5s ease}
#downloadContainer.docGrid a:hover img.pdf {filter:brightness(2);transform:scale(1.1)}

/* ================================
   LATEST EVENTS PAGE
================================ */

.event-content h3,.event-content p {max-width:100%;color:var(--white)!important}
.events-grid {display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:5px;padding-bottom:40px;}
.event-card {background-color:var(--back);border-radius:5px;overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,0.2);display:flex;flex-direction:column;transition:filter 0.25s ease;}
.event-card:hover {filter:brightness(1.2);opacity:1}
.event-video-card{overflow:hidden;border-radius:0px;display:block;text-decoration:none;color:inherit;max-width:720px;margin:auto;box-shadow:0 16px 35px rgba(0,0,0,.3);transition:transform .25s ease,box-shadow .25s ease,opacity .25s ease;background:var(--back)}
.event-media img,.event-media iframe {width:100%;height:100%;object-fit:cover;display:block;border:0;}
.event-content {padding:1.25rem;}
.event-content h3 {margin:0 0 0.25rem;font-size:1.5rem;line-height:1.3;}

.event-content p {margin:0;font-size:0.85rem;line-height:1.5;}
.event-badge {display:inline-block;margin-bottom:0.5rem;padding:0.25rem 0.6rem;font-size:0.8rem;font-family:'heading';text-transform:uppercase;letter-spacing:0.05em;background:var(--pink);color:#fff;border-radius:4px;}
.event-media {position:relative;aspect-ratio:16/9;background:#000;}
.event-media::after {content:"";position:absolute;bottom:0.75rem;right:0.75rem;width:30px;height:30px;background:url("/images/logo/pianos.svg") no-repeat center/contain;opacity:0.85;pointer-events:none;z-index:3;}
.event-faq {color:var(--white);background:var(--blue);max-width:100%;padding:40px 20px;display:block}
.event-faq p, .event-faq h4 {margin:0 auto;padding:5px;max-width:80ch;text-align:center}
.event-faq h4 {font-size:2rem;font-family:'heading'}
.event-video-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;border-radius:0!important}
.event-video-thumb img{width:100%;height:100.5%;object-fit:cover;object-position:center;display:block;position:relative;z-index:1;transition:transform .35s ease,filter .35s ease;border-radius:0;}
.event-video-thumb::after{content:'';position:absolute;top:50%;left:50%;width:70px;height:70px;background:rgba(0,0,0,.65);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:2;transition:transform .25s ease,background .25s ease}
.event-video-thumb::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-40%,-50%);border-left:22px solid white;border-top:14px solid transparent;border-bottom:14px solid transparent;pointer-events:none;z-index:3}
.event-media:hover .event-video-thumb::after{background:var(--pink)}
span.event-date {display:inline-block;padding:3px 10px;background:var(--h2);margin:1rem 0;font-size:0.85rem;color:var(--back);font-size:0.9rem;font-family:'heading'!important;border-radius:4px;opacity:0.75}
/* ==============================
   PianoFactor – Videos Grid
   Markup:
   .pf-video-grid
   .pf-video-card
   .pf-video-card__link
   .pf-video-card__media
   .pf-video-card__thumb
   .pf-video-card__play
   .pf-video-card__title
   .pf-video-card__desc
   .pf-video-embed (created by JS)
   ============================== */
#videos {padding:20px}
   .pf-video-grid {display:grid;grid-template-columns:1fr;gap:15px;max-width:1600px;margin:auto}
   
   @media (min-width:700px) {
   .pf-video-grid {grid-template-columns:repeat(2,minmax(0,1fr));gap:15px;}
   }
   
   @media (min-width:1050px) {
   .pf-video-grid {grid-template-columns:repeat(3,minmax(0,1fr));gap:15px;}
   }
   
   @media (min-width:1450px) {
   .pf-video-grid {grid-template-columns:repeat(3,minmax(0,1fr));}
   }
   
   .pf-video-card {border-radius:5px;overflow:hidden;background:var(--white);color:var(--black);box-shadow:0 18px 50px rgba(0,0,0,0.35);border:1px solid black);display:flex;flex-direction:column;min-height:100%;transition:transform 220ms ease,box-shadow 220ms ease,border-color 220ms ease;}
   .pf-video-card a {color:var(--black)}
   .pf-video-card:hover {box-shadow:0 22px 70px rgba(0,0,0,0.45);background:white;filter:brightness(1.1);}
   .pf-video-card__link {display:block;color:inherit;text-decoration:none;}
   .pf-video-card__link:focus-visible {outline:2px solid rgba(232,15,112,0.75);outline-offset:3px;border-radius:12px;}
   .pf-video-card__media {position:relative;aspect-ratio:16/9;width:100%;background:rgba(0,0,0,0.08);overflow:hidden;}
   .pf-video-card__thumb {width:100%;height:100%;object-fit:cover;display:block;}
   .pf-video-embed {width:100%;aspect-ratio:16/9;background:#000;}
   .pf-video-embed iframe {width:100%;height:100%;border:0;display:block;}
   .pf-video-card__play {position:absolute;inset:0;display:grid;place-items:center;pointer-events:none;}
   .pf-video-card__play::before {content:"";width:56px;height:56px;border-radius:999px;background:rgba(0,0,0,0.55);box-shadow:0 10px 30px rgba(0,0,0,0.35);transition:transform 220ms ease,background 220ms ease;}
   .pf-video-card__play::after {content:"";position:absolute;width:0;height:0;border-left:16px solid rgba(255,255,255,0.95);border-top:10px solid transparent;border-bottom:10px solid transparent;margin-left:3px;}
   .pf-video-card:hover .pf-video-card__play::before {background:var(--pink);transform:scale(1.05);}
   .pf-video-card__title {margin:16px 16px 0 16px;line-height:1.2;}
   .pf-video-card__desc {margin:10px 16px 18px 16px;opacity:0.9;line-height:1.55;display:-webkit-box;-webkit-line-clamp:none;-webkit-box-orient:vertical;overflow:hidden;}
   .pf-video-card.is-playing .pf-video-card__desc {-webkit-line-clamp:unset;}
   #videos .cta-btn {max-width:520px;margin-left:auto;margin-right:auto;}
   
   @media (prefers-reduced-motion:reduce) {
   .pf-video-card,.pf-video-card:hover {transform:none!important;transition:none!important;}
   .pf-video-card__play::before {transition:none!important;}
   }
   .videoWatch-inline-pad {display:block;padding:40px}
/* ======== REVIEWS PAGE ======== */
.reviewsContent {max-width:1200px;padding:20px}


/* ---------- CLIENT SECTION ---------- */
#clients {position:relative;width:100%;margin:auto;text-align:center;padding-top:80px;display:inline-flex;}
.clientCont {margin:auto;max-width:100%}
.noPad {padding-top:0!important}

ul.benefits {text-align:left;display:grid;grid-template-columns:repeat(3,1fr);gap:20px 40px;padding:0;margin:40px auto;list-style:none;max-width:1200px}
ul.benefits li {margin:0}
ul.benefits2 {text-align:center;display:grid;grid-template-columns:repeat(3,1fr);gap:20px 40px;padding:0;margin:40px auto;max-width:1200px}
ul.benefits2 li {background: repeating-linear-gradient(
    to bottom,
    transparent 0,
    transparent calc(100% / 5 - 2px),
    color-mix(in srgb, var(--white) 25%, transparent) calc(100% / 5 - 2px),
    color-mix(in srgb, var(--white) 25%, transparent) calc(100% / 5)
  );
padding:15px 0;margin:0;color:var(--white);font-family:'heading';font-size:1.3rem;border-radius:0px;box-shadow:var(--shadow)}

.benefits li > strong:first-of-type {
  font-family: 'heading';font-weight:normal;font-size:1.15rem
}

ul.benefits3 {text-align:center;display:grid;grid-template-columns:repeat(3,1fr);gap:20px 40px;padding:0;margin:40px auto;max-width:1400px}
ul.benefits3 li {padding:15px;margin:0;background:rgba(0,0,0,0.4);color:var(--white);font-family:'heading'!important;font-size:1.2rem;border-radius:30px;box-shadow:var(--shadow)}

 #experienceSection {max-width:100%;width:100%;margin:auto;padding: 60px 20px}
 #experienceSection ul {list-style: disc; padding-left: 1.25rem; margin: 1rem 0 2rem 0}
 #experienceSection li {list-style: disc; list-style-position: outside; margin: 0 0 0.5rem 0;font-size:0.9rem}
 #experienceSection .clientCont {margin:4rem auto 3rem;max-width:100%;}
 #experienceSection .clientGroup {margin:1.25rem 0;}
 #experienceSection .clientGroup__items {display:flex;flex-wrap:wrap;justify-content:center;gap:20px;margin:0;padding:0;}
 #experienceSection .logoBox {position:relative;display:inline-flex;width:clamp(58px,4vw,90px);height:clamp(58px,4vw,90px);padding:15px;margin:5px;background:none;box-sizing:border-box;}
 #experienceSection .logoBox svg {position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-height:100%;max-width:100%;}
 #experienceSection .clientGroup__title {margin:2.5rem auto 1.1rem;text-align:center;font-family:'text';font-size:0.95rem;letter-spacing:0.18em;text-transform:uppercase;opacity:0.78;position:relative;padding-bottom:0.9rem;max-width:100%;}
 #experienceSection .clientGroup__title::after {content:"";position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:calc(100vw - 80px);height:2px;background:rgba(0,0,0,0.12);border-radius:2px;}
 #experienceSection p {max-width:62ch}
 
/* Inline YouTube Video - Watch Page Link  */
.inlineVideo{max-width:900px;margin:40px auto;text-align:center;position:relative}
.inline-video-card{overflow:hidden;border-radius:10px;display:block;text-decoration:none;color:inherit;max-width:720px;margin:auto;box-shadow:0 16px 35px rgba(0,0,0,.3);transition:transform .25s ease,box-shadow .25s ease,opacity .25s ease;background:var(--back)}
.inline-video-thumb{position:relative;aspect-ratio:16/8;overflow:hidden}
.inline-video-thumb img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;position:relative;z-index:1;transition:transform .35s ease,filter .35s ease}
.inline-video-thumb::after{content:'';position:absolute;top:50%;left:50%;width:70px;height:70px;background:rgba(0,0,0,.65);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:2;transition:transform .25s ease,background .25s ease}
.inline-video-thumb::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-40%,-50%);border-left:22px solid white;border-top:14px solid transparent;border-bottom:14px solid transparent;pointer-events:none;z-index:3}
.inline-video-title{display:block;font-family:'bold';font-size:1rem;z-index:9;position:absolute;width:100%;bottom:2%;padding:10px 0 10px 0;background:linear-gradient(90deg,rgba(247, 189, 85, 0),rgba(5, 5, 5, 0.75)75%)}
h3.inline-video-title{text-align:right!important;padding-right:20px;color:var(--h2);max-width:720px;}
.inline-video-cta{display:block;font-family:'text';font-size:.95rem;margin:4px auto 14px auto;opacity:.85;letter-spacing:.04em;transition:opacity .25s ease}
.inline-video-card:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 16px 35px rgba(0,0,0,.5)}
.inline-video-card:hover .inline-video-thumb img{transform:scale(1.04);filter:brightness(1.08)}
.inline-video-card:hover .inline-video-thumb::after{transform:translate(-50%,-50%) scale(1.06);background:rgba(0,0,0,.75)}
.inline-video-card:hover .inline-video-cta{opacity:1}
 
/*
.yt-thumbnail {position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;z-index:1;}


.yt-lite{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;  
  background: var(--back);
  cursor: pointer;
  margin: 40px 0;
  overflow: hidden;
  position: relative;
}

.yt-lite iframe{
  position: absolute;
  inset: 0;              
  width: 100%;
  height: 100%;
  border: 0;
  display: block;       
  background: transparent;
}
.yt-lite iframe { width: 100% !important; height: 100% !important; }
.yt-lite::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 5;


  background: linear-gradient(
    90deg,
    rgba(40,36,42,1) 0,
    rgba(40,36,42,1) 0.2%,
    rgba(0,0,0,0) 0.2%,
    rgba(0,0,0,0) 99.8%,
    rgba(40,36,42,1) 99.8%
  );
}
 .yt-playbtn {width:100%;height:100%;color:rgba(250,250,250,0.8);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:10;border-radius:10px;transition:all 0.5s ease;font-size:1.6rem;text-shadow:-5px 5px 20px black}
.yt-playbtn::after {position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);content:"Watch Video →";text-align:center;font-family:bold;color:white;}

.yt-lite:hover .yt-playbtn {font-size:1.8rem}

.marTop {margin-top:20px}
.inlineVideo {max-width:1080px;margin:auto;box-shadow:-10px 10px 40px var(--black)} */


#inlineVideoSection {color:var(--white);padding:0 20px 40px 20px}
.topPad {padding-top:40px}

#trust  {padding:80px 0 40px 0;color:var(--white)}
#trust .trustColumns {max-width:1000px;margin:auto;margin-top:40px;padding:0 30px;display:grid;grid-template-columns:repeat(2,1fr);column-gap:20px}
#trust .trustColumns p {break-inside:avoid;page-break-inside:avoid;-webkit-column-break-inside:avoid;-moz-column-break-inside:avoid}
.trust-item h3 {text-align:left;margin-left:0}
#trust .brand-decorative {margin-top:100px}
span.brand-decorative::before{position:absolute;bottom:-5px;left:calc(50% - 144px);content:'';background:url('/images/logo.png');background-size:100%;width:280px;height:54px;background-repeat:no-repeat;display:block;}
span.brand-decorative {position:relative;font-family:'pf';color:transparent;font-size:clamp(4rem,8vmin,6rem);text-align:center;width:100%;display:block;font-weight:normal;letter-spacing:1.4px;padding-bottom:10px;height:40px;}
.brand-decorative span {color:transparent!important;mix-blend-mode:normal;}
#what-you-get.brandbackPink:after, #what-you-get.brandbackBlue:after {content:'';position:absolute;left:0;right:0;top:0;bottom:0;background:url('/images/graphics/piano-keys.jpg');display:block;z-index:-1;mix-blend-mode:soft-light;opacity:0.2;background-position:35% 40%;background-size:cover}
#page-intro header {max-width:800px;color:var(--white);margin:auto}
#page-intro  {color:var(--white);padding:20px}
#page-intro header h1 {margin-top:-80px}

#homepage-reviews h2 {color:var(--white)}
#homepage-reviews {text-align:center;padding:10px;margin:80px auto;opacity:0; transform:translateY(100px); transition:opacity .6s ease, transform .6s ease;}
.elfsight-app-52752b50-3138-4f87-a629-c8822431acd1 {margin-top:80px}
.elfsight-app-52752b50-3138-4f87-a629-c8822431acd1 .es-header-heading-text {color:white!important}
.elfsight-app-52752b50-3138-4f87-a629-c8822431acd1 .es-rating-value {color:white!important}
.elfsight-app-52752b50-3138-4f87-a629-c8822431acd1 .es-bullets-control-container {filter:invert(180)}

#wedding-reviews, #service-reviews {margin:60px auto;max-width:1200px;display:grid;grid-template-columns:repeat(3,1fr);gap:-10px}
.specificReview-card {background:#ffffff;border:1px solid #ddd;border-radius:10px;padding:0px;box-shadow:-30px 30px 20px rgba(40,36,42,0.3);box-sizing:border-box;transform:rotate(-4deg);margin-top:-5px}
.specificReview-stars {display:inline-block;width:100%}
.specificReview-stars:after {display:block;font-size:22px;content:'★★★★★';color:#f4b400;padding-bottom:6px;text-align:right}
.specificReview-card blockquote {font-size:0.9rem;font-family:'bold';margin:0;padding:25px;color:#333!important;border-radius:6px;line-height:1.5}
.specificReview-card footer {text-align:right;font-family:'text'!important;margin-top:20px;color:var(--black)}
.specificReview-card footer {background:transparent!important;padding:0}
.google-icon {width:52px;height:32px;margin-left:6px;margin-bottom:6px;vertical-align:middle;display:inline-block}
.google-badge {display:inline-block;background:#4285f4;color:#666;line-height:1;padding:3px 6px;border-radius:4px;margin-left:6px}
.specificReview-header {color:var(--back);border-radius:10px 10px 0 0;position:relative;display:flex;align-items:center;gap:6px;margin-bottom:10px;background:linear-gradient(90deg,rgba(0,0,50,0.05),rgba(0,0,120,0.1));padding:10px;font-size:0.7rem}
.specificReview-card footer p {font-size:1.2rem;font-family:'heading';margin:0}

.inv-btn-cont {width:100%;display:block;text-align:center;margin:100px auto}
.reviews-container {overflow:hidden;max-width:1400px;transform-origin:top;transform:scaleY(0);opacity:0;padding:0 20px 0 20px;margin:auto;border-radius:10px;transition:transform 0.45s ease,opacity 0.45s ease;}
.reviews-container.expanded {transform:scaleY(1);opacity:1;padding-bottom:60px}
.load-reviews-btn.collapsing {transform:scaleY(0);opacity:0;transition:transform 0.35s ease,opacity 0.35s ease;transform-origin:top;}
#fiveSteps {margin:0;width:100%;padding:20px 20px 0px 20px}
#fiveSteps .intro-text-div {color:var(--white)}
.process-steps {position:relative;padding-left:3.5rem;background:var(--black);}
.process-steps::before {content:'';position:absolute;left:1.2rem;top:0;bottom:0;width:1px;background:linear-gradient( to bottom,transparent,rgba(255,255,255,0.4),transparent );}
.process-step {position:relative;z-index:1;padding:2.5rem 0 2.5rem 3.5rem;opacity:0;transform:translateY(80px);transition:opacity 0.25s ease,transform 0.35s cubic-bezier(0.22,0.61,0.36,1);}
.process-step h3 {margin:0;padding-left:0;text-align:left!important}
.process-step p {margin:0;text-align:left!important}
.process-step.is-active {opacity:1;transform:translateY(0)}
.process-step__number {position:absolute;font-family:'heading';left:0;top:0;font-size:clamp(3.5rem,8vw,6rem);font-weight:700;line-height:1;opacity:0.25;z-index:0;pointer-events:none;}
.process-step__title {font-size:clamp(1.2rem,2.2vw,1.6rem);font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--white);margin-bottom:0.4rem;}
.process-step__text {font-size:0.95rem;line-height:1.65;max-width:42ch;color:rgba(255,255,255,0.85);z-index:1;}
.process-step__title,.process-step__text {position:relative;z-index:1;}
span.psn1 {color:#1366b0;}
span.psn2 {color:#4a5fa5;}
span.psn3 {color:#7a4f9a;}
span.psn4 {color:#a33a7e;}
span.psn5 {color:#ca1660;}
.processSection {width:100%;background:var(--black);}
.processInner {max-width:1200px;margin-inline:auto;padding-inline:2rem;position:relative;}


span.price {font-family:'bold'}
span.price span {display:inline-block;font-size:1.6rem;font-family:'heading';transform:translateY(3px)}

sd img.imgCover {min-width:100%;min-height:100%;max-width:100%;max-height:100%;bottom:0;left:0;margin:auto;overflow:auto;position:fixed;right:0;top:0;-o-object-fit:cover;object-fit:cover;-webkit-object-fit:cover;-moz-object-fit:cover}
 .spread {font-size:9vmin;letter-spacing:2.40vmin}
#title h1 a {color:var(--blue);transition:font-size 0.5s}
#title h2 a {color:var(--pink);transition:font-size 0.5s}
#title h3 a {color:var(--purp);transition:font-size 0.5s}
#title h1 a:hover,#title h2 a:hover,#title h3 a:hover {font-size:120%;transition:font-size 0.1s}
#title h1,#title h2,#title h3 {padding:0px}
.hidden {display:none}
#expend {display:none}
.expend-close {max-height:0px!important}
#expend+.smalldesc {max-height:5000px;overflow:hidden}
#expend:checked+.smalldesc {max-height:5000px!important}
label.rmore {color:#333;width:100px;cursor:default;border:none}
label.rmore:after {color:#fcbf03;content:"\2605 \2605 \2605 \2605 \2605"}
.titleBack {left:0;right:0;top:0;bottom:0;opacity:0;background:var(--black);position:fixed;display:block;animation:fadeAway 3s;animation-delay:0s}
.info-box {padding-bottom:0;max-width:1024px}
.faq-followup {transform:translateY(-100px)}

#piano-experience-details {padding:4rem 0}
/* PLAIN TEMPLATE LIGHT AND DARK */
.contentContainer.templatePlain {max-width:920px;padding:60px 20px;}
.templatePlain p, .templatePlain li {max-width:100%;line-height:1.6;}
.templatePlain ul {margin:1rem 0 2rem 1.25rem;}
.templatePlain li {margin-bottom:0.5rem;}
.templatePlain ul {list-style: disc; padding-left: 1.25rem; margin: 1rem 0 2rem 0;}
.templatePlain li {list-style: disc; list-style-position: outside; margin: 0 0 0.5rem 0;}
.templatePlain h1,
.templatePlain h2,
.templatePlain h3,
.templatePlain p {margin-left:0;margin-right:auto;}
.templatePlain h2 {text-align:left;}
.light .templatePlain hr {margin:4rem 0;border:none;border-top:1px solid rgba(0,0,0,0.25);}
.dark .templatePlain hr {margin:4rem 0;border:none;border-top:1px solid rgba(255,255,255,0.25);}
.dark .templatePlain{color:var(--white)}
.light .templatePlain {color:var(--black)}
.templatePlain img {max-width:100%;box-shadow:-10px 10px 10px rgba(0, 0, 0, 0.213)}
.template #piano-experience-details h3 {padding-bottom:20px}
.templatePlain a {color:var(--white);}



/* London Logistics */
#infoLondon {box-shadow: 0 -1px 0 var(--black)}
.london-logistics {padding:30px 0 0 0;}
.london-logistics h2 {margin:0 0 20px;line-height:1.2;text-align:left;padding-left:0}
.london-logistics__row {position:relative;}
.london-logistics__cta {padding:20px;border-left:4px solid var(--blue);background:linear-gradient(90deg,rgba(255,255,255,0.04),transparent);border-radius:2px;padding-right:280px;}
.production-graphic {position:absolute;right:0;top:-90px;width:250px;text-align:right;}
.production-graphic img {box-shadow:none;opacity:0.6;display:inline-block;}
.expand-panel {overflow:hidden;max-height:0;opacity:0;transition:max-height 350ms ease,opacity 250ms ease;margin-top:100px;}
.london-faq-cta {margin-top:30px;}
.expand-panel.is-open {opacity:1;}
.london-logistics__cta button {margin-left:0;align:left}
@media (max-width:920px) {
.production-graphic {display:none;}
.london-logistics__cta {padding-right:20px;}
.expand-panel {margin-top:20px;}
}

/* Google Reviews CTA refinement */
.cta-btn.cta-google {
  display: inline-flex;
  align-items: center;
  gap: 12px;

  padding: 14px 22px;
  border-radius: 999px; /* pill shape */

  font-weight: 600;
  letter-spacing: 0.2px;max-width:310px!important;
}

/* Icon alignment & clarity */
.cta-btn.cta-google img {
  display: block;
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
}

/* Subtle polish on hover */
.cta-btn.cta-google:hover {
  transform: translateY(-1px);background:rgba(255,255,255,0.1);
  box-shadow: 0 10px 30px rgba(0,0,0,0.18);
}

/* Motion-safe */
@media (prefers-reduced-motion: reduce) {
  .cta-btn.cta-google:hover {
  transform: none;
  }
}
@media (max-width: 650px){
  .pf-reviews__google{ margin-left: 0; width: 100%; justify-content: center; }
}



.mobile, .mobile-version  {display:none}
.desktop, .desktop-version  {display:block}



@supports (-webkit-touch-callout:none) {
.info-grid-spacer {width:100%;height:0}
}

/* --------------------------------- */
/* ----- Landing Page Template ----- */
/* --------------------------------- */

.template figure {margin:0;}
.template .longFade{padding-top:40vh;background:linear-gradient(rgba(40,36,42,0.2),var(--black) )}
.template .ctaLink {color:var(--white);padding-bottom:2px;text-align:center;display:block;margin:auto;width:160px;font-size:0.9rem;font-family:'bold';border-bottom:2px solid transparent;transition: border 0.5s ease}
.template .ctaLink:hover {border-bottom:2px solid rgba(255, 255, 255, 0.67)}
.template .clientGroup__items {width:calc(100vw - 40px);left:50%;position:relative;transform:translate(-50%, 0)}

.template .template-image img {width:100%;height:auto}
 


.editorial {background:var(--white);color:var(--back);padding: 60px 2rem 40px 2rem;z-index:1}
.editorial .contentContainer {max-width:1200px;z-index:1;position:relative}
.editorial .contentContainer figure {transform:rotate(-3deg);z-index:0;position:relative;max-width:700px;margin:4rem auto;background:var(--back);border-radius:15px;}
.editorial .contentContainer figure figcaption {font-family:'bold';position:absolute;bottom:5px;text-align:center;left:5px;width:calc(100% - 10px);padding:1rem 2rem;border-radius:0 0 0 5px;color:var(--white);background:rgba(40,38,42,0.6)}
.editorial .contentContainer img {display:block;width:100%;height:auto;margin:auto;box-shadow:-100px 50px 20px rgba(0, 0, 0, 0.2), 100px -50px 20px rgba(0, 0, 0, 0.1);border:5px solid var(--back);border-radius:15px;}
.editorial .contentContainer h2 {text-shadow:-50px 25px 5px  rgba(0, 0, 0, 0.1);z-index:0;position:relative;}
.editorial .contentContainer .cta-btn {margin:4rem auto;display:block;max-width:24rem;text-align:center}
.opaque-back {border-top:1px solid var(--green); border-bottom:1px solid var(--green);margin:3rem 0;position:relative }
.opaque-back::after {text-align:center;width:100%;max-width:400px;position:absolute;top:-1.2rem;font-size:1.4rem;color:white;content:'Included as standard';left:50%;transform: translateX(-50%);background:var(--green);padding:0 1rem; border-radius:30px}
#what-is-x.editorial .contentContainer figure {transform:rotate(3deg);z-index:0;}
 #what-you-get ul.included {text-align:left;display:grid;grid-template-columns:repeat(3,1fr);gap:20px 40px;margin:40px auto;max-width:1000px}
 #what-you-get ul.included li {position:relative;padding:15px 0;margin-left:50px;color:var(--back);font-family:'text';font-size:1rem;}
 #what-you-get ul.included li::before {
content:'✓';display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;margin-right:12px;border-radius:50%;background:rgba(255,255,255,0);color:var(--green);border:3px solid var(--green);font-size:26px;line-height:1;flex-shrink:0;position:absolute;left:-50px;top:10px;box-shadow:-15px 15px 10px 8px rgba(0, 0, 0, 0)}






.niceColumns {  columns:2 300px;
  column-gap:50px;
  margin-top:50px;max-width:880px;margin:auto;}
.niceColumns > * {break-inside: avoid;page-break-inside: avoid;}
ul.niceColumns li  {line-height:1.6rem;font-size:0.9rem;margin-bottom:2rem;margin-top:auto}
ul.niceColumns li strong {font-family:'text';font-size:1.4rem}
.niceColumns h3 {margin:0;padding-left:0;padding-bottom:1rem;z-index:4;font-family:'heading';font-size:1.6rem;text-align:left}
.niceColumns p {z-index:4}
.niceColumns a {color:var(--back)}
@media (max-width:1100px) {
  .niceColumns {column-count: 2;column-gap: 24px}
}
@media (max-width:780px) {
  .niceColumns {column-count: 1;column-gap: 24px}
  .editorial .contentContainer .cta-btn {max-width:100%}
  #what-is-x.editorial .contentContainer figure,.editorial .contentContainer figure {transform:rotate(0deg) translateX(-34px);width:103vw;max-width:104vw;padding:0}
  .editorial .contentContainer img {box-shadow:-50px 50px 20px rgba(0, 0, 0, 0.2), 100px -50px 20px rgba(0, 0, 0, 0.1);border:0px solid transparent;border-radius:0px;padding:0;margin:0}
  
  .editorial .contentContainer figure figcaption {bottom:0px;}
}



.whatIsXColumns{
  columns:2 300px;
  column-gap:50px;
  margin-top:50px;max-width:960px;margin:auto;
}

.whatIsXItem{

  margin-bottom:40px;
}

.whatIsXItem h3{
  break-inside:avoid;
margin-top:0;
margin-bottom:14px;
text-align:left;
padding-left:0;
margin-left:0;
width:100%;font-size:1.8em}

.whatIsXItem p{
  line-height:1.7;  break-inside:avoid;
}

/* =========================
   TABLET
========================= */

@media (max-width: 1100px){

  .whatIsXColumns{
    grid-template-columns:repeat(2,1fr);
    gap:40px;
  }

}

/* =========================
   MOBILE
========================= */

@media (max-width: 700px){

  .whatIsXColumns{
    grid-template-columns:1fr;
    gap:30px;
  }

}




/* --------------------------------- */
/* ---------- ANIMATIONS ----------- */
/* --------------------------------- */
@keyframes borderFlash {
  0%   { border-color: rgba(255, 255, 255, 0.4); }
  15%  { border-color: rgba(255, 255, 255, 1.0); }
  40%  { border-color: rgba(255, 255, 255, 0.4); }
  100% { border-color: rgba(255, 255, 255, 0.4); }
}
@keyframes space {
40% {opacity:.75}
50% {opacity:.25}
60% {opacity:.75}
100% {transform:rotate(360deg)}
}

@keyframes spin {
from {transform:rotate(0deg)}
to {transform:rotate(360deg)}
}

@keyframes backgroundScroll {
0% {transform:translate(0,0)}
100% {transform:translate(-6400px,0)}
}

@keyframes borderShift {
0% {background-position:0% 50%}
15% {background-position:100% 150%}
30% {background-position:0% 50%}
100% {background-position:0% 50%}
}

/* --------------------------------- */
/* ---------- MEDIA CALLS ---------- */
/* --------------------------------- */

@media (max-width:1024px) { /* ========== ≤ 1024px ========== */
 
.quickLinks {max-width:120px}
.info-grid-item {width:calc(100vw - 60px);height:calc(100vw - 60px);}
.price-icon {width:55px}
.container-p,.reviewContainer,.mainContainer,.description {padding:0}
#wedding-reviews,#service-reviews {grid-template-columns:repeat(3,1fr)}
#trust .trustColumns {grid-template-columns:repeat(2,1fr)}
#trust h2 {padding:0 10px}
#pageintro .intro-item {vertical-align:top;display:inline-block;width:100%;}
#pageintro .centre-box {width:100%;padding:0;}
 #about-our-shows .hColumn {display:flex;min-width:0;}
 #about-our-shows .hColumns {display:flex;gap:5px;margin:0;}
 .hColumn img {min-height:300px}
 .hColumns {display:block;padding-bottom:0}
 .hColumn {max-width:calc(600px);display:block;margin:auto;margin-bottom:15px;}
 .hColumn ul {margin-left:20px}
 .hColumn ul li {font-size:1rem;padding:0;margin:0;}
 .hColumn p {font-size:1.2rem}
 .hColumn h3 {text-align:center;}
 .hColumn .guidePrice {text-align:center}

   .events-grid { grid-template-columns: repeat(2, 1fr);}
   .pf-columns .pf-content {display:block;}
  .pf-col {margin:15px auto}

   
} /* ========== END ≤ 1024px ========== */


@media (max-width:919px) { /* ========== ≤ 919px ========== */
  

 /* .led::before {background:url('/images/graphics/led3.jpg');background-size:cover;background-position:center;} */
 ul.benefits {grid-template-columns:repeat(2,1fr)}
 ul.benefits2,ul.benefits3 {grid-template-columns:1fr}
 #what-you-get.brandbackPink:after,#what-you-get.brandbackBlue:after {background-size:cover}
 

 #what-you-get ul.included {padding-left:0;margin:40px auto;max-width:100%;grid-template-columns:repeat(2,1fr);gap:20px 40px;}



 
 .process-steps {padding-left:15px}
 .process-step__number {left:-40px;font-size:7rem}
 .process-steps::before {display:none}
 .process-step.is-active {padding:2.8rem 0 2rem}
 .events-grid {padding:20px;padding-bottom:0px}

} /* ========== END ≤ 919px ========== */


@media (min-width:920px) { /* ========== ≥ 920px Greater than ========== */
  

  .process-step {transform:translate(var(--x,0),80px);}
  .process-step.is-active {transform:translate(var(--x,0),0);}


} /* ========== END ≥ 920px Greater than ========== */


@media (max-width:800px) { /* ========== ≤ 800px ========== */
 
.desktop,.desktop-version,.not-mobile {display:none}
/* Mobile nav: cleaner + less chunky */
.mobile,.mobile-version{display:block}

/* panel spacing */
#navMenu{padding-top:70px;}

/* single-column list, scrollable within panel */
#navMenu .columns{
  grid-template-columns:1fr;
  gap:12px;
  padding:0 12px 16px;
  margin:0;
  max-height:calc(100dvh - 80px);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding-bottom: calc(env(safe-area-inset-bottom) + 24px);
}


/* section headers: smaller, lighter, sticky optional later */
#navMenu .nav-section-title
{
  margin:12px 0 6px;
  padding:10px 12px;
  font-size:1.3rem;
  letter-spacing:.2px;
  color:#fff;
  border-radius:10px;
}




/* list layout */
#navMenu .column{margin:0;padding:0}
#navMenu .column ul{margin:0;padding:0;list-style:none}

/* reduce per-item spacing */
#navMenu .column ul li{
  margin:0;
  padding:0;
}

/* links: tap-friendly but not huge */
#navMenu .column ul li a{
  display:block;
  width:100%;
  font-size:1rem;
  line-height:1.2;
  padding:14px 12px;       /* ~44px height on most devices */
  margin:0;margin-bottom:3px;
  text-decoration:none;
}

/* hover (desktop emulation) + active feel */
#navMenu .column ul li a:hover{

  background:var(--blue);
  box-shadow:none;
}

#navMenu .column ul li a:active{
  transform:translateY(1px);
}



 .events-grid { grid-template-columns: repeat(1, 1fr);}


span.logoText {opacity:0}
a.logoContainer {width:0}
.quickLinks {min-width:calc(25vw - 6px)}

.cta-stats-row {display:block;min-width:100%;gap:0;}
.stat-number {font-size:clamp(3rem,4vw,3rem)}
.cta-stat:not(:last-child)::after {display:none}
.accordion-content ul {columns:1}
#show-info-popup .linefifty {width:100%}
#show-info-popup .vbuttons {display:inline-block;max-width:480px;width:30vw;min-width:210px;height:100px;margin:auto;}
#show-info-popup .vbuttons button,#show-info-popup .vbuttons form {margin:0}
.act-block {flex-direction:column}
.act-thumb {width:100%;margin-top:10px}
.intro-lead {text-align:left;}
#trust .trustColumns {grid-template-columns:1fr}
ul.benefits {grid-template-columns:1fr;padding-bottom:20px;}
ul.benefits2,ul.benefits3 {grid-template-columns:1fr}
#what-you-get.brandbackPink:after,#what-you-get.brandbackBlue:after {display:none}
#wedding-reviews,#service-reviews {grid-template-columns:1fr;max-width:500px;}
.specificReview-card {box-shadow:-30px -30px 20px rgba(40,36,42,0.3);}
.img-blk-con1,.img-blk-con {width:100%!important;margin:0;}
.img-blk-title1 {height:90px}

   #what-you-get ul.included {padding-left:0;margin:50px auto;max-width:100%;grid-template-columns:repeat(1,1fr);gap:0}
 #what-you-get ul.included li::after {content:'';border-bottom:1px solid rgba(255, 255, 255, 0.25);position:absolute;right:0;bottom:8px;width:100%;display:inline-block}
} /* ========== END ≤ 800px ========== */



@media (max-width:500px) { /* ========== ≤ 500px ========== */
  .quickLinks {min-width:calc(33vw - 5px);width:auto}
  .heading, .quo {padding:0;margin:0}
  .book-cont {display:none}
.hColumn ul {margin-left:10px}
   .hColumn p {font-size:1.2rem;}
 


} /* ========== END ≤ 500px ========== */

/* ===============================
   Motion preferences
================================ */
@media (prefers-reduced-motion: reduce) {
  .process-step {
    transform:none;
    transition:opacity 0.15s linear;
  }
  .soc-icon {
    transition:none;
  }
  .soc-icon:hover,
  .soc-icon:focus-visible {
    transform:none;
  }
}