/* ============================================================
   NAUTILIA YACHTING — SAILING ITINERARIES MODULE
   mod_ny_itineraries / naut-itineraries.css
   ------------------------------------------------------------
   Matches the charter-base itinerary card design system.
   Scoped to .naut-itineraries-mod .cb-* so it works wherever
   the module is loaded, with or without charter-base.css.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,300..600;1,6..72,300..500&family=Public+Sans:ital,wght@0,400..800;1,400&family=IBM+Plex+Mono:wght@400;500&display=swap');

.naut-itineraries-mod{
  --navy:#15264d; --royal:#27408b; --accent:#d92b2e; --sea:#1f7a86;
  --paper:#f6f2ea; --surface:#ffffff; --surface-2:#f4f0e8;
  --ink:#15213f; --body:#3b424f; --muted:#7c7f88;
  --line:rgba(21,33,63,.12); --line-soft:rgba(21,33,63,.07);
  --font-head:'Newsreader',Georgia,serif;
  --font-body:'Public Sans',system-ui,sans-serif;
  --font-mono:'IBM Plex Mono',ui-monospace,monospace;
  --r-sm:8px; --r-md:14px; --r-lg:22px;
  --shadow-sm:0 1px 2px rgba(21,33,63,.05),0 2px 10px rgba(21,33,63,.05);
  --shadow-md:0 12px 40px rgba(21,33,63,.12);
  --ease:cubic-bezier(.4,.7,.3,1);
  --ico:var(--sea);
  font-family:var(--font-body);
  color:var(--body);
  -webkit-font-smoothing:antialiased;
}
.naut-itineraries-mod *{box-sizing:border-box}

/* Defeat the template's article column-count rule when the module is dropped
   into pages that haven't loaded charter-base.css */
.naut-itineraries-mod article,
.naut-itineraries-mod article:first-of-type,
.naut-itineraries-mod .cb-itin,
.naut-itineraries-mod .cb-itin:first-of-type,
.naut-itineraries-mod .cb-itin__head,
.naut-itineraries-mod .cb-itin__body,
.naut-itineraries-mod .cb-timeline,
.naut-itineraries-mod .cb-day,
.naut-itineraries-mod .cb-day__body{
  column-count:1 !important;
  column-gap:0 !important;
  columns:auto !important;
  -webkit-columns:auto !important;
  -moz-columns:auto !important;
}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.naut-itineraries-mod .cb-kick{
  font-family:var(--font-mono);
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--sea);
  display:inline-flex;
  align-items:center;
  gap:9px;
}
.naut-itineraries-mod .cb-kick::before{
  content:"";
  width:22px;
  height:1px;
  background:currentColor;
  opacity:.7;
}
.naut-itineraries-mod .cb-section__head p{
  margin:10px 0 0;
  font-size:.95rem;
  line-height:1.5;
  color:var(--body);
}
.naut-itineraries-mod .cb-section__head a{
  color:var(--accent);
  font-weight:600;
  text-decoration:none;
  border-bottom:1.5px solid currentColor;
  transition:color .2s,border-color .2s;
}
.naut-itineraries-mod .cb-section__head a:hover{
  color:var(--navy);
  border-color:var(--navy);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.naut-itineraries-mod a.cb-btn,
.naut-itineraries-mod button.cb-btn,
.naut-itineraries-mod .cb-btn{
  display:inline-flex !important;
  align-items:center;
  gap:8px;
  cursor:pointer;
  border:none;
  font-family:var(--font-body);
  font-weight:600;
  font-size:.9rem;
  letter-spacing:.01em;
  padding:13px 24px;
  border-radius:8px !important;
  text-decoration:none !important;
  white-space:nowrap;
  transition:transform .15s var(--ease),box-shadow .2s,background .2s,color .2s;
  line-height:1.2;
}
.naut-itineraries-mod .cb-btn:hover{transform:translateY(-1px)}

.naut-itineraries-mod a.cb-btn--primary,
.naut-itineraries-mod .cb-btn--primary{
  background:var(--accent) !important;
  background-color:var(--accent) !important;
  color:#ffffff !important;
  border:0 !important;
  box-shadow:0 6px 18px rgba(217,43,46,.28);
}
.naut-itineraries-mod a.cb-btn--primary:hover,
.naut-itineraries-mod .cb-btn--primary:hover{
  background:#b8242c !important;
  background-color:#b8242c !important;
  color:#ffffff !important;
  box-shadow:0 10px 26px rgba(217,43,46,.4);
}

.naut-itineraries-mod a.cb-btn--outline,
.naut-itineraries-mod .cb-btn--outline{
  background:transparent !important;
  color:var(--navy) !important;
  border:1.5px solid var(--line) !important;
  box-shadow:none;
}
.naut-itineraries-mod a.cb-btn--outline:hover,
.naut-itineraries-mod .cb-btn--outline:hover{
  border-color:var(--navy) !important;
  background:var(--navy) !important;
  color:#ffffff !important;
}

.naut-itineraries-mod .cb-btn--sm{
  padding:9px 16px !important;
  font-size:.82rem !important;
  border-radius:7px !important;
}

/* ============================================================
   ITINERARIES — responsive grid layout
   Mobile: 1 column, Tablet: 2 columns, Desktop: 3 columns
   ============================================================ */
.naut-itineraries-mod .cb-itins{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:18px !important;
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  padding:0 !important;
  box-sizing:border-box;
}
@media(min-width:680px){
  .naut-itineraries-mod .cb-itins{
    grid-template-columns:repeat(2,1fr) !important;
  }
}
@media(min-width:1024px){
  .naut-itineraries-mod .cb-itins{
    grid-template-columns:repeat(3,1fr) !important;
  }
}

.naut-itineraries-mod .cb-itin{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  flex:none !important;
  float:none !important;
  margin:0 !important;
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  background:var(--surface);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
  transition:box-shadow .25s,border-color .25s;
  box-sizing:border-box;
  grid-template-columns:none !important;
  grid-template-rows:none !important;
  flex-direction:column !important;
}
.naut-itineraries-mod .cb-itin > .cb-itin__head{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  flex:none !important;
  float:none !important;
  grid-column:1 / -1 !important;
  box-sizing:border-box;
}
.naut-itineraries-mod .cb-itin:last-child{margin-bottom:0 !important}
.naut-itineraries-mod .cb-itin.is-open{box-shadow:var(--shadow-md);border-color:var(--line)}

/* Head: full-width clickable target */
.naut-itineraries-mod .cb-itin__head{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  text-align:left;
  background:none;
  border:0;
  cursor:pointer;
  padding:20px 22px;
  font-family:inherit;
  color:inherit;
  transition:background .2s;
  box-sizing:border-box;
  grid-template-columns:none !important;
  grid-template-rows:none !important;
  flex-direction:column !important;
  column-count:auto !important;
  columns:auto !important;
}
.naut-itineraries-mod .cb-itin__head > *{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  float:none !important;
  flex:none !important;
  grid-column:1 / -1 !important;
  grid-row:auto !important;
  box-sizing:border-box;
  clear:both;
}
.naut-itineraries-mod .cb-itin__head > .cb-itin__tagrow{
  display:flex !important;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  margin-bottom:12px;
}
.naut-itineraries-mod .cb-itin__head > .cb-itin__title{
  display:flex !important;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  flex-wrap:nowrap;
  margin:0;
}
.naut-itineraries-mod .cb-itin__head > .cb-itin__stats{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:0;
  margin-top:20px;
  border-top:1px solid var(--line-soft);
  padding-top:16px;
}
.naut-itineraries-mod .cb-itin__head > .cb-mini{
  display:flex !important;
  align-items:center;
  gap:0;
  margin-top:18px;
  overflow:hidden;
}
.naut-itineraries-mod .cb-itin__head:hover{background:color-mix(in srgb,var(--sea) 3%,#fff)}
.naut-itineraries-mod .cb-itin.is-open .cb-itin__head{background:color-mix(in srgb,var(--sea) 4%,#fff)}

.naut-itineraries-mod .cb-itin__region{
  font-family:var(--font-mono);
  font-size:.62rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--sea);
  background:color-mix(in srgb,var(--sea) 10%,#fff);
  padding:5px 11px;
  border-radius:999px;
}
.naut-itineraries-mod .cb-itin__dur{
  font-family:var(--font-mono);
  font-size:.62rem;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--muted);
}
.naut-itineraries-mod .cb-itin__title{
  font-family:var(--font-head);
  font-weight:480;
  font-size:1.25rem;
  line-height:1.25;
  color:var(--ink);
  letter-spacing:-.01em;
}
.naut-itineraries-mod .cb-itin__title > span:first-child{
  flex:1;
  min-width:0;
  word-wrap:break-word;
}
.naut-itineraries-mod .cb-itin__chev{
  flex-shrink:0;
  width:32px;
  height:32px;
  border-radius:50%;
  border:1px solid var(--line);
  display:flex !important;
  align-items:center;
  justify-content:center;
  color:var(--navy);
  transition:.3s var(--ease);
}
.naut-itineraries-mod .cb-itin__chev .naut-ico{width:17px;height:17px}
.naut-itineraries-mod .cb-itin.is-open .cb-itin__chev{
  transform:rotate(180deg);
  background:var(--navy);
  color:#fff;
  border-color:var(--navy);
}

.naut-itineraries-mod .cb-itin__stat{
  padding:0 18px;
  border-right:1px solid var(--line-soft);
  min-width:0;
}
.naut-itineraries-mod .cb-itin__stat:first-child{padding-left:0}
.naut-itineraries-mod .cb-itin__stat:last-child{padding-right:0;border-right:0}
.naut-itineraries-mod .cb-itin__stat .v{
  font-family:var(--font-head);
  font-size:1.2rem;
  color:var(--navy);
  line-height:1;
  font-weight:500;
  white-space:nowrap;
}
.naut-itineraries-mod .cb-itin__stat .v .u{
  font-size:.7rem;
  font-family:var(--font-mono);
  color:var(--muted);
  margin-left:3px;
}
.naut-itineraries-mod .cb-itin__stat .k{
  font-family:var(--font-mono);
  font-size:.58rem;
  letter-spacing:.11em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:7px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.naut-itineraries-mod .cb-mini__dot{
  width:9px;
  height:9px;
  border-radius:50%;
  background:var(--sea);
  flex-shrink:0;
  position:relative;
  z-index:2;
}
.naut-itineraries-mod .cb-mini__dot.end{background:var(--accent)}
.naut-itineraries-mod .cb-mini__seg{
  height:2px;
  flex:1;
  background:var(--line);
  min-width:8px;
}

/* Body — collapse/expand grid trick */
.naut-itineraries-mod .cb-itin__body{
  display:grid !important;
  grid-template-rows:0fr !important;
  transition:grid-template-rows .4s var(--ease);
  width:100% !important;
  overflow:hidden;
}
.naut-itineraries-mod .cb-itin.is-open .cb-itin__body{grid-template-rows:1fr !important}
.naut-itineraries-mod .cb-itin__bodyin{
  overflow:hidden;
  width:100%;
  min-height:0;
}

/* ============================================================
   SINGLE-COLUMN TIMELINE
   Cards in the module grid are too narrow for zig-zag — use a
   clean left-aligned vertical timeline like the mobile view.
   ============================================================ */
.naut-itineraries-mod .cb-timeline{
  position:relative;
  padding:20px 22px 20px 22px;
  border-top:1px solid var(--line-soft);
  width:100%;
}
.naut-itineraries-mod .cb-timeline::before{
  content:"";
  position:absolute;
  left:32px;
  top:24px;
  bottom:24px;
  width:2px;
  background:linear-gradient(to bottom,
    transparent 0%,
    rgba(31,122,134,.28) 6%,
    rgba(31,122,134,.28) 94%,
    transparent 100%);
  z-index:0;
}

.naut-itineraries-mod .cb-day{
  position:relative;
  width:100%;
  margin-left:0;
  padding:12px 0 12px 52px;
  z-index:1;
  display:grid;
  grid-template-columns:1fr;
  grid-template-rows:auto auto;
  gap:2px;
  align-items:start;
  min-height:54px;
  box-sizing:border-box;
}
.naut-itineraries-mod .cb-day:nth-child(even){
  margin-left:0;
  padding:12px 0 12px 52px;
}

/* Day number always above the body, both odd and even, left-aligned */
.naut-itineraries-mod .cb-day:nth-child(odd) .cb-day__num,
.naut-itineraries-mod .cb-day:nth-child(even) .cb-day__num{
  grid-column:1;
  grid-row:1;
  text-align:left;
  padding-top:0;
  margin-bottom:0;
}
.naut-itineraries-mod .cb-day:nth-child(odd) .cb-day__body,
.naut-itineraries-mod .cb-day:nth-child(even) .cb-day__body{
  grid-column:1;
  grid-row:2;
  text-align:left;
}
.naut-itineraries-mod .cb-day:nth-child(odd) .cb-day__meta,
.naut-itineraries-mod .cb-day:nth-child(even) .cb-day__meta{
  justify-content:flex-start;
}

.naut-itineraries-mod .cb-day__num{
  font-family:var(--font-mono);
  font-size:.62rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:700;
  white-space:nowrap;
}

.naut-itineraries-mod .cb-day__body{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:4px;
  word-wrap:break-word;
}

/* Day node — sits on the left vertical spine */
.naut-itineraries-mod .cb-day__node,
.naut-itineraries-mod .cb-day:nth-child(odd) .cb-day__node,
.naut-itineraries-mod .cb-day:nth-child(even) .cb-day__node{
  position:absolute;
  top:18px;
  left:27px !important;
  right:auto !important;
  margin-left:0 !important;
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--sea);
  border:0;
  box-shadow:
    0 0 0 3px #ffffff,
    0 0 0 4px rgba(31,122,134,.30);
  z-index:2;
  transform:none;
}
.naut-itineraries-mod .cb-day--port .cb-day__node{
  background:var(--accent);
  box-shadow:
    0 0 0 3px #ffffff,
    0 0 0 4px rgba(217,43,46,.30);
}
.naut-itineraries-mod .cb-day:first-child .cb-day__node,
.naut-itineraries-mod .cb-day:last-child .cb-day__node{
  background:var(--navy);
  box-shadow:
    0 0 0 3px #ffffff,
    0 0 0 4px rgba(21,38,77,.30);
}

.naut-itineraries-mod .cb-day__place{
  font-family:var(--font-head);
  font-weight:500;
  font-size:1.05rem;
  color:var(--ink);
  line-height:1.3;
  letter-spacing:-.005em;
  white-space:normal;
  word-wrap:break-word;
}

.naut-itineraries-mod .cb-day__meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px 12px;
  font-size:.82rem;
  line-height:1.4;
  color:var(--body);
  margin-top:2px;
}

.naut-itineraries-mod .cb-day__nm{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-family:var(--font-mono);
  font-size:.78rem;
  color:var(--sea);
  font-weight:500;
  white-space:nowrap;
}
.naut-itineraries-mod .cb-day__nm .naut-ico{width:16px;height:16px;opacity:.7}

.naut-itineraries-mod .cb-day__note{
  font-size:.82rem;
  color:var(--muted);
  font-style:italic;
  white-space:normal;
}
.naut-itineraries-mod .cb-day__note[href]{
  color:var(--sea);
  text-decoration:none;
  font-style:normal;
  border-bottom:1px dotted currentColor;
  transition:color .2s;
}
.naut-itineraries-mod .cb-day__note[href]:hover{color:var(--accent)}

/* Footer */
.naut-itineraries-mod .cb-itin__foot{
  padding:24px 26px 26px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  border-top:1px solid var(--line-soft);
  width:100%;
  box-sizing:border-box;
}
.naut-itineraries-mod .cb-itin__foot .cb-btn{
  white-space:normal;
  text-align:center;
  flex:0 1 auto;
  min-width:160px;
  max-width:100%;
}

/* ============================================================
   MOBILE — tighter spacing
   (Timeline is already single-column at all sizes, so no need to
   override layout — just tweak spacing and font sizes.)
   ============================================================ */
@media(max-width:768px){
  .naut-itineraries-mod .cb-itin__head{padding:20px 18px !important}
  .naut-itineraries-mod .cb-itin__title{font-size:1.05rem}
  .naut-itineraries-mod .cb-itin__stat{padding:0 10px}
  .naut-itineraries-mod .cb-itin__stat .v{font-size:1.1rem}
  .naut-itineraries-mod .cb-itin__stat .k{font-size:.55rem}

  .naut-itineraries-mod .cb-timeline{padding:14px 18px 18px}
  .naut-itineraries-mod .cb-timeline::before{left:21px}
  .naut-itineraries-mod .cb-day,
  .naut-itineraries-mod .cb-day:nth-child(even){padding:10px 0 10px 44px}
  .naut-itineraries-mod .cb-day__node,
  .naut-itineraries-mod .cb-day:nth-child(odd) .cb-day__node,
  .naut-itineraries-mod .cb-day:nth-child(even) .cb-day__node{
    left:16px !important;
    top:15px;
  }
  .naut-itineraries-mod .cb-day__place{font-size:1rem}

  .naut-itineraries-mod .cb-itin__foot{padding:18px 18px 22px}
  .naut-itineraries-mod .cb-itin__foot .cb-btn{flex:1 1 100%;min-width:0}
}

@media(max-width:480px){
  .naut-itineraries-mod .cb-day__place{font-size:.95rem}
  .naut-itineraries-mod .cb-day__meta{font-size:.75rem}
  .naut-itineraries-mod .cb-day__nm{font-size:.72rem}
}
