/* Boat Rental Marbella — design system
   Palette: navy ink, sea blue, sun yellow, sand, WhatsApp green
*/
:root{
  --c-bg:#fff;
  --c-ink:#0a1f33;
  --c-ink-soft:#2c3e50;
  --c-muted:#5a6b7a;
  --c-line:#e6ecf2;
  --c-line-soft:#f0f4f8;
  --c-sea:#0a6db5;
  --c-sea-d:#075590;
  --c-sea-l:#e8f2fa;
  --c-sun:#f5a623;
  --c-sun-d:#d68910;
  --c-sand:#fef7e7;
  --c-sand-d:#f1e5c1;
  --c-wa:#25d366;
  --c-wa-d:#1ebe5a;
  --r:14px;
  --r-lg:20px;
  --shadow-sm:0 2px 8px rgba(10,31,51,.06);
  --shadow:0 8px 28px rgba(10,31,51,.10);
  --shadow-lg:0 18px 50px rgba(10,31,51,.18);
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;
  --font-serif:"Playfair Display",Georgia,"Times New Roman",serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font);
  font-size:17px;
  line-height:1.65;
  color:var(--c-ink);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-sea);text-decoration:none;transition:color .15s ease}
a:hover{color:var(--c-sea-d);text-decoration:underline}

/* ─── Typography ──────────────────────── */
h1,h2,h3,h4{color:var(--c-ink);line-height:1.18;margin-top:1.8em;margin-bottom:.5em;letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,4vw,2.6rem);font-weight:800;margin-top:.6em}
h2{font-size:clamp(1.45rem,2.4vw,1.85rem);font-weight:700;padding-left:14px;border-left:4px solid var(--c-sun);margin-top:2.4em}
h3{font-size:1.2rem;font-weight:700}
h4{font-size:1rem;font-weight:700}
p,ul,ol{margin:0 0 1.1em}
strong{color:var(--c-ink);font-weight:700}
.content > p:first-of-type{font-size:1.13rem;color:var(--c-ink-soft);line-height:1.6}

/* ─── Header ──────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--c-line);
}
.header-row{display:flex;gap:18px;align-items:center;padding:12px 24px;min-height:62px}
.brand{font-weight:800;font-size:1.05rem;color:var(--c-ink);display:flex;gap:8px;align-items:center;flex-shrink:0}
.brand:hover{text-decoration:none;color:var(--c-ink)}
.brand-mark{color:var(--c-sea);font-size:1.3rem}
.brand-text{letter-spacing:-.01em}
.brand-text em{font-style:italic;color:var(--c-sea);font-weight:600;margin:0 1px}
.nav{display:flex;gap:22px;margin-left:14px;flex:1;flex-wrap:wrap;align-items:center}
.nav a{color:var(--c-ink);font-size:.95rem;font-weight:500;padding:6px 0;position:relative}
.nav a:hover{color:var(--c-sea);text-decoration:none}
.nav a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--c-sun);transform:scaleX(0);transform-origin:center;transition:transform .2s ease}
.nav a:hover::after{transform:scaleX(1)}
.cta-stack{display:flex;gap:8px;flex-shrink:0;align-items:center}
.cta-wa,.cta-tel{
  display:inline-flex;align-items:center;gap:6px;
  padding:9px 16px;border-radius:999px;
  font-weight:600;font-size:.9rem;
  transition:transform .12s ease,box-shadow .12s ease,filter .12s ease;
}
.cta-wa{background:var(--c-wa);color:#fff}
.cta-tel{background:var(--c-sea);color:#fff;padding:9px 13px}
.cta-wa:hover,.cta-tel:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.12);filter:brightness(1.06)}
.nav-burger{display:none;background:none;border:0;font-size:1.5rem;color:var(--c-ink);cursor:pointer;padding:6px 10px}

/* ─── Hero ────────────────────────────── */
.hero{position:relative;width:100%;overflow:hidden;background:#0a1f33;color:#fff}
.hero-img-wrap{display:block;width:100%;height:100%;position:absolute;inset:0}
.hero-img-wrap img{width:100%;height:100%;object-fit:cover}
.hero-shade{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(10,31,51,.10) 0%, rgba(10,31,51,.30) 50%, rgba(10,31,51,.78) 100%),
    linear-gradient(110deg, rgba(10,31,51,.55) 0%, rgba(10,31,51,.18) 55%, rgba(10,31,51,0) 80%);
}
.hero-content{
  position:relative;z-index:2;
  padding:96px 24px 80px;
  min-height:clamp(420px, 62vh, 620px);
  display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;
  max-width:1180px;margin:0 auto;
}
.eyebrow{
  display:inline-block;
  font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--c-sun);
  background:rgba(245,166,35,.14);
  border:1px solid rgba(245,166,35,.45);
  padding:6px 14px;border-radius:999px;
  margin-bottom:18px;
}
.hero-title{
  color:#fff;font-size:clamp(2rem, 5.4vw, 3.6rem);font-weight:800;
  line-height:1.05;margin:0 0 14px;max-width:900px;
  letter-spacing:-.02em;
  text-shadow:0 2px 30px rgba(0,0,0,.35);
}
.hero-sub{
  color:rgba(255,255,255,.92);
  font-size:clamp(1rem, 1.6vw, 1.22rem);
  line-height:1.5;
  max-width:680px;
  margin:0 0 20px;
}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:24px;font-size:.98rem;color:rgba(255,255,255,.95)}
.hero-price strong{color:var(--c-sun);font-size:1.18em}
.hero-dot{opacity:.5}
.hero-incl{opacity:.85}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-hero-primary,.btn-hero-ghost{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 22px;border-radius:12px;
  font-weight:700;font-size:1rem;
  transition:transform .12s,box-shadow .12s,filter .12s;
}
.btn-hero-primary{background:var(--c-wa);color:#fff;box-shadow:0 8px 28px rgba(37,211,102,.35)}
.btn-hero-primary:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(37,211,102,.5);filter:brightness(1.05);text-decoration:none}
.btn-hero-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(4px)}
.btn-hero-ghost:hover{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.65);text-decoration:none;color:#fff}

/* ─── Trust strip ─────────────────────── */
.trust-strip{
  background:linear-gradient(180deg, var(--c-sand) 0%, #fdf3d2 100%);
  border-bottom:1px solid var(--c-sand-d);
  font-size:.92rem;
  padding:14px 0;
  color:var(--c-ink);
}
.trust-row{display:flex;gap:32px;flex-wrap:wrap;justify-content:center;align-items:center}
.trust-item{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;font-weight:500}
.trust-ico{font-size:1.15rem;line-height:1}

/* ─── Boat-type grid (hub) ────────────── */
.boat-grid-section{padding:64px 0 24px;background:linear-gradient(180deg, #fff 0%, var(--c-sea-l) 100%)}
.boat-grid-section .section-head{text-align:center;max-width:680px;margin:0 auto 32px;padding:0 24px}
.boat-grid-section .section-head .eyebrow{color:var(--c-sea);background:var(--c-sea-l);border-color:rgba(10,109,181,.28);margin-bottom:14px}
.boat-grid-section .section-head h2{
  border:0;padding:0;margin:0 0 12px;
  font-size:clamp(1.7rem, 3vw, 2.2rem);font-weight:800;color:var(--c-ink);letter-spacing:-.02em;
}
.boat-grid-section .section-head p{color:var(--c-muted);font-size:1.05rem;margin:0}
.boat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:22px;
  max-width:1180px;
  margin:0 auto;
  padding:0 24px;
}
.boat-card{
  background:#fff;
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform .2s ease, box-shadow .2s ease;
  display:flex;flex-direction:column;
  border:1px solid var(--c-line);
}
.boat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none}
.boat-card-img{aspect-ratio:16/10;overflow:hidden;background:var(--c-line-soft);position:relative}
.boat-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.boat-card:hover .boat-card-img img{transform:scale(1.05)}
.boat-card-tag{
  position:absolute;top:12px;left:12px;
  background:var(--c-sun);color:#fff;
  font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 10px;border-radius:6px;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.boat-card-body{padding:20px;flex:1;display:flex;flex-direction:column}
.boat-card-title{
  font-size:1.18rem;font-weight:800;color:var(--c-ink);
  margin:0 0 6px;letter-spacing:-.01em;
}
.boat-card-desc{color:var(--c-muted);font-size:.93rem;line-height:1.5;margin:0 0 14px;flex:1}
.boat-card-meta{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding-top:14px;border-top:1px dashed var(--c-line)}
.boat-card-price{color:var(--c-ink);font-weight:700;font-size:1rem}
.boat-card-price strong{font-size:1.25rem;color:var(--c-sea)}
.boat-card-price small{display:block;color:var(--c-muted);font-weight:400;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}
.boat-card-cta{
  display:inline-flex;align-items:center;gap:4px;
  color:var(--c-sea);font-weight:700;font-size:.92rem;
}

/* ─── Main layout ─────────────────────── */
.page{
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:48px;
  padding:48px 24px 80px;
  max-width:1180px;margin:0 auto;
}
.content{min-width:0;max-width:720px}
.breadcrumbs{font-size:.88rem;color:var(--c-muted);margin-bottom:16px;grid-column:1 / -1}
.breadcrumbs a{color:var(--c-muted);text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s}
.breadcrumbs a:hover{text-decoration-color:var(--c-muted)}
.byline{
  color:var(--c-muted);font-size:.93rem;
  padding:10px 0 10px 14px;border-left:3px solid var(--c-sun);
  margin:0 0 1.6em;font-style:italic;
}
.byline strong{font-style:normal;color:var(--c-ink)}

/* ─── Content elements ────────────────── */
.content ul,.content ol{padding-left:1.4em}
.content li{margin:.3em 0}
.inline-img{margin:2em -8px;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.inline-img img{display:block;width:100%;height:auto}
table{
  border-collapse:separate;border-spacing:0;width:100%;
  margin:1.4em 0;font-size:.95rem;
  border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--c-line);
}
th,td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--c-line)}
th{background:var(--c-sea-l);color:var(--c-sea-d);font-weight:700;font-size:.86rem;text-transform:uppercase;letter-spacing:.04em}
tr:last-child td{border-bottom:0}
tbody tr:hover{background:var(--c-line-soft)}
blockquote{border-left:4px solid var(--c-sun);background:var(--c-sand);margin:1.6em 0;padding:14px 20px;border-radius:0 var(--r) var(--r) 0;color:var(--c-ink-soft)}
.callout{background:var(--c-sea-l);border:1px solid #cfe5f4;border-radius:var(--r);padding:16px 20px;margin:1.4em 0;color:var(--c-ink-soft)}
.callout strong{color:var(--c-sea-d)}
details{
  border:1px solid var(--c-line);border-radius:12px;
  padding:14px 18px;margin:8px 0;
  background:#fff;
  transition:box-shadow .15s ease,border-color .15s ease;
}
details[open]{box-shadow:var(--shadow-sm);border-color:var(--c-sea-l)}
details summary{font-weight:600;cursor:pointer;color:var(--c-ink);list-style:none;padding-right:24px;position:relative}
details summary::-webkit-details-marker{display:none}
details summary::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);font-weight:700;color:var(--c-sea);font-size:1.2rem;transition:transform .2s}
details[open] summary::after{content:"−";transform:translateY(-50%)}
details p{margin:.6em 0 0;color:var(--c-ink-soft)}

/* ─── Book card (sidebar) ─────────────── */
.book-card{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--r-lg);
  padding:24px;
  position:sticky;top:84px;height:max-content;
  box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:10px;
}
.book-card-price{
  background:linear-gradient(135deg, var(--c-sand) 0%, #fdf3d2 100%);
  border-radius:12px;
  padding:14px 18px;
  margin:-8px -8px 6px;
  text-align:center;
  font-size:.95rem;color:var(--c-ink-soft);
}
.book-card-price strong{display:inline-block;font-size:1.9rem;color:var(--c-ink);font-weight:800;letter-spacing:-.02em;margin:0 4px}
.book-card-sub{display:block;font-size:.85rem;color:var(--c-muted);margin-top:2px}
.book-card-pitch{font-size:.93rem;color:var(--c-ink-soft);line-height:1.5;margin:6px 0 10px}
.btn{
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:13px 18px;border-radius:11px;
  font-weight:700;font-size:.98rem;
  transition:transform .12s,box-shadow .12s,filter .12s;
}
.btn-primary{background:var(--c-wa);color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.28)}
.btn-primary:hover{transform:translateY(-1px);filter:brightness(1.05);box-shadow:0 6px 20px rgba(37,211,102,.4);text-decoration:none}
.btn-secondary{background:var(--c-sea);color:#fff}
.btn-secondary:hover{background:var(--c-sea-d);text-decoration:none;color:#fff}
.btn-ghost{background:#fff;border:1.5px solid var(--c-line);color:var(--c-ink);font-weight:600;font-size:.93rem}
.btn-ghost:hover{border-color:var(--c-sea);color:var(--c-sea);text-decoration:none}
.book-card-micro{text-align:center;color:var(--c-muted);font-size:.82rem;margin:-2px 0 8px}
.book-card-incl{margin-top:16px;padding-top:16px;border-top:1px dashed var(--c-line);font-size:.88rem}
.book-card-incl strong{display:block;color:var(--c-ink);margin-bottom:6px;font-size:.84rem;text-transform:uppercase;letter-spacing:.08em}
.book-card-incl ul{padding:0;list-style:none;margin:0;color:var(--c-ink-soft)}
.book-card-incl li{position:relative;padding-left:20px;margin:2px 0}
.book-card-incl li::before{content:"✓";position:absolute;left:0;color:var(--c-wa);font-weight:700}

/* ─── Footer ──────────────────────────── */
.site-footer{background:#0a1f33;color:#cfd8e0;padding:56px 0 18px;margin-top:60px}
.site-footer h4{color:#fff;margin:0 0 12px;font-size:.95rem;font-weight:700;letter-spacing:.02em}
.site-footer a{color:#cfd8e0;text-decoration:none}
.site-footer a:hover{color:var(--c-sun);text-decoration:none}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:32px}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin:6px 0;font-size:.92rem}
.footer-grid p{font-size:.92rem;line-height:1.55;color:#9eb1c3}
.footer-legal{border-top:1px solid #1c3148;margin-top:36px;padding-top:16px;font-size:.82rem;color:#7a8fa3}
.footer-legal a{color:#7a8fa3}

/* ─── Mobile sticky CTA bar ──────────── */
.mobile-cta{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:60;
  padding:10px 12px env(safe-area-inset-bottom);
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);
  border-top:1px solid var(--c-line);
  gap:8px;box-shadow:0 -4px 20px rgba(0,0,0,.08);
}
.mobile-cta-wa,.mobile-cta-tel{
  display:flex;align-items:center;justify-content:center;
  padding:14px;border-radius:11px;font-weight:700;font-size:1rem;
}
.mobile-cta-wa{background:var(--c-wa);color:#fff;flex:1}
.mobile-cta-tel{background:var(--c-sea);color:#fff;min-width:56px}
.mobile-cta a:hover{text-decoration:none}

/* ─── Responsive ──────────────────────── */
@media (max-width:1024px){
  .page{grid-template-columns:1fr;gap:36px}
  .book-card{position:static;order:-1}
}
@media (max-width:880px){
  .nav{display:none;position:absolute;top:62px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:14px 24px;border-bottom:1px solid var(--c-line);box-shadow:0 8px 20px rgba(0,0,0,.08);gap:0}
  .nav.open{display:flex}
  .nav a{padding:12px 0;border-bottom:1px solid var(--c-line-soft);width:100%}
  .nav a:last-child{border-bottom:0}
  .nav-burger{display:block;margin-left:auto;order:99}
  .cta-tel{display:none}
  .hero-content{padding:64px 24px 96px;min-height:clamp(360px, 56vh, 520px)}
  .hero-title{font-size:clamp(1.8rem, 8vw, 2.4rem)}
  .mobile-cta{display:flex}
  body{padding-bottom:78px}
  .page{padding:32px 16px 48px}
  .inline-img{margin:1.6em 0}
  table{font-size:.86rem;display:block;overflow-x:auto}
  .trust-row{gap:14px;font-size:.84rem;justify-content:flex-start;padding:0 4px;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none}
  .trust-row::-webkit-scrollbar{display:none}
  .trust-item{scroll-snap-align:start;flex:0 0 auto}
  .footer-grid{gap:24px}
}
@media (max-width:520px){
  body{font-size:16px}
  h2{font-size:1.4rem}
  .hero-meta{font-size:.92rem}
  .btn-hero-primary,.btn-hero-ghost{padding:12px 18px;font-size:.95rem}
}

/* ─── Print ──────────────────────────── */
@media print{
  .site-header,.mobile-cta,.book-card,.cta-stack,.hero-actions{display:none}
  .hero{height:200px}
  body{color:#000}
}
