/* ===== Tokens ===== */
:root{
  --navy:#1b2440; --navy-soft:#2a3556;
  --yellow:#fdb913; --yellow-dark:#e8a800;
  --teal:#37b6c3;
  --bg:#fff; --bg-soft:#f5f6f8;
  --muted:#6b7280; --border:#eceef1;
  --container:1180px;
  --radius-card:16px; --radius-input:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:"Open Sans",system-ui,sans-serif;color:var(--navy);
  background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.font-head{font-family:"Jost",system-ui,sans-serif;
  font-weight:700;line-height:1.15;color:var(--navy)}
h2{font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;text-align:center}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
section{padding:64px 0}
/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;cursor:pointer;font-family:"Jost",sans-serif;font-weight:600;
  border-radius:999px;padding:14px 28px;font-size:1rem;transition:.2s}
.btn--primary{background:var(--yellow);color:var(--navy)}
.btn--primary:hover{background:var(--yellow-dark)}
.btn--ghost{background:#fff;color:var(--navy);border:1.5px solid var(--border)}
.btn--ghost:hover{border-color:var(--navy)}
/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:#fff;
  box-shadow:0 2px 12px rgba(27,36,64,.06)}
.site-header__inner{display:flex;align-items:center;gap:24px;
  min-height:72px}
.brand{font-family:"Jost",sans-serif;font-weight:800;font-size:1.4rem;
  color:var(--navy);letter-spacing:.3px}
.muted{color:var(--muted)}
.field{display:flex;flex-direction:column;gap:8px}
.stars{color:var(--yellow);letter-spacing:2px}
.main-nav{display:flex;gap:22px;margin-left:auto}
.main-nav a{font-family:"Jost",sans-serif;font-weight:500;
  padding:6px 0;border-bottom:2px solid transparent}
.main-nav a:hover,.main-nav a.is-active{border-color:var(--yellow)}
.site-header__cta{display:flex;align-items:center;gap:16px}
.header-phone{font-family:"Jost",sans-serif;font-weight:600;white-space:nowrap}
.nav-toggle{display:none;font-size:1.6rem;background:none;border:none;
  cursor:pointer;color:var(--navy)}
@media(max-width:960px){
  .nav-toggle{display:block;margin-left:auto}
  .main-nav{display:none;position:absolute;top:72px;left:0;right:0;
    background:#fff;flex-direction:column;padding:16px 20px;
    box-shadow:0 8px 20px rgba(0,0,0,.1)}
  .main-nav.open{display:flex}
  .site-header__cta .btn{display:none}
}
/* ===== Footer ===== */
.site-footer{background:#fff;border-top:1px solid var(--border);padding-top:48px}
.site-footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1.3fr;gap:32px}
.site-footer__brand p{color:var(--muted);margin:12px 0;max-width:34ch}
.site-footer__col{display:flex;flex-direction:column;gap:10px}
.site-footer__col h4{margin-bottom:4px}
.site-footer__col a,.site-footer__col span{color:var(--muted)}
.site-footer__col a:hover{color:var(--navy)}
.socials{display:flex;gap:10px}
.socials a{width:36px;height:36px;border-radius:50%;background:var(--navy);
  color:#fff;display:grid;place-items:center;font-size:.8rem}
.site-footer__bottom{border-top:1px solid var(--border);margin-top:32px;
  padding:20px 20px 32px;color:var(--muted);font-size:.9rem}
@media(max-width:720px){.site-footer__grid{grid-template-columns:1fr}}
/* ===== Hero ===== */
.hero{position:relative;color:#fff;padding:96px 0 120px;overflow:hidden;background:var(--navy)}
.hero>.container{position:relative;z-index:2}
.hero__slides{position:absolute;inset:0;z-index:0}
.hero__slide{position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;animation:heroFade 21s infinite}
.hero__slide:nth-child(1){animation-delay:0s}
.hero__slide:nth-child(2){animation-delay:7s}
.hero__slide:nth-child(3){animation-delay:14s}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(27,36,64,.45),rgba(27,36,64,.62))}
@keyframes heroFade{0%,100%{opacity:0}8%,33%{opacity:1}41%{opacity:0}}
@media(prefers-reduced-motion:reduce){
  .hero__slide{animation:none}
  .hero__slide:nth-child(1){opacity:1}
}
.hero__eyebrow{font-family:"Jost",sans-serif;font-weight:600;letter-spacing:1px;
  text-transform:uppercase;opacity:.9}
.hero__title{color:#fff;font-size:clamp(2rem,5vw,3.4rem);font-weight:800;margin:12px 0}
.hero__sub{font-size:1.1rem;margin-bottom:24px;opacity:.95}
.search-bar{background:#fff;border-radius:18px;box-shadow:0 18px 40px rgba(0,0,0,.18);
  display:flex;gap:0;align-items:stretch;margin-top:-56px;position:relative;overflow:hidden}
.search-bar label{flex:1;display:flex;flex-direction:column;gap:4px;
  padding:16px 18px;border-right:1px solid var(--border);
  font-size:.78rem;color:var(--muted);font-family:"Jost",sans-serif}
.search-bar input{border:none;font-size:1rem;color:var(--navy);font-weight:600;outline:none}
.search-bar__go{border-radius:0;padding:0 32px}
.search-bar__note{color:var(--muted);font-size:.85rem;margin-top:10px;text-align:center}
@media(max-width:860px){.search-bar{flex-direction:column;margin-top:24px}
  .search-bar label{border-right:none;border-bottom:1px solid var(--border)}
  .search-bar__go{padding:16px}}
/* ===== Hot Tours Preview ===== */
.center{text-align:center;margin-top:32px}
.accent{color:var(--yellow)}
h2 .accent{color:var(--yellow)}
.card-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px}
.tour-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);
  overflow:hidden;transition:.2s;color:var(--navy)}
.tour-card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(27,36,64,.12)}
.tour-card__img{height:160px;background-size:cover;background-position:center;position:relative}
.tour-card__badge{position:absolute;left:12px;top:12px;background:var(--yellow);
  color:var(--navy);font-family:"Jost",sans-serif;font-weight:600;font-size:.75rem;
  padding:4px 10px;border-radius:999px}
.tour-card__body{padding:16px}
.tour-card__price{color:var(--yellow-dark);font-weight:700;margin-top:8px}
@media(max-width:900px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.card-grid{grid-template-columns:1fr}}
.bg-soft{background:var(--bg-soft)}
.adv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.adv{text-align:center}
.adv__icon{width:64px;height:64px;border-radius:50%;background:#fff;
  color:var(--teal);display:grid;place-items:center;margin:0 auto 16px;
  box-shadow:0 8px 20px rgba(27,36,64,.08)}
.adv h3{font-size:1.05rem;margin-bottom:6px}
.adv p{color:var(--muted);font-size:.95rem;max-width:26ch;margin:0 auto}
@media(max-width:780px){.adv-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.adv-grid{grid-template-columns:1fr}}
.card-grid--3{grid-template-columns:repeat(3,1fr)}
.review{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);
  padding:24px;text-align:left;display:flex;flex-direction:column;height:100%}
.review__text{color:var(--muted)}
.review__author{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:18px}
.review__avatar{width:44px;height:44px;border-radius:50%;background:var(--bg-soft) center/cover;flex:none}
.review__author small{color:var(--muted)}
@media(max-width:780px){.card-grid--3{grid-template-columns:1fr}}
.trust{background:linear-gradient(180deg,#eef6f8,#fff)}
.trust__text{max-width:680px;margin:0 auto;text-align:center}
.trust__text h2{margin-bottom:14px}
.trust__text p{color:var(--muted);margin-bottom:24px}
.contact-map{padding-top:0}
.contact-map__inner{position:relative}
.contact-card{position:absolute;z-index:2;top:24px;left:24px;background:#fff;
  border-radius:var(--radius-card);box-shadow:0 14px 30px rgba(27,36,64,.15);
  padding:20px 24px;display:flex;flex-direction:column;gap:10px;max-width:320px}
.contact-card__row{font-family:"Jost",sans-serif;font-weight:600}
.contact-map__frame{width:100%;height:420px;border:0;border-radius:var(--radius-card)}
@media(max-width:680px){.contact-card{position:static;margin-bottom:16px;max-width:none}}
.picker__title{text-align:center;font-size:clamp(2rem,5vw,3rem);font-weight:800;margin:48px 0 32px}
.picker__tabs{display:flex;gap:24px;background:var(--yellow);border-radius:14px 14px 0 0;padding:14px 20px}
.tab{background:none;border:none;font-family:"Jost",sans-serif;font-weight:600;cursor:pointer;opacity:.7}
.tab.is-active{opacity:1;border-bottom:2px solid var(--navy)}
.picker__bar{display:flex;background:var(--yellow);padding:0 20px 18px;gap:0;border-radius:0 0 14px 14px;margin-bottom:24px}
.picker__bar label{flex:1;display:flex;flex-direction:column;gap:4px;padding:12px 16px;
  background:#fff;margin:0 4px;border-radius:10px;font-size:.78rem;color:var(--muted);font-family:"Jost",sans-serif}
.picker__bar input{border:none;font-weight:600;color:var(--navy);outline:none}
.picker__grid{display:grid;grid-template-columns:280px 1fr;gap:24px}
.checklist{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:12px}
.checklist--hotels{max-height:320px;overflow:auto;border:1px solid var(--border);border-radius:10px;padding:12px}
.picker__resorts,.picker__hotels{background:#fff;border:1px solid var(--border);border-radius:var(--radius-card);padding:20px}
.picker__filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.picker__filters select,.picker__search{padding:10px 14px;border:1px solid var(--border);border-radius:10px;font:inherit}
.picker__search{width:100%;margin-bottom:16px}
.field--budget{margin-top:24px;display:flex;flex-direction:column;gap:8px;max-width:420px}
@media(max-width:820px){.picker__grid{grid-template-columns:1fr}.picker__bar{flex-wrap:wrap}}
/* ===== Hot-tours / News page ===== */
.page-title{text-align:center;font-size:clamp(2rem,5vw,3rem);font-weight:800;margin:48px 0 32px}
.page-lead{text-align:center;color:var(--muted);max-width:60ch;margin:0 auto 40px}
.news-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding-bottom:64px}
.news-card{display:flex;gap:16px;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius-card);overflow:hidden}
.news-card__img{flex:0 0 200px;background-size:cover;background-position:center}
.news-card__body{padding:18px 18px 18px 0;display:flex;flex-direction:column;gap:8px}
.news-card__date{color:var(--yellow-dark);font-weight:700;font-size:.85rem}
.news-card__body .btn{align-self:flex-start;margin-top:auto;padding:10px 22px}
@media(max-width:820px){.news-grid{grid-template-columns:1fr}}
@media(max-width:480px){.news-card{flex-direction:column}.news-card__img{flex-basis:180px}
  .news-card__body{padding:0 18px 18px}}
.prose{max-width:760px;margin:0 auto;padding:24px 0 64px}
.prose p{margin-bottom:16px;color:var(--navy)}
.prose .muted{color:var(--muted);font-style:italic}
.prose a{color:var(--yellow-dark);font-weight:600}
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start;padding-bottom:64px}
.messengers{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0}
.btn.btn--max{color:#fff}
@media(max-width:780px){.contacts-grid{grid-template-columns:1fr}}

/* ===== Logo ===== */
.brand{display:inline-flex;align-items:center}
.brand__logo{height:52px;width:auto;display:block}
@media(max-width:480px){.brand__logo{height:44px}}

/* ===== Advantage numbers ===== */
.adv__num{width:64px;height:64px;border-radius:50%;background:#fff;color:var(--yellow);
  display:grid;place-items:center;margin:0 auto 16px;font-family:"Jost",sans-serif;
  font-weight:800;font-size:1.5rem;box-shadow:0 8px 20px rgba(27,36,64,.08)}

/* ===== Review stars ===== */
.review .stars{font-size:1.05rem;margin-bottom:12px}

/* ===== Social: MAX ===== */
.social-max{width:auto !important;height:36px;padding:0 18px;border-radius:999px !important;
  background:linear-gradient(135deg,#2c8cff,#0a5ad6) !important;color:#fff;
  font-family:"Jost",sans-serif;font-weight:700;font-size:.85rem;letter-spacing:.5px}
.social-max:hover{filter:brightness(1.07)}

/* ===== Beach footer (crab) ===== */
.beach-footer{position:relative;border-top:none;padding-top:300px;color:#fff;
  background:
    linear-gradient(180deg,
      #fff 0%,
      rgba(255,255,255,.5) 7%,
      rgba(255,255,255,0) 20%,
      rgba(13,28,26,0) 34%,
      rgba(12,26,24,.4) 52%,
      rgba(10,22,20,.68) 72%,
      rgba(8,18,17,.88) 100%),
    url("../img/crab-footer.jpg") center bottom/cover no-repeat}
.beach-footer .site-footer__grid,
.beach-footer .site-footer__bottom{text-shadow:0 1px 3px rgba(0,0,0,.45)}
.footer-logo{display:inline-block;background:#fff;padding:12px 16px;border-radius:14px;
  box-shadow:0 10px 28px rgba(0,0,0,.22);text-shadow:none}
.footer-logo img{height:50px;width:auto;display:block}
.beach-footer .site-footer__brand p{color:rgba(255,255,255,.92);margin-top:16px}
.beach-footer .site-footer__col h4{color:#fff}
.beach-footer .site-footer__col a,
.beach-footer .site-footer__col span{color:rgba(255,255,255,.9)}
.beach-footer .site-footer__col a:hover{color:#fff;text-decoration:underline}
.beach-footer .site-footer__bottom{border-top:1px solid rgba(255,255,255,.2);
  color:rgba(255,255,255,.82)}
.site-footer__credit{display:block;margin-top:6px;font-size:.75rem;opacity:.7}
@media(max-width:720px){.beach-footer{padding-top:170px}}
