/* ============================================================
   PRIMALI TRAVELS
   main.css — Centralized Design System — Single Source of Truth
   Version: 2.0.0 | www.primalitravels.com

   Brand: Primali Travels — Inbound Destination Management Specialists
   Founded by: D.G. Prabath Induka
   Location: Kirinda-Puhulwella, Matara, Southern Province, Sri Lanka
   Markets: United Kingdom & Germany

   Palette: Indian Ocean Sapphire · Southern Teal · Coral Reef Gold · v2.0
   Theme: PREMIUM — Deep ocean sapphire luxury tourism website
   Inspiration: Southern Sri Lanka coastline, Indian Ocean at Matara,
                Mirissa deep-water horizon, Galle Fort limestone white,
                whale watching dawn, open ocean depth layers,
                sapphire abyss to seafoam — 6°N Indian Ocean colour story

   ⚠️  DO NOT hardcode colors, fonts, or spacing in any other CSS file.
   ⚠️  ALL values in child CSS files must reference variables defined here.
   ⚠️  DO NOT inline CSS or JS in HTML files.
   ⚠️  ALL company data must come from about-us.json — no fallback hardcoding.
   ============================================================ */

/* ============================================================
   1. GOOGLE FONTS IMPORT
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500;1,600&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500&family=Italiana&display=swap');

/* ============================================================
   2. DESIGN TOKENS — BRAND COLORS
   ============================================================ */
:root {

  /* ─── PRIMALI TRAVELS LIGHT PALETTE — SOUTHERN OCEAN WHITE ───────────── */
  /*
     Deep Southern Teal      → Rich deep ocean teal — primary brand anchor
     Indian Ocean Aqua       → Mid ocean brightness — secondary brand
     Coral Reef Gold         → Warm southern gold — CTA and accent
     Ocean White             → Pure light — premium page base
  */

  /* Deep Southern Teal (Primary Brand) — Indian Ocean depth, Mirissa blue-green */
  --color-teal:             #0d5c63;
  --color-teal-deep:        #083d42;
  --color-teal-abyss:       #042428;
  --color-teal-dark:        #0a4a50;
  --color-teal-mid:         #107880;
  --color-teal-light:       #1a9aa5;
  --color-teal-soft:        #4dbac4;
  --color-teal-pale:        #a8dde0;
  --color-teal-ghost:       #e0f5f7;
  --color-teal-border:      rgba(13, 92, 99, 0.20);
  --color-teal-rgb:         13, 92, 99;

  /* ─── INDIAN OCEAN SAPPHIRE — Matara deep water palette ────────── */
  /*
     The open Indian Ocean off Matara at 6°N is not turquoise —
     it is a heavy, ink-sapphire blue with five visible depth layers.
     These tokens map those layers directly to page sections,
     giving the site the gravitas of the actual ocean it represents.

     Sapphire Sky     → horizon at Mirissa dawn — topbar, accent rings
     Sapphire Surface → shallow reef, shallow section tints
     Sapphire Mid     → mid-depth — primary dark section background
     Sapphire Deep    → open ocean — hero overlay, deep sections
     Sapphire Abyss   → trench — footer base, heaviest anchor
  */
  --color-sapphire:           #0d3a5c;   /* mid-depth — primary sapphire */
  --color-sapphire-deep:      #071e3d;   /* deep ocean — dark sections   */
  --color-sapphire-abyss:     #040d1a;   /* abyss — footer anchor        */
  --color-sapphire-mid:       #1a5276;   /* upper-mid — topbar           */
  --color-sapphire-light:     #2980b9;   /* surface shimmer              */
  --color-sapphire-soft:      #5dade2;   /* reef highlight, link hover   */
  --color-sapphire-pale:      #aed6f1;   /* muted text on dark bg        */
  --color-sapphire-ghost:     #e8f4fd;   /* section tint on light bg     */
  --color-sapphire-foam:      #f0f8ff;   /* seafoam — lightest tint      */
  --color-sapphire-border:    rgba(41, 128, 185, 0.22);
  --color-sapphire-rgb:       13, 58, 92;

  /* Sapphire gradients */
  --gradient-sapphire:        linear-gradient(160deg, var(--color-sapphire-abyss) 0%, var(--color-sapphire-deep) 40%, var(--color-sapphire) 75%, var(--color-sapphire-mid) 100%);
  --gradient-sapphire-section:linear-gradient(135deg, var(--color-sapphire-deep) 0%, var(--color-sapphire) 100%);
  --gradient-sapphire-card:   linear-gradient(145deg, var(--color-sapphire-mid) 0%, var(--color-sapphire) 100%);
  --gradient-depth-ocean:     linear-gradient(180deg, var(--color-sapphire-abyss) 0%, var(--color-sapphire-deep) 50%, var(--color-sapphire) 100%);
  --gradient-horizon:         linear-gradient(135deg, var(--color-sapphire-deep) 0%, var(--color-sapphire-mid) 50%, rgba(200, 131, 74, 0.15) 100%);

  /* Sapphire shadows & glows */
  --shadow-sapphire:          0 4px 24px rgba(13, 58, 92, 0.35);
  --shadow-sapphire-lg:       0 12px 48px rgba(4, 13, 26, 0.55);
  --glow-sapphire:            0 8px 44px rgba(13, 58, 92, 0.45), 0 0 24px rgba(41, 128, 185, 0.18);

  /* Indian Ocean Aqua (Secondary) — sea glass, shallow reef light */
  --color-aqua:             #2ab5c0;
  --color-aqua-light:       #4dcdd7;
  --color-aqua-pale:        #a0e4e9;
  --color-aqua-dark:        #1a8f98;
  --color-aqua-ghost:       #e8f9fa;
  --color-aqua-bg:          rgba(42, 181, 192, 0.08);
  --color-aqua-rgb:         42, 181, 192;

  /* Coral Reef Gold (Accent / CTA) — warm southern sun on ocean horizon */
  --color-gold:             #c8834a;
  --color-gold-light:       #df9e6b;
  --color-gold-pale:        #f2c99e;
  --color-gold-dark:        #a6622e;
  --color-gold-darker:      #7d4820;
  --color-gold-glow:        rgba(200, 131, 74, 0.25);
  --color-gold-glow-sm:     rgba(200, 131, 74, 0.12);
  --color-gold-bg:          rgba(200, 131, 74, 0.08);
  --color-gold-bg-hover:    rgba(200, 131, 74, 0.14);
  --color-gold-rgb:         200, 131, 74;

  /* Sea Sage (eco / sustainability accents) */
  --color-sage:             #4a8c72;
  --color-sage-light:       #6aaa8e;
  --color-sage-pale:        rgba(74, 140, 114, 0.15);
  --color-sage-bg:          rgba(74, 140, 114, 0.08);
  --color-sage-dark:        #326050;
  --color-sage-rgb:         74, 140, 114;

  /* ─── OCEAN WHITE / NEUTRAL SCALE ──────────────────────────── */
  --color-white:            #ffffff;
  --color-off-white:        #f7fbfc;
  --color-pearl:            #f0f8f9;
  --color-mist:             #e6f3f5;
  --color-foam:             #daeef1;

  /* Teal-tinted opacity whites */
  --color-white-95:         rgba(255, 255, 255, 0.95);
  --color-white-90:         rgba(255, 255, 255, 0.90);
  --color-white-80:         rgba(255, 255, 255, 0.80);
  --color-white-70:         rgba(255, 255, 255, 0.70);
  --color-white-60:         rgba(255, 255, 255, 0.60);
  --color-white-50:         rgba(255, 255, 255, 0.50);
  --color-white-40:         rgba(255, 255, 255, 0.40);
  --color-white-30:         rgba(255, 255, 255, 0.30);
  --color-white-20:         rgba(255, 255, 255, 0.20);
  --color-white-12:         rgba(255, 255, 255, 0.12);
  --color-white-08:         rgba(255, 255, 255, 0.08);
  --color-white-05:         rgba(255, 255, 255, 0.05);

  /* Gray Scale — light-tuned, cool ocean undertone */
  --color-gray-50:          #f7fbfc;
  --color-gray-100:         #eef6f7;
  --color-gray-200:         #daeef1;
  --color-gray-300:         #b8d8dc;
  --color-gray-400:         #8ab8be;
  --color-gray-500:         #5e9098;
  --color-gray-600:         #3d6b72;
  --color-gray-700:         #254c52;
  --color-gray-800:         #163338;
  --color-gray-900:         #0a1e21;

  /* Dark Overlay Scale — deep teal-based for image overlays */
  --color-dark-90:          rgba(4, 36, 40, 0.92);
  --color-dark-80:          rgba(4, 36, 40, 0.82);
  --color-dark-70:          rgba(4, 36, 40, 0.70);
  --color-dark-50:          rgba(4, 36, 40, 0.50);
  --color-dark-30:          rgba(4, 36, 40, 0.30);

  /* ─── SEMANTIC / STATUS COLORS ───────────────────────────── */
  --color-success:          #2e8b57;
  --color-success-light:    rgba(46, 139, 87, 0.12);
  --color-success-dark:     #1d5c3a;
  --color-success-rgb:      46, 139, 87;

  --color-warning:          #c8834a;
  --color-warning-light:    rgba(200, 131, 74, 0.12);
  --color-warning-dark:     #a6622e;
  --color-warning-rgb:      200, 131, 74;

  --color-error:            #d94f4f;
  --color-error-light:      rgba(217, 79, 79, 0.12);
  --color-error-dark:       #a83030;
  --color-error-text:       #c04040;
  --color-error-rgb:        217, 79, 79;

  --color-info:             #2ab5c0;
  --color-info-light:       rgba(42, 181, 192, 0.12);
  --color-info-dark:        #1a8f98;
  --color-info-rgb:         42, 181, 192;

  /* ─── BACKGROUND TOKENS ─────────────────────────────────── */
  --bg-primary:             #ffffff;
  --bg-secondary:           #f7fbfc;
  --bg-tertiary:            #f0f8f9;
  --bg-dark:                var(--color-teal-deep);
  --bg-overlay:             rgba(4, 36, 40, 0.60);
  --bg-overlay-light:       rgba(4, 36, 40, 0.30);
  --bg-teal-light:          rgba(13, 92, 99, 0.06);
  --bg-gold-light:          rgba(200, 131, 74, 0.07);
  --bg-sage-light:          rgba(74, 140, 114, 0.07);
  --bg-texture-subtle:      linear-gradient(135deg, #f7fbfc 0%, #eef6f7 100%);
  --bg-sapphire:            var(--color-sapphire-deep);
  --bg-sapphire-mid:        var(--color-sapphire);
  --bg-sapphire-abyss:      var(--color-sapphire-abyss);
  --bg-seafoam:             var(--color-sapphire-foam);
  --bg-ocean-tint:          var(--color-sapphire-ghost);

  /* ─── TEXT TOKENS ───────────────────────────────────────── */
  --text-primary:           #0a2d32;
  --text-secondary:         #254c52;
  --text-muted:             #3d6b72;
  --text-light:             #5e9098;
  --text-lighter:           #8ab8be;
  --text-white:             #ffffff;
  --text-gold:              var(--color-gold-dark);
  --text-teal:              var(--color-teal);
  --text-sage:              var(--color-sage);

  /* ─── BORDER TOKENS ─────────────────────────────────────── */
  --border-primary:         #c8e4e7;
  --border-secondary:       #daeef1;
  --border-light:           rgba(13, 92, 99, 0.12);
  --border-gold:            rgba(200, 131, 74, 0.30);
  --border-teal:            var(--color-teal-border);
  --border-focus:           var(--color-teal);

  /* ─── GRADIENTS ─────────────────────────────────────────── */
  /* Primary brand gradient — deep ocean teal */
  --gradient-primary:       linear-gradient(135deg, var(--color-teal-deep) 0%, var(--color-teal-light) 100%);
  /* Coral gold CTA gradient */
  --gradient-gold:          linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-dark) 100%);
  --gradient-gold-hover:    linear-gradient(135deg, var(--color-gold-light) 0%, var(--color-gold) 100%);
  /* Sea sage eco gradient */
  --gradient-sage:          linear-gradient(135deg, var(--color-sage-dark) 0%, var(--color-sage) 100%);
  /* Hero / depth gradients — ocean dawn */
  --gradient-hero:          linear-gradient(160deg, var(--color-teal-abyss) 0%, var(--color-teal-deep) 40%, var(--color-teal) 70%, var(--color-teal-light) 100%);
  --gradient-depth:         linear-gradient(180deg, var(--color-teal-abyss) 0%, var(--color-teal) 100%);
  --gradient-overlay:       linear-gradient(180deg, rgba(4, 36, 40, 0) 0%, rgba(4, 36, 40, 0.85) 100%);
  /* Premium ocean with gold shimmer */
  --gradient-premium:       linear-gradient(135deg, var(--color-teal-deep) 0%, var(--color-teal) 50%, rgba(200, 131, 74, 0.10) 100%);
  /* Card gradient — elevated white surface */
  --gradient-card:          linear-gradient(145deg, #ffffff 0%, #f7fbfc 100%);
  /* Glass effect — ocean frosted */
  --gradient-glass:         linear-gradient(135deg, rgba(255, 255, 255, 0.70) 0%, rgba(255, 255, 255, 0.40) 100%);
  /* Text gradient */
  --gradient-text:          linear-gradient(135deg, var(--color-teal), var(--color-aqua));
  /* Ocean section background */
  --gradient-ocean-section: linear-gradient(135deg, var(--color-teal-ghost) 0%, var(--color-aqua-ghost) 100%);
  /* Button gradient alias */
  --gradient-button:        var(--gradient-gold);

  /* ─── SHADOWS ────────────────────────────────────────────── */
  --shadow-xs:              0 1px 3px rgba(13, 92, 99, 0.10);
  --shadow-sm:              0 2px 6px rgba(13, 92, 99, 0.12), 0 1px 2px rgba(13, 92, 99, 0.08);
  --shadow-md:              0 4px 16px rgba(13, 92, 99, 0.14), 0 2px 6px rgba(13, 92, 99, 0.08);
  --shadow-lg:              0 10px 30px rgba(13, 92, 99, 0.16), 0 4px 10px rgba(13, 92, 99, 0.10);
  --shadow-xl:              0 20px 50px rgba(13, 92, 99, 0.18), 0 8px 20px rgba(13, 92, 99, 0.10);
  --shadow-2xl:             0 30px 70px rgba(13, 92, 99, 0.22);
  --shadow-inner:           inset 0 2px 8px rgba(13, 92, 99, 0.10);
  --shadow-premium:         0 12px 40px rgba(13, 92, 99, 0.16), 0 4px 12px rgba(13, 92, 99, 0.08);

  /* Brand shadows */
  --shadow-gold:            0 4px 24px rgba(200, 131, 74, 0.30);
  --shadow-gold-lg:         0 8px 44px rgba(200, 131, 74, 0.26);
  --shadow-teal:            0 4px 24px rgba(13, 92, 99, 0.22);
  --shadow-sage:            0 4px 20px rgba(74, 140, 114, 0.22);

  /* Glow aliases — soft halos on white */
  --glow-teal:              0 8px 44px rgba(13, 92, 99, 0.22), 0 0 20px rgba(42, 181, 192, 0.12);
  --glow-gold:              0 8px 44px rgba(200, 131, 74, 0.32);
  --glow-sage:              0 8px 40px rgba(74, 140, 114, 0.28);
  --glow-premium:           0 12px 55px rgba(13, 92, 99, 0.18), 0 4px 20px rgba(200, 131, 74, 0.18);
  --glow-soft:              0 4px 20px rgba(13, 92, 99, 0.10);

  /* Luxury shadow */
  --shadow-luxury:          0 20px 65px rgba(13, 92, 99, 0.18), 0 6px 24px rgba(200, 131, 74, 0.14);

  /* ─── TYPOGRAPHY ─────────────────────────────────────────── */
  /*
     Display:  Playfair Display — editorial luxury serif, commanding on white.
               Hero titles, section headings, pull quotes.
               Evokes premium print travel magazines; southern elegance.
     Body:     Plus Jakarta Sans — clean, warm modern sans, exceptional readability.
               Body copy, navigation, UI labels, descriptions.
     Elegant:  Italiana — ultra-refined display italic for special moments.
               Eyebrow quotes, romantic taglines, pull decorations.
  */
  --font-display:         'Playfair Display', 'Georgia', serif;
  --font-primary:         'Plus Jakarta Sans', 'Helvetica Neue', sans-serif;
  --font-elegant:         'Italiana', 'Playfair Display', serif;
  --font-mono:            'Courier New', monospace;

  /* Font-weight tokens */
  --font-weight-light:    300;
  --font-weight-normal:   400;
  --font-weight-medium:   500;
  --font-weight-semibold: 600;
  --font-weight-bold:     700;
  --font-weight-extrabold:800;
  --font-weight-black:    900;

  /* Type scale */
  --text-xs:    0.72rem;
  --text-sm:    0.85rem;
  --text-base:  1rem;
  --text-md:    1.075rem;
  --text-lg:    1.2rem;
  --text-xl:    1.35rem;
  --text-2xl:   1.6rem;
  --text-3xl:   1.95rem;
  --text-4xl:   2.4rem;
  --text-5xl:   3rem;
  --text-6xl:   3.75rem;
  --text-7xl:   4.5rem;
  --text-8xl:   5.5rem;
  --text-9xl:   7rem;

  /* Line heights */
  --leading-none:     1;
  --leading-tight:    1.2;
  --leading-snug:     1.35;
  --leading-normal:   1.55;
  --leading-relaxed:  1.70;
  --leading-loose:    1.90;

  /* Letter spacing */
  --ls-tight:    -0.015em;
  --ls-normal:   0;
  --ls-wide:     0.04em;
  --ls-wider:    0.08em;
  --ls-widest:   0.18em;

  /* ─── SPACING SCALE ──────────────────────────────────────── */
  --spacing-0:     0;
  --spacing-px:    1px;
  --spacing-0-5:   0.125rem;
  --spacing-1:     0.25rem;
  --spacing-1-5:   0.375rem;
  --spacing-2:     0.5rem;
  --spacing-2-5:   0.625rem;
  --spacing-3:     0.75rem;
  --spacing-3-5:   0.875rem;
  --spacing-4:     1rem;
  --spacing-5:     1.25rem;
  --spacing-6:     1.5rem;
  --spacing-7:     1.75rem;
  --spacing-8:     2rem;
  --spacing-9:     2.25rem;
  --spacing-10:    2.5rem;
  --spacing-11:    2.75rem;
  --spacing-12:    3rem;
  --spacing-14:    3.5rem;
  --spacing-16:    4rem;
  --spacing-20:    5rem;
  --spacing-24:    6rem;
  --spacing-28:    7rem;
  --spacing-32:    8rem;
  --spacing-40:    10rem;
  --spacing-48:    12rem;
  --spacing-56:    14rem;
  --spacing-64:    16rem;
  --spacing-72:    18rem;
  --spacing-96:    24rem;
  --spacing-128:   32rem;
  --spacing-144:   36rem;

  /* ─── BORDER RADIUS ──────────────────────────────────────── */
  --radius-none:  0;
  --radius-xs:    2px;
  --radius-sm:    4px;
  --radius-md:    8px;
  --radius-lg:    12px;
  --radius-xl:    16px;
  --radius-2xl:   22px;
  --radius-3xl:   30px;
  --radius-4xl:   40px;
  --radius-full:  9999px;

  /* ─── TRANSITIONS ────────────────────────────────────────── */
  --transition-none:      none;
  --transition-fast:      all 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base:      all 250ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow:      all 400ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-smooth:    all 400ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-premium:   all 500ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --transition-elegant:   all 350ms cubic-bezier(0.165, 0.84, 0.44, 1);
  --transition-bounce:    all 500ms cubic-bezier(0.34, 1.56, 0.64, 1);

  /* ─── Z-INDEX SCALE ──────────────────────────────────────── */
  --z-index-hide:     -1;
  --z-index-0:         0;
  --z-index-auto:      auto;
  --z-index-base:      0;
  --z-index-10:        10;
  --z-index-20:        20;
  --z-index-30:        30;
  --z-index-50:        50;
  --z-index-docked:    10;
  --z-index-dropdown:  100;
  --z-index-sticky:    200;
  --z-index-fixed:     300;
  --z-index-overlay:   400;
  --z-index-modal:     500;
  --z-index-toast:     600;
  --z-index-tooltip:   700;
  --z-index-max:       9999;
  --z-index-maximum:   9999;

  /* ─── LAYOUT ─────────────────────────────────────────────── */
  --container-max:    1200px;
  --container-wide:   1400px;
  --container-narrow: 900px;

  /* Header */
  --header-height-top:      42px;
  --header-height-nav:      72px;
  --header-height-total:    114px;
  --header-height-scrolled: 60px;

  /* WhatsApp widget tokens */
  --wa-green:         #25d366;
  --wa-green-dark:    #1da851;
  --wa-green-light:   #dcf8c6;
  --wa-bubble-bg:     #f0f8f9;
  --wa-fab-size:      60px;
  --wa-popup-width:   320px;
  --wa-popup-height:  420px;

  /* Slide interval */
  --slide-interval:   5000ms;
}

/* ============================================================
   3. BACKWARD COMPATIBILITY BRIDGE
   Maps ALL legacy variable names used across every child CSS file
   to the new Primali Travels brand tokens.
   DO NOT remove these — ALL child CSS files depend on them.
   ============================================================ */
:root {

  /* ── Old "navy" → Deep Southern Teal ──────────────────────── */
  --color-navy:              var(--color-teal);
  --color-navy-deep:         var(--color-teal-deep);
  --color-navy-abyss:        var(--color-teal-abyss);
  --color-navy-card:         #ffffff;
  --color-navy-mid:          var(--color-teal-mid);
  --color-navy-light:        var(--color-teal-light);
  --color-navy-soft:         var(--color-teal-soft);
  --color-navy-border:       var(--color-teal-border);
  --color-navy-rgb:          var(--color-teal-rgb);

  /* ── Old "orange" accent → Coral Reef Gold ──────────────── */
  --primary-orange:          var(--color-gold);
  --secondary-orange:        var(--color-gold-light);
  --accent-orange:           var(--color-gold-pale);
  --dark-orange:             var(--color-gold-dark);
  --light-orange:            var(--color-gold-bg);
  --orange-50:               rgba(200, 131, 74, 0.04);
  --orange-100:              rgba(200, 131, 74, 0.08);
  --orange-200:              rgba(200, 131, 74, 0.15);
  --orange-300:              var(--color-gold-pale);
  --orange-400:              var(--color-gold-light);
  --orange-500:              var(--color-gold);
  --orange-600:              var(--color-gold-dark);
  --orange-700:              var(--color-gold-dark);
  --orange-800:              var(--color-gold-darker);
  --orange-900:              var(--color-gold-darker);

  /* ── Old "teal" scale → Deep Southern Teal tones ──────────── */
  --primary-teal:            var(--color-teal-soft);
  --secondary-teal:          var(--color-teal-light);
  --accent-teal:             var(--color-teal-border);
  --dark-teal:               var(--color-teal-mid);
  --light-teal:              rgba(13, 92, 99, 0.10);
  --teal-50:                 rgba(13, 92, 99, 0.04);
  --teal-100:                rgba(13, 92, 99, 0.08);
  --teal-200:                rgba(13, 92, 99, 0.15);
  --teal-300:                rgba(13, 92, 99, 0.30);
  --teal-400:                var(--color-teal-border);
  --teal-500:                var(--color-teal-soft);
  --teal-600:                var(--color-teal-light);
  --teal-700:                var(--color-teal-mid);
  --teal-800:                var(--color-teal);
  --teal-900:                var(--color-teal-deep);

  /* ── Old "green" → Sea Sage ─────────────────────────────── */
  --color-green:             var(--color-sage);
  --color-green-light:       var(--color-sage-light);
  --color-green-pale:        var(--color-sage-pale);
  --color-green-bg:          var(--color-sage-bg);
  --color-green-dark:        var(--color-sage-dark);
  --color-green-rgb:         var(--color-sage-rgb);

  /* ── Old "red" → error color ─────────────────────────────── */
  --primary-red:             var(--color-error);
  --secondary-red:           #e57373;
  --accent-red:              #ef9a9a;
  --dark-red:                var(--color-error-dark);
  --light-red:               var(--color-error-light);
  --red-50:                  var(--color-error-light);
  --red-100:                 var(--color-error-light);
  --red-200:                 rgba(217, 79, 79, 0.20);
  --red-300:                 rgba(217, 79, 79, 0.40);
  --red-400:                 rgba(217, 79, 79, 0.60);
  --red-500:                 var(--color-error);
  --red-600:                 var(--color-error);
  --red-700:                 var(--color-error-dark);
  --red-800:                 var(--color-error-dark);
  --red-900:                 var(--color-error-dark);

  /* ── Old "dark" → Primary Teal ──────────────────────────── */
  --primary-dark:            var(--color-teal);
  --secondary-dark:          var(--color-teal-soft);
  --charcoal:                var(--color-teal);

  /* ── Old neutral names ────────────────────────────────────── */
  --white:                   #ffffff;
  --off-white:               #f7fbfc;
  --light-gray:              var(--color-gray-50);
  --lighter-gray:            var(--color-gray-100);
  --medium-gray:             var(--color-gray-200);
  --border-gray:             var(--color-gray-300);
  --divider-gray:            var(--color-gray-400);
  --text-gray:               var(--color-gray-600);
  --dark-gray:               var(--color-gray-700);
  --charcoal-gray:           var(--color-gray-800);
  --almost-black:            var(--color-gray-900);
  --light-bg:                var(--bg-secondary);
  --dark-text-muted:         var(--color-gray-600);

  /* ── Old background names ─────────────────────────────────── */
  --bg-orange:               var(--color-gold);
  --bg-teal:                 var(--color-teal);
  --bg-red:                  var(--color-error);
  --bg-orange-light:         var(--color-gold-bg);
  --bg-teal-light:           rgba(13, 92, 99, 0.06);
  --bg-red-light:            var(--color-error-light);
  --bg-overlay-orange:       rgba(200, 131, 74, 0.90);
  --bg-overlay-teal:         rgba(4, 36, 40, 0.88);
  --bg-overlay-red:          rgba(217, 79, 79, 0.90);
  --bg-ocean-light:          rgba(13, 92, 99, 0.06);
  --bg-emerald-light:        var(--color-sage-bg);
  --bg-golden-light:         var(--color-gold-bg);

  /* ── Old text color names ─────────────────────────────────── */
  --text-orange:             var(--color-gold);
  --text-teal:               var(--color-teal);
  --text-red:                var(--color-error);
  --text-dark:               var(--text-primary);
  --text-navy:               var(--color-teal);

  /* ── Old gradient names ───────────────────────────────────── */
  --gradient-orange:         var(--gradient-gold);
  --gradient-teal:           var(--gradient-primary);
  --gradient-red:            linear-gradient(135deg, var(--color-error) 0%, #e57373 100%);
  --gradient-luxury:         linear-gradient(135deg, var(--color-teal) 0%, var(--color-gold) 100%);
  --gradient-emerald:        var(--gradient-sage);
  --gradient-golden:         var(--gradient-gold);
  --gradient-green:          var(--gradient-sage);

  /* ── Ocean-theme name aliases ──────────────────────────────── */
  --primary-ocean-blue:            var(--color-teal);
  --primary-ocean-blue-light:      var(--color-teal-light);
  --primary-ocean-blue-dark:       var(--color-teal-mid);
  --primary-ocean-blue-darker:     var(--color-teal-deep);
  --primary-ocean-blue-rgb:        var(--color-teal-rgb);
  --primary-emerald:               var(--color-sage);
  --primary-emerald-light:         var(--color-sage-light);
  --primary-emerald-dark:          var(--color-sage-dark);
  --primary-emerald-rgb:           var(--color-sage-rgb);
  --accent-golden:                 var(--color-gold);
  --accent-golden-light:           var(--color-gold-light);
  --accent-golden-dark:            var(--color-gold-dark);
  --accent-golden-darker:          var(--color-gold-darker);
  --accent-golden-rgb:             var(--color-gold-rgb);

  /* Gradient aliases */
  --gradient-ocean:          var(--gradient-primary);
  --gradient-depth:          linear-gradient(180deg, var(--color-teal-deep) 0%, var(--color-teal) 100%);

  /* Shadow aliases */
  --shadow-ocean:            var(--shadow-teal);
  --shadow-emerald:          var(--shadow-sage);
  --shadow-golden:           var(--shadow-gold);
  --shadow-orange:           var(--shadow-gold);
  --shadow-teal:             var(--shadow-teal);
  --shadow-red:              0 4px 20px rgba(217, 79, 79, 0.22);
  --shadow-medium:           var(--shadow-md);
  --shadow-large:            var(--shadow-lg);
  --shadow-navy:             var(--shadow-teal);
  --shadow-brand:            var(--shadow-luxury);

  /* Glow aliases */
  --glow-navy:               var(--glow-teal);
  --glow-ocean:              var(--glow-teal);
  --glow-emerald:            var(--glow-sage);
  --glow-golden:             var(--glow-gold);
  --glow-orange:             var(--glow-gold);
  --glow-primary:            var(--glow-premium);

  /* Glass aliases */
  --glass-ocean:             linear-gradient(135deg, rgba(255, 255, 255, 0.75) 0%, rgba(240, 248, 249, 0.55) 100%);
  --glass-emerald:           linear-gradient(135deg, rgba(74, 140, 114, 0.12) 0%, rgba(74, 140, 114, 0.04) 100%);
  --glass-golden:            linear-gradient(135deg, rgba(200, 131, 74, 0.12) 0%, rgba(200, 131, 74, 0.04) 100%);

  /* Old typography name aliases */
  --font-heading:            var(--font-display);
  --font-body:               var(--font-primary);
  --font-serif:              var(--font-display);
  --font-sans:               var(--font-primary);
  --font-luxury:             var(--font-elegant);
  --font-accent:             var(--font-elegant);

  /* Status color aliases */
  --status-success:          var(--color-success);
  --status-success-light:    var(--color-success-light);
  --status-success-dark:     var(--color-success-dark);
  --status-success-rgb:      var(--color-success-rgb);
  --status-warning:          var(--color-warning);
  --status-warning-light:    var(--color-warning-light);
  --status-warning-rgb:      var(--color-warning-rgb);
  --status-error:            var(--color-error);
  --status-error-light:      var(--color-error-light);
  --status-error-dark:       var(--color-error-dark);
  --status-error-rgb:        var(--color-error-rgb);
  --status-info:             var(--color-info);
  --status-info-light:       var(--color-info-light);
  --status-info-rgb:         var(--color-info-rgb);

  /* Legacy booking.css variables */
  --success-color:           var(--color-success);
  --success-light:           var(--color-success-light);
  --error-color:             var(--color-error);
  --error-light:             var(--color-error-light);
  --warning-color:           var(--color-warning);
  --warning-light:           var(--color-warning-light);
  --info-color:              var(--color-info);
  --info-light:              var(--color-info-light);
  --error-background:        var(--color-error-light);

  /* Old elegant-gray names */
  --elegant-gray-50:         var(--color-gray-50);
  --elegant-gray-100:        var(--color-gray-100);
  --elegant-gray-200:        var(--color-gray-200);
  --elegant-gray-300:        var(--color-gray-300);
  --elegant-gray-400:        var(--color-gray-400);
  --elegant-gray-500:        var(--color-gray-500);
  --elegant-gray-600:        var(--color-gray-600);
  --elegant-gray-700:        var(--color-gray-700);
  --elegant-gray-800:        var(--color-gray-800);
  --elegant-gray-900:        var(--color-gray-900);

  /* Old primary / theme naming */
  --primary-white:           #ffffff;
  --white-color:             #ffffff;
  --dark-color:              var(--color-teal);
  --primary-color:           var(--color-teal);
  --primary-color-rgb:       var(--color-teal-rgb);
  --primary-accent:          var(--color-gold);
  --primary-accent-rgb:      var(--color-gold-rgb);
  --primary-blue:            var(--color-teal);
  --primary-blue-light:      var(--color-teal-light);
  --primary-blue-dark:       var(--color-teal-mid);
  --primary-blue-rgb:        var(--color-teal-rgb);
  --secondary-blue:          var(--color-teal-soft);
  --primary-gold:            var(--color-gold);
  --primary-gold-light:      var(--color-gold-light);
  --primary-gold-dark:       var(--color-gold-dark);
  --primary-gold-rgb:        var(--color-gold-rgb);

  /* Misc old names — remapped to white theme */
  --subtle-texture:          #f7fbfc;
  --sophisticated-ivory:     #f0f8f9;
  --elegant-pearl:           #ffffff;
  --luxury-cream:            #f7fbfc;
  --luxury-coral:            var(--color-error);
  --premium-charcoal:        var(--color-gray-700);
  --premium-charcoal-light:  var(--color-gray-600);
  --premium-charcoal-dark:   var(--color-gray-800);
  --bg-texture-subtle:       linear-gradient(135deg, #f7fbfc 0%, #eef6f7 100%);

  /* Border aliases */
  --border-color:            var(--border-primary);
  --muted-text:              var(--text-muted);
  --card-background:         var(--bg-primary);

  /* Border radius aliases */
  --border-radius:           var(--radius-md);
  --border-radius-:          var(--radius-md);
  --border-radius-sm:        var(--radius-sm);
  --border-radius-md:        var(--radius-md);
  --border-radius-lg:        var(--radius-lg);
  --border-radius-xl:        var(--radius-xl);
  --border-radius-2xl:       var(--radius-2xl);
  --border-radius-full:      var(--radius-full);

  /* Font-weight short aliases */
  --fw-light:                var(--font-weight-light);
  --fw-regular:              var(--font-weight-normal);
  --fw-medium:               var(--font-weight-medium);
  --fw-semibold:             var(--font-weight-semibold);
  --fw-bold:                 var(--font-weight-bold);

  /* Old font-size short aliases */
  --fs-xs:    var(--text-xs);
  --fs-sm:    var(--text-sm);
  --fs-base:  var(--text-base);
  --fs-md:    var(--text-md);
  --fs-lg:    var(--text-lg);
  --fs-xl:    var(--text-xl);
  --fs-2xl:   var(--text-2xl);
  --fs-3xl:   var(--text-3xl);
  --fs-4xl:   var(--text-4xl);
  --fs-5xl:   var(--text-5xl);
  --fs-6xl:   var(--text-6xl);

  /* Line-height short aliases */
  --lh-tight:    var(--leading-tight);
  --lh-snug:     var(--leading-snug);
  --lh-normal:   var(--leading-normal);
  --lh-relaxed:  var(--leading-relaxed);
  --lh-loose:    var(--leading-loose);

  /* Letter-spacing short aliases */
  --ls-tight:    -0.015em;
  --ls-normal:   0;
  --ls-wide:     0.04em;
  --ls-wider:    0.08em;
  --ls-widest:   0.18em;

  /* Background texture aliases */
  --bg-texture-ocean: radial-gradient(circle at 25% 25%, rgba(13, 92, 99, 0.05) 0%, transparent 60%),
                      radial-gradient(circle at 75% 75%, rgba(42, 181, 192, 0.04) 0%, transparent 60%),
                      #f7fbfc;
  --bg-texture-waves: repeating-linear-gradient(45deg,
    transparent, transparent 10px,
    rgba(13, 92, 99, 0.018) 10px, rgba(13, 92, 99, 0.018) 20px), #f7fbfc;

  /* Text color extras */
  --text-tertiary:           var(--color-gray-600);
  --light-text-primary:      rgba(10, 45, 50, 0.85);

  /* Mobile responsive tokens */
  --mobile-text-xs:          0.7rem;
  --mobile-text-sm:          0.8rem;
  --mobile-text-base:        0.875rem;
  --mobile-text-lg:          1rem;
  --mobile-text-xl:          1.125rem;
  --mobile-text-2xl:         1.25rem;
  --mobile-spacing-xs:       var(--spacing-2);
  --mobile-spacing-sm:       var(--spacing-3);
  --mobile-spacing-md:       var(--spacing-4);
  --mobile-spacing-lg:       var(--spacing-6);
  --mobile-spacing-xl:       var(--spacing-8);

  /* Touch / accessibility tokens */
  --touch-target-min:        44px;

  /* Transition aliases */
  --transition-smooth:       all 400ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-premium:      all 500ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --transition-elegant:      all 350ms cubic-bezier(0.165, 0.84, 0.44, 1);

  /* Misc */
  --secondary-purple:        #7c3aed;
  --slide-interval:          5000ms;

  /* Border radius base alias */
  --radius-base:             var(--radius-md);

  /* Short space aliases */
  --space-1:   var(--spacing-1);
  --space-2:   var(--spacing-2);
  --space-3:   var(--spacing-3);
  --space-4:   var(--spacing-4);
  --space-5:   var(--spacing-5);
  --space-6:   var(--spacing-6);
  --space-8:   var(--spacing-8);
  --space-10:  var(--spacing-10);
  --space-12:  var(--spacing-12);
  --space-16:  var(--spacing-16);
  --space-20:  var(--spacing-20);
  --space-24:  var(--spacing-24);

  /* Text shadow aliases */
  --text-shadow-soft:    0 1px 4px rgba(4, 36, 40, 0.25);
  --text-shadow-medium:  0 2px 8px rgba(4, 36, 40, 0.40);
  --text-shadow-strong:  0 4px 16px rgba(4, 36, 40, 0.60);

  /* Short z-index aliases */
  --z-below:     -1;
  --z-base:       0;
  --z-raised:     10;
  --z-dropdown:   100;
  --z-sticky:     200;
  --z-fixed:      300;
  --z-modal:      500;
  --z-toast:      600;
}

/* ============================================================
   4. CSS RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
  font-family: var(--font-primary);
  font-size: var(--text-base);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  background-color: var(--bg-primary);
  background-image: radial-gradient(ellipse at 20% 10%, rgba(13, 92, 99, 0.04) 0%, transparent 50%),
                    radial-gradient(ellipse at 80% 90%, rgba(42, 181, 192, 0.03) 0%, transparent 50%);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  letter-spacing: -0.01em;
}

img, video, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: var(--color-teal);
  text-decoration: none;
  transition: color var(--transition-base);
  position: relative;
}

a:hover {
  color: var(--color-teal-dark);
  text-decoration: none;
}

ul, ol { list-style: none; }

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

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
}

/* ============================================================
   5. TYPOGRAPHY SYSTEM
   ============================================================ */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: var(--font-display);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  line-height: var(--leading-tight);
  letter-spacing: -0.01em;
  margin-bottom: var(--spacing-4);
}

h1, .h1 { font-size: clamp(var(--text-3xl), 5vw, var(--text-6xl)); }
h2, .h2 { font-size: clamp(var(--text-2xl), 4vw, var(--text-5xl)); margin-bottom: var(--spacing-5); }
h3, .h3 { font-size: clamp(var(--text-xl), 3vw, var(--text-4xl)); }
h4, .h4 { font-size: clamp(var(--text-lg), 2.5vw, var(--text-3xl)); }
h5, .h5 { font-size: var(--text-xl); }
h6, .h6 { font-size: var(--text-lg); }

p {
  margin-bottom: var(--spacing-4);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
  font-family: var(--font-primary);
  font-weight: var(--font-weight-normal);
  letter-spacing: 0;
  text-transform: none;
}
p:last-child { margin-bottom: 0; }

.lead {
  font-size: var(--text-xl);
  font-weight: var(--font-weight-medium);
  color: var(--text-primary);
  margin-bottom: var(--spacing-6);
  line-height: var(--leading-relaxed);
  text-transform: none;
  letter-spacing: 0;
}

/* Links */
.link-brand {
  color: var(--color-teal);
  font-weight: var(--font-weight-medium);
  position: relative;
}
.link-brand::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--gradient-gold);
  transition: width var(--transition-elegant);
}
.link-brand:hover::after { width: 100%; }

.link-gold { color: var(--color-gold-dark); font-weight: var(--font-weight-semibold); }
.link-gold:hover { color: var(--color-gold); }

.link-ocean  { color: var(--color-teal); font-weight: var(--font-weight-medium); }
.link-ocean:hover { color: var(--color-teal-dark); }
.link-golden { color: var(--color-gold-dark); font-weight: var(--font-weight-semibold); }
.link-golden:hover { color: var(--color-gold); }

/* ============================================================
   6. SECTION HEADERS
   ============================================================ */
.section-header {
  text-align: center;
  margin-bottom: var(--spacing-8);
}

.section-label,
.section-subtitle-above {
  display: inline-block;
  font-family: var(--font-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--color-teal);
  margin-bottom: var(--spacing-3);
  position: relative;
  padding: 0 var(--spacing-6);
}
.section-label::before,
.section-label::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 30px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-teal));
}
.section-label::before { right: 100%; transform: translateX(var(--spacing-6)); }
.section-label::after  { left: 100%; transform: translateX(calc(-1 * var(--spacing-6))); background: linear-gradient(90deg, var(--color-teal), transparent); }

.section-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 3.5vw, var(--text-5xl));
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  line-height: var(--leading-tight);
  margin-bottom: var(--spacing-4);
  letter-spacing: -0.01em;
}
.section-title span,
.section-title em { color: var(--color-teal); font-style: normal; }
.section-title.text-gradient {
  background: linear-gradient(135deg, var(--color-teal), var(--color-aqua));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.section-subtitle {
  font-size: var(--text-lg);
  color: var(--text-muted);
  max-width: 620px;
  margin: 0 auto;
  line-height: var(--leading-relaxed);
  font-family: var(--font-primary);
  text-transform: none;
  letter-spacing: 0;
}

.section-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-3);
  margin: var(--spacing-5) auto;
}
.section-divider span {
  display: block;
  width: 60px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-teal-pale));
}
.section-divider span:last-child { background: linear-gradient(90deg, var(--color-teal-pale), transparent); }
.section-divider i { color: var(--color-teal); font-size: var(--text-sm); }

/* Section spacing classes — tightened for premium rhythm (v2.0) */
.section    { padding: var(--spacing-16) 0; }
.section-sm { padding: var(--spacing-10) 0; }
.section-lg { padding: var(--spacing-20) 0; }
.section-hero         { padding: var(--spacing-32) 0 var(--spacing-20); }
.section-destinations { padding: var(--spacing-16) 0; }
.section-tours        { padding: var(--spacing-20) 0; }
.section-testimonials { padding: var(--spacing-16) 0; }
.section-contact      { padding: var(--spacing-12) 0; }
.section-ocean        { padding: var(--spacing-20) 0; background: var(--bg-texture-subtle); }
.section-emerald      { padding: var(--spacing-16) 0; background: var(--color-sage-bg); }
.section-golden       { padding: var(--spacing-12) 0; background: var(--color-gold-bg); }

/* Light section variants */
.section-dark  { background: var(--color-teal-deep);  color: var(--color-white); }
.section-navy  { background: var(--color-teal-abyss); color: var(--color-white); }
.section-light { background: var(--color-gray-50); }
.section-pearl { background: var(--color-pearl); }
.section-seafoam { background: var(--bg-seafoam); }
.section-ocean-tint { background: var(--bg-ocean-tint); }

/* ─── SAPPHIRE DEPTH SECTIONS — Indian Ocean alternation ─────────────────
   Apply these classes to template section wrappers to create the
   dark/light alternating rhythm. Each maps to a different ocean depth.
   All text inside automatically inherits appropriate colours via
   the child selectors below — no extra classes needed in templates.
   ───────────────────────────────────────────────────────────────────── */

/* Mid-depth — primary dark section (About Sri Lanka, Why Book) */
.section-sapphire {
  padding: var(--spacing-16) 0;
  background: var(--gradient-sapphire-section);
  color: var(--color-white);
  position: relative;
  overflow: hidden;
}
.section-sapphire::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 10% 50%, rgba(41, 128, 185, 0.08) 0%, transparent 70%),
    radial-gradient(ellipse 60% 80% at 90% 20%, rgba(200, 131, 74, 0.04) 0%, transparent 60%);
  pointer-events: none;
}
.section-sapphire .section-label        { color: var(--color-sapphire-soft); }
.section-sapphire .section-label::before,
.section-sapphire .section-label::after { background: linear-gradient(90deg, transparent, var(--color-sapphire-soft)); }
.section-sapphire .section-title        { color: var(--color-white); }
.section-sapphire .section-title span,
.section-sapphire .section-title em     { color: var(--color-gold-light); }
.section-sapphire .section-subtitle     { color: var(--color-sapphire-pale); }
.section-sapphire .section-divider span { background: linear-gradient(90deg, transparent, rgba(174, 214, 241, 0.40)); }
.section-sapphire .section-divider span:last-child { background: linear-gradient(90deg, rgba(174, 214, 241, 0.40), transparent); }
.section-sapphire .section-divider i    { color: var(--color-sapphire-soft); }
.section-sapphire p                     { color: var(--color-sapphire-pale); }
.section-sapphire h3, .section-sapphire h4 { color: var(--color-white); }

/* Deep ocean — testimonials, impact sections */
.section-sapphire-deep {
  padding: var(--spacing-16) 0;
  background: var(--color-sapphire-deep);
  color: var(--color-white);
  position: relative;
  overflow: hidden;
}
.section-sapphire-deep::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 100% 70% at 50% 100%, rgba(13, 58, 92, 0.60) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 10%, rgba(41, 128, 185, 0.06) 0%, transparent 60%);
  pointer-events: none;
}
.section-sapphire-deep .section-label        { color: var(--color-gold-light); }
.section-sapphire-deep .section-title        { color: var(--color-white); }
.section-sapphire-deep .section-title span,
.section-sapphire-deep .section-title em     { color: var(--color-gold-light); }
.section-sapphire-deep .section-subtitle     { color: var(--color-sapphire-pale); }
.section-sapphire-deep p                     { color: var(--color-sapphire-pale); }
.section-sapphire-deep h3, .section-sapphire-deep h4 { color: var(--color-white); }

/* Abyss — footer-adjacent panels, fullwidth CTA strips */
.section-abyss {
  padding: var(--spacing-14) 0;
  background: var(--color-sapphire-abyss);
  color: var(--color-white);
}
.section-abyss .section-title   { color: var(--color-white); }
.section-abyss .section-subtitle{ color: rgba(174, 214, 241, 0.70); }
.section-abyss p                { color: rgba(174, 214, 241, 0.65); }

/* ============================================================
   7. BUTTON SYSTEM
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-3-5) var(--spacing-8);
  border: 1px solid transparent;
  border-radius: var(--radius-xl);
  font-family: var(--font-primary);
  font-size: var(--text-base);
  font-weight: var(--font-weight-bold);
  line-height: var(--leading-tight);
  letter-spacing: 0.04em;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  position: relative;
  overflow: hidden;
  min-height: 48px;
  transition: var(--transition-elegant);
  will-change: transform;
  transform: translateZ(0);
  backface-visibility: hidden;
}
.btn:focus-visible {
  outline: 2px solid var(--color-teal);
  outline-offset: 3px;
  border-radius: var(--radius-md);
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Primary — Coral Reef Gold CTA */
.btn-primary,
.btn-gold,
.btn-cta,
.btn-golden {
  background: var(--gradient-gold);
  border: none;
  color: var(--color-white);
  box-shadow: var(--shadow-gold);
  font-weight: var(--font-weight-bold);
}
.btn-primary:hover,
.btn-gold:hover,
.btn-cta:hover,
.btn-golden:hover {
  background: var(--gradient-gold-hover);
  transform: translateY(-2px);
  box-shadow: var(--shadow-gold-lg);
  color: var(--color-white);
}
.btn-primary:active,
.btn-gold:active { transform: translateY(0); }

/* Secondary — Deep Southern Teal */
.btn-secondary,
.btn-navy,
.btn-ocean,
.btn-blue {
  background: var(--gradient-primary);
  border: none;
  color: var(--color-white);
  box-shadow: var(--shadow-teal);
}
.btn-secondary:hover,
.btn-navy:hover,
.btn-ocean:hover,
.btn-blue:hover {
  background: linear-gradient(135deg, var(--color-teal-mid) 0%, var(--color-teal-light) 100%);
  transform: translateY(-2px);
  box-shadow: var(--glow-teal);
  color: var(--color-white);
}

/* Sage / eco button */
.btn-emerald,
.btn-green,
.btn-teal {
  background: var(--gradient-sage);
  border: none;
  color: var(--color-white);
  box-shadow: var(--shadow-sage);
}
.btn-emerald:hover,
.btn-green:hover,
.btn-teal:hover {
  transform: translateY(-2px);
  box-shadow: var(--glow-sage);
  color: var(--color-white);
}

/* Outline variants */
.btn-outline-primary,
.btn-outline-gold {
  background: transparent;
  border: 2px solid var(--color-gold);
  color: var(--color-gold-dark);
}
.btn-outline-primary:hover,
.btn-outline-gold:hover {
  background: var(--gradient-gold);
  border-color: var(--color-gold);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-gold);
}

.btn-outline-navy,
.btn-outline-ocean,
.btn-outline-primary-navy {
  background: transparent;
  border: 2px solid var(--color-teal);
  color: var(--color-teal);
}
.btn-outline-navy:hover,
.btn-outline-ocean:hover {
  background: var(--gradient-primary);
  border-color: var(--color-teal);
  color: var(--color-white);
  transform: translateY(-2px);
}

.btn-outline-emerald,
.btn-outline-green {
  background: transparent;
  border: 2px solid var(--color-sage);
  color: var(--color-sage);
}
.btn-outline-emerald:hover,
.btn-outline-green:hover {
  background: var(--gradient-sage);
  border-color: var(--color-sage);
  color: var(--color-white);
  transform: translateY(-2px);
}

/* White / Ghost button — light theme version */
.btn-white {
  background: rgba(255, 255, 255, 0.85);
  color: var(--color-teal);
  border: 1px solid var(--color-teal-border);
  box-shadow: var(--shadow-sm);
}
.btn-white:hover {
  background: #ffffff;
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  color: var(--color-teal-dark);
}

.btn-glass {
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.50);
  color: var(--color-teal);
  box-shadow: var(--shadow-sm);
}
.btn-glass:hover {
  background: rgba(255, 255, 255, 0.85);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

/* Dark button — for use on light sections */
.btn-dark {
  background: var(--color-teal-deep);
  border: none;
  color: var(--color-white);
  box-shadow: var(--shadow-teal);
}
.btn-dark:hover {
  background: var(--color-teal);
  transform: translateY(-2px);
  box-shadow: var(--glow-teal);
  color: var(--color-white);
}

/* Button sizes */
.btn-sm { padding: var(--spacing-2) var(--spacing-5); font-size: var(--text-sm); min-height: 36px; }
.btn-lg { padding: var(--spacing-4) var(--spacing-10); font-size: var(--text-lg); min-height: 56px; }
.btn-xl { padding: var(--spacing-5) var(--spacing-12); font-size: var(--text-xl); min-height: 64px; }

/* ============================================================
   8. CARD SYSTEM
   ============================================================ */
.card {
  background: var(--bg-primary);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: var(--transition-elegant);
  box-shadow: var(--shadow-sm);
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-teal-border);
}
.card-body  { padding: var(--spacing-6); }
.card-header { padding: var(--spacing-5) var(--spacing-6); border-bottom: 1px solid var(--border-secondary); }
.card-footer { padding: var(--spacing-5) var(--spacing-6); border-top: 1px solid var(--border-secondary); background: var(--bg-secondary); }

/* Card variants */
.card-ocean {
  background: var(--gradient-ocean-section);
  border-color: var(--color-teal-border);
}
.card-pearl {
  background: var(--color-pearl);
  border-color: var(--border-secondary);
}
.card-gold {
  background: linear-gradient(145deg, #fffbf6 0%, #fff5ea 100%);
  border-color: var(--border-gold);
}
.card-teal {
  background: var(--gradient-primary);
  border: none;
  color: var(--color-white);
  box-shadow: var(--shadow-teal);
}
.card-premium {
  background: #ffffff;
  border: 1px solid var(--color-teal-border);
  box-shadow: var(--shadow-premium);
}

/* Tour / package card */
.card-tour {
  background: var(--bg-primary);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  transition: var(--transition-premium);
  box-shadow: var(--shadow-md);
}
.card-tour:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
  border-color: var(--color-teal-border);
}
.card-tour .card-img { position: relative; overflow: hidden; }
.card-tour .card-img img { transition: transform 0.6s ease; }
.card-tour:hover .card-img img { transform: scale(1.05); }

/* ============================================================
   9. CONTAINER & LAYOUT
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--spacing-6);
}
.container-wide {
  width: 100%;
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--spacing-6);
}
.container-narrow {
  width: 100%;
  max-width: var(--container-narrow);
  margin: 0 auto;
  padding: 0 var(--spacing-6);
}

/* Grid helpers */
.grid { display: grid; gap: var(--spacing-6); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-auto { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

@media (max-width: 992px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .grid-4, .grid-3, .grid-2 { grid-template-columns: 1fr; }
}

/* Flex helpers */
.flex        { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between{ display: flex; align-items: center; justify-content: space-between; }
.flex-col    { display: flex; flex-direction: column; }
.flex-wrap   { flex-wrap: wrap; }
.gap-1  { gap: var(--spacing-1); }
.gap-2  { gap: var(--spacing-2); }
.gap-3  { gap: var(--spacing-3); }
.gap-4  { gap: var(--spacing-4); }
.gap-6  { gap: var(--spacing-6); }
.gap-8  { gap: var(--spacing-8); }

/* ============================================================
   10. NAVIGATION
   ============================================================ */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-index-fixed);
  transition: var(--transition-smooth);
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-secondary);
  box-shadow: var(--shadow-sm);
}
.navbar.scrolled {
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow-md);
}
.navbar-brand {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-teal);
  letter-spacing: -0.02em;
}
.navbar-nav .nav-link {
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--text-secondary);
  padding: var(--spacing-2) var(--spacing-4);
  transition: color var(--transition-fast);
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active { color: var(--color-teal); }

/* Top info bar — sapphire-mid: Indian Ocean mid-depth premium feel */
.navbar-topbar {
  background: var(--color-sapphire-mid);
  color: var(--color-white-80);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  letter-spacing: var(--ls-wide);
  padding: var(--spacing-2) 0;
  height: var(--header-height-top);
  border-bottom: 1px solid rgba(41, 128, 185, 0.18);
}

/* ============================================================
   11. HERO SECTION
   ============================================================ */
.hero-section {
  position: relative;
  overflow: hidden;
  min-height: 100vh;
  display: flex;
  align-items: center;
  margin-top: var(--header-height-total);
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: var(--gradient-overlay);
  z-index: 1;
}
.hero-content {
  position: relative;
  z-index: 2;
}
.hero-eyebrow {
  font-family: var(--font-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--color-aqua-light);
  margin-bottom: var(--spacing-4);
}
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-4xl), 6vw, var(--text-8xl));
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  line-height: var(--leading-tight);
  letter-spacing: -0.02em;
  margin-bottom: var(--spacing-6);
}
.hero-description {
  font-family: var(--font-primary);
  font-size: var(--text-lg);
  font-weight: var(--font-weight-normal);
  color: var(--color-white-80);
  line-height: var(--leading-relaxed);
  max-width: 600px;
  margin-bottom: var(--spacing-8);
}
.hero-actions { display: flex; gap: var(--spacing-4); flex-wrap: wrap; }

/* ============================================================
   12. BADGES & TAGS
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  padding: var(--spacing-1) var(--spacing-3);
  border-radius: var(--radius-full);
  font-family: var(--font-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.badge-teal    { background: var(--bg-teal-light); color: var(--color-teal); border: 1px solid var(--color-teal-border); }
.badge-gold    { background: var(--color-gold-bg);  color: var(--color-gold-dark); border: 1px solid var(--border-gold); }
.badge-sage    { background: var(--color-sage-bg);  color: var(--color-sage-dark); }
.badge-premium { background: var(--gradient-primary); color: var(--color-white); }

/* Market flags */
.badge-uk { background: rgba(0, 0, 128, 0.08); color: #000080; border: 1px solid rgba(0, 0, 128, 0.18); }
.badge-de { background: rgba(60, 60, 60, 0.08); color: #3c3c3c; border: 1px solid rgba(60, 60, 60, 0.18); }

/* ============================================================
   13. FORM SYSTEM
   ============================================================ */
.form-group { margin-bottom: var(--spacing-5); }

.form-label {
  display: block;
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--spacing-2);
  letter-spacing: var(--ls-wide);
}

.form-control,
.form-select {
  display: block;
  width: 100%;
  padding: var(--spacing-3) var(--spacing-4);
  font-family: var(--font-primary);
  font-size: var(--text-base);
  font-weight: var(--font-weight-normal);
  color: var(--text-primary);
  background-color: var(--bg-primary);
  border: 1.5px solid var(--border-primary);
  border-radius: var(--radius-lg);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  outline: none;
}
.form-control:focus,
.form-select:focus {
  border-color: var(--color-teal);
  box-shadow: 0 0 0 3px rgba(13, 92, 99, 0.12);
}
.form-control::placeholder { color: var(--text-lighter); }

textarea.form-control { resize: vertical; min-height: 120px; }

.form-text {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--spacing-1);
}
.form-control:disabled { background-color: var(--bg-secondary); opacity: 0.55; }
.form-label.required::after { content: '*'; color: var(--color-error); margin-left: 4px; }

.form-select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%230d5c63' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 12px center;
  background-repeat: no-repeat;
  background-size: 16px 12px;
  padding-right: 40px;
}

/* ============================================================
   14. GLASS MORPHISM
   ============================================================ */
.glass {
  background: rgba(255, 255, 255, 0.65);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.50);
  box-shadow: var(--shadow-md);
}
.glass-ocean {
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(13, 92, 99, 0.15);
  box-shadow: var(--shadow-teal);
}
.glass-golden {
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(200, 131, 74, 0.20);
}
.glass-teal {
  background: rgba(13, 92, 99, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(42, 181, 192, 0.20);
  color: var(--color-white);
}
/* Legacy alias */
.glass-emerald { background: rgba(74, 140, 114, 0.10); border: 1px solid rgba(74, 140, 114, 0.18); }

/* ============================================================
   15. TESTIMONIALS
   ============================================================ */
.testimonial-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-2xl);
  padding: var(--spacing-8);
  box-shadow: var(--shadow-md);
  transition: var(--transition-elegant);
}
.testimonial-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--color-teal-border);
  transform: translateY(-3px);
}
.testimonial-quote {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--text-primary);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--spacing-6);
}
.testimonial-author-name {
  font-family: var(--font-primary);
  font-weight: var(--font-weight-bold);
  color: var(--text-primary);
  font-size: var(--text-base);
}
.testimonial-author-location {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-top: var(--spacing-1);
}
.testimonial-stars { color: var(--color-gold); font-size: var(--text-sm); margin-bottom: var(--spacing-4); }

/* ============================================================
   16. STATS COUNTER
   ============================================================ */
.stat-item {
  text-align: center;
  padding: var(--spacing-6);
}
.stat-number {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-6xl));
  font-weight: var(--font-weight-bold);
  color: var(--color-teal);
  line-height: 1;
  margin-bottom: var(--spacing-2);
}
.stat-label {
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  color: var(--text-muted);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

/* ============================================================
   17. DESTINATION CARD
   ============================================================ */
.destination-card {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  aspect-ratio: 3/4;
  cursor: pointer;
  box-shadow: var(--shadow-md);
  transition: var(--transition-premium);
}
.destination-card:hover {
  transform: scale(1.02);
  box-shadow: var(--shadow-xl);
}
.destination-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.7s ease;
}
.destination-card:hover img { transform: scale(1.08); }
.destination-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(4, 36, 40, 0.88) 100%);
}
.destination-card-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--spacing-6);
}
.destination-card-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-white);
  margin-bottom: var(--spacing-1);
}
.destination-card-subtitle {
  font-size: var(--text-sm);
  color: var(--color-white-70);
}

/* ============================================================
   18. FEATURE / WHY-US ITEMS
   ============================================================ */
.feature-item {
  display: flex;
  gap: var(--spacing-5);
  align-items: flex-start;
  padding: var(--spacing-6);
  background: var(--bg-primary);
  border: 1px solid var(--border-secondary);
  border-radius: var(--radius-xl);
  transition: var(--transition-elegant);
  box-shadow: var(--shadow-xs);
}
.feature-item:hover {
  border-color: var(--color-teal-border);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.feature-icon {
  width: 52px;
  height: 52px;
  min-width: 52px;
  border-radius: var(--radius-lg);
  background: var(--bg-teal-light);
  color: var(--color-teal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xl);
  transition: var(--transition-elegant);
}
.feature-item:hover .feature-icon {
  background: var(--gradient-primary);
  color: var(--color-white);
}
.feature-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  margin-bottom: var(--spacing-2);
}
.feature-text {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: var(--leading-relaxed);
  margin: 0;
}

/* ============================================================
   19. WHATSAPP WIDGET
   ============================================================ */
.wa-fab {
  position: fixed;
  bottom: var(--spacing-6);
  right: var(--spacing-6);
  width: var(--wa-fab-size);
  height: var(--wa-fab-size);
  background: var(--wa-green);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: var(--z-index-toast);
  box-shadow: 0 4px 20px rgba(37, 211, 102, 0.40);
  transition: var(--transition-elegant);
  color: var(--color-white);
  font-size: var(--text-2xl);
  text-decoration: none;
}
.wa-fab:hover {
  background: var(--wa-green-dark);
  transform: scale(1.08) translateY(-2px);
  box-shadow: 0 8px 30px rgba(37, 211, 102, 0.50);
  color: var(--color-white);
}
.wa-popup {
  position: fixed;
  bottom: calc(var(--wa-fab-size) + var(--spacing-8));
  right: var(--spacing-6);
  width: var(--wa-popup-width);
  background: var(--color-white);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-index-toast);
  overflow: hidden;
  border: 1px solid var(--border-secondary);
}
.wa-popup-header {
  background: var(--gradient-primary);
  padding: var(--spacing-5) var(--spacing-6);
  color: var(--color-white);
}
.wa-popup-body { padding: var(--spacing-5) var(--spacing-6); background: var(--wa-bubble-bg); }
.wa-bubble {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  padding: var(--spacing-3) var(--spacing-4);
  font-size: var(--text-sm);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-secondary);
}

/* ============================================================
   20. FOOTER — sapphire abyss: deepest ocean anchor (v2.0)
   ============================================================ */
.footer {
  background: var(--color-sapphire-abyss);
  color: var(--color-white-80);
  padding: var(--spacing-16) 0 var(--spacing-8);
  position: relative;
}
/* Gold accent line — sunrise on the horizon */
.footer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-gold);
}
/* Subtle depth texture */
.footer::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 50% at 20% 80%, rgba(13, 58, 92, 0.35) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 20%, rgba(41, 128, 185, 0.06) 0%, transparent 60%);
  pointer-events: none;
}
.footer > * { position: relative; z-index: 1; }
.footer-brand {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  margin-bottom: var(--spacing-4);
}
.footer-tagline {
  font-size: var(--text-sm);
  color: var(--color-sapphire-pale);
  margin-bottom: var(--spacing-6);
}
.footer-heading {
  font-family: var(--font-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--color-gold-light);
  margin-bottom: var(--spacing-5);
}
.footer-link {
  font-size: var(--text-sm);
  color: var(--color-sapphire-pale);
  display: block;
  padding: var(--spacing-1) 0;
  transition: color var(--transition-fast);
}
.footer-link:hover { color: var(--color-white); }
.footer-divider {
  border: none;
  height: 1px;
  background: rgba(174, 214, 241, 0.10);
  margin: var(--spacing-8) 0;
}
.footer-bottom {
  font-size: var(--text-xs);
  color: rgba(174, 214, 241, 0.40);
  padding-top: var(--spacing-6);
  border-top: 1px solid rgba(174, 214, 241, 0.08);
}

/* ============================================================
   21. UTILITY CLASSES
   ============================================================ */

/* Text colors */
.text-primary   { color: var(--text-primary) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-muted     { color: var(--text-muted) !important; }
.text-white     { color: var(--color-white) !important; }
.text-teal      { color: var(--color-teal) !important; }
.text-gold      { color: var(--color-gold-dark) !important; }
.text-sage      { color: var(--color-sage) !important; }
.text-ocean     { color: var(--color-teal) !important; }
.text-golden    { color: var(--color-gold-dark) !important; }
.text-navy      { color: var(--color-teal-deep) !important; }

/* Background colors */
.bg-white     { background-color: var(--color-white) !important; }
.bg-pearl     { background-color: var(--color-pearl) !important; }
.bg-teal      { background-color: var(--color-teal) !important; }
.bg-teal-deep { background-color: var(--color-teal-deep) !important; }
.bg-gold      { background-color: var(--color-gold) !important; }
.bg-primary   { background-color: var(--bg-primary) !important; }
.bg-secondary { background-color: var(--bg-secondary) !important; }
.bg-mist      { background-color: var(--color-mist) !important; }
.bg-ocean     { background: var(--gradient-primary) !important; }

/* Border utilities */
.border-teal  { border-color: var(--color-teal-border) !important; }
.border-gold  { border-color: var(--border-gold) !important; }
.border-light { border-color: var(--border-secondary) !important; }

/* Text align */
.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

/* Font */
.font-display { font-family: var(--font-display) !important; }
.font-primary { font-family: var(--font-primary) !important; }
.font-elegant { font-family: var(--font-elegant) !important; }
.font-serif   { font-family: var(--font-display) !important; }

/* Weight */
.fw-light     { font-weight: var(--font-weight-light) !important; }
.fw-normal    { font-weight: var(--font-weight-normal) !important; }
.fw-medium    { font-weight: var(--font-weight-medium) !important; }
.fw-semibold  { font-weight: var(--font-weight-semibold) !important; }
.fw-bold      { font-weight: var(--font-weight-bold) !important; }

/* Display */
.d-none         { display: none !important; }
.d-block        { display: block !important; }
.d-flex         { display: flex !important; }
.d-grid         { display: grid !important; }
.d-inline-flex  { display: inline-flex !important; }

/* Spacing margin */
.mt-0  { margin-top: var(--spacing-0)  !important; }
.mt-2  { margin-top: var(--spacing-2)  !important; }
.mt-4  { margin-top: var(--spacing-4)  !important; }
.mt-6  { margin-top: var(--spacing-6)  !important; }
.mt-8  { margin-top: var(--spacing-8)  !important; }
.mt-12 { margin-top: var(--spacing-12) !important; }
.mt-16 { margin-top: var(--spacing-16) !important; }

.mb-0  { margin-bottom: var(--spacing-0)  !important; }
.mb-2  { margin-bottom: var(--spacing-2)  !important; }
.mb-4  { margin-bottom: var(--spacing-4)  !important; }
.mb-6  { margin-bottom: var(--spacing-6)  !important; }
.mb-8  { margin-bottom: var(--spacing-8)  !important; }
.mb-12 { margin-bottom: var(--spacing-12) !important; }
.mb-16 { margin-bottom: var(--spacing-16) !important; }

/* Spacing padding */
.pt-0  { padding-top: var(--spacing-0)  !important; }
.pt-4  { padding-top: var(--spacing-4)  !important; }
.pt-8  { padding-top: var(--spacing-8)  !important; }
.pt-12 { padding-top: var(--spacing-12) !important; }
.pt-16 { padding-top: var(--spacing-16) !important; }
.pb-0  { padding-bottom: var(--spacing-0)  !important; }
.pb-4  { padding-bottom: var(--spacing-4)  !important; }
.pb-8  { padding-bottom: var(--spacing-8)  !important; }
.pb-12 { padding-bottom: var(--spacing-12) !important; }
.pb-16 { padding-bottom: var(--spacing-16) !important; }

/* Radius */
.rounded-sm   { border-radius: var(--radius-sm)   !important; }
.rounded-md   { border-radius: var(--radius-md)   !important; }
.rounded-lg   { border-radius: var(--radius-lg)   !important; }
.rounded-xl   { border-radius: var(--radius-xl)   !important; }
.rounded-2xl  { border-radius: var(--radius-2xl)  !important; }
.rounded-full { border-radius: var(--radius-full) !important; }

/* Width */
.w-full  { width: 100% !important; }
.w-auto  { width: auto !important; }
.mw-100  { max-width: 100% !important; }

/* Position */
.position-relative { position: relative; }
.position-absolute { position: absolute; }
.position-fixed    { position: fixed; }

/* Overflow */
.overflow-hidden   { overflow: hidden; }

/* Hover interactions */
.hover-lift { transition: var(--transition-elegant); }
.hover-lift:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.hover-scale { transition: var(--transition-elegant); }
.hover-scale:hover { transform: scale(1.03); }

/* ============================================================
   22. PRICE & PACKAGE DISPLAY
   ============================================================ */
.price-from {
  font-family: var(--font-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  color: var(--text-muted);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.price-amount {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-teal);
  line-height: 1;
}
.price-currency {
  font-size: var(--text-lg);
  vertical-align: super;
  font-weight: var(--font-weight-semibold);
}
.price-per-person {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

/* Package duration badge */
.duration-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  background: var(--bg-teal-light);
  color: var(--color-teal);
  border: 1px solid var(--color-teal-border);
  border-radius: var(--radius-full);
  padding: var(--spacing-1) var(--spacing-3);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--ls-wide);
}

/* Market tag */
.market-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  background: var(--color-gold-bg);
  color: var(--color-gold-dark);
  border: 1px solid var(--border-gold);
  border-radius: var(--radius-full);
  padding: var(--spacing-1) var(--spacing-3);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

/* ============================================================
   23. BREADCRUMB
   ============================================================ */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
  list-style: none;
  flex-wrap: wrap;
}
.breadcrumb-item {
  font-size: var(--text-sm);
  color: var(--text-muted);
}
.breadcrumb-item a { color: var(--color-teal); }
.breadcrumb-item a:hover { color: var(--color-teal-dark); }
.breadcrumb-item + .breadcrumb-item::before {
  content: '/';
  color: var(--text-lighter);
  margin-right: var(--spacing-2);
}
.breadcrumb-item.active { color: var(--text-primary); font-weight: var(--font-weight-medium); }

/* ============================================================
   24. DIVIDERS & DECORATORS
   ============================================================ */
.divider {
  border: none;
  height: 1px;
  background: var(--border-secondary);
  margin: var(--spacing-8) 0;
}
.divider-teal {
  border: none;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-teal), transparent);
  margin: var(--spacing-8) 0;
}
.divider-gold {
  border: none;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-gold), transparent);
  margin: var(--spacing-8) 0;
}

/* ============================================================
   25. KEYFRAME ANIMATIONS
   ============================================================ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInScale {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-30px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(30px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes waveMotion {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.60; }
}
@keyframes bounce {
  0%, 100% { transform: translateY(0); animation-timing-function: cubic-bezier(0.8, 0, 1, 1); }
  50%       { transform: translateY(-12px); animation-timing-function: cubic-bezier(0, 0, 0.2, 1); }
}
@keyframes rotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-10px); }
}
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes pulse-teal {
  0%, 100% { box-shadow: 0 0 0 0 rgba(13, 92, 99, 0.30); }
  50%       { box-shadow: 0 0 0 10px rgba(13, 92, 99, 0); }
}

/* Animation utility classes */
.animate-fade-up    { animation: fadeInUp 0.6s ease-out; }
.animate-fade-scale { animation: fadeInScale 0.6s ease-out; }
.animate-slide-left { animation: slideInLeft 0.7s ease-out; }
.animate-slide-right{ animation: slideInRight 0.7s ease-out; }
.animate-wave       { animation: waveMotion 4s ease-in-out infinite; }
.animate-pulse      { animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite; }
.animate-bounce     { animation: bounce 1s infinite; }
.animate-rotate     { animation: rotate 2s linear infinite; }
.animate-float      { animation: float 3s ease-in-out infinite; }
.animate-fadeInUp   { animation: fadeInUp 0.6s ease forwards; }
.animate-fadeIn     { animation: fadeInScale 0.4s ease forwards; }
.animate-pulse-teal { animation: pulse-teal 2s ease infinite; }
.animate-shimmer {
  background: linear-gradient(90deg, var(--color-gray-100) 25%, var(--color-gray-200) 50%, var(--color-gray-100) 75%);
  background-size: 200% 100%;
  animation: shimmer 2s infinite;
}

/* ============================================================
   26. PERFORMANCE OPTIMIZATIONS
   ============================================================ */
img { max-width: 100%; height: auto; }

.btn, .card, .animate-wave, .animate-fade-up,
.animate-slide-left, .animate-slide-right, .animate-fade-scale,
.hover-lift, .hover-scale {
  will-change: transform;
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* ============================================================
   27. SCROLLBAR
   ============================================================ */
::-webkit-scrollbar       { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--color-gray-50); border-radius: var(--radius-full); }
::-webkit-scrollbar-thumb { background: var(--color-teal-pale); border-radius: var(--radius-full); }
::-webkit-scrollbar-thumb:hover { background: var(--color-teal); }

/* ============================================================
   28. SELECTION & FOCUS
   ============================================================ */
::selection      { background: rgba(13, 92, 99, 0.18); color: var(--color-teal-deep); }
::-moz-selection { background: rgba(13, 92, 99, 0.18); color: var(--color-teal-deep); }

:focus-visible {
  outline: 2px solid var(--color-teal);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* ============================================================
   29. RESPONSIVE BREAKPOINTS
   ============================================================ */
@media (max-width: 1200px) {
  :root { --container-max: 100%; }
  :root {
    --text-3xl: 1.6rem;
    --text-4xl: 2rem;
    --text-5xl: 2.5rem;
  }
}

@media (max-width: 992px) {
  :root {
    --text-2xl: 1.3rem;
    --text-3xl: 1.5rem;
    --text-4xl: 1.9rem;
    --text-5xl: 2.2rem;
  }
  .section    { padding: var(--spacing-16) 0; }
  .section-lg { padding: var(--spacing-20) 0; }
  .btn { padding: var(--spacing-3) var(--spacing-6); }
  .card-body  { padding: var(--spacing-5); }
}

@media (max-width: 768px) {
  :root {
    --header-height-top:   0px;
    --header-height-nav:   60px;
    --header-height-total: 60px;
    --text-xl:   1.15rem;
    --text-2xl:  1.3rem;
    --text-3xl:  1.5rem;
    --text-4xl:  1.7rem;
    --text-5xl:  2rem;
  }
  .container  { padding: 0 var(--spacing-4); }
  .section    { padding: var(--spacing-12) 0; }
  .section-sm { padding: var(--spacing-8) 0; }
  .btn {
    padding: var(--spacing-3) var(--spacing-5);
    font-size: var(--text-sm);
    width: 100%;
    margin-bottom: var(--spacing-2);
  }
  .card { margin-bottom: var(--spacing-4); }
  .card-body { padding: var(--spacing-4); }
}

@media (max-width: 480px) {
  :root {
    --text-lg:   1.05rem;
    --text-xl:   1.15rem;
    --text-2xl:  1.25rem;
    --text-3xl:  1.45rem;
    --text-4xl:  1.65rem;
  }
  .container { padding: 0 var(--spacing-3); }
  .btn-lg { padding: var(--spacing-3) var(--spacing-6); font-size: var(--text-sm); }
}

/* ============================================================
   30. ACCESSIBILITY
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

@media (prefers-contrast: high) {
  .card      { border: 2px solid var(--color-teal) !important; }
  .form-control, .form-select { border: 2px solid var(--border-primary) !important; }
  .btn       { border: 2px solid currentColor !important; }
}

/* ============================================================
   31. DARK MODE OVERRIDE (white-first theme)
   If user explicitly prefers dark mode, apply minimal overrides.
   Core brand identity stays light — only base surfaces adapt.
   ============================================================ */
@media (prefers-color-scheme: dark) {
  :root {
    /* Override only if truly needed — white/light is the Primali default */
    --bg-primary:       #f7fbfc;
    --bg-secondary:     #eef6f7;
    --bg-tertiary:      #e6f3f5;
    --text-primary:     #0a2d32;
    --text-secondary:   #254c52;
    --border-primary:   #c8e4e7;
    --border-secondary: #daeef1;
  }
}

/* ============================================================
   32. PRINT STYLES
   ============================================================ */
@media print {
  *, *::before, *::after {
    text-shadow: none !important;
    box-shadow: none !important;
  }
  body { font-size: 12pt; color: #000 !important; background: #fff !important; }
  .btn {
    border: 2px solid #000 !important;
    background: transparent !important;
    color: #000 !important;
  }
  .card { border: 1px solid #ccc !important; break-inside: avoid; }
  h1, h2, h3, h4, h5, h6 { color: #000 !important; break-after: avoid; background: none !important; -webkit-text-fill-color: initial !important; }
  .no-print, .d-print-none { display: none !important; }
  .d-print-block { display: block !important; }
}

/* ============================================================
   8b. BUTTON EXTRAS (premium shimmer + ripple)
   ============================================================ */

/* Premium shimmer button */
.btn-premium {
  background: var(--gradient-premium);
  border: none;
  color: var(--color-white);
  font-weight: var(--font-weight-bold);
}
.btn-premium::before {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.22), transparent);
  transition: left 0.6s ease;
}
.btn-premium:hover::before { left: 100%; }
.btn-premium:hover {
  transform: translateY(-2px) scale(1.01);
  box-shadow: var(--glow-premium);
  color: var(--color-white);
}

/* Ripple effect */
.btn-ripple { position: relative; overflow: hidden; }
.btn-ripple::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 0; height: 0;
  border-radius: 50%;
  background: rgba(255,255,255,0.35);
  transform: translate(-50%, -50%);
  transition: width 0.5s, height 0.5s;
}
.btn-ripple:active::after { width: 300px; height: 300px; }

/* ============================================================
   9b. CARD EXTRAS (title, text, dark, glass, golden, emerald)
   ============================================================ */
.card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
}
.card-title {
  margin-bottom: var(--spacing-3);
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--text-primary);
  letter-spacing: -0.01em;
}
.card-text { color: var(--text-secondary); line-height: var(--leading-relaxed); }

.card-dark {
  background: var(--color-teal-deep);
  border: 1px solid var(--color-teal-border);
  border-radius: var(--radius-xl);
  color: var(--color-white);
  transition: var(--transition-slow);
}
.card-dark:hover { border-color: var(--color-gold); box-shadow: var(--shadow-gold); }
.card-dark .card-title { color: var(--color-white); }
.card-dark .card-text  { color: var(--color-white-80); }

.card-golden {
  background: var(--gradient-gold);
  border: 2px solid var(--color-gold);
  color: var(--color-white);
  box-shadow: var(--shadow-gold);
}
.card-golden .card-title { color: var(--color-white); }
.card-golden .card-text  { color: rgba(255,255,255,0.9); }
.card-golden:hover { transform: translateY(-8px) scale(1.01); box-shadow: var(--glow-gold); }

.card-emerald {
  background: var(--gradient-sage);
  border: 2px solid var(--color-sage);
  color: var(--color-white);
  box-shadow: var(--shadow-sage);
}
.card-emerald .card-title { color: var(--color-white); }
.card-emerald .card-text  { color: rgba(255,255,255,0.9); }
.card-emerald:hover { transform: translateY(-8px) scale(1.01); box-shadow: var(--glow-sage); }

.card-glass {
  background: var(--gradient-glass);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.50);
  box-shadow: var(--shadow-lg);
}
.card-glass:hover { transform: translateY(-6px); box-shadow: var(--shadow-2xl); }

/* ============================================================
   9c. CONTAINER EXTRAS
   ============================================================ */
.container-ocean   { max-width: 1400px; margin: 0 auto; padding: 0 var(--spacing-6); }
.container-premium { max-width: 1600px; margin: 0 auto; padding: 0 var(--spacing-8); }
.container-content { max-width: 1200px; margin: 0 auto; padding: 0 var(--spacing-5); }

.flex-gap-2 { gap: var(--spacing-2); }
.flex-gap-3 { gap: var(--spacing-3); }
.flex-gap-4 { gap: var(--spacing-4); }

/* ============================================================
   12. ALERT SYSTEM
   ============================================================ */
.alert {
  position: relative;
  padding: var(--spacing-4) var(--spacing-6);
  margin-bottom: var(--spacing-4);
  border: 1px solid transparent;
  border-radius: var(--radius-xl);
  border-left: 4px solid;
}
.alert-success {
  color: var(--color-success-dark);
  background: linear-gradient(135deg, rgba(46, 139, 87, 0.10) 0%, rgba(46, 139, 87, 0.04) 100%);
  border-color: rgba(46, 139, 87, 0.18);
  border-left-color: var(--color-success);
}
.alert-warning {
  color: var(--color-gold-dark);
  background: linear-gradient(135deg, rgba(200, 131, 74, 0.10) 0%, rgba(200, 131, 74, 0.04) 100%);
  border-color: rgba(200, 131, 74, 0.18);
  border-left-color: var(--color-gold);
}
.alert-danger,
.alert-error {
  color: var(--color-error-dark);
  background: linear-gradient(135deg, rgba(217, 79, 79, 0.10) 0%, rgba(217, 79, 79, 0.04) 100%);
  border-color: rgba(217, 79, 79, 0.18);
  border-left-color: var(--color-error);
}
.alert-info {
  color: var(--color-info-dark);
  background: linear-gradient(135deg, rgba(42, 181, 192, 0.10) 0%, rgba(42, 181, 192, 0.04) 100%);
  border-color: rgba(42, 181, 192, 0.18);
  border-left-color: var(--color-info);
}

/* ============================================================
   13. DECORATIVE ELEMENTS
   ============================================================ */
.gold-line { width: 60px; height: 2px; background: linear-gradient(90deg, var(--color-gold-dark), var(--color-gold-light)); border-radius: var(--radius-full); }
.gold-line-center { margin: 0 auto; }

.gold-diamond {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-2);
  color: var(--color-gold);
}
.gold-diamond::before, .gold-diamond::after { content: '◆'; font-size: 6px; opacity: 0.6; }

.divider-ocean,
.divider-brand {
  height: 2px;
  background: var(--gradient-primary);
  margin: var(--spacing-8) 0;
  border: none;
  border-radius: var(--radius-full);
  position: relative;
}
.divider-ocean::before, .divider-brand::before {
  content: '';
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 60px; height: 6px;
  background: var(--gradient-gold);
  border-radius: var(--radius-full);
}
.divider-waves {
  height: 4px;
  background: var(--gradient-premium);
  margin: var(--spacing-6) 0;
  border: none;
  border-radius: var(--radius-full);
  animation: waveMotion 6s ease-in-out infinite;
}

.text-shimmer {
  background: linear-gradient(90deg, var(--color-gold-dark) 0%, var(--color-gold-pale) 25%, var(--color-gold) 50%, var(--color-gold-pale) 75%, var(--color-gold-dark) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer 3s linear infinite;
}

/* ============================================================
   14. NAVIGATION EXTRAS
   ============================================================ */
.navbar-ocean {
  background: rgba(255, 255, 255, 0.80);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-secondary);
  transition: var(--transition-elegant);
}

/* ============================================================
   15. HERO EXTRAS
   ============================================================ */
.hero-ocean {
  background: var(--gradient-hero);
  color: var(--color-white);
  padding: var(--spacing-32) 0;
  position: relative;
  overflow: hidden;
}
.hero-ocean::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.018'%3E%3Ccircle cx='30' cy='30' r='4'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

/* ============================================================
   16. FOOTER EXTRAS
   ============================================================ */
.footer-ocean {
  background: var(--gradient-depth);
  color: var(--color-white);
  padding: var(--spacing-16) 0 var(--spacing-8);
  position: relative;
}
.footer-ocean::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gradient-gold);
}

/* ============================================================
   17. PREMIUM COMPONENTS
   ============================================================ */

/* Progress bars */
.progress-modern {
  height: var(--spacing-3);
  background: var(--color-gray-200);
  border-radius: var(--radius-full);
  overflow: hidden;
  box-shadow: var(--shadow-inner);
}
.progress-bar-ocean,
.progress-bar-brand {
  height: 100%;
  background: var(--gradient-primary);
  border-radius: var(--radius-full);
  transition: width var(--transition-smooth);
  position: relative;
  overflow: hidden;
}
.progress-bar-gold  { background: var(--gradient-gold); }
.progress-bar-green { background: var(--gradient-sage); }
.progress-bar-ocean::before {
  content: '';
  position: absolute; top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.30), transparent);
  animation: shimmer 2s infinite;
}

/* Tooltips */
.tooltip-ocean { position: relative; cursor: help; }
.tooltip-ocean::before {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 100%; left: 50%;
  transform: translateX(-50%);
  background: var(--color-teal-deep);
  color: var(--color-white);
  padding: var(--spacing-2) var(--spacing-3);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  white-space: nowrap;
  opacity: 0; visibility: hidden;
  transition: var(--transition-elegant);
  z-index: var(--z-index-tooltip);
  box-shadow: var(--shadow-lg);
}
.tooltip-ocean::after {
  content: '';
  position: absolute;
  bottom: 100%; left: 50%;
  transform: translateX(-50%) translateY(1px);
  border: 4px solid transparent;
  border-top-color: var(--color-teal-deep);
  opacity: 0; visibility: hidden;
  transition: var(--transition-elegant);
}
.tooltip-ocean:hover::before,
.tooltip-ocean:hover::after {
  opacity: 1; visibility: visible;
  transform: translateX(-50%) translateY(-8px);
}

/* Modals */
.modal-ocean .modal-content {
  border: none;
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-2xl);
  background: var(--bg-primary);
  border: 1px solid var(--border-secondary);
  overflow: hidden;
}
.modal-ocean .modal-header {
  background: var(--gradient-primary);
  color: var(--color-white);
  border-bottom: none;
  padding: var(--spacing-6);
}
.modal-ocean .modal-title {
  font-family: var(--font-display);
  font-weight: var(--font-weight-semibold);
  font-size: var(--text-2xl);
}
.modal-ocean .modal-body { padding: var(--spacing-8); }
.modal-ocean .modal-footer {
  background: var(--bg-secondary);
  border-top: 1px solid var(--border-secondary);
  padding: var(--spacing-6);
}

/* Badge extras (premium section) */
.badge-ocean   { background: var(--gradient-primary); color: var(--color-white); }
.badge-emerald { background: var(--gradient-sage); color: var(--color-white); }
.badge-navy    { background: var(--color-teal-deep); color: var(--color-white); }
.badge-glass {
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(8px);
  color: var(--text-primary);
  border: 1px solid var(--border-secondary);
}

/* ============================================================
   18. TOURISM-SPECIFIC COMPONENTS
   ============================================================ */

/* Destination Cards (full version with overlay) */
.destination-card .card-image { position: relative; overflow: hidden; height: 250px; }
.destination-card .card-image img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition-smooth); }
.destination-card:hover .card-image img { transform: scale(1.10); }
.destination-card .card-overlay {
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background: var(--gradient-overlay);
  opacity: 0; transition: var(--transition-elegant);
  display: flex; align-items: center; justify-content: center;
}
.destination-card:hover .card-overlay { opacity: 1; }
.destination-card .price-badge {
  position: absolute; top: var(--spacing-4); right: var(--spacing-4);
  background: var(--gradient-gold);
  color: var(--color-white);
  padding: var(--spacing-2) var(--spacing-4);
  border-radius: var(--radius-full);
  font-weight: var(--font-weight-bold);
  font-size: var(--text-sm);
  box-shadow: var(--shadow-gold);
}

/* Tour Package Cards */
.tour-package {
  background: var(--bg-primary);
  border-radius: var(--radius-3xl);
  padding: var(--spacing-8);
  box-shadow: var(--shadow-premium);
  transition: var(--transition-premium);
  border: 2px solid transparent;
  position: relative;
  overflow: hidden;
}
.tour-package::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: var(--gradient-gold);
}
.tour-package:hover {
  transform: translateY(-6px);
  box-shadow: var(--glow-premium);
  border-color: var(--border-gold);
}
.tour-package.featured { border-color: var(--color-gold); box-shadow: var(--shadow-gold); }
.tour-package.featured::before { background: var(--gradient-gold); }

/* Gallery Grid */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--spacing-6);
  padding: var(--spacing-8) 0;
}
.gallery-item {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  background: var(--bg-secondary);
  box-shadow: var(--shadow-md);
  transition: var(--transition-premium);
  aspect-ratio: 4/3;
}
.gallery-item:hover { transform: scale(1.03); box-shadow: var(--glow-teal); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition-smooth); }
.gallery-item:hover img { transform: scale(1.10); }
.gallery-item .overlay {
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background: var(--gradient-overlay);
  opacity: 0; transition: var(--transition-elegant);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-white);
  font-size: var(--text-2xl);
  font-weight: var(--font-weight-bold);
}
.gallery-item:hover .overlay { opacity: 1; }

/* Booking Form */
.booking-form {
  background: var(--bg-primary);
  border-radius: var(--radius-3xl);
  padding: var(--spacing-10);
  box-shadow: var(--shadow-2xl);
  border: 2px solid var(--border-gold);
}
.booking-form .form-section { margin-bottom: var(--spacing-8); }
.booking-form .form-section:last-child { margin-bottom: 0; }
.booking-form .section-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-teal);
  margin-bottom: var(--spacing-4);
  position: relative;
}
.booking-form .section-title::after {
  content: '';
  position: absolute;
  bottom: -8px; left: 0;
  width: 50px; height: 3px;
  background: var(--gradient-gold);
  border-radius: var(--radius-full);
}

/* Statistics */
.stats-section {
  background: var(--gradient-hero);
  color: var(--color-white);
  padding: var(--spacing-16) 0;
  position: relative;
}

/* Feature Highlights */
.feature-highlight {
  display: flex;
  align-items: center;
  padding: var(--spacing-6);
  background: var(--bg-primary);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-md);
  transition: var(--transition-elegant);
  border-left: 4px solid var(--color-gold);
  margin-bottom: var(--spacing-4);
}
.feature-highlight:hover { transform: translateX(8px); box-shadow: var(--shadow-lg); }
.feature-highlight .icon {
  width: 60px; height: 60px;
  background: var(--gradient-primary);
  border-radius: var(--radius-xl);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-white);
  font-size: var(--text-2xl);
  margin-right: var(--spacing-6);
  box-shadow: var(--shadow-teal);
  flex-shrink: 0;
}
.feature-highlight .content h3 { color: var(--color-teal); font-size: var(--text-xl); font-weight: var(--font-weight-semibold); margin-bottom: var(--spacing-2); }
.feature-highlight .content p  { color: var(--text-secondary); margin: 0; line-height: var(--leading-relaxed); }

/* ============================================================
   19b. UTILITY TEXT EXTRAS
   ============================================================ */
.text-dark      { color: var(--text-primary)    !important; }
.text-navy      { color: var(--color-teal-deep) !important; }
.text-green     { color: var(--color-sage)      !important; }
.text-emerald   { color: var(--color-sage)      !important; }
.text-orange    { color: var(--color-gold)      !important; }
.text-blue      { color: var(--color-teal)      !important; }
.text-red       { color: var(--color-error)     !important; }
.text-success   { color: var(--color-success)   !important; }
.text-warning   { color: var(--color-warning)   !important; }
.text-danger    { color: var(--color-error)     !important; }
.text-info      { color: var(--color-info)      !important; }
.text-serif     { font-family: var(--font-display)  !important; }
.text-elegant   { font-family: var(--font-elegant)  !important; }

/* Gradient text utilities */
.text-gradient {
  background: var(--gradient-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: var(--font-weight-bold);
}
.text-ocean-gradient {
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: var(--font-weight-bold);
}
.text-golden-gradient {
  background: var(--gradient-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: var(--font-weight-bold);
}
.text-ocean-glow  { color: var(--color-teal); text-shadow: 0 0 20px rgba(13, 92, 99, 0.35); }
.text-golden-glow { color: var(--color-gold); text-shadow: 0 0 20px rgba(200, 131, 74, 0.45); }

/* Tourism text utilities */
.text-hero {
  font-size: var(--text-6xl);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-none);
  font-family: var(--font-display);
  background: var(--gradient-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.text-subtitle    { font-size: var(--text-2xl); font-weight: var(--font-weight-light); color: var(--text-secondary); line-height: var(--leading-relaxed); }
.text-price       { font-size: var(--text-3xl); font-weight: var(--font-weight-bold); color: var(--color-teal); }
.text-highlight {
  background: linear-gradient(to right, var(--color-gold), var(--color-gold-light));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: var(--font-weight-semibold);
}
.text-premium-shadow { text-shadow: 2px 2px 8px rgba(13, 92, 99, 0.20); }

/* ============================================================
   20b. UTILITY BACKGROUND EXTRAS
   ============================================================ */
.bg-tertiary  { background-color: var(--bg-tertiary)  !important; }
.bg-dark      { background-color: var(--color-teal-deep) !important; }
.bg-navy      { background-color: var(--color-teal-deep) !important; }
.bg-green     { background-color: var(--color-sage)   !important; }
.bg-ocean     { background-color: var(--color-teal)   !important; }
.bg-emerald   { background-color: var(--color-sage)   !important; }
.bg-golden    { background-color: var(--color-gold)   !important; }
.bg-blue      { background-color: var(--color-teal)   !important; }
.bg-orange    { background-color: var(--color-gold)   !important; }
.bg-red       { background-color: var(--color-error)  !important; }

.bg-ocean-light   { background-color: var(--bg-teal-light)   !important; }
.bg-emerald-light { background-color: var(--color-sage-bg)   !important; }
.bg-golden-light  { background-color: var(--color-gold-bg)   !important; }

/* Gradient backgrounds */
.bg-gradient         { background: var(--gradient-primary)  !important; }
.bg-gradient-navy    { background: var(--gradient-primary)  !important; }
.bg-gradient-ocean   { background: var(--gradient-primary)  !important; }
.bg-gradient-gold    { background: var(--gradient-gold)     !important; }
.bg-gradient-golden  { background: var(--gradient-gold)     !important; }
.bg-gradient-emerald { background: var(--gradient-sage)     !important; }
.bg-gradient-premium { background: var(--gradient-premium)  !important; }
.bg-gradient-hero    { background: var(--gradient-hero)     !important; }
.bg-gradient-primary { background: var(--gradient-primary)  !important; }
.bg-gradient-blue    { background: var(--gradient-primary)  !important; }
.bg-gradient-orange  { background: var(--gradient-gold)     !important; }
.bg-gradient-teal    { background: var(--gradient-primary)  !important; }

/* Texture backgrounds */
.bg-texture-subtle {
  background: radial-gradient(circle at 25% 25%, rgba(13, 92, 99, 0.04) 0%, transparent 50%),
              radial-gradient(circle at 75% 75%, rgba(42, 181, 192, 0.03) 0%, transparent 50%),
              var(--bg-primary);
}
.bg-ocean-pattern {
  background: radial-gradient(circle at 25% 25%, rgba(13, 92, 99, 0.06) 0%, transparent 60%),
              radial-gradient(circle at 75% 75%, rgba(200, 131, 74, 0.04) 0%, transparent 60%),
              var(--bg-primary);
}
.bg-waves-pattern {
  background: repeating-linear-gradient(45deg,
    transparent, transparent 10px,
    rgba(13, 92, 99, 0.018) 10px,
    rgba(13, 92, 99, 0.018) 20px),
    var(--bg-primary);
}

/* Glass morphism utility classes */
.glass-ocean   { background: var(--glass-ocean);   backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid rgba(13, 92, 99, 0.15);  border-radius: var(--radius-2xl); box-shadow: var(--shadow-lg); }
.glass-emerald { background: var(--glass-emerald); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(74, 140, 114, 0.14); border-radius: var(--radius-2xl); box-shadow: var(--shadow-lg); }
.glass-golden  { background: var(--glass-golden);  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(200, 131, 74, 0.18); border-radius: var(--radius-2xl); box-shadow: var(--shadow-gold); }

/* Content containers */
.content-ocean {
  max-width: 900px; margin: 0 auto;
  padding: var(--spacing-10);
  background: var(--bg-primary);
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-premium);
  border: 1px solid var(--border-secondary);
}
.content-glass {
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.50);
}

/* ============================================================
   21. UTILITY: BORDERS
   ============================================================ */
.border   { border: 1px solid var(--border-primary) !important; }
.border-0 { border: 0 !important; }
.border-2 { border: 2px solid var(--border-primary) !important; }

.border-primary   { border-color: var(--border-primary)   !important; }
.border-secondary { border-color: var(--border-secondary) !important; }
.border-ocean     { border-color: var(--color-teal)  !important; }
.border-emerald   { border-color: var(--color-sage)  !important; }
.border-golden    { border-color: var(--color-gold)  !important; }
.border-blue      { border-color: var(--color-teal)  !important; }
.border-orange    { border-color: var(--color-gold)  !important; }

.border-modern        { border: 2px solid var(--color-teal) !important; border-radius: var(--radius-xl) !important; }
.border-golden-accent { border: 2px solid var(--color-gold) !important; border-radius: var(--radius-xl) !important; box-shadow: var(--shadow-sm) !important; }

/* ============================================================
   22. UTILITY: SHADOWS
   ============================================================ */
.shadow-none { box-shadow: none !important; }
.shadow-xs   { box-shadow: var(--shadow-xs) !important; }
.shadow-sm   { box-shadow: var(--shadow-sm) !important; }
.shadow-md   { box-shadow: var(--shadow-md) !important; }
.shadow-lg   { box-shadow: var(--shadow-lg) !important; }
.shadow-xl   { box-shadow: var(--shadow-xl) !important; }
.shadow-2xl  { box-shadow: var(--shadow-2xl) !important; }

.shadow-ocean   { box-shadow: var(--shadow-teal) !important; }
.shadow-emerald { box-shadow: var(--shadow-sage) !important; }
.shadow-golden  { box-shadow: var(--shadow-gold) !important; }
.shadow-blue    { box-shadow: var(--shadow-teal) !important; }
.shadow-orange  { box-shadow: var(--shadow-gold) !important; }
.shadow-teal    { box-shadow: var(--shadow-teal) !important; }

/* ============================================================
   23b. UTILITY MISC EXTRAS
   ============================================================ */
.mt-auto { margin-top: auto; }
.p-0     { padding: 0 !important; }
.w-100   { width: 100%; }
.h-100   { height: 100%; }

.sr-only {
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Icon boxes */
.icon-ocean {
  display: inline-flex; align-items: center; justify-content: center;
  width: 3.5rem; height: 3.5rem;
  background: var(--gradient-primary);
  color: var(--color-white);
  border-radius: var(--radius-2xl);
  font-size: var(--text-xl);
  box-shadow: var(--shadow-teal);
  transition: var(--transition-elegant);
}
.icon-ocean:hover    { transform: scale(1.1) rotate(5deg); box-shadow: var(--glow-teal); }
.icon-emerald        { background: var(--gradient-sage);   box-shadow: var(--shadow-sage); }
.icon-emerald:hover  { box-shadow: var(--glow-sage); }
.icon-golden         { background: var(--gradient-gold);   color: var(--color-white); box-shadow: var(--shadow-gold); }
.icon-golden:hover   { box-shadow: var(--glow-gold); }
.icon-glass {
  background: rgba(255,255,255,0.65); backdrop-filter: blur(12px);
  color: var(--color-teal);
  border: 1px solid rgba(255,255,255,0.50);
  box-shadow: var(--shadow-md);
}

/* Image effects */
.image-ocean {
  border-radius: var(--radius-2xl); overflow: hidden;
  box-shadow: var(--shadow-lg); transition: var(--transition-premium);
  border: 2px solid transparent;
}
.image-ocean:hover   { transform: scale(1.02) rotate(1deg); box-shadow: var(--glow-teal); border-color: var(--color-teal-pale); }
.image-golden {
  border-radius: var(--radius-xl);
  border: 3px solid var(--color-gold);
  box-shadow: var(--shadow-gold);
  transition: var(--transition-elegant);
}
.image-golden:hover  { box-shadow: var(--glow-gold); transform: scale(1.02); }

/* Hover helpers */
.hover-glow:hover { box-shadow: var(--glow-teal); }

/* Overlay effects */
.overlay-ocean {
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background: var(--gradient-overlay);
  opacity: 0; transition: var(--transition-premium);
  border-radius: inherit;
}
.overlay-ocean:hover { opacity: 1; }
.overlay-glass {
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.50);
}

/* Float parallax */
.float-ocean   { animation: waveMotion 8s ease-in-out infinite; }
.float-emerald { animation: waveMotion 6s ease-in-out infinite reverse; }
.float-golden  { animation: waveMotion 10s ease-in-out infinite; animation-delay: -2s; }
.parallax-ocean {
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
}
.parallax-ocean::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background: var(--gradient-overlay);
  opacity: 0.60;
}

/* Special */
.floating-cta {
  position: fixed;
  bottom: var(--spacing-8); right: var(--spacing-8);
  z-index: var(--z-index-sticky);
  animation: bounce 2s infinite;
}
.scroll-indicator {
  position: absolute;
  bottom: var(--spacing-8); left: 50%;
  transform: translateX(-50%);
  color: var(--color-white);
  font-size: var(--text-2xl);
  animation: bounce 2s infinite;
}

/* RTL Support */
[dir="rtl"] { text-align: right; }
[dir="rtl"] .section-label::before { right: auto; left: 100%; background: linear-gradient(90deg, var(--color-teal), transparent); }
[dir="rtl"] .section-label::after  { left: auto; right: 100%; background: linear-gradient(90deg, transparent, var(--color-teal)); }

/* ============================================================
   24b. ANIMATION EXTRAS
   ============================================================ */
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-40px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes slideInDown {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes ripple {
  0%   { transform: scale(0); opacity: 1; }
  100% { transform: scale(4); opacity: 0; }
}
@keyframes slideIn {
  from { width: 0; }
  to   { width: 80px; }
}
@keyframes autoGrow {
  0%   { width: 10%; }
  50%  { width: 82%; }
  100% { width: 10%; }
}

/* Additional animation utility classes */
.animate-fade-down { animation: fadeInDown 0.8s ease-out; }
.animate-spin      { animation: spin 2s linear infinite; }

/* ============================================================
   END OF MAIN.CSS — PRIMALI TRAVELS v1.0.0
   www.primalitravels.com
   Brand: Inbound Destination Management Specialists — Southern Sri Lanka
   Markets: United Kingdom & Germany
   Palette: Southern Ocean White · Deep Teal · Coral Reef Gold
   Theme: Premium White Ocean Light Theme
   Founder: D.G. Prabath Induka | Kirinda-Puhulwella, Matara
   ============================================================ */

/* ============================================================
   33. SAPPHIRE PREMIUM COMPONENT SYSTEM
   Indian Ocean depth layers — Matara, Southern Sri Lanka
   Version 2.0.0 — all tokens reference :root variables above.
   ============================================================ */

/* ─── SAPPHIRE CARDS ──────────────────────────────────────── */

/* Glass card for use on sapphire section backgrounds */
.card-sapphire-glass {
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(174, 214, 241, 0.15);
  border-radius: var(--radius-2xl);
  box-shadow: 0 8px 32px rgba(4, 13, 26, 0.35);
  transition: var(--transition-elegant);
}
.card-sapphire-glass:hover {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(174, 214, 241, 0.28);
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(4, 13, 26, 0.50);
}
.card-sapphire-glass .card-title { color: var(--color-white); }
.card-sapphire-glass .card-text  { color: var(--color-sapphire-pale); }

/* Solid sapphire card — feature highlights on dark sections */
.card-sapphire {
  background: var(--gradient-sapphire-card);
  border: 1px solid var(--color-sapphire-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-sapphire);
  transition: var(--transition-premium);
  color: var(--color-white);
}
.card-sapphire:hover {
  transform: translateY(-6px);
  box-shadow: var(--glow-sapphire);
  border-color: rgba(93, 173, 226, 0.35);
}
.card-sapphire .card-title { color: var(--color-white); }
.card-sapphire .card-text  { color: var(--color-sapphire-pale); }

/* Premium ocean card — white with sapphire depth shadow */
.card-ocean-premium {
  background: var(--color-white);
  border: 1px solid var(--color-sapphire-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-sapphire);
  transition: var(--transition-premium);
  position: relative;
  overflow: hidden;
}
.card-ocean-premium::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-sapphire-section);
  opacity: 0;
  transition: opacity var(--transition-elegant);
}
.card-ocean-premium:hover {
  transform: translateY(-6px);
  box-shadow: var(--glow-sapphire);
  border-color: var(--color-sapphire-border);
}
.card-ocean-premium:hover::before { opacity: 1; }

/* ─── SAPPHIRE BUTTONS ────────────────────────────────────── */

/* Sapphire filled — for use on white/light sections */
.btn-sapphire {
  background: var(--gradient-sapphire-section);
  border: none;
  color: var(--color-white);
  box-shadow: var(--shadow-sapphire);
  font-weight: var(--font-weight-bold);
}
.btn-sapphire:hover {
  background: linear-gradient(135deg, var(--color-sapphire-mid) 0%, var(--color-sapphire-light) 100%);
  transform: translateY(-2px);
  box-shadow: var(--glow-sapphire);
  color: var(--color-white);
}
.btn-sapphire:active { transform: translateY(0); }

/* Sapphire outline — for use on white sections */
.btn-outline-sapphire {
  background: transparent;
  border: 2px solid var(--color-sapphire);
  color: var(--color-sapphire);
}
.btn-outline-sapphire:hover {
  background: var(--gradient-sapphire-section);
  border-color: var(--color-sapphire);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sapphire);
}

/* Ghost button — for use ON sapphire dark backgrounds */
.btn-ghost-sapphire {
  background: rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1.5px solid rgba(174, 214, 241, 0.35);
  color: var(--color-white);
}
.btn-ghost-sapphire:hover {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(174, 214, 241, 0.60);
  color: var(--color-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(4, 13, 26, 0.30);
}

/* Gold CTA on sapphire — primary action on dark backgrounds */
.btn-gold-on-dark {
  background: var(--gradient-gold);
  border: none;
  color: var(--color-white);
  box-shadow: var(--shadow-gold), 0 0 0 3px rgba(200, 131, 74, 0.18);
  font-weight: var(--font-weight-bold);
}
.btn-gold-on-dark:hover {
  background: var(--gradient-gold-hover);
  transform: translateY(-2px);
  box-shadow: var(--shadow-gold-lg), 0 0 0 4px rgba(200, 131, 74, 0.22);
  color: var(--color-white);
}

/* ─── TESTIMONIAL CARD — SAPPHIRE DARK VERSION ────────────── */

/* For use on .section-sapphire or .section-sapphire-deep */
.testimonial-card-dark {
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(174, 214, 241, 0.14);
  border-radius: var(--radius-2xl);
  padding: var(--spacing-8);
  box-shadow: 0 8px 32px rgba(4, 13, 26, 0.35);
  transition: var(--transition-elegant);
}
.testimonial-card-dark:hover {
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(174, 214, 241, 0.28);
  transform: translateY(-3px);
  box-shadow: 0 16px 48px rgba(4, 13, 26, 0.50);
}
.testimonial-card-dark .testimonial-quote {
  color: var(--color-white);
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  line-height: var(--leading-relaxed);
  margin-bottom: var(--spacing-6);
}
.testimonial-card-dark .testimonial-author-name { color: var(--color-white); }
.testimonial-card-dark .testimonial-author-location { color: var(--color-sapphire-pale); }
.testimonial-card-dark .testimonial-stars { color: var(--color-gold-light); }

/* ─── STAT ITEMS — SAPPHIRE DARK VERSION ─────────────────── */

.stat-item-dark {
  text-align: center;
  padding: var(--spacing-6);
}
.stat-item-dark .stat-number {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-6xl));
  font-weight: var(--font-weight-bold);
  color: var(--color-gold-light);
  line-height: 1;
  margin-bottom: var(--spacing-2);
}
.stat-item-dark .stat-label {
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-sapphire-pale);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}

/* ─── FEATURE ITEMS — SAPPHIRE DARK VERSION ──────────────── */

.feature-item-dark {
  display: flex;
  gap: var(--spacing-5);
  align-items: flex-start;
  padding: var(--spacing-6);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(174, 214, 241, 0.12);
  border-radius: var(--radius-xl);
  transition: var(--transition-elegant);
}
.feature-item-dark:hover {
  background: rgba(255, 255, 255, 0.09);
  border-color: rgba(174, 214, 241, 0.25);
  transform: translateY(-2px);
}
.feature-item-dark .feature-icon {
  background: rgba(41, 128, 185, 0.20);
  color: var(--color-sapphire-soft);
  border: 1px solid rgba(93, 173, 226, 0.20);
}
.feature-item-dark:hover .feature-icon {
  background: var(--gradient-gold);
  color: var(--color-white);
  border-color: transparent;
}
.feature-item-dark .feature-title { color: var(--color-white); }
.feature-item-dark .feature-text  { color: var(--color-sapphire-pale); }

/* ─── NAVBAR — ENHANCED SCROLLED STATE ───────────────────── */

/* Subtle sapphire-tinted border on scroll for premium depth */
.navbar.scrolled {
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow-md), 0 1px 0 rgba(13, 58, 92, 0.08);
  border-bottom-color: rgba(13, 58, 92, 0.12);
}

/* ─── SECTION DIVIDERS — SAPPHIRE VERSIONS ───────────────── */

.divider-sapphire {
  border: none;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--color-sapphire), transparent);
  margin: var(--spacing-8) 0;
}
.divider-ocean-depth {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(174, 214, 241, 0.30), transparent);
  margin: var(--spacing-6) 0;
}

/* ─── BADGE — SAPPHIRE VARIANTS ──────────────────────────── */

.badge-sapphire {
  background: var(--color-sapphire-ghost);
  color: var(--color-sapphire);
  border: 1px solid var(--color-sapphire-border);
}
.badge-sapphire-dark {
  background: rgba(41, 128, 185, 0.20);
  color: var(--color-sapphire-soft);
  border: 1px solid rgba(93, 173, 226, 0.25);
}
.badge-ocean-depth {
  background: var(--gradient-sapphire-section);
  color: var(--color-white);
  border: none;
}

/* ─── SECTION BACKGROUND UTILITY ALIASES ─────────────────── */

.bg-sapphire         { background-color: var(--color-sapphire)       !important; }
.bg-sapphire-deep    { background-color: var(--color-sapphire-deep)   !important; }
.bg-sapphire-abyss   { background-color: var(--color-sapphire-abyss)  !important; }
.bg-sapphire-light   { background-color: var(--color-sapphire-ghost)  !important; }
.bg-seafoam          { background-color: var(--color-sapphire-foam)   !important; }
.bg-gradient-sapphire{ background: var(--gradient-sapphire-section)   !important; }
.bg-gradient-depth   { background: var(--gradient-depth-ocean)        !important; }
.bg-gradient-horizon { background: var(--gradient-horizon)            !important; }

/* ─── TEXT COLOUR — SAPPHIRE VARIANTS ────────────────────── */

.text-sapphire       { color: var(--color-sapphire)       !important; }
.text-sapphire-light { color: var(--color-sapphire-soft)  !important; }
.text-sapphire-pale  { color: var(--color-sapphire-pale)  !important; }

/* ─── SHADOW — SAPPHIRE VARIANTS ─────────────────────────── */

.shadow-sapphire     { box-shadow: var(--shadow-sapphire)    !important; }
.shadow-sapphire-lg  { box-shadow: var(--shadow-sapphire-lg) !important; }
.glow-sapphire       { box-shadow: var(--glow-sapphire)      !important; }

/* ─── ICON BOXES — SAPPHIRE VARIANTS ─────────────────────── */

.icon-sapphire {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  background: var(--gradient-sapphire-section);
  color: var(--color-white);
  border-radius: var(--radius-2xl);
  font-size: var(--text-xl);
  box-shadow: var(--shadow-sapphire);
  transition: var(--transition-elegant);
}
.icon-sapphire:hover {
  transform: scale(1.1) rotate(5deg);
  box-shadow: var(--glow-sapphire);
}
.icon-sapphire-glass {
  background: rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(12px);
  color: var(--color-sapphire-soft);
  border: 1px solid rgba(174, 214, 241, 0.20);
  box-shadow: none;
}

/* ─── FOOTER EXTRAS ───────────────────────────────────────── */

/* Social icon on footer */
.footer-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-full);
  background: rgba(174, 214, 241, 0.08);
  border: 1px solid rgba(174, 214, 241, 0.14);
  color: var(--color-sapphire-pale);
  transition: var(--transition-elegant);
  font-size: var(--text-sm);
}
.footer-social-link:hover {
  background: var(--gradient-gold);
  border-color: transparent;
  color: var(--color-white);
  transform: translateY(-3px);
  box-shadow: var(--shadow-gold);
}

/* ─── FOOTER — OCEAN VARIANT ALIAS ───────────────────────── */

.footer-ocean {
  background: var(--gradient-depth-ocean);
  color: var(--color-white);
  padding: var(--spacing-16) 0 var(--spacing-8);
  position: relative;
}
.footer-ocean::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-gold);
}

/* ============================================================
   END OF MAIN.CSS — PRIMALI TRAVELS v2.0.0
   www.primalitravels.com
   Brand: Inbound Destination Management Specialists — Southern Sri Lanka
   Markets: United Kingdom & Germany
   Palette: Indian Ocean Sapphire · Southern Teal · Coral Reef Gold
   Theme: Premium Ocean Sapphire — 5 depth layers from Matara coastline
   Founder: D.G. Prabath Induka | Kirinda-Puhulwella, Matara
   ============================================================ */
