
    :root {
      --cbg-primary:     #0B1D3A;
      --cbg-ocean:       #1E63D7;
      --cbg-orange:      #FF6B00;
      --cbg-light-blue:  #F1F6FD;
      --cbg-bg:          #f8f9fb;
      --cbg-text:        #333333;
      --cbg-muted:       #6b7a92;
      --cbg-border:      rgba(255,255,255,0.10);
      --cbg-white:       #ffffff;
      --cbg-card-bg:     rgba(255,255,255,0.04);
      --cbg-radius:      10px;
      --cbg-font-head:   'Playfair Display', Georgia, serif;
      --cbg-font-body:   'DM Sans', sans-serif;
    }
 

    /* ── WAVE DIVIDER ─────────────────────────────────────── */
    .cruisefooter-wave {
      display: block;
      width: 100%;
      line-height: 0;
      overflow: hidden;
    }
    .cruisefooter-wave svg {
      display: block;
      width: 100%;
    }
 
    /* ── NEWSLETTER BAND ──────────────────────────────────── */
    .cruisefooter-newsletter {
      background: linear-gradient(135deg, #1251a8 0%, var(--cbg-ocean) 60%, #0e3d8a 100%);
      padding: 52px 5vw;
    }
    .cruisefooter-newsletter-inner {
      max-width: 1160px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 32px;
      flex-wrap: wrap;
    }
    .cruisefooter-newsletter-copy h3 {
      font-family: var(--cbg-font-head);
      font-size: clamp(1.35rem, 3vw, 1.8rem);
      color: var(--cbg-white);
      margin-bottom: 6px;
    }
    .cruisefooter-newsletter-copy p {
      color: rgba(255,255,255,0.72);
      font-size: 0.93rem;
      font-weight: 300;
    }
    .cruisefooter-newsletter-form {
      display: flex;
      gap: 0;
      border-radius: 50px;
      overflow: hidden;
      box-shadow: 0 8px 32px rgba(0,0,0,0.25);
      flex: 0 1 420px;
      min-width: 260px;
    }
    .cruisefooter-newsletter-form input {
      flex: 1;
      padding: 14px 22px;
      border: none;
      outline: none;
      font-family: var(--cbg-font-body);
      font-size: 0.9rem;
      color: var(--cbg-text);
      background: var(--cbg-white);
    }
    .cruisefooter-newsletter-form button {
      padding: 14px 26px;
      background: var(--cbg-orange);
      color: var(--cbg-white);
      border: none;
      font-family: var(--cbg-font-body);
      font-weight: 600;
      font-size: 0.9rem;
      cursor: pointer;
      white-space: nowrap;
      transition: background 0.2s;
    }
    .cruisefooter-newsletter-form button:hover { background: #e05c00; }
 
    /* ── MAIN FOOTER ──────────────────────────────────────── */
    .cruisefooter-main {
      background: var(--cbg-primary);
      padding: 72px 5vw 0;
      position: relative;
      overflow: hidden;
    }
    /* subtle decorative circle */
    .cruisefooter-main::before {
      content: '';
      position: absolute;
      top: -120px; right: -120px;
      width: 420px; height: 420px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(30,99,215,0.18) 0%, transparent 70%);
      pointer-events: none;
    }
 
    .cruisefooter-grid {
      max-width: 1160px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 2fr 1fr 1fr 1.3fr;
      gap: 48px 40px;
    }
 
    /* Brand column */
    .cruisefooter-brand-logo {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 18px;
    }
    .cruisefooter-brand-logo svg { flex-shrink: 0; }
    .cruisefooter-brand-logo-text { line-height: 1.1; }
    .cruisefooter-brand-logo-text strong {
      display: block;
      font-family: var(--cbg-font-head);
      font-size: 1.12rem;
      color: var(--cbg-white);
      letter-spacing: 0.02em;
    }
    .cruisefooter-brand-logo-text span {
      font-size: 0.72rem;
      color: var(--cbg-orange);
      font-weight: 600;
      letter-spacing: 0.15em;
      text-transform: uppercase;
    }
    .cruisefooter-brand-desc {
      color: rgba(255,255,255,0.55);
      font-size: 0.875rem;
      line-height: 1.75;
      font-weight: 300;
      margin-bottom: 26px;
    }
    .cruisefooter-brand-badges {
      display: flex;
      gap: 10px;
      flex-wrap: wrap;
    }
    .cruisefooter-badge {
      display: flex;
      align-items: center;
      gap: 6px;
      background: var(--cbg-card-bg);
      border: 1px solid var(--cbg-border);
      border-radius: 6px;
      padding: 7px 13px;
      color: rgba(255,255,255,0.75);
      font-size: 0.78rem;
      font-weight: 500;
    }
    .cruisefooter-badge svg { color: var(--cbg-orange); flex-shrink:0; }
 
    /* Column headings */
    .cruisefooter-col-title {
      font-family: var(--cbg-font-body);
      font-weight: 600;
      font-size: 0.82rem;
      letter-spacing: 0.13em;
      text-transform: uppercase;
      color: var(--cbg-orange);
      margin-bottom: 22px;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .cruisefooter-col-title::after {
      content: '';
      flex: 1;
      height: 1px;
      background: rgba(255,102,0,0.25);
    }
 
    /* Nav links */
    .cruisefooter-links { list-style: none; }
    .cruisefooter-links li { margin-bottom: 11px; }
    .cruisefooter-links a {
      color: rgba(255,255,255,0.60);
      text-decoration: none;
      font-size: 0.88rem;
      font-weight: 400;
      transition: color 0.2s, padding-left 0.2s;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .cruisefooter-links a::before {
      content: '›';
      color: var(--cbg-orange);
      font-size: 1rem;
      opacity: 0;
      transition: opacity 0.2s;
    }
    .cruisefooter-links a:hover { color: var(--cbg-white); padding-left: 4px; }
    .cruisefooter-links a:hover::before { opacity: 1; }
 
    /* Contact column */
    .cruisefooter-contact-list { list-style: none; }
    .cruisefooter-contact-list li {
      display: flex;
      gap: 12px;
      margin-bottom: 18px;
      align-items: flex-start;
    }
    .cruisefooter-contact-icon {
      width: 36px; height: 36px;
      border-radius: 8px;
      background: rgba(30,99,215,0.22);
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0;
    }
    .cruisefooter-contact-icon svg { color: var(--cbg-ocean); }
    .cruisefooter-contact-info strong {
      display: block;
      color: var(--cbg-white);
      font-size: 0.85rem;
      font-weight: 600;
      margin-bottom: 2px;
    }
    .cruisefooter-contact-info span {
      color: rgba(255,255,255,0.50);
      font-size: 0.8rem;
    }
 
    /* Social row */
    .cruisefooter-socials {
      display: flex;
      gap: 10px;
      margin-top: 20px;
    }
    .cruisefooter-social-btn {
      width: 38px; height: 38px;
      border-radius: 9px;
      border: 1px solid var(--cbg-border);
      background: var(--cbg-card-bg);
      display: flex; align-items: center; justify-content: center;
      color: rgba(255,255,255,0.55);
      text-decoration: none;
      transition: background 0.2s, color 0.2s, border-color 0.2s, transform 0.2s;
    }
    .cruisefooter-social-btn:hover {
      background: var(--cbg-ocean);
      color: var(--cbg-white);
      border-color: var(--cbg-ocean);
      transform: translateY(-2px);
    }
    .cruisefooter-social-btn.cruisefooter-social-wa:hover {
      background: #25D366;
      border-color: #25D366;
    }
 
    /* ── BOTTOM BAR ───────────────────────────────────────── */
    .cruisefooter-divider {
      max-width: 1160px;
      margin: 56px auto 0;
      height: 1px;
      background: var(--cbg-border);
    }
    .cruisefooter-bottom {
      background: var(--cbg-primary);
      padding: 22px 5vw 28px;
    }
    .cruisefooter-bottom-inner {
      max-width: 1160px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      flex-wrap: wrap;
    }
    .cruisefooter-copyright {
      color: rgba(255,255,255,0.38);
      font-size: 0.8rem;
    }
    .cruisefooter-copyright a {
      color: var(--cbg-orange);
      text-decoration: none;
    }
    .cruisefooter-legal-links {
      display: flex;
      gap: 22px;
      list-style: none;
    }
    .cruisefooter-legal-links a {
      color: rgba(255,255,255,0.38);
      font-size: 0.8rem;
      text-decoration: none;
      transition: color 0.2s;
    }
    .cruisefooter-legal-links a:hover { color: rgba(255,255,255,0.75); }
 
    /* ── RESPONSIVE ───────────────────────────────────────── */
    @media (max-width: 960px) {
      .cruisefooter-grid {
        grid-template-columns: 1fr 1fr;
      }
    }
    @media (max-width: 640px) {
      .cruisefooter-grid {
        grid-template-columns: 1fr;
        gap: 36px;
      }
      .cruisefooter-newsletter-inner { flex-direction: column; align-items: flex-start; }
      .cruisefooter-newsletter-form { flex: 1 1 100%; width: 100%; }
      .cruisefooter-bottom-inner { flex-direction: column; align-items: flex-start; }
      .cruisefooter-legal-links { flex-wrap: wrap; gap: 12px; }
    }