@charset "utf-8";

/* BODY */
body {
  background-color: black;
  margin: 0;
  font-family: Rockwell, serif;
}

/* WRAPPER */
div.wrapper {
  width: 1290px;
  margin: 0 auto;
}

/* HEADER */
div.header {
  height: 105px; 
  background-color: #973e3e;
  position: relative;
  z-index: 2; 
}

img.logo {
  width:203px;
  height:109px;
  margin:35px 0 20px 0;
  float:left;
}
.logo {
  display: block;
}

div.header ul {
  margin-right: 60px;
  float:right;
}

div.header li {
  display: inline-block;
  margin: 50px 30px 10px;
}

div.header a {
  font-size:18pt;
  color: #ffffff;
  text-decoration: none;
}

/* CONTENT */
div.content .wrapper {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

/* LEFT SIDE */
div.column1 {
  width: 30%;
  margin-top: 55px; 
}


div.column2 {
  width: 60%;
  position: relative;
}

/* IMAGE BEHIND HEADER */
div.column2 img {
  width: 830px;
  height: auto;
  display: block;
  position: relative;
  top: -120px;  
  z-index: 0;  
}
.trainer {
  margin-left: 0;      
  margin-top: 10px;
  clear: both;
}

.trainer img {
  width: 300px;      
  height: auto;
  display: block;
  margin-top: 10px;  
}

/* POLYGON BANNERS */
.banner {
  background-color: #973e3e;
  color: white;           
  font-size: 40px;
  padding: 15px 50px;     
  margin-bottom: 15px;
  width: 300px;
  clip-path: polygon(0 0, 90% 0, 100% 100%, 0 100%);
  filter: drop-shadow(6px 6px 10px rgba(0,0,0,0.4));
}

.banner2 {
  background-color: #973e3e;
  color: white;           
  font-size: 40px;
  padding: 15px 65px;     
  margin-bottom: 15px;
  width: 320px;
  clip-path: polygon(0 0, 90% 0, 100% 100%, 0 100%);
  filter: drop-shadow(6px 6px 10px rgba(0,0,0,0.4));
}

.banner3 {
  background-color: #973e3e;
  color: white;           
  font-size: 40px;
  padding: 15px 83px;     
  margin-bottom: 15px;
  width: 340px;
  clip-path: polygon(0 0, 90% 0, 100% 100%, 0 100%);
  filter: drop-shadow(6px 6px 10px rgba(0,0,0,0.4));
}
/* BUTTON */
.join-btn {
  display: inline-block;
	margin-top: 20px;
    

  background-color: white;
  color: #973e3e;
  padding: 10px 25px;
  text-decoration: none;
  font-size: 20px;

  clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
}


h1 {
  color: white;
  font-size: 48px;
  margin-bottom: 20px;
}

p, li {
  color: white;
  font-size: 20px;
  line-height: 1.6;
}
div.content {
  padding-top: 40px;
}

a {
  color: #ffffff;
}

a:hover {
  color: #ffb3b3;
}

/* polygon */


/* right text */
.about-text {
	margin-top: 40px;
  max-width: 500px;
}


.polygon-box {
  background-color: #973e3e;
  clip-path: polygon(10% 0, 100% 0, 90% 100%, 0 100%);
  color: white;
  max-width: 700px;
  display: block;
	float: none;
	margin-top: 30px;
 
}

.polygon-box-flat-edge {
  background-color: #FFFFFF;
  clip-path: polygon(0 0, 100% 0, 90% 100%, 0 100%);
  color: black;
	width: 100%;
	box-shadow: 6px 6px 0 #973e3e;
	margin-bottom: 15px;
 
}

.polygon-content {
	max-width: 1200px;
  padding:15px 50px;  
}


.polygon-box h1 {
  margin: 0;
  font-size: 36px;
	white-space: nowrap;
}

.polygon-box p {
  font-size: 18px;
  line-height: 1.6;
  color: black;
}

.polygon-box-hover {
  background-color: #b44e4e;
  transition: 0.3s;
}


.about-text {
  color: white;
  font-size: 20px;
  line-height: 1.6;
  max-width: 400px;
}
.calendar-title {
  color: white;
  text-align: center;
  font-size: 40px;
  margin-top: 40px;
}

/* Classes list styling */
.classes-list {
  list-style: none; /* remove bullets */
  padding: 0;
  margin: 50px 0;
	margin-right:100px;
  display: flex; /* horizontal layout */
  flex-direction: row; /* change to row if you want them side by side */
  gap: 100px; /* spacing between items */
}

.classes-list li {
  display: block; /* or inline-block for horizontal */
  font-size: 20px;
  color: white;
}

/* CALENDAR TABLE */
table.schedule {
  width: 100%;
  border-collapse: collapse;
  margin-top: 20px;
  table-layout: fixed;
}

table.schedule th {
  background-color: #973e3e;
  color: white;
  padding: 10px;
  font-size: 16px;
}

table.schedule td {
  border: 2px solid black;
  height: 100px;
  padding: 8px;
  vertical-align: top;
	background-color: white;
	color: black;
  font-size: 14px;
}


table.schedule td:hover {
  background-color: #973e3e;
}
table.schedule td {
  background-color: white;
	
  color: black;
  
  border: 2px solid black;
  padding: 10px;
  height: 120px;
  vertical-align: top;
}

/* memberships */
.memberships-list {
  margin-top: 40px;
	margin-right: 70px;
  display: flex;
  flex-direction: column;
  gap: 15px; 
}

.memberships-list .polygon-box {
  max-width: 100%;   
}

.memberships-list h2 {
  margin-top: 0;
  text-align: left;
}

.memberships-list p {
  text-align: left;
  margin: 5px 0;
	color: black;
}

.membership-row {
  display: flex;
  justify-content: space-between;
	width: 100%;
  align-items: center;
}

.membership-info {
	flex:1;
  min-width: 0;
  color:#973e3e;
}
/* MEMBERSHIP PAGE HEADER ONLY */


.price {
  right: 200px;                
  top: 50%;                
  transform: translateY(-50%);
  font-weight: bold;
  font-size: 22px;
  color: black;
  white-space: nowrap;
}

.about-section {
  display: flex;
  gap: 40px;
  align-items: flex-start;
}


.left-column {
  display: flex;
  flex-direction: column;
}
/* IMAGE UNDER POLYGON */
.trainer img {
  width: 500px;
  height: auto;
  display: block;
  margin-top: 15px;
  position: static;   
}

/* TEXT RIGHT SIDE */
.about-text {
  max-width: 730px;
}


.contact-box {
  background-color: white;
  color: black;
  padding: 40px 50px;
  width: 300px;      /* narrower */
  font-size: 20px;
  font-weight: bold;
  margin-top: 70px;
  box-shadow: 6px 6px 0 #973e3e;
  text-align: center;
}

.contact-box p {
  margin: 5px 0;
	color:black;
	white-space: nowrap;
}

.contact-row{
	display: flex;
	align-items: center;
	gap: 80px;
	margin-top: 60px;
}

.footer {
  background-color: #973e3e;
  padding: 20px 0;
margin-top: 100px;
  left: 0;
  width: 100%;
	max-height: 200px;
	
}

.footer-content {
  display: flex;
  justify-content: space-between;
	 align-items: flex-start;
}

.footer-col {
  width: 30%;
}

.footer h3 {
  color: black;
  margin-bottom: 15px;
}

.footer p {
  color: white;
  margin: 5px 0;
}

.footer ul {
  list-style: none;
  padding: 0;
}

.footer ul li {
  margin-bottom: 8px;
}

.footer a {
  color: white;
  text-decoration: none;
}

.footer {
	padding: 25px;
}
.contact-form{
  background-color: white;
  padding: 40px;
  width: 350px;
  box-shadow: 6px 6px 0 #973e3e;
}

.contact-form input,
.contact-form textarea{
  width: 100%;
  padding: 8px;
  margin-bottom: 15px;
  border: 1px solid #ccc;
  font-family: Rockwell, serif;
}

.contact-form button{
  background-color: #973e3e;
  color: white;
  border: none;
  padding: 10px 20px;
  cursor: pointer;
}

/* MEMBERSHIP HOVER EFFECT */
.memberships-list .polygon-box-flat-edg hover{
  background-color: #f2f2f2;   
  cursor: pointer;
  transition: 0.2s;
}

