/* ============================================================
   RAVIERA CEYLON (RC)
   main.css — Centralized Design System — Single Source of Truth
   Version: 1.0.0 | www.ravieraceylon.com

   Brand: Raviera Ceylon Pvt Ltd — Inbound Tourism · Heritage · Luxury
   Founded by: Mrs. Bhagya Ravindradhasa
   Location: 23/2 Hospital Road, Kegalle, Sri Lanka

   Palette: Obsidian · Prestige Gold · Charcoal · Warm Pearl · Pearl White
   Inspiration: Ceylon sapphires, Kegalle highland mist,
                ancient temple gold leaf, luxury dark hospitality

   ⚠️  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;1,400;1,500&family=Inter:wght@300;400;500;600;700&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&display=swap');

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

  /* ─── RAVIERA CEYLON BRAND PALETTE ───────────────────────────────── */
  /*
     Prestige Gold  → Ceylon gold leaf, temple ornaments, luxury warmth
     Obsidian       → Premium editorial dark — deep, rich, never blue
     Charcoal       → Layered dark surfaces — cards, sections, panels
     Smoke          → Muted text, borders, subtle dividers
     Pearl          → Refined highlights on dark canvas

     DESIGN RULE: No electric blues. No bright oranges. The palette is
     obsidian-black + warm gold. Section contrast comes from depth,
     not hue shifts.
  */

  /* ── Prestige Gold (sole accent / CTA) — all interactive elements */
  --color-gold:           #c9a84c;
  --color-gold-light:     #dbbf6a;
  --color-gold-pale:      #f0dfa8;
  --color-gold-bright:    #e8c96a;
  --color-gold-dark:      #a8872e;
  --color-gold-darker:    #7d6320;
  --color-gold-glow:      rgba(201, 168, 76, 0.25);
  --color-gold-glow-sm:   rgba(201, 168, 76, 0.12);
  --color-gold-bg:        rgba(201, 168, 76, 0.08);
  --color-gold-bg-hover:  rgba(201, 168, 76, 0.14);
  --color-gold-rgb:       201, 168, 76;

  /* ── Obsidian / Charcoal surface scale — dark premium backgrounds */
  --color-obsidian:       #0a0a0a;   /* true deep black — body bg            */
  --color-obsidian-warm:  #111111;   /* warm off-black — main bg             */
  --color-charcoal-deep:  #181818;   /* section alt bg — barely lighter      */
  --color-charcoal:       #1f1f1f;   /* card surface — primary card bg       */
  --color-charcoal-mid:   #242424;   /* card hover / raised surface          */
  --color-charcoal-light: #2c2c2c;   /* elevated panels, nav scrolled        */
  --color-charcoal-border:#333333;   /* default border on dark surfaces      */
  --color-smoke:          #3d3d3d;   /* secondary / subtle borders           */
  --color-smoke-light:    #4a4a4a;   /* dividers, disabled borders           */

  /* ── Neutral / slate scale (text, muted elements) */
  --color-slate-900:      #0a0a0a;
  --color-slate-800:      #181818;
  --color-slate-700:      #2c2c2c;
  --color-slate-600:      #404040;
  --color-slate-500:      #555555;
  --color-slate-400:      #737373;
  --color-slate-300:      #9a9a9a;
  --color-slate-200:      #c2c2c2;
  --color-slate-100:      #e5e5e5;
  --color-slate-50:       #f5f5f5;

  /* ── Navy — kept only as a subtle cool tint, never for section backgrounds */
  --color-navy:           #1a2332;   /* very dark, near-black navy — subtle  */
  --color-navy-deep:      #0d1520;   /* darkest navy — footer, deep sections */
  --color-navy-mid:       #1e2d42;   /* mid-dark slate-navy                  */
  --color-navy-light:     #253450;   /* lighter — only for subtle accents    */
  --color-navy-soft:      #8fa3b8;   /* desaturated — muted text only        */
  --color-navy-border:    #1a2332;
  --color-navy-rgb:       26, 35, 50;

  /* ─── WHITE OPACITY SCALE ─────────────────────────────────── */
  --color-white:          #ffffff;
  --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-75:       rgba(255, 255, 255, 0.75);
  --color-white-70:       rgba(255, 255, 255, 0.70);
  --color-white-65:       rgba(255, 255, 255, 0.65);
  --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-35:       rgba(255, 255, 255, 0.35);
  --color-white-30:       rgba(255, 255, 255, 0.30);
  --color-white-20:       rgba(255, 255, 255, 0.20);
  --color-white-18:       rgba(255, 255, 255, 0.18);
  --color-white-12:       rgba(255, 255, 255, 0.12);
  --color-white-10:       rgba(255, 255, 255, 0.10);
  --color-white-08:       rgba(255, 255, 255, 0.08);
  --color-white-05:       rgba(255, 255, 255, 0.05);

  /* Dark Overlay Scale — obsidian-based */
  --color-dark-90:        rgba(10, 10, 10, 0.92);
  --color-dark-80:        rgba(10, 10, 10, 0.80);
  --color-dark-70:        rgba(10, 10, 10, 0.70);
  --color-dark-50:        rgba(10, 10, 10, 0.50);
  --color-dark-30:        rgba(10, 10, 10, 0.30);

  /* ─── SEMANTIC / STATUS COLORS ───────────────────────────── */
  --color-success:        #10b981;
  --color-success-light:  rgba(16, 185, 129, 0.15);
  --color-success-dark:   #059669;
  --color-success-rgb:    16, 185, 129;

  --color-warning:        #f59e0b;
  --color-warning-light:  rgba(245, 158, 11, 0.15);
  --color-warning-dark:   #d97706;
  --color-warning-rgb:    245, 158, 11;

  --color-error:          #ef4444;
  --color-error-light:    rgba(239, 68, 68, 0.15);
  --color-error-dark:     #dc2626;
  --color-error-rgb:      239, 68, 68;

  --color-info:           #3b82f6;
  --color-info-light:     rgba(59, 130, 246, 0.15);
  --color-info-dark:      #2563eb;
  --color-info-rgb:       59, 130, 246;

  /* ─── BACKGROUND TOKENS — PREMIUM DARK THEME ───────────────────── */
  --bg-primary:           #111111;   /* main page background                  */
  --bg-secondary:         #1a1a1a;   /* alt sections, sidebar panels          */
  --bg-tertiary:          #222222;   /* cards, dropdowns, elevated surfaces   */
  --bg-dark:              #0a0a0a;   /* footer, deepest sections              */
  --bg-overlay:           rgba(10, 10, 10, 0.80);
  --bg-overlay-light:     rgba(10, 10, 10, 0.45);
  --bg-gold-light:        rgba(201, 168, 76, 0.07);
  --bg-navy-light:        rgba(26, 35, 50, 0.25);
  --bg-texture-subtle:    linear-gradient(135deg, #111111 0%, #1a1a1a 100%);

  /* ─── TEXT TOKENS — PREMIUM DARK THEME ─────────────────────────── */
  --text-primary:         #f0ede8;   /* warm white — main headings            */
  --text-secondary:       #c8c2b8;   /* warm gray — body copy                 */
  --text-muted:           #8a8278;   /* muted warm — captions, meta           */
  --text-light:           #5c5650;   /* light muted — placeholders            */
  --text-lighter:         #3d3935;   /* lightest — disabled states            */
  --text-white:           #ffffff;
  --text-gold:            var(--color-gold);
  --text-navy:            var(--color-slate-300);

  /* ─── BORDER TOKENS — PREMIUM DARK THEME ───────────────────────── */
  --border-primary:       #2c2c2c;   /* default card / section borders        */
  --border-secondary:     #222222;   /* subtle inner borders                  */
  --border-light:         rgba(255, 255, 255, 0.07);
  --border-gold:          rgba(201, 168, 76, 0.35);
  --border-navy:          #1a2332;
  --border-focus:         var(--color-gold);
  --border-gray:          #2c2c2c;   /* legacy alias */

  /* ─── GRADIENTS — PREMIUM DARK (obsidian + gold only) ─────────── */

  /* Primary surface gradient — subtle dark lift */
  --gradient-primary:     linear-gradient(135deg, #111111 0%, #1a1a1a 100%);
  /* Prestige Gold CTA */
  --gradient-gold:        linear-gradient(135deg, #c9a84c 0%, #a8872e 100%);
  --gradient-gold-hover:  linear-gradient(135deg, #dbbf6a 0%, #c9a84c 100%);
  --gradient-gold-subtle: linear-gradient(135deg, rgba(201,168,76,0.15) 0%, rgba(201,168,76,0.05) 100%);
  /* Hero — deep obsidian */
  --gradient-hero:        linear-gradient(160deg, #080808 0%, #111111 55%, #181818 100%);
  /* Depth — footer / darkest */
  --gradient-depth:       linear-gradient(180deg, #0a0a0a 0%, #060606 100%);
  /* Overlay — image overlays */
  --gradient-overlay:     linear-gradient(180deg, rgba(10,10,10,0) 0%, rgba(10,10,10,0.88) 100%);
  /* Premium — dark + gold whisper (replaces the blue-orange abomination) */
  --gradient-premium:     linear-gradient(135deg, #111111 0%, #1a1a1a 60%, rgba(201,168,76,0.10) 100%);
  /* Card — elevated charcoal */
  --gradient-card:        linear-gradient(145deg, #1f1f1f 0%, #181818 100%);
  /* Luxury — dark to gold glow */
  --gradient-luxury:      linear-gradient(135deg, #1a1a1a 0%, rgba(201,168,76,0.18) 100%);
  /* Glass — dark frosted */
  --gradient-glass:       linear-gradient(135deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  /* Text gradient — gold shimmer */
  --gradient-text:        linear-gradient(135deg, #c9a84c, #dbbf6a);
  /* Warm gradient */
  --gradient-warm:        linear-gradient(135deg, #c9a84c 0%, #a8872e 60%, #1a1a1a 100%);
  /* Stats / dark-section background */
  --gradient-stats:       linear-gradient(135deg, #161616 0%, #1e1e1e 100%);
  /* CTA section background */
  --gradient-cta:         linear-gradient(135deg, #1a1a1a 0%, #222222 100%);
  /* Button alias */
  --gradient-button:      var(--gradient-gold);

  /* ─── SHADOWS — PREMIUM DARK ─────────────────────────────── */
  --shadow-xs:            0 1px 3px rgba(0, 0, 0, 0.50);
  --shadow-sm:            0 2px 6px rgba(0, 0, 0, 0.55), 0 1px 3px rgba(0, 0, 0, 0.40);
  --shadow-md:            0 4px 14px rgba(0, 0, 0, 0.60), 0 2px 6px rgba(0, 0, 0, 0.45);
  --shadow-lg:            0 10px 28px rgba(0, 0, 0, 0.65), 0 4px 10px rgba(0, 0, 0, 0.50);
  --shadow-xl:            0 20px 45px rgba(0, 0, 0, 0.72), 0 8px 18px rgba(0, 0, 0, 0.55);
  --shadow-2xl:           0 30px 65px rgba(0, 0, 0, 0.80);
  --shadow-inner:         inset 0 2px 6px rgba(0, 0, 0, 0.55);
  --shadow-premium:       0 12px 38px rgba(0, 0, 0, 0.65), 0 4px 12px rgba(0, 0, 0, 0.50);

  /* Brand shadows */
  --shadow-gold:          0 4px 22px rgba(201, 168, 76, 0.30);
  --shadow-gold-lg:       0 8px 42px rgba(201, 168, 76, 0.25);
  --shadow-navy:          0 4px 20px rgba(10, 10, 10, 0.70);
  --shadow-brand:         0 8px 32px rgba(201, 168, 76, 0.18), 0 4px 14px rgba(0, 0, 0, 0.55);

  /* Glow aliases */
  --glow-navy:            0 8px 40px rgba(10, 10, 10, 0.80);
  --glow-gold:            0 8px 42px rgba(201, 168, 76, 0.38);
  --glow-premium:         0 12px 52px rgba(0, 0, 0, 0.65), 0 4px 16px rgba(201, 168, 76, 0.22);
  --glow-soft:            0 4px 22px rgba(201, 168, 76, 0.14);

  /* Luxury shadow */
  --shadow-luxury:        0 20px 60px rgba(0, 0, 0, 0.72), 0 6px 22px rgba(201, 168, 76, 0.14);

  /* ─── TYPOGRAPHY ─────────────────────────────────────────── */
  /*
     Display:  Playfair Display — editorial luxury, heritage elegance,
               Sri Lankan colonial grandeur. Headlines & hero titles.
     Body:     Inter — clean, modern, international travel brand clarity.
               Body copy, navigation, UI labels, stats.
     Elegant:  Poppins — refined contemporary warmth.
               Pull quotes, testimonials, feature callouts.
  */
  --font-display:         'Playfair Display', 'Georgia', serif;
  --font-primary:         'Inter', 'Helvetica Neue', sans-serif;
  --font-elegant:         'Poppins', 'Helvetica Neue', sans-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:     #1f1f1f;
  --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 Raviera Ceylon brand tokens.
   DO NOT remove these — ALL child CSS files depend on them.
   ============================================================ */
:root {

  /* ── Old "gold" accent names ──────────────────────────────── */
  --primary-gold:         var(--color-gold);
  --secondary-gold:       var(--color-gold-light);
  --accent-gold:          var(--color-gold-pale);
  --dark-gold:            var(--color-gold-dark);
  --light-gold:           var(--color-gold-bg);
  --gold-50:              rgba(201, 168, 76, 0.04);
  --gold-100:             rgba(201, 168, 76, 0.08);
  --gold-200:             rgba(201, 168, 76, 0.15);
  --gold-300:             var(--color-gold-pale);
  --gold-400:             var(--color-gold-light);
  --gold-500:             var(--color-gold);
  --gold-600:             var(--color-gold-dark);
  --gold-700:             var(--color-gold-dark);
  --gold-800:             var(--color-gold-darker);
  --gold-900:             var(--color-gold-darker);

  /* ── Old "blue / navy" names — mapped to neutral darks, NOT electric blue */
  --primary-blue:         var(--color-navy);
  --secondary-blue:       var(--color-navy-soft);
  --accent-blue:          var(--color-navy-soft);
  --dark-blue:            var(--color-navy-mid);
  --light-blue:           rgba(26, 35, 50, 0.25);
  --blue-50:              rgba(26, 35, 50, 0.04);
  --blue-100:             rgba(26, 35, 50, 0.08);
  --blue-200:             rgba(26, 35, 50, 0.15);
  --blue-300:             rgba(26, 35, 50, 0.30);
  --blue-400:             var(--color-navy-border);
  --blue-500:             var(--color-navy-soft);
  --blue-600:             var(--color-navy-light);
  --blue-700:             var(--color-navy-mid);
  --blue-800:             var(--color-navy);
  --blue-900:             var(--color-navy-deep);

  /* ── Old "red" → error color ─────────────────────────────── */
  --primary-red:          var(--color-error);
  --secondary-red:        #f87171;
  --accent-red:           #fca5a5;
  --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(239, 68, 68, 0.20);
  --red-300:              rgba(239, 68, 68, 0.40);
  --red-400:              rgba(239, 68, 68, 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 neutral names ────────────────────────────────── */
  --primary-dark:         var(--color-navy);
  --secondary-dark:       var(--color-navy-soft);
  --charcoal:             var(--bg-secondary);

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

  /* ── Old background names ─────────────────────────────────── */
  --bg-blue:              var(--color-navy);
  --bg-blue-light:        rgba(26, 35, 50, 0.20);
  --bg-gold:              var(--color-gold);
  --bg-gold-light:        var(--color-gold-bg);
  --bg-red:               var(--color-error);
  --bg-red-light:         var(--color-error-light);
  --bg-overlay-blue:      rgba(10, 10, 10, 0.80);
  --bg-overlay-gold:      rgba(201, 168, 76, 0.80);
  --bg-overlay-red:       rgba(239, 68, 68, 0.80);
  --bg-ocean-light:       rgba(26, 35, 50, 0.10);
  --bg-golden-light:      var(--color-gold-bg);

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

  /* ── Old gradient names ───────────────────────────────────── */
  --gradient-orange:      var(--gradient-gold);
  --gradient-teal:        var(--gradient-primary);
  --gradient-blue:        var(--gradient-primary);
  --gradient-red:         linear-gradient(135deg, var(--color-error) 0%, #f87171 100%);
  --gradient-golden:      var(--gradient-gold);
  --gradient-emerald:     linear-gradient(135deg, #059669 0%, #10b981 100%);

  /* ── Shadow / glow name aliases ───────────────────────────── */
  --shadow-medium:        var(--shadow-md);
  --shadow-large:         var(--shadow-lg);
  --shadow-orange:        var(--shadow-gold);
  --shadow-teal:          var(--shadow-navy);
  --shadow-red:           0 4px 20px rgba(239, 68, 68, 0.30);

  --glow-orange:          var(--glow-gold);
  --glow-teal:            var(--glow-navy);
  --glow-primary:         var(--glow-premium);

  /* ── Glass aliases ────────────────────────────────────────── */
  --glass-navy:           linear-gradient(135deg, rgba(26, 35, 50, 0.40) 0%, rgba(26, 35, 50, 0.20) 100%);
  --glass-gold:           linear-gradient(135deg, rgba(201, 168, 76, 0.12) 0%, rgba(201, 168, 76, 0.04) 100%);
  --glass-dark:           linear-gradient(135deg, rgba(10, 10, 10, 0.70) 0%, rgba(10, 10, 10, 0.50) 100%);

  /* Legacy glass aliases used in older child files */
  --glass-ocean:          var(--glass-navy);
  --glass-emerald:        linear-gradient(135deg, rgba(5, 150, 105, 0.12) 0%, rgba(5, 150, 105, 0.04) 100%);
  --glass-golden:         var(--glass-gold);

  /* ── 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);
  --font-secondary:       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/form status 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 primary / theme naming ───────────────────────────── */
  --primary-white:        #ffffff;
  --white-color:          #ffffff;
  --dark-color:           var(--color-navy);
  --primary-color:        var(--color-gold);
  --primary-color-rgb:    var(--color-gold-rgb);
  --primary-accent:       var(--color-gold);
  --primary-accent-rgb:   var(--color-gold-rgb);
  --primary-gold-light:   var(--color-gold-light);
  --primary-gold-dark:    var(--color-gold-dark);
  --primary-gold-rgb:     var(--color-gold-rgb);
  --primary-blue-light:   var(--color-navy-light);
  --primary-blue-dark:    var(--color-navy-mid);
  --primary-blue-rgb:     var(--color-navy-rgb);

  /* ── 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);
  --radius-base:          var(--radius-md);

  /* ── 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);

  /* ── 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);

  /* ── Background texture aliases ───────────────────────────── */
  --bg-texture-ocean: radial-gradient(circle at 25% 25%, rgba(26, 35, 50, 0.12) 0%, transparent 60%),
                      radial-gradient(circle at 75% 75%, rgba(201, 168, 76, 0.06) 0%, transparent 60%),
                      #121212;
  --bg-texture-waves: repeating-linear-gradient(45deg,
    transparent, transparent 10px,
    rgba(201, 168, 76, 0.02) 10px, rgba(201, 168, 76, 0.02) 20px), #111111;
  --subtle-texture:   #1a1a1a;

  /* ── Text color extras ────────────────────────────────────── */
  --text-tertiary:        var(--text-muted);
  --light-text-primary:   rgba(255, 255, 255, 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;

  /* ── 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 3px rgba(0, 0, 0, 0.40);
  --text-shadow-medium:   0 2px 6px rgba(0, 0, 0, 0.55);
  --text-shadow-strong:   0 4px 12px rgba(0, 0, 0, 0.70);

  /* ── 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;

  /* ── Card background alias ────────────────────────────────── */
  --card-background:      var(--bg-secondary);
  --border-color:         var(--border-primary);
  --muted-text:           var(--text-muted);

  /* Misc */
  --secondary-purple:     #7c3aed;
}

/* ============================================================
   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: var(--bg-texture-subtle);
  -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-gold);
  text-decoration: none;
  transition: color var(--transition-base);
  position: relative;
}

a:hover {
  color: var(--color-gold-light);
  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-gold);
  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); font-weight: var(--font-weight-semibold); }
.link-gold:hover { color: var(--color-gold-light); text-shadow: 0 0 8px var(--color-gold-glow); }

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

.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-gold);
  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-gold));
}
.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-gold), 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-gold); font-style: normal; }
.section-title.text-gradient {
  background: linear-gradient(135deg, var(--text-primary), var(--color-gold));
  -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-gold));
}
.section-divider span:last-child { background: linear-gradient(90deg, var(--color-gold), transparent); }
.section-divider i { color: var(--color-gold); font-size: var(--text-sm); }

/* Section spacing classes */
.section    { padding: var(--spacing-20) 0; }
.section-sm { padding: var(--spacing-12) 0; }
.section-lg { padding: var(--spacing-24) 0; }
.section-hero         { padding: var(--spacing-32) 0 var(--spacing-24); }
.section-destinations { padding: var(--spacing-20) 0; }
.section-tours        { padding: var(--spacing-24) 0; }
.section-testimonials { padding: var(--spacing-20) 0; }
.section-contact      { padding: var(--spacing-16) 0; }
.section-ocean        { padding: var(--spacing-24) 0; background: var(--bg-secondary); }
.section-emerald      { padding: var(--spacing-20) 0; background: rgba(16, 185, 129, 0.06); }
.section-golden       { padding: var(--spacing-16) 0; background: var(--color-gold-bg); }

/* Dark section variants */
.section-dark  { background: var(--bg-tertiary);  color: var(--color-white); }
.section-navy  { background: var(--color-navy-deep); color: var(--color-white); }
.section-light { background: var(--bg-secondary); }

/* ============================================================
   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-semibold);
  line-height: var(--leading-tight);
  letter-spacing: 0.06em;
  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-gold);
  outline-offset: 3px;
  border-radius: var(--radius-md);
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Primary — Prestige Gold CTA */
.btn-primary,
.btn-gold,
.btn-cta,
.btn-golden {
  background: var(--gradient-gold);
  border: none;
  color: var(--bg-primary);
  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(--bg-primary);
}
.btn-primary:active,
.btn-gold:active { transform: translateY(0); }

/* Secondary — Deep Navy */
.btn-secondary,
.btn-navy,
.btn-ocean,
.btn-blue {
  background: var(--gradient-primary);
  border: 1px solid var(--border-gold);
  color: var(--text-primary);
  box-shadow: var(--shadow-navy);
}
.btn-secondary:hover,
.btn-navy:hover,
.btn-ocean:hover,
.btn-blue:hover {
  background: linear-gradient(135deg, #1f1f1f 0%, #181818 100%);
  border-color: var(--color-gold);
  transform: translateY(-2px);
  box-shadow: var(--glow-gold);
  color: var(--color-gold);
}

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

.btn-outline-navy,
.btn-outline-ocean {
  background: transparent;
  border: 1.5px solid rgba(255, 255, 255, 0.40);
  color: var(--text-primary);
}
.btn-outline-navy:hover,
.btn-outline-ocean:hover {
  border-color: var(--color-gold);
  color: var(--color-gold);
  background: rgba(201, 168, 76, 0.08);
  transform: translateY(-2px);
}

/* White / Glass button */
.btn-white {
  background: rgba(255, 255, 255, 0.10);
  color: var(--text-primary);
  border: 1px solid rgba(255, 255, 255, 0.20);
}
.btn-white:hover {
  background: rgba(255, 255, 255, 0.18);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  color: var(--text-primary);
}

.btn-glass {
  background: var(--gradient-glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--color-white-20);
  color: var(--color-white);
  font-weight: var(--font-weight-semibold);
}
.btn-glass:hover {
  background: linear-gradient(135deg, rgba(255,255,255,0.14) 0%, rgba(255,255,255,0.06) 100%);
  transform: translateY(-2px);
  box-shadow: var(--shadow-premium);
  color: var(--color-white);
}

/* 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.20), 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.30);
  transform: translate(-50%, -50%);
  transition: width 0.5s, height 0.5s;
}
.btn-ripple:active::after { width: 300px; height: 300px; }

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

/* ============================================================
   8. CONTAINER & LAYOUT
   ============================================================ */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--spacing-6);
}
.container-wide    { max-width: var(--container-wide); margin: 0 auto; padding: 0 var(--spacing-8); }
.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); }

.grid  { display: grid; }
.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-gap-2 { gap: var(--spacing-2); }
.flex-gap-3 { gap: var(--spacing-3); }
.flex-gap-4 { gap: var(--spacing-4); }

/* ============================================================
   9. CARD SYSTEM
   ============================================================ */
.card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background: var(--gradient-card);
  background-clip: border-box;
  border: 1px solid var(--border-light);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-premium);
  overflow: hidden;
  will-change: transform;
}
.card:hover {
  transform: translateY(-6px) scale(1.01);
  box-shadow: var(--shadow-premium);
  border-color: var(--border-gold);
}
.card-header {
  padding: var(--spacing-6);
  background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
  border-bottom: 1px solid var(--border-primary);
  border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
  margin-bottom: 0;
}
.card-body  { flex: 1 1 auto; padding: var(--spacing-6); }
.card-footer {
  padding: var(--spacing-6);
  background: linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);
  border-top: 1px solid var(--border-primary);
  border-radius: 0 0 var(--radius-2xl) var(--radius-2xl);
}
.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 variants */
.card-premium {
  background: var(--bg-secondary);
  border: 1px solid var(--border-gold);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-slow);
}
.card-premium:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-luxury);
  border-color: var(--color-gold);
}

.card-dark {
  background: var(--gradient-card);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-lg);
  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); }

/* Navy card */
.card-ocean,
.card-navy {
  background: var(--gradient-primary);
  border: 1px solid var(--color-navy);
  color: var(--text-white);
  box-shadow: var(--shadow-navy);
}
.card-ocean .card-title, .card-navy .card-title { color: var(--color-white); }
.card-ocean .card-text,  .card-navy .card-text  { color: var(--color-white-80); }
.card-ocean:hover, .card-navy:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-gold);
  border-color: var(--color-gold);
}

.card-golden {
  background: var(--gradient-gold);
  border: 1px solid var(--color-gold);
  color: var(--bg-primary);
  box-shadow: var(--shadow-gold);
}
.card-golden .card-title { color: var(--bg-primary); }
.card-golden .card-text  { color: rgba(10, 10, 10, 0.85); }
.card-golden:hover {
  transform: translateY(-6px);
  box-shadow: var(--glow-gold);
}

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

/* ============================================================
   10. BADGE SYSTEM
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-1);
  padding: var(--spacing-1) var(--spacing-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.badge-gold,
.badge-golden {
  background: var(--color-gold-bg);
  color: var(--color-gold);
  border: 1px solid rgba(201, 168, 76, 0.35);
}
.badge-navy,
.badge-ocean {
  background: rgba(26, 35, 50, 0.35);
  color: var(--color-navy-soft);
  border: 1px solid rgba(26, 35, 50, 0.40);
}
.badge-glass {
  background: var(--gradient-glass);
  backdrop-filter: blur(8px);
  color: var(--text-primary);
  border: 1px solid var(--color-white-20);
}

/* ============================================================
   11. FORM ELEMENTS
   ============================================================ */
.form-control {
  display: block;
  width: 100%;
  padding: var(--spacing-4);
  font-size: var(--text-base);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  background-color: var(--bg-secondary);
  border: 1px solid var(--border-primary);
  border-radius: var(--radius-xl);
  transition: var(--transition-elegant);
}
.form-control:focus {
  color: var(--text-primary);
  background-color: var(--bg-secondary);
  border-color: var(--color-gold);
  outline: 0;
  box-shadow: 0 0 0 0.2rem var(--color-gold-glow-sm);
}
.form-control::placeholder { color: var(--text-lighter); opacity: 1; }
.form-control:disabled { background-color: var(--bg-tertiary); opacity: 0.6; }

.form-label {
  display: block;
  margin-bottom: var(--spacing-2);
  font-family: var(--font-primary);
  font-weight: var(--font-weight-semibold);
  color: var(--text-secondary);
  letter-spacing: 0.01em;
}
.form-label.required::after { content: '*'; color: var(--color-error); margin-left: 4px; }

.form-select {
  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='%23c9a84c' 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;
}

/* ============================================================
   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);
  background: var(--color-success-light);
  border-color: rgba(16, 185, 129, 0.25);
  border-left-color: var(--color-success);
}
.alert-warning {
  color: var(--color-warning);
  background: var(--color-warning-light);
  border-color: rgba(245, 158, 11, 0.25);
  border-left-color: var(--color-warning);
}
.alert-danger,
.alert-error {
  color: var(--color-error);
  background: var(--color-error-light);
  border-color: rgba(239, 68, 68, 0.25);
  border-left-color: var(--color-error);
}
.alert-info {
  color: var(--color-info);
  background: var(--color-info-light);
  border-color: rgba(59, 130, 246, 0.20);
  border-left-color: var(--color-info);
}

/* ============================================================
   13. DECORATIVE ELEMENTS
   ============================================================ */
/* Prestige Gold line separator */
.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; }

/* Dividers */
.divider-ocean,
.divider-brand {
  height: 2px;
  background: var(--gradient-gold);
  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;
}

/* Shimmer text */
.text-shimmer {
  background: linear-gradient(90deg, var(--color-gold-dark) 0%, var(--color-gold-light) 25%, var(--color-gold) 50%, var(--color-gold-light) 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
   ============================================================ */
.navbar-ocean {
  background: rgba(18, 18, 18, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--color-white-08);
  transition: var(--transition-elegant);
}

/* ============================================================
   15. HERO SECTIONS
   ============================================================ */
.hero-ocean {
  background: var(--gradient-hero);
  color: var(--text-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='%23c9a84c' fill-opacity='0.015'%3E%3Ccircle cx='30' cy='30' r='4'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}

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

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

/* Progress bars */
.progress-modern {
  height: var(--spacing-3);
  background: var(--bg-secondary);
  border-radius: var(--radius-full);
  overflow: hidden;
  box-shadow: var(--shadow-inner);
}
.progress-bar-ocean,
.progress-bar-brand {
  height: 100%;
  background: var(--gradient-gold);
  border-radius: var(--radius-full);
  transition: width var(--transition-smooth);
  position: relative;
  overflow: hidden;
}
.progress-bar-gold  { background: var(--gradient-gold); }
.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.25), 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(--bg-secondary);
  border: 1px solid var(--border-gold);
  color: var(--text-primary);
  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(--border-gold);
  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: 1px solid var(--border-gold);
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-2xl);
  background: var(--gradient-card);
  overflow: hidden;
}
.modal-ocean .modal-header {
  background: var(--gradient-primary);
  border-bottom: 1px solid var(--border-gold);
  color: var(--text-white);
  padding: var(--spacing-6);
}
.modal-ocean .modal-title {
  font-family: var(--font-display);
  font-weight: var(--font-weight-semibold);
  font-size: var(--text-2xl);
  color: var(--text-primary);
}
.modal-ocean .modal-body { padding: var(--spacing-8); }
.modal-ocean .modal-footer {
  background: var(--bg-tertiary);
  border-top: 1px solid var(--border-primary);
  padding: var(--spacing-6);
}

/* Badge variants (premium section) */
.badge-ocean { background: rgba(26, 35, 50, 0.35); color: var(--color-navy-soft); border: 1px solid rgba(26, 35, 50, 0.40); }
.badge-gold, .badge-golden { background: var(--color-gold-bg); color: var(--color-gold); border: 1px solid var(--border-gold); }
.badge-glass {
  background: var(--gradient-glass);
  backdrop-filter: blur(8px);
  color: var(--text-primary);
  border: 1px solid var(--color-white-20);
}

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

/* Destination Cards */
.destination-card {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  background: var(--gradient-card);
  box-shadow: var(--shadow-lg);
  transition: var(--transition-premium);
  border: 1px solid var(--border-light);
}
.destination-card:hover {
  transform: translateY(-10px) scale(1.02);
  box-shadow: var(--glow-premium);
  border-color: var(--border-gold);
}
.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.1); }
.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(--bg-primary);
  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(--gradient-card);
  border-radius: var(--radius-3xl);
  padding: var(--spacing-8);
  box-shadow: var(--shadow-premium);
  transition: var(--transition-premium);
  border: 1px solid var(--border-light);
  position: relative;
  overflow: hidden;
}
.tour-package::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  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); }

/* Testimonial Cards */
.testimonial-card {
  background: var(--gradient-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius-2xl);
  padding: var(--spacing-8);
  text-align: center;
  position: relative;
  border: 1px solid var(--color-white-12);
  transition: var(--transition-elegant);
}
.testimonial-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-2xl); }
.testimonial-card .quote-icon { font-size: var(--text-4xl); color: var(--color-gold); margin-bottom: var(--spacing-4); }
.testimonial-card .avatar {
  width: 80px; height: 80px;
  border-radius: var(--radius-full);
  border: 3px solid var(--color-gold);
  margin: var(--spacing-6) auto var(--spacing-4);
  box-shadow: var(--shadow-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-gold); }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: var(--transition-smooth); }
.gallery-item:hover img { transform: scale(1.1); }
.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(--text-white);
  font-size: var(--text-2xl);
  font-weight: var(--font-weight-bold);
}
.gallery-item:hover .overlay { opacity: 1; }

/* Booking Form */
.booking-form {
  background: var(--gradient-card);
  border-radius: var(--radius-3xl);
  padding: var(--spacing-10);
  box-shadow: var(--shadow-2xl);
  border: 1px 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(--text-primary);
  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(--bg-secondary);
  color: var(--text-white);
  padding: var(--spacing-16) 0;
  position: relative;
}
.stat-item { text-align: center; padding: var(--spacing-6); }
.stat-number {
  font-size: var(--text-5xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-gold);
  display: block;
  margin-bottom: var(--spacing-2);
  font-family: var(--font-display);
}
.stat-label {
  font-size: var(--text-lg);
  font-weight: var(--font-weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
}

/* Feature Highlights */
.feature-highlight {
  display: flex;
  align-items: center;
  padding: var(--spacing-6);
  background: var(--gradient-card);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-md);
  transition: var(--transition-elegant);
  border-left: 3px solid var(--color-gold);
  border: 1px solid var(--border-primary);
  border-left: 3px solid var(--color-gold);
  margin-bottom: var(--spacing-4);
}
.feature-highlight:hover { transform: translateX(8px); box-shadow: var(--shadow-lg); border-left-color: var(--color-gold); }
.feature-highlight .icon {
  width: 60px; height: 60px;
  background: rgba(201, 168, 76, 0.10);
  border: 1px solid rgba(201, 168, 76, 0.30);
  border-radius: var(--radius-xl);
  display: flex; align-items: center; justify-content: center;
  color: var(--color-gold);
  font-size: var(--text-2xl);
  margin-right: var(--spacing-6);
  flex-shrink: 0;
}
.feature-highlight .content h3 { color: var(--text-primary); 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); }

/* ============================================================
   19. UTILITY: TEXT
   ============================================================ */
.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(--text-white)     !important; }
.text-dark      { color: var(--text-primary)   !important; }
.text-navy      { color: var(--color-navy-soft)!important; }
.text-gold      { color: var(--color-gold)     !important; }
.text-blue      { color: var(--color-navy-soft)!important; }
.text-orange    { color: var(--color-gold)     !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; }

/* Legacy text aliases */
.text-ocean     { color: var(--color-navy-soft) !important; }
.text-golden    { color: var(--color-gold)      !important; }
.text-teal      { color: var(--color-navy-soft) !important; }
.text-emerald   { color: var(--color-success)   !important; }

/* Gradient text */
.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: linear-gradient(135deg, var(--text-primary), var(--color-gold));
  -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-navy-soft); text-shadow: 0 0 20px rgba(26, 35, 50, 0.50); }
.text-golden-glow { color: var(--color-gold); text-shadow: 0 0 20px rgba(201, 168, 76, 0.55); }

/* 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-muted); line-height: var(--leading-relaxed); }
.text-price     { font-size: var(--text-3xl); font-weight: var(--font-weight-bold); color: var(--color-gold); }
.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(0, 0, 0, 0.60); }

/* ============================================================
   20. UTILITY: BACKGROUND
   ============================================================ */
.bg-primary   { background-color: var(--bg-primary)   !important; }
.bg-secondary { background-color: var(--bg-secondary) !important; }
.bg-tertiary  { background-color: var(--bg-tertiary)  !important; }
.bg-dark      { background-color: var(--bg-dark)      !important; }
.bg-navy      { background-color: var(--color-navy)   !important; }
.bg-gold      { background-color: var(--color-gold)   !important; }

/* Legacy aliases */
.bg-ocean     { background-color: var(--bg-secondary)    !important; }
.bg-blue      { background-color: var(--color-navy)      !important; }
.bg-orange    { background-color: var(--color-gold)      !important; }
.bg-teal      { background-color: var(--color-navy-soft) !important; }
.bg-red       { background-color: var(--color-error)     !important; }
.bg-golden    { background-color: var(--color-gold-bg)   !important; }
.bg-ocean-light   { background-color: rgba(26, 35, 50, 0.12) !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-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%, var(--color-gold-glow-sm) 0%, transparent 50%),
              radial-gradient(circle at 75% 75%, rgba(26, 35, 50, 0.08) 0%, transparent 50%),
              var(--bg-primary);
}
.bg-ocean-pattern {
  background: radial-gradient(circle at 25% 25%, rgba(26, 35, 50, 0.12) 0%, transparent 60%),
              radial-gradient(circle at 75% 75%, var(--color-gold-glow-sm) 0%, transparent 60%),
              var(--bg-primary);
}

/* Glass morphism */
.glass-ocean   { background: var(--glass-navy);   backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(26, 35, 50, 0.35); border-radius: var(--radius-2xl); box-shadow: var(--shadow-lg); }
.glass-golden  { background: var(--glass-gold);   backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid rgba(201, 168, 76, 0.20); border-radius: var(--radius-2xl); box-shadow: var(--shadow-gold); }
.glass-dark    { background: var(--glass-dark);   backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid var(--color-white-10);    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(16, 185, 129, 0.20); border-radius: var(--radius-2xl); box-shadow: var(--shadow-lg); }

/* Content containers */
.content-ocean {
  max-width: 900px; margin: 0 auto;
  padding: var(--spacing-10);
  background: var(--gradient-card);
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-premium);
  border: 1px solid var(--border-gold);
}
.content-glass {
  background: var(--gradient-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--color-white-12);
}

/* ============================================================
   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-navy)  !important; }
.border-golden   { border-color: var(--color-gold)  !important; }
.border-blue     { border-color: var(--color-navy)  !important; }
.border-orange   { border-color: var(--color-gold)  !important; }
.border-teal     { border-color: var(--color-navy-soft) !important; }

.border-modern        { border: 1px solid var(--border-gold) !important; border-radius: var(--radius-xl) !important; }
.border-golden-accent { border: 1px solid var(--color-gold)  !important; border-radius: var(--radius-xl) !important; box-shadow: var(--shadow-gold) !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-navy)  !important; }
.shadow-golden { box-shadow: var(--shadow-gold)  !important; }
.shadow-blue   { box-shadow: var(--shadow-navy)  !important; }
.shadow-orange { box-shadow: var(--shadow-gold)  !important; }
.shadow-teal   { box-shadow: var(--shadow-navy)  !important; }

/* ============================================================
   23. UTILITY: SPACING & MISC
   ============================================================ */
.mt-auto  { margin-top: auto; }
.mb-0     { margin-bottom: 0 !important; }
.p-0      { padding: 0 !important; }
.w-100    { width: 100%; }
.h-100    { height: 100%; }
.overflow-hidden  { overflow: hidden; }
.position-relative{ position: relative; }
.position-absolute{ position: absolute; }
.d-none   { display: none !important; }
.d-block  { display: block; }
.d-flex   { display: flex; }
.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }
.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;
}
.d-print-none  { display: none !important; }
.d-print-block { display: block !important; }
.no-print      { display: none !important; }

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

/* Image effects */
.image-ocean {
  border-radius: var(--radius-2xl); overflow: hidden;
  box-shadow: var(--shadow-lg); transition: var(--transition-premium);
  border: 1px solid var(--border-light);
}
.image-ocean:hover  { transform: scale(1.02); box-shadow: var(--glow-gold); border-color: var(--border-gold); }
.image-golden {
  border-radius: var(--radius-xl);
  border: 2px 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-lift       { transition: var(--transition-elegant); }
.hover-lift:hover { transform: translateY(-8px); }
.hover-scale      { transition: var(--transition-elegant); }
.hover-scale:hover{ transform: scale(1.05); }
.hover-glow:hover { box-shadow: var(--glow-gold); }

/* 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: var(--gradient-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid var(--color-white-12);
}

/* Float/parallax */
.float-ocean   { animation: waveMotion 8s ease-in-out infinite; }
.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.7;
}

/* 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(--text-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-gold), transparent); }
[dir="rtl"] .section-label::after  { left: auto; right: 100%; background: linear-gradient(90deg, transparent, var(--color-gold)); }

/* ============================================================
   24. ANIMATIONS
   ============================================================ */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(40px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-40px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInScale {
  from { opacity: 0; transform: scale(0.9); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes slideInLeft {
  from { opacity: 0; transform: translateX(-40px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(40px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes slideInDown {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes waveMotion {
  0%, 100% { transform: translateY(0px)   rotate(0deg); }
  25%       { transform: translateY(-5px) rotate(1deg); }
  75%       { transform: translateY(3px)  rotate(-1deg); }
}
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.7; }
}
@keyframes pulse-gold {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201, 168, 76, 0.4); }
  50%       { box-shadow: 0 0 0 10px rgba(201, 168, 76, 0); }
}
@keyframes bounce {
  0%, 20%, 53%, 80%, 100% { transform: translate3d(0,0,0); }
  40%, 43%                 { transform: translate3d(0,-20px,0); }
  70%                      { transform: translate3d(0,-10px,0); }
  90%                      { transform: translate3d(0,-4px,0); }
}
@keyframes rotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes rcSpinRing {
  to { transform: rotate(360deg); }
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}
@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%; }
}
@keyframes goldPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201, 168, 76, 0.35); }
  50%       { box-shadow: 0 0 0 12px rgba(201, 168, 76, 0); }
}

/* Animation utility classes */
.animate-fade-up      { animation: fadeInUp 0.8s ease-out; }
.animate-fade-down    { animation: fadeInDown 0.8s 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-gold   { animation: pulse-gold 2s ease infinite; }
.animate-gold-pulse   { animation: goldPulse 2s ease infinite; }
.animate-shimmer {
  background: linear-gradient(90deg, var(--bg-secondary) 25%, var(--color-onyx-600) 50%, var(--bg-secondary) 75%);
  background-size: 200% 100%;
  animation: shimmer 2s infinite;
}

/* ============================================================
   25. 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;
}

/* ============================================================
   26. SCROLLBAR
   ============================================================ */
::-webkit-scrollbar       { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg-tertiary); border-radius: var(--radius-full); }
::-webkit-scrollbar-thumb { background: var(--color-onyx-500); border-radius: var(--radius-full); }
::-webkit-scrollbar-thumb:hover { background: var(--color-gold-dark); }

/* ============================================================
   27. SELECTION & FOCUS
   ============================================================ */
::selection      { background: var(--color-gold-glow); color: var(--color-onyx-900); }
::-moz-selection { background: var(--color-gold-glow); color: var(--color-onyx-900); }

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

/* ============================================================
   28. 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); }
}

/* ============================================================
   29. 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-gold) !important; }
  .form-control, .form-select { border: 2px solid var(--border-gold) !important; }
  .btn       { border: 2px solid currentColor !important; }
}

/* ============================================================
   30. 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 #000 !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; }
}

/* ============================================================
   END OF MAIN.CSS — RAVIERA CEYLON v1.0.0
   www.ravieraceylon.com
   Brand: Inbound Tourism · Heritage · Luxury
   Palette: Obsidian · Prestige Gold · Charcoal · Warm Pearl
   ============================================================ */

/* ============================================================
   ADDENDUM A — COMPLETE BACKWARD COMPAT BRIDGE (PART 2)
   Additional aliases ensuring full parity with all child CSS
   files and legacy naming conventions.
   ============================================================ */
:root {

  /* ── Color green / emerald scale (used in sustainability, eco sections) */
  --color-green:          #10b981;
  --color-green-light:    #34d399;
  --color-green-pale:     rgba(16, 185, 129, 0.15);
  --color-green-bg:       rgba(16, 185, 129, 0.08);
  --color-green-dark:     #059669;
  --color-green-rgb:      16, 185, 129;

  /* ── Color gray scale (full MC-compatible scale, mapped to dark slate) */
  --color-gray-50:        var(--color-slate-900);
  --color-gray-100:       var(--color-slate-800);
  --color-gray-200:       var(--color-slate-700);
  --color-gray-300:       var(--color-slate-600);
  --color-gray-400:       var(--color-slate-500);
  --color-gray-500:       var(--color-slate-400);
  --color-gray-600:       var(--color-slate-300);
  --color-gray-700:       var(--color-slate-200);
  --color-gray-800:       var(--color-slate-100);
  --color-gray-900:       var(--color-slate-50);

  /* ── Elegant gray aliases (used in some child files) */
  --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 "orange" → gold aliases (full scale) */
  --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(201, 168, 76, 0.04);
  --orange-100:           rgba(201, 168, 76, 0.08);
  --orange-200:           rgba(201, 168, 76, 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" → dark navy aliases (full scale) */
  --primary-teal:         var(--color-navy-soft);
  --secondary-teal:       var(--color-navy-light);
  --accent-teal:          var(--color-navy-border);
  --dark-teal:            var(--color-navy-mid);
  --light-teal:           rgba(26, 35, 50, 0.20);
  --teal-50:              rgba(26, 35, 50, 0.04);
  --teal-100:             rgba(26, 35, 50, 0.08);
  --teal-200:             rgba(26, 35, 50, 0.15);
  --teal-300:             rgba(26, 35, 50, 0.30);
  --teal-400:             var(--color-navy-border);
  --teal-500:             var(--color-navy-soft);
  --teal-600:             var(--color-navy-light);
  --teal-700:             var(--color-navy-mid);
  --teal-800:             var(--color-navy);
  --teal-900:             var(--color-navy-deep);

  /* ── Ocean-theme name aliases → RC equivalents */
  --primary-ocean-blue:            var(--color-navy);
  --primary-ocean-blue-light:      var(--color-navy-light);
  --primary-ocean-blue-dark:       var(--color-navy-mid);
  --primary-ocean-blue-darker:     var(--color-navy-deep);
  --primary-ocean-blue-rgb:        var(--color-navy-rgb);
  --primary-emerald:               var(--color-green);
  --primary-emerald-light:         var(--color-green-light);
  --primary-emerald-dark:          var(--color-green-dark);
  --primary-emerald-rgb:           var(--color-green-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 (full set) */
  --gradient-ocean:       var(--gradient-primary);
  --gradient-green:       linear-gradient(135deg, var(--color-green) 0%, var(--color-green-light) 100%);
  --gradient-emerald:     var(--gradient-green);

  /* ── Shadow aliases (full set) */
  --shadow-green:         0 4px 20px rgba(16, 185, 129, 0.25);
  --shadow-emerald:       var(--shadow-green);
  --shadow-golden:        var(--shadow-gold);
  --shadow-ocean:         var(--shadow-navy);

  /* ── Glow aliases (full set) */
  --glow-green:           0 8px 40px rgba(16, 185, 129, 0.30);
  --glow-emerald:         var(--glow-green);
  --glow-golden:          var(--glow-gold);
  --glow-ocean:           var(--glow-navy);
  --text-green:           var(--color-green);

  /* ── Background aliases (full set) */
  --bg-teal:              var(--color-navy-soft);
  --bg-teal-light:        rgba(26, 35, 50, 0.15);
  --bg-orange:            var(--color-gold);
  --bg-orange-light:      var(--color-gold-bg);
  --bg-overlay-orange:    rgba(201, 168, 76, 0.80);
  --bg-overlay-teal:      rgba(26, 35, 50, 0.80);
  --bg-emerald-light:     rgba(16, 185, 129, 0.08);
  --bg-green-light:       rgba(16, 185, 129, 0.08);

  /* ── Misc legacy names */
  --premium-charcoal:       var(--color-slate-500);
  --premium-charcoal-light: var(--color-slate-400);
  --premium-charcoal-dark:  var(--color-slate-600);
  --sophisticated-ivory:    var(--bg-secondary);
  --elegant-pearl:          var(--bg-tertiary);
  --luxury-cream:           var(--bg-secondary);
  --luxury-coral:           var(--color-error);
}

/* ============================================================
   ADDENDUM B — MISSING CSS CLASSES
   Full parity with all utility classes in the Mindora
   white-theme main.css.
   ============================================================ */

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

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

.btn-outline-primary-navy {
  background: transparent;
  border: 1.5px solid rgba(255, 255, 255, 0.40);
  color: var(--text-primary);
}
.btn-outline-primary-navy:hover {
  border-color: var(--color-gold);
  color: var(--color-gold);
  background: rgba(201, 168, 76, 0.08);
  transform: translateY(-2px);
}

/* Emerald card */
.card-emerald {
  background: var(--gradient-green);
  border: 1px solid var(--color-green);
  color: var(--color-white);
  box-shadow: var(--shadow-green);
}
.card-emerald .card-title { color: var(--color-white); }
.card-emerald .card-text  { color: rgba(255, 255, 255, 0.90); }
.card-emerald:hover {
  transform: translateY(-6px);
  box-shadow: var(--glow-green);
}

/* Badge emerald / green */
.badge-emerald,
.badge-green {
  background: var(--color-green-bg);
  color: var(--color-green);
  border: 1px solid rgba(16, 185, 129, 0.35);
}

/* Text green */
.text-green   { color: var(--color-green)   !important; }

/* Background green / emerald */
.bg-green     { background-color: var(--color-green)      !important; }
.bg-emerald   { background-color: var(--color-green-dark) !important; }
.bg-emerald-light { background-color: var(--color-green-bg) !important; }
.bg-gradient-emerald { background: var(--gradient-green)  !important; }

/* Border emerald */
.border-emerald { border-color: var(--color-green) !important; }

/* Shadow emerald */
.shadow-emerald { box-shadow: var(--shadow-green) !important; }

/* Icon emerald */
.icon-emerald {
  background: rgba(16, 185, 129, 0.10);
  border: 1px solid rgba(16, 185, 129, 0.30);
  color: var(--color-green);
}
.icon-emerald:hover { box-shadow: var(--glow-green); }

/* Progress bar green */
.progress-bar-green { background: var(--gradient-green); }

/* Float emerald */
.float-emerald { animation: waveMotion 6s ease-in-out infinite reverse; }

/* Link aliases */
.link-ocean  { color: var(--color-gold); font-weight: var(--font-weight-medium); }
.link-ocean:hover { color: var(--color-gold-light); }
.link-golden { color: var(--color-gold); font-weight: var(--font-weight-semibold); }
.link-golden:hover { color: var(--color-gold-light); }

/* Waves background pattern */
.bg-waves-pattern {
  background: repeating-linear-gradient(45deg,
    transparent, transparent 10px,
    rgba(201, 168, 76, 0.02) 10px,
    rgba(201, 168, 76, 0.02) 20px),
    var(--bg-primary);
}

/* ============================================================
   31. DARK MODE OVERRIDE
   RC is already a dark theme. This section ensures that if
   a browser/OS is in dark mode, the dark theme is preserved
   correctly (no accidental light-mode overrides).
   ============================================================ */
@media (prefers-color-scheme: dark) {
  /* RC is already dark — no overrides needed for backgrounds/text.
     Only ensure any Bootstrap or third-party light defaults are
     suppressed where needed. */
  .card {
    background: var(--gradient-card);
    border-color: var(--border-primary);
    color: var(--text-primary);
  }
  .form-control {
    background-color: var(--bg-secondary);
    color: var(--text-primary);
    border-color: var(--border-primary);
  }
  .glass-ocean, .glass-emerald, .glass-golden, .glass-dark {
    background: var(--gradient-glass);
    border-color: var(--color-white-12);
  }
}
