:root{
  --fera-purple:#54279a;
  --fera-purple-2:#7b2df0;
  --fera-dark:#061a3d;
  --fera-navy:#07112f;
  --fera-turquoise:#11d4cf;
  --fera-cyan:#24e0ff;
  --fera-yellow:#ffd23f;
  --soft:#f5f8ff;
  --text:#11172f;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:#f7f9ff;
}
a{text-decoration:none}
h1,h2,h3,h4{font-weight:900;letter-spacing:-.035em}
.fera-navbar{
  padding:18px 0;
  background:linear-gradient(180deg, rgba(4,18,50,.92), rgba(4,18,50,.35), transparent);
  backdrop-filter:blur(10px);
  transition:.25s;
}
.fera-navbar.scrolled{
  padding:10px 0;
  background:rgba(4,18,50,.96);
  box-shadow:0 16px 42px rgba(0,0,0,.22)
}
.brand-logo{width:96px;max-height:66px;object-fit:contain}
.brand-text{font-weight:900;color:#fff;line-height:1.05;font-size:.9rem}
.navbar .nav-link{
  color:#fff!important;
  font-size:.78rem;
  text-transform:uppercase;
  font-weight:800;
  letter-spacing:.04em;
  margin:0 .55rem;
  position:relative
}
.navbar .nav-link::after{
  content:"";position:absolute;left:.5rem;right:.5rem;bottom:2px;height:2px;
  background:linear-gradient(90deg,var(--fera-turquoise),var(--fera-purple-2));
  transform:scaleX(0);transition:.2s;transform-origin:left
}
.navbar .nav-link:hover::after,.navbar .nav-link.active::after{transform:scaleX(1)}
.btn{
  border-radius:14px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.02em;
  border:0
}
.btn-fera{
  color:#fff!important;
  background:linear-gradient(135deg,var(--fera-purple),var(--fera-purple-2));
  box-shadow:0 12px 30px rgba(84,39,154,.35)
}
.btn-fera:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn-turquoise{
  color:#fff!important;
  background:linear-gradient(135deg,#09b9b7,var(--fera-turquoise));
  box-shadow:0 12px 30px rgba(17,212,207,.28)
}
.btn-outline-light{
  border:1px solid rgba(255,255,255,.55);
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(8px)
}
.hero-section{
  position:relative;
  overflow:hidden;
  min-height:730px;
  background:var(--fera-dark);
}
.hero-bg{
  position:absolute;inset:0;
  background-image:url("../img/hero-gales-maragogi.png");
  background-size:cover;
  background-position:center 40%;
  transform:scale(1.0);
  transition:background-image .6s ease-in-out;
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 75% 45%, rgba(17,212,207,.06), transparent 32%),
    linear-gradient(90deg, rgba(2,9,33,.82) 0%, rgba(2,9,33,.55) 35%, rgba(2,9,33,.12) 69%, rgba(2,9,33,.08) 100%),
    linear-gradient(180deg, rgba(1,8,28,.25), rgba(1,8,28,.05) 60%, rgba(1,8,28,.15) 100%);
}
.section-pill{
  display:inline-flex;
  color:#fff;
  background:linear-gradient(135deg,var(--fera-purple),var(--fera-purple-2));
  border-radius:999px;
  padding:.45rem .85rem;
  font-weight:900;
  text-transform:uppercase;
  font-size:.8rem
}
.hero-title{
  color:#fff;
  text-transform:uppercase;
  font-size:clamp(3.2rem,8vw,7rem);
  line-height:.85;
  max-width:720px;
  margin:0
}
.hero-title span{
  display:block;
  font-family:"Trebuchet MS",system-ui,sans-serif;
  font-size:clamp(1.8rem,4.2vw,4rem);
  font-style:italic;
  letter-spacing:-.04em;
}
.hero-title strong{
  display:block;
  color:var(--fera-turquoise);
  font-style:italic;
  text-shadow:0 6px 0 rgba(84,39,154,.85)
}
.hero-subtitle{
  color:#fff;
  max-width:520px;
  font-size:1.3rem;
  line-height:1.55;
  margin-top:1.4rem
}
.feature-floating{margin-top:-70px;position:relative;z-index:5}
.premium-card{
  background:#fff;
  border-radius:22px;
  box-shadow:0 22px 50px rgba(8,31,77,.1);
  border:1px solid rgba(12,28,68,.06)
}
.shadow-soft{box-shadow:0 28px 70px rgba(8,31,77,.16)}
.feature-item{
  padding:28px 24px;
  border-right:1px solid rgba(84,39,154,.15);
  display:flex;
  flex-direction:column;
  align-items:flex-start
}
.feature-item i{font-size:2.4rem;color:var(--fera-purple);margin-bottom:12px}
.feature-item h3{font-size:1rem;text-transform:uppercase;color:var(--fera-purple);margin-bottom:6px}
.feature-item p{margin:0;color:#566078;font-size:.9rem}
.section-padding{padding:90px 0}
.mini-title{
  color:var(--fera-purple);
  font-size:.86rem;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em
}
.section-padding h2,.premium-card h2{font-size:clamp(2rem,4vw,3rem)}
.tour-card{
  height:100%;
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 18px 44px rgba(8,31,77,.11);
  transition:.25s;
  border:1px solid rgba(12,28,68,.06)
}
.tour-card:hover{transform:translateY(-6px);box-shadow:0 26px 70px rgba(8,31,77,.17)}
.tour-img{height:230px;width:100%;object-fit:cover}
.tour-body{padding:28px;position:relative}
.tour-icon{
  width:58px;height:58px;border-radius:50%;
  background:linear-gradient(135deg,var(--fera-purple),var(--fera-purple-2));
  color:#fff;display:grid;place-items:center;font-size:1.65rem;
  position:absolute;top:-29px;left:24px;
  border:5px solid #fff
}
.tour-badge{
  color:var(--fera-purple);
  background:rgba(84,39,154,.09);
  font-weight:900;border-radius:999px;padding:.3rem .75rem;font-size:.74rem
}
.tour-card h3{font-size:1.35rem;text-transform:uppercase;margin-top:20px}
.tour-card p{color:#505a75;line-height:1.65}
.link-more{font-weight:900;color:var(--fera-purple);text-transform:uppercase;font-size:.86rem}
.fleet-banner{
  position:relative;
  border-radius:22px;
  background:
    linear-gradient(90deg, rgba(18,8,63,.98), rgba(18,8,63,.84), rgba(18,8,63,.1)),
    url("../img/lancha-maragogi.png");
  background-size:cover;
  background-position:center;
  color:#fff;
  min-height:410px;
  box-shadow:0 28px 70px rgba(8,31,77,.18)
}
/* ── Seção frota: cards centralizados e layout premium ───── */
.fleet-banner-new{
  position:relative;
  border-radius:26px;
  background:
    radial-gradient(circle at top right, rgba(0,224,255,.12), transparent 26%),
    radial-gradient(circle at bottom left, rgba(155,89,232,.18), transparent 34%),
    linear-gradient(135deg,#0f073a 0%,#1c0e68 56%,#140948 100%);
  color:#fff;
  padding:2.5rem 2rem;
  box-shadow:0 28px 70px rgba(8,31,77,.22);
  overflow:hidden;
}
.fleet-banner-new::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0));
  pointer-events:none;
}
.fleet-banner-new > *{position:relative;z-index:1}
.fleet-header{
  max-width:1120px;
  margin:0 auto 2rem;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
}
.fleet-title{
  font-size:clamp(2rem,3vw,2.9rem);
  text-transform:uppercase;
  font-weight:900;
  line-height:1.08;
  margin:.5rem 0 .75rem;
}
.fleet-subtitle{
  color:rgba(255,255,255,.82);
  max-width:580px;
  margin:0;
  font-size:1.02rem;
  line-height:1.7;
}
.fleet-cards-list{
  max-width:1140px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,360px));
  justify-content:center;
  gap:1.5rem;
}
.fleet-card-new{
  display:flex;
  flex-direction:column;
  min-height:100%;
  border-radius:20px;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.11),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.13);
  backdrop-filter:blur(12px);
  box-shadow:0 18px 40px rgba(0,0,0,.22);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.fleet-card-new:hover{
  transform:translateY(-4px);
  border-color:rgba(23,162,184,.45);
  box-shadow:0 22px 46px rgba(0,0,0,.28);
}
.fleet-card-img{
  width:100%;
  max-width:none;
  flex:none;
  height:215px;
  position:relative;
  overflow:hidden;
}
.fleet-card-img::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(10,5,40,.15) 100%);
}
.fleet-card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .4s ease;
}
.fleet-card-new:hover .fleet-card-img img{transform:scale(1.05)}
.fleet-img-placeholder{
  width:100%;
  height:215px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:3rem;
  color:rgba(255,255,255,.2);
  background:rgba(255,255,255,.04);
}
.fleet-card-info{
  flex:1;
  padding:1.35rem 1.35rem 1.5rem;
  display:flex;
  flex-direction:column;
}
.fleet-card-badge{
  font-size:.74rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.11em;
  color:rgba(0,224,255,.85);
  margin-bottom:.55rem;
}
.fleet-card-info h3{
  font-size:1.55rem;
  font-weight:900;
  text-transform:uppercase;
  margin:0 0 1rem;
  color:#fff;
}
.fleet-specs{
  display:flex;
  flex-direction:column;
  gap:.55rem;
  margin-bottom:1.35rem;
}
.fleet-spec{
  display:flex;
  align-items:center;
  gap:.7rem;
  color:rgba(255,255,255,.78);
  font-size:.98rem;
}
.fleet-spec i{
  color:rgba(0,224,255,.82);
  font-size:1rem;
  flex-shrink:0;
}
.fleet-reservar{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  margin-top:auto;
  color:#b061ff;
  font-weight:800;
  text-decoration:none;
  font-size:.94rem;
  transition:.2s;
  width:fit-content;
}
.fleet-reservar:hover{color:#fff;gap:.6rem}
@media(max-width:767px){
  .fleet-banner-new{padding:1.5rem 1.15rem}
  .fleet-header{flex-direction:column;align-items:flex-start;margin-bottom:1.5rem}
  .fleet-cards-list{grid-template-columns:1fr;gap:1.15rem}
  .fleet-card-img,.fleet-img-placeholder{height:200px}
  .fleet-card-info{padding:1.15rem}
  .fleet-card-info h3{font-size:1.35rem}
}
@media(min-width:768px) and (max-width:991px){
  .fleet-cards-list{grid-template-columns:repeat(2,minmax(280px,1fr))}
}
.fleet-content h2{font-size:clamp(2rem,3vw,3.2rem);text-transform:uppercase}
.fleet-content p{color:rgba(255,255,255,.86);max-width:460px}
.fleet-card{
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(10px);
  border-radius:16px;
  padding:18px
}
.fleet-card img{width:100%;height:56px;object-fit:contain;filter:drop-shadow(0 9px 18px rgba(0,0,0,.25));margin-bottom:12px}
.fleet-card h3{font-size:1rem;text-transform:uppercase}
.fleet-card span{display:block;color:rgba(255,255,255,.78);font-size:.88rem;margin-bottom:4px}
.tide-box-wrap{display:flex;align-items:flex-end;justify-content:center;padding:34px}
.tide-box{
  width:min(100%,360px);
  background:#fff;color:#1b2340;border-radius:22px;padding:26px;
  display:flex;gap:18px;box-shadow:0 22px 60px rgba(0,0,0,.18)
}
.tide-icon{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:rgba(84,39,154,.09);color:var(--fera-purple);font-size:2.2rem;flex:0 0 64px}
.tide-box h3{font-size:1.25rem;text-transform:uppercase;color:var(--fera-purple)}
.tide-box p{font-size:.9rem;color:#566078;margin-bottom:12px}
.gallery-card{
  position:relative;overflow:hidden;border-radius:18px;height:280px;
  box-shadow:0 18px 44px rgba(8,31,77,.12)
}
.gallery-card img{width:100%;height:100%;object-fit:cover;transition:.35s}
.gallery-card:hover img{transform:scale(1.07)}
.gallery-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 35%, rgba(2,9,33,.86))}
.gallery-card h3{position:absolute;left:22px;right:22px;bottom:18px;color:#fff;font-size:1.25rem;z-index:2}
.testimonial{border-right:1px solid rgba(84,39,154,.14);height:100%}
.testimonial:last-child{border-right:0}
.testimonial .avatar{width:70px;height:70px;border-radius:50%;object-fit:cover}
.stars{color:#ffc107;letter-spacing:.08em}
.testimonial p{color:#48536e;line-height:1.6;font-size:.95rem}
.cta-final{
  border-radius:22px;
  background:
    radial-gradient(circle at 8% 50%, rgba(123,45,240,.55), transparent 22%),
    linear-gradient(135deg,#35117d,#5d22b3 45%, #230d61);
  color:#fff;
  padding:38px 44px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  overflow:hidden;
  box-shadow:0 24px 60px rgba(84,39,154,.28)
}
.cta-final h2{text-transform:uppercase;line-height:1}
.cta-final h2 span{color:var(--fera-turquoise);font-style:italic;text-transform:none}
.cta-final p{margin:0;color:rgba(255,255,255,.82)}
.footer-premium{
  background:linear-gradient(135deg,#061234,#14093d 60%,#250760);
  color:#fff;
  padding:58px 0 20px
}
.footer-logo{width:180px;max-height:92px;object-fit:contain}
.footer-premium p{color:rgba(255,255,255,.76)}
.footer-premium h4{font-size:.9rem;text-transform:uppercase;margin-bottom:16px}
.footer-premium a{display:block;color:rgba(255,255,255,.76);margin-bottom:7px}
.footer-premium a:hover{color:#fff}
.socials{display:flex;gap:12px}
.socials a{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  background:rgba(255,255,255,.1);
  color:#fff;font-size:1.2rem
}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:35px;padding-top:18px;color:rgba(255,255,255,.62);font-size:.86rem}
.floating-whats{
  position:fixed;right:22px;bottom:22px;width:58px;height:58px;border-radius:50%;
  display:grid;place-items:center;background:#25d366;color:#fff;font-size:1.85rem;
  box-shadow:0 12px 35px rgba(37,211,102,.38);z-index:50
}
@media(max-width:991px){
  .fera-navbar{background:rgba(4,18,50,.96)}
  .hero-section{min-height:760px}
  .hero-bg{background-position:center top}
  .feature-floating{margin-top:-40px}
  .feature-item{border-right:0;border-bottom:1px solid rgba(84,39,154,.12)}
  .cta-final{flex-direction:column;text-align:center;padding:30px 22px}
}
@media(max-width:575px){
  .brand-logo{width:74px}
  .brand-text{font-size:.75rem}
  .hero-title{font-size:3.15rem}
  .hero-subtitle{font-size:1.05rem}
  .section-padding{padding:65px 0}
  .tour-img{height:190px}
  .tide-box{flex-direction:column}
}

/* ── Gallery Modal ───────────────────────────── */
.gallery-open{cursor:pointer}
.gallery-zoom-icon{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) scale(0);
  background:rgba(108,46,185,.85);
  color:#fff;width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;
  transition:.25s cubic-bezier(.34,1.56,.64,1);
  z-index:3;
  backdrop-filter:blur(4px);
}
.gallery-open:hover .gallery-zoom-icon{transform:translate(-50%,-50%) scale(1)}
.gallery-open:hover img{transform:scale(1.07)}
#galeriaImg{transition:.25s opacity}

/* ── Reserva form inputs placeholder ────────── */
#modalReserva input::placeholder,
#modalReserva textarea::placeholder{color:rgba(255,255,255,.3)}
#modalReserva .form-control:focus,
#modalReserva .form-select:focus{
  background:rgba(255,255,255,.12)!important;
  border-color:rgba(155,89,232,.6)!important;
  box-shadow:0 0 0 3px rgba(108,46,185,.2)!important;
  color:#fff!important;
}
#modalReserva select option{background:#1a0a2e;color:#fff}

/* ── Depoimentos Carrossel ───────────────────────────────── */
#depTrack .dep-item{min-width:calc(33.333% - 1rem)}
@media(max-width:1023px){#depTrack .dep-item{min-width:calc(50% - .75rem)}}
@media(max-width:767px) {#depTrack .dep-item{min-width:100%}}
#depCarrossel{cursor:grab}
#depCarrossel:active{cursor:grabbing}
.dep-dot{cursor:pointer;transition:.2s}
.dep-dot:hover{transform:scale(1.4)}

/* ── Hero HD image smooth transition ────────────────────── */
.hero-bg{transition:background-image .6s ease-in-out}

/* ── Tide section legenda ────────────────────────────────── */
.tide-section .border-top { border-color: rgba(255,255,255,.12) !important; }
.tide-section .border-top div,
.tide-section .border-top span { 
  color: rgba(255,255,255,.55) !important; 
  font-size:.82rem !important;
}
.tide-note { 
  font-size:.78rem !important; 
  color:rgba(255,196,7,.75) !important;
}
/* source line */
.tide-section [style*="rgba(255,255,255,.3)"] {
  color: rgba(255,255,255,.45) !important;
  font-size:.78rem !important;
}

/* ── Gallery card cursor ─────────────────────────────────── */
.gallery-card, .gallery-open { cursor:pointer !important; }

/* ── Hero HD transition ──────────────────────────────────── */
.hero-bg { transition: background-image .5s ease-in-out !important; }

/* ═══════════════════════════════════════════════════════════
   MOBILE — Ajustes responsivos completos
   ═══════════════════════════════════════════════════════════ */

/* Navbar mobile */
@media (max-width: 991.98px) {
  .fera-navbar .navbar-collapse {
    background: rgba(2,9,33,.97);
    border-radius: 0 0 20px 20px;
    padding: 1rem 1.5rem 1.5rem;
    margin-top: .5rem;
    box-shadow: 0 12px 40px rgba(0,0,0,.3);
  }
  .fera-navbar .navbar-nav { gap: .25rem; }
  .fera-navbar .nav-link { 
    padding: .6rem .75rem; 
    border-radius: 10px;
    font-size: .9rem;
  }
  .fera-navbar .nav-link:hover { background: rgba(255,255,255,.08); }
  .btn-fera.btn-sm { margin-top: .5rem; width: 100%; justify-content: center; }
}

/* Hero mobile */
@media (max-width: 767.98px) {
  .hero-section { min-height: 100svh; }
  .hero-title  { font-size: 2.6rem !important; line-height: 1.05; }
  .hero-subtitle { font-size: .95rem !important; }
  .hero-section .d-flex.flex-column { gap: .75rem !important; }
  .hero-section .btn-lg { 
    width: 100%; 
    justify-content: center;
    padding: .85rem 1rem;
    font-size: .95rem;
  }
}

/* Feature cards mobile */
@media (max-width: 767.98px) {
  .feature-floating { margin-top: -40px !important; }
  .premium-card.feature-card .feature-item {
    border-right: none !important;
    border-bottom: 1px solid rgba(255,255,255,.08);
    padding: 1.25rem !important;
  }
  .premium-card.feature-card .feature-item:last-child { border-bottom: none; }
}

/* Passeios cards mobile */
@media (max-width: 575.98px) {
  .tour-card .tour-img { height: 180px !important; }
  .tour-body { padding: 1rem !important; }
  .tour-body h3 { font-size: 1.1rem !important; }
}

/* Fleet banner mobile */
@media (max-width: 991.98px) {
  .fleet-banner .row { flex-direction: column !important; }
  .fleet-banner .fleet-content { padding: 2rem !important; }
  .fleet-card img { height: 120px !important; }
}

/* Tide section mobile */
@media (max-width: 767.98px) {
  .tide-section { padding: 1.5rem 1.25rem !important; border-radius: 16px !important; }
  .tide-extreme { padding: .75rem .35rem !important; }
  .tide-extreme .te-time { font-size: .95rem !important; }
  .tide-tabs { flex-wrap: wrap; gap: .5rem !important; }
  .tide-tabs .nav-link { font-size: .8rem !important; padding: .35rem .75rem !important; }
}

/* Galeria mobile */
@media (max-width: 767.98px) {
  #galeria .col-md-6 { width: 50% !important; }
  .gallery-card { aspect-ratio: 1/1 !important; }
  .gallery-card h3 { font-size: 1rem !important; }
}
@media (max-width: 479.98px) {
  #galeria .col-md-6 { width: 100% !important; }
}

/* Depoimentos carrossel mobile */
@media (max-width: 767.98px) {
  #depTrack .dep-item { min-width: 100% !important; }
  .testimonial .avatar { width: 44px !important; height: 44px !important; }
}

/* Modal de reserva mobile */
@media (max-width: 575.98px) {
  #modalReserva .modal-dialog { 
    margin: auto 1rem !important; 
    max-width: calc(100vw - 2rem) !important;
  }
  #modalReserva .modal-body { padding: .75rem 1rem !important; }
  #modalReserva .modal-header { padding: 1rem !important; }
  #modalReserva .modal-footer { padding: .75rem 1rem !important; }
}

/* Modal galeria mobile */
@media (max-width: 767.98px) {
  #modalGaleria .modal-dialog { 
    margin: .5rem;
    max-width: calc(100vw - 1rem) !important;
  }
  #galeriaImg { max-height: 65vw !important; }
}

/* Footer mobile */
@media (max-width: 767.98px) {
  .footer-premium .row { text-align: center; }
  .footer-premium .socials { justify-content: center; }
  .footer-premium a { display: block; padding: .35rem 0; }
}

/* Floating WhatsApp mobile */
@media (max-width: 767.98px) {
  .floating-whats { 
    width: 52px !important; 
    height: 52px !important; 
    font-size: 1.4rem !important;
    bottom: 20px !important; 
    right: 16px !important;
  }
}

/* CTA final mobile */
@media (max-width: 767.98px) {
  .cta-final { 
    padding: 2rem 1.5rem !important; 
    text-align: center;
    flex-direction: column !important;
    gap: 1.5rem !important;
  }
  .cta-final h2 { font-size: 1.6rem !important; }
  .cta-final .btn { width: 100% !important; justify-content: center !important; }
}

/* Gallery modal image quality */
.gallery-card img {
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
}
