/* ═══════════════════════════════════════════
   FAMTRAVELERS.COM — Global Styles
   Brand: Montserrat | Navy #17396E | Rosa #E22A63 | Coral #FE7A6A
   ═══════════════════════════════════════════ */

/* ── BRAND TOKENS ── */
:root{
  --navy:#17396E;--rosa:#E22A63;--coral:#FE7A6A;
  --turq:#41BCB9;--crema:#FAF5ED;--amarillo:#FFD379;--verde:#5CBF82;
  --beige:#F3F2EE;--gris:#A5A8AC;--gris-osc:#2E2E2E;
  --white:#FFFFFF;--bg:#FAFBFC;
  --shadow-sm:0 1px 3px rgba(23,57,110,0.04);
  --shadow-md:0 4px 20px rgba(23,57,110,0.06);
  --shadow-lg:0 20px 50px rgba(23,57,110,0.08);
  --shadow-glow:0 10px 30px rgba(226,42,99,0.2);
  --radius-sm:12px;--radius-md:16px;--radius-lg:20px;--radius-xl:28px;--radius-full:50px;
  --ease:cubic-bezier(0.25,0.46,0.45,0.94);
  --content-max:1100px;
  --nav-h:68px;
}

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{font-family:'Montserrat',system-ui,-apple-system,sans-serif;color:var(--gris-osc);background:var(--white);overflow-x:hidden;line-height:1.6;font-weight:400;font-size:15px;}
a{text-decoration:none;color:inherit;transition:color 0.25s;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
img,svg{display:block;max-width:100%;}
ul,ol{list-style:none;}

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5,h6{font-weight:800;color:var(--navy);line-height:1.15;letter-spacing:-0.5px;}
h1{font-size:clamp(32px,5.5vw,56px);letter-spacing:-1.5px;}
h2{font-size:clamp(26px,4vw,40px);}
h3{font-size:clamp(18px,2.5vw,22px);}
p{color:#555;line-height:1.75;font-weight:400;}
.text-gradient{background:linear-gradient(135deg,var(--rosa),var(--coral));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

/* ── LAYOUT ── */
.container{max-width:var(--content-max);margin:0 auto;padding:0 24px;}
.section{padding:100px 24px;}
.section-head{text-align:center;margin-bottom:56px;}
.section-tag{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--rosa);margin-bottom:12px;display:block;}
.section-title{color:var(--navy);}
.section-subtitle{font-size:clamp(14px,1.6vw,16px);color:var(--gris);max-width:560px;margin:16px auto 0;font-weight:400;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border-radius:var(--radius-full);font-size:14px;font-weight:700;letter-spacing:0.3px;transition:all 0.3s var(--ease);}
.btn-primary{background:linear-gradient(135deg,var(--navy),var(--rosa));color:var(--white);box-shadow:var(--shadow-glow);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(226,42,99,0.3);}
.btn-secondary{border:2px solid var(--navy);color:var(--navy);}
.btn-secondary:hover{background:var(--navy);color:var(--white);}
.btn-coral{background:linear-gradient(135deg,var(--rosa),var(--coral));color:var(--white);}
.btn-coral:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(254,122,106,0.35);}
.btn-sm{padding:10px 24px;font-size:12px;}
.btn-lg{padding:16px 40px;font-size:15px;}
.btn-icon{width:48px;height:48px;padding:0;border-radius:50%;}

/* ── CARDS ── */
.card{background:var(--white);border-radius:var(--radius-lg);padding:32px 24px;transition:all 0.35s var(--ease);border:1px solid transparent;position:relative;overflow:hidden;}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(226,42,99,0.08);}
.card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--coral));opacity:0;transition:opacity 0.3s;}
.card:hover::after{opacity:1;}
.card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.card h3{margin-bottom:10px;}
.card p{font-size:13px;color:var(--gris);line-height:1.7;}

/* ── GRID ── */
.grid{display:grid;gap:20px;max-width:var(--content-max);margin:0 auto;}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;transition:all 0.4s var(--ease);height:var(--nav-h);}
.nav.scrolled{background:rgba(255,255,255,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-md);padding:12px 32px;}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo img{width:36px;height:36px;border-radius:8px;}
.nav-brand{font-size:20px;font-weight:800;color:var(--navy);letter-spacing:-0.5px;}
.nav-brand em{font-style:normal;color:var(--rosa);}
.nav-links{display:flex;gap:24px;align-items:center;}
.nav-links a{font-size:13px;font-weight:600;color:var(--navy);opacity:0.6;transition:all 0.25s;letter-spacing:0.3px;}
.nav-links a:hover{opacity:1;color:var(--rosa);}
.nav-cta{background:linear-gradient(135deg,var(--navy),var(--coral));color:var(--white)!important;opacity:1!important;padding:10px 26px;border-radius:var(--radius-full);font-size:12px;font-weight:700;letter-spacing:0.5px;transition:all 0.3s;}
.nav-cta:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);}

/* Mobile nav */
.menu-btn{display:none;flex-direction:column;gap:5px;padding:4px;}
.menu-btn span{width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all 0.3s;}
.mobile-menu{display:none;position:fixed;inset:0;background:rgba(255,255,255,0.98);backdrop-filter:blur(20px);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:28px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-size:18px;font-weight:700;color:var(--navy);transition:color 0.2s;}
.mobile-menu a:hover{color:var(--rosa);}
.mobile-menu .x{position:absolute;top:20px;right:24px;font-size:28px;color:var(--navy);}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:calc(var(--nav-h) + 40px) 24px 80px;background:linear-gradient(180deg,var(--crema) 0%,var(--white) 50%,var(--beige) 100%);position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:-20%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(254,122,106,0.07) 0%,transparent 70%);border-radius:50%;}
.hero::after{content:'';position:absolute;bottom:-10%;left:-10%;width:400px;height:400px;background:radial-gradient(circle,rgba(65,188,185,0.05) 0%,transparent 70%);border-radius:50%;}
.hero-content{position:relative;max-width:720px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--white);border:1px solid rgba(23,57,110,0.08);padding:8px 20px;border-radius:var(--radius-full);font-size:11px;font-weight:600;color:var(--navy);margin-bottom:28px;box-shadow:var(--shadow-sm);}
.hero h1{margin-bottom:20px;}
.hero p{font-size:clamp(14px,1.8vw,17px);color:var(--gris);margin-bottom:36px;max-width:560px;margin-left:auto;margin-right:auto;}
.hero-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* ── DESTINATION CARDS ── */
.dest-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:var(--content-max);margin:0 auto;}
.dest-card{border-radius:var(--radius-lg);padding:32px 28px;color:var(--white);min-height:180px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;transition:transform 0.3s var(--ease);background-size:cover;background-position:center;}
.dest-card:hover{transform:scale(1.02);}
.dest-card.span-full{grid-column:1/-1;}
.dest-tag{position:absolute;top:16px;right:16px;background:var(--coral);padding:4px 14px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:0.5px;}
.dest-card h3{font-size:22px;font-weight:800;color:var(--white);margin-bottom:4px;}
.dest-card p{font-size:11px;opacity:0.85;line-height:1.5;color:var(--white);}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:center;max-width:900px;margin:0 auto;}
.about-frame{width:100%;max-width:300px;aspect-ratio:1;border-radius:50%;overflow:hidden;border:4px solid var(--crema);box-shadow:var(--shadow-lg);margin:0 auto;position:relative;}
.about-frame img{width:100%;height:100%;object-fit:cover;}
.about-role{font-size:12px;font-weight:700;color:var(--coral);letter-spacing:1px;text-transform:uppercase;margin-bottom:16px;}
.about-tagline{font-size:15px;font-style:italic;color:var(--rosa);font-weight:600;margin-top:8px;}
.social-row{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap;}
.social-pill{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);border:1px solid var(--beige);font-size:11px;font-weight:600;color:var(--navy);transition:all 0.25s;}
.social-pill:hover{border-color:var(--rosa);color:var(--rosa);}

/* ── PROCESS ── */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:28px;max-width:900px;margin:0 auto;}
.step{text-align:center;padding:20px 14px;}
.step-num{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--rosa));color:var(--white);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;margin:0 auto 14px;}
.step h4{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:8px;}
.step p{font-size:11px;color:var(--gris);line-height:1.6;}

/* ── CTA BOX ── */
.cta-box{max-width:700px;margin:0 auto;background:linear-gradient(135deg,var(--navy),#1a4a8a);border-radius:var(--radius-xl);padding:60px 40px;color:var(--white);position:relative;overflow:hidden;text-align:center;}
.cta-box::before{content:'';position:absolute;top:-30%;right:-15%;width:300px;height:300px;background:radial-gradient(circle,rgba(254,122,106,0.12) 0%,transparent 70%);border-radius:50%;}
.cta-box h2{color:var(--white);position:relative;}
.cta-box p{opacity:0.8;position:relative;margin-bottom:24px;font-size:14px;}
.cta-phone{display:flex;align-items:center;gap:8px;justify-content:center;margin-top:18px;font-size:12px;opacity:0.6;position:relative;}

/* ── FOOTER ── */
footer{padding:40px 24px 20px;background:var(--navy);color:rgba(255,255,255,0.7);text-align:center;}
footer .f-brand{font-size:18px;font-weight:800;color:var(--white);margin-bottom:6px;}
footer .f-brand em{font-style:normal;color:var(--coral);}
footer p{font-size:11px;line-height:1.6;}
footer .f-links{display:flex;justify-content:center;gap:20px;margin:14px 0;font-size:11px;}
footer .f-links a{color:rgba(255,255,255,0.5);transition:color 0.2s;}
footer .f-links a:hover{color:var(--coral);}
footer .f-copy{font-size:9px;opacity:0.3;margin-top:16px;}

/* ── BREADCRUMBS ── */
.breadcrumbs{padding:calc(var(--nav-h) + 16px) 24px 0;font-size:12px;color:var(--gris);max-width:var(--content-max);margin:0 auto;}
.breadcrumbs a{color:var(--navy);font-weight:600;}
.breadcrumbs a:hover{color:var(--rosa);}
.breadcrumbs span{margin:0 8px;opacity:0.4;}

/* ── FAQ (AEO) ── */
.faq{max-width:700px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--beige);padding:20px 0;}
.faq-q{font-size:15px;font-weight:700;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq-q::after{content:'+';font-size:20px;color:var(--rosa);transition:transform 0.3s;flex-shrink:0;}
.faq-item.open .faq-q::after{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s var(--ease),padding 0.4s;font-size:13px;color:#555;line-height:1.7;}
.faq-item.open .faq-a{max-height:300px;padding-top:12px;}

/* ── ANIMATIONS ── */
.reveal{opacity:0;transform:translateY(30px);transition:all 0.7s var(--ease);}
.reveal.visible{opacity:1;transform:translateY(0);}
.d1{transition-delay:0.1s;}.d2{transition-delay:0.15s;}.d3{transition-delay:0.2s;}.d4{transition-delay:0.25s;}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .nav{padding:14px 16px;}.nav.scrolled{padding:10px 16px;}
  .nav-links{display:none;}.menu-btn{display:flex;}
  .section{padding:70px 20px;}
  .about-grid{grid-template-columns:1fr;text-align:center;}
  .about-frame{max-width:220px;}
  .social-row{justify-content:center;}
  .dest-grid{grid-template-columns:1fr;}
  .grid-4{grid-template-columns:1fr 1fr;}
  .steps-grid{grid-template-columns:1fr 1fr;}
  .cta-box{padding:40px 24px;}
}
@media(max-width:480px){
  .grid-4{grid-template-columns:1fr;}
  .steps-grid{grid-template-columns:1fr;}
  .hero-ctas{flex-direction:column;align-items:center;}
  .hero{min-height:auto;padding-top:calc(var(--nav-h) + 24px);padding-bottom:60px;}
}

/* ── UTILITIES ── */
.text-center{text-align:center;}
.text-navy{color:var(--navy);}
.text-rosa{color:var(--rosa);}
.text-coral{color:var(--coral);}
.bg-cream{background:var(--crema);}
.bg-beige{background:var(--beige);}
.bg-gray{background:var(--bg);}
.mt-0{margin-top:0;}.mt-1{margin-top:8px;}.mt-2{margin-top:16px;}.mt-3{margin-top:24px;}.mt-4{margin-top:40px;}
.mb-0{margin-bottom:0;}.mb-1{margin-bottom:8px;}.mb-2{margin-bottom:16px;}.mb-3{margin-bottom:24px;}
.gap-sm{gap:12px;}.gap-md{gap:20px;}.gap-lg{gap:32px;}
