/* ============================================================
   Fajardo Seabob Rentals — Brand Stylesheet
   Tropical • Premium • Mobile-first
   ============================================================ */

:root{
  --turquoise:#19C4C9;
  --turquoise-bright:#22D3D3;
  --ocean:#0E7FA8;
  --ocean-deep:#0A5F86;
  --navy:#0A3D57;
  --ink:#0A2A3A;
  --muted:#5B7785;
  --sand:#F6EFDD;
  --sand-2:#EFE3C7;
  --coral:#FF6B5C;
  --yellow:#FFC23C;
  --white:#ffffff;
  --paper:#F4FBFB;

  --grad-ocean:linear-gradient(135deg,#22D3D3 0%,#0E7FA8 55%,#0A3D57 100%);
  --grad-cta:linear-gradient(135deg,#FF8A5C 0%,#FF6B5C 100%);
  --grad-sun:linear-gradient(135deg,#FFD45E,#FFB23C);

  --shadow-sm:0 4px 14px rgba(10,61,87,.10);
  --shadow-md:0 12px 30px rgba(10,61,87,.16);
  --shadow-lg:0 24px 60px rgba(10,61,87,.22);

  --radius:18px;
  --radius-lg:26px;
  --maxw:1160px;
  --font-head:'Poppins','Segoe UI',system-ui,Arial,sans-serif;
  --font-body:'Inter','Segoe UI',system-ui,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--ocean);text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-head);color:var(--navy);line-height:1.15;margin:0 0 .5em}
h1{font-size:clamp(2rem,6vw,3.5rem);font-weight:800;letter-spacing:-.5px}
h2{font-size:clamp(1.6rem,4vw,2.5rem);font-weight:800;letter-spacing:-.4px}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1rem}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section--tight{padding:48px 0}
.center{text-align:center}
.eyebrow{
  display:inline-block;font-family:var(--font-head);font-weight:700;
  letter-spacing:3px;text-transform:uppercase;font-size:.78rem;
  color:var(--ocean);margin-bottom:10px;
}
.lead{font-size:1.1rem;color:var(--muted);max-width:640px;margin:0 auto 8px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-head);font-weight:700;font-size:1rem;
  padding:15px 26px;border-radius:60px;border:0;cursor:pointer;
  transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease;
  text-align:center;line-height:1.1;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--cta{background:var(--grad-cta);color:#fff;box-shadow:0 10px 24px rgba(255,107,92,.38)}
.btn--wa{background:#25D366;color:#fff;box-shadow:0 10px 24px rgba(37,211,102,.34)}
.btn--ocean{background:var(--grad-ocean);color:#fff;box-shadow:0 10px 24px rgba(14,127,168,.34)}
.btn--ghost{background:#fff;color:var(--navy);border:2px solid #d9e7ec}
.btn--ghost:hover{border-color:var(--turquoise)}
.btn--block{display:flex;width:100%}
.btn--lg{font-size:1.08rem;padding:17px 30px}
.btn[disabled]{opacity:.45;cursor:not-allowed;transform:none;filter:grayscale(.3)}
.btn .ico{width:20px;height:20px;flex:0 0 auto}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(244,251,251,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(10,61,87,.08);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav__logo img{height:46px;width:auto}
.nav__links{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0}
.nav__links a{font-family:var(--font-head);font-weight:600;color:var(--navy);font-size:.96rem}
.nav__links a:hover{color:var(--ocean)}
.nav__cta{display:flex;align-items:center;gap:10px}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav__toggle span{display:block;width:26px;height:3px;background:var(--navy);border-radius:3px;margin:5px 0;transition:.25s}
.nav .btn{padding:11px 20px;font-size:.92rem}

@media(max-width:900px){
  .nav__links{
    position:absolute;top:72px;left:0;right:0;flex-direction:column;gap:0;
    background:var(--paper);border-bottom:1px solid rgba(10,61,87,.1);
    max-height:0;overflow:hidden;transition:max-height .3s ease;
  }
  .nav__links.open{max-height:420px}
  .nav__links li{width:100%;border-top:1px solid rgba(10,61,87,.06)}
  .nav__links a{display:block;padding:16px 20px}
  .nav__toggle{display:block}
  .nav__cta .btn--ghost{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:var(--grad-ocean);z-index:0}
.hero__media{
  position:absolute;inset:0;z-index:0;opacity:.5;
  background:
    radial-gradient(circle at 78% 18%,rgba(255,194,60,.55),transparent 42%),
    repeating-linear-gradient(115deg,rgba(255,255,255,.05) 0 28px,transparent 28px 56px);
  mix-blend-mode:screen;
}
.hero__inner{position:relative;z-index:2;padding:84px 0 92px;max-width:760px}
.hero h1{color:#fff;text-shadow:0 4px 26px rgba(6,30,44,.35)}
.hero__sub{font-size:1.18rem;color:#eafafa;max-width:600px;margin-bottom:26px}
.hero__btns{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:18px}
.hero__price-flag{
  display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:60px;
  font-weight:700;font-family:var(--font-head);backdrop-filter:blur(6px);
}
.hero__wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:1;line-height:0}
.hero__wave svg{width:100%;height:auto;display:block}

/* ---------- Trust badges ---------- */
.trust{background:var(--white);border-bottom:1px solid rgba(10,61,87,.06)}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:26px 0}
.trust__item{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:600;color:var(--navy);font-size:.96rem}
.trust__item .badge{width:42px;height:42px;border-radius:12px;background:var(--paper);display:grid;place-items:center;flex:0 0 auto;color:var(--ocean)}
@media(max-width:760px){.trust__grid{grid-template-columns:1fr 1fr}}

/* ---------- Image placeholders ---------- */
.ph{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,#d6eef0,#bfe3ea 60%,#a9d8e6);
  display:grid;place-items:center;color:#3a6678;min-height:220px;
  border:1px dashed rgba(14,127,168,.35);
}
.ph::after{
  content:attr(data-label);position:absolute;bottom:10px;left:0;right:0;
  text-align:center;font-size:.72rem;letter-spacing:1px;text-transform:uppercase;
  color:#4a7486;font-family:var(--font-head);font-weight:600;opacity:.8;
}
.ph .ph__icon{width:46px;height:46px;opacity:.55;margin-bottom:6px}
.ph .ph__txt{font-family:var(--font-head);font-weight:700;color:#3a6678;opacity:.8;font-size:.95rem}
.ph--tall{min-height:340px}
.ph--hero{min-height:380px}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery .ph{min-height:200px}
.gallery .ph:nth-child(1){grid-column:span 2;grid-row:span 2;min-height:auto}
@media(max-width:760px){.gallery{grid-template-columns:1fr 1fr}.gallery .ph:nth-child(1){grid-column:span 2}}

/* ---------- Cards / Pricing ---------- */
.cards{display:grid;gap:22px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:880px){.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}

.card{background:#fff;border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-sm);border:1px solid rgba(10,61,87,.05)}
.card--feature{border:2px solid var(--turquoise);box-shadow:var(--shadow-md);position:relative}
.card__tag{position:absolute;top:-13px;left:30px;background:var(--grad-cta);color:#fff;font-family:var(--font-head);font-weight:700;font-size:.74rem;letter-spacing:1px;padding:6px 14px;border-radius:30px;text-transform:uppercase}

.price{display:flex;align-items:baseline;gap:8px;margin:6px 0 16px}
.price__num{font-family:var(--font-head);font-weight:800;font-size:3rem;color:var(--navy);line-height:1}
.price__per{color:var(--muted);font-weight:600}
.includes{list-style:none;margin:0;padding:0}
.includes li{position:relative;padding:8px 0 8px 30px;border-top:1px solid rgba(10,61,87,.07)}
.includes li:first-child{border-top:0}
.includes li::before{content:"";position:absolute;left:0;top:14px;width:18px;height:18px;border-radius:50%;background:rgba(25,196,201,.18) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230E7FA8' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat}

/* Add-ons */
.addons{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:6px}
.addon{background:#fff;border:1px solid rgba(10,61,87,.08);border-radius:16px;padding:18px;display:flex;justify-content:space-between;align-items:center;gap:10px;box-shadow:var(--shadow-sm)}
.addon b{font-family:var(--font-head);color:var(--navy)}
.addon .amt{font-family:var(--font-head);font-weight:800;color:var(--coral);white-space:nowrap}
.addon--wide{grid-column:1/-1;background:linear-gradient(135deg,#fff,#f2fbfb)}
@media(max-width:760px){.addons{grid-template-columns:1fr}}

/* ---------- How it works ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:step}
.step{background:#fff;border-radius:var(--radius);padding:26px 24px;box-shadow:var(--shadow-sm);position:relative;border:1px solid rgba(10,61,87,.05)}
.step::before{counter-increment:step;content:counter(step);position:absolute;top:-16px;left:24px;width:42px;height:42px;border-radius:50%;background:var(--grad-ocean);color:#fff;font-family:var(--font-head);font-weight:800;display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.step h3{margin:12px 0 4px}
.step p{margin:0;color:var(--muted)}
@media(max-width:880px){.steps{grid-template-columns:1fr}}

/* ---------- Why us ---------- */
.feature-band{background:var(--navy);color:#eafafa;background-image:var(--grad-ocean)}
.feature-band h2{color:#fff}
.why{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;list-style:none;padding:0;margin:18px 0 0}
.why li{display:flex;gap:12px;align-items:flex-start;font-size:1.02rem}
.why li svg{flex:0 0 auto;margin-top:3px}
@media(max-width:760px){.why{grid-template-columns:1fr}}

/* ---------- Availability strip ---------- */
.avail{background:var(--sand);border-radius:var(--radius-lg);padding:34px;display:flex;gap:24px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.avail__big{font-family:var(--font-head);font-weight:800;font-size:2.4rem;color:var(--ocean);line-height:1}
.avail__chip{background:#fff;border-radius:14px;padding:14px 18px;text-align:center;box-shadow:var(--shadow-sm);min-width:120px}
.avail__chips{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Location / map ---------- */
.map-wrap{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid rgba(10,61,87,.08)}
.map-wrap iframe{width:100%;height:380px;border:0;display:block}

/* ---------- Contact ---------- */
.contact-card{background:var(--grad-ocean);color:#fff;border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-lg)}
.contact-card h2{color:#fff}
.contact-list{list-style:none;padding:0;margin:18px 0;display:grid;gap:12px}
.contact-list a{color:#fff;font-weight:600}
.contact-list li{display:flex;align-items:center;gap:12px}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq__item{background:#fff;border:1px solid rgba(10,61,87,.08);border-radius:14px;margin-bottom:12px;overflow:hidden}
.faq__q{width:100%;text-align:left;background:none;border:0;padding:20px 22px;font-family:var(--font-head);font-weight:700;color:var(--navy);font-size:1.04rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq__q .chev{transition:transform .25s;flex:0 0 auto}
.faq__item.open .chev{transform:rotate(180deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--muted)}
.faq__a p{padding:0 22px 20px}
.faq__item.open .faq__a{max-height:340px}

/* ---------- Footer ---------- */
.footer{background:var(--navy);color:#cfe2ea;background-image:linear-gradient(180deg,#0A3D57,#082c40)}
.footer a{color:#cfe2ea}
.footer a:hover{color:#fff}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding:56px 0 30px}
.footer__logo img{height:54px;margin-bottom:14px}
.footer h4{color:#fff;font-size:1rem;letter-spacing:1px;text-transform:uppercase;margin-bottom:14px}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:9px}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;font-size:.85rem;color:#9fc0cd;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer__disc{font-size:.82rem;color:#8fb4c2;max-width:540px;margin-top:10px}
@media(max-width:760px){.footer__grid{grid-template-columns:1fr;gap:26px}}

/* ---------- Sticky mobile bar + WhatsApp FAB ---------- */
.wa-fab{
  position:fixed;right:18px;bottom:88px;z-index:70;width:58px;height:58px;border-radius:50%;
  background:#25D366;display:grid;place-items:center;box-shadow:0 10px 26px rgba(37,211,102,.5);
  color:#fff;transition:transform .15s;
}
.wa-fab:hover{transform:scale(1.07)}
.wa-fab svg{width:30px;height:30px}
.mobile-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:65;display:none;gap:10px;padding:10px 14px;
  background:rgba(255,255,255,.95);backdrop-filter:blur(10px);
  border-top:1px solid rgba(10,61,87,.1);box-shadow:0 -8px 24px rgba(10,61,87,.12);
}
.mobile-bar .btn{flex:1;padding:14px;font-size:.96rem}
@media(max-width:760px){
  .mobile-bar{display:flex}
  .wa-fab{bottom:84px}
  body{padding-bottom:74px}
}

/* ---------- Generic content pages ---------- */
.page-hero{background:var(--grad-ocean);color:#fff;padding:60px 0 70px;text-align:center}
.page-hero h1{color:#fff}
.page-hero p{color:#eafafa;max-width:640px;margin:0 auto}
.prose{max-width:820px;margin:0 auto}
.prose h2{margin-top:32px;font-size:1.5rem}
.prose h3{margin-top:24px}
.prose ul{padding-left:20px}
.prose li{margin-bottom:8px}
.prose .meta{color:var(--muted);font-size:.9rem}
.callout{background:var(--sand);border-left:4px solid var(--turquoise);border-radius:12px;padding:16px 20px;margin:18px 0}

/* ---------- Forms / Booking ---------- */
.form-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:30px;border:1px solid rgba(10,61,87,.06)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-head);font-weight:600;color:var(--navy);margin-bottom:7px;font-size:.95rem}
.field .req{color:var(--coral)}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1.5px solid #d9e7ec;border-radius:12px;font:inherit;color:var(--ink);background:#fbfeff;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--turquoise);box-shadow:0 0 0 4px rgba(25,196,201,.15)}
.field input.invalid,.field select.invalid{border-color:var(--coral);box-shadow:0 0 0 4px rgba(255,107,92,.12)}
.grid-fields{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
@media(max-width:620px){.grid-fields{grid-template-columns:1fr}}

.step-head{display:flex;align-items:center;gap:12px;margin:0 0 18px}
.step-head .n{width:34px;height:34px;border-radius:50%;background:var(--grad-ocean);color:#fff;font-family:var(--font-head);font-weight:800;display:grid;place-items:center;flex:0 0 auto}
.step-head h2{margin:0;font-size:1.35rem}

.waiver-box{max-height:300px;overflow-y:auto;background:#f7fcfd;border:1.5px solid #d9e7ec;border-radius:14px;padding:20px 22px;font-size:.92rem;color:#324b57;margin-bottom:18px}
.waiver-box h3{font-size:1rem;color:var(--navy)}
.waiver-box p{margin-bottom:.7rem}

.check{display:flex;gap:12px;align-items:flex-start;background:#f7fcfd;border:1.5px solid #d9e7ec;border-radius:12px;padding:14px 16px;margin-bottom:12px;cursor:pointer}
.check input{margin-top:3px;width:20px;height:20px;flex:0 0 auto;accent-color:var(--ocean)}
.check span{font-size:.93rem;color:var(--ink)}

.sig-row{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap}
.sig-row .field{flex:1;min-width:240px;margin-bottom:0}
#signaturePreview{font-family:'Brush Script MT','Segoe Script',cursive;font-size:1.6rem;color:var(--ocean);min-height:34px}

.gate-note{display:flex;gap:10px;align-items:center;background:#fff6f4;border:1px solid #ffd9d2;color:#b4493c;border-radius:12px;padding:13px 16px;font-size:.9rem;margin-bottom:16px}
.locked-pay{opacity:.5;pointer-events:none;filter:grayscale(.4)}

.summary{background:var(--sand);border-radius:16px;padding:20px;font-size:.95rem}
.summary dl{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;margin:0}
.summary dt{color:var(--muted)}
.summary dd{margin:0;text-align:right;font-weight:600;color:var(--navy)}

.badge-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.badge-row .pill{background:#fff;border:1px solid rgba(10,61,87,.1);border-radius:30px;padding:7px 14px;font-size:.85rem;font-weight:600;color:var(--navy);display:flex;align-items:center;gap:7px}

/* Status pages */
.status-wrap{min-height:60vh;display:grid;place-items:center;text-align:center;padding:60px 20px}
.status-icon{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;margin:0 auto 22px}
.status-icon--ok{background:rgba(37,211,102,.15)}
.status-icon--no{background:rgba(255,107,92,.15)}

/* ---------- Real photos ---------- */
.hero__photo{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;transform:scale(1.03)}
.hero__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(115deg,rgba(8,44,64,.90) 0%,rgba(10,95,134,.66) 46%,rgba(34,211,211,.32) 100%)}
.hero .hero__inner{z-index:3}
.img-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);height:100%}
.img-cover{width:100%;height:100%;object-fit:cover;display:block}
.gallery img{width:100%;height:100%;min-height:200px;object-fit:cover;border-radius:var(--radius);display:block}
.gallery .feat{grid-column:span 2;grid-row:span 2}
.gallery .feat img{min-height:260px;height:100%}
@media(max-width:760px){.gallery .feat{grid-column:span 2}.gallery .feat img{min-height:240px}}
.page-hero--photo{position:relative;overflow:hidden}
.page-hero--photo .ph-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.page-hero--photo .ph-ov{position:absolute;inset:0;background:linear-gradient(120deg,rgba(8,44,64,.88),rgba(10,95,134,.62));z-index:1}
.page-hero--photo .container{position:relative;z-index:2}

hr.soft{border:0;border-top:1px solid rgba(10,61,87,.1);margin:30px 0}
.text-coral{color:var(--coral)}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
