/* ====================================
   PLANES — DRAU Design
   ==================================== */

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

.planes-page {
	background: #E8EEF2;
	min-height: 100vh;
	position: relative;
	overflow-x: hidden;
	font-family: 'F37 Ginger', sans-serif;
	color: #1a2750;
}
.planes-page::before {
	content: "";
	position: fixed;
	inset: 0;
	background-image:
		linear-gradient(to right, rgba(0, 25, 126, 0.08) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(0, 25, 126, 0.08) 1px, transparent 1px);
	background-size: 28px 28px;
	-webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
	mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
	pointer-events: none;
	z-index: 0;
}

.logo-planes {
	position: absolute;
	margin: 50px 0 0 50px;
	z-index: 40;
	width: 100px;
	height: 42px;
}
.planes-page .nav { z-index: 999999; }
.planes-page .menu-icon { z-index: 1000000; }
.planes-page.nav-active iframe[src*="wadesk"],
.planes-page.nav-active [id^="wadesk"],
.planes-page.nav-active [class*="wadesk"] { display: none !important; }

.planes-main {
	position: relative;
	z-index: 1;
	max-width: 1300px;
	margin: 0 auto;
	padding: 180px 6% 100px;
}

/* ===== HERO ===== */
.plan-hero {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 80px;
	align-items: end;
	margin-bottom: 60px;
}
.plan-eyebrow,
.srv-eyebrow,
.blog-eyebrow {
	display: inline-block;
	margin: 0 0 24px;
	padding: 10px 20px;
	background: linear-gradient(135deg, #8F2D24 0%, #C94A3A 100%);
	color: #ffffff;
	font-size: 11px;
	font-weight: bold;
	letter-spacing: 2px;
	text-transform: uppercase;
	border-radius: 50px;
	box-shadow: 0 10px 20px rgba(237, 106, 90, 0.2);
	line-height: 1;
}
.plan-title {
	font-size: 56px;
	font-weight: bold;
	line-height: 1.05;
	letter-spacing: -1.5px;
	color: #00197E;
	margin: 0;
}
.plan-hero-intro {
	font-size: 17px;
	line-height: 1.55;
	color: #4A5568;
	margin: 0;
}

/* ===== DISCLAIMER ===== */
.plan-disclaimer {
	background: rgba(255, 193, 7, 0.08);
	border-left: 4px solid #FFC107;
	padding: 24px 32px;
	border-radius: 8px;
	margin-bottom: 60px;
	font-size: 16px;
	line-height: 1.6;
	color: #4A5568;
}
.plan-disclaimer p {
	margin: 0;
}
.plan-disclaimer strong {
	color: #00197E;
}

/* ===== PRICING GRID ===== */
.plans-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	margin-bottom: 80px;
	align-items: start;
}

/* ===== COMPARISON TABLE ===== */
.plan-comparison {
	margin-bottom: 80px;
	background: #ffffff;
	border-radius: 16px;
	padding: 40px;
	box-shadow: 0 20px 50px -20px rgba(0, 25, 126, 0.18);
	overflow-x: auto;
}

.comparison-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 15px;
}

.comparison-table thead {
	background: #F5F7FB;
}

.comparison-table th {
	padding: 24px 16px;
	text-align: left;
	font-weight: bold;
	color: #00197E;
	border-bottom: 2px solid #E8EEF2;
	font-size: 14px;
	letter-spacing: 0.5px;
	vertical-align: middle;
}

.comparison-table th.table-feature {
	width: 35%;
	padding: 20px 16px;
}

.comparison-table th.table-plan {
	width: 21.67%;
	text-align: center;
	font-size: 14px;
	padding: 0;
	position: relative;
}

.plan-header {
	padding: 20px 16px;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 8px;
}


.plan-header-name {
	font-size: 16px;
	font-weight: bold;
	color: #00197E;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	flex-wrap: wrap;
}

.plan-header-price {
	font-size: 32px;
	font-weight: bold;
	color: #00197E;
	line-height: 1;
}

.plan-header-price span {
	font-size: 14px;
	font-weight: 500;
	color: #A0A8B8;
	margin-left: 4px;
}

.comparison-table th.table-recommended {
	background: rgba(37, 211, 102, 0.08);
}

.comparison-table th.table-recommended .plan-header-name,
.comparison-table th.table-recommended .plan-header-price {
	color: #00197E;
}

.badge-small {
	display: block;
	width: 100%;
	background: #25D366;
	color: #ffffff;
	padding: 8px 16px;
	border-radius: 8px 8px 0 0;
	font-size: 11px;
	font-weight: bold;
	letter-spacing: 0.5px;
	text-align: center;
	margin: 0;
	box-sizing: border-box;
	position: absolute;
	top: -28px;
	left: 0;
	right: 0;
}

.comparison-table td {
	padding: 16px;
	border-bottom: 1px solid #E8EEF2;
	color: #4A5568;
}

.comparison-table td.text-center {
	text-align: center;
	font-weight: 500;
}

.comparison-table td.feature-name {
	color: #2D3748;
	font-weight: 500;
}

.comparison-table td.highlighted {
	background: rgba(37, 211, 102, 0.04);
}

.comparison-table tr.section-header {
	background: #F5F7FB;
}

.comparison-table tr.section-header td {
	padding: 18px 16px;
	border-bottom: 2px solid #E8EEF2;
	color: #00197E;
	font-weight: bold;
	font-size: 14px;
	letter-spacing: 0.5px;
}

.table-footnote {
	margin-top: 16px;
	font-size: 13px;
	color: #A0A8B8;
	font-style: italic;
}

/* ===== PLAN CARD ===== */
.plan-card {
	position: relative;
	background: #ffffff;
	border-radius: 16px;
	box-shadow: 0 20px 50px -20px rgba(0, 25, 126, 0.18);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.plan-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 30px 60px -15px rgba(0, 25, 126, 0.25);
}

/* Plan Card Inner */
.plan-card-inner {
	padding: 40px;
	display: flex;
	flex-direction: column;
	height: 100%;
}

/* Plan Badge */
.plan-badge {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	background: #25D366;
	color: #ffffff;
	padding: 8px 20px;
	border-radius: 50px;
	font-size: 13px;
	font-weight: bold;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	box-shadow: 0 8px 20px rgba(37, 211, 102, 0.3);
}

/* Plan Name */
.plan-name {
	font-size: 24px;
	font-weight: bold;
	color: #00197E;
	margin: 0 0 16px;
	letter-spacing: -0.5px;
}

/* Plan Price */
.plan-price {
	display: flex;
	align-items: baseline;
	gap: 6px;
	margin-bottom: 8px;
}
.price-amount {
	font-size: 42px;
	font-weight: bold;
	color: #00197E;
	line-height: 1;
}
.price-period {
	font-size: 14px;
	color: #A0A8B8;
	font-weight: 500;
}

/* Plan Description */
.plan-description {
	font-size: 15px;
	color: #4A5568;
	line-height: 1.5;
	margin: 0 0 32px;
}

/* Plan Features */
.plan-features {
	list-style: none;
	padding: 0;
	margin: 0 0 32px;
	flex-grow: 1;
}

.plan-feature {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	margin-bottom: 14px;
	font-size: 15px;
	line-height: 1.5;
	color: #4A5568;
}

.plan-feature.included {
	color: #2D3748;
}

.plan-feature.excluded {
	color: #A0A8B8;
	text-decoration: line-through;
	opacity: 0.7;
}

.plan-feature.info {
	font-size: 13px;
	color: #A0A8B8;
	margin-top: 8px;
	margin-bottom: 0;
}

.feature-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	font-weight: bold;
	font-size: 18px;
	flex-shrink: 0;
}

.plan-feature.included .feature-icon {
	color: #25D366;
}

.plan-feature.excluded .feature-icon {
	color: #cbd5e0;
}

.feature-note {
	font-weight: 500;
	color: #ED6A5A;
}

/* ===== CTA BUTTONS ===== */
.plan-cta-btn {
	display: inline-block;
	padding: 16px 36px;
	background: #25D366;
	color: #ffffff;
	font-family: 'F37 Ginger', sans-serif;
	font-size: 15px;
	font-weight: bold;
	letter-spacing: 0.5px;
	text-decoration: none;
	border-radius: 50px;
	box-shadow: 0 10px 28px rgba(37, 211, 102, 0.35);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.plan-cta-btn:hover {
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 14px 34px rgba(37, 211, 102, 0.45);
}

.plan-final-actions {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

.plan-cta-btn--wa { background: #25D366; }
.plan-cta-btn--alt {
	background: #ffffff;
	color: #00197E;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}
.plan-cta-btn--alt:hover {
	color: #00197E;
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.25);
}

/* ===== PLAN VARIANTS ===== */
.plan-card--basic {
	transform: scale(1.05);
	box-shadow: 0 30px 60px -20px rgba(0, 25, 126, 0.25);
}
.plan-card--basic:hover {
	box-shadow: 0 40px 80px -15px rgba(0, 25, 126, 0.3);
}

/* ===== TRABAJAMOS CON ===== */
.trabajamos-con {
	margin-bottom: 80px;
	padding: 60px 40px;
}

.trabajamos-con-title {
	font-size: 32px;
	font-weight: bold;
	color: #00197E;
	text-align: center;
	margin: 0 0 48px;
	letter-spacing: -0.5px;
}

.trabajamos-con-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 60px 40px;
	align-items: center;
	justify-items: center;
}

.trabajamos-con-item {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 70px;
}

.trabajamos-con-item img {
	width: 80%;
	height: 80%;
	object-fit: contain;
	filter: grayscale(100%);
	transition: filter 0.3s ease;
}

.trabajamos-con-item:hover img {
	filter: grayscale(0%);
}

/* ===== FINAL CTA ===== */
.plan-final-cta {
	background: linear-gradient(135deg, #00197E 0%, #002bb0 100%);
	border-radius: 28px;
	padding: 70px 50px;
	text-align: center;
	color: #ffffff;
	box-shadow: 0 30px 70px -20px rgba(0, 25, 126, 0.35);
}

.plan-final-cta h2 {
	font-size: 38px;
	font-weight: bold;
	line-height: 1.15;
	letter-spacing: -1px;
	color: #ffffff;
	margin: 0 0 32px;
}

.plan-final-cta p {
	font-size: 17px;
	color: rgba(255, 255, 255, 0.85);
	margin: 0 0 32px;
	line-height: 1.5;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

/* ===== RESPONSIVE ===== */
@media only screen and (max-width: 1300px) {
	.planes-main { padding: 160px 6% 80px; }
	.plan-hero { gap: 60px; }
	.plan-title { font-size: 48px; }
	.trabajamos-con-grid { gap: 32px; }
}

@media only screen and (max-width: 1100px) {
	.logo-planes { margin: 30px 0 0 30px; }
	.plan-title { font-size: 42px; }
	.plans-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 24px;
	}
	.plan-card--basic {
		transform: scale(1.03);
	}
}

@media only screen and (max-width: 900px) {
	.planes-main { padding: 120px 6% 80px; }
	.plan-hero {
		grid-template-columns: 1fr;
		gap: 40px;
	}
	.plan-title { font-size: 38px; }
	.plan-comparison { padding: 40px 24px; }
	.comparison-table { font-size: 14px; }
	.comparison-table th,
	.comparison-table td { padding: 14px 12px; }
	.plan-header { padding: 16px 12px; gap: 6px; }
	.plan-header-name { font-size: 14px; }
	.plan-header-price { font-size: 28px; }
	.plans-grid {
		grid-template-columns: 1fr;
		gap: 24px;
	}
	.plan-card--basic {
		transform: scale(1);
	}
	.trabajamos-con-grid {
		grid-template-columns: repeat(5, 1fr);
		gap: 28px;
	}
	.plan-final-cta {
		padding: 50px 30px;
	}
	.plan-final-cta h2 {
		font-size: 28px;
	}
}

@media only screen and (max-width: 768px) {
	.planes-page::before { background-size: 18px 18px; }
	.logo-planes { width: 70px; margin: 20px 0 0 20px; }
	.planes-main { padding: 140px 6% 60px; }
	.plan-hero { margin-bottom: 40px; }
	.plan-title { font-size: 32px; letter-spacing: -1px; }
	.plan-hero-intro { font-size: 15px; }
	.plan-eyebrow,
	.srv-eyebrow { font-size: 11px; }
	.plan-comparison {
		padding: 40 px 16px;
		margin-bottom: 50px;
		overflow-x: visible;
	}
	.comparison-table { font-size: 12px; }
	.comparison-table th,
	.comparison-table td { padding: 10px 6px; }
	.comparison-table th.table-feature { width: 38%; }
	.comparison-table th.table-plan { font-size: 12px; }
	.plan-header { padding: 12px 8px; gap: 4px; }
	.plan-header-name { font-size: 12px; }
	.plan-header-price { font-size: 22px; }
	.badge-small { font-size: 9px; padding: 9px 12px; }
	.table-footnote { font-size: 12px; margin-top: 12px; }
	.plans-grid { margin-bottom: 60px; }
	.plan-card-inner { padding: 32px 24px; }
	.plan-name { font-size: 20px; }
	.price-amount { font-size: 36px; }
	.plan-description { font-size: 14px; margin-bottom: 24px; }
	.plan-feature { font-size: 14px; margin-bottom: 12px; }
	.plan-features { margin-bottom: 24px; }
	.trabajamos-con {
		padding: 40px 24px;
		margin-bottom: 50px;
	}
	.trabajamos-con-title { font-size: 26px; margin-bottom: 36px; }
	.trabajamos-con-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}
	.trabajamos-con-item { height: 55px; }
	.plan-final-cta { padding: 50px 28px; border-radius: 20px; }
	.plan-final-cta h2 { font-size: 24px; margin-bottom: 24px; }
	.plan-cta-btn { padding: 14px 28px; font-size: 14px; }
	.plan-final-cta p { font-size: 15px; }
}

@media only screen and (max-width: 480px) {
	.planes-main { padding: 110px 5% 50px; }
	.logo-planes { width: 60px; }
	.plan-title { font-size: 28px; }
	.plan-eyebrow,
	.srv-eyebrow { font-size: 10px; }
	.plan-comparison {
		padding: 40px 8px 20px;
		margin-bottom: 40px;
		overflow-x: visible;
		margin-left: 0;
		margin-right: 0;
		box-sizing: border-box;
		width: 100%;
	}
	.comparison-table { font-size: 11px; line-height: 1.35; box-sizing: border-box; }
	.comparison-table th,
	.comparison-table td { padding: 7px 4px; }
	.comparison-table th.table-feature { width: 40%; }
	.comparison-table th.table-plan { font-size: 10px; }
	.plan-header { padding: 10px 6px; gap: 2px; }
	.plan-header-name { font-size: 11px; }
	.plan-header-price { font-size: 18px; }
	.badge-small { font-size: 8px; padding: 9px 8px; margin: 0 0 3px 0; }
	.table-footnote { font-size: 11px; margin-top: 10px; }
	.plan-name { font-size: 18px; margin-bottom: 12px; }
	.price-amount { font-size: 32px; }
	.plan-description { font-size: 13px; margin-bottom: 20px; }
	.plan-feature { font-size: 13px; margin-bottom: 10px; }
	.plan-badge { font-size: 11px; padding: 6px 16px; }
	.trabajamos-con {
		padding: 30px 16px;
		margin-bottom: 40px;
	}
	.trabajamos-con-title { font-size: 20px; margin-bottom: 24px; }
	.trabajamos-con-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 16px;
	}
	.trabajamos-con-item { height: 45px; }
	.plan-final-cta { padding: 50px 28px; margin-bottom: 40px; }
	.plan-final-cta h2 { font-size: 22px; margin-bottom: 24px; }
	.plan-final-cta p { font-size: 14px; margin-bottom: 24px; }
	.plan-cta-btn { padding: 14px 28px; font-size: 14px; }
	.plan-final-actions { flex-direction: column; align-items: stretch; }
}

@media only screen and (max-width: 375px) {
	.logo-planes { width: 60px; }
	.planes-main { padding: 100px 4% 40px; }
	.plan-title { font-size: 24px; }
	.plan-hero-intro { font-size: 13px; }
	.plan-eyebrow,
	.srv-eyebrow { font-size: 10px; }
	.plan-comparison {
		padding: 28px 8px 8px 8px;
		margin-bottom: 30px;
		overflow-x: visible;
		margin-left: 0;
		margin-right: 0;
		box-sizing: border-box;
		width: 100%;
	}
	.comparison-table { font-size: 10px; line-height: 1.3; }
	.comparison-table th,
	.comparison-table td { padding: 6px 3px; }
	.comparison-table th.table-feature { width: 38%; }
	.comparison-table th.table-plan { font-size: 9px; }
	.plan-header { padding: 9px 5px; gap: 2px; }
	.plan-header-name { font-size: 10px; }
	.plan-header-price { font-size: 16px; }
	.plan-header-price span { font-size: 11px; }
	.badge-small { font-size: 7px; padding: 6px 6px; margin: 0 0 3px 0; }
	.table-footnote { font-size: 10px; margin-top: 8px; }
	.plan-final-cta { padding: 50px 28px; }
	.plan-final-cta h2 { font-size: 20px; margin-bottom: 24px; }
	.plan-final-cta p { font-size: 12px; margin-bottom: 24px; }
	.plan-cta-btn { padding: 14px 28px; font-size: 14px; }
	.plan-final-actions { flex-direction: column; align-items: stretch; }
}

/* Logo y botón hamburguesa se desplazan con el scroll (no fijos).
   relative no sirve para el botón porque perdería el anclaje top/right;
   absolute mantiene la esquina pero scrollea con la página. */
.planes-page .logo-link {
	position: relative;
}
.planes-page .menu-toggle-label {
	position: absolute;
}
