/* =============================================================
   Xellent English — Main Stylesheet
   ============================================================= */
:root{
  --navy-900:#06143a;
  --navy-800:#0b1f4d;
  --navy-700:#13306f;
  --navy-600:#1b4dbd;
  --blue-500:#3b82f6;
  --blue-300:#7eb6ff;
  --blue-100:#e6f0ff;
  --gold-500:#f5b301;
  --gold-600:#e6a200;
  --orange-500:#ff7a00;
  --white:#ffffff;
  --gray-50:#f7f9fc;
  --gray-100:#eef2f8;
  --gray-200:#dde4ee;
  --gray-500:#6b7794;
  --gray-700:#3a425a;
  --gray-900:#0e1530;
  --grad-hero: radial-gradient(120% 80% at 10% 0%, #1b4dbd 0%, #0b1f4d 55%, #06143a 100%);
  --grad-soft: linear-gradient(135deg, #e6f0ff 0%, #ffffff 60%);
  --grad-card: linear-gradient(160deg, #ffffff 0%, #f4f8ff 100%);
  --grad-gold: linear-gradient(135deg, #f5b301 0%, #ff7a00 100%);
  --shadow-sm: 0 4px 14px rgba(11,31,77,.06);
  --shadow-md: 0 12px 36px rgba(11,31,77,.10);
  --shadow-lg: 0 24px 60px rgba(11,31,77,.18);
  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --container: 1200px;
  --transition: .3s cubic-bezier(.2,.7,.2,1);
  --font-display: 'Poppins','Plus Jakarta Sans',system-ui,sans-serif;
  --font-body: 'Plus Jakarta Sans','Inter',system-ui,sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--gray-900);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--navy-700); text-decoration:none; transition:color var(--transition); }
a:hover{ color:var(--blue-500); }

h1,h2,h3,h4{ font-family:var(--font-display); font-weight:700; line-height:1.2; margin:0 0 .5em; color:var(--navy-900); letter-spacing:-.01em; }
h1{ font-size: clamp(2rem, 4.6vw, 3.6rem); }
h2{ font-size: clamp(1.6rem, 3.2vw, 2.4rem); }
h3{ font-size: 1.25rem; }
p{ margin:0 0 1em; color:var(--gray-700); }

.container{ width:100%; max-width:var(--container); margin:0 auto; padding:0 24px; }
.eyebrow{ display:inline-block; font-weight:700; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--blue-500); margin-bottom:8px; }
.screen-reader-text{ position:absolute !important; clip:rect(1px,1px,1px,1px); width:1px; height:1px; overflow:hidden; }
.skip-link{ position:absolute; left:-9999px; }
.skip-link:focus{ left:8px; top:8px; background:var(--gold-500); padding:8px 12px; z-index:9999; border-radius:8px; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 22px; border-radius:999px;
  font-weight:600; font-family:var(--font-display);
  font-size:.95rem; line-height:1;
  border:none; cursor:pointer; transition:all var(--transition);
  text-align:center; white-space:nowrap;
}
.btn-lg{ padding:16px 28px; font-size:1rem; }
.btn-primary{
  background:linear-gradient(135deg,var(--blue-500),var(--navy-700));
  color:var(--white);
  box-shadow:0 10px 24px rgba(27,77,189,.35);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 32px rgba(27,77,189,.5); color:#fff; }
.btn-outline{ background:transparent; color:var(--navy-800); border:2px solid var(--gray-200); }
.btn-outline:hover{ border-color:var(--blue-500); color:var(--blue-500); transform:translateY(-2px); }
.btn-outline-white{ background:transparent; color:#fff; border:2px solid rgba(255,255,255,.5); }
.btn-outline-white:hover{ background:#fff; color:var(--navy-800); }
.btn-ghost{ background:rgba(255,255,255,.12); color:#fff; backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.25); }
.btn-ghost:hover{ background:rgba(255,255,255,.22); color:#fff; transform:translateY(-2px); }
.btn-gold{ background:var(--grad-gold); color:#1a0f00; box-shadow:0 10px 28px rgba(245,179,1,.45); }
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 16px 36px rgba(245,179,1,.6); color:#1a0f00; }

/* Header */
.site-header{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid rgba(11,31,77,.06);
  transition:all var(--transition);
}
.site-header.is-scrolled{ box-shadow:var(--shadow-sm); background:rgba(255,255,255,.96); }
.site-header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:6px 24px;
  min-height:56px;
}
.site-logo{ display:flex; align-items:center; gap:10px; font-family:var(--font-display); font-weight:800; color:var(--navy-900); font-size:1.25rem; }
.logo-mark{
  width:38px; height:38px; border-radius:10px;
  display:grid; place-items:center;
  background:linear-gradient(135deg,var(--blue-500),var(--navy-800));
  color:#fff; font-weight:800; box-shadow:0 6px 14px rgba(27,77,189,.35);
}
.logo-text span{ color:var(--blue-500); }
.primary-menu{
  list-style:none; display:flex; gap:6px; margin:0; padding:0;
}
.primary-menu li{ position:relative; }
.primary-menu a{
  display:inline-block; padding:10px 14px; border-radius:10px;
  font-weight:500; color:var(--gray-700); font-size:.95rem;
  transition:all var(--transition);
}
.primary-menu a:hover, .primary-menu .current-menu-item > a{
  color:var(--navy-800); background:var(--blue-100);
}
.site-header__cta .btn{ padding:10px 18px; font-size:.9rem; }
.nav-toggle{ display:none; background:transparent; border:0; width:42px; height:42px; padding:0; cursor:pointer; }
.nav-toggle span{ display:block; width:22px; height:2px; background:var(--navy-800); margin:5px auto; transition:all .3s; border-radius:2px; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

@media (max-width: 1024px){
  .site-header__cta{ display:none; }
}
@media (max-width: 880px){
  .nav-toggle{ display:block; }
  .site-nav{
    position:fixed; inset:72px 0 auto 0;
    background:#fff;
    transform:translateY(-120%); transition:transform .35s ease;
    box-shadow:var(--shadow-lg);
    padding:16px 24px 32px;
  }
  .site-nav.is-open{ transform:translateY(0); }
  .primary-menu{ flex-direction:column; gap:0; }
  .primary-menu a{ display:block; padding:14px 6px; border-bottom:1px solid var(--gray-100); border-radius:0; }
}

/* HERO */
.xe-hero{ position:relative; overflow:hidden; padding:90px 0 80px; color:#fff; }
.xe-hero__bg{
  position:absolute; inset:0;
  background:var(--grad-hero);
  z-index:0;
}
.xe-hero__bg::after{
  content:""; position:absolute; inset:0;
  background-image:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.4), transparent 40%),
    radial-gradient(2px 2px at 80% 20%, rgba(255,255,255,.3), transparent 40%),
    radial-gradient(1.5px 1.5px at 60% 70%, rgba(255,255,255,.35), transparent 40%);
  opacity:.7;
}
.xe-hero__overlay{
  position:absolute; inset:0; z-index:1;
  background:radial-gradient(ellipse at 80% 20%, rgba(245,179,1,.18), transparent 50%);
}
.xe-hero__inner{
  position:relative; z-index:2;
  display:grid; grid-template-columns: 1.15fr .85fr; gap:48px; align-items:center;
}
.xe-hero__content { color:#fff; }
.xe-hero__content--center { text-align:center; margin:0 auto; max-width:780px; }
.xe-hero__cta--center { justify-content:center; }
.xe-hero h1{ color:#fff; }
.xe-badge{
  display:inline-block; padding:8px 14px; border-radius:999px;
  background:rgba(255,255,255,.12); color:#fff; backdrop-filter:blur(8px);
  font-size:.85rem; font-weight:500; border:1px solid rgba(255,255,255,.18);
  margin-bottom:18px;
  animation: fadeUp .8s ease both;
}
.xe-grad-text{
  background:linear-gradient(120deg,var(--gold-500),#ffd271 60%,#fff);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.xe-hero__sub{ color:rgba(255,255,255,.85); font-size:1.12rem; max-width:580px; margin-bottom:28px; }
.xe-hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:42px; }

.xe-trust{
  display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:18px;
  padding:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius-md);
  backdrop-filter:blur(10px);
}
.xe-trust__item{ text-align:center; color:#fff; }
.xe-trust__item strong{ display:block; font-size:1.8rem; font-family:var(--font-display); color:var(--gold-500); }
.xe-trust__item span{ font-size:.82rem; color:rgba(255,255,255,.8); }

.xe-hero__visual{ position:relative; min-height:420px; }
.xe-hero__photo{
  position:absolute; inset:0;
  border-radius:var(--radius-xl);
  background:
    linear-gradient(135deg, rgba(27,77,189,.35), rgba(11,31,77,.5)),
    radial-gradient(circle at 30% 30%, #7eb6ff 0%, #1b4dbd 60%, #06143a 100%);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.xe-hero__photo{
  position:absolute;
  inset:0;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-lg);

  background:url("https://xellentenglish.com/wp-content/uploads/2026/06/Untitled-design-11.png") center center / cover no-repeat !important;
}

.xe-hero__photo::after{
  display:none !important;
  content:"";
}
.xe-hero__card{
  position:absolute; z-index:2;
  display:flex; align-items:center; gap:12px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  padding:14px 18px; border-radius:16px;
  box-shadow:var(--shadow-md); color:var(--navy-900);
  font-size:.85rem;
  animation: floatY 5s ease-in-out infinite;
}
.xe-hero__card strong{ display:block; font-size:.95rem; }
.xe-hero__card small{ color:var(--gray-500); font-size:.75rem; }
.xe-hero__card--1{ top:-10px; left:-20px; animation-delay:.2s; }
.xe-hero__card--2{ bottom:-15px; right:-10px; color:var(--blue-500); animation-delay:.6s; }
.xe-avatar{ width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,#7eb6ff,#1b4dbd); }
.xe-avatar--lg{ width:52px; height:52px; }

.xe-hero--page{ padding:80px 0 60px; }

@keyframes fadeUp{ from{ opacity:0; transform:translateY(16px);} to{ opacity:1; transform:none;} }
@keyframes floatY{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-10px);} }

@media (max-width: 880px){
  .xe-hero__inner{ grid-template-columns:1fr; gap:36px; }
  .xe-hero__visual{ min-height:280px; }
  .xe-trust{ grid-template-columns:repeat(2,1fr); }
}

/* Sections */
.xe-section{ padding: 90px 0; }
.xe-section--alt{ background:var(--grad-soft); }
.xe-section__head{ text-align:center; max-width:720px; margin:0 auto 56px; }
.xe-section__head p{ font-size:1.05rem; }

/* Grid */
.xe-grid{ display:grid; gap:24px; }
.xe-grid--3{ grid-template-columns:repeat(3, minmax(0,1fr)); }
@media (max-width: 880px){ .xe-grid--3{ grid-template-columns:1fr; } }
@media (min-width:881px) and (max-width:1100px){ .xe-grid--3{ grid-template-columns:repeat(2,1fr); } }

/* Card */
.xe-card{
  background:var(--grad-card);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  padding:28px;
  box-shadow:var(--shadow-sm);
  transition:all var(--transition);
  position:relative; overflow:hidden;
}
.xe-card::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(27,77,189,0), rgba(245,179,1,.08));
  opacity:0; transition:opacity var(--transition);
}
.xe-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:var(--blue-300); }
.xe-card:hover::before{ opacity:1; }
.xe-card__icon{
  width:56px; height:56px; border-radius:14px;
  display:grid; place-items:center; color:#fff;
  background:linear-gradient(135deg,var(--blue-500),var(--navy-700));
  margin-bottom:18px;
  box-shadow:0 8px 20px rgba(27,77,189,.3);
  position:relative; z-index:1;
}
.xe-card h3{ position:relative; z-index:1; }
.xe-card p{ position:relative; z-index:1; margin-bottom:0; }

.xe-card--program .xe-card__thumb{
  height:160px; border-radius:var(--radius-md);
  background:linear-gradient(135deg,var(--blue-100),#fff);
  display:grid; place-items:center;
  color:var(--blue-500);
  margin-bottom:18px;
  border:1px solid var(--gray-100);
}
.xe-card--program .xe-card__thumb svg{ width:54px; height:54px; }
.xe-link{ display:inline-flex; align-items:center; gap:6px; font-weight:600; color:var(--blue-500); margin-top:8px; }
.xe-link:hover{ gap:10px; }

/* About */
.xe-about{ display:grid; grid-template-columns:1fr 1.1fr; gap:60px; align-items:center; }
.xe-about__media{ position:relative; }
.xe-about__photo{
  aspect-ratio:4/5; border-radius:var(--radius-xl);
  background:linear-gradient(135deg, var(--blue-100), var(--blue-300) 60%, var(--navy-700));
  box-shadow:var(--shadow-lg); position:relative; overflow:hidden;
}
.xe-about__photo::after{ content:"🌍"; position:absolute; inset:0; display:grid; place-items:center; font-size:120px; opacity:.55; }
.xe-about__badge{
  position:absolute; bottom:-20px; right:-20px;
  background:#fff; padding:18px 24px; border-radius:18px;
  box-shadow:var(--shadow-md); text-align:center;
}
.xe-about__badge strong{ display:block; font-size:1.8rem; color:var(--blue-500); font-family:var(--font-display); }
.xe-about__badge span{ font-size:.85rem; color:var(--gray-500); }
.xe-list{ list-style:none; padding:0; margin:0 0 24px; }
.xe-list li{ display:flex; gap:10px; align-items:flex-start; margin-bottom:12px; color:var(--gray-700); }
.xe-list li .xe-icon{ color:var(--blue-500); flex-shrink:0; margin-top:3px; }
@media (max-width: 880px){ .xe-about{ grid-template-columns:1fr; } .xe-about__badge{ right:10px; bottom:10px; } }

/* Testimonial */
.xe-testi-track{
  display:flex; gap:24px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding-bottom:18px; scrollbar-width:thin;
}
.xe-testi-track::-webkit-scrollbar{ height:6px; }
.xe-testi-track::-webkit-scrollbar-thumb{ background:var(--gray-200); border-radius:99px; }
.xe-testi{
  flex:0 0 360px; scroll-snap-align:start;
  background:#fff; border-radius:var(--radius-lg);
  padding:28px; border:1px solid var(--gray-100);
  box-shadow:var(--shadow-sm);
}
.xe-testi__stars{ color:var(--gold-500); letter-spacing:2px; margin-bottom:10px; }
.xe-testi p{ font-style:italic; color:var(--gray-700); }
.xe-testi__person{ display:flex; align-items:center; gap:12px; margin-top:14px; }
.xe-testi__person strong{ display:block; color:var(--navy-900); }
.xe-testi__person small{ color:var(--gray-500); font-size:.8rem; }
.xe-testi--video .xe-testi__video{
  height:160px; border-radius:var(--radius-md);
  background:linear-gradient(135deg, var(--navy-700), var(--navy-900));
  display:grid; place-items:center; color:#fff; margin-bottom:18px;
}
.xe-testi--video .xe-testi__video svg{ width:46px; height:46px; }

/* FAQ */
.xe-faq{ max-width:820px; margin:0 auto; display:flex; flex-direction:column; gap:14px; }
.xe-faq__item{
  background:#fff; border:1px solid var(--gray-100); border-radius:16px;
  padding:18px 22px; box-shadow:var(--shadow-sm);
  transition:all var(--transition);
}
.xe-faq__item[open]{ border-color:var(--blue-300); box-shadow:var(--shadow-md); }
.xe-faq__item summary{
  list-style:none; cursor:pointer; display:flex; justify-content:space-between;
  align-items:center; font-weight:600; color:var(--navy-900); font-family:var(--font-display);
}
.xe-faq__item summary::-webkit-details-marker{ display:none; }
.xe-faq__toggle{
  width:30px; height:30px; border-radius:50%;
  display:grid; place-items:center; background:var(--blue-100); color:var(--blue-500);
  font-size:1.2rem; transition:all var(--transition);
}
.xe-faq__item[open] .xe-faq__toggle{ transform:rotate(45deg); background:var(--blue-500); color:#fff; }
.xe-faq__answer{ padding-top:14px; color:var(--gray-700); }

/* CTA Band */
.xe-cta-band{
  padding:80px 0;
  background:var(--grad-hero);
  color:#fff;
  text-align:center;
  position:relative; overflow:hidden;
}
.xe-cta-band::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 20% 80%, rgba(245,179,1,.25), transparent 50%);
}
.xe-cta-band > .container{ position:relative; }
.xe-cta-band h2{ color:#fff; }
.xe-cta-band p{ color:rgba(255,255,255,.85); max-width:600px; margin:0 auto 28px; font-size:1.1rem; }
.xe-cta-band__buttons{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* Pricing */
.xe-pricing{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width: 880px){ .xe-pricing{ grid-template-columns:1fr; } }
.xe-price-card{
  background:#fff; border-radius:var(--radius-lg); padding:32px;
  border:1px solid var(--gray-100); box-shadow:var(--shadow-sm);
  position:relative; transition:all var(--transition);
  display:flex; flex-direction:column;
}
.xe-price-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.xe-price-card--featured{
  background:var(--grad-hero); color:#fff; transform:scale(1.04);
  border:none;
}
.xe-price-card--featured h3, .xe-price-card--featured .xe-price strong{ color:#fff; }
.xe-price-card--featured p, .xe-price-card--featured ul li{ color:rgba(255,255,255,.85); }
.xe-pop{ position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  background:var(--grad-gold); color:#1a0f00; font-size:.75rem; font-weight:700;
  padding:6px 14px; border-radius:99px; letter-spacing:.05em; }
.xe-price-card header h3{ margin-bottom:4px; }
.xe-price-card header p{ color:var(--gray-500); margin-bottom:18px; }
.xe-price{ display:flex; align-items:baseline; gap:4px; margin-bottom:22px; }
.xe-price .cur{ font-size:1rem; color:var(--gray-500); }
.xe-price strong{ font-size:2.6rem; font-family:var(--font-display); color:var(--navy-900); }
.xe-price small{ color:var(--gray-500); font-size:.85rem; margin-left:4px; }
.xe-price-card ul{ list-style:none; padding:0; margin:0 0 24px; flex:1; }
.xe-price-card ul li{ display:flex; gap:10px; align-items:center; padding:8px 0; border-bottom:1px solid rgba(0,0,0,.06); color:var(--gray-700); }
.xe-price-card--featured ul li{ border-color:rgba(255,255,255,.12); }
.xe-price-card--featured ul li svg{ color:var(--gold-500); }
.xe-price-card ul li svg{ color:var(--blue-500); flex-shrink:0; }

/* Timeline */
.xe-timeline{ list-style:none; padding:0; max-width:720px; margin:0 auto; counter-reset:tl; position:relative; }
.xe-timeline::before{ content:""; position:absolute; left:23px; top:14px; bottom:14px; width:2px; background:linear-gradient(var(--blue-500),var(--gold-500)); }
.xe-timeline li{ display:flex; gap:20px; padding:14px 0; position:relative; align-items:flex-start; }
.xe-timeline li span{
  width:48px; height:48px; border-radius:50%; flex-shrink:0;
  display:grid; place-items:center; background:#fff; border:2px solid var(--blue-500);
  color:var(--blue-500); font-weight:700; font-family:var(--font-display); font-size:1.1rem;
  box-shadow:0 4px 12px rgba(27,77,189,.2); z-index:1;
}
.xe-timeline li h4{ margin:6px 0 4px; }
.xe-timeline li p{ margin:0; }

/* Contact page */
.xe-contact{ display:grid; grid-template-columns:1fr 1.1fr; gap:48px; }
@media (max-width: 880px){ .xe-contact{ grid-template-columns:1fr; } }
.xe-map{ margin-top:24px; border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm); }
.xe-map iframe{ width:100%; height:280px; border:0; display:block; }
.xe-form{ background:#fff; border:1px solid var(--gray-100); border-radius:var(--radius-lg); padding:32px; box-shadow:var(--shadow-md); }
.xe-form label{ display:block; margin-bottom:16px; font-size:.9rem; font-weight:600; color:var(--navy-900); }
.xe-form input, .xe-form select, .xe-form textarea{
  width:100%; margin-top:6px; padding:12px 14px;
  border:1px solid var(--gray-200); border-radius:10px;
  font:inherit; color:var(--gray-900); background:#fff;
  transition:all var(--transition);
}
.xe-form input:focus, .xe-form select:focus, .xe-form textarea:focus{
  outline:none; border-color:var(--blue-500); box-shadow:0 0 0 4px rgba(59,130,246,.15);
}

/* Page hero */
.page-hero{
  padding:90px 0 70px;
  background:var(--grad-hero); color:#fff;
  background-size:cover; background-position:center;
}
.page-hero--solid{ background:var(--grad-hero); }
.page-hero__title{ color:#fff; margin:0; }
.page-hero__meta{ color:rgba(255,255,255,.8); margin-top:8px; }
.page-content{ padding:60px 24px; max-width:880px; }

/* Posts grid */
.posts-grid{ display:grid; gap:24px; grid-template-columns:repeat(3,minmax(0,1fr)); padding:60px 0; }
@media (max-width:880px){ .posts-grid{ grid-template-columns:1fr; } }
.post-card{ background:#fff; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--gray-100); transition:all var(--transition); }
.post-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.post-card__thumb img{ width:100%; height:200px; object-fit:cover; }
.post-card__body{ padding:22px; }
.post-card__title{ font-size:1.15rem; margin-bottom:6px; }
.post-card__title a{ color:var(--navy-900); }
.post-card__title a:hover{ color:var(--blue-500); }
.post-card__meta{ color:var(--gray-500); font-size:.85rem; margin-bottom:10px; }

/* Footer */
.site-footer{
  background:var(--navy-900); color:rgba(255,255,255,.78);
  padding:70px 0 24px; margin-top:60px;
}
.site-footer h4{ color:#fff; margin-bottom:14px; font-size:1.05rem; }
.site-footer a{ color:rgba(255,255,255,.78); }
.site-footer a:hover{ color:var(--gold-500); }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.3fr; gap:36px; }
@media (max-width: 880px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width: 540px){ .footer-grid{ grid-template-columns:1fr; } }
.footer-col ul{ list-style:none; padding:0; margin:0; }
.footer-col ul li{ padding:5px 0; }
.footer-brand p{ color:rgba(255,255,255,.7); margin:14px 0 18px; }
.social-row{ display:flex; gap:10px; }
.social-row a{
  width:38px; height:38px; border-radius:50%;
  display:grid; place-items:center; font-weight:700; font-size:.75rem;
  background:rgba(255,255,255,.08); color:#fff; transition:all var(--transition);
}
.social-row a:hover{ background:var(--gold-500); color:var(--navy-900); transform:translateY(-3px); }
.newsletter{ display:flex; gap:8px; margin-top:14px; }
.newsletter input{
  flex:1; padding:11px 14px; border-radius:99px;
  border:1px solid rgba(255,255,255,.15); background:rgba(255,255,255,.06);
  color:#fff;
}
.newsletter input::placeholder{ color:rgba(255,255,255,.5); }
.newsletter .btn{ padding:11px 18px; font-size:.85rem; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.08); padding-top:20px; margin-top:40px; text-align:center; font-size:.85rem; }

/* Floating WhatsApp */
.xe-floating-wa{
  position:fixed; right:22px; bottom:22px; z-index:99;
  width:58px; height:58px; border-radius:50%;
  background:#25d366; color:#fff;
  display:grid; place-items:center;
  box-shadow:0 10px 26px rgba(37,211,102,.45);
  animation:pulseWA 2.4s ease-in-out infinite;
  transition:transform var(--transition);
}
.xe-floating-wa:hover{ transform:scale(1.08); color:#fff; }
@keyframes pulseWA{ 0%,100%{ box-shadow:0 10px 26px rgba(37,211,102,.45);} 50%{ box-shadow:0 10px 26px rgba(37,211,102,.85);} }

/* Reveal animation */
[data-reveal]{ opacity:0; transform:translateY(20px); transition:all .8s cubic-bezier(.2,.7,.2,1); }
[data-reveal].is-visible{ opacity:1; transform:none; }

/* Misc */
.page-header{ padding:48px 0 0; text-align:center; }
.page-title{ font-size:2rem; }
@media print{ .site-header, .site-footer, .xe-floating-wa{ display:none; } }