/*RESET*/
* { padding: 0; margin: 0; box-sizing: border-box; }

/*GLOBAL VARS*/
:root{
--font-serif: 'Iowan Old Style', 'Palatino Linotype', 'URW Palladio L', P052, serif;
--font-sans-serif: Rubik, sans-serif;
--color1: #000000;
--color2: #7A0039; /*burgundy*/
--color3: #515254; /*dark grey*/
--color4: #CC0080; /*pink*/
--color5: #FF0083; /*bright pink*/ 
--color6: #00B8ED; /*cyan*/
--color7: #F0F0F0; /*light grey*/
--color8: #FFFFFF; 
--color9: #1e4cc7;
--color10: #1e73dc; 
--width-normal: 1110px;
--width-medium: 960px;
--width-narrow: 720px;
--gap-xs: 5px;
--gap-s: 10px;
--gap-m: 15px;
--gap-l: 20px;
--gap-xl: 30px;
--gap-xxl: 40px;
--gap-xxxl: 60px;
--gap-xxxxl: 80px;
--text-xs: 12px;
--text-s: 12px;
--text-m: 13px;
--text-d: 14px;
--text-l: 16px;
--text-xl: 18px;
--text-xxl: 20px;
--text-xxxl: 28px;

}
@media only screen and (min-width: 768px) {
:root{
--text-xs: 12px;
--text-s: 13px;
--text-m: 14px;
--text-d: 15px;
--text-l: 18px;
--text-xl: 20px;
--text-xxl: 22px;
--text-xxxl: 28px;	
}
}
@media only screen and (min-width: 1024px) {
:root {
--text-xs: 12px;
--text-s: 14px;
--text-m: 16px;
--text-d: 17px;
--text-l: 20px;
--text-xl: 22px;
--text-xxl: 26px;
--text-xxxl: 30px;	
}
}

/* DEFAULTS */
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; background: bar(--color7); }
body { font-family: var(--font-sans-serif); font-weight: normal; font-size: var(--text-d); color: var(--color1); line-height: 1.5; padding: 0; background-color: #E6E6E6; margin: 0; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img { max-width: 100%; height: auto; }	
h1,h2,h3,h4,h5,h6 { font-family: var(--font-sans-serif); line-height: 1.25; margin: 0 0 var(--gap-s) 0; }
h1 { font-size: var(--text-xxxl); font-weight: 600; color: var(--color4); letter-spacing: 1px; }
h2 { font-size: var(--text-xxl); font-weight: 600; }
h3 { font-size: var(--text-xl); }
h4,h5,h6 { font-size: var(--text-l); }
p {  margin: 0 0 var(--gap-l) 0; }
ul { margin: 0 0  var(--gap-l)  var(--gap-l); }
ul ul { margin-top: 0; margin-bottom: 0; }
ol { margin: 0 0 var(--gap-l) var(--gap-l); }
dl { margin: 0 0 var(--gap-l) 0; }
dt { font-weight: 700; }
hr { margin: 45px 0 30px 0; height: 5px; background: var(--color4); border: 0; }
small { font-family: var(--font-sans-serif); font-size: var(--text-s); }
blockquote { position: relative; font-family: sans-serif; font-size: var(--text-l); color: var(--color2); padding: 30px 30px 30px 60px; margin: 0 0 var(--gap-l) 0; opacity: 0.75; border-top: 1px solid var(--color2); border-bottom: 1px solid var(--color2); }
blockquote::before { content: "\275D"; position: absolute; left: 0; font-size: var(--text-xxl); color: var(--color2); line-height: 1; }
blockquote p { margin: 0; }
blockquote cite { font-size: var(--text-m); }
figure { text-align: center; margin: 0 0 var(--gap-l) 0; }
figure img { display: block; width: 100%; }
figcaption { font-family: var(--font-sans-serif); font-size: var(--text-m); color: var(--color3); text-align: center; padding-top: 5px; }
code { font-size: var(--text-m); padding: 3px 5px; background: var(--color6); border-radius: 3px; }
pre { margin: 0 0 30px 0; }
pre::before { content: "CODE"; display: block; width: 40px; font-size: var(--text-s); padding: 5px 10px 0 15px; background: var(--color6); clear; right; border-radius: 7px 7px 0 0; }
pre code { display: block; padding: 15px; background: var(--color6); border-radius: 0 7px 7px 7px; }
audio { width: 100%; background: #555; }
video { display: block; }
time { font-weight: var(--text-m); }
a { color: var(--color5); text-decoration: none; text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover,a:focus { color: var(--color6); text-decoration: underline;  }

/* FORMS  */
.booking-form { max-width: 640px; margin: 0 auto; }
fieldset { border: 0; }
legend { margin-bottom: var(--gap-l); }
.form-item { margin-bottom: var(--gap-l); }
.form-item-instructions { display:block; color: var(--color3); margin-bottom: 3px; }
form ul { list-style: none; margin: 0; }
form ul li { margin-bottom: var(--gap-s); }
input[type='text'],input[type='search'],input[type='email'] { width: 100%; height: 42px; font-size: var(--text-m); text-indent: 10px; border: 1px solid var(--color3); }
input[type=number] { width: 60px; height: 40px; font-size: var(--text-m); text-indent: 5px; background: var(--color7); border: 1px solid var(--color3); }
input[type='radio'],input[type='checkbox'] { zoom: 150%; }
select { width: 100%; height: 42px; font-size: var(--text-m); padding-left: 10px; background: white; border: 1px solid var(--color3); }
textarea { width: 100%; min-height: 140px; font-size: var(--text-m); padding: 10px; border: 1px solid var(--color3); }
button { height: 42px; font-size: var(--text-m); font-weight: 700; color: var(--color7); padding: 0 var(--gap-m); background: var(--color9); border: 0; }
button:hover, button:focus { color: var(--color8); background: var(--color5); }

/*ROWS*/
.row-nav { background: var(--color8); z-index: 999; }
.row-nav-home { background: var(--color7); z-index: 999; }
.row-slides { background: var(--color2); }
.row-hero { background: var(--color7); padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-content { background: var(--color8); padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-content-courses { padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-content-course { padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-newsletter { background: var(--color8); padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-reviews { background: var(--color7); padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-why { background: var(--color2); padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-location { background: var(--color7); padding-right: var(--gap-l); padding-left: var(--gap-l); }
.row-footer { height: 100%; background: var(--color2); }

@media only screen and (min-width: 768px) {
.row-nav {
  position: sticky;
  top: 0;
}
}

/*CONTENT*/
.content { max-width: var(--width-medium); padding: var(--gap-xl) var(--gap-l); margin: 0 auto; }
.content.hero { padding-top: 0; padding-right: 0; padding-left: 0; }
.content.slides { max-width: var(--width-normal); padding-top: 0; padding-right: 0; padding-left: 0; }
.content.content-intro { padding-right: 0; padding-left: 0; }
.content.courses-item { padding: var(--gap-l) 0; }
.content.course-dates { padding-right: 0; padding-left: 0; }
.content.course-description { padding-right: 0; padding-left: 0; }
.content.newsletter { padding-right: 0; padding-left: 0; }
.content.reviews { padding-right: 0; padding-left: 0; }
.content.why { padding-right: 0; padding-left: 0; }
.content.location { padding-right: 0; padding-left: 0; }
.content.footer { max-width: var(--width-normal); padding-right: var(--gap-l); padding-left: var(--gap-l); }

@media only screen and (min-width: 768px) {
.content.hero { padding-right: var(--gap-xxxl); padding-left: var(--gap-xxxl); }
.content.content-intro { padding-right: var(--gap-xxxl); padding-left: var(--gap-xxxl); }
.content.courses-item { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.course-dates { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.course-description { padding-right: var(--gap-xxxl); padding-left: var(--gap-xxxl); }
}

@media only screen and (min-width: 1024px) {
.content { padding: var(--gap-xl) var(--gap-xxxxl); }
.Xcontent.content-intro { padding-right: 0; padding-left: var(--gap-xxxl); }
.Xcontent.courses-item { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.newsletter { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.reviews { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.why { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.location { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.slides { padding: 0 var(--gap-l); }
.content.course-dates { padding-right: 0; padding-left: var(--gap-xxxl); }
.Xcontent.course-description { padding-right: var(--gap-xxxxl); padding-left: var(--gap-xxxl); }
}
@media only screen and (min-width: 1025px) {
.content.hero { padding-right: var(--gap-xxxl); padding-left: var(--gap-xxxl); }
.content.content-intro { padding-right: var(--gap-xxxl); padding-left: var(--gap-xxxl); }
.content.courses-item { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.course-dates { padding-right: 0; padding-left: var(--gap-xxxl); }
.content.course-description { padding-right: var(--gap-xxxl); padding-left: var(--gap-xxxl); }
}

/*GRIDS UNUSED*/
.grid { display: grid; gap: 30px; grid-template-columns: 1fr; margin: 30px 0 30px 0; }
.grid-flexi { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
@media only screen and (min-width: 768px) {
.grid2 { grid-template-columns: 1fr 1fr; }
.grid-entries { grid-template-columns: 1fr 1fr 1fr; }
}

/*PRIMARY NAV*/
.nav { position: relative; display: flex; gap: var(--gap-l); align-items: center; justify-content: space-between; max-width: var(--width-normal); padding: var(--gap-s) var(--gap-l); margin: 0 auto; }
.push { margin-left: auto; }
.logo { font-weight: 700; color: var(--color1); }
.logo a { color: var(--color1); text-decoration: none; }
.logo a:hover, .logo a:focus { text-decoration: none; }
.logo img { display: block; with: auto; height: 40px; }
@media only screen and (min-width: 768px) {
.nav { padding-top: var(--gap-s); padding-bottom: var(--gap-m); }
.logo img { height: 50px; }
 }
 @media only screen and (min-width: 1024px) {
.nav { padding-top: var(--gap-s); padding-bottom: var(--gap-m); }
.logo img { height: 55px; }
 }

.nav-socials { display: none; }
.nav-socials ul { display: flex; align-items: flex-end; font-size: var(--text-m); list-style: none; margin: 0; }
.nav-socials ul li { margin: 0 0 0 var(--gap-xs); }
.nav-socials a { display: block; color: var(--color1); }
.nav-socials a:hover, .nav-socials a:focus { color: var(--color1); text-decoration: underline; }
.nav-socials svg, .footer-socials svg { display: block; width: 35px; height: 40px; }
.icon-link svg { transition: 0.5s; }
.icon-link svg:hover .shape { fill: var(--color5); }
@media only screen and (min-width: 768px) {
.nav-socials { display: block; }
 }


.menu-toggle { display: none; width: 28px; font-size: 32px; color: #000; line-height: 1; padding: 0; background: transparent; border: 0; margin-left: var(--gap-m); cursor: pointer; }
.menu-toggle:hover, .menu-toggle:focus { background: transparent; }
.bar { display: block; height: 4px; background: var(--color1); margin-top: 4px; margin-bottom: 4px; }

#menu { display: none; position: absolute; top: -999em; right: 0; transition: 0s; z-index:999; }
#menu.menu-active { top: 76px; right: 0; min-width: 240px; margin-top: 0px; }
.menu { font-family: var(--font-sans-serif); font-size: var(--text-m); font-weight: 700; list-style: none; line-height: 36px; padding: 30px; background: var(--color1); margin: 0; }
.menu a { display: block; color: var(--color7); text-decoration: none; }
.menu a:hover,.menu a:focus { color: #00FF00; background: transparent; text-decoration: underline; text-decoration-color: #00FF00; }
@media only screen and (min-width: 1024px) {
 }
#menu { position: relative; top: 0; }
.menu { display: flex; gap: 20px; padding: 0; background: transparent; margin: 0 0 0 20px; }	

/*SLIDES*/
.slides { position: relative; }
.slick-slider div { width: 100%; height: 375px; background-position: center center; background-size: cover; }
.slick-slider div.slick-slide { object-fit: cover !important; object-position: center center !important; }
@media only screen and (min-width: 768px) {
.slick-slider div.slick-slide { height: 500px; }
}
@media only screen and (min-width: 1024px) {
.slick-slider div.slick-slide { height: 500; }
}

.slider-buttons { position: absolute; bottom: 0; right: 0; left: 0; height: 40px; text-align: center; z-index: 99;}
.btn-arrow { width: 40px; height: 40px; padding: 0; border: 0; margin: 0 5px; cursor: pointer; }
.btn-arrow img { display: block; }
.btn-arrow:hover img, .btn-arrow:focus img { filter: brightness(125%); }
.arrow-left {}
.arrow-right {}
.slides { padding: 0; }
.slides img { display: block; }

/*HERO*/
.hero { }
.hero-image { max-width: 320px; margin: 0 auto; aspect-ratio: 1/1; overflow: hidden; } 
.hero-image img { object-fit: cover; width: 100%; height: 100%; }
.hero-image video { object-fit: cover; width: 100%; height: 100%; }
video:focus { outline:none; }
.hero-text { padding-top: var(--gap-l); margin: 0 auto; }
h1.hero-heading { display: flex; column-gap: var(--gap-xs); flex-wrap: wrap; justify-content: center; align-items: center; text-align: center; text-transform: uppercase; margin-bottom: 0; line-height: 1; }
.hero-text img { display: block; width: 278px; height: 46px; }
.hero-text p { font-size: var(--text-l); text-align: center; margin-top: var(--gap-xs); margin-bottom: 0; }
@media only screen and (min-width: 768px) {
.hero-image { max-width: 420px; }
.hero-text { padding-right: 0; padding-left: 0; }
}
@media only screen and (min-width: 768px) and (orientation : landscape) {
.hero-image { max-width: 220px; }
}
@media only screen and (min-width: 1024px) {
.hero-image { max-width: 420px; }
.hero-text img { display: block; width: 290px; height: 48px; }
}
@media only screen and (min-width: 1025px) {
.hero-image { max-width: 420px; }
}
@media only screen and (min-width: 1280px) {
.hero-image { max-width: 520px; }
}
@media only screen and (min-width: 1440px) {
.hero-image { max-width: 520px; }
}
@media only screen and (min-width: 1600px) {
.hero-image { max-width: 620px; }
}
@media only screen and (min-width: 1920px) {
.hero-image { max-width: 820px; }
}

/*HEADER*/

/*SECTION*/
.section-heading { color: var(--color3); }

/*COURSES*/
.courses { }
.courses-item { border-top: 1px solid var(--color2); }
.courses-item-heading { font-size: var(--text-xl); }
.courses-item-fee { margin-bottom: var(--gap-s); }
.courses-item-summary {  }
.courses-item img { width: 114px; }
.courses-item-heading { text-transform: uppercase; margin-top: var(--gap-l); letter-spacing: 1px; }
.courses-item-links { display: flex; column-gap: var(--gap-s); justify-content: flex-end; list-style: none; margin: 0; }
@media only screen and (min-width: 768px) {
.courses-item { display: grid; column-gap: var(--gap-l); grid-template-columns: 114px 1fr; }
.courses-item-summary { margin-right: var(--gap-xxxl); }
}
@media only screen and (min-width: 1024px) {
}

/*COURSE*/
.course-description { border-top: 1px solid var(--color2); }
.course-description p { max-width: 960px; }
.course-dates { display: grid; gap: var(--gap-m); grid-template-columns: 1fr; }
.course-dates-list { display: grid; column-gap: var(--gap-s); grid-template-columns: auto 1fr; margin: 0; }
.course-dates-action { align-self: end; text-align: right; }
.course-dates-links { text-align: right; list-style: none; margin: 0; }
.course-dates-links li { display: inline-block; }
.fluid-list ul { display: grid; row-gap: var(--gap-s); grid-template-columns: 1fr; }
@media only screen and (min-width: 768px) {
.course-dates { grid-template-columns: 3fr 1fr; }
.fluid-list ul { column-gap: var(--gap-xxxl); grid-template-columns: 1fr 1fr; }
}

/*NEWSLETTER*/
.newsletter { display: grid; gap: var(--gap-m); grid-template-columns: 1fr; border-top: 1px solid var(--color2); }
.newsletter-blurb { }
.newsletter-blurb p { color: var(--color3); margin: 0; }
.newsletter-action { align-self: end; text-align: right; }
@media only screen and (min-width: 768px) {
.newsletter { grid-template-columns: 3fr 1fr; }
}

/*REVIEWS*/
.reviews p { color: var(--color3); }

/*WHY*/
.why * { color: var(--color8); }
.why-list { display: grid; column-gap: var(--gap-xxl); grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); margin: var(--gap-m) 0 0 var(--gap-l); }
.why-list li {margin-bottom: var(--gap-m); }
@media only screen and (min-width: 768px) {
.why-list { grid-template-columns: 1fr 1fr; }
}

/*LOCATION*/
.location {}
.location-list { max-width: var(--width-narrow); color: var(--color3); list-style: none; margin: var(--gap-l) var(--gap-xl) var(--gap-l) 0; }
.location-list li { display: grid; column-gap: var(--gap-s); grid-template-columns: 37px 1fr; align-items: center; margin-bottom: var(--gap-xs); }
.location-list li img { width: 37px; height: 42px; }
.location-list a { color: var(--color3); }
.location-map { width: 100%; max-width: 800px; height: 320px; background-position: center center; background-repeat: no-repeat; background-size: 150%; }
.location-map a { display: block; width: 100%; height: 100%; }
@media only screen and (min-width: 768px) {
.location-map { height: 420px; background-size: cover; }
}
@media only screen and (min-width: 1024px) {
.location-map { max-width: calc(100% - var(--gap-xxxxl)); height: 500px; background-size: cover; }
}


/*FOOTER*/
.footer-items { display: flex; flex-wrap: nowrap; justify-content: space-between; color: var(--color8); margin: 0 auto; }
.footer-links { display: flex; flex-wrap: wrap; font-size: var(--text-s); color: var(--color8); line-height: 1; list-style: none; margin-left: 0; }
.footer-links li { padding-right: 5px; border-right: 1px solid #FFF; margin-right: 5px;  }
.footer-links li:last-of-type { border-right: 0; }
.footer-links a { font-weight: 700; color: var(--color8); text-transform: uppercase; }
.footer-links a:hover, .footer-links a:focus { color: var(--color8); text-decoration: underline;  }
.footer-blurb { max-width: var(--width-medium); font-size: var(--text-xs); color: var(--color8); }
.footer-socials { display: flex; gap: var(--gap-xs); justify-content: flex-end; font-family: var(--font-sans-serif); font-size: var(--text-m); list-style: none; margin-left: 0; }
.footer-credit, .footer-credit a { font-size: var(--text-xs); color: #dbdbdb; text-align: right; }

/*LINKS*/
.link { display: inline-block; font-weight: 700; text-decoration: none; text-transform: uppercase; }
.link:hover, .link-focus { text-decoration: none; }
.link-pri { color: var(--color8); background: var(--color4); }
.link-pri:hover, .link-pri:focus { color: var(--color8); background: var(--color5); }
.link-sec { color: var(--color8); background: var(--color9); }
.link-sec:hover, .link-sec:focus { color: var(--color8); background: var(--color10); }
.link-l { height: 50px; font-size: 1rem; line-height: 50px; padding: 0 1.5rem; }
.link-m { height: 40px; font-size: 0.925rem; line-height: 40px; padding: 0 1.5rem; }
.link-s { height: 30px; font-size: 0.85rem; line-height: 30px; padding: 0 1.5rem; }

/*ALERTS*/
.alert { font-weight: 700; color: var(--color7); padding: var(--gap-s); margin-bottom: var(--gap-l); border-radius: 5px; }
.alert-success { background: var(--color5); }
.alert-success::before { content: "\2713  "; }

/*UTILITIES*/
.text-right { text-align: right; }
.skiplink { position: absolute; top:-999em; }
.sr-only { position: absolute; left: -999em; }

/*TEMP*/
.swatch {width: 100%; display: grid; grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr; display: none;  }
.swatch div { height: 30px; border: 1px dotted black; }
.s1 { background: var(--color1); }
.s2 { background: var(--color2); }
.s3 { background: var(--color3); }
.s4 { background: var(--color4); }
.s5 { background: var(--color5); }
.s6 { background: var(--color6); }
.s7 { background: var(--color7); }
.s8 { background: var(--color8); }
a[href="#"],a[href=""] { text-decoration: line-through; }
