/* GOOGLE FONTS IMPORT */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  /* === DARK PALETTE === */
  --color-onyx: #1A1A1A;           
  --color-charcoal: #2C2C2C;       
  --color-slate: #3D3D3D;          
  
  /* === GOLD/ACCENT === */
  --color-champagne: #C9A96E;      
  --color-champagne-hover: #B8943D; 
  --color-champagne-light: #E8D5B0; 
  --color-champagne-pale: #F5EDDB; 
  
  /* === LIGHT PALETTE === */
  --color-cream: #FAF8F4;          
  --color-ivory: #F0EBE1;          
  --color-linen: #E8E0D4;          
  --color-white: #FFFFFF;          
  
  /* === TEXT === */
  --color-text-dark: #1A1A1A;      
  --color-text-mid: #5A5A5A;       
  --color-text-light: #9A9A9A;     
  --color-text-white: #FFFFFF;     
  --color-text-white-muted: rgba(255,255,255,0.7); 
  
  /* === BORDERS & DIVIDERS === */
  --color-border: rgba(201,169,110,0.2);  
  --color-border-light: rgba(0,0,0,0.08); 
  --color-border-dark: rgba(255,255,255,0.1); 
  
  /* === FUNCTIONAL === */
  --color-success: #4CAF50;
  --color-error: #E53E3E;
  --color-whatsapp: #25D366;

  /* === FONT FAMILIES === */
  --font-display: 'Cormorant Garamond', Georgia, serif;  
  --font-body: 'DM Sans', system-ui, sans-serif;          
  
  /* === FONT SIZES (fluid scaling with clamp) === */
  --fs-hero:   clamp(48px, 7vw, 96px);    
  --fs-h1:     clamp(36px, 5vw, 64px);    
  --fs-h2:     clamp(28px, 4vw, 48px);    
  --fs-h3:     clamp(22px, 3vw, 32px);    
  --fs-h4:     clamp(18px, 2vw, 24px);    
  --fs-lead:   clamp(16px, 1.5vw, 20px);  
  --fs-body:   16px;                       
  --fs-small:  14px;                       
  --fs-xsmall: 12px;                       
  --fs-stat:   clamp(48px, 6vw, 80px);    
  
  /* === LINE HEIGHTS === */
  --lh-tight:  1.1;    
  --lh-heading: 1.3;   
  --lh-body:   1.7;    
  
  /* === LETTER SPACING === */
  --ls-tight:    -0.02em;  
  --ls-normal:   0;
  --ls-wide:     0.05em;   
  --ls-wider:    0.12em;   
  --ls-widest:   0.2em;    

  /* === SPACING SCALE === */
  --space-xs:   4px;
  --space-sm:   8px;
  --space-md:   16px;
  --space-lg:   24px;
  --space-xl:   40px;
  --space-2xl:  64px;
  --space-3xl:  96px;
  --space-4xl:  128px;
  
  /* === SECTION PADDING === */
  --section-pad-desktop: 120px 0;
  --section-pad-tablet:  80px 0;
  --section-pad-mobile:  60px 0;
  
  /* === CONTAINER === */
  --container-max:    1280px;
  --container-narrow: 840px;
  --container-pad:    clamp(20px, 5vw, 60px); 
  
  /* === CARD === */
  --card-pad: 32px;
  --card-pad-mobile: 20px;
  --card-radius: 2px; 
  --card-shadow: 0 4px 40px rgba(0,0,0,0.08);
  --card-shadow-hover: 0 12px 60px rgba(0,0,0,0.15);

  /* === TIMING FUNCTIONS === */
  --ease-luxury:    cubic-bezier(0.22, 1, 0.36, 1);  
  --ease-sharp:     cubic-bezier(0.4, 0, 0.2, 1);     
  --ease-bounce:    cubic-bezier(0.34, 1.56, 0.64, 1); 
}

/* === RESET === */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-body);
  color: var(--color-text-dark);
  background-color: var(--color-cream);
  line-height: var(--lh-body);
  font-size: var(--fs-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6, .font-display {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: var(--lh-heading);
  letter-spacing: var(--ls-normal);
  color: inherit;
}

h1 { font-size: var(--fs-h1); line-height: var(--lh-tight); letter-spacing: var(--ls-tight); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); font-weight: 600; }
h4 { font-size: var(--fs-h4); font-family: var(--font-body); font-weight: 500; }

a {
  color: inherit;
  text-decoration: none;
}

img, picture, svg {
  display: block;
  max-width: 100%;
}

ul, ol {
  list-style: none;
}

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

/* === UTILITIES === */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
}

.container--narrow {
  max-width: var(--container-narrow);
}

.section {
  padding: var(--section-pad-desktop);
}

@media (max-width: 1024px) {
  .section { padding: var(--section-pad-tablet); }
}

@media (max-width: 767px) {
  .section { padding: var(--section-pad-mobile); }
}

.section--dark {
  background: var(--color-charcoal);
  color: var(--color-text-white);
}

.section--dark h2,
.section--dark h3 {
  color: var(--color-white);
}

.section--dark p {
  color: var(--color-text-white-muted);
}

.section--dark .overline {
  color: var(--color-champagne);
}

/* Typography utilities */
.overline {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-xsmall);
  font-weight: 500;
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--color-champagne);
  margin-bottom: var(--space-md);
}

/* Section Header Component */
.section-header {
  margin-bottom: var(--space-3xl);
}

.section-header--center {
  text-align: center;
}

.section-header--center .section-divider {
  margin: 0 auto var(--space-lg);
}

.section-header--left {
  text-align: left;
}

.section-header--left .section-divider {
  margin: 0 0 var(--space-lg);
}

.section-header__title {
  margin-bottom: var(--space-md);
}

.section-header__desc {
  max-width: 560px;
  font-size: var(--fs-lead);
  color: var(--color-text-mid);
}

.section-header--center .section-header__desc {
  margin: 0 auto;
}

.section-divider {
  width: 40px;
  height: 1px;
  background: var(--color-champagne);
}

/* Button Patterns */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: var(--fs-xsmall);
  font-weight: 500;
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  text-decoration: none;
  padding: 16px 36px;
  border: 1px solid transparent;
  cursor: pointer;
  border-radius: var(--card-radius);
  transition: all 0.25s var(--ease-sharp);
}

.btn-primary {
  background: var(--color-champagne);
  color: var(--color-onyx);
  border-color: var(--color-champagne);
}
.btn-primary:hover {
  background: var(--color-champagne-hover);
  border-color: var(--color-champagne-hover);
  letter-spacing: calc(var(--ls-wider) + 0.04em);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(201,169,110,0.3);
}

.btn-outline {
  background: transparent;
  color: var(--color-champagne);
  border-color: var(--color-champagne);
}
.btn-outline:hover {
  background: var(--color-champagne);
  color: var(--color-onyx);
}

.btn-outline-white {
  background: transparent;
  color: white;
  border-color: rgba(255,255,255,0.6);
}
.btn-outline-white:hover {
  background: white;
  color: var(--color-onyx);
  border-color: white;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(255,255,255,0.2);
}

.btn-ghost {
  background: transparent;
  color: var(--color-champagne);
  padding: 0;
  transition: padding-left 0.25s var(--ease-sharp);
}
.btn-ghost:hover {
  padding-left: 8px;
}

/* Grids */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-xl); }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-xl); }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-xl); }

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

@media (max-width: 767px) {
  .grid-4, .grid-3, .grid-2 { grid-template-columns: 1fr; gap: var(--space-lg); }
  
  .btn {
    width: 100%;
    min-height: 52px;
  }
}
