:root {
    --primary: #6aa84f;
    --dark: #1a1a1a;
    --light: #f5f7f5;
    --accent: #e8f5e9;
    --facebook: #1877f2;
    --instagram: #c13584;
    --red: #d9534f;
}

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

body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    line-height: 1.6;
    color: #333;
    background: var(--light);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* Navigation */
nav { background: var(--dark); border-bottom: 4px solid var(--primary); }
nav ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    list-style: none;
    max-width: 1200px;
    margin: auto;
    padding: 0.5rem; /* Reduced padding for mobile */
    gap: 0.8rem; /* Reduced gap for mobile to fit items better */
}
/* Restore larger spacing on desktop */
@media(min-width: 768px) {
    nav ul { padding: 1rem; gap: 1.5rem; }
}

nav a { color: #fff; text-decoration: none; font-weight: 600; text-transform: uppercase; font-size: 0.85rem; transition: color 0.3s; white-space: nowrap; }
nav a:hover, nav a.active { color: var(--primary); }
.nav-btn-highlight { background-color: var(--primary); color: #fff !important; padding: 0.5rem 1rem; border-radius: 4px; }

/* Hero Section */
.hero {
    background: #333 linear-gradient(rgba(0,0,0,0.6), rgba(0,0,0,0.6)), url('../assets/images/hero.jpg') center/cover no-repeat;
    color: #000000;
    text-align: center;
    padding: 3rem 1rem; /* Compact padding for mobile */
    margin-bottom: 2rem;
}
@media(min-width: 768px) {
    .hero { padding: 5rem 1rem; }
}

.hero h1 { font-size: 2rem; margin-bottom: 0.5rem; } /* Slightly smaller heading on mobile */
@media(min-width: 768px) { .hero h1 { font-size: 2.5rem; } }

.hero p { font-size: 1.1rem; opacity: 0.9; }

/* Layout & Grid System */
.container { max-width: 1100px; margin: auto; padding: 0 1rem; flex: 1; }
.container_center { max-width: 1100px; margin: auto; padding: 0 1rem; flex: 1; text-align: center;}

/* Grid defaults to 1 column (Mobile First) */
.grid { display: grid; gap: 2rem; grid-template-columns: 1fr; margin-bottom: 3rem; }

/* Desktop Grid Overrides */
@media(min-width: 768px) { 
    .grid { grid-template-columns: 1fr 1fr; align-items: start; } 
    /* These specific layouts only trigger on larger screens now */
    .grid-75-25 { grid-template-columns: 3fr 1fr !important; }
    .grid-3 { grid-template-columns: repeat(3, 1fr) !important; }
}

/* Typography & Elements */
h1, h2, h3 { color: var(--dark); margin-bottom: 1rem; }
h1 { border-bottom: 2px solid var(--primary); padding-bottom: 0.5rem; display: inline-block; }
p { margin-bottom: 1rem; }
img { max-width: 100%; height: auto; }
ul.list { list-style-position: inside; margin-bottom: 1rem; }
blockquote { border-left: 5px solid var(--primary); padding-left: 1rem; font-style: italic; color: #555; margin: 1rem 0; }
.btn { display: inline-block; background: var(--primary); color: #fff; padding: 0.7rem 1.5rem; text-decoration: none; border-radius: 4px; font-weight: bold; transition: background 0.3s; cursor:pointer; border:none;}
.btn:hover { background: #5a8f42; }
input, textarea, select { width: 100%; padding: 0.8rem; margin-bottom: 1rem; border: 1px solid #ddd; border-radius: 4px; }

/* Tables - General */
table { width: 100%; border-collapse: collapse; margin-top: 1rem; background: #fff; margin-bottom: 0; }
th, td { border: 1px solid #ddd; padding: 12px; text-align: left; }
th { background-color: var(--primary); color: white; }
tr:nth-child(even) { background-color: #f2f2f2; }
.price-note { font-size: 0.85rem; color: #666; font-style: italic; }

/* Table Wrapper for Mobile Scrolling */
.table-wrapper {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
    margin-bottom: 2rem;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

/* Calendar Styles */
.calendar-wrapper { background: white; padding: 1rem; border-radius: 8px; box-shadow: 0 2px 10px rgba(0,0,0,0.1); }
.calendar-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; }
.calendar-header h2 { font-size: 1.2rem; } 

.calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; text-align: center; }
.cal-day-name { font-weight: bold; padding: 5px; background: #eee; font-size: 0.75rem; }
.cal-day { padding: 5px; border: 1px solid #eee; min-height: 60px; position: relative; font-size: 0.8rem; }
.cal-day.today { background-color: #e8f5e9; border: 2px solid var(--primary); }
.cal-day.closed { background-color: #fce8e6; color: var(--red); }
.cal-day.open { background-color: #e6fce9; color: var(--green); }
.cal-day.event { background-color: #4f99fa; color: var(--blue); }
.cal-label { font-size: 0.65rem; display: block; margin-top: 2px; font-weight: bold; line-height: 1.1; }
.cal-btn { background: #ddd; border: none; padding: 5px 10px; cursor: pointer; border-radius: 4px; font-size: 0.9rem;}

/* Calendar Desktop overrides */
@media(min-width: 768px) {
    .calendar-wrapper { padding: 2rem; }
    .calendar-grid { gap: 5px; }
    .cal-day-name { padding: 10px; font-size: 1rem; }
    .cal-day { padding: 15px; min-height: 80px; font-size: 1rem; }
    .cal-label { font-size: 0.8rem; margin-top: 5px; }
    .calendar-header h2 { font-size: 1.5rem; }
    .cal-btn { padding: 5px 15px; }
}

/* Social Section */
.social-container {
    text-align: center;
    background: #fff;
    padding: 2rem 1rem;
    border-radius: 8px;
    margin-bottom: 2rem;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}
.social-btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 10px 20px; color: white; text-decoration: none;
    border-radius: 5px; font-weight: bold; margin: 5px;
}
.fb-btn { background: var(--facebook); }
.insta-btn { background: var(--instagram); }

/* Footer */
footer { background: var(--dark); color: #fff; padding: 2rem 0; margin-top: auto; }
.footer-content {
    max-width: 1100px; margin: auto; padding: 0 1.5rem;
    display: grid; grid-template-columns: 1fr; gap: 2rem;
    align-items: center;
}
@media(min-width: 768px) { .footer-content { grid-template-columns: 1fr 1fr; } }

.footer-map iframe { width: 100%; height: 200px; border-radius: 4px; border:0; }
.footer-info { text-align: center; }
@media(min-width: 768px) { .footer-info { text-align: right; } }

.member-link { color: #555; font-size: 0.8rem; text-decoration: none; transition: 0.3s; }
.member-link:hover { color: #888; }

/* Member Area Login */
.login-box {
    max-width: 400px; margin: 3rem auto; padding: 2rem;
    background: #fff; border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1); text-align: center;
}
#member-content { display: none; }

/* Alert Box for Terms */
.alert-box {
    background-color: #fff3cd;
    border: 1px solid #ffeeba;
    border-left: 5px solid #ffc107;
    color: #856404;
    padding: 1.5rem;
    margin-bottom: 2rem;
    border-radius: 4px;
}
.alert-box ul {
    margin-left: 1.5rem;
    margin-top: 0.5rem;
}

/* Form Styling */
.trial-form {
    background: #fff;
    padding: 1.5rem; /* Reduced padding for mobile */
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
}
@media(min-width: 768px) { .trial-form { padding: 2rem; } }

.form-group { margin-bottom: 1.5rem; }
.form-group label { display: block; margin-bottom: 0.5rem; font-weight: bold; }
.form-checkbox { display: flex; align-items: start; gap: 0.5rem; margin-bottom: 1.5rem; font-size: 0.9rem; }
.form-checkbox input { width: auto; margin-top: 0.3rem; }
.btn-large { width: 100%; font-size: 1.1rem; padding: 1rem; cursor: pointer; border: none; }
