/*
Theme Name: CA Tower
Theme URI: https://catower.in/
Author: Lakshmidas Menon Manikkath
Author URI: https://choondal.com/
Description: Premium one-page WordPress theme purpose-built for CA Tower — a fully renovated lodge opposite the Private Bus Stand, East Nada, Guruvayoor. Features a dynamic hero, About, Rooms & Suites, Amenities, Gallery, Discover Guruvayoor, Contact with embedded map, and a floating WhatsApp button. Fully responsive (mobile, tablet, desktop) and 100% editable via the WordPress Customizer (colors, fonts, content, images). Designed and developed by Lakshmidas Menon Manikkath of Choondal Global Services (Choondal.com).
Version: 20.26.05.06.1
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v3 or later
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Text Domain: ca-tower
Tags: one-page, custom-logo, custom-menu, custom-colors, custom-background, featured-images, threaded-comments, translation-ready, theme-options, blog, e-commerce

CA Tower WordPress Theme
Copyright (C) 2026 Lakshmidas Menon Manikkath / Choondal Global Services (https://choondal.com/)
Distributed under the terms of the GNU GPL v3 or later.

Developer:  Lakshmidas Menon Manikkath
Company:    Choondal Global Services
Website:    https://choondal.com/  |  https://guvr.in/
Contact:    +91 9446666639
*/

/* ============================================================
   1. CSS RESET / BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--ct-font-body, 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif);
	font-size: 16px;
	line-height: 1.65;
	color: var(--ct-text, #2c2c2c);
	background: var(--ct-bg, #ffffff);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--ct-primary, #e63027); text-decoration: none; transition: color .25s ease; }
a:hover, a:focus { color: var(--ct-primary-dark, #b5231c); }
h1, h2, h3, h4, h5, h6 {
	font-family: var(--ct-font-heading, 'Poppins', sans-serif);
	font-weight: 700;
	line-height: 1.25;
	margin: 0 0 .6em;
	color: var(--ct-heading, #1a1a1a);
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.6rem); }
p  { margin: 0 0 1em; }

/* Skip link — accessibility */
.skip-link {
	position: absolute; left: -9999px; top: 0;
	background: var(--ct-primary, #e63027); color: #fff;
	padding: 10px 16px; z-index: 9999;
}
.skip-link:focus { left: 0; }

/* Container */
.ct-container { width: min(1200px, 92%); margin-inline: auto; }

/* Buttons */
.ct-btn {
	display: inline-block;
	padding: 14px 32px;
	background: var(--ct-primary, #e63027);
	color: #fff !important;
	border-radius: 50px;
	font-weight: 600;
	letter-spacing: .3px;
	border: 2px solid var(--ct-primary, #e63027);
	cursor: pointer;
	transition: all .3s ease;
	box-shadow: 0 6px 20px rgba(230,48,39,.25);
}
.ct-btn:hover, .ct-btn:focus {
	background: var(--ct-primary-dark, #b5231c);
	border-color: var(--ct-primary-dark, #b5231c);
	transform: translateY(-2px);
	box-shadow: 0 10px 25px rgba(230,48,39,.35);
}
.ct-btn--ghost {
	background: transparent;
	color: var(--ct-primary, #e63027) !important;
	box-shadow: none;
}
.ct-btn--ghost:hover {
	background: var(--ct-primary, #e63027);
	color: #fff !important;
}
.ct-btn--white {
	background: #fff;
	color: var(--ct-primary, #e63027) !important;
	border-color: #fff;
}
.ct-btn--white:hover {
	background: transparent;
	color: #fff !important;
	border-color: #fff;
}

/* Section base */
.ct-section { padding: clamp(60px, 9vw, 110px) 0; position: relative; }
.ct-section--alt { background: var(--ct-section-alt, #f8f6f2); }
.ct-section__head { text-align: center; max-width: 720px; margin: 0 auto 60px; }
.ct-section__eyebrow {
	display: inline-block;
	font-size: 13px;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--ct-accent, #1aa6a0);
	font-weight: 600;
	margin-bottom: 12px;
}
.ct-section__title {
	margin: 0 0 18px;
	color: var(--ct-heading, #1a1a1a);
}
.ct-section__title span { color: var(--ct-primary, #e63027); }
.ct-section__lead { color: #666; font-size: 1.05rem; }

/* ============================================================
   2. HEADER
   ============================================================ */
.ct-site-header {
	position: fixed;
	top: 0; left: 0; right: 0;
	z-index: 999;
	padding: 18px 0;
	transition: all .35s ease;
	background: transparent;
}
.ct-site-header.is-scrolled {
	background: rgba(255,255,255,.97);
	backdrop-filter: saturate(180%) blur(10px);
	-webkit-backdrop-filter: saturate(180%) blur(10px);
	box-shadow: 0 4px 20px rgba(0,0,0,.06);
	padding: 10px 0;
}
.ct-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}
.ct-logo { display: flex; align-items: center; gap: 12px; }
.ct-logo img { max-height: 60px; width: auto; transition: max-height .3s ease; }
.is-scrolled .ct-logo img { max-height: 48px; }
.ct-logo__text {
	font-weight: 700;
	font-size: 1.25rem;
	color: var(--ct-heading, #1a1a1a);
	line-height: 1;
}
.ct-logo__text small {
	display: block;
	font-size: .65rem;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--ct-accent, #1aa6a0);
	font-weight: 500;
	margin-top: 4px;
}

/* Header initial state — light text on dark hero */
.ct-site-header:not(.is-scrolled) .ct-logo__text { color: #fff; }
.ct-site-header:not(.is-scrolled) .ct-nav a { color: #fff; }
.ct-site-header:not(.is-scrolled) .ct-nav-toggle span { background: #fff; }

/* Nav */
.ct-nav { display: flex; align-items: center; gap: 8px; }
.ct-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 4px;
}
.ct-nav a {
	display: inline-block;
	padding: 10px 16px;
	color: var(--ct-heading, #1a1a1a);
	font-weight: 500;
	font-size: 15px;
	border-radius: 6px;
	transition: all .25s ease;
}
.ct-nav a:hover, .ct-nav .current-menu-item > a {
	color: var(--ct-primary, #e63027);
}
.ct-nav .ct-btn { margin-left: 12px; padding: 10px 22px; font-size: 14px; }

/* Mobile toggle */
.ct-nav-toggle {
	display: none;
	background: transparent;
	border: 0;
	padding: 8px;
	cursor: pointer;
	width: 44px; height: 44px;
	position: relative;
}
.ct-nav-toggle span {
	display: block;
	width: 26px; height: 2px;
	background: var(--ct-heading, #1a1a1a);
	margin: 6px auto;
	transition: all .3s ease;
}
.ct-nav-toggle.is-open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.ct-nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.ct-nav-toggle.is-open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* ============================================================
   3. HERO
   ============================================================ */
.ct-hero {
	min-height: 100vh;
	display: flex;
	align-items: center;
	position: relative;
	color: #fff;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	overflow: hidden;
}
.ct-hero::before {
	content: '';
	position: absolute; inset: 0;
	background: linear-gradient(135deg, rgba(20,20,20,.65), rgba(40,15,15,.55));
	z-index: 1;
}
.ct-hero__inner {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 880px;
	margin: 0 auto;
	padding: 120px 0 60px;
}
.ct-hero__eyebrow {
	display: inline-block;
	background: rgba(255,255,255,.15);
	backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,.25);
	padding: 8px 20px;
	border-radius: 50px;
	font-size: 13px;
	letter-spacing: 2px;
	text-transform: uppercase;
	font-weight: 500;
	margin-bottom: 24px;
}
.ct-hero__title {
	color: #fff;
	font-size: clamp(2.4rem, 6vw, 4.5rem);
	margin-bottom: 20px;
	line-height: 1.1;
	letter-spacing: -1px;
	text-shadow: 0 2px 20px rgba(0,0,0,.3);
}
.ct-hero__title span { color: var(--ct-primary, #e63027); }
.ct-hero__subtitle {
	font-size: clamp(1rem, 2vw, 1.25rem);
	max-width: 640px;
	margin: 0 auto 36px;
	color: rgba(255,255,255,.92);
}
.ct-hero__cta { display: inline-flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.ct-hero__price {
	margin-top: 40px;
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 12px 24px;
	background: rgba(255,255,255,.1);
	backdrop-filter: blur(8px);
	border-radius: 50px;
	border: 1px solid rgba(255,255,255,.2);
	font-size: 15px;
}
.ct-hero__price strong { color: #ffd166; font-size: 1.3rem; font-weight: 700; }

/* Scroll cue */
.ct-hero__scroll {
	position: absolute;
	bottom: 30px; left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	color: #fff;
	opacity: .8;
	animation: ct-bounce 2.4s infinite;
}
@keyframes ct-bounce {
	0%,100% { transform: translate(-50%, 0); }
	50%     { transform: translate(-50%, -10px); }
}

/* ============================================================
   4. ABOUT
   ============================================================ */
.ct-about__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	align-items: center;
}
.ct-about__media {
	position: relative;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 30px 60px rgba(0,0,0,.12);
}
.ct-about__media img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4/5; }
.ct-about__media::after {
	content: '';
	position: absolute;
	bottom: -20px; right: -20px;
	width: 140px; height: 140px;
	background: var(--ct-accent, #1aa6a0);
	border-radius: 16px;
	z-index: -1;
}
.ct-about__media { position: relative; z-index: 1; }
.ct-about__content h2 { margin-bottom: 20px; }
.ct-about__highlights {
	list-style: none;
	padding: 0;
	margin: 24px 0 32px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px 20px;
}
.ct-about__highlights li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 15px;
	color: #444;
}
.ct-about__highlights svg {
	flex-shrink: 0;
	width: 22px; height: 22px;
	color: var(--ct-accent, #1aa6a0);
	margin-top: 2px;
}

/* ============================================================
   5. ROOMS
   ============================================================ */
.ct-rooms__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 30px;
}
.ct-room {
	background: #fff;
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 10px 40px rgba(0,0,0,.06);
	transition: transform .35s ease, box-shadow .35s ease;
	border: 1px solid rgba(0,0,0,.04);
}
.ct-room:hover {
	transform: translateY(-8px);
	box-shadow: 0 20px 50px rgba(0,0,0,.12);
}
.ct-room__media {
	aspect-ratio: 16/10;
	overflow: hidden;
	position: relative;
}
.ct-room__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .6s ease;
}
.ct-room:hover .ct-room__media img { transform: scale(1.06); }
.ct-room__badge {
	position: absolute;
	top: 16px; left: 16px;
	background: var(--ct-primary, #e63027);
	color: #fff;
	padding: 6px 14px;
	border-radius: 50px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: .5px;
	text-transform: uppercase;
}
.ct-room__body { padding: 26px 24px 28px; }
.ct-room__title {
	margin: 0 0 8px;
	font-size: 1.35rem;
}
.ct-room__price {
	color: var(--ct-primary, #e63027);
	font-weight: 700;
	font-size: 1.05rem;
	margin-bottom: 14px;
}
.ct-room__price small { color: #888; font-weight: 500; font-size: .85rem; }
.ct-room__desc { color: #555; font-size: 15px; margin-bottom: 18px; }
.ct-room__features {
	list-style: none;
	padding: 0;
	margin: 0 0 20px;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.ct-room__features li {
	background: #f4f1ea;
	color: #555;
	padding: 4px 12px;
	border-radius: 50px;
	font-size: 12px;
	font-weight: 500;
}

/* ============================================================
   6. AMENITIES
   ============================================================ */
.ct-amenities__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 24px;
}
.ct-amenity {
	text-align: center;
	padding: 36px 22px;
	background: #fff;
	border-radius: 14px;
	transition: all .3s ease;
	border: 1px solid rgba(0,0,0,.05);
}
.ct-amenity:hover {
	transform: translateY(-4px);
	box-shadow: 0 14px 30px rgba(0,0,0,.08);
	border-color: transparent;
}
.ct-amenity__icon {
	width: 60px; height: 60px;
	margin: 0 auto 18px;
	display: grid;
	place-items: center;
	background: linear-gradient(135deg, var(--ct-primary, #e63027), var(--ct-accent, #1aa6a0));
	border-radius: 50%;
	color: #fff;
}
.ct-amenity__icon svg { width: 28px; height: 28px; }
.ct-amenity__title { margin: 0 0 6px; font-size: 1.05rem; }
.ct-amenity__desc { color: #777; font-size: 14px; margin: 0; }

/* ============================================================
   7. GALLERY (showcase strip)
   ============================================================ */
.ct-gallery__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 16px;
}
.ct-gallery__item {
	aspect-ratio: 4/3;
	overflow: hidden;
	border-radius: 12px;
	cursor: pointer;
	position: relative;
}
.ct-gallery__item img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .6s ease;
}
.ct-gallery__item:hover img { transform: scale(1.08); }

/* ============================================================
   8. LOCATION / DISCOVER
   ============================================================ */
.ct-discover {
	background: linear-gradient(135deg, #1a1a1a, #2c1810);
	color: #fff;
	position: relative;
}
.ct-discover .ct-section__title { color: #fff; }
.ct-discover .ct-section__lead { color: rgba(255,255,255,.75); }
.ct-discover .ct-section__eyebrow { color: var(--ct-accent, #1aa6a0); }
.ct-discover__grid {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 50px;
	align-items: center;
}
.ct-discover__text p { color: rgba(255,255,255,.85); font-size: 1.05rem; }
.ct-discover__stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 22px;
	margin-top: 30px;
}
.ct-stat {
	background: rgba(255,255,255,.06);
	border: 1px solid rgba(255,255,255,.1);
	padding: 20px;
	border-radius: 12px;
}
.ct-stat strong {
	display: block;
	font-size: 1.8rem;
	color: var(--ct-accent, #1aa6a0);
	margin-bottom: 4px;
}
.ct-stat span { color: rgba(255,255,255,.7); font-size: 14px; }

/* ============================================================
   9. CONTACT
   ============================================================ */
.ct-contact__grid {
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: 50px;
	align-items: stretch;
}
.ct-contact__info {
	background: linear-gradient(145deg, var(--ct-primary, #e63027), #b5231c);
	color: #fff;
	padding: 48px 40px;
	border-radius: 16px;
	box-shadow: 0 20px 50px rgba(230,48,39,.25);
}
.ct-contact__info h3 { color: #fff; margin-bottom: 8px; }
.ct-contact__info p { color: rgba(255,255,255,.9); margin-bottom: 28px; }
.ct-contact__list { list-style: none; padding: 0; margin: 0; }
.ct-contact__list li {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 22px;
	color: #fff;
}
.ct-contact__list li:last-child { margin-bottom: 0; }
.ct-contact__list svg {
	flex-shrink: 0;
	width: 22px; height: 22px;
	margin-top: 3px;
	color: #ffd166;
}
.ct-contact__list a { color: #fff; }
.ct-contact__list a:hover { color: #ffd166; }
.ct-contact__list strong {
	display: block;
	font-size: 12px;
	letter-spacing: 2px;
	text-transform: uppercase;
	opacity: .8;
	margin-bottom: 4px;
	font-weight: 500;
}
.ct-contact__map {
	border-radius: 16px;
	overflow: hidden;
	min-height: 460px;
	box-shadow: 0 20px 50px rgba(0,0,0,.1);
}
.ct-contact__map iframe { width: 100%; height: 100%; min-height: 460px; border: 0; display: block; }

/* ============================================================
   10. FOOTER
   ============================================================ */
.ct-footer {
	background: #111;
	color: rgba(255,255,255,.7);
	padding: 60px 0 0;
}
.ct-footer__grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: 40px;
	padding-bottom: 40px;
}
.ct-footer h4 { color: #fff; font-size: 1rem; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 18px; }
.ct-footer ul { list-style: none; padding: 0; margin: 0; }
.ct-footer li { margin-bottom: 10px; }
.ct-footer a { color: rgba(255,255,255,.7); }
.ct-footer a:hover { color: #fff; }
.ct-footer__brand img { max-height: 50px; margin-bottom: 14px; filter: brightness(0) invert(1); }
.ct-footer__about { font-size: 14px; color: rgba(255,255,255,.6); }
.ct-footer__bottom {
	border-top: 1px solid rgba(255,255,255,.1);
	padding: 20px 0;
	text-align: center;
	font-size: 13px;
	color: rgba(255,255,255,.5);
}
.ct-footer__bottom a { color: var(--ct-accent, #1aa6a0); }

/* Floating call button */
.ct-float-call {
	position: fixed;
	bottom: 22px; right: 22px;
	z-index: 998;
	display: grid;
	place-items: center;
	width: 58px; height: 58px;
	background: linear-gradient(135deg, #25d366, #128c7e);
	color: #fff;
	border-radius: 50%;
	box-shadow: 0 10px 30px rgba(37,211,102,.45);
	transition: transform .3s ease;
	animation: ct-pulse 2.4s infinite;
}
.ct-float-call:hover { transform: scale(1.08); color: #fff; }
.ct-float-call svg { width: 28px; height: 28px; }
@keyframes ct-pulse {
	0% { box-shadow: 0 10px 30px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,.5); }
	70% { box-shadow: 0 10px 30px rgba(37,211,102,.45), 0 0 0 16px rgba(37,211,102,0); }
	100% { box-shadow: 0 10px 30px rgba(37,211,102,.45), 0 0 0 0 rgba(37,211,102,0); }
}

/* ============================================================
   11. BLOG / SINGLE / PAGE (fallback)
   ============================================================ */
.ct-page-content {
	padding: 160px 0 80px;
	max-width: 820px;
	margin: 0 auto;
}
.ct-page-content h1 { margin-bottom: 24px; }
.ct-page-content img { border-radius: 12px; margin: 20px 0; }
.ct-page-content blockquote {
	border-left: 4px solid var(--ct-primary, #e63027);
	padding: 8px 20px;
	margin: 20px 0;
	background: #f8f6f2;
	font-style: italic;
}

/* ============================================================
   12. UTILITIES & ANIMATIONS
   ============================================================ */
.ct-fade-in { opacity: 0; transform: translateY(30px); transition: all .8s ease; }
.ct-fade-in.is-visible { opacity: 1; transform: translateY(0); }
.screen-reader-text {
	clip: rect(1px,1px,1px,1px);
	position: absolute !important;
	height: 1px; width: 1px;
	overflow: hidden;
}

/* ============================================================
   13. RESPONSIVE — Mobile, Tablet, Desktop
   ============================================================ */

/* Large Desktop ≤ 1280px */
@media (max-width: 1280px) {
	.ct-container { width: min(1140px, 92%); }
}

/* Tablet Landscape ≤ 1024px */
@media (max-width: 1024px) {
	.ct-container { width: 94%; }
	.ct-section { padding: 80px 0; }
	.ct-section__head { margin-bottom: 50px; }
	.ct-about__grid,
	.ct-discover__grid,
	.ct-contact__grid {
		grid-template-columns: 1fr;
		gap: 50px;
	}
	.ct-about__highlights { grid-template-columns: 1fr 1fr; }
	.ct-footer__grid { grid-template-columns: 1.5fr 1fr 1fr; gap: 30px; }
	.ct-nav a { padding: 8px 12px; font-size: 14px; }
}

/* Tablet Portrait ≤ 900px — switch to mobile menu */
@media (max-width: 900px) {
	.ct-nav-toggle { display: block; z-index: 10000; }
	.ct-nav ul {
		position: fixed;
		top: 0; right: -100%;
		width: 85%;
		max-width: 360px;
		height: 100vh;
		background: #fff;
		flex-direction: column;
		padding: 100px 30px 40px;
		gap: 0;
		overflow-y: auto;
		transition: right .35s ease;
		box-shadow: -10px 0 40px rgba(0,0,0,.18);
	}
	.ct-nav ul.is-open { right: 0; }
	.ct-nav a {
		display: block;
		padding: 16px 0;
		border-bottom: 1px solid #f0f0f0;
		color: #1a1a1a !important;
		font-size: 16px;
	}
	.ct-nav .ct-btn {
		margin: 20px 0 0;
		text-align: center;
		display: block;
		border-bottom: 0 !important;
	}
	.ct-site-header:not(.is-scrolled) .ct-nav a { color: #1a1a1a !important; }
	.ct-site-header:not(.is-scrolled) .ct-nav .ct-btn { color: #fff !important; }

	/* Body lock when menu is open */
	body.menu-open { overflow: hidden; }

	/* Mobile menu overlay */
	body.menu-open::after {
		content: '';
		position: fixed; inset: 0;
		background: rgba(0,0,0,.5);
		z-index: 998;
	}
}

/* Tablet ≤ 768px */
@media (max-width: 768px) {
	body { font-size: 15px; }
	.ct-section { padding: 70px 0; }
	.ct-hero { min-height: 90vh; }
	.ct-hero__inner { padding: 100px 0 70px; }
	.ct-hero__title { font-size: clamp(2rem, 7vw, 2.8rem); }
	.ct-hero__cta { flex-direction: column; align-items: stretch; gap: 12px; max-width: 280px; margin: 0 auto; }
	.ct-hero__cta .ct-btn { width: 100%; }
	.ct-rooms__grid { grid-template-columns: 1fr; max-width: 460px; margin: 0 auto; }
	.ct-amenities__grid { grid-template-columns: 1fr 1fr; gap: 16px; }
	.ct-gallery__grid { grid-template-columns: 1fr 1fr; gap: 12px; }
	.ct-discover__stats { grid-template-columns: 1fr 1fr; }
	.ct-footer__grid { grid-template-columns: 1fr; text-align: center; gap: 36px; }
	.ct-footer__brand img { margin-inline: auto; }
	.ct-about__media::after { width: 80px; height: 80px; bottom: -10px; right: -10px; }
	.ct-contact__map { min-height: 360px; }
	.ct-contact__map iframe { min-height: 360px; }
}

/* Mobile Large ≤ 600px */
@media (max-width: 600px) {
	.ct-section { padding: 60px 0; }
	.ct-section__head { margin-bottom: 40px; }
	.ct-section__eyebrow { font-size: 11px; letter-spacing: 2px; }
	.ct-hero__inner { padding: 90px 0 60px; }
	.ct-hero__eyebrow { font-size: 11px; padding: 6px 16px; }
	.ct-hero__price { font-size: 13px; padding: 10px 18px; }
	.ct-hero__price strong { font-size: 1.1rem; }
	.ct-hero__scroll { display: none; }
	.ct-about__highlights { grid-template-columns: 1fr; }
	.ct-amenity { padding: 28px 16px; }
	.ct-contact__info { padding: 32px 22px; }
	.ct-contact__list svg { width: 18px; height: 18px; }
	.ct-room__body { padding: 22px 20px 24px; }
	.ct-btn { padding: 12px 24px; font-size: 14px; }
}

/* Mobile ≤ 480px */
@media (max-width: 480px) {
	.ct-container { width: 92%; }
	.ct-section { padding: 50px 0; }
	.ct-section__head { margin-bottom: 32px; }
	.ct-amenities__grid { grid-template-columns: 1fr; gap: 14px; }
	.ct-gallery__grid { grid-template-columns: 1fr; }
	.ct-discover__stats { grid-template-columns: 1fr; }
	.ct-stat { padding: 16px; }
	.ct-stat strong { font-size: 1.5rem; }
	.ct-float-call {
		width: 52px; height: 52px;
		bottom: 16px; right: 16px;
	}
	.ct-float-call svg { width: 24px; height: 24px; }
	.ct-logo img { max-height: 44px; }
	.is-scrolled .ct-logo img { max-height: 38px; }
	.ct-site-header { padding: 12px 0; }
	.is-scrolled.ct-site-header { padding: 8px 0; }
	.ct-page-content { padding: 130px 0 60px; }
}

/* Small mobile ≤ 360px */
@media (max-width: 360px) {
	.ct-hero__title { font-size: 1.8rem; }
	.ct-hero__subtitle { font-size: .95rem; }
	.ct-section__title { font-size: 1.5rem; }
	.ct-amenity__icon { width: 52px; height: 52px; }
	.ct-amenity__icon svg { width: 24px; height: 24px; }
}

/* Reduced motion accessibility */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
		scroll-behavior: auto !important;
	}
	.ct-fade-in { opacity: 1; transform: none; }
}

/* High-DPI / retina image crispness */
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
	.ct-room__media img,
	.ct-gallery__item img,
	.ct-about__media img { image-rendering: -webkit-optimize-contrast; }
}

/* Print */
@media print {
	.ct-site-header, .ct-float-call, .ct-hero__scroll { display: none !important; }
	.ct-hero { min-height: auto; color: #000; }
	.ct-hero::before { display: none; }
	body { color: #000; background: #fff; }
}
