/*
Theme Name: BlankSlate
Theme URI: https://opencollective.com/blankslate
Author: Web Guy
Author URI: https://opencollective.com/blankslate#section-contributors
Description: Donate: https://opencollective.com/blankslate. Learn: https://blankslate.me/. BlankSlate is the definitive WordPress boilerplate starter theme. I've carefully constructed the most clean and minimalist theme possible for designers and developers to use as a base to build websites for clients or to build completely custom themes from scratch. Clean, simple, unstyled, semi-minified, unformatted, and valid code, SEO-friendly, jQuery-enabled, no programmer comments, standardized and as white label as possible, and most importantly, the CSS is reset for cross-browser-compatability, with no intrusive visual CSS styles added whatsoever. A perfect skeleton theme. For support and suggestions, go to: https://github.com/webguyio/blankslate/issues. Thank you.
Tags: accessibility-ready, one-column, two-columns, custom-menu, featured-images, microformats, sticky-post, threaded-comments, translation-ready
Version: 2026
Requires at least: 5.2
Tested up to: 6.8
Requires PHP: 7.4
License: GNU General Public License v3 or Later
License URI: https://www.gnu.org/licenses/gpl.html
Text Domain: blankslate

BlankSlate WordPress Theme 2011-2026
BlankSlate is distributed under the terms of the GNU GPL
*/

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}html{scroll-behavior:smooth}body{line-height:1}a{text-decoration-skip-ink:auto}a[href^="tel"]{color:inherit;text-decoration:none}button{outline:0}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:'';content:none}q{display:inline;font-style:italic}q:before{content:'"';font-style:normal}q:after{content:'"';font-style:normal}textarea,input[type="text"],input[type="button"],input[type="submit"],input[type="reset"],input[type="search"],input[type="password"]{appearance:none;border-radius:0}input[type="search"]{appearance:textfield}table{border-collapse:collapse;border-spacing:0}th,td{padding:2px}big{font-size:120%}small,sup,sub{font-size:80%}sup{vertical-align:super}sub{vertical-align:sub}dd{margin-left:20px}kbd,tt{font-family:courier;font-size:12px}ins{text-decoration:underline}del,strike,s{text-decoration:line-through}dt{font-weight:bold}address,cite,var{font-style:italic}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}

.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute!important;width:1px;word-wrap:normal!important;word-break:normal}
.screen-reader-text:focus{background-color:#f7f7f7;border-radius:3px;box-shadow:0 0 2px 2px rgba(0,0,0,.6);clip:auto!important;clip-path:none;color:#007acc;display:block;font-size:14px;font-size:.875rem;font-weight:700;height:auto;right:5px;line-height:normal;padding:15px 23px 14px;text-decoration:none;top:5px;width:auto;z-index:100000}
.skip-link{left:-9999rem;top:2.5rem;z-index:999999999;text-decoration:underline}
.skip-link:focus{display:block;left:6px;top:7px;font-size:14px;font-weight:600;text-decoration:none;line-height:normal;padding:15px 23px 14px;z-index:100000;right:auto}
.visually-hidden:not(:focus):not(:active), .form-allowed-tags:not(:focus):not(:active){position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}

/* ========================================
   RAGEROOM - Custom Styles
   ======================================== */

:root {
	--color-primary: #E08D4A;
	--color-dark: #2a2420;
	--color-text: #b8b8b8;
	--color-white: #ffffff;
}

body {
	background-color: var(--color-dark);
	color: var(--color-text);
	font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
	font-size: 16px;
	line-height: 1.6;
}

/* Header & Navigation */
header#header {
	background-color: var(--color-dark);
	padding: 1.5rem 0;
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
	position: sticky;
	top: 0;
	z-index: 100;
}

.header-wrapper {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 2rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	position: relative;
}

#branding {
	flex-shrink: 0;
	text-align: center;
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0;
}

#branding a {
	color: var(--color-white);
	text-decoration: none;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

#branding span {
	font-size: 1.4rem;
	font-weight: bold;
	letter-spacing: 2px;
}

#site-title {
	margin: 0;
}

#site-description {
	display: none;
}

nav#menu {
	flex: 1;
	display: flex;
	justify-content: center;
	gap: 2rem;
	flex-wrap: wrap;
}

nav#menu ul {
	display: flex;
	gap: 2rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

nav#menu li {
	list-style: none;
	margin: 0;
	padding: 0;
}

nav#menu a {
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.95rem;
	transition: all 0.3s ease;
	padding: 0.5rem 0;
	border-bottom: 2px solid transparent;
	white-space: nowrap;
}

nav#menu a:hover {
	color: var(--color-primary);
	border-bottom-color: var(--color-primary);
}

#search {
	display: none;
}

.header-cta {
	flex-shrink: 0;
}

.btn-reserve {
	display: inline-block;
	background-color: var(--color-primary);
	color: var(--color-dark);
	padding: 0.75rem 1.5rem;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	letter-spacing: 1px;
	transition: all 0.3s ease;
	border: 2px solid var(--color-primary);
	border-radius: 4px;
	white-space: nowrap;
}

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

/* Menu Burger Button */
/* Hero Section */
.rageroom-hero {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 4rem 2rem;
	min-height: calc(100vh - 150px);
	display: flex;
	align-items: center;
	justify-content: center;
}

.hero-content {
	max-width: 1200px;
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: center;
}

.hero-text {
	padding: 2rem;
}

.hero-badge {
	display: inline-block;
	border: 2px solid var(--color-primary);
	color: var(--color-primary);
	padding: 0.5rem 1rem;
	font-size: 0.85rem;
	letter-spacing: 1px;
	margin-bottom: 1.5rem;
	font-weight: 600;
}

.hero-title {
	font-size: 4rem;
	font-weight: 900;
	line-height: 1.1;
	margin: 0 0 0.5rem 0;
	letter-spacing: -1px;
}

.hero-title .orange {
	color: var(--color-primary);
}

.hero-subtitle {
	font-size: 2rem;
	color: var(--color-text);
	font-weight: 300;
	margin: 0 0 1.5rem 0;
	letter-spacing: 1px;
}

.hero-description {
	color: var(--color-text);
	font-size: 1rem;
	line-height: 1.8;
	margin-bottom: 1.5rem;
	max-width: 500px;
}

.hero-description strong {
	color: var(--color-primary);
	font-weight: 600;
}

.hero-feature {
	background: rgba(224, 141, 74, 0.1);
	border-left: 3px solid var(--color-primary);
	padding: 1.5rem;
	margin-bottom: 2rem;
	border-radius: 4px;
}

.feature-icon {
	font-size: 1.5rem;
	margin-right: 0.5rem;
}

.hero-feature p {
	margin: 0;
	font-size: 0.95rem;
	color: var(--color-text);
}

.hero-feature strong {
	color: var(--color-primary);
}

/* Buttons */
.hero-buttons {
	display: flex;
	gap: 1.5rem;
	flex-wrap: wrap;
}

.btn {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 1rem 2rem;
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	border: 2px solid transparent;
	cursor: pointer;
	transition: all 0.3s ease;
	letter-spacing: 1px;
	white-space: nowrap;
}

.btn-primary {
	background-color: var(--color-primary);
	color: var(--color-dark);
	border-color: var(--color-primary);
}

.btn-primary:hover {
	background-color: transparent;
	color: var(--color-primary);
	box-shadow: inset 0 0 0 2px var(--color-primary);
}

.btn-secondary {
	background-color: transparent;
	color: var(--color-text);
	border-color: var(--color-primary);
}

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

/* Images Section */
.hero-images {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	align-items: center;
	justify-content: center;
}

.image-card {
	position: relative;
	border: 3px solid var(--color-primary);
	overflow: hidden;
	background: linear-gradient(135deg, rgba(224, 141, 74, 0.3) 0%, rgba(224, 141, 74, 0.1) 100%);
	min-height: 300px;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}

.image-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.image-card.defoulement {
	width: 280px;
	height: 350px;
	margin-right: auto;
}

.image-card.securite {
	width: 280px;
	height: 350px;
	margin-left: auto;
}

.image-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(224, 141, 74, 0.2) 0%, rgba(224, 141, 74, 0.05) 100%);
	color: var(--color-primary);
	font-size: 1.1rem;
	font-weight: 600;
	text-align: center;
	padding: 2rem;
	line-height: 1.4;
}

.image-placeholder small {
	font-size: 0.8rem;
	color: var(--color-text);
	margin-top: 0.5rem;
	display: block;
}

.card-label {
	position: absolute;
	bottom: 2rem;
	left: 0;
	font-size: 1.5rem;
	font-weight: 900;
	color: var(--color-primary);
	letter-spacing: 2px;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.8);
	padding: 0 1.5rem;
}

.card-duration, .card-security {
	position: absolute;
	bottom: 0.5rem;
	left: 1.5rem;
	font-size: 0.85rem;
	color: var(--color-white);
	margin: 0;
	text-shadow: 0 1px 5px rgba(0, 0, 0, 0.8);
}

/* Main container & footer */
#wrapper {
	background-color: var(--color-dark);
}

#container {
	max-width: 1400px;
	margin: 0 auto;
	padding: 0;
}

footer#footer {
	background-color: var(--color-dark);
	border-top: 1px solid rgba(224, 141, 74, 0.2);
	padding: 2rem;
	text-align: center;
	color: var(--color-text);
	margin-top: 4rem;
}

#copyright {
	font-size: 0.9rem;
	color: var(--color-text);
}

/* Benefits Section */
.poste-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 4rem 2rem;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
	text-align: center;
}

.poste-container {
	max-width: 1400px;
	margin: 0 auto;
}

.poste-header {
	font-size: 0.95rem;
	color: var(--color-text);
	letter-spacing: 2px;
	margin-bottom: 2rem;
	text-transform: uppercase;
}

.poste-title {
	font-size: 2.5rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1.5rem 0;
	letter-spacing: 1px;
}

.poste-title .orange {
	color: var(--color-primary);
}

.poste-description {
	font-size: 1rem;
	color: var(--color-text);
	max-width: 700px;
	margin: 0 auto 2rem;
	line-height: 1.8;
	letter-spacing: 0.5px;
}

.poste-description .orange {
	color: var(--color-primary);
	font-weight: 600;
}

.btn-discover {
	display: inline-block;
	background-color: transparent;
	color: var(--color-text);
	border: 2px solid var(--color-primary);
	padding: 0.75rem 2rem;
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	letter-spacing: 1px;
	transition: all 0.3s ease;
	margin-bottom: 3rem;
	white-space: nowrap;
}

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

.stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.5rem;
	margin-top: 2rem;
}

.stat-card {
	border: 2px solid rgba(224, 141, 74, 0.2);
	padding: 2rem;
	background: rgba(224, 141, 74, 0.05);
	transition: all 0.3s ease;
}

.stat-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
}

.stat-number {
	font-size: 2.5rem;
	font-weight: 900;
	color: var(--color-primary);
	margin-bottom: 0.5rem;
	letter-spacing: 1px;
}

.stat-label {
	font-size: 0.85rem;
	color: var(--color-text);
	letter-spacing: 1px;
	text-transform: uppercase;
	font-weight: 600;
}

/* Experience Section */
.experience-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 4rem 2rem;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.experience-container {
	max-width: 1400px;
	margin: 0 auto;
}

.experience-title {
	font-size: 2.5rem;
	font-weight: 900;
	text-align: center;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	letter-spacing: 1px;
}

.experience-title .orange {
	color: var(--color-primary);
}

.experience-subtitle {
	text-align: center;
	color: var(--color-text);
	font-size: 1rem;
	margin-bottom: 3rem;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
	line-height: 1.6;
}

.experience-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
}

.experience-card {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 2rem;
	text-align: center;
	transition: all 0.3s ease;
	background: rgba(224, 141, 74, 0.05);
}

.experience-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-5px);
}

.experience-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
	display: block;
}

.experience-card h3 {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 1rem 0;
	letter-spacing: 0.5px;
}

.experience-card p {
	color: var(--color-text);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

/* Benefits Section */
.benefits-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.8) 0%, rgba(52, 44, 38, 0.8) 100%);
	padding: 4rem 2rem;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
}

.benefits-container {
	max-width: 1400px;
	margin: 0 auto;
}

.benefits-title {
	font-size: 2.5rem;
	font-weight: 900;
	text-align: center;
	margin: 0 0 0.5rem 0;
	color: var(--color-white);
	letter-spacing: 2px;
}

.benefits-title .orange {
	color: var(--color-primary);
}

.benefits-subtitle {
	text-align: center;
	color: var(--color-text);
	font-size: 1rem;
	margin-bottom: 3rem;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
	line-height: 1.6;
}

.benefits-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
}

.benefit-card {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 2rem;
	text-align: center;
	transition: all 0.3s ease;
	background: rgba(224, 141, 74, 0.05);
}

.benefit-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-5px);
}

.benefit-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
	display: block;
}

.benefit-card h3 {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 1rem 0;
	letter-spacing: 0.5px;
}

.benefit-card p {
	color: var(--color-text);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

/* Reservation Section */
.reservation-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 3rem 2rem;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
}

.reservation-container {
	max-width: 1200px;
	margin: 0 auto;
}

.reservation-grid {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 2rem;
	align-items: center;
}

.reservation-card {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 2.5rem 2rem;
	text-align: center;
	position: relative;
	background: rgba(224, 141, 74, 0.05);
	transition: all 0.3s ease;
	min-height: 280px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.reservation-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-5px);
}

.card-badge {
	font-size: 0.8rem;
	color: var(--color-primary);
	letter-spacing: 2px;
	text-transform: uppercase;
	font-weight: 700;
	margin-bottom: 1rem;
}

.combo-badge {
	font-size: 0.8rem;
	color: var(--color-primary);
	letter-spacing: 2px;
	text-transform: uppercase;
	font-weight: 700;
	margin-bottom: 1rem;
	background: rgba(224, 141, 74, 0.2);
	padding: 0.5rem 1rem;
	display: inline-block;
	border-radius: 4px;
}

.card-title {
	font-size: 2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0.5rem 0 1rem 0;
	letter-spacing: 1px;
}

.card-title .orange {
	color: var(--color-primary);
}

.card-description {
	color: var(--color-text);
	font-size: 0.95rem;
	line-height: 1.6;
	margin-bottom: 1.5rem;
	flex-grow: 1;
}

.btn-reserve-card {
	display: inline-block;
	background-color: var(--color-primary);
	color: var(--color-dark);
	padding: 0.8rem 2rem;
	font-size: 0.9rem;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 1px;
	border: 2px solid var(--color-primary);
	transition: all 0.3s ease;
	white-space: nowrap;
}

.btn-reserve-card:hover {
	background-color: transparent;
	color: var(--color-primary);
}

.btn-combo {
	display: inline-block;
	background-color: var(--color-primary);
	color: var(--color-dark);
	padding: 0.8rem 2rem;
	font-size: 0.9rem;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 1px;
	border: 2px solid var(--color-primary);
	transition: all 0.3s ease;
	white-space: nowrap;
	margin-bottom: 1rem;
}

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

.link-tarifs {
	display: inline-block;
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.9rem;
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 0.5rem 1rem;
	transition: all 0.3s ease;
}

.link-tarifs:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.reservation-plus {
	font-size: 2.5rem;
	color: var(--color-primary);
	font-weight: 900;
	text-align: center;
	letter-spacing: 1px;
}

/* Location Section */
.location-section {
	background: rgba(42, 36, 32, 0.8);
	border-top: 1px solid rgba(224, 141, 74, 0.2);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
	padding: 2.5rem 2rem;
}

.location-container {
	max-width: 1200px;
	margin: 0 auto;
	text-align: center;
}

.location-title {
	font-size: 1.3rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 0 0 0.5rem 0;
	letter-spacing: 0.5px;
}

.location-subtitle {
	color: var(--color-text);
	font-size: 0.95rem;
	margin-bottom: 1.5rem;
}

.location-items {
	display: flex;
	justify-content: center;
	gap: 2rem;
	flex-wrap: wrap;
}

.location-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: var(--color-text);
	font-size: 0.95rem;
}

.location-icon {
	font-size: 1.1rem;
}

.contact-link {
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 600;
	transition: all 0.3s ease;
}

.contact-link:hover {
	opacity: 0.8;
	text-decoration: underline;
}

/* Footer Styles */
footer#footer {
	background-color: var(--color-dark);
	border-top: 1px solid rgba(224, 141, 74, 0.2);
	margin-top: 4rem;
}

.footer-main {
	padding: 3rem 2rem;
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.footer-container {
	max-width: 1400px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3rem;
}

.footer-column {
	text-align: left;
}

.footer-branding {
	text-align: left;
}

.footer-logo {
	font-size: 1.5rem;
	font-weight: 900;
	letter-spacing: 2px;
	margin-bottom: 1rem;
}

.footer-logo .rage {
	color: var(--color-white);
}

.footer-logo .room {
	color: var(--color-primary);
}

.footer-tagline {
	color: var(--color-text);
	font-size: 0.9rem;
	line-height: 1.6;
	margin: 0;
}

.footer-title {
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--color-white);
	letter-spacing: 2px;
	text-transform: uppercase;
	margin: 0 0 1.5rem 0;
}

.footer-links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-links li {
	margin-bottom: 0.8rem;
}

.footer-links a {
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.95rem;
	transition: color 0.3s ease;
}

.footer-links a:hover {
	color: var(--color-primary);
}

.footer-contact-item {
	display: flex;
	align-items: flex-start;
	gap: 0.8rem;
	margin-bottom: 1rem;
	font-size: 0.95rem;
}

.contact-icon {
	font-size: 1.2rem;
	flex-shrink: 0;
}

.footer-contact-item a {
	color: var(--color-text);
	text-decoration: none;
	transition: color 0.3s ease;
}

.footer-contact-item a:hover {
	color: var(--color-primary);
}

.footer-contact-item span:not(.contact-icon) {
	color: var(--color-text);
}

/* Footer Bottom */
.footer-bottom {
	background: rgba(224, 141, 74, 0.05);
	padding: 2rem;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
}

.footer-bottom .footer-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 2rem;
}

.footer-copyright {
	font-size: 0.85rem;
	color: var(--color-text);
	margin: 0;
}

.author-link {
	color: var(--color-primary);
	font-weight: 600;
	text-decoration: none;
	transition: all 0.3s ease;
	border-bottom: 2px solid var(--color-primary);
}

.author-link:hover {
	color: #ffb366;
}

.footer-tagline-bottom {
	font-size: 0.85rem;
	color: var(--color-text);
	text-align: right;
	font-weight: 600;
}

/* Footer Legal Links */
.footer-legal-links {
	flex: 1;
	display: flex;
	justify-content: center;
	gap: 2rem;
}

.footer-legal-list {
	display: flex;
	gap: 2rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-legal-list li {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-legal-list a {
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.85rem;
	transition: all 0.3s ease;
	padding: 0.5rem 0;
	border-bottom: 2px solid transparent;
	white-space: nowrap;
}

.footer-legal-list a:hover {
	color: var(--color-primary);
	border-bottom-color: var(--color-primary);
}

/* Mentions Légales, CGV, Politique de Confidentialité Pages */
.mentions-intro-section,
.cgv-intro-section,
.privacy-intro-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 4rem 2rem;
	text-align: center;
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.mentions-hero,
.cgv-hero,
.privacy-hero {
	max-width: 800px;
	margin: 0 auto;
}

.mentions-hero-title,
.cgv-hero-title,
.privacy-hero-title {
	font-size: 2.8rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0;
	letter-spacing: 1px;
}

.mentions-hero-title .orange,
.cgv-hero-title .orange,
.privacy-hero-title .orange {
	color: var(--color-primary);
}

/* Legal Pages Content */
.legal-info-section,
.cgv-content-section,
.privacy-content-section {
	padding: 3rem 2rem;
}

.mentions-container,
.cgv-container,
.privacy-container {
	max-width: 1000px;
	margin: 0 auto;
}

.legal-content,
.cgv-content,
.privacy-content {
	color: var(--color-text);
	line-height: 1.8;
}

.legal-block {
	background: rgba(224, 141, 74, 0.05);
	border: 1px solid rgba(224, 141, 74, 0.1);
	padding: 2rem;
	border-radius: 8px;
	margin-bottom: 2rem;
}

.legal-item {
	margin-bottom: 2rem;
}

.legal-item:last-child {
	margin-bottom: 0;
}

.legal-item h3,
.cgv-article h3,
.privacy-article h3 {
	color: var(--color-primary);
	font-size: 1.1rem;
	margin: 1rem 0 0.5rem 0;
}

.cgv-article,
.privacy-article {
	margin-bottom: 2.5rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid rgba(224, 141, 74, 0.1);
}

.cgv-article:last-child,
.privacy-article:last-child {
	border-bottom: none;
}

.cgv-article h2,
.privacy-article h2 {
	color: var(--color-white);
	font-size: 1.5rem;
	margin: 0 0 1rem 0;
}

.cgv-article ul,
.privacy-article ul {
	margin-left: 1.5rem;
}

.cgv-article li,
.privacy-article li {
	margin-bottom: 0.5rem;
	color: var(--color-text);
}

.cgv-date {
	color: var(--color-primary);
	font-size: 0.95rem;
	margin-bottom: 2rem;
}

/* Responsive Footer */
@media (max-width: 768px) {
	.footer-main {
		padding: 2rem;
	}

	.footer-container {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.footer-column {
		text-align: left;
	}

	.footer-bottom .footer-container {
		flex-direction: column;
		text-align: center;
		gap: 1rem;
	}

	.footer-tagline-bottom {
		text-align: center;
	}

	.footer-copyright {
		text-align: center;
	}
}

/* About Page - Introduction */
.about-intro-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 4rem 2rem;
	text-align: center;
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.about-hero {
	max-width: 800px;
	margin: 0 auto;
}

.about-hero-title {
	font-size: 2.8rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1.5rem 0;
	letter-spacing: 1px;
}

.about-hero-title .orange {
	color: var(--color-primary);
}

.about-hero-text {
	font-size: 1.1rem;
	color: var(--color-text);
	line-height: 1.8;
	margin: 0;
}

/* About Page - Activity Section */
.activity-section {
	padding: 4rem 2rem;
	background-color: var(--color-dark);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.activity-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 2rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.activity-section .orange {
	color: var(--color-primary);
}

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

.activity-content > p {
	font-size: 1.1rem;
	color: var(--color-text);
	text-align: center;
	margin-bottom: 2rem;
}

.activity-cards-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 1.5rem;
	max-width: 1200px;
	margin: 0 auto;
}

.activity-card {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 1.8rem;
	text-align: center;
	background: rgba(224, 141, 74, 0.05);
	transition: all 0.3s ease;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.8rem;
}

.activity-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-5px);
}

.activity-emoji {
	font-size: 2.5rem;
	display: block;
}

.activity-card h3 {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 0.5rem 0;
}

.activity-card p {
	color: var(--color-text);
	font-size: 0.85rem;
	line-height: 1.5;
	margin: 0;
}

/* Weapons Section */
.weapons-section {
	padding: 4rem 2rem;
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.8) 0%, rgba(52, 44, 38, 0.8) 100%);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.weapons-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.weapons-section .orange {
	color: var(--color-primary);
}

.section-intro {
	text-align: center;
	color: var(--color-text);
	margin-bottom: 2.5rem;
	font-size: 1rem;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.weapons-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	max-width: 1200px;
	margin: 0 auto;
	align-items: stretch;
}

.weapons-list {
	display: flex;
	flex-direction: column;
	gap: 2rem;
	min-height: 500px;
	justify-content: center;
}

.weapon-item {
	border-left: 4px solid var(--color-primary);
	padding-left: 1.5rem;
	transition: all 0.3s ease;
}

.weapon-item h3 {
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 0 0 0.5rem 0;
}

.weapon-item p {
	color: var(--color-text);
	font-size: 0.9rem;
	line-height: 1.6;
	margin: 0;
}

.weapon-item:hover {
	border-left-color: var(--color-white);
	padding-left: 2rem;
}

.weapons-gallery {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 500px;
}

.weapons-gallery-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.5rem;
	width: 100%;
	height: 100%;
}

.gallery-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 8px;
	border: 2px solid rgba(224, 141, 74, 0.3);
	transition: all 0.3s ease;
}

.gallery-image:hover {
	border-color: var(--color-primary);
	box-shadow: 0 5px 20px rgba(224, 141, 74, 0.2);
	transform: scale(1.02);
}

/* Objects Section */
.objects-section {
	padding: 4rem 2rem;
	background-color: var(--color-dark);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.objects-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.objects-section .orange {
	color: var(--color-primary);
}

.objects-list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	min-height: 500px;
	justify-content: center;
}

.object-item {
	border-left: 4px solid var(--color-primary);
	padding-left: 1.5rem;
	transition: all 0.3s ease;
}

.object-item h3 {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 0;
}

.object-item:hover {
	border-left-color: var(--color-white);
	padding-left: 2rem;
}

.objects-layout {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	max-width: 1200px;
	margin: 0 auto;
	align-items: stretch;
}

.objects-gallery {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 600px;
	height: 100%;
	width: 100%;
}

.objects-layout iframe {
	width: stretch;
	height: stretch;
	border-radius: 8px;
	flex: 1;
}

.object-gallery-video {
	width: 100% !important;
	height: 100% !important;
	max-width: 100%;
	object-fit: contain;
}

.object-gallery-placeholder {
	width: 100%;
	height: 500px;
	background: linear-gradient(135deg, rgba(224, 141, 74, 0.2) 0%, rgba(224, 141, 74, 0.1) 100%);
	border: 2px dashed rgba(224, 141, 74, 0.5);
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.1rem;
	color: rgba(184, 184, 184, 0.7);
	font-weight: 600;
	text-align: center;
	padding: 2rem;
}

/* Process Section */
.process-section {
	padding: 4rem 2rem;
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.process-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 3rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.process-section .orange {
	color: var(--color-primary);
}

.process-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	max-width: 1100px;
	margin: 0 auto;
}

.process-card {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 2rem;
	text-align: center;
	background: rgba(224, 141, 74, 0.05);
	transition: all 0.3s ease;
}

.process-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-5px);
}

.process-number {
	display: inline-flex;
	width: 50px;
	height: 50px;
	background: rgba(224, 141, 74, 0.2);
	border: 2px solid var(--color-primary);
	border-radius: 50%;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 900;
	color: var(--color-primary);
	margin-bottom: 1rem;
}

.process-card h3 {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 1rem 0;
}

.process-card p {
	color: var(--color-text);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

.process-card strong {
	color: var(--color-primary);
	font-weight: 700;
}

/* About CTA Section */
.about-cta-section {
	background: linear-gradient(135deg, rgba(224, 141, 74, 0.15) 0%, rgba(224, 141, 74, 0.05) 100%);
	padding: 4rem 2rem;
	text-align: center;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
}

.about-cta-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	letter-spacing: 1px;
}

.about-cta-section .orange {
	color: var(--color-primary);
}

.about-cta-section p {
	font-size: 1.1rem;
	color: var(--color-text);
	margin-bottom: 2rem;
}

.btn-cta {
	display: inline-block;
	background-color: var(--color-primary);
	color: var(--color-dark);
	padding: 1rem 2.5rem;
	font-size: 1rem;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 1px;
	border: 2px solid var(--color-primary);
	transition: all 0.3s ease;
}

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

/* Responsive About */
@media (max-width: 768px) {
	.activity-cards-grid {
		grid-template-columns: repeat(3, 1fr);
	}

	.weapons-layout {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.weapons-gallery {
		min-height: 350px;
	}

	.weapons-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}

	.objects-layout {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.objects-gallery {
		min-height: 350px;
	}

	.object-gallery-placeholder {
		height: 350px;
	}

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

/* Responsive Design */
@media (max-width: 768px) {
	.header-wrapper {
		flex-direction: column;
		gap: 1.5rem;
	}

	#branding {
		width: 70%;
		text-align: center;
	}

	#branding span {
		font-size: 1.2rem;
	}

	.hero-content {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.hero-title {
		font-size: 2.5rem;
	}

	.hero-subtitle {
		font-size: 1.3rem;
	}

	.hero-images {
		flex-direction: column;
		align-items: center;
	}

	.image-card.defoulement,
	.image-card.securite {
		margin-right: auto;
		margin-left: auto;
		width: 250px;
		height: 300px;
	}

	.hero-buttons {
		flex-direction: column;
		align-items: stretch;
	}

	.btn {
		justify-content: center;
	}
}

@media (max-width: 768px) {
	.benefits-grid {
		grid-template-columns: repeat(2, 1fr);
	}

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

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

	.reservation-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.reservation-plus {
		display: none;
	}
}

@media (max-width: 600px) {
	.poste-title {
		font-size: 1.8rem;
	}

	.poste-description {
		font-size: 0.9rem;
	}

	.stats-grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}

	.stat-card {
		padding: 1.5rem;
	}

	.stat-number {
		font-size: 2rem;
	}

	.stat-label {
		font-size: 0.8rem;
	}

	.experience-title {
		font-size: 1.8rem;
	}

	.experience-subtitle {
		font-size: 0.9rem;
	}

	.experience-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.experience-card {
		padding: 1.5rem;
	}

	.experience-icon {
		font-size: 2rem;
	}

	.experience-card h3 {
		font-size: 1rem;
	}

	.experience-card p {
		font-size: 0.9rem;
	}

	.benefits-title {
		font-size: 1.8rem;
	}

	.benefits-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.benefit-card {
		padding: 1.5rem;
	}

	.benefit-icon {
		font-size: 2rem;
	}

	.benefit-card h3 {
		font-size: 1rem;
	}

	.benefit-card p {
		font-size: 0.9rem;
	}

	.reservation-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.reservation-plus {
		display: none;
	}

	.reservation-card {
		padding: 1.5rem;
		min-height: auto;
	}

	.card-title {
		font-size: 1.5rem;
	}

	.card-description {
		font-size: 0.9rem;
	}

	.location-items {
		gap: 1rem;
		font-size: 0.85rem;
	}

	.location-title {
		font-size: 1.1rem;
	}

	.location-subtitle {
		font-size: 0.85rem;
	}

	.about-hero-title {
		font-size: 1.8rem;
	}

	.about-hero-text {
		font-size: 0.95rem;
	}

	.activity-cards-grid {
		grid-template-columns: 1fr;
	}

	.weapons-layout {
		grid-template-columns: 1fr;
	}

	.weapons-gallery {
		min-height: 300px;
	}

	.weapons-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}

	.weapon-card {
		padding: 1.5rem;
	}

	.weapon-icon {
		font-size: 2rem;
	}

	.objects-layout {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.objects-gallery {
		min-height: 300px;
	}

	.object-gallery-placeholder {
		height: 300px;
	}

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

	.process-card {
		padding: 1.5rem;
	}

	.process-number {
		width: 45px;
		height: 45px;
		font-size: 1.2rem;
	}

	.weapons-layout {
		grid-template-columns: 1fr;
	}

	.weapons-gallery {
		min-height: 250px;
	}

	.weapons-gallery-grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}

	.contact-title {
		font-size: 1.8rem;
	}

	.contact-info-grid {
		grid-template-columns: 1fr;
	}

	.info-card {
		padding: 1.5rem;
	}

	.form-wrapper {
		padding: 1.5rem;
	}

	.form-wrapper h2 {
		font-size: 1.8rem;
	}

	.simple-contact-form {
		padding-top: 1.5rem;
	}
}

/* Contact Page */
.contact-intro-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 4rem 2rem;
	text-align: center;
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.contact-container {
	max-width: 1200px;
	margin: 0 auto;
}

.contact-title {
	font-size: 2.8rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	letter-spacing: 1px;
}

.contact-title .orange {
	color: var(--color-primary);
}

.contact-subtitle {
	font-size: 1.1rem;
	color: var(--color-text);
	margin: 0;
	line-height: 1.8;
	max-width: 700px;
	margin: 0 auto;
}

/* Contact Info Section */
.contact-info-section {
	padding: 4rem 2rem;
	background-color: var(--color-dark);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.contact-info-section h3 {
	font-size: 1.3rem;
	font-weight: 700;
	color: var(--color-white);
	margin-bottom: 1rem;
}

.contact-info-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	max-width: 1200px;
	margin: 0 auto;
}

.info-card {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 2rem;
	text-align: center;
	background: rgba(224, 141, 74, 0.05);
	transition: all 0.3s ease;
}

.info-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-5px);
}

.info-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
	display: block;
}

.info-card p {
	color: var(--color-text);
	font-size: 0.95rem;
	margin: 0.5rem 0;
	line-height: 1.6;
}

.info-note {
	font-size: 0.85rem !important;
	color: rgba(184, 184, 184, 0.7) !important;
	font-style: italic;
	margin-top: 1rem !important;
}

.phone-link,
.email-link,
.info-link {
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 600;
	transition: all 0.3s ease;
}

.phone-link:hover,
.email-link:hover,
.info-link:hover {
	color: lighten(var(--color-primary), 10%);
	text-decoration: underline;
}

/* Contact Map and Form Grid Wrapper */
.contact-map-form-wrapper {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
	align-items: center;
}

/* Contact Form Section */
.contact-form-section {
	padding: 4rem 2rem;
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.8) 0%, rgba(52, 44, 38, 0.8) 100%);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
}

.form-wrapper {
	background: rgba(224, 141, 74, 0.05);
	border: 2px solid rgba(224, 141, 74, 0.2);
	padding: 3rem;
	max-width: 700px;
	margin: 0 auto;
}

.form-wrapper h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.form-wrapper .orange {
	color: var(--color-primary);
}

.form-intro {
	text-align: center;
	color: var(--color-text);
	margin-bottom: 2rem;
	font-size: 1rem;
	line-height: 1.6;
}

.simple-contact-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.form-group label {
	color: var(--color-white);
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.5px;
}

.form-group input,
.form-group textarea {
	background: transparent;
	border: 2px solid rgba(224, 141, 74, 0.3);
	color: var(--color-text);
	padding: 0.75rem;
	font-size: 0.95rem;
	transition: all 0.3s ease;
	font-family: inherit;
}

.form-group input:focus,
.form-group textarea:focus {
	outline: none;
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.1);
	box-shadow: 0 0 10px rgba(224, 141, 74, 0.2);
}

.form-group textarea {
	resize: vertical;
}

.btn-submit {
	background-color: var(--color-primary);
	color: var(--color-dark);
	padding: 1rem 2rem;
	font-size: 1rem;
	font-weight: 700;
	border: 2px solid var(--color-primary);
	cursor: pointer;
	transition: all 0.3s ease;
	letter-spacing: 1px;
	margin-top: 1rem;
}

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

/* Map Section */
.contact-map-section {
	padding: 0;
	background-color: var(--color-dark);
	border-right: 1px solid rgba(224, 141, 74, 0.2);
	border-bottom: none;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.map-container {
	width: 100%;
	min-height: 500px;
}

.map-container iframe {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 500px;
}

/* Contact CTA Section */
.contact-cta-section {
	background: linear-gradient(135deg, rgba(224, 141, 74, 0.15) 0%, rgba(224, 141, 74, 0.05) 100%);
	padding: 4rem 2rem;
	text-align: center;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
}

.contact-cta-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	letter-spacing: 1px;
}

.contact-cta-section .orange {
	color: var(--color-primary);
}

.contact-cta-section p {
	font-size: 1.1rem;
	color: var(--color-text);
	margin-bottom: 2rem;
}

/* Reservation Page */
.reservation-intro-section {
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.95) 0%, rgba(52, 44, 38, 0.95) 100%);
	padding: 4rem 2rem;
	text-align: center;
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.reservation-container {
	max-width: 1200px;
	margin: 0 auto;
}

.reservation-title {
	font-size: 2.8rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	letter-spacing: 1px;
}

.reservation-title .orange {
	color: var(--color-primary);
}

.reservation-subtitle {
	font-size: 1.1rem;
	color: var(--color-text);
	margin: 0;
	line-height: 1.8;
}

/* Calendar Section */
.calendar-section {
	padding: 4rem 2rem;
	background-color: var(--color-dark);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.calendar-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 3rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.calendar-section .orange {
	color: var(--color-primary);
}

.calendar-wrapper {
	max-width: 900px;
	margin: 0 auto;
	background: rgba(224, 141, 74, 0.05);
	border: 2px solid rgba(224, 141, 74, 0.2);
	border-radius: 8px;
	overflow: hidden;
}

.calendar-placeholder {
	padding: 4rem 2rem;
	text-align: center;
	background: linear-gradient(135deg, rgba(224, 141, 74, 0.1) 0%, rgba(224, 141, 74, 0.05) 100%);
	min-height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.placeholder-content {
	max-width: 500px;
}

.placeholder-icon {
	font-size: 4rem;
	margin-bottom: 1.5rem;
}

.calendar-placeholder h3 {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-white);
	margin-bottom: 1rem;
}

.calendar-placeholder p {
	color: var(--color-text);
	font-size: 1rem;
	line-height: 1.6;
	margin: 0;
}

/* Pricing Section */
.pricing-section {
	padding: 4rem 2rem;
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.8) 0%, rgba(52, 44, 38, 0.8) 100%);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.pricing-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.pricing-section .orange {
	color: var(--color-primary);
}

.pricing-intro {
	text-align: center;
	color: var(--color-text);
	margin-bottom: 3rem;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	font-size: 1rem;
	line-height: 1.6;
}

.pricing-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	max-width: 1300px;
	margin: 0 auto;
}

.pricing-card {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 2rem;
	background: rgba(224, 141, 74, 0.05);
	text-align: center;
	position: relative;
	transition: all 0.3s ease;
	display: flex;
	flex-direction: column;
}

.pricing-card:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-10px);
	box-shadow: 0 10px 30px rgba(224, 141, 74, 0.2);
}



.pricing-badge {
	position: absolute;
	top: 1rem;
	right: 1rem;
	background: rgba(224, 141, 74, 0.3);
	color: var(--color-primary);
	padding: 0.5rem 1rem;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 1px;
	border-radius: 20px;
	text-transform: uppercase;
}

.pricing-icon {
	font-size: 3rem;
	margin-bottom: 1rem;
}

.pricing-card h3 {
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 0 0 0.5rem 0;
}

.pricing-duration {
	color: var(--color-text);
	font-size: 0.9rem;
	margin: 0 0 1rem 0;
	font-style: italic;
}

.pricing-people {
	color: var(--color-primary);
	font-size: 0.95rem;
	font-weight: 600;
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.pricing-amount {
	margin: 1.5rem 0 2rem 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.pricing-amount .currency {
	font-size: 0.85rem;
	color: rgba(184, 184, 184, 0.7);
	letter-spacing: 0.5px;
}

.pricing-amount .price {
	font-size: 2.5rem;
	font-weight: 900;
	color: var(--color-primary);
}

.pricing-features {
	list-style: none;
	padding: 0;
	margin: 2rem 0;
	flex-grow: 1;
	text-align: left;
}

.pricing-features li {
	color: var(--color-text);
	font-size: 0.9rem;
	padding: 0.5rem 0;
	border-bottom: 1px solid rgba(224, 141, 74, 0.1);
}

.pricing-features li:last-child {
	border-bottom: none;
}

.btn-reserve {
	display: inline-block;
	background-color: transparent;
	color: var(--color-primary);
	padding: 0.9rem 1.8rem;
	font-size: 0.95rem;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: 1px;
	border: 2px solid var(--color-primary);
	transition: all 0.3s ease;
	margin-top: 1.5rem;
}

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



/* Reservation Info Section */
.reservation-info-section {
	padding: 4rem 2rem;
	background-color: var(--color-dark);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.reservation-info-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 3rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.reservation-info-section .orange {
	color: var(--color-primary);
}

.info-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	max-width: 1200px;
	margin: 0 auto;
}

.info-box {
	border: 2px solid rgba(224, 141, 74, 0.3);
	padding: 2rem;
	background: rgba(224, 141, 74, 0.05);
	text-align: center;
	transition: all 0.3s ease;
}

.info-box:hover {
	border-color: var(--color-primary);
	background: rgba(224, 141, 74, 0.15);
	transform: translateY(-5px);
}

.info-box-icon {
	font-size: 2.5rem;
	margin-bottom: 1rem;
}

.info-box h3 {
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 0 0 1rem 0;
}

.info-box p {
	color: var(--color-text);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

/* FAQ Section */
.faq-section {
	padding: 4rem 2rem;
	background: linear-gradient(135deg, rgba(42, 36, 32, 0.8) 0%, rgba(52, 44, 38, 0.8) 100%);
	border-bottom: 1px solid rgba(224, 141, 74, 0.2);
}

.faq-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 3rem 0;
	text-align: center;
	letter-spacing: 1px;
}

.faq-section .orange {
	color: var(--color-primary);
}

.faq-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	max-width: 1200px;
	margin: 0 auto;
}

.faq-item {
	border-left: 4px solid var(--color-primary);
	padding: 1.5rem;
	background: rgba(224, 141, 74, 0.05);
	transition: all 0.3s ease;
}

.faq-item:hover {
	background: rgba(224, 141, 74, 0.15);
	transform: translateX(5px);
}

.faq-item h3 {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-white);
	margin: 0 0 0.8rem 0;
}

.faq-item p {
	color: var(--color-text);
	font-size: 0.9rem;
	line-height: 1.6;
	margin: 0;
}

/* Reservation CTA Section */
.reservation-cta-section {
	background: linear-gradient(135deg, rgba(224, 141, 74, 0.15) 0%, rgba(224, 141, 74, 0.05) 100%);
	padding: 4rem 2rem;
	text-align: center;
	border-top: 1px solid rgba(224, 141, 74, 0.2);
}

.reservation-cta-section h2 {
	font-size: 2.2rem;
	font-weight: 900;
	color: var(--color-white);
	margin: 0 0 1rem 0;
	letter-spacing: 1px;
}

.reservation-cta-section .orange {
	color: var(--color-primary);
}

.reservation-cta-section p {
	font-size: 1.1rem;
	color: var(--color-text);
	margin-bottom: 2rem;
}

.btn-lg {
	padding: 1.2rem 3rem !important;
	font-size: 1.1rem !important;
}

/* Responsive Reservation */
@media (max-width: 768px) {
	.pricing-grid {
		grid-template-columns: repeat(2, 1fr);
	}



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

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

/* Responsive Contact */
@media (max-width: 768px) {
	.contact-info-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.contact-title {
		font-size: 2rem;
	}

	.contact-subtitle {
		font-size: 1rem;
	}

	.contact-info-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.info-card {
		padding: 1.5rem;
	}
}

/* Objects Section Layout - Video on the Right */
.objects-layout {
	display: flex;
	align-items: flex-start;
	gap: 40px;
}

.objects-list {
	flex: 0 1 auto;
	min-width: 300px;
}

.objects-gallery {
	flex: 0 0 550px;
	display: flex;
	align-items: flex-start;
}

.object-gallery-video {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 12px;
	box-shadow: 0 4px 24px rgba(0,0,0,0.3);
}

@media (max-width: 1000px) {
	.objects-layout {
		flex-direction: column;
		gap: 24px;
	}

	.objects-gallery {
		min-width: 100%;
	}

	.object-gallery-video {
		width: 100%;
	}
}

	.form-wrapper {
		padding: 2rem;
	}

	.contact-map-form-wrapper {
		grid-template-columns: 1fr 1fr;
	}

	.contact-map-section {
		border-right: 1px solid rgba(224, 141, 74, 0.2);
		border-bottom: none;
	}

	.form-wrapper h2 {
		font-size: 1.8rem;
	}

	.map-container,
	.map-container iframe {
		min-height: 400px;
	}

	.contact-cta-section h2 {
		font-size: 1.8rem;
	}

/* Responsive About 768px */
@media (max-width: 768px) {
	.about-hero-title {
		font-size: 2rem;
	}

	.about-hero-text {
		font-size: 1rem;
	}

	.activity-cards-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.2rem;
	}

	.activity-card {
		padding: 1.2rem;
	}

	.activity-emoji {
		font-size: 2rem;
	}

	.activity-card h3 {
		font-size: 0.95rem;
	}

	.activity-card p {
		font-size: 0.8rem;
	}

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

	.weapon-image-placeholder {
		height: 180px;
	}

	.objects-layout {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.objects-gallery {
		min-height: 400px;
	}

	.object-gallery-placeholder {
		height: 400px;
	}

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

/* Responsive Reservation 768px */
@media (max-width: 768px) {
	.reservation-title {
		font-size: 2rem;
	}

	.reservation-subtitle {
		font-size: 1rem;
	}

	.calendar-section h2 {
		font-size: 1.8rem;
	}

	.pricing-section h2 {
		font-size: 1.8rem;
	}

	.pricing-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem;
	}



	.pricing-card {
		padding: 1.5rem;
	}

	.pricing-icon {
		font-size: 2.5rem;
	}

	.pricing-amount .price {
		font-size: 2rem;
	}

	.info-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem;
	}

	.info-box {
		padding: 1.5rem;
	}

	.faq-grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.faq-item {
		padding: 1.2rem;
	}

	.reservation-cta-section h2 {
		font-size: 1.8rem;
	}
}

/* Responsive Reservation 600px */
@media (max-width: 600px) {
	.reservation-title {
		font-size: 1.8rem;
	}

	.calendar-section h2,
	.pricing-section h2,
	.reservation-cta-section h2 {
		font-size: 1.5rem;
	}

	.pricing-grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}

	.pricing-card {
		padding: 1.2rem;
	}

	.pricing-badge {
		font-size: 0.7rem;
		top: 0.8rem;
		right: 0.8rem;
	}

	.pricing-icon {
		font-size: 2rem;
	}

	.pricing-card h3 {
		font-size: 1.2rem;
	}

	.pricing-amount .price {
		font-size: 1.8rem;
	}

	.pricing-features li {
		font-size: 0.85rem;
		padding: 0.3rem 0;
	}

	.btn-reserve {
		padding: 0.7rem 1.5rem !important;
		font-size: 0.85rem !important;
	}
}

/* Contact Form 7 - RAGEROOM STYLING */
.wpcf7-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

/* Form Fields Wrapper */
.wpcf7-form p {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

/* Labels */
.wpcf7-form label {
	color: var(--color-white);
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.5px;
	display: block;
	margin-bottom: 0.5rem;
}

/* Form Inputs & Textareas */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="date"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="url"],
.wpcf7-form textarea,
.wpcf7-form select {
	background: transparent !important;
	border: 2px solid rgba(224, 141, 74, 0.3) !important;
	color: var(--color-text) !important;
	padding: 0.75rem !important;
	font-size: 0.95rem !important;
	transition: all 0.3s ease !important;
	font-family: inherit !important;
	width: 100%;
	box-sizing: border-box;
}

.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder {
	color: rgba(184, 184, 184, 0.5);
}

/* Focus states */
.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form input[type="date"]:focus,
.wpcf7-form input[type="number"]:focus,
.wpcf7-form input[type="url"]:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus {
	outline: none !important;
	border-color: var(--color-primary) !important;
	background: rgba(224, 141, 74, 0.1) !important;
	box-shadow: 0 0 10px rgba(224, 141, 74, 0.2) !important;
}

/* Textarea */
.wpcf7-form textarea {
	resize: vertical;
	min-height: 120px;
}

/* Form line (separators) */
.wpcf7-form .wpcf7-form-control + .wpcf7-form-control {
	margin-top: 1.5rem;
}

/* Checkbox & Radio styles */
.wpcf7-form input[type="checkbox"],
.wpcf7-form input[type="radio"] {
	margin-right: 0.5rem;
	accent-color: var(--color-primary);
	cursor: pointer;
	width: auto;
}

.wpcf7-form .wpcf7-checkbox label,
.wpcf7-form .wpcf7-radio label {
	display: inline;
	margin-left: 0.5rem;
	cursor: pointer;
}

/* Checkbox & Radio lists */
.wpcf7-form .wpcf7-checkbox,
.wpcf7-form .wpcf7-radio {
	display: flex;
	flex-direction: column;
	gap: 0.8rem;
	margin-top: 0.5rem;
}

.wpcf7-form .wpcf7-checkbox span,
.wpcf7-form .wpcf7-radio span {
	display: flex;
	align-items: center;
}

/* Submit Button */
.wpcf7-form input[type="submit"],
.wpcf7-form button {
	background-color: var(--color-primary) !important;
	color: var(--color-dark) !important;
	padding: 1rem 2rem !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	border: 2px solid var(--color-primary) !important;
	cursor: pointer !important;
	transition: all 0.3s ease !important;
	letter-spacing: 1px !important;
	margin-top: 1rem !important;
	width: 100%;
	box-sizing: border-box;
	text-transform: uppercase;
}

.wpcf7-form input[type="submit"]:hover,
.wpcf7-form button:hover {
	background-color: transparent !important;
	color: var(--color-primary) !important;
	cursor: pointer;
}

.wpcf7-form input[type="submit"]:active,
.wpcf7-form button:active {
	transform: scale(0.98);
}

/* Success/Error Messages */
.wpcf7-mail-sent-ok {
	background: rgba(76, 175, 80, 0.1) !important;
	border: 2px solid #4CAF50 !important;
	color: #4CAF50 !important;
	padding: 1rem !important;
	border-radius: 4px !important;
	font-weight: 600 !important;
	margin-bottom: 1.5rem !important;
}

.wpcf7-form-control-wrap .wpcf7-not-valid-tip,
.wpcf7-validation-errors {
	background: rgba(244, 67, 54, 0.1) !important;
	border: 2px solid #F44336 !important;
	color: #F44336 !important;
	padding: 1rem !important;
	border-radius: 4px !important;
	font-weight: 600 !important;
	margin-bottom: 1.5rem !important;
	display: block !important;
}

.wpcf7-form-control:invalid {
	border-color: #F44336 !important;
	background: rgba(244, 67, 54, 0.05) !important;
}

/* Required field indicator */
.wpcf7-form abbr {
	color: var(--color-primary);
	font-weight: 700;
}

/* Select dropdown styling */
.wpcf7-form select {
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23E08D4A' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.75rem center;
	padding-right: 2.5rem !important;
	cursor: pointer;
}

/* Multiple choice groups */
.wpcf7-checkbox-multiple,
.wpcf7-radio-multiple {
	display: flex;
	flex-direction: column;
	gap: 0.8rem;
}

.wpcf7-checkbox-multiple .wpcf7-checkbox,
.wpcf7-radio-multiple .wpcf7-radio {
	flex-direction: row;
}

/* Responsive CF7 Forms */
@media (max-width: 768px) {
	.wpcf7-form {
		gap: 1.2rem;
	}

	.wpcf7-form input[type="submit"],
	.wpcf7-form button {
		padding: 0.9rem 1.5rem !important;
		font-size: 0.95rem !important;
	}

	.form-wrapper {
		padding: 1.5rem;
	}
}

	.info-grid {
		grid-template-columns: 1fr;
		gap: 1.2rem;
	}

	.info-box {
		padding: 1.2rem;
	}

	.info-box-icon {
		font-size: 2rem;
	}

	.info-box h3 {
		font-size: 1rem;
	}

	.info-box p {
		font-size: 0.9rem;
	}

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

	.faq-item h3 {
		font-size: 1rem;
	}

	.faq-item p {
		font-size: 0.85rem;
	}

	.reservation-cta-section p {
		font-size: 1rem;
	}

	.btn-lg {
		padding: 0.9rem 2rem !important;
		font-size: 1rem !important;
	}

	.weapon-image-placeholder {
		height: 150px;
	}

	.objects-layout {
		grid-template-columns: 1fr;
	}

	.objects-gallery {
		min-height: 250px;
	}

	.objects-gallery-grid {
		grid-template-columns: 1fr;
		gap: 1rem;
	}


/* Menu Burger Styles */
.hamburger {
	display: none;
	flex-direction: column;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	gap: 6px;
	z-index: 1000;
}

.hamburger span {
	width: 25px;
	height: 3px;
	background-color: #ff6600;
	border-radius: 3px;
	transition: all 0.3s ease;
}

.hamburger.active span:nth-child(1) {
	transform: rotate(45deg) translate(8px, 8px);
}

.hamburger.active span:nth-child(2) {
	opacity: 0;
}

.hamburger.active span:nth-child(3) {
	transform: rotate(-45deg) translate(7px, -7px);
}

@media (max-width: 768px) {
	.hamburger {
		display: flex;
	}
	
	#site-title {
		text-align: center;
	}
	
	#menu {
		position: fixed;
		top: 70px;
		right: 0;
		width: 100vw;
		height: calc(100vh - 70px);
		background-color: rgba(0, 0, 0, 0.95);
		padding: 20px;
		overflow-y: auto;
		transform: translateX(100%);
		transition: transform 0.3s ease;
		z-index: 999;
		border-left: 3px solid #ff6600;
		margin-top: 0;
		text-align: center;
		display: flex;
		flex-direction: column;
	}
	
	#menu.open {
		transform: translateX(0);
	}

	.header-cta {
		display: none;
	}

	.header-wrapper {
		flex-direction: row !important;
		align-items: center;
		justify-content: space-between;
	}

	#menu ul {
		flex-direction: column;
	}
}