:root {
--color-primary: #2c5f4f;
--color-primary-dark: #1e4436;
--color-primary-light: #3d7a63;
--color-secondary: #7fb069;
--color-background: #ffffff;
--color-background-alt: #f5f7f5;
--color-text: #2d3436;
--color-text-light: #5a6c57;
--color-border: #d4e0d4;
--color-overlay: rgba(44, 95, 79, 0.7);

--font-primary: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
--font-size-base: 16px;
--font-size-small: 14px;
--font-size-large: 18px;
--font-size-h1: 48px;
--font-size-h2: 36px;
--font-size-h3: 24px;
--font-weight-normal: 400;
--font-weight-medium: 500;
--font-weight-bold: 700;
--line-height-base: 1.6;
--line-height-heading: 1.2;

--shadow-small: 0 2px 4px rgba(0, 0, 0, 0.1);
--shadow-medium: 0 4px 8px rgba(0, 0, 0, 0.12);
--shadow-large: 0 8px 16px rgba(0, 0, 0, 0.15);
--shadow-hover: 0 12px 24px rgba(0, 0, 0, 0.18);

--radius-small: 4px;
--radius-medium: 8px;
--radius-large: 12px;
--radius-full: 50%;

--spacing-xs: 8px;
--spacing-sm: 16px;
--spacing-md: 24px;
--spacing-lg: 32px;
--spacing-xl: 48px;
--spacing-xxl: 64px;

--transition-fast: 0.2s ease;
--transition-medium: 0.3s ease;
--transition-slow: 0.5s ease;

--container-width: 1200px;
}

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

html {
scroll-behavior: smooth;
}

body {
font-family: var(--font-primary);
font-size: var(--font-size-base);
line-height: var(--line-height-base);
color: var(--color-text);
background-color: var(--color-background);
}

.container {
max-width: var(--container-width);
margin: 0 auto;
padding: 0 var(--spacing-md);
}

header {
background-color: var(--color-background);
box-shadow: var(--shadow-small);
position: sticky;
top: 0;
z-index: 1000;
}

header .container {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-sm) var(--spacing-md);
}

.brand {
font-size: var(--font-size-large);
font-weight: var(--font-weight-bold);
color: var(--color-primary);
}

nav {
display: flex;
gap: var(--spacing-md);
}

nav a {
color: var(--color-text);
text-decoration: none;
font-weight: var(--font-weight-medium);
transition: color var(--transition-fast);
}

nav a:hover {
color: var(--color-primary);
}

main {
min-height: 100vh;
}

section {
padding: var(--spacing-xxl) 0;
}

h1 {
font-size: var(--font-size-h1);
line-height: var(--line-height-heading);
font-weight: var(--font-weight-bold);
margin-bottom: var(--spacing-md);
}

h2 {
font-size: var(--font-size-h2);
line-height: var(--line-height-heading);
font-weight: var(--font-weight-bold);
margin-bottom: var(--spacing-md);
color: var(--color-primary);
}

h3 {
font-size: var(--font-size-h3);
line-height: var(--line-height-heading);
font-weight: var(--font-weight-bold);
margin-bottom: var(--spacing-sm);
}

h4 {
font-size: var(--font-size-large);
font-weight: var(--font-weight-bold);
margin-bottom: var(--spacing-sm);
}

p {
margin-bottom: var(--spacing-sm);
}

ul, ol {
margin-bottom: var(--spacing-sm);
padding-left: var(--spacing-lg);
}

li {
margin-bottom: var(--spacing-xs);
}

a {
color: var(--color-primary);
transition: color var(--transition-fast);
}

a:hover {
color: var(--color-primary-dark);
}

img {
max-width: 100%;
height: auto;
display: block;
}

figure {
margin: 0;
}

.hero {
background: linear-gradient(135deg, #1e4436 0%, #2c5f4f 50%, #3d7a63 100%);
color: var(--color-background);
position: relative;
padding: 0;
min-height: 100vh;
display: flex;
align-items: center;
overflow: hidden;
}

.hero-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: radial-gradient(circle at 20% 50%, rgba(127, 176, 105, 0.15) 0%, transparent 50%),
radial-gradient(circle at 80% 50%, rgba(232, 168, 124, 0.15) 0%, transparent 50%);
pointer-events: none;
}

.hero-container {
position: relative;
z-index: 1;
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--spacing-xxl);
align-items: center;
padding: var(--spacing-xxl) var(--spacing-md);
}

.hero-content {
max-width: 600px;
}

.hero-badge {
display: inline-block;
padding: var(--spacing-xs) var(--spacing-md);
background: rgba(127, 176, 105, 0.2);
border: 1px solid rgba(127, 176, 105, 0.4);
border-radius: 50px;
color: var(--color-secondary);
font-size: var(--font-size-small);
font-weight: var(--font-weight-bold);
text-transform: uppercase;
letter-spacing: 1px;
margin-bottom: var(--spacing-md);
animation: fadeInDown 0.8s ease;
}

.hero-title {
font-size: 64px;
line-height: 1.1;
margin-bottom: var(--spacing-md);
color: var(--color-background);
}

.hero-title-line {
display: block;
animation: fadeInUp 0.8s ease;
}

.hero-title-line:nth-child(2) {
animation-delay: 0.2s;
}

.hero-title-accent {
background: linear-gradient(135deg, #7fb069 0%, #e8a87c 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}

.hero-description {
font-size: 20px;
line-height: 1.6;
color: rgba(255, 255, 255, 0.9);
margin-bottom: var(--spacing-lg);
animation: fadeInUp 0.8s ease 0.4s both;
}

.hero-actions {
display: flex;
gap: var(--spacing-sm);
margin-bottom: var(--spacing-xl);
animation: fadeInUp 0.8s ease 0.6s both;
}

.cta-primary {
background-color: var(--color-secondary);
color: var(--color-primary-dark);
padding: var(--spacing-sm) var(--spacing-lg);
border-radius: var(--radius-medium);
font-weight: var(--font-weight-bold);
text-decoration: none;
transition: all var(--transition-medium);
box-shadow: 0 4px 20px rgba(127, 176, 105, 0.3);
}

.cta-primary:hover {
background-color: var(--color-accent);
transform: translateY(-3px);
box-shadow: 0 8px 30px rgba(232, 168, 124, 0.4);
}

.cta-secondary {
background-color: transparent;
color: var(--color-background);
padding: var(--spacing-sm) var(--spacing-lg);
border: 2px solid rgba(255, 255, 255, 0.3);
border-radius: var(--radius-medium);
font-weight: var(--font-weight-bold);
text-decoration: none;
transition: all var(--transition-medium);
}

.cta-secondary:hover {
background-color: rgba(255, 255, 255, 0.1);
border-color: var(--color-background);
transform: translateY(-3px);
}

.hero-stats {
display: flex;
gap: var(--spacing-lg);
animation: fadeInUp 0.8s ease 0.8s both;
}

.hero-stat {
display: flex;
flex-direction: column;
}

.stat-number {
font-size: 36px;
font-weight: var(--font-weight-bold);
color: var(--color-secondary);
line-height: 1;
margin-bottom: var(--spacing-xs);
}

.stat-label {
font-size: var(--font-size-small);
color: rgba(255, 255, 255, 0.7);
text-transform: uppercase;
letter-spacing: 0.5px;
}

.hero-visual {
position: relative;
height: 500px;
animation: fadeIn 1s ease 0.5s both;
}

.hero-image-wrapper {
position: relative;
width: 100%;
height: 100%;
}

.hero-floating-card {
position: absolute;
background: rgba(255, 255, 255, 0.95);
backdrop-filter: blur(10px);
padding: var(--spacing-md);
border-radius: var(--radius-large);
box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
display: flex;
align-items: center;
gap: var(--spacing-sm);
color: var(--color-text);
font-weight: var(--font-weight-medium);
animation: float 3s ease-in-out infinite;
}

.hero-floating-card svg {
flex-shrink: 0;
}

.card-1 {
top: 10%;
left: 10%;
animation-delay: 0s;
}

.card-2 {
top: 50%;
right: 10%;
animation-delay: 1s;
}

.card-3 {
bottom: 15%;
left: 20%;
animation-delay: 2s;
}

.hero-scroll {
position: absolute;
bottom: var(--spacing-lg);
left: 50%;
transform: translateX(-50%);
display: flex;
flex-direction: column;
align-items: center;
gap: var(--spacing-xs);
color: rgba(255, 255, 255, 0.7);
font-size: var(--font-size-small);
animation: bounce 2s ease-in-out infinite;
}

@keyframes fadeInDown {
from {
opacity: 0;
transform: translateY(-20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}

@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}

@keyframes fadeIn {
from {
opacity: 0;
}
to {
opacity: 1;
}
}

@keyframes float {
0%, 100% {
transform: translateY(0);
}
50% {
transform: translateY(-20px);
}
}

@keyframes bounce {
0%, 100% {
transform: translateX(-50%) translateY(0);
}
50% {
transform: translateX(-50%) translateY(-10px);
}
}

.grid-3 {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: var(--spacing-lg);
}

.section-header {
text-align: center;
margin-bottom: var(--spacing-xl);
}

.section-badge {
display: inline-block;
padding: var(--spacing-xs) var(--spacing-md);
background: rgba(127, 176, 105, 0.1);
border: 1px solid rgba(127, 176, 105, 0.3);
border-radius: 50px;
color: var(--color-secondary);
font-size: var(--font-size-small);
font-weight: var(--font-weight-bold);
text-transform: uppercase;
letter-spacing: 1px;
margin-bottom: var(--spacing-sm);
}

.section-intro {
max-width: 700px;
margin: 0 auto;
font-size: var(--font-size-large);
color: var(--color-text-light);
}

.community-icon,
.location-icon {
width: 48px;
height: 48px;
margin-bottom: var(--spacing-sm);
}

.cta-section {
background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
color: var(--color-background);
padding: var(--spacing-xxl) 0;
position: relative;
overflow: hidden;
}

.cta-section::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: radial-gradient(circle at 30% 50%, rgba(127, 176, 105, 0.2) 0%, transparent 50%);
pointer-events: none;
}

.cta-content {
position: relative;
z-index: 1;
text-align: center;
max-width: 1000px;
margin: 0 auto;
}

.cta-badge {
display: inline-block;
padding: var(--spacing-xs) var(--spacing-md);
background: rgba(255, 255, 255, 0.2);
border: 1px solid rgba(255, 255, 255, 0.3);
border-radius: 50px;
color: var(--color-background);
font-size: var(--font-size-small);
font-weight: var(--font-weight-bold);
text-transform: uppercase;
letter-spacing: 1px;
margin-bottom: var(--spacing-md);
}

.cta-content h2 {
color: var(--color-background);
font-size: 42px;
margin-bottom: var(--spacing-md);
}

.cta-content > p {
font-size: var(--font-size-large);
color: rgba(255, 255, 255, 0.9);
margin-bottom: var(--spacing-xl);
max-width: 800px;
margin-left: auto;
margin-right: auto;
}

.cta-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-lg);
margin-bottom: var(--spacing-xl);
}

.cta-benefit {
background: rgba(255, 255, 255, 0.1);
backdrop-filter: blur(10px);
padding: var(--spacing-lg);
border-radius: var(--radius-large);
border: 1px solid rgba(255, 255, 255, 0.2);
transition: all var(--transition-medium);
}

.cta-benefit:hover {
background: rgba(255, 255, 255, 0.15);
transform: translateY(-5px);
}

.cta-icon {
margin: 0 auto var(--spacing-sm);
width: 48px;
height: 48px;
}

.cta-benefit h3 {
color: var(--color-background);
font-size: 20px;
margin-bottom: var(--spacing-sm);
}

.cta-benefit p {
color: rgba(255, 255, 255, 0.85);
font-size: var(--font-size-base);
margin: 0;
}

.cta-actions {
display: flex;
justify-content: center;
gap: var(--spacing-sm);
flex-wrap: wrap;
}

.cta-button-large {
padding: var(--spacing-md) var(--spacing-xl);
border-radius: var(--radius-medium);
font-size: var(--font-size-large);
font-weight: var(--font-weight-bold);
text-decoration: none;
transition: all var(--transition-medium);
display: inline-block;
}

.cta-button-large.cta-primary {
background-color: var(--color-secondary);
color: var(--color-primary-dark);
box-shadow: 0 4px 20px rgba(127, 176, 105, 0.3);
}

.cta-button-large.cta-primary:hover {
background-color: var(--color-accent);
transform: translateY(-3px);
box-shadow: 0 8px 30px rgba(232, 168, 124, 0.4);
}

.cta-button-large.cta-outline {
background-color: transparent;
color: var(--color-background);
border: 2px solid rgba(255, 255, 255, 0.5);
}

.cta-button-large.cta-outline:hover {
background-color: rgba(255, 255, 255, 0.1);
border-color: var(--color-background);
transform: translateY(-3px);
}

.benefit-card, .activity-item, .community-card, .season-card, .equipment-card, .location-card, .story-card {
background-color: var(--color-background);
border-radius: var(--radius-large);
overflow: hidden;
box-shadow: var(--shadow-medium);
transition: all var(--transition-medium);
}

.benefit-card:hover, .activity-item:hover, .community-card:hover, .season-card:hover, .equipment-card:hover, .location-card:hover, .story-card:hover {
transform: translateY(-8px);
box-shadow: var(--shadow-hover);
}

.benefit-card img, .activity-item img, .season-card img, .equipment-card img, .story-card img {
width: 100%;
height: auto;
}

.benefit-card h3, .activity-item h3, .community-card h3, .season-card h3, .equipment-card h3, .location-card h3, .story-card h3 {
padding: var(--spacing-md) var(--spacing-md) 0;
}

.benefit-card p, .activity-item p, .community-card p, .season-card p, .equipment-card p, .location-card p, .story-card p {
padding: 0 var(--spacing-md) var(--spacing-md);
color: var(--color-text-light);
}

.benefits {
background-color: var(--color-background-alt);
}

.activities {
background-color: var(--color-background);
}

.activity-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: var(--spacing-md);
}

.nature {
background-color: var(--color-background-alt);
}

.nature-content {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--spacing-xl);
align-items: center;
}

.nature-text ul {
list-style: none;
padding: 0;
}

.nature-text li {
padding-left: var(--spacing-md);
position: relative;
}

.nature-text li::before {
content: "✓";
position: absolute;
left: 0;
color: var(--color-secondary);
font-weight: var(--font-weight-bold);
}

.nature-image img {
border-radius: var(--radius-large);
box-shadow: var(--shadow-large);
}

.community {
background-color: var(--color-background);
}

.community-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-md);
}

.community-card {
padding: var(--spacing-lg);
}

.seasons {
background-color: var(--color-background-alt);
}

.seasons-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-md);
}

.mindfulness {
background-color: var(--color-background);
}

.mindfulness-content {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--spacing-xl);
align-items: center;
}

.mindfulness-image img {
border-radius: var(--radius-large);
box-shadow: var(--shadow-large);
}

.mindfulness-tips {
background-color: var(--color-background-alt);
padding: var(--spacing-md);
border-radius: var(--radius-medium);
margin-top: var(--spacing-md);
}

.mindfulness-tips ul {
margin-bottom: 0;
}

.equipment {
background-color: var(--color-background-alt);
}

.equipment-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-md);
}

.locations {
background-color: var(--color-background);
}

.locations-content p {
text-align: center;
max-width: 800px;
margin: 0 auto var(--spacing-lg);
}

.locations-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-md);
}

.location-card {
padding: var(--spacing-lg);
}

.stories {
background-color: var(--color-background-alt);
}

.stories-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: var(--spacing-lg);
}

.resources {
background-color: var(--color-background);
}

.resources-content {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: var(--spacing-lg);
}

.resource-section {
background-color: var(--color-background-alt);
padding: var(--spacing-lg);
border-radius: var(--radius-medium);
border-left: 4px solid var(--color-secondary);
}

.contact {
background-color: var(--color-background-alt);
}

.contact-wrapper {
display: grid;
grid-template-columns: 1fr 2fr;
gap: var(--spacing-xl);
}

.contact-info {
background-color: var(--color-background);
padding: var(--spacing-lg);
border-radius: var(--radius-medium);
box-shadow: var(--shadow-medium);
}

.contact-form {
background-color: var(--color-background);
padding: var(--spacing-lg);
border-radius: var(--radius-medium);
box-shadow: var(--shadow-medium);
}

.form-group {
margin-bottom: var(--spacing-md);
}

.form-group label {
display: block;
margin-bottom: var(--spacing-xs);
font-weight: var(--font-weight-medium);
color: var(--color-text);
}

.form-group input,
.form-group textarea {
width: 100%;
padding: var(--spacing-sm);
border: 1px solid var(--color-border);
border-radius: var(--radius-small);
font-family: var(--font-primary);
font-size: var(--font-size-base);
transition: border-color var(--transition-fast);
}

.form-group input:focus,
.form-group textarea:focus {
outline: none;
border-color: var(--color-primary);
}

.form-group input.error,
.form-group textarea.error {
border-color: var(--color-error);
}

.error-message {
display: block;
color: var(--color-error);
font-size: var(--font-size-small);
margin-top: var(--spacing-xs);
}

.checkbox-group label {
display: flex;
align-items: flex-start;
gap: var(--spacing-xs);
cursor: pointer;
}

.checkbox-group input[type="checkbox"] {
width: auto;
margin-top: 4px;
}

.btn-primary {
background-color: var(--color-primary);
color: var(--color-background);
padding: var(--spacing-sm) var(--spacing-lg);
border: none;
border-radius: var(--radius-medium);
font-size: var(--font-size-base);
font-weight: var(--font-weight-bold);
cursor: pointer;
transition: all var(--transition-medium);
box-shadow: var(--shadow-small);
}

.btn-primary:hover {
background-color: var(--color-primary-dark);
transform: translateY(-2px);
box-shadow: var(--shadow-medium);
}

.btn-secondary {
background-color: var(--color-background);
color: var(--color-primary);
padding: var(--spacing-sm) var(--spacing-lg);
border: 2px solid var(--color-primary);
border-radius: var(--radius-medium);
font-size: var(--font-size-base);
font-weight: var(--font-weight-bold);
cursor: pointer;
transition: all var(--transition-medium);
}

.btn-secondary:hover {
background-color: var(--color-primary);
color: var(--color-background);
}

.disclaimer {
background-color: var(--color-background-alt);
padding: var(--spacing-lg) 0;
border-top: 1px solid var(--color-border);
}

.disclaimer p {
text-align: center;
color: var(--color-text-light);
font-size: var(--font-size-small);
margin: 0;
}

footer {
background-color: var(--color-primary);
color: var(--color-background);
padding: var(--spacing-lg) 0;
}

.footer-links {
display: flex;
justify-content: center;
flex-wrap: wrap;
gap: var(--spacing-md);
margin-bottom: var(--spacing-md);
}

.footer-links a {
color: var(--color-background);
text-decoration: none;
transition: opacity var(--transition-fast);
}

.footer-links a:hover {
opacity: 0.8;
}

.copyright {
text-align: center;
font-size: var(--font-size-small);
margin: 0;
}

.cookie-banner {
position: fixed;
bottom: 0;
left: 0;
right: 0;
background-color: var(--color-primary);
color: var(--color-background);
padding: var(--spacing-md);
box-shadow: var(--shadow-large);
z-index: 2000;
display: none;
}

.cookie-banner.show {
display: block;
}

.cookie-content {
max-width: var(--container-width);
margin: 0 auto;
display: flex;
justify-content: space-between;
align-items: center;
gap: var(--spacing-md);
}

.cookie-buttons {
display: flex;
gap: var(--spacing-sm);
}

.cookie-modal {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-color: var(--color-overlay);
display: none;
justify-content: center;
align-items: center;
z-index: 3000;
}

.cookie-modal.show {
display: flex;
}

.modal-content {
background-color: var(--color-background);
padding: var(--spacing-xl);
border-radius: var(--radius-large);
max-width: 500px;
width: 90%;
box-shadow: var(--shadow-large);
}

.modal-content h2 {
margin-bottom: var(--spacing-md);
}

.cookie-category {
margin-bottom: var(--spacing-md);
}

.cookie-category label {
display: flex;
align-items: center;
gap: var(--spacing-sm);
cursor: pointer;
}

.modal-buttons {
display: flex;
gap: var(--spacing-sm);
margin-top: var(--spacing-lg);
}

.policy-section {
padding: var(--spacing-xxl) 0;
}

.policy-content {
max-width: 900px;
margin: 0 auto;
}

.policy-content h2 {
margin-top: var(--spacing-xl);
}

.policy-content h3 {
margin-top: var(--spacing-lg);
}

.policy-content table {
width: 100%;
border-collapse: collapse;
margin: var(--spacing-md) 0;
}

.policy-content th,
.policy-content td {
padding: var(--spacing-sm);
border: 1px solid var(--color-border);
text-align: left;
}

.policy-content th {
background-color: var(--color-background-alt);
font-weight: var(--font-weight-bold);
}

.thank-you-section {
min-height: 60vh;
display: flex;
align-items: center;
justify-content: center;
}

.thank-you-content {
text-align: center;
max-width: 600px;
padding: var(--spacing-xl);
background-color: var(--color-background-alt);
border-radius: var(--radius-large);
box-shadow: var(--shadow-medium);
}

.thank-you-content h1 {
color: var(--color-primary);
margin-bottom: var(--spacing-md);
}

.thank-you-content p {
font-size: var(--font-size-large);
margin-bottom: var(--spacing-md);
}

@media (max-width: 768px) {
:root {
--font-size-h1: 36px;
--font-size-h2: 28px;
--font-size-h3: 20px;
--spacing-xxl: 48px;
}

header .container {
flex-direction: column;
gap: var(--spacing-sm);
padding: var(--spacing-sm);
}

.brand {
font-size: var(--font-size-base);
}

nav {
flex-wrap: wrap;
justify-content: center;
gap: var(--spacing-xs);
width: 100%;
}

nav a {
font-size: 14px;
padding: 4px 8px;
}

.hero {
min-height: auto;
padding: var(--spacing-xl) 0;
}

.hero-container {
grid-template-columns: 1fr;
gap: var(--spacing-lg);
padding: var(--spacing-lg) var(--spacing-sm);
}

.hero-title {
font-size: 36px;
}

.hero-description {
font-size: 16px;
}

.hero-visual {
height: 300px;
}

.hero-stats {
flex-wrap: wrap;
gap: var(--spacing-md);
justify-content: center;
}

.hero-actions {
flex-direction: column;
width: 100%;
}

.hero-actions a {
text-align: center;
width: 100%;
}

.cta-content h2 {
font-size: 28px;
}

.cta-grid {
grid-template-columns: 1fr;
}

.cta-actions {
flex-direction: column;
width: 100%;
}

.cta-button-large {
width: 100%;
text-align: center;
}

.nature-content,
.mindfulness-content,
.contact-wrapper {
grid-template-columns: 1fr;
}

.cookie-content {
flex-direction: column;
text-align: center;
}

.cookie-buttons {
flex-direction: column;
width: 100%;
}

.cookie-buttons button {
width: 100%;
}

.footer-links {
flex-direction: column;
align-items: center;
gap: var(--spacing-sm);
}

.section-intro {
font-size: var(--font-size-base);
}
}

@media (max-width: 480px) {
:root {
--font-size-h1: 28px;
--font-size-h2: 24px;
--font-size-h3: 18px;
--font-size-base: 15px;
--spacing-md: 16px;
--spacing-lg: 24px;
--spacing-xl: 32px;
--spacing-xxl: 40px;
}

.container {
padding: 0 var(--spacing-sm);
}

header .container {
padding: var(--spacing-xs) var(--spacing-sm);
}

.brand {
font-size: 15px;
}

nav a {
font-size: 13px;
padding: 4px 6px;
}

.hero-title {
font-size: 28px;
}

.hero-description {
font-size: 15px;
}

.hero-badge,
.section-badge,
.cta-badge {
font-size: 11px;
padding: 6px 12px;
}

.stat-number {
font-size: 24px;
}

.stat-label {
font-size: 12px;
}

.hero-visual {
height: 250px;
}

.hero-floating-card {
padding: var(--spacing-xs);
font-size: 12px;
}

.hero-floating-card svg {
width: 30px;
height: 30px;
}

.cta-content h2 {
font-size: 24px;
}

.cta-content > p {
font-size: var(--font-size-base);
}

.cta-benefit h3 {
font-size: 16px;
}

.cta-benefit p {
font-size: 14px;
}

.grid-3,
.activity-grid,
.community-grid,
.seasons-grid,
.equipment-grid,
.locations-grid,
.stories-grid,
.resources-content {
grid-template-columns: 1fr;
}

.benefit-card h3,
.activity-item h3,
.community-card h3,
.season-card h3,
.equipment-card h3,
.location-card h3,
.story-card h3 {
font-size: 18px;
}

.benefit-card p,
.activity-item p,
.community-card p,
.season-card p,
.equipment-card p,
.location-card p,
.story-card p {
font-size: 14px;
}

section {
padding: var(--spacing-xl) 0;
}

.section-header {
margin-bottom: var(--spacing-lg);
}

h2 {
font-size: 24px;
}

h3 {
font-size: 18px;
}

h4 {
font-size: 16px;
}

.contact-form,
.contact-info {
padding: var(--spacing-md);
}

.form-group label {
font-size: 14px;
}

.form-group input,
.form-group textarea {
font-size: 14px;
padding: 10px;
}

.btn-primary,
.btn-secondary {
padding: 12px var(--spacing-md);
font-size: 14px;
}

.modal-content {
padding: var(--spacing-lg);
width: 95%;
}

.footer-links a {
font-size: 14px;
}

.copyright {
font-size: 12px;
}
}

@media (max-width: 375px) {
:root {
--font-size-h1: 26px;
--font-size-h2: 22px;
--font-size-h3: 17px;
--font-size-base: 14px;
--spacing-sm: 12px;
--spacing-md: 14px;
--spacing-lg: 20px;
--spacing-xl: 28px;
--spacing-xxl: 36px;
}

.hero-title {
font-size: 26px;
}

.hero-description {
font-size: 14px;
}

.stat-number {
font-size: 22px;
}

.cta-content h2 {
font-size: 22px;
}

.hero-floating-card {
padding: 6px;
font-size: 11px;
}

.hero-floating-card svg {
width: 24px;
height: 24px;
}
}

@media (max-width: 320px) {
:root {
--font-size-h1: 24px;
--font-size-h2: 20px;
--font-size-h3: 16px;
--font-size-base: 14px;
--font-size-small: 12px;
--spacing-xs: 6px;
--spacing-sm: 10px;
--spacing-md: 12px;
--spacing-lg: 18px;
--spacing-xl: 24px;
--spacing-xxl: 32px;
}

.container {
padding: 0 10px;
}

header .container {
padding: 8px 10px;
}

.brand {
font-size: 14px;
}

nav {
gap: 6px;
}

nav a {
font-size: 12px;
padding: 3px 5px;
}

.hero-container {
padding: var(--spacing-lg) 10px;
}

.hero-title {
font-size: 24px;
line-height: 1.2;
}

.hero-description {
font-size: 14px;
line-height: 1.5;
}

.hero-badge,
.section-badge,
.cta-badge {
font-size: 10px;
padding: 5px 10px;
letter-spacing: 0.5px;
}

.hero-actions a {
padding: 12px var(--spacing-md);
font-size: 14px;
}

.stat-number {
font-size: 20px;
}

.stat-label {
font-size: 11px;
}

.hero-visual {
height: 200px;
}

.hero-floating-card {
padding: 5px;
font-size: 10px;
gap: 4px;
}

.hero-floating-card svg {
width: 20px;
height: 20px;
}

.hero-scroll {
font-size: 11px;
}

.hero-scroll svg {
width: 18px;
height: 18px;
}

section {
padding: var(--spacing-lg) 0;
}

.section-header {
margin-bottom: var(--spacing-md);
}

h2 {
font-size: 20px;
margin-bottom: var(--spacing-sm);
}

h3 {
font-size: 16px;
margin-bottom: 8px;
}

h4 {
font-size: 15px;
}

p {
font-size: 14px;
line-height: 1.5;
margin-bottom: 12px;
}

.section-intro {
font-size: 14px;
}

.cta-content h2 {
font-size: 20px;
}

.cta-content > p {
font-size: 14px;
}

.cta-benefit {
padding: var(--spacing-md);
}

.cta-benefit h3 {
font-size: 15px;
}

.cta-benefit p {
font-size: 13px;
}

.cta-icon {
width: 40px;
height: 40px;
}

.cta-icon svg {
width: 40px;
height: 40px;
}

.cta-button-large {
padding: 12px var(--spacing-md);
font-size: 14px;
}

.benefit-card,
.activity-item,
.community-card,
.season-card,
.equipment-card,
.location-card,
.story-card {
margin-bottom: var(--spacing-md);
}

.benefit-card h3,
.activity-item h3,
.community-card h3,
.season-card h3,
.equipment-card h3,
.location-card h3,
.story-card h3 {
font-size: 16px;
padding: var(--spacing-sm) var(--spacing-sm) 0;
}

.benefit-card p,
.activity-item p,
.community-card p,
.season-card p,
.equipment-card p,
.location-card p,
.story-card p {
font-size: 13px;
line-height: 1.5;
padding: 0 var(--spacing-sm) var(--spacing-sm);
}

.community-card,
.location-card {
padding: var(--spacing-md);
}

.community-icon,
.location-icon {
width: 40px;
height: 40px;
}

.community-icon svg,
.location-icon svg {
width: 40px;
height: 40px;
}

.grid-3,
.activity-grid,
.community-grid,
.seasons-grid,
.equipment-grid,
.locations-grid,
.stories-grid,
.resources-content,
.cta-grid {
gap: var(--spacing-md);
}

.nature-text ul,
.mindfulness-tips ul {
padding-left: var(--spacing-lg);
}

.nature-text li,
.mindfulness-tips li {
font-size: 13px;
margin-bottom: 6px;
}

.mindfulness-tips {
padding: var(--spacing-sm);
}

.resource-section {
padding: var(--spacing-md);
}

.resource-section h3 {
font-size: 16px;
}

.resource-section p {
font-size: 13px;
}

.contact-wrapper {
gap: var(--spacing-md);
}

.contact-form,
.contact-info {
padding: var(--spacing-sm);
}

.contact-info h3 {
font-size: 16px;
}

.contact-info p {
font-size: 13px;
}

.form-group {
margin-bottom: var(--spacing-sm);
}

.form-group label {
font-size: 13px;
margin-bottom: 4px;
}

.form-group input,
.form-group textarea {
font-size: 13px;
padding: 8px;
}

.btn-primary,
.btn-secondary {
padding: 10px var(--spacing-sm);
font-size: 13px;
}

.disclaimer p {
font-size: 12px;
padding: 0 10px;
}

.footer-links {
gap: 8px;
}

.footer-links a {
font-size: 13px;
}

.copyright {
font-size: 11px;
}

.cookie-banner {
padding: var(--spacing-sm);
}

.cookie-content {
gap: var(--spacing-sm);
}

.cookie-content p {
font-size: 13px;
}

.cookie-buttons {
gap: 6px;
}

.cookie-buttons button {
font-size: 13px;
padding: 8px var(--spacing-sm);
}

.modal-content {
padding: var(--spacing-md);
width: 95%;
max-width: 280px;
}

.modal-content h2 {
font-size: 18px;
}

.cookie-category label {
font-size: 13px;
}

.modal-buttons {
gap: 6px;
}

.modal-buttons button {
font-size: 13px;
padding: 8px var(--spacing-sm);
}

.thank-you-content {
padding: var(--spacing-lg);
}

.thank-you-content h1 {
font-size: 22px;
}

.thank-you-content p {
font-size: 14px;
}

.thank-you-icon svg {
width: 60px;
height: 60px;
}

.policy-content {
padding: 0 10px;
}

.policy-content h2 {
font-size: 20px;
margin-top: var(--spacing-lg);
}

.policy-content h3 {
font-size: 16px;
margin-top: var(--spacing-md);
}

.policy-content p,
.policy-content li {
font-size: 13px;
}

.policy-content table {
font-size: 12px;
}

.policy-content th,
.policy-content td {
padding: 6px;
}
}
