/*
Theme Name: Fantasías de Verano
Theme URI: https://fantasiasdeverano.com
Author: Fantasías de Verano
Author URI: https://fantasiasdeverano.com
Description: Tema premium para la agencia de viajes Fantasías de Verano. Planes de playa, paquetes todo incluido y viajes al Caribe.
Version: 2.0
License: Proprietary
Text Domain: fantasias-de-verano
*/

/* ====== RESET & VARIABLES ====== */
:root{
  --font-display:'Playfair Display',serif;
  --font-body:'DM Sans',sans-serif;
  --bg:#faf8f5;--fg:#1a2332;
  --card:#fff;--card-fg:#1a2332;
  --primary-h:195;--primary-s:85%;--primary-l:28%;
  --primary:hsl(var(--primary-h) var(--primary-s) var(--primary-l));
  --primary-fg:#fff;
  --secondary:hsl(38 90% 55%);--secondary-fg:#1a2332;
  --muted:hsl(38 20% 94%);--muted-fg:hsl(210 10% 46%);
  --accent:hsl(16 85% 58%);--accent-fg:#fff;
  --coral:hsl(16 85% 58%);--coral-light:hsl(16 80% 68%);
  --ocean:hsl(195 85% 28%);--ocean-light:hsl(195 70% 45%);--ocean-dark:hsl(200 90% 18%);
  --sand:hsl(38 50% 92%);--sand-dark:hsl(38 35% 78%);
  --tropical-green:hsl(155 60% 35%);
  --gold:hsl(38 90% 55%);--gold-light:hsl(38 85% 65%);
  --border:hsl(38 20% 88%);
  --radius:0.75rem;
  --gradient-hero:linear-gradient(135deg,hsl(200 90% 18%/.85),hsl(195 85% 28%/.6));
  --gradient-ocean:linear-gradient(135deg,hsl(195 85% 28%),hsl(195 70% 45%));
  --gradient-sunset:linear-gradient(135deg,hsl(16 85% 58%),hsl(38 90% 55%));
  --gradient-tropical:linear-gradient(135deg,hsl(195 85% 28%),hsl(155 60% 35%));
  --shadow-card:0 4px 24px -4px rgba(26,35,50,.08);
  --shadow-card-hover:0 12px 40px -8px rgba(26,35,50,.15);
  --shadow-elevated:0 20px 60px -12px rgba(26,35,50,.2);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--fg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.2}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{max-width:1280px;margin:0 auto;padding:0 1rem}

/* ====== UTILITIES ====== */
.section-padding{padding:4rem 1rem}
@media(min-width:768px){.section-padding{padding:6rem 2rem}}
@media(min-width:1024px){.section-padding{padding:7rem 2rem}}
.text-center{text-align:center}
.badge-offer{display:inline-flex;align-items:center;border-radius:9999px;padding:.25rem .75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--gradient-sunset);color:#fff}

/* ====== BUTTONS ====== */
.btn-whatsapp{display:inline-flex;align-items:center;gap:.5rem;border-radius:9999px;padding:1rem 2rem;font-weight:600;color:#fff;background:var(--tropical-green);box-shadow:0 4px 20px rgba(46,139,87,.4);transition:all .3s;border:0;cursor:pointer;font-size:1rem}
.btn-whatsapp:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(46,139,87,.5)}
.btn-cta{display:inline-flex;align-items:center;gap:.5rem;border-radius:9999px;padding:1rem 2rem;font-weight:600;color:#fff;background:var(--gradient-sunset);box-shadow:0 4px 20px rgba(225,100,60,.4);transition:all .3s;border:0;cursor:pointer;font-size:1rem}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(225,100,60,.5)}
.btn-outline-light{display:inline-flex;align-items:center;gap:.5rem;border-radius:9999px;padding:1rem 2rem;font-weight:600;border:2px solid rgba(255,255,255,.6);color:#fff;backdrop-filter:blur(4px);background:rgba(255,255,255,.1);transition:all .3s;cursor:pointer}
.btn-outline-light:hover{background:rgba(255,255,255,.2);border-color:#fff;transform:translateY(-2px)}

/* ====== NAVBAR ====== */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.site-nav .container{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem}
.nav-logo img{height:3rem;width:auto}
@media(min-width:768px){.nav-logo img{height:3.5rem}}
.nav-links{display:none;list-style:none;gap:1.5rem;align-items:center}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{font-size:.875rem;font-weight:500;color:rgba(26,35,50,.7);transition:color .2s}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}
.nav-actions{display:none;align-items:center;gap:.75rem}
@media(min-width:1024px){.nav-actions{display:flex}}
.nav-phone{display:flex;align-items:center;gap:.35rem;font-size:.875rem;font-weight:500;color:rgba(26,35,50,.7)}
.nav-phone:hover{color:var(--primary)}
.nav-toggle{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:none;border:none;cursor:pointer;color:var(--fg)}
@media(min-width:1024px){.nav-toggle{display:none}}
.mobile-menu{display:none;flex-direction:column;padding:1rem;gap:.5rem;background:var(--card);border-bottom:1px solid var(--border)}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:.5rem 0;font-size:1rem;font-weight:500;color:rgba(26,35,50,.7)}
.mobile-menu a:hover{color:var(--primary)}

/* ====== HERO ====== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:var(--gradient-hero)}
.hero-content{position:relative;z-index:10;max-width:48rem}
.hero h1{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:1.5rem;line-height:1.1}
@media(min-width:640px){.hero h1{font-size:3rem}}
@media(min-width:768px){.hero h1{font-size:3.75rem}}
@media(min-width:1024px){.hero h1{font-size:4.5rem}}
.hero p{font-size:1.125rem;color:rgba(255,255,255,.85);max-width:36rem;margin-bottom:2.5rem;line-height:1.7}
.hero-actions{display:flex;flex-direction:column;gap:1rem}
@media(min-width:640px){.hero-actions{flex-direction:row}}

/* ====== SEARCH BLOCK ====== */
.search-block{margin-top:-5rem;position:relative;z-index:20}
.search-card{background:var(--card);border-radius:1.5rem;padding:1.5rem;box-shadow:var(--shadow-elevated)}
@media(min-width:768px){.search-card{padding:2rem 2.5rem}}
.search-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}
@media(min-width:640px){.search-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.search-grid{grid-template-columns:repeat(4,1fr)}}
.search-select{width:100%;padding:.875rem 1rem .875rem 2.5rem;border-radius:.75rem;background:var(--muted);border:none;font-size:.875rem;color:var(--fg);appearance:none;outline:none}
.search-select:focus{box-shadow:0 0 0 2px var(--primary)}
.search-field{position:relative}
.search-field svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:var(--muted-fg)}

/* ====== DESTINATIONS GRID ====== */
.dest-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.dest-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.dest-grid{grid-template-columns:repeat(3,1fr);gap:2rem}}
.card-dest{position:relative;overflow:hidden;border-radius:1rem;box-shadow:var(--shadow-card);transition:all .5s}
.card-dest:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-6px)}
.card-dest .aspect{position:relative;padding-bottom:133%;overflow:hidden}
.card-dest img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s}
.card-dest:hover img{transform:scale(1.1)}
.card-dest .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,35,50,.8),rgba(26,35,50,.2),transparent)}
.card-dest .tag{position:absolute;top:1rem;left:1rem}
.card-dest .info{position:absolute;bottom:0;left:0;right:0;padding:1.5rem}
.card-dest h3{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:.25rem}
.card-dest .desc{color:rgba(255,255,255,.8);font-size:.875rem;margin-bottom:.75rem}
.card-dest .link{display:inline-flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:600;color:var(--gold-light);transition:gap .3s}
.card-dest:hover .link{gap:.5rem}

/* ====== PACKAGES ====== */
.packages-bg{background:var(--sand)}
.packages-intro{display:grid;gap:3rem;align-items:center;margin-bottom:4rem}
@media(min-width:1024px){.packages-intro{grid-template-columns:1fr 1fr}}
.pkg-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.pkg-grid{grid-template-columns:repeat(3,1fr)}}
.pkg-card{background:var(--card);border-radius:1rem;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-card);transition:all .3s}
.pkg-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-4px)}
.pkg-card .body{padding:1.5rem;flex:1}
.pkg-card .foot{padding:0 1.5rem 1.5rem;margin-top:auto}
.pkg-card h3{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}
.pkg-card .duration{font-size:.875rem;color:var(--muted-fg);margin-bottom:1rem}
.pkg-card .includes{list-style:none;margin-bottom:1.5rem}
.pkg-card .includes li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:rgba(26,35,50,.8);padding:.25rem 0}
.pkg-card .includes li svg{width:1rem;height:1rem;color:var(--tropical-green);flex-shrink:0}
.pkg-card .price-label{font-size:.7rem;color:var(--muted-fg)}
.pkg-card .price{font-size:1.875rem;font-weight:700}

/* ====== BENEFITS ====== */
.benefits-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:640px){.benefits-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.benefits-grid{grid-template-columns:repeat(3,1fr)}}
.benefit-card{background:var(--card);border-radius:1rem;padding:2rem;text-align:center;box-shadow:var(--shadow-card);transition:all .3s}
.benefit-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-card-hover)}
.benefit-icon{width:3.5rem;height:3.5rem;border-radius:.75rem;background:hsla(195,85%,28%,.1);color:var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}
.benefit-card:hover .benefit-icon{background:var(--primary);color:#fff}
.benefit-card h3{font-size:1.125rem;font-weight:700;margin-bottom:.5rem}
.benefit-card p{font-size:.875rem;color:var(--muted-fg);line-height:1.6}

/* ====== OFFERS ====== */
.offers-bg{background:var(--gradient-ocean)}
.offer-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2.5rem}
@media(min-width:768px){.offer-grid{grid-template-columns:1fr 1fr}}
.offer-card{background:var(--card);border-radius:1.5rem;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-elevated)}
@media(min-width:640px){.offer-card{flex-direction:row}}
.offer-card .img-wrap{position:relative;height:14rem;overflow:hidden}
@media(min-width:640px){.offer-card .img-wrap{width:40%;height:auto}}
.offer-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.offer-card:hover img{transform:scale(1.05)}
.offer-card .content{padding:1.5rem;display:flex;flex-direction:column;justify-content:center}
@media(min-width:640px){.offer-card .content{width:60%}}
.offer-card h3{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}
.offer-card .subtitle{font-size:.875rem;color:var(--muted-fg);margin-bottom:1rem}
.offer-prices{display:flex;align-items:baseline;gap:.75rem;margin-bottom:1rem}
.offer-prices .old{color:var(--muted-fg);text-decoration:line-through;font-size:.875rem}
.offer-prices .new{font-size:1.875rem;font-weight:700;color:var(--coral)}
.offer-card .tax{font-size:.7rem;color:var(--muted-fg);margin-bottom:1rem}
.finance-banner{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border-radius:9999px;padding:.75rem 1.5rem;color:#fff;font-size:.875rem}

/* ====== TESTIMONIALS ====== */
.test-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
@media(min-width:768px){.test-grid{grid-template-columns:1fr 1fr}}
.test-card{background:var(--card);border-radius:1rem;padding:2rem;box-shadow:var(--shadow-card)}
.test-stars{display:flex;gap:.25rem;margin-bottom:1rem;color:var(--gold)}
.test-card blockquote{color:rgba(26,35,50,.8);line-height:1.7;margin-bottom:1.5rem;font-style:italic}
.test-author{display:flex;align-items:center;gap:.75rem}
.test-avatar{width:2.75rem;height:2.75rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;color:#fff;background:var(--gradient-ocean)}
.test-name{font-weight:600;font-size:.875rem}
.test-trip{font-size:.75rem;color:var(--muted-fg)}

/* ====== TRUST ====== */
.trust-bg{background:var(--sand);padding:3rem 1rem}
.trust-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
@media(min-width:640px){.trust-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.trust-grid{grid-template-columns:repeat(6,1fr)}}
.trust-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}
.trust-item .icon{width:3rem;height:3rem;border-radius:.75rem;background:hsla(195,85%,28%,.1);color:var(--primary);display:flex;align-items:center;justify-content:center}
.trust-item span{font-size:.75rem;font-weight:500}

/* ====== FAQ ====== */
.faq-list{max-width:48rem;margin:0 auto}
.faq-item{background:var(--card);border-radius:.75rem;margin-bottom:.75rem;box-shadow:var(--shadow-card);overflow:hidden}
.faq-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;background:none;border:none;cursor:pointer;font-weight:600;font-size:1rem;color:var(--fg);text-align:left;font-family:var(--font-body)}
.faq-btn svg{transition:transform .3s;flex-shrink:0;width:1.25rem;height:1.25rem}
.faq-item.open .faq-btn svg{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-answer{max-height:20rem}
.faq-answer p{padding:0 1.5rem 1.25rem;color:var(--muted-fg);line-height:1.7}

/* ====== CTA FINAL ====== */
.cta-section{position:relative;overflow:hidden;background:var(--gradient-ocean)}
.cta-section .deco{position:absolute;border-radius:50%;opacity:.1}
.cta-section .deco-1{top:-50%;right:-25%;width:50rem;height:50rem;background:var(--gold)}
.cta-section .deco-2{bottom:-50%;left:-25%;width:37rem;height:37rem;background:var(--coral)}
.cta-grid{display:grid;gap:3rem;align-items:center;position:relative;z-index:10}
@media(min-width:1024px){.cta-grid{grid-template-columns:1fr 1fr}}
.cta-form{background:var(--card);border-radius:1.5rem;padding:2rem;box-shadow:var(--shadow-elevated)}
.cta-form h3{font-size:1.25rem;font-weight:700;margin-bottom:1.5rem}
.cta-form .field{width:100%;padding:.875rem 1rem;border-radius:.75rem;background:var(--muted);border:none;font-size:.875rem;color:var(--fg);outline:none;font-family:var(--font-body);margin-bottom:1rem}
.cta-form .field:focus{box-shadow:0 0 0 2px var(--primary)}
.cta-form select.field{appearance:none}
.cta-form textarea.field{resize:none;min-height:5rem}
.cta-form .note{font-size:.75rem;color:var(--muted-fg);text-align:center;margin-top:1rem}

/* ====== FOOTER ====== */
.site-footer{position:relative;color:#fff;overflow:hidden}
.footer-texture{position:absolute;inset:0;background-size:cover;background-position:center}
.footer-overlay{position:absolute;inset:0;background:hsla(200,90%,18%,.85)}
.footer-inner{position:relative;padding:4rem 1rem}
.footer-grid{display:grid;grid-template-columns:1fr;gap:2.5rem}
@media(min-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.footer-grid{grid-template-columns:repeat(4,1fr)}}
.footer-brand img{height:4rem;width:auto;margin-bottom:1rem}
.footer-brand p{color:rgba(255,255,255,.7);font-size:.875rem;line-height:1.6;margin-bottom:1rem}
.footer-rnt{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:rgba(255,255,255,.6)}
.footer-rnt svg{width:1rem;height:1rem}
.footer-section h4{font-size:1.125rem;font-weight:600;margin-bottom:1.25rem}
.footer-links{list-style:none}
.footer-links li{margin-bottom:.625rem}
.footer-links a{font-size:.875rem;color:rgba(255,255,255,.7);transition:color .2s}
.footer-links a:hover{color:#fff}
.sede-card{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);backdrop-filter:blur(8px);border-radius:.75rem;padding:.875rem;margin-bottom:1rem;transition:background .2s}
.sede-card:hover{background:rgba(255,255,255,.1)}
.sede-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}
.sede-header svg{width:1rem;height:1rem;color:var(--coral);flex-shrink:0}
.sede-header span{font-weight:600;font-size:.875rem}
.sede-tag{margin-left:.375rem;font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;color:var(--coral);background:rgba(225,100,60,.15);border-radius:9999px;padding:.125rem .5rem}
.sede-addr{font-size:.75rem;color:rgba(255,255,255,.8);margin-left:1.5rem}
.sede-ref{font-size:.68rem;color:rgba(255,255,255,.5);margin-left:1.5rem;display:flex;align-items:center;gap:.25rem;margin-top:.125rem}
.sede-ref svg{width:.75rem;height:.75rem}
.contact-list{list-style:none}
.contact-list li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:rgba(255,255,255,.7);margin-bottom:.875rem}
.contact-list li svg{width:1rem;height:1rem;color:var(--coral);flex-shrink:0}
.contact-list a{color:rgba(255,255,255,.7);transition:color .2s}
.contact-list a:hover{color:#fff}
.contact-schedule{align-items:flex-start!important}
.contact-schedule svg{margin-top:.125rem}
.footer-bottom{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:1rem;font-size:.75rem;color:rgba(255,255,255,.5)}
@media(min-width:768px){.footer-bottom{flex-direction:row}}
.footer-legal{display:flex;gap:1rem}
.footer-legal a{color:rgba(255,255,255,.5);transition:color .2s}
.footer-legal a:hover{color:#fff}

/* ====== WHATSAPP FLOAT ====== */
.wa-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:50;width:4rem;height:4rem;border-radius:50%;background:var(--tropical-green);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(46,139,87,.5);transition:all .3s;animation:pulse-wa 2s infinite}
.wa-float:hover{transform:scale(1.1);box-shadow:0 8px 32px rgba(46,139,87,.6)}
.wa-float svg{width:2rem;height:2rem;fill:#fff}
@keyframes pulse-wa{0%,100%{box-shadow:0 6px 24px rgba(46,139,87,.5)}50%{box-shadow:0 6px 24px rgba(46,139,87,.8),0 0 0 12px rgba(46,139,87,.15)}}

/* ====== DEST DETAIL PAGE ====== */
.dest-detail{padding:4rem 1rem}
@media(min-width:768px){.dest-detail{padding:6rem 2rem}}
.dest-row{display:grid;gap:3rem;align-items:center;margin-bottom:4rem}
@media(min-width:1024px){.dest-row{grid-template-columns:1fr 1fr}}
.dest-row.reverse{direction:rtl}
.dest-row.reverse>*{direction:ltr}
.dest-img{border-radius:1.5rem;overflow:hidden;box-shadow:var(--shadow-elevated)}
.dest-img img{width:100%;height:20rem;object-fit:cover}
@media(min-width:768px){.dest-img img{height:28rem}}
.dest-info h2{font-size:1.875rem;font-weight:700;margin-bottom:1rem}
@media(min-width:768px){.dest-info h2{font-size:3rem}}
.dest-info>p{color:var(--muted-fg);line-height:1.7;margin-bottom:1.5rem}
.dest-ideal{display:flex;align-items:center;gap:.5rem;font-size:.875rem;margin-bottom:1rem}
.dest-ideal svg{width:1rem;height:1rem;color:var(--primary)}
.dest-cols{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}
@media(min-width:640px){.dest-cols{grid-template-columns:1fr 1fr}}
.dest-cols h4{font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.dest-cols h4 svg{width:1rem;height:1rem;color:var(--primary)}
.dest-cols ul{list-style:none}
.dest-cols li{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--muted-fg);padding:.25rem 0}
.dest-cols li svg{width:.875rem;height:.875rem;flex-shrink:0}
.dest-cols li .check{color:var(--tropical-green)}
.dest-cols li .pin{color:var(--coral)}
.dest-pricing{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.dest-pricing .from{font-size:.7rem;color:var(--muted-fg)}
.dest-pricing .amount{font-size:1.875rem;font-weight:700}
.dest-pricing .per{font-size:.7rem;color:var(--muted-fg)}

/* ====== PAGE HERO BANNERS ====== */
.page-hero{padding:6rem 1rem 4rem;text-align:center}
.page-hero h1{font-size:2.5rem;font-weight:700;color:#fff;margin-top:.75rem;margin-bottom:1rem}
@media(min-width:768px){.page-hero h1{font-size:3.75rem}}
.page-hero p{color:rgba(255,255,255,.8);max-width:42rem;margin:0 auto;font-size:1.125rem}
.page-hero .tag{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}

/* ====== ABOUT / NOSOTROS ====== */
.about-grid{display:grid;gap:3rem;align-items:center}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1fr}}
.about-img{border-radius:1.5rem;overflow:hidden;box-shadow:var(--shadow-elevated)}
.about-img img{width:100%;height:20rem;object-fit:cover}
@media(min-width:768px){.about-img img{height:28rem}}

/* ====== LEGAL PAGES ====== */
.legal-page{padding:6rem 1rem 4rem;max-width:48rem;margin:0 auto}
.legal-page .header{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}
.legal-page .header svg{width:2rem;height:2rem;color:var(--primary)}
.legal-page .header h1{font-size:1.875rem;font-weight:700}
@media(min-width:768px){.legal-page .header h1{font-size:2.25rem}}
.legal-page .updated{font-size:.875rem;color:var(--muted-fg);margin-bottom:1.5rem}
.legal-page h2{font-size:1.25rem;font-weight:600;margin:2rem 0 .75rem}
.legal-page p,.legal-page li{color:var(--muted-fg);line-height:1.7;font-size:.9375rem}
.legal-page ul{list-style:disc;padding-left:1.25rem;margin:.5rem 0}
.legal-page li{margin-bottom:.25rem}
.cancel-table{border:1px solid var(--border);border-radius:.75rem;padding:1rem;background:var(--card);margin:1rem 0}
.cancel-table .row{display:flex;justify-content:space-between;padding:.5rem 0}
.cancel-table .head{border-bottom:1px solid var(--border);padding-bottom:.5rem;margin-bottom:.5rem;font-weight:600;color:var(--fg)}
.cancel-table .danger{color:hsl(0 84% 60%);font-weight:600}

/* ====== CHECK LIST ====== */
.check-list{list-style:none;padding:0;margin:0}
.check-list li{display:flex;align-items:center;gap:.75rem;padding:.375rem 0;color:var(--fg)}
.check-list li svg{width:1.5rem;height:1.5rem;border-radius:50%;padding:.25rem;background:var(--primary);color:#fff;flex-shrink:0}

/* ====== SECTION HEADINGS ====== */
.section-tag{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.section-heading{font-size:1.875rem;font-weight:700;margin-top:.75rem;margin-bottom:1rem}
@media(min-width:768px){.section-heading{font-size:3rem}}
.section-desc{color:var(--muted-fg);max-width:42rem;margin:0 auto}
