/* ============================================
   DESIGN TOKENS — Psickari Vrable
   ============================================ */

:root {
  /* Primary palette — forest/nature */
  --color-primary: #2D6A4F;
  --color-primary-dark: #1B4332;
  --color-primary-light: #52B788;
  --color-primary-lighter: #95D5B2;
  --color-primary-lightest: #D8F3DC;

  /* Secondary palette — warm amber */
  --color-secondary: #E07A3A;
  --color-secondary-light: #F4A261;
  --color-secondary-lighter: #FDDCB5;

  /* Neutrals */
  --color-white: #FAFAF8;
  --color-gray-50: #F5F5F3;
  --color-gray-100: #E8E8E4;
  --color-gray-200: #D1D1CC;
  --color-gray-300: #A8A8A2;
  --color-gray-400: #7A7A74;
  --color-gray-500: #5C5C56;
  --color-gray-600: #3D3D38;
  --color-gray-700: #2A2A25;
  --color-gray-800: #1A1714;
  --color-black: #111111;

  /* Semantic */
  --color-success: #40916C;
  --color-error: #C1121F;
  --color-info: #457B9D;

  /* Typography */
  --font-heading: 'Plus Jakarta Sans', sans-serif;
  --font-body: 'DM Sans', sans-serif;

  --fs-display: clamp(2.75rem, 5vw + 1rem, 4.75rem);
  --fs-h1: clamp(2.25rem, 4vw + 0.5rem, 3.75rem);
  --fs-h2: clamp(1.9rem, 3vw + 0.5rem, 3rem);
  --fs-h3: clamp(1.4rem, 2vw + 0.25rem, 1.9rem);
  --fs-h4: clamp(1.2rem, 1.5vw + 0.25rem, 1.45rem);
  --fs-body: clamp(1.05rem, 0.5vw + 0.9rem, 1.25rem);
  --fs-body-sm: clamp(0.95rem, 0.3vw + 0.85rem, 1.1rem);
  --fs-caption: 0.9rem;
  --fs-overline: 0.85rem;

  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;

  --lh-tight: 1.2;
  --lh-normal: 1.6;
  --lh-relaxed: 1.8;

  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;
  --space-section: clamp(4rem, 8vw, 8rem);

  /* Border radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 24px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.1);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.12);
  --shadow-xl: 0 16px 48px rgba(0,0,0,0.16);
  --shadow-card: 0 2px 8px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.08);

  /* Transitions */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --duration-fast: 200ms;
  --duration-normal: 350ms;
  --duration-slow: 500ms;

  /* Layout */
  --container-max: 1200px;
  --container-narrow: 800px;
  --container-wide: 1400px;
  --nav-height: 72px;
}

/* ============================================
   BASE RESET & TYPOGRAPHY
   ============================================ */

*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-body) !important;
  font-size: var(--fs-body);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  color: var(--color-gray-700);
  background-color: var(--color-white);
  overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: var(--font-heading) !important;
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  color: var(--color-gray-800);
  margin-top: 0;
}

h1, .h1 { font-size: var(--fs-h1); }
h2, .h2 { font-size: var(--fs-h2); }
h3, .h3 { font-size: var(--fs-h3); }
h4, .h4 { font-size: var(--fs-h4); }

p {
  margin-top: 0;
  margin-bottom: var(--space-md);
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

a:hover {
  color: var(--color-primary-dark);
}

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

/* Container */
.ps-container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-xl);
}

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

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

/* ============================================
   OVERRIDE HESTIA DEFAULTS
   ============================================ */

/* Override Hestia's navbar — white bg, no scroll transition */
.navbar,
.navbar.navbar-transparent,
.navbar.navbar-not-transparent,
.navbar.navbar-color-on-scroll {
  background-color: rgba(255, 255, 255, 0.98) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 3px rgba(0,0,0,0.08) !important;
  transition: none !important;
  height: var(--nav-height) !important;
  min-height: var(--nav-height) !important;
  max-height: var(--nav-height) !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  transform: none !important;
}

/* Kill Hestia's transparent-state container padding that causes the jump */
.navbar > .container,
.navbar.navbar-transparent > .container,
.navbar.navbar-not-transparent > .container {
  display: flex !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  height: var(--nav-height) !important;
  transition: none !important;
}

/* Lock navbar inner elements — no padding/size changes on scroll */
.navbar .navbar-header {
  transition: none !important;
  transform: none !important;
  height: var(--nav-height) !important;
  display: flex !important;
  align-items: center !important;
  float: none !important;
  flex-shrink: 0 !important;
}

.navbar .navbar-brand,
.navbar .nav > li > a {
  transition: none !important;
  transform: none !important;
}

.navbar .navbar-collapse {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex: 1 !important;
  float: none !important;
  height: var(--nav-height) !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: visible !important;
}

.navbar .navbar-brand {
  font-size: 0 !important;
  color: transparent !important;
  display: flex !important;
  align-items: center !important;
  gap: 0 !important;
  overflow: visible;
  padding: 8px 0 !important;
}

/* Style the native theme logo */
.navbar .navbar-brand img {
  width: 56px !important;
  height: 56px !important;
  max-height: 56px !important;
  border-radius: 50%;
  object-fit: cover;
}

/* Hide Hestia page header description/tagline */
.page-header .container .motto,
.page-header .container h3,
.page-header .sub-title,
.page-header.header-small .container .motto,
.main > .section .hestia-title-tagline,
.page-header p.sub-title {
  display: none !important;
}

.navbar .nav > li > a {
  font-family: var(--font-body) !important;
  font-weight: var(--fw-semibold) !important;
  font-size: 1.15rem !important;
  letter-spacing: 0.01em;
  text-transform: none !important;
  padding: 10px 18px !important;
  border-radius: var(--radius-md);
  transition: all var(--duration-fast) var(--ease-out);
  color: var(--color-gray-700) !important;
}

.navbar .nav > li > a:hover,
.navbar .nav > li > a:focus {
  background-color: var(--color-primary-lightest) !important;
  color: var(--color-primary-dark) !important;
}

/* Hamburger icon — dark for white navbar */
.navbar .navbar-toggler,
.navbar .navbar-toggle {
  border-color: var(--color-gray-300) !important;
}

.navbar .navbar-toggle .icon-bar {
  background-color: var(--color-gray-700) !important;
}

/* Dropdown menus */
.navbar .dropdown-menu a {
  color: var(--color-gray-700) !important;
}

.navbar .dropdown-menu a:hover {
  background-color: var(--color-primary-lightest) !important;
  color: var(--color-primary-dark) !important;
}

/* Override Hestia's page header */
.page-header {
  min-height: 0 !important;
  padding: 0 !important;
}

/* Hide default Hestia sections on front page */
body.home .main-raised {
  margin: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body.home .hestia-blogs,
body.home .hestia-features,
body.home .hestia-ribbon,
body.home .hestia-team,
body.home .hestia-testimonials,
body.home .hestia-subscribe,
body.home .hestia-shop,
body.home .hestia-contact {
  display: none !important;
}

/* Override Hestia footer */
.footer {
  background-color: var(--color-gray-800) !important;
  padding: var(--space-2xl) 0 var(--space-lg) !important;
}

.footer .copyright {
  font-family: var(--font-body) !important;
  color: var(--color-gray-400) !important;
}
