/*@font-face {
  font-family: 'Playfair Display';
  src: url("../fonts/PlayfairDisplay-Black.eot");
  src: url("../fonts/PlayfairDisplay-Black.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplay-Black.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Black.woff") format("woff"), url("../fonts/PlayfairDisplay-Black.ttf") format("truetype");
  font-weight: 900;
  font-style: normal; }
@font-face {
  font-family: 'Playfair Display';
  src: url("../fonts/PlayfairDisplay-BlackItalic.eot");
  src: url("../fonts/PlayfairDisplay-BlackItalic.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplay-BlackItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-BlackItalic.woff") format("woff"), url("../fonts/PlayfairDisplay-BlackItalic.ttf") format("truetype");
  font-weight: 900;
  font-style: Italic; }
@font-face {
  font-family: 'Playfair Display';
  src: url("../fonts/PlayfairDisplay-Bold.eot");
  src: url("../fonts/PlayfairDisplay-Bold.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplay-Bold.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Bold.woff") format("woff"), url("../fonts/PlayfairDisplay-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal; }
@font-face {
  font-family: 'Playfair Display';
  src: url("../fonts/PlayfairDisplay-BoldItalic.eot");
  src: url("../fonts/PlayfairDisplay-BoldItalic.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplay-BoldItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-BoldItalic.woff") format("woff"), url("../fonts/PlayfairDisplay-BoldItalic.ttf") format("truetype");
  font-weight: 700;
  font-style: Italic; }*/
@font-face {
  font-family: 'Playfair Display Regular';
  src: url("../fonts/playfair/PlayfairDisplay-Regular.eot");
  src: url("../fonts/playfair/PlayfairDisplay-Regular.eot?#iefix") 
  format("embedded-opentype"), 
  url("../fonts/playfair/PlayfairDisplay-Regular.woff2") format("woff2"), 
  url("../fonts/playfair/PlayfairDisplay-Regular.woff") format("woff"), 
  url("../fonts/playfair/PlayfairDisplay-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal; }
/*@font-face {
  font-family: 'Playfair Display';
  src: url("../fonts/PlayfairDisplay-Italic.eot");
  src: url("../fonts/PlayfairDisplay-Italic.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplay-Italic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Italic.woff") format("woff"), url("../fonts/PlayfairDisplay-Italic.ttf") format("truetype");
  font-weight: 400;
  font-style: Italic; }
@font-face {
  font-family: 'Playfair Display SC';
  src: url("../fonts/PlayfairDisplaySC-Black.eot");
  src: url("../fonts/PlayfairDisplaySC-Black.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplaySC-Black.woff2") format("woff2"), url("../fonts/PlayfairDisplaySC-Black.woff") format("woff"), url("../fonts/PlayfairDisplaySC-Black.ttf") format("truetype");
  font-weight: 900;
  font-style: normal; }
@font-face {
  font-family: 'Playfair Display SC';
  src: url("../fonts/PlayfairDisplaySC-BlackItalic.eot");
  src: url("../fonts/PlayfairDisplaySC-BlackItalic.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplaySC-BlackItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplaySC-BlackItalic.woff") format("woff"), url("../fonts/PlayfairDisplaySC-BlackItalic.ttf") format("truetype");
  font-weight: 900;
  font-style: Italic; }
@font-face {
  font-family: 'Playfair Display SC';
  src: url("../fonts/PlayfairDisplaySC-Regular.eot");
  src: url("../fonts/PlayfairDisplaySC-Regular.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplaySC-Regular.woff2") format("woff2"), url("../fonts/PlayfairDisplaySC-Regular.woff") format("woff"), url("../fonts/PlayfairDisplaySC-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal; }
@font-face {
  font-family: 'Playfair Display SC';
  src: url("../fonts/PlayfairDisplaySC-Italic.eot");
  src: url("../fonts/PlayfairDisplaySC-Italic.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplaySC-Italic.woff2") format("woff2"), url("../fonts/PlayfairDisplaySC-Italic.woff") format("woff"), url("../fonts/PlayfairDisplaySC-Italic.ttf") format("truetype");
  font-weight: 400;
  font-style: Italic; }
@font-face {
  font-family: 'Playfair Display SC';
  src: url("../fonts/PlayfairDisplaySC-Bold.eot");
  src: url("../fonts/PlayfairDisplaySC-Bold.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplaySC-Bold.woff2") format("woff2"), url("../fonts/PlayfairDisplaySC-Bold.woff") format("woff"), url("../fonts/PlayfairDisplaySC-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal; }
@font-face {
  font-family: 'Playfair Display SC';
  src: url("../fonts/PlayfairDisplaySC-BoldItalic.eot");
  src: url("../fonts/PlayfairDisplaySC-BoldItalic.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplaySC-BoldItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplaySC-BoldItalic.woff") format("woff"), url("../fonts/PlayfairDisplaySC-BoldItalic.ttf") format("truetype");
  font-weight: 700;
  font-style: Italic; 
}
*/




/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/montserrat/montserrat-regular-webfont.eot");
  src: url("../fonts/montserrat/montserrat-regular-webfont.eot?#iefix") 
  format("embedded-opentype"), url("../fonts/montserrat/montserrat-regular-webfont.woff2") 
  format("woff2"), url("../fonts/montserrat/montserrat-regular-webfont.woff") 
  format("woff"), url("../fonts/montserrat/montserrat-regular-webfont.ttf") 
  format("truetype");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215, U+E0FF, U+EFFD, U+F000;
}
/* latin */
/*@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/montserrat-bold-webfont.eot");
  src: url("../fonts/montserrat-bold-webfont.eot?#iefix") format("embedded-opentype"), url("../fonts/montserrat-bold-webfont.woff2") format("woff2"), url("../fonts/montserrat-bold-webfont.woff") format("woff"), url("../fonts/montserrat-bold-webfont.ttf") format("truetype");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2212, U+2215, U+E0FF, U+EFFD, U+F000;
}*/

/* ---------- Design Tokens (CSS Variables)033266 ---------- */
:root {
  
      
    --secondary-color: #F29900;


  --bg-color: #FAFAFA;
  --form-border-color:  #d1dbe7;
  
  --hover-color: #02254d;
  --background: #f9fafb;
  --border-color: #ddd;
  --success-color: #188038;
  --error-color: #d93025;
 




  --accent-color: #00bcd4;
  --accent-color1: #F5F5DC;
  --accent-color2: #D4AF37;
  --accent-color3: #2C3E50;

  --muted-text: #777;
  --background-color: #f9f9f9;  
  --danger-color: #e74c3c;
  --success-color: #2ecc71;
  --border-color: #ddd;
  
  
  /* Final */
  --light: #fff;
  --dark: #000;
  --bg-blue:#f4f9fc;
  --heading-color1: #033266;
  --blue: #033266;
  --white: #fff;
  --yellow: #fcae24;
   
  --paragraph-dark-color: #1e3f5f;
  --form-color: #0f2e5a;
  --form-indicator: #d9534f;

  
  /* Final */
  /*--font-family1: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;*/
  --font-family2: "Oswald", sans-serif;


  --font-family1: 'Merriweather', serif;"
  --font-family3: "Open Sans", sans-serif;

      --font-family3: 'Poppins', sans-serif;
      
      --font-family4: 'EB Garamond', serif;
      --font-family5: 'IBM Plex Serif', sans-serif;

  --font-heading: 'Montserrat', sans-serif;

  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 2rem;

  
  --heading-size: clamp(1.5rem, 2.5vw, 2.5rem);

  --transition-fast: 0.2s ease;
  --transition-base: 0.3s ease;

  --z-header: 1000;
  --z-overlay: 1100;
  --z-modal: 1200;

    /* Colors */
    --deep-plum: #4A4A6A;
    --soft-teal: #66B2B2;
    --soft-cloud: #F0F0F5;
    --light-grayish-blue: #E8E8EE;
    --bright-gold: #FFD700;
    --muted-lavender: #5C5C7A;
    --pure-white: #FFFFFF;


    --gray-50: #111827;
    --gray-100: #1f2937;
    --gray-200: #374151;
    --gray-300: #4b5563;
    --gray-400: #6b7280;
    --gray-500: #9ca3af;
    --gray-600: #d1d5db;
    --gray-700: #e5e7eb;
    --gray-800: #f3f4f6;
    --gray-900: #f9fafb;
    

    /* Font Sizes - Fluid Typography */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.375vw, 1rem);
  --text-base: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.625vw, 1.25rem);
  --text-xl: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
  --text-2xl: clamp(1.5rem, 1.3rem + 1vw, 1.875rem);
  --text-3xl: clamp(1.875rem, 1.6rem + 1.375vw, 2.25rem);
  --text-4xl: clamp(2.25rem, 1.9rem + 1.75vw, 3rem);
  --text-5xl: clamp(3rem, 2.5rem + 2.5vw, 4rem);

  /* Font Weights */
  --font-light: 300;
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --font-bold: 700;
  --font-extrabold: 800;

  /* Line Heights */
  --leading-tight: 1.25;
  --leading-snug: 1.375;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;
  --leading-loose: 2;

  /* Spacing Scale */
  --space-px: 1px;
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;
  --space-40: 10rem;
  --space-48: 12rem;
  --space-56: 14rem;
  --space-64: 16rem;

  /* Border Radius */
  --radius-none: 0;
  --radius-sm: 0.125rem;
  --radius-base: 0.25rem;
  --radius-md: 0.375rem;
  --radius-lg: 0.5rem;
  --radius-xl: 0.75rem;
  --radius-2xl: 1rem;
  --radius-3xl: 1.5rem;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-base: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);

  /* Transitions */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 300ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 500ms cubic-bezier(0.4, 0, 0.2, 1);

  /* Z-Index Scale */
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;

  /* Breakpoints (for reference in media queries) */
  --breakpoint-sm: 640px;
  --breakpoint-md: 768px;
  --breakpoint-lg: 1024px;
  --breakpoint-xl: 1280px;
  --breakpoint-2xl: 1536px;

  /* Container Max Widths */
  --container-sm: 640px;
  --container-md: 768px;
  --container-lg: 1024px;
  --container-xl: 1280px;
  --container-2xl: 1536px;
--container-3xl: 90%;




   /* Color Palette - Modern & Accessible */
  --primary-50: #f0f9ff;
  --primary-100: #e0f2fe;
  --primary-200: #bae6fd;
  --primary-300: #7dd3fc;
  --primary-400: #38bdf8;
  --primary-500: #0ea5e9;
  --primary-600: #0284c7;
  --primary-700: #0369a1;
  --primary-800: #075985;
  --primary-900: #0c4a6e;
  --primary-950: #082f49;

  --secondary-50: #fdf4ff;
  --secondary-100: #fae8ff;
  --secondary-200: #f5d0fe;
  --secondary-300: #f0abfc;
  --secondary-400: #e879f9;
  --secondary-500: #d946ef;
  --secondary-600: #c026d3;
  --secondary-700: #a21caf;
  --secondary-800: #86198f;
  --secondary-900: #701a75;
  --secondary-950: #4a044e;

  --accent-50: #fff7ed;
  --accent-100: #ffedd5;
  --accent-200: #fed7aa;
  --accent-300: #fdba74;
  --accent-400: #fb923c;
  --accent-500: #f97316;
  --accent-600: #ea580c;
  --accent-700: #c2410c;
  --accent-800: #9a3412;
  --accent-900: #7c2d12;
  --accent-950: #431407;

  /* Neutral Colors */
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;
  --gray-950: #030712;

  /* Semantic Colors */
  --success-50: #f0fdf4;
  --success-500: #22c55e;
  --success-600: #16a34a;
  --error-50: #fef2f2;
  --error-500: #ef4444;
  --error-600: #dc2626;
  --warning-50: #fffbeb;
  --warning-500: #f59e0b;
  --warning-600: #d97706;
  --info-50: #eff6ff;
  --info-500: #3b82f6;
  --info-600: #2563eb;

  /* Typography */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', Consolas, monospace;

  /* Font Sizes - Fluid Typography */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.375vw, 1rem);
  --text-base: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);
  --text-lg: clamp(1.125rem, 1rem + 0.625vw, 1.25rem);
  --text-xl: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
  --text-2xl: clamp(1.5rem, 1.3rem + 1vw, 1.875rem);
  --text-3xl: clamp(1.875rem, 1.6rem + 1.375vw, 2.25rem);
  --text-4xl: clamp(2.25rem, 1.9rem + 1.75vw, 3rem);
  --text-5xl: clamp(3rem, 2.5rem + 2.5vw, 4rem);

  /* Font Weights */
  --font-light: 300;
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --font-bold: 700;
  --font-extrabold: 800;

  /* Line Heights */
  --leading-tight: 1.25;
  --leading-snug: 1.375;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;
  --leading-loose: 2;

  /* Spacing Scale */
  --space-px: 1px;
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;
  --space-40: 10rem;
  --space-48: 12rem;
  --space-56: 14rem;
  --space-64: 16rem;

  /* Border Radius */
  --radius-none: 0;
  --radius-sm: 0.125rem;
  --radius-base: 0.25rem;
  --radius-md: 0.375rem;
  --radius-lg: 0.5rem;
  --radius-xl: 0.75rem;
  --radius-2xl: 1rem;
  --radius-3xl: 1.5rem;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-base: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);

  /* Transitions */
  --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-base: 300ms cubic-bezier(0.4, 0, 0.2, 1);
  --transition-slow: 500ms cubic-bezier(0.4, 0, 0.2, 1);

  /* Z-Index Scale */
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;

}

/* ---------- Dark Mode ---------- */
@media (prefers-color-scheme: dark) {
  :root {
    --background-color: #121212;
    --text-color: #f0f0f0;
    --border-color: #333;
  }
}

/* ---------- Reset & Base ---------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 100%;
  scroll-behavior: smooth;
}

.body-inner {
    overflow: hidden;
}



/* ---------- Typography ---------- */

  

/* Section Titles */
/*h2{
  font-family: var(--font-family1);
  font-size: 36px;
  font-weight: 600;
  color: #2C3E50;
  line-height: 1.3rem;
  letter-spacing:normal;
}*/
/* Section Titles */

/* Sub-Section Titles */
h3{
  font-family: var(--font-family1);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--accent-color3);
  line-height: 1.4rem;
  letter-spacing:normal;
}
/* Sub-Section Titles */

/* Smaller Headings/ Labels */
h4{
  font-family: var(--font-family1);
  font-size: 20px;
  font-weight: 500;
  color: #36454F;
  line-height: 1.5rem;
  letter-spacing:normal;
}
/* Smaller Headings/ Labels */

/* Smaller Headings/ Labels */
h5{
  font-family: var(--font-family1);
  font-size: 18px;
  font-weight: 500;
  color: #36454F;
  line-height: 1.5rem;
  letter-spacing:normal;
}
/* Smaller Headings/ Labels */

/* Smaller Headings/ Labels */
h6{
  font-family: var(--font-family1);
  font-size: 16px;
  font-weight: 500;
  color: #36454F;
  line-height: 1.5rem;
  letter-spacing:normal;
}
/* Smaller Headings/ Labels */





.subheading {
    text-align: center;
    margin-bottom: 2.5rem;
}
/* Body Text */

/* navigation Link */
a{
  font-family: var(--font-family1);
  font-size: 18px;
  font-weight: 500;
  color: var(--paragraph-color);
  line-height: 1.2rem;
  letter-spacing:0.05em;
}

a:hover{
  color: var(--primary-color);
  text-decoration: underline;
  text-underline-offset: 3px;
}
/* navigation Link */

button{
  font-family: var(--font-family1);
  font-size: 18px;
  font-weight: 700;
  color: var(--accent-color3);
  line-height: 1.2rem;
  letter-spacing:0.03em;
}



.btn {
  font-family: var(--font-family1);
  /*display: inline-block;
  padding: 0.75rem 1.5rem;
  font-size: 1rem;
      font-weight: 600; 
  background: var(--primary-color);
  color: var(--light);
  border: none;
  border-radius: 4px;
  cursor: pointer;*/
  transition: background var(--transition-fast), transform var(--transition-fast);
        position: relative;
      display: inline-block;
      /*padding: 14px 34px;*/
      font-size: 16px;
      font-weight: 600;
      /*border-radius: 50px;*/
      border: 2px solid transparent;
      cursor: pointer;
      overflow: hidden;
      transition: all 0.4s ease;
      text-align: center;
      text-decoration: none;
      letter-spacing: 0.5px;
      /*min-width: 150px;*/
}
.btn:hover {
  transform: translateY(-2px);
}
/* Button Sizes */
.btn-sm {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
}

.btn-lg {
  padding: var(--space-3) var(--space-6);
  font-size: var(--text-base);
}

.btn-xl {
  padding: var(--space-4) var(--space-8);
  font-size: var(--text-lg);
}

/* Button Variants */
.btn-primary {
  background: var(--primary-color);
/*  align-self: center;    
    color: #fff;
    text-decoration: none;
    font-weight: 600;
    padding: 0.85rem 2.5rem;
    border-radius: 30px;
    font-size: 1.1rem;
    transition: background-color 0.3s ease;
    box-shadow: 0 4px 10px rgb(3 50 102 / 0.3);*/
}

.btn-primary:hover:not(:disabled) {
  background-color: var(--primary-700);
  border-color: var(--primary-700);
}

.btn-secondary {
  background-color: var(--gray-600);
  color: white;
  border-color: var(--gray-600);
}

.btn-secondary:hover:not(:disabled) {
  background-color: var(--gray-700);
  border-color: var(--gray-700);
}

.button-secondary {
    background-color: var(--soft-teal);
    color: var(--pure-white);
}

.button-accent {
    background-color: var(--accent-orange);
    color: var(--pure-white);
}

.btn-outline {
  background-color: transparent;
  color: var(--secondary-color);
  border-color: var(--secondary-color);
}

.btn-outline:hover:not(:disabled) {
  background-color: var(--secondary-color);
  color: white;
}

.btn-ghost {
  background-color: transparent;
  color: var(--gray-700);
  border-color: transparent;
}

.btn-ghost:hover:not(:disabled) {
  background-color: var(--gray-100);
}



/* Typography utilities */
.text-xs { font-size: var(--text-xs); }
.text-sm { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-lg { font-size: var(--text-lg); }
.text-xl { font-size: var(--text-xl); }
.text-2xl { font-size: var(--text-2xl); }
.text-3xl { font-size: var(--text-3xl); }
.text-4xl { font-size: var(--text-4xl); }
.text-5xl { font-size: var(--text-5xl); }

.font-light { font-weight: var(--font-light); }
.font-normal { font-weight: var(--font-normal); }
.font-medium { font-weight: var(--font-medium); }
.font-semibold { font-weight: var(--font-semibold); }
.font-bold { font-weight: var(--font-bold); }

.text-left { text-align: left; }
.text-center { text-align: center; }
.text-right { text-align: right; }

/* Color utilities */
.text-gray-500 { color: var(--gray-500); }
.text-gray-600 { color: var(--gray-600); }
.text-gray-700 { color: var(--gray-700); }
.text-gray-900 { color: var(--gray-900); }
.text-primary-500 { color: var(--primary-500); }
.text-primary-600 { color: var(--primary-600); }
.text-white { color: white; }

/* Responsive adjustments */
/* --- Responsive Design --- */



/* Background Combinations */
.bg-blue{
  background-color: var(--bg-blue);
}

.bg-deep-plum {
    background-color: var(--deep-plum);
    color: var(--soft-cloud);
}

.bg-soft-teal {
    background-color: var(--soft-teal);
    color: var(--deep-plum);
}

.bg-light-grayish-blue {
    background-color: var(--light-grayish-blue);
    color: var(--deep-plum);
}

.bg-grey{
  background-color: #F5F5DC;
}

.bg-white { background-color: white; }
.bg-gray-50 { background-color: var(--gray-50); }
.bg-gray-100 { background-color: var(--gray-100); }
.bg-primary-500 { background-color: var(--primary-500); }
.bg-primary-600 { background-color: var(--primary-600); }
.bg-none {background: transparent;}
/* Border utilities */
.border { border-width: 1px; border-style: solid; }
.border-gray-200 { border-color: var(--gray-200); }
.border-gray-300 { border-color: var(--gray-300); }
.rounded { border-radius: var(--radius-base); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-xl { border-radius: var(--radius-xl); }
.rounded-full { border-radius: var(--radius-full); }

/* Shadow utilities */
.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow { box-shadow: var(--shadow-base); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }
.shadow-xl { box-shadow: var(--shadow-xl); }

@media (max-width: 600px) {
  .shadow-xl-mob{ 
    box-shadow: var(--shadow-xl);
  }

  .rounded-md-mob { 
    border-radius: var(--radius-md); 
  }
}

@media (min-width: 601px) and (max-width: 768px) {
  .shadow-xl-tab{ 
    box-shadow: var(--shadow-xl);
  }

  .rounded-md-tab { 
    border-radius: var(--radius-md); 
  }
}
/* Position utilities */
.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }
.top-0 { top: 0; }
.right-0 { right: 0; }
.bottom-0 { bottom: 0; }
.left-0 { left: 0; }

/* Display utilities */
.block { display: block; }
.inline-block { display: inline-block; }
.inline { display: inline; }
.hidden { display: none; }

/* Width and Height utilities */
.w-full { width: 100%; }
.w-auto { width: auto; }
.h-full { height: 100%; }
.h-auto { height: auto; }
.h-screen { height: 100vh; }

/* Transition utilities */
.transition { transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms; }
.transition-all { transition-property: all; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms; }
.duration-150 { transition-duration: 150ms; }
.duration-300 { transition-duration: 300ms; }
.ease-in-out { transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); }

/* Element Specific Colors */
.text-bright-gold {
    color: var(--bright-gold);
}

.text-muted-lavender {
    color: var(--muted-lavender);
}

.text-deep-plum {
    color: var(--deep-plum);
}

.border-soft-teal {
    border-color: var(--soft-teal);
}

div:has(> .bottom-right) {
    position: relative;
}

.bottom-right {
    position: absolute;
    bottom: 20px;
    right: 20px;
}

/* ---------- Containers ---------- */
.container {
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: var(--space-md);
}

.section {
  padding-block: var(--space-lg);
}

@media (min-width: 640px) {
  .container { max-width: var(--container-sm); }

}

@media (min-width: 768px) {
  .container { max-width: var(--container-md); }
}

@media (min-width: 1024px) {
  .container { max-width: var(--container-lg); }
}

@media (min-width: 1200px) {
  .container { max-width: var(--container-xl); }
  .container-fluid{ max-width: 90% }
}

@media (min-width: 1536px) {
  .container { max-width: var(--container-xl); }
  .container-fluid{ max-width: 90% }
}

@media (min-width: 1600px) {
  .container { max-width: var(--container-3xl); }
  .container-fluid{ max-width: 90% }
}

/* ---------- Grid & Flex ---------- */
.grid {
  display: -ms-grid;
  display: grid;
  gap: var(--space-md);
}

.flex {
  display: flex;
 /* flex-wrap: wrap;*/
  gap: var(--space-md);
}

/* Flexbox utilities */
.flex { display: flex; }
.inline-flex { display: inline-flex; }
.flex-col { flex-direction: column; }
.flex-row { flex-direction: row; }
.flex-wrap { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }
.items-start { align-items: flex-start; }
.items-center { align-items: center; }
.items-end { align-items: flex-end; }
.items-stretch { align-items: stretch; }
.justify-start { justify-content: flex-start; }
.justify-center { justify-content: center; }
.justify-end { justify-content: flex-end; }
.justify-between { justify-content: space-between; }
.justify-around { justify-content: space-around; }
.justify-evenly { justify-content: space-evenly; }
.flex-1 { flex: 1 1 0%; }
.flex-auto { flex: 1 1 auto; }
.flex-initial { flex: 0 1 auto; }
.flex-none { flex: none; }

/* Grid utilities */
.grid { display: grid; }
.grid-cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid-cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.grid-cols-12 { grid-template-columns: repeat(12, minmax(0, 1fr)); }

.gap-0 { gap: var(--space-0); }
.gap-1 { gap: var(--space-1); }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }


.flex-center {
  justify-content: center;
  align-items: center;
}

.flex-wrap-wrap{
  flex-wrap: wrap;
}

.justify-content-flex-end {
    justify-content: flex-end;
}

@media screen and (max-width: 768px){
.sm-justify-content-end {
    justify-content: flex-end;
}
}

@media screen and (max-width: 1199.5px){
.md-justify-content-end {
    justify-content: flex-end;
}
}

@media (min-width: 1024px) and (max-width: 1201px){
  .laptop-only{
    display: block;
  }
.d-flex-laptop-only{
    display: flex;
  }
}

@media (min-width: 768px) and (max-width: 1024px){
  .tab-only{
    display: block;
  }
.d-flex-tab-only{
    display: flex;
  }
}

@media screen and (min-width: 768px){
.mob-only{
      display: none;
  }
}

@media screen and (max-width: 767px){
  .mob-only{
    display: block;
  }
  .d-flex-mob-only{
    display: flex;
  }
}

/* Padding and Margin */
/* Spacing utilities */
.p-0 { padding: var(--space-0); }
.p-1 { padding: var(--space-1); }
.p-2 { padding: var(--space-2); }
.p-3 { padding: var(--space-3); }
.p-4 { padding: var(--space-4); }
.p-6 { padding: var(--space-6); }
.p-8 { padding: var(--space-8); }
.px-2 { padding-left: var(--space-2); padding-right: var(--space-2); }
.px-3 { padding-left: var(--space-3); padding-right: var(--space-3); }
.px-4 { padding-left: var(--space-4); padding-right: var(--space-4); }
.px-6 { padding-left: var(--space-6); padding-right: var(--space-6); }
.py-1 { padding-top: var(--space-1); padding-bottom: var(--space-1); }
.py-2 { padding-top: var(--space-2); padding-bottom: var(--space-2); }
.py-3 { padding-top: var(--space-3); padding-bottom: var(--space-3); }
.py-4 { padding-top: var(--space-4); padding-bottom: var(--space-4); }
.pt-50px{
  padding-top: 50px;
}

.pb-50px{
  padding-bottom: 50px;
}

.m-0 { margin: var(--space-0); }
.m-1 { margin: var(--space-1); }
.m-2 { margin: var(--space-2); }
.m-4 { margin: var(--space-4); }
.mx-auto { margin-left: auto; margin-right: auto; }
.mb-2 { margin-bottom: var(--space-2); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }
.mt-2 { margin-top: var(--space-2); }
.mt-4 { margin-top: var(--space-4); }
.mt-8 { margin-top: var(--space-8); }

.ms-0{
  margin-left: var(--space-0);
}

@media screen and (max-width: 767px){
.mob-pl-0{
  padding-left: 0;
}
}
/* ---------- Utility Grid Classes ---------- */
.row {
  display: flex;
  flex-wrap: wrap;
  margin-inline: -0.5rem;
}
.col {
  flex: 1;
  padding-inline: 0.5rem;
}

/************* Form *****************/
.required {
    color: var(--form-indicator);
    margin-left: 3px;
}

.price {
    font-weight: 700;
    font-size: 1.35rem;
    color: #115580;
}
/* ---------- Responsive Aspect Ratio Helper ---------- */
.aspect-ratio {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.aspect-ratio > * {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
}

.heading1 {
    font-size: 18px;
    line-height: 1.5;
    letter-spacing: 1px;
    text-transform: uppercase;
    text-align: center;
    position: relative;
    color: #fff;
    margin: 0 -25px 30px -30px;
    padding: 10px 22px;
    text-shadow: 0 1px rgba(0,0,0,.8);
    background-color: #5c5c5c;
    background-image:  linear-gradient(rgba(255,255,255,.3), rgba(255,255,255,0));
    box-shadow: 0 2px 0 rgba(0,0,0,.3);
    max-width: fit-content;
  }

  .heading1::before,
  .heading1::after {
    content: '';
    position: absolute;
    border-style: solid;
    border-color: transparent;
    bottom: -10px;
  }

  .heading1::before {
    border-width: 0 10px 10px 0;
    border-right-color: #666;
    left: 2px;
  }

  .heading1::after {
    /* border-width: 0 0 10px 10px; */
    /* border-left-color: #666; */
    /* right: 0; */
  }
 /* Slides */
 .owl-loaded{
      display: grid;
    overflow: hidden;
    height: 100%;
    float: left;
        padding-bottom: 25px;
 }

.owl-dots {
    /*position: relative; */
    display: flex;
    align-items: center;
    justify-items: center;
    margin-top: 15px;
    /* display: none; */
    /* width: 100%; */
    position: absolute;
    left: calc(50% - 32px);
    overflow: hidden;
    bottom: 21px;
    /* justify-content: center;*/
}

.owl-dots button.owl-dot {
     width: 10px;
     height: 10px; 
    border-radius: 50%;
    /* display: inline-block; */
    background:var(--primary-color);
    margin: 0 3px;
    padding: unset;
    border: unset;
    }

/*button.owl-dot {
    background-color: #000;
}*/

button.owl-dot.active {
    background-color:var(--secondary-color);
}
/******************************tooltip************/
.tooltip {
      position: relative;
    display: inline-block;
    /* border-bottom: 1px dotted black; */
    opacity: 1;
    font-weight: 500;
    z-index: auto;
}

.tooltip .tooltiptext {
  visibility: hidden;
  width: max-content;
  background-color: black;
  color: #fff;
  text-align: center;
  border-radius: 6px;
  padding: 5px 15px;

  /* Position the tooltip */
  position: absolute;
  z-index: 99;
    top: -27px;
  /*  right: calc(-100% - 15px);*/
  left: 0;
}

.tooltip:hover .tooltiptext {
  visibility: visible;
}

/* ---------- Sticky Header ---------- */
.sticky {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: var(--z-header);
  background: var(--background-color);
}

/* ---------- Skip Link ---------- */
.skip-link {
  position: absolute;
  left: -999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.skip-link:focus {
  left: 0;
  width: auto;
  height: auto;
  background: var(--accent-color);
  color: #fff;
  padding: var(--space-sm);
  z-index: var(--z-modal);
}

/* ---------- Lazy Load ---------- */
img {
  max-width: 100%;
  height: auto;
  display: block;
}
img[loading="lazy"] {
  /*opacity: 0;*/
  transition: opacity 0.5s ease;
}
img[loading="lazy"].loaded {
  opacity: 1;
}


/* ---------- Cards ---------- */
.card {
  border: 1px solid var(--border-color);
  padding: var(--space-md);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  transition: transform 0.3s ease;
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.card-header {
  padding: var(--space-6);
  border-bottom: 1px solid var(--gray-200);
}

.card-title {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--gray-900);
  margin-bottom: var(--space-2);
}

.card-description {
  color: var(--gray-600);
  font-size: var(--text-sm);
}

.card-content {
  padding: var(--space-6);
}

.card-footer {
  padding: var(--space-6);
  border-top: 1px solid var(--gray-200);
  background-color: var(--gray-50);
}

/* Card variations */
.card-deep-plum {
    background-color: var(--deep-plum);
    color: var(--soft-cloud);
    border: 1px solid var(--muted-lavender);
}

.card-soft-teal {
    background-color: var(--soft-teal);
    color: var(--deep-plum);
    border: 1px solid var(--deep-plum);
}

/* Enquiry Form Specific Styles */
.enquiry-form-background {
    background-color: var(--light-grayish-blue); /* A light, clean background for the form */
    padding: 30px;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.enquiry-form-heading {
    color: var(--deep-plum); /* Deep Plum for the heading */
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 20px;
}

/* ---------- Feature Box ---------- */
.feature-box {
  border-left: 5px solid var(--primary-color);
  background: var(--light);
  padding: var(--space-md);
  transition: border-color var(--transition-base);
}
.feature-box:hover {
  border-left-color: var(--accent-color);
}

/* ---------- Lists & Headings with Icons ---------- */
ul, ol {
 /* padding-left: 1.5rem;*/
  margin-bottom: var(--space-md);
}

ul li {
  margin-bottom: var(--space-xs);
  list-style: none;
  position: relative;  
  transition: color var(--transition-base);
  cursor: default;
  font-size: 1rem;
}

@media (max-width: 1024px) {
  ul li {
    font-size: 13px;
  }
}
/*ul.list-dot li*/
ul.list-point{
  margin-left: 0;
}
ul.list-point li
{
  padding-left: 1.2rem;
}

/*ul.list-dot li::before {*/
ul.list-point li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--accent-color);
  font-weight: bold;
}

ul.list-point li:hover {
  color: var(--primary-color);
  cursor: pointer;
}

.heading-icon {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.heading-icon i {
  font-size: 1.25rem;
  color: var(--accent-color);
}


/* ---------- Callout Boxes ---------- */
.callout {
  padding: var(--space-md);
  border-left: 4px solid var(--secondary-color);
  background: #fff7ec;
  margin-bottom: var(--space-md);
}
.callout.success {
  border-color: var(--success-color);
  background-color: #e7fbe7;
}
.callout.danger {
  border-color: var(--danger-color);
  background-color: #fdecec;
}

/* ---------- Scroll Snap ---------- */
.scroll-snap-container {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
}
.scroll-snap-item {
  scroll-snap-align: start;
  flex: 0 0 100%;
}

/* ---------- Skeleton Loader ---------- */
.skeleton {
  background: linear-gradient(90deg, #eee, #f5f5f5, #eee);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
}
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

/* ---------- Icons ---------- */
.icon {
  transition: transform 0.3s ease;
}
.icon:hover {
  transform: scale(1.2);
}

/* ---------- Fade Animation ---------- */
[data-animate="fade-up"] {
  opacity: 0;
  animation: fadeInUp 0.6s ease forwards;
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ---------- Forms ---------- */

input[type="text"], 
input[type="email"], 
input[type="tel"],
input[type="date"], 
input[type="datetime-local"],
input[type="password"],
select, 
textarea {
  width: 100%;
  padding: 0.65rem 0.9rem;
  border: 1.8px solid var(--form-border-color);
  border-radius: 8px;
  font-size: 1rem;
  color: #1c2b4a;
  transition: border-color 0.3s ease;
  box-sizing: border-box;
}


/* Example for input/textarea focus effect */
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="date"]:focus, 
textarea:focus {
    border-color: var(--primary-color); /* Highlight border on focus */
  /*  box-shadow: 0 0 0 0.2rem rgba(249, 249, 249, 0.25); */
    /* Subtle glow */
}


/* Additional elements for completeness */


label {
    font-size: 17px;
    display: block;
    font-weight: 600;
    margin-bottom: 0.3rem;
    margin-top: 1.3rem;
    color: var(----form-color);   
}

/* Example for section backgrounds/cards */
.section-background {
    background-color: var(--primary-color);
    padding: 20px;
    margin-bottom: 20px;
}
/* ---------- Accessibility ---------- */
:focus-visible {
  outline: 2px dashed var(--accent-color);
  outline-offset: 2px;
}
/*@media (prefers-reduced-motion: reduce) {*/
  *, *::before, *::after {
 /*   animation: none !important;
    transition: none !important;*/
  }
  .btn:hover, .btn:hover, .icon:hover, .card:hover {
    /*transform: none !important;*/
    box-shadow: none;
  }
/*}*/

/* Hover utilities */
.hover\:bg-primary-700:hover { background-color: var(--primary-700); }
.hover\:text-primary-600:hover { color: var(--primary-600); }
.hover\:shadow-lg:hover { box-shadow: var(--shadow-lg); }
/* ---------- Print Enhancements ---------- */
@media print {
  body {
    background: #fff;
    color: #000;
  }
  header, footer, nav {
    display: none !important;
  }
  a::after {
    content: " (" attr(href) ")";
    font-size: 0.85em;
    color: var(--muted-text);
  }
}

/* ---------- Container Queries ---------- */
@media screen and (min-width: 600px) {
  .card {
    padding: var(--space-lg);
  }
}

/* Animation */
@keyframes mymove {
  from {top: -20%;}
  to {top: 0px;}
}

/* ========================================
   ANIMATIONS & MICRO-INTERACTIONS
   ======================================== */
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slideInDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.animate-fade-in {
  animation: fadeIn 0.3s ease-out;
}

.animate-slide-up {
  animation: slideInUp 0.3s ease-out;
}

.animate-slide-down {
  animation: slideInDown 0.3s ease-out;
}

.animate-pulse {
  animation: pulse 2s infinite;
}


/** Payment */
/* --- Payment Status Styles --- */

/* Base style for payment status messages */
.payment-status {
    font-size: 16px;
    font-weight: 500;
    padding: 8px 12px;
    border-radius: 4px;
    margin-top: 10px;
    display: inline-block;
}

/* Confirmation State */
.payment-status.confirmed {
    background-color: #E8F5E9; /* Light Green */
    color: #2E7D32; /* Dark Green */
    border: 1px solid #A5D6A7;
}

/* Selection State (e.g., when an option is chosen but not yet confirmed) */
.payment-status.selected {
    background-color: #E3F2FD; /* Light Blue */
    color: #1976D2; /* Dark Blue */
    border: 1px solid #90CAF9;
}

/* Rejection/Failed State */
.payment-status.rejected {
    background-color: #FFEBEE; /* Light Red */
    color: #D32F2F; /* Dark Red */
    border: 1px solid #EF9A9A;
}

/* Pending State */
.payment-status.pending {
    background-color: #FFFDE7; /* Light Yellow */
    color: #FBC02D; /* Dark Yellow */
    border: 1px solid #FFF59D;
}




/* --- Form Submission Feedback Styles --- */
/* ========================================
   FORM COMPONENTS
   ======================================== */
.form-group {
  margin-bottom: var(--space-4);
  padding: 0 5px;
}

.form-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--gray-700);
  margin-bottom: var(--space-2);
}

.form-input,
.form-textarea,
.form-select {
  width: 100%;
  padding: var(--space-3);
  font-size: var(--text-sm);
  border: 1px solid var(--gray-300);
  border-radius: var(--radius-md);
  background-color: white;
  transition: all var(--transition-base);
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  outline: none;
  border-color: var(--primary-500);
  box-shadow: 0 0 0 3px var(--primary-100);
}

.form-input:invalid,
.form-textarea:invalid {
  border-color: var(--error-500);
}

.form-help {
  font-size: var(--text-xs);
  color: var(--gray-500);
  margin-top: var(--space-1);
}

.form-error {
  font-size: var(--text-xs);
  color: var(--error-500);
  margin-top: var(--space-1);
}


/* Base style for form messages */
.form-message {
    font-size: 15px;
    padding: 10px 15px;
    border-radius: 4px;
    margin-top: 15px;
    text-align: center;
    font-weight: 500;
}

/* Success Message */
.form-message.success {
    background-color: #E8F5E9; /* Light Green */
    color: #2E7D32; /* Dark Green */
    border: 1px solid #A5D6A7;
}

/* Error Message */
.form-message.error {
    background-color: #FFEBEE; /* Light Red */
    color: #D32F2F; /* Dark Red */
    border: 1px solid #EF9A9A;
}
/* Payment */
/* Optional: Styles for a support request button */
.support-button {
    font-size: 18px;
    font-weight: 700;
    color: var(--pure-white);
    background-color: var(--deep-plum); /* Using Deep Plum for a prominent button */
    border: none;
    padding: 12px 25px;
    border-radius: 5px;
    cursor: pointer;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.support-button:hover {
    background-color: var(--soft-teal); /* Soft Teal on hover */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* ========================================
   MODAL COMPONENTS
   ======================================== */
 .modal-overlay {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      background: rgba(0, 0, 0, 0.4);
      display: flex;
      justify-content: center;
      align-items: center;
      animation: fadeIn 0.4s ease-in-out;
      z-index: 9999;
    }

.modal-overlay.active {
  opacity: 1;
  visibility: visible;
}

.modal {
/*  background-color: white;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-2xl);
  max-width: 500px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  transform: scale(0.95);
  transition: transform var(--transition-base);*/
}

.modal-overlay.active .modal {
  transform: scale(1);
}

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-4);
    border-bottom: 1px solid var(--gray-400);
}


.modal-close {
  padding: var(--space-2);
  background: none;
  border: none;
  color: var(--gray-500);
  cursor: pointer;
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
}

.modal-close:hover {
  background-color: var(--gray-100);
  color: var(--gray-700);
}

.modal-content {
  padding: var(--space-0);
}

.modal-footer {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  padding: var(--space-6);
  border-top: 1px solid var(--gray-200);
}
.modal-hidden {
      display: none;
    }
/*************** FAQ ***************/

  .faq-section {
    /*max-width: 700px;*/
   /* margin: 3rem auto;*/
    /*font-family: 'Poppins', sans-serif;*/
    /*background: #f9fbfd;*/
    /*padding: 2rem 2.5rem;*/
    /*border-radius: 12px;*/
    /*box-shadow: 0 10px 25px rgba(3, 50, 102, 0.1);*/
  }

  .faq-item {
    border-bottom: 1px solid #dbe7f3;
    /*margin-bottom: 1rem;*/
    padding: 8px 0;
    outline: none;
  }

  .faq-item:last-child {
    border-bottom: none;
  }

  .faq-question {
    background: transparent;
    border: none;
    width: 100%;
    text-align: left;
    font-size: 1.1rem;
    font-weight: 600;
    color: #033266;
    cursor: pointer;
    padding: 1rem 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: color 0.3s ease;
  }
  .faq-question:hover,
  .faq-question:focus {
    color: #025c99;
    border: none;
    outline: none;
  }

  .faq-icon {
    font-weight: 700;
    font-size: 1.5rem;
    color: #025c99;
    transition: transform 0.3s ease;
  }

  .faq-question[aria-expanded="true"] .faq-icon {
    transform: rotate(45deg);
  }

  .faq-answer {
    font-size: 1rem;
    line-height: 1.5;
    color: #2f4858;
    padding-top: 1rem;
    padding-bottom: 1rem;
    padding-left: 0.5rem;
  }

/************** Testimonial ***************/
/* Final */


.slider-track {
    display: flex;
    gap: 25px;
    padding-bottom: 10px;
  }

  
/* Final */

.testimonial-carousel {
  /*overflow: hidden;*/
  /*position: relative;*/
  /*padding: 0 20px;*/
}

.carousel-track {
  display: flex;
  gap: 1.5rem;
  animation: scrollX 40s linear infinite;
  width: max-content;
}

.testimonial-card {
  flex: 0 0 280px;
  background: #fff;
  padding: 1.2rem 1rem;
  border-radius: 12px;
  box-shadow: 0 8px 20px rgba(3, 50, 102, 0.08);
  transition: transform 0.3s ease;
}

.testimonial-author strong {
  font-weight: 600;
}
.testimonial-author span {
  font-weight: 400;
  color: #777;
}

/* testimonials2 */
#global-testimonials {
    overflow: hidden;
    position: relative;
    /* max-width: 1200px; */
}



  .slider-container::-webkit-scrollbar {
    display: none;
  }

  

  

  

  #global-testimonials .author {
    font-weight: 600;
    font-size: 0.95em;
    color: #115580;
    text-align: right;
  }

  .slider-dots {
    text-align: center;
    margin-top: 30px;
  }

  .slider-dots .dot {
    height: 12px;
    width: 12px;
    margin: 0 6px;
    background-color: #ccc;
    border-radius: 50%;
    display: inline-block;
    cursor: pointer;
    transition: background-color 0.3s ease;
  }

  .slider-dots .dot.active {
    background-color: #033266;
  }

  @media (max-width: 768px) {
    .testimonial-card {
      flex: 0 0 230px;
      padding: 20px 15px;
    }

    #global-testimonials h2 {
      font-size: 1.8em;
    }
  }

  /* Testimonial3*/
  .tirikala-testimonial-section {
/*    background-color: #f4f9fc;
    padding: 60px 20px;
    font-family: 'Poppins', sans-serif;
    color: #033266;*/
  }

  .tirikala-testimonial-container {
/*    max-width: 1200px;
    margin: auto;*/
  }

  .tirikala-testimonial-section h2 {
/*    font-family: 'Playfair Display', serif;
    font-size: 2rem;
    font-weight: 600;
    margin-bottom: 40px;
    text-align: center;
    color: #033266;*/
  }

  .tirikala-testimonial-slider-wrapper {
    position: relative;
    overflow: hidden;
  }

  .tirikala-testimonial-slider {
    display: flex;
    transition: transform 0.5s ease-in-out;
  }

  .tirikala-testimonial-card {
    background: #fff;
    flex: 0 0 300px;
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 4px 14px rgba(3, 50, 102, 0.07);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin-right: 24px;
  }

  .tirikala-testimonial-card:last-child {
    margin-right: 0;
  }

  .tirikala-testimonial-text {
    font-size: 1rem;
    line-height: 1.6;
    color: #444;
    margin-bottom: 20px;
    font-style: italic;
  }

  .tirikala-testimonial-client {
    font-weight: 600;
    color: #033266;
    font-size: 1.1rem;
  }

  .tirikala-testimonial-location {
    font-size: 0.9rem;
    color: #666;
  }

  /* Dots navigation */
  .tirikala-dots {
    text-align: center;
    margin-top: 30px;
  }

  .tirikala-dot {
    display: inline-block;
    width: 12px;
    height: 12px;
    margin: 0 6px;
    background-color: #bbb;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s ease;
  }

  .tirikala-dot.active {
    background-color: #033266;
  }

  @media (max-width: 768px) {
    .tirikala-testimonial-card {
      flex: 0 0 260px;
      padding: 20px;
      margin-right: 16px;
    }
  }
  /* End here */
  /* How Ite works - Steps */
   .horizontal-timeline {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    /*margin: 50px auto;*/
    padding: 20px;
    /*max-width: 1000px;*/
    position: relative;
    animation: fadeInUp 1s ease-out;
  }

  .horizontal-timeline::before {
    content: "";
    position: absolute;
    top: 35px;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #033266;
    z-index: 0;
  }

  .step {
    width: 23%;
    text-align: center;
    position: relative;
    z-index: 1;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    cursor: default;
  }

  .step:hover {
    transform: translateY(-8px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
  }

  .circle {
    background-color: #033266;
    color: white;
    width: 50px;
    height: 50px;
    margin: 0 auto 12px;
    border-radius: 50%;
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 12px #03326699;
    transition: background-color 0.3s ease;
  }

  .step:hover .circle {
    background-color: #025c99;
  }

  .step h3 {
   /* font-size: 1.05rem;
    margin: 10px 0 6px;*/
  /*  color: #033266;*/
  }

  .step p {
    font-size: 0.9rem;
    color: #444;
    line-height: 1.4;
    padding: 0 10px;
  }

  /* Responsive */
  @media (max-width: 768px) {
    .horizontal-timeline {
      /* flex-direction: column; */
        align-items: center;
        flex-wrap: wrap;
    }

    .horizontal-timeline::before {
      top: auto;
      left: 35px;
      width: 4px;
      height: 100%;
      display: none;
    }

    .step {
      width: 49%;
      /*text-align: left;*/
      /*padding-left: 60px;*/
      margin-bottom: 15px;
      text-align: center;
      padding: 10px;
    }

    .step p{
      text-align: center;
    }

    .circle {
      /*position: absolute;*/
      /*left: 10px;*/
      /*top: 0;*/
    }
  }

  @media (max-width: 600px) {
    .horizontal-timeline {
      flex-direction: column;
      align-items: center;
    }

    .horizontal-timeline::before {
      top: auto;
      left: 35px;
      width: 4px;
      height: 100%;
      display: none;
    }

    .step {
      width: 100%;
      /*text-align: left;*/
      /*padding-left: 60px;*/
      margin-bottom: 15px;
      text-align: center;
      padding: 10px;
    }

    .step p{
      text-align: center;
    }

    .circle {
      /*position: absolute;*/
      /*left: 10px;*/
      /*top: 0;*/
    }
  }
  }

  /* Animations */
  @keyframes fadeInUp {
    from {
      opacity: 0;
      transform: translateY(30px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
   /* How Ite works - Steps */
/* Animation */
@keyframes scrollX {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Responsive for mobile */
@media (max-width: 768px) {
  .carousel-track {
    animation: none;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .testimonial-card {
    scroll-snap-align: start;
  }
}
/* --- Blog Section Styles --- */

/* Blog Post Card */
.blog-post-card {
    background-color: var(--pure-white);
    border: 1px solid var(--light-grayish-blue);
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    margin-bottom: 30px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.blog-post-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

.blog-post-card img {
    width: 100%;
    height: 200px; /* Fixed height for consistency */
    object-fit: cover;
}

.blog-post-content {
    padding: 20px;
}

/* Blog Post Title */
.blog-post-title {
    font-size: 28px;
    font-weight: 600;
    color: var(--deep-plum);
    margin-top: 0;
    margin-bottom: 10px;
    line-height: 1.3em;
}

.blog-post-title a {
    color: inherit;
    text-decoration: none;
}

.blog-post-title a:hover {
    color: var(--bright-gold);
}

/* Blog Post Metadata */
.blog-post-meta {
    font-size: 14px;
    color: var(--muted-lavender);
    margin-bottom: 15px;
}

.blog-post-meta span {
    margin-right: 15px;
}

.blog-post-meta a {
    color: var(--muted-lavender);
    text-decoration: none;
}

.blog-post-meta a:hover {
    color: var(--deep-plum);
}

/* Blog Post Excerpt/Body */
.blog-post-excerpt {
    font-size: 16px;
    color: var(--muted-lavender);
    line-height: 1.6em;
    margin-bottom: 20px;
}

/* Read More Button */
.read-more-button {
    display: inline-block;
    background-color: var(--secondary-color);
    color: var(--pure-white);
    padding: 5px 10px;
    border-radius: 5px;
    text-decoration: none;
    font-size: 16px;
    font-weight: 700;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.read-more-button:hover {
    background-color: var(--deep-plum);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Blog Post Detail Page (if applicable) */
.blog-detail-content {    
    font-size: 17px;
    line-height: 1.7em;
    color: var(--muted-lavender);
}

.blog-detail-content h1, .blog-detail-content h2, .blog-detail-content h3 {
    color: var(--deep-plum);
}

.blog-detail-content img {
    margin: 20px 0;
}

/* product */
.product-card ul {
    list-style: none;
    padding-left: 0;
    margin-bottom: 2rem;
    color: #455a7b;
}

.product-card ul li {
    margin-bottom: 0.9rem;
    position: relative;
    padding-left: 1.6rem;
    font-size: 1rem;
}

.product-card ul li::before {
    content: '✔';
    position: absolute;
    left: 0;
    color: #33a64a;
    font-weight: 700;
}

  /* Owl */
  .owl-stage{
    display: flex;
  }

  .owl-nav {
    display: none;
  }

  .owl-loaded {
    padding-bottom: 30px;
  }