:root{
  --bg:#f5efe4;
  --bg-2:#fff9f0;
  --ink:#17324f;
  --ink-soft:#53708e;
  --deep-blue:#124b9c;
  --sea-blue:#1d68d8;
  --light-sea:#dfeeff;
  --sand:#f3d7a2;
  --gold:#d9a441;
  --shell:#fff7ea;
  --coral:#ff8c69;
  --foam:#ffffff;
  --line:rgba(23,50,79,0.10);
  --shadow:0 18px 45px rgba(18,75,156,0.10);
  --radius-xl:36px;
  --radius-lg:28px;
  --radius-md:20px;
  --radius-sm:14px;
  --max:1480px;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family:"Inter", sans-serif;
  background:
    radial-gradient(circle at top left, rgba(29,104,216,.10), transparent 25%),
    radial-gradient(circle at bottom right, rgba(255,140,105,.08), transparent 20%),
    linear-gradient(180deg, #f7f1e8, #fdf8f0);
  color:var(--ink);
  min-height:100vh;
}

a{
  text-decoration:none;
  color:inherit;
}

button{
  border:none;
  background:none;
  font:inherit;
  cursor:pointer;
}

img{
  display:block;
  width:100%;
}

.sea-overlay{
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.08;
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.9) 0 2px, transparent 3px),
    radial-gradient(circle at 70% 40%, rgba(255,255,255,.9) 0 2px, transparent 3px),
    radial-gradient(circle at 40% 70%, rgba(255,255,255,.9) 0 2px, transparent 3px);
  background-size:260px 260px;
}

.captain-bar{
  width:min(calc(100% - 28px), var(--max));
  margin:18px auto 0;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(255,255,255,.75);
  border-radius:24px;
  padding:14px 18px;
  backdrop-filter:blur(12px);
  box-shadow:var(--shadow);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  position:sticky;
  top:16px;
  z-index:20;
}

.crest-wrap{
  display:flex;
  align-items:center;
  gap:14px;
}

.crest-badge{
  width:62px;
  height:62px;
  border-radius:18px;
  background:linear-gradient(135deg, var(--deep-blue), var(--sea-blue));
  color:#fff;
  display:grid;
  place-items:center;
  font-size:1.6rem;
  box-shadow:0 14px 26px rgba(29,104,216,.22);
}

.crest-mini{
  display:block;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--ink-soft);
}

.crest-copy h1{
  font-family:"DM Serif Display", serif;
  font-size:2rem;
  line-height:1;
  font-weight:400;
}

.captain-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.nav-chip,
.captain-cta,
.cta-primary,
.cta-secondary,
.dish-btn,
.final-boat-btn{
  padding:14px 18px;
  border-radius:999px;
  font-weight:800;
  transition:.22s ease;
}

.nav-chip{
  background:rgba(18,75,156,.06);
  color:var(--ink);
}

.captain-cta,
.cta-primary,
.final-boat-btn{
  background:linear-gradient(135deg, var(--deep-blue), var(--sea-blue));
  color:#fff;
  box-shadow:0 14px 28px rgba(29,104,216,.20);
}

.cta-secondary{
  background:#fff;
  color:var(--ink);
  border:1px solid var(--line);
}

.nav-chip:hover,
.captain-cta:hover,
.cta-primary:hover,
.cta-secondary:hover,
.dish-btn:hover,
.final-boat-btn:hover{
  transform:translateY(-2px);
}

.harbor-layout{
  width:min(calc(100% - 28px), var(--max));
  margin:18px auto 42px;
  display:flex;
  flex-direction:column;
  gap:22px;
  position:relative;
  z-index:1;
}

.deck-hero{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:18px;
}

.deck-left{
  background:
    linear-gradient(145deg, rgba(255,255,255,.78), rgba(255,255,255,.56)),
    var(--bg-2);
  border-radius:38px;
  padding:34px;
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative;
}

.deck-left::before{
  content:"";
  position:absolute;
  right:-70px;
  bottom:-70px;
  width:240px;
  height:240px;
  border-radius:50%;
  background:rgba(29,104,216,.10);
  filter:blur(12px);
}

.hero-bread{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}

.kicker{
  font-size:.82rem;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--deep-blue);
}

.dark-kicker{
  color:#fff;
}

.status-pill{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(18,75,156,.12);
  padding:10px 14px;
  border-radius:999px;
  font-size:.85rem;
  font-weight:800;
  display:flex;
  gap:10px;
  align-items:center;
}

.status-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:#34c759;
  box-shadow:0 0 16px rgba(52,199,89,.7);
}

.deck-left h2,
.log-main h2,
.dock-head h2,
.atmosphere-copy h2,
.port-card h2,
.faq-head h2,
.captain-final h2{
  font-family:"DM Serif Display", serif;
  font-weight:400;
  font-size:clamp(2.9rem, 6vw, 5.4rem);
  line-height:.92;
  margin-top:18px;
}

.deck-left h2 span{
  color:var(--sea-blue);
  font-style:italic;
}

.deck-copy{
  margin-top:18px;
  max-width:680px;
  color:var(--ink-soft);
  line-height:1.85;
  font-size:1.02rem;
}

.deck-cta{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:28px 0 26px;
}

.tide-points{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}

.tide-item{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(18,75,156,.08);
  border-radius:20px;
  padding:16px;
}

.tide-item strong{
  display:block;
  font-size:1rem;
}

.tide-item span{
  font-size:.88rem;
  color:var(--ink-soft);
}

.deck-right{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.hero-photo-card{
  grid-column:1 / span 2;
  min-height:420px;
  border-radius:34px;
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow);
  background:#d5e7ff;
}

.hero-photo-card img{
  height:100%;
  object-fit:cover;
}

.foam-ring{
  position:absolute;
  inset:0;
  border:14px solid rgba(255,255,255,.16);
  border-radius:34px;
  z-index:1;
  pointer-events:none;
}

.captain-note{
  position:absolute;
  left:18px;
  bottom:18px;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px);
  padding:14px 16px;
  border-radius:18px;
  z-index:2;
  box-shadow:var(--shadow);
}

.captain-note small{
  display:block;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.72rem;
  font-weight:800;
  color:var(--ink-soft);
}

.captain-note strong{
  font-family:"DM Serif Display", serif;
  font-size:1.45rem;
  font-weight:400;
}

.signal-card{
  min-height:170px;
  border-radius:26px;
  padding:20px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

.signal-card span{
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:10px;
}

.signal-card h3,
.promo-flag h3,
.a-panel h3,
.port-map-surface h3{
  font-family:"DM Serif Display", serif;
  font-weight:400;
  font-size:2rem;
  line-height:1;
}

.signal-card p,
.log-main p,
.dish-body p,
.atmosphere-copy p,
.a-panel p,
.faq-grid p,
.captain-final p{
  color:var(--ink-soft);
  line-height:1.75;
}

.signal-card.sky{
  background:linear-gradient(145deg, #dcebff, #bddbff);
}

.signal-card.sand{
  background:linear-gradient(145deg, #fff4dd, #f4dab0);
}

.wave-strip{
  background:linear-gradient(90deg, var(--deep-blue), var(--sea-blue));
  color:#fff;
  border-radius:22px;
  overflow:hidden;
  padding:14px 0;
  box-shadow:var(--shadow);
}

.wave-track{
  display:flex;
  gap:34px;
  white-space:nowrap;
  padding:0 20px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.captain-log{
  display:grid;
  grid-template-columns:1.1fr .7fr .7fr .7fr;
  gap:16px;
}

.log-main,
.promo-flag{
  min-height:250px;
  border-radius:32px;
  padding:24px;
  box-shadow:var(--shadow);
}

.log-main{
  background:linear-gradient(135deg, #0f4ea6, #1c72e6);
  color:#fff;
}

.log-main p{
  color:rgba(255,255,255,.82);
  margin-top:14px;
  max-width:620px;
}

.promo-flag{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

.promo-flag span{
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin-bottom:12px;
}

.promo-flag.gold{
  background:linear-gradient(145deg, #ffe0a0, #d7a03f);
  color:#19304d;
}

.promo-flag.blue{
  background:linear-gradient(145deg, #e5f1ff, #bddbff);
}

.promo-flag.shell{
  background:linear-gradient(145deg, #fffdf7, #f8ead1);
}

.menu-docks{
  background:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.7);
  border-radius:36px;
  padding:28px;
  box-shadow:var(--shadow);
}

.dock-head{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-end;
  margin-bottom:22px;
}

.dock-filters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.dock-filter{
  padding:12px 16px;
  border-radius:999px;
  background:#fff;
  color:var(--ink-soft);
  font-weight:800;
  border:1px solid rgba(18,75,156,.10);
}

.dock-filter.active{
  background:var(--deep-blue);
  color:#fff;
}

.dock-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:18px;
}

.dish-card{
  grid-column:span 4;
  background:#fff;
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  transition:.25s ease;
}

.dish-card:hover{
  transform:translateY(-4px);
}

.featured-dish{
  grid-column:span 8;
  background:linear-gradient(180deg, #fff, #f4f8ff);
}

.dish-media{
  height:245px;
}

.featured-dish .dish-media{
  height:310px;
}

.dish-media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.dish-body{
  padding:18px;
  display:flex;
  flex-direction:column;
  flex:1;
}

.dish-tag{
  display:inline-block;
  margin-bottom:12px;
  font-size:.75rem;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--sea-blue);
}

.dish-top{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:10px;
}

.dish-top h3{
  font-family:"DM Serif Display", serif;
  font-weight:400;
  font-size:1.95rem;
  line-height:1;
}

.dish-top span{
  font-weight:900;
  color:var(--deep-blue);
  white-space:nowrap;
}

.dish-body p{
  margin-bottom:18px;
}

.dish-btn{
  margin-top:auto;
  align-self:flex-start;
  background:var(--deep-blue);
  color:#fff;
}

.harbor-atmosphere{
  display:grid;
  grid-template-columns:.88fr 1.12fr;
  gap:18px;
}

.atmosphere-copy{
  background:linear-gradient(145deg, #fff7ea, #f5e3bf);
  border-radius:32px;
  padding:30px;
  box-shadow:var(--shadow);
}

.atmosphere-panels{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}

.a-panel{
  min-height:240px;
  border-radius:28px;
  padding:22px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

.shell-panel{
  background:linear-gradient(145deg, #ffffff, #eef6ff);
}

.ocean-panel{
  background:linear-gradient(145deg, #0f4ea6, #2678e9);
  color:#fff;
}

.ocean-panel p{
  color:rgba(255,255,255,.82);
}

.sunset-panel{
  background:linear-gradient(145deg, #ffd8c2, #ff9f7f);
}

.port-section{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:18px;
}

.port-card{
  border-radius:32px;
  overflow:hidden;
  box-shadow:var(--shadow);
}

.info-port{
  background:#fff;
  padding:28px;
}

.info-port ul{
  list-style:none;
  margin-top:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
  color:var(--ink-soft);
  line-height:1.75;
}

.map-port{
  min-height:340px;
  background:
    linear-gradient(rgba(18,75,156,.22), rgba(18,75,156,.22)),
    repeating-linear-gradient(
      90deg,
      rgba(255,255,255,.18) 0px,
      rgba(255,255,255,.18) 36px,
      transparent 36px,
      transparent 72px
    ),
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,.18) 0px,
      rgba(255,255,255,.18) 36px,
      transparent 36px,
      transparent 72px
    ),
    linear-gradient(145deg, #0f4ea6, #1f73e4);
  display:grid;
  place-items:center;
  padding:22px;
}

.port-map-surface{
  width:100%;
  height:100%;
  border-radius:26px;
  border:2px dashed rgba(255,255,255,.35);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:20px;
  color:#fff;
}

.port-pin{
  font-size:3rem;
  margin-bottom:10px;
}

.port-map-surface p{
  margin-top:8px;
  color:rgba(255,255,255,.82);
}

.harbor-faq{
  background:rgba(255,255,255,.52);
  border:1px solid rgba(255,255,255,.7);
  border-radius:34px;
  padding:28px;
  box-shadow:var(--shadow);
}

.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:18px;
}

.faq-grid details{
  background:#fff;
  border-radius:22px;
  padding:18px 20px;
  box-shadow:var(--shadow);
}

.faq-grid summary{
  list-style:none;
  cursor:pointer;
  font-weight:800;
  position:relative;
  padding-right:24px;
}

.faq-grid summary::after{
  content:"+";
  position:absolute;
  right:0;
  top:0;
  font-size:1.2rem;
}

.faq-grid details[open] summary::after{
  content:"−";
}

.faq-grid p{
  margin-top:12px;
}

.captain-final{
  background:linear-gradient(145deg, #0f4ea6, #1c72e6 68%, #5da1ff);
  color:#fff;
  border-radius:36px;
  padding:30px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  box-shadow:var(--shadow);
}

.captain-final p{
  color:rgba(255,255,255,.84);
  max-width:720px;
  margin-top:12px;
}

.final-boat-btn{
  background:#fff;
  color:var(--deep-blue);
  white-space:nowrap;
}

@media (max-width: 1220px){
  .deck-hero,
  .harbor-atmosphere,
  .port-section{
    grid-template-columns:1fr;
  }

  .captain-log{
    grid-template-columns:1fr 1fr;
  }

  .atmosphere-panels{
    grid-template-columns:1fr 1fr 1fr;
  }

  .dock-grid{
    grid-template-columns:1fr 1fr;
  }

  .dish-card,
  .featured-dish{
    grid-column:span 1;
  }
}

@media (max-width: 980px){
  .captain-bar,
  .dock-head,
  .captain-final{
    flex-direction:column;
    align-items:flex-start;
  }

  .deck-right,
  .tide-points,
  .atmosphere-panels,
  .faq-grid,
  .dock-grid{
    grid-template-columns:1fr;
  }

  .hero-photo-card{
    grid-column:auto;
  }

  .captain-log{
    grid-template-columns:1fr;
  }
}

@media (max-width: 680px){
  .captain-bar,
  .deck-left,
  .hero-photo-card,
  .signal-card,
  .log-main,
  .promo-flag,
  .menu-docks,
  .dish-card,
  .atmosphere-copy,
  .a-panel,
  .port-card,
  .harbor-faq,
  .captain-final{
    border-radius:24px;
  }

  .captain-bar,
  .menu-docks,
  .harbor-faq,
  .captain-final{
    padding:22px;
  }

  .deck-left,
  .atmosphere-copy,
  .info-port{
    padding:22px;
  }

  .deck-left h2,
  .log-main h2,
  .dock-head h2,
  .atmosphere-copy h2,
  .port-card h2,
  .faq-head h2,
  .captain-final h2{
    font-size:clamp(2.4rem, 11vw, 4.2rem);
  }

  .captain-actions{
    width:100%;
  }

  .nav-chip,
  .captain-cta{
    flex:1 1 auto;
    text-align:center;
  }

  .dock-grid{
    grid-template-columns:1fr;
  }
}