/* ==========================================================
   TES Borovets — Alpine Editorial Design System
   Display:  Noto Serif 400 (editorial serif headings)
   Body:     Manrope 400/500/700 (clean geometric sans)
   Palette:  Deep Navy · Antique Gold · Warm Cream · Charcoal
   Shape:    Sharp — zero border-radius on all components
   ========================================================== */

/* ── Sections ────────────────────────────────────────────────
   0.  Material Symbols helper
   1.  Design Tokens
   2.  Reset + Base
   3.  Typography
   4.  Layout + Reveals
   5.  Buttons
   6.  Accessibility
   7.  Header
   8.  Mobile Navigation
   9.  Hero
   10. Breadcrumb
   11. Page Intro
   12. Stats Grid
   13. Property Cards
   14. Property Detail
   15. Complex Cards (overlay photo style)
   16. Complex Section (Apartments page)
   17. Filter Bar
   18. Services Grid + Cards
   19. Process Steps
   20. Season Cards
   21. Contact Methods
   22. Forms
   23. CTA Band
   24. Property Images & Gallery
   25. Page Placeholder
   26. Footer
   27. Utility
   28. Reduced Motion
   29. Promo Banner
   ──────────────────────────────────────────────────────────── */


/* ─── 0. Material Symbols ───────────────────────────────── */
.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
  font-style: normal;
  font-size: 24px;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
}


/* ─── 1. Design Tokens ──────────────────────────────────── */
:root {
  /* Brand — overridden per-client via base.njk */
  --primary:  #00243b;
  --accent:   #745b1b;
  --surface:  #faf9fb;
  --text:     #1a1c1d;
  --sky:      #f4f3f5;

  /* Extended Alpine Editorial palette */
  --on-primary:            #ffffff;
  --primary-container:     #1b3a52;
  --on-primary-container:  #86a4c0;
  --secondary:             #745b1b;
  --on-secondary:          #ffffff;
  --secondary-container:   #ffdc8e;
  --surface-dim:           #dadadc;
  --surface-container-low: #f4f3f5;
  --surface-container:     #eeedf0;
  --surface-container-high:#e9e8ea;
  --on-surface:            #1a1c1d;
  --on-surface-variant:    #42474d;
  --outline:               #73777d;
  --outline-variant:       #c3c7cd;
  --surface-tint:          #44617b;
  --primary-fixed-dim:     #accae8;

  /* Primary scale */
  --color-primary-50:   #EDF2F7;
  --color-primary-100:  #D0DDE9;
  --color-primary-200:  #A0BBCF;
  --color-primary-300:  #6D96B3;
  --color-primary-500:  #2C6285;
  --color-primary-700:  #1b3a52;
  --color-primary-800:  #00243b;
  --color-primary-900:  #001827;

  /* Accent (antique gold) */
  --color-accent-200:   #c9a961;
  --color-accent-300:   #b08d3e;
  --color-accent-400:   #745b1b;
  --color-accent-500:   #5a4302;
  --color-accent-600:   #3d2c00;

  /* Neutral — warm cream */
  --color-neutral-0:    #ffffff;
  --color-neutral-50:   #faf9fb;
  --color-neutral-100:  #f4f3f5;
  --color-neutral-200:  #eeedf0;
  --color-neutral-300:  #e3e2e4;
  --color-neutral-400:  #c3c7cd;
  --color-neutral-500:  #73777d;
  --color-neutral-600:  #42474d;
  --color-neutral-700:  #2f3032;
  --color-neutral-800:  #1a1c1d;
  --color-neutral-900:  #0d0f10;

  /* Typography */
  --font-display: 'Noto Serif', Georgia, 'Times New Roman', serif;
  --font-sans:    'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;

  /* Type scale */
  --text-xs:   0.75rem;     /* 12px — kicker */
  --text-sm:   0.875rem;    /* 14px — label */
  --text-base: 1rem;        /* 16px — body-md */
  --text-lg:   1.125rem;    /* 18px — body-lg */
  --text-xl:   1.25rem;
  --text-2xl:  1.5rem;
  --text-3xl:  1.875rem;
  --text-4xl:  2.25rem;
  --text-5xl:  3rem;        /* 48px — h1 */
  --text-6xl:  3.75rem;
  --text-7xl:  5rem;        /* 80px — display */

  /* Spacing */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-7:  2rem;
  --space-8:  2.5rem;
  --space-9:  3rem;
  --space-10: 4rem;
  --space-11: 5rem;
  --space-12: 6rem;   /* 96px */
  --space-16: 8rem;   /* 128px — section-gap */

  /* Layout */
  --container-lg: 1440px;
  --container-md: 960px;
  --container-sm: 680px;
  --margin-edge:  4rem;     /* 64px */

  /* Component */
  --banner-h:  0px;
  --header-h:  80px;
  --section-v: var(--space-16);

  /* Transitions */
  --t-fast:   150ms ease;
  --t-base:   300ms ease;
  --t-slow:   700ms ease;

  /* Zero radius — Alpine Editorial: sharp geometry */
  --radius: 0;
}


/* ─── 2. Reset + Base ───────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--text);
  background: var(--surface);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  padding-top: var(--banner-h);
}

img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; }


/* ─── 3. Typography ─────────────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 400;
  line-height: 1.1;
  color: var(--text);
}

h1 {
  font-size: clamp(2.5rem, 5vw, 3rem);
  letter-spacing: -0.02em;
  line-height: 1.1;
}

h2 {
  font-size: clamp(1.75rem, 3.5vw, 2rem);
  letter-spacing: 0;
  line-height: 1.2;
}

h3 {
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
  font-weight: 400;
}

h4 {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

p {
  font-family: var(--font-sans);
  max-width: 68ch;
  line-height: 1.65;
}
p + p { margin-top: var(--space-4); }

/* Kicker / eyebrow — Manrope, uppercase, gold, tracked */
.eyebrow,
.kicker {
  display: block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--accent);
  margin-bottom: var(--space-4);
}

.section-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: 400;
  color: var(--on-surface-variant);
  margin-top: var(--space-4);
  max-width: 56ch;
}

/* Display — large serif for hero */
.display-heading {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 5rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 1.0;
}

.display-number {
  font-family: var(--font-display);
  font-size: clamp(3rem, 8vw, 4.5rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--primary);
}


/* ─── 4. Layout + Reveals ───────────────────────────────── */
.container {
  width: 100%;
  max-width: var(--container-lg);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--margin-edge);
  padding-right: var(--margin-edge);
}

section {
  padding-top: var(--section-v);
  padding-bottom: var(--section-v);
}

section.section-alt { background: var(--color-neutral-100); }

.section-header { margin-bottom: var(--space-10); }

/* Scroll reveal — kept for explicit .reveal usage only */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 600ms cubic-bezier(0.16, 1, 0.3, 1),
              transform 600ms cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 90ms; }
.reveal-delay-2 { transition-delay: 180ms; }
.reveal-delay-3 { transition-delay: 270ms; }


@media (max-width: 767px) {
  .container { padding-left: var(--space-6); padding-right: var(--space-6); }
  section { padding-top: var(--space-12); padding-bottom: var(--space-12); }
}


/* ─── 5. Buttons ────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  line-height: 1;
  text-decoration: none;
  border-radius: 0;                /* sharp */
  padding: 0.875rem var(--space-6);
  border: 1.5px solid transparent;
  transition: background var(--t-base), color var(--t-base), border-color var(--t-base);
  cursor: pointer;
  white-space: nowrap;
}

.btn-sm { font-size: var(--text-xs); padding: 0.625rem var(--space-4); }

.btn-primary {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}
.btn-primary:hover {
  background: var(--primary-container);
  border-color: var(--primary-container);
}

.btn-gold {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.btn-gold:hover {
  background: var(--color-accent-500);
  border-color: var(--color-accent-500);
}

.btn-secondary {
  background: transparent;
  color: var(--primary);
  border-color: var(--primary);
}
.btn-secondary:hover {
  background: var(--primary);
  color: #fff;
}

.btn-outline {
  background: transparent;
  color: #fff;
  border-color: rgba(255,255,255,0.55);
}
.btn-outline:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.90);
}

.btn-ghost-gold {
  background: transparent;
  color: var(--accent);
  border-color: var(--accent);
}
.btn-ghost-gold:hover {
  background: var(--accent);
  color: #fff;
}

/* Viber / WhatsApp */
.btn-viber {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: #7360F2;
  color: #fff;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: var(--space-3) var(--space-5);
  border-radius: 0;
  text-decoration: none;
  transition: opacity var(--t-base);
}
.btn-viber:hover { opacity: 0.88; }

.btn-whatsapp {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: #25D366;
  color: #fff;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: var(--space-3) var(--space-5);
  border-radius: 0;
  text-decoration: none;
  transition: opacity var(--t-base);
}
.btn-whatsapp:hover { opacity: 0.88; }


/* ─── 6. Accessibility ──────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -100px; left: 0;
  background: var(--primary);
  color: #fff;
  padding: var(--space-3) var(--space-5);
  font-weight: 600;
  text-decoration: none;
  z-index: 1000;
  transition: top var(--t-base);
}
.skip-link:focus { top: 0; }

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

*:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}


/* ─── 7. Header ─────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: var(--banner-h);
  z-index: 100;
  height: var(--header-h);
  background: var(--surface);
  border-bottom: 1px solid rgba(116, 91, 27, 0.25);
  transition: box-shadow var(--t-base), border-color var(--t-base);
}

.site-header.scrolled {
  box-shadow: 0 2px 20px rgba(0, 36, 59, 0.08);
  border-color: rgba(116, 91, 27, 0.4);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: var(--space-6);
}

.logo {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  flex-shrink: 0;
}

.logo-name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  letter-spacing: 0.05em;
  color: var(--primary);
  line-height: 1;
}

.logo-tagline {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  font-weight: 500;
  color: var(--on-surface-variant);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  line-height: 1;
  margin-top: 4px;
}

.logo-img {
  height: 48px;
  width: auto;
  display: block;
  object-fit: contain;
}

.main-nav {
  display: flex;
  align-items: center;
  gap: 0;
  flex: 1;
  justify-content: center;
}

.main-nav > a {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--on-surface-variant);
  text-decoration: none;
  padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid transparent;
  transition: color var(--t-base), border-color var(--t-base);
  white-space: nowrap;
}

.main-nav > a:hover {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

.main-nav > a[aria-current="page"] {
  color: var(--primary);
  border-bottom-color: var(--primary);
}

.header-right {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}

.header-contact {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.header-contact .btn-viber,
.header-contact .btn-whatsapp {
  padding: 0.4rem var(--space-3);
  font-size: var(--text-xs);
}

.lang-switcher {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.lang-divider { color: var(--color-neutral-400); }
.lang-active { color: var(--primary); }

.lang-switcher a {
  color: var(--on-surface-variant);
  text-decoration: none;
  transition: color var(--t-base);
}
.lang-switcher a:hover { color: var(--primary); }

/* Header BOOK NOW button */
.btn-header-cta {
  background: var(--primary);
  color: #fff;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  padding: 0.75rem var(--space-5);
  text-decoration: none;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  border-radius: 0;
  transition: background var(--t-base);
}
.btn-header-cta:hover { background: var(--primary-container); }

.mobile-menu-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: var(--space-2);
  cursor: pointer;
}

.hamburger-line {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--text);
  transition: transform var(--t-base), opacity var(--t-base);
}

.mobile-nav-divider,
.mobile-nav-contact,
.mobile-nav-lang { display: none; }


/* ─── 8. Mobile Navigation ──────────────────────────────── */
@media (max-width: 1023px) {
  .main-nav {
    position: fixed;
    top: calc(var(--banner-h) + var(--header-h));
    left: 0; right: 0; bottom: 0;
    background: var(--surface);
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    padding: var(--space-6);
    overflow-y: auto;
    transform: translateX(100%);
    transition: transform 320ms cubic-bezier(0.4, 0, 0.2, 1);
    border-top: 1px solid var(--outline-variant);
  }

  .main-nav.open {
    transform: translateX(0);
    display: flex;
  }

  .main-nav > a {
    font-size: var(--text-2xl);
    padding: var(--space-5) 0;
    border-bottom: 1px solid var(--color-neutral-200);
    border-right: none;
    letter-spacing: 0.05em;
  }
  .main-nav > a:last-of-type { border-bottom: none; }

  .mobile-nav-divider {
    display: block;
    height: 1px;
    background: var(--color-neutral-200);
    margin: var(--space-6) 0;
  }

  .mobile-nav-contact {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
  }
  .mobile-nav-contact a {
    font-size: var(--text-base);
    font-weight: 500;
    color: var(--on-surface-variant);
    text-decoration: none;
  }

  .mobile-nav-lang {
    display: flex;
    gap: var(--space-4);
    margin-top: var(--space-6);
    font-family: var(--font-sans);
    font-size: var(--text-2xl);
    font-weight: 700;
    text-transform: uppercase;
  }
  .mobile-nav-lang a { color: var(--on-surface-variant); text-decoration: none; }
  .mobile-nav-lang .lang-active { color: var(--primary); }

  .mobile-menu-toggle { display: flex; }
  .header-contact { display: none; }
  .lang-switcher { display: none; }
  .btn-header-cta { display: none; }
}


/* ─── 9. Hero ───────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: calc(100vh - var(--header-h));
  display: flex;
  align-items: flex-end;
  color: #fff;
  overflow: hidden;
  background: var(--primary);
}

.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-color: var(--primary);
}

.hero-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 36, 59, 0.85) 0%,
    rgba(0, 36, 59, 0.40) 50%,
    rgba(0, 36, 59, 0.10) 100%
  );
}

.hero-content {
  position: relative;
  z-index: 2;
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
  width: 100%;
}

.hero-eyeline {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.hero-eyeline-bar {
  width: 3rem;
  height: 1px;
  background: var(--color-accent-200);
}

.hero-eyeline-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-accent-200);
}

.hero h1,
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.75rem, 7vw, 5rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.0;
  color: #fff;
  margin-bottom: var(--space-6);
  max-width: 16ch;
}

.hero-title-secondary {
  display: block;
  font-size: 0.75em;
  opacity: 0.65;
  margin-top: var(--space-2);
}

.hero-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.75);
  max-width: 44ch;
  margin-bottom: var(--space-9);
  line-height: 1.65;
}

.hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}

/* Stats bar in hero */
.hero-stats {
  display: flex;
  gap: var(--space-10);
  margin-top: var(--space-12);
  padding-top: var(--space-7);
  border-top: 1px solid rgba(255, 255, 255, 0.15);
}

.hero-stat { display: flex; flex-direction: column; gap: var(--space-1); }

.hero-stat-value {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 400;
  color: #fff;
  line-height: 1;
}

.hero-stat-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: rgba(255, 255, 255, 0.50);
}

@media (max-width: 767px) {
  .hero { min-height: 75vh; align-items: flex-end; }
  .hero-stats { gap: var(--space-7); }
  .hero-stat-value { font-size: var(--text-3xl); }
  .hero-cta { flex-direction: column; align-items: flex-start; }
}


/* ─── 10. Breadcrumb ────────────────────────────────────── */
.breadcrumb {
  background: var(--color-neutral-100);
  border-bottom: 1px solid var(--color-neutral-300);
  padding: var(--space-3) 0;
}

.breadcrumb-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
}

.breadcrumb-list li { display: flex; align-items: center; gap: var(--space-1); }

.breadcrumb-list a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}
.breadcrumb-list a:hover { text-decoration: underline; }

.bc-sep { color: var(--color-neutral-400); }
.bc-current { font-weight: 600; color: var(--text); }


/* ─── 11. Page Intro ────────────────────────────────────── */
.page-intro {
  background: var(--color-neutral-100);
  border-bottom: 1px solid var(--color-neutral-300);
  padding: var(--space-10) 0;
}

.page-intro h1 { font-size: clamp(2rem, 5vw, 3rem); }
.page-intro .lead { margin-top: var(--space-4); }


/* ─── 12. Stats Grid ────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.stat-item {
  display: flex;
  flex-direction: column;
  padding: var(--space-7) var(--space-6) var(--space-6);
  background: var(--color-neutral-100);
  border: 1px solid var(--color-neutral-300);
  border-radius: 0;
}

.stat-number {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  color: var(--primary);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.stat-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--on-surface-variant);
}

/* Full-width trust stats (homepage) */
.trust-stats-section {
  background: var(--color-neutral-100);
  border-top: 1px solid var(--outline-variant);
  border-bottom: 1px solid var(--outline-variant);
  padding: 0;
}

.trust-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.trust-stat {
  text-align: center;
  padding: var(--space-12) var(--space-7);
  border-right: 1px solid var(--outline-variant);
}
.trust-stat:last-child { border-right: none; }

.trust-stat-number {
  font-family: var(--font-display);
  font-size: clamp(3rem, 6vw, 4rem);
  font-weight: 400;
  color: var(--primary);
  line-height: 1;
  letter-spacing: -0.04em;
  margin-bottom: var(--space-3);
}

.trust-stat-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--on-surface-variant);
}

@media (max-width: 767px) {
  .trust-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .trust-stat { border-bottom: 1px solid var(--outline-variant); }
  .trust-stat:nth-child(even) { border-right: none; }
}


/* ─── 13. Property Cards ────────────────────────────────── */
.property-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1px;
  background: var(--outline-variant);
  margin-top: var(--space-6);
}

.property-card {
  background: var(--surface);
  display: flex;
  flex-direction: column;
  border-radius: 4px;
  transition: box-shadow 400ms cubic-bezier(0.16, 1, 0.3, 1),
              transform 400ms cubic-bezier(0.16, 1, 0.3, 1);
}

.property-card:hover {
  box-shadow: 0 8px 32px rgba(0,36,59,0.12);
  transform: translateY(-2px);
}

.property-card-image {
  aspect-ratio: 4 / 3;
  background: var(--color-neutral-200);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: var(--space-4);
}

.property-card-image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,36,59,0.55) 0%, transparent 50%);
  pointer-events: none;
}

.property-type-badge {
  position: relative;
  z-index: 1;
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: #fff;
  background: var(--primary);
  padding: var(--space-1) var(--space-3);
}

.property-vip-badge {
  position: absolute;
  z-index: 2;
  top: var(--space-4);
  right: var(--space-4);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.25em;
  color: #1a1000;
  background: linear-gradient(135deg, #f5d97a 0%, #e8a020 45%, #c97a00 100%);
  padding: 6px 14px;
  box-shadow: 0 2px 8px rgba(200,120,0,0.45);
}

.property-vip-badge::before {
  content: '★';
  font-size: 0.6rem;
  line-height: 1;
}

.property-hero-image {
  position: relative;
}

.property-vip-badge--hero {
  font-size: 0.78rem;
  padding: 10px 22px;
  letter-spacing: 0.3em;
  gap: 8px;
  box-shadow: 0 3px 14px rgba(200,120,0,0.55);
}

.property-vip-badge--hero::before {
  font-size: 0.75rem;
}

.property-card-body {
  padding: var(--space-5) var(--space-5) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  border-top: 1px solid var(--outline-variant);
}

.property-card-body h3 {
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--text);
  line-height: 1.2;
}

.property-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--on-surface-variant);
}

.property-card-body p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.65;
  flex: 1;
}

.property-card-body .btn { align-self: flex-start; margin-top: auto; }

.property-card.filter-hidden { display: none; }
.complex-filter-section.all-hidden { display: none; }

.filter-no-results {
  display: none;
  text-align: center;
  padding: var(--space-12) 0;
  color: var(--on-surface-variant);
  font-family: var(--font-sans);
  font-size: var(--text-lg);
}
.filter-no-results.visible { display: block; }

/* Property card real image */
.property-card-bg-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--t-slow);
}
.property-card:hover .property-card-bg-img { transform: scale(1.04); }


/* ─── 14. Property Detail ───────────────────────────────── */
.property-hero-image {
  aspect-ratio: 16 / 7;
  overflow: hidden;
  position: relative;
}

.property-detail-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: var(--space-9);
  align-items: start;
  margin-top: var(--space-8);
}

.property-specs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--outline-variant);
  border-bottom: 1px solid var(--outline-variant);
  margin: var(--space-6) 0;
}

.property-spec-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--on-surface-variant);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.property-amenities {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

.amenity-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: var(--space-2) var(--space-3);
  background: var(--color-neutral-100);
  border: 1px solid var(--outline-variant);
  color: var(--on-surface-variant);
}

.property-contact-box {
  background: var(--surface);
  border: 1px solid var(--outline-variant);
  border-top: 3px solid var(--accent);
  padding: var(--space-6);
  position: sticky;
  top: calc(var(--banner-h) + var(--header-h) + var(--space-5));
}

.property-contact-box h4 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--text);
  margin-bottom: var(--space-2);
}

.property-contact-box p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  margin-bottom: var(--space-5);
}

.property-contact-box .contact-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.property-similar { margin-top: var(--space-10); }

.complex-info-box {
  margin-top: var(--space-9);
  padding: var(--space-8);
  background: var(--color-neutral-100);
  border: 1px solid var(--outline-variant);
  border-left: 3px solid var(--accent);
}

.complex-info-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 400;
  color: var(--text);
  margin-bottom: var(--space-4);
}

.complex-info-desc {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--on-surface-variant);
  max-width: 72ch;
}

.complex-info-location {
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  margin-top: var(--space-5);
}

@media (max-width: 900px) {
  .property-detail-grid { grid-template-columns: 1fr; }
  .property-contact-box { position: static; }
}


/* ─── 15. Complex Cards (Overlay Photo Style) ────────────── */

/* Homepage 2x2 grid */
.complexes-overlay-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--outline-variant);
  margin-top: var(--space-10);
}

.complex-overlay-card {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  cursor: pointer;
  display: block;
  text-decoration: none;
}

.complex-overlay-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--t-slow);
}

.complex-overlay-card:hover img { transform: scale(1.05); }

.complex-overlay-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 36, 59, 0.90) 0%,
    rgba(0, 36, 59, 0.20) 55%,
    transparent 100%
  );
}

.complex-overlay-content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: var(--space-8);
  color: #fff;
}

.complex-overlay-content .kicker {
  color: var(--color-accent-200);
  margin-bottom: var(--space-2);
}

.complex-overlay-content h3 {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  font-weight: 400;
  color: #fff;
}

/* Apartments page: complex section headers */
.complexes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1px;
  background: var(--outline-variant);
  margin-top: var(--space-8);
}

.complex-card {
  background: var(--surface);
  display: flex;
  flex-direction: column;
  transition: background var(--t-base);
}
.complex-card:hover { background: var(--color-neutral-100); }

.complex-card-image {
  aspect-ratio: 16 / 10;
  position: relative;
  overflow: hidden;
}

.complex-card-image::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,36,59,0.50) 0%, transparent 60%);
}

.complex-card-content {
  padding: var(--space-5) var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
  border-top: 1px solid var(--outline-variant);
}

.complex-card-content h3 {
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--text);
}

.complex-card-content .tagline {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.55;
}

.complex-card-content .meta {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--on-surface-variant);
}

.complex-card-content .btn { align-self: flex-start; margin-top: auto; }

/* Complex gradient fallbacks (if no image) */
.flora-gradient { background: linear-gradient(150deg, #1A4A2E 0%, #2E6B45 100%); }
.royal-plaza-gradient { background: linear-gradient(150deg, #1E1040 0%, #3D2870 100%); }
.rila-park-gradient { background: linear-gradient(150deg, #122840 0%, #1F4A70 100%); }
.borovets-gardens-gradient { background: linear-gradient(150deg, #1A2A0C 0%, #3A5020 100%); }

/* Complex page hero */
.complex-hero {
  aspect-ratio: 21 / 7;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: var(--space-8);
  color: #fff;
  position: relative;
}

.complex-hero::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,36,59,0.75) 0%, transparent 60%);
}

.complex-hero h1 {
  position: relative;
  z-index: 1;
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 400;
  color: #fff;
}

@media (max-width: 767px) {
  .complexes-overlay-grid { grid-template-columns: 1fr; }
}


/* ─── 16. Complex Section (Apartments page) ─────────────── */
.complex-section-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  padding-top: var(--space-10);
  margin-bottom: var(--space-2);
}
.complex-section-header:first-child { padding-top: 0; }

.complex-section-header h2 { font-size: clamp(1.75rem, 4vw, 2.5rem); }

.count-badge {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--primary);
  background: var(--color-primary-50);
  border: 1px solid var(--color-primary-100);
  padding: var(--space-1) var(--space-3);
}


/* ─── 17. Filter Bar ────────────────────────────────────── */
.filter-bar {
  background: var(--color-neutral-100);
  border: 1px solid var(--outline-variant);
  padding: var(--space-5) var(--space-6);
  margin-bottom: var(--space-8);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.filter-bar-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--on-surface-variant);
  white-space: nowrap;
}

.filter-selects { display: flex; flex-wrap: wrap; gap: var(--space-3); flex: 1; }

.filter-select-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 160px;
}

.filter-select-group label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--on-surface-variant);
}

.filter-select {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--outline-variant);
  border-radius: 0;
  padding: var(--space-2) var(--space-4);
  padding-right: var(--space-8);
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%2342474d'%3E%3Cpath fill-rule='evenodd' d='M5.23 7.21a.75.75 0 011.06.02L10 11.168l3.71-3.938a.75.75 0 111.08 1.04l-4.25 4.5a.75.75 0 01-1.08 0l-4.25-4.5a.75.75 0 01.02-1.06z' clip-rule='evenodd'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  background-size: 18px;
  cursor: pointer;
  transition: border-color var(--t-base);
}
.filter-select:focus { border-color: var(--primary); outline: none; }

.filter-reset {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--on-surface-variant);
  background: none;
  border: 1px solid var(--outline-variant);
  border-radius: 0;
  padding: var(--space-2) var(--space-5);
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--t-base), border-color var(--t-base);
  margin-left: auto;
}
.filter-reset:hover { color: var(--primary); border-color: var(--primary); }

.filter-results-count {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  font-weight: 500;
  white-space: nowrap;
}

@media (max-width: 767px) {
  .filter-bar { padding: var(--space-4); }
  .filter-selects { gap: var(--space-2); }
  .filter-select-group { min-width: calc(50% - var(--space-1)); }
  .filter-reset { margin-left: 0; width: 100%; }
}


/* ─── 18. Services Grid + Cards ─────────────────────────── */

/* Services editorial grid (homepage) */
.services-editorial-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid rgba(116, 91, 27, 0.2);
  border-left: 1px solid rgba(116, 91, 27, 0.2);
  margin-top: var(--space-10);
}

.service-editorial-cell {
  border-right: 1px solid rgba(116, 91, 27, 0.2);
  border-bottom: 1px solid rgba(116, 91, 27, 0.2);
  padding: var(--space-10) var(--space-7);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-5);
  text-decoration: none;
  color: var(--text);
  transition: background var(--t-base);
}

.service-editorial-cell:hover { background: var(--color-neutral-100); }

.service-editorial-cell .material-symbols-outlined {
  font-size: 2.5rem;
  color: var(--accent);
}

.service-editorial-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--text);
}

/* Standard service cards (services page) */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1px;
  background: var(--outline-variant);
  margin-top: var(--space-8);
}

.service-card {
  background: var(--surface);
  padding: var(--space-6);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: background var(--t-base);
}

.service-card:hover { background: var(--color-neutral-100); }

.service-icon,
.service-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  background: var(--color-neutral-100);
  flex-shrink: 0;
}

.service-icon.material-symbols-outlined {
  width: auto; height: auto;
  background: none;
  font-size: 2rem;
  color: var(--accent);
}

.service-card h3 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--text);
  line-height: 1.2;
}

.service-desc,
.service-card p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.65;
}

.service-link-arrow {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--accent);
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

/* Service detail */
.service-detail-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

.service-detail-icon {
  font-size: 2.5rem;
  width: 72px; height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-neutral-100);
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .services-editorial-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ─── 19. Process Steps ─────────────────────────────────── */
.process-steps {
  counter-reset: step-counter;
  display: flex;
  flex-direction: column;
  gap: var(--space-7);
  margin-top: var(--space-7);
}

.process-step {
  counter-increment: step-counter;
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: var(--space-5);
  align-items: start;
}

.process-step::before {
  content: counter(step-counter);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px; height: 52px;
  border: 1px solid var(--outline-variant);
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--primary);
  background: var(--color-neutral-100);
  flex-shrink: 0;
}

.process-step-content h4 {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--text);
  margin-bottom: var(--space-2);
}

.process-step-content p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.65;
}


/* ─── 20. Season Cards ──────────────────────────────────── */
.seasons-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); margin-top: var(--space-8); }

.season-card { background: var(--surface); border: 1px solid var(--outline-variant); overflow: hidden; }

.season-card-header { padding: var(--space-6); background: var(--primary); color: #fff; }
.season-card-header h3 { font-size: var(--text-3xl); font-weight: 400; color: #fff; }

.season-card-body { padding: var(--space-6); }
.season-card-body ul { display: flex; flex-direction: column; gap: var(--space-3); }
.season-card-body li {
  display: flex; align-items: flex-start; gap: var(--space-3);
  font-family: var(--font-sans); font-size: var(--text-sm); color: var(--on-surface-variant); line-height: 1.55;
}
.season-card-body li::before {
  content: '';
  display: inline-block; width: 4px; height: 4px;
  background: var(--accent); flex-shrink: 0; margin-top: 9px;
}

.route-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); margin-top: var(--space-6); }
.route-item { padding: var(--space-5); background: var(--color-neutral-100); border: 1px solid var(--outline-variant); }
.route-item strong {
  font-family: var(--font-display);
  display: block; font-weight: 400; font-size: var(--text-xl);
  margin-bottom: var(--space-1); color: var(--primary);
}
.route-item span { font-family: var(--font-sans); font-size: var(--text-sm); color: var(--on-surface-variant); }

@media (max-width: 767px) {
  .seasons-grid { grid-template-columns: 1fr; }
  .route-grid { grid-template-columns: 1fr; }
}


/* ─── 21. Contact Methods ───────────────────────────────── */
.contact-methods-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1px;
  background: var(--outline-variant);
  margin-top: var(--space-6);
}

.contact-method-card {
  background: var(--surface);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: background var(--t-base);
}
.contact-method-card:hover { background: var(--color-neutral-100); }

.contact-method-icon { font-size: 1.5rem; line-height: 1; }

.contact-method-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--on-surface-variant);
}

.contact-method-value {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 400;
  color: var(--text);
  text-decoration: none;
}
.contact-method-value:hover { color: var(--primary); }

.contact-method-note {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--on-surface-variant);
}


/* ─── 22. Forms ─────────────────────────────────────────── */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}

.form-group label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--on-surface-variant);
}

.form-group input,
.form-group textarea,
.form-group select {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--outline-variant);
  border-radius: 0;
  padding: var(--space-3) var(--space-4);
  transition: border-color var(--t-base);
  width: 100%;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--primary);
  outline: none;
}

.form-group textarea { resize: vertical; min-height: 140px; line-height: 1.65; }

.form-required { color: #ba1a1a; margin-left: var(--space-1); }
.form-honey { display: none; }
.form-submit { margin-top: var(--space-6); }

.form-success {
  display: none;
  padding: var(--space-4) var(--space-5);
  background: #F0FFF4;
  border: 1px solid #9AE6B4;
  color: #276749;
  font-family: var(--font-sans);
  font-weight: 500;
  margin-top: var(--space-5);
}


/* ─── 23. CTA Band ──────────────────────────────────────── */
.cta-band {
  background: var(--primary);
  padding: var(--space-16) var(--space-9);
  color: #fff;
  text-align: center;
}

.cta-band h2, .cta-band h3 {
  color: #fff;
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 400;
}

.cta-band p {
  color: rgba(255,255,255,0.75);
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  max-width: 52ch;
  margin: var(--space-4) auto 0;
}

.cta-band .btn { margin-top: var(--space-7); }


/* ─── 24. Property Images & Gallery ─────────────────────── */
.property-hero-image { position: relative; }
.property-hero-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}

.property-gallery { padding: var(--space-9) 0 0; }

/* Mosaic (desktop ≥768px) */
.gallery-mosaic-wrapper { position: relative; }

.gallery-mosaic {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 4px;
  aspect-ratio: 2 / 1;
  overflow: hidden;
  background: var(--color-neutral-300);
}

.gallery-hero { grid-column: 1 / 3; grid-row: 1 / 3; }

.gallery-cell {
  overflow: hidden;
  cursor: pointer;
  position: relative;
  background: var(--color-neutral-200);
}

.gallery-img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: filter 0.2s ease;
}
.gallery-cell:hover .gallery-img { filter: brightness(1.06); }
.gallery-cell:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }

.gallery-view-all {
  position: absolute;
  bottom: 20px; right: 20px;
  display: flex; align-items: center; gap: 8px;
  background: var(--surface); color: var(--primary);
  border: 1px solid var(--primary);
  padding: 10px 18px;
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: 600;
  cursor: pointer; line-height: 1;
  box-shadow: 0 2px 10px rgba(0,0,0,0.12);
  transition: background var(--t-base), color var(--t-base);
  z-index: 10;
}
.gallery-view-all:hover { background: var(--primary); color: #fff; }

.gallery-count-badge {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--primary); color: #fff;
  padding: 2px 8px; font-size: 11px; font-weight: 700; min-width: 22px; line-height: 1.4;
}

.gallery-carousel { display: none; }

@media (max-width: 1023px) {
  .gallery-mosaic { grid-template-columns: repeat(3, 1fr); }
  .gallery-thumb-4, .gallery-thumb-5 { display: none; }
}

@media (max-width: 767px) {
  .gallery-mosaic-wrapper { display: none; }
  .gallery-carousel { display: block; position: relative; }

  .gallery-carousel-track {
    display: flex;
    overflow-x: auto; overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -ms-overflow-style: none; scrollbar-width: none;
    aspect-ratio: 4 / 3;
  }
  .gallery-carousel-track::-webkit-scrollbar { display: none; }

  .gallery-carousel-slide {
    flex: 0 0 100%; scroll-snap-align: start;
    overflow: hidden; cursor: pointer; position: relative;
  }
  .gallery-carousel-slide .gallery-img { width: 100%; height: 100%; object-fit: cover; }

  .gallery-counter {
    position: absolute; bottom: 14px; right: 14px;
    background: rgba(0,0,0,0.55); color: #fff;
    padding: 4px 12px;
    font-family: var(--font-sans); font-size: 13px; font-weight: 600;
    pointer-events: none; z-index: 5; line-height: 1.4;
  }

  .gallery-dots { display: flex; justify-content: center; flex-wrap: wrap; gap: 6px; padding: 12px 0 4px; }
  .gallery-dot {
    width: 8px; height: 8px;
    background: var(--color-neutral-300); border: none; padding: 0; cursor: pointer; flex-shrink: 0;
    transition: background 0.2s ease;
  }
  .gallery-dot.active { background: var(--primary); }
}

/* Lightbox */
.gallery-lightbox {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  animation: lb-fadein 0.25s ease; outline: none;
}
.gallery-lightbox[hidden] { display: none; }

@keyframes lb-fadein { from { opacity: 0; } to { opacity: 1; } }

.gallery-lb-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.95); cursor: pointer; }

.gallery-lb-inner {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: center;
  max-width: 90vw; max-height: 90vh;
}

.gallery-lb-img { max-width: 90vw; max-height: 90vh; object-fit: contain; display: block; user-select: none; }

.gallery-lb-close {
  position: absolute; top: 16px; right: 16px; z-index: 3;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.25);
  border-radius: 50%; color: #fff; font-size: 20px; cursor: pointer; line-height: 1;
  transition: background 0.15s ease;
}
.gallery-lb-close:hover { background: rgba(255,255,255,0.28); }

.gallery-lb-counter {
  position: absolute; top: 16px; left: 50%; transform: translateX(-50%); z-index: 3;
  color: #fff; font-family: var(--font-sans); font-size: 14px; font-weight: 600;
  background: rgba(0,0,0,0.45); padding: 5px 16px; white-space: nowrap;
}

.gallery-lb-prev, .gallery-lb-next {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 3;
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,0.10); border: 1px solid rgba(255,255,255,0.20);
  border-radius: 50%; color: #fff; font-size: 26px; cursor: pointer; line-height: 1;
  transition: background 0.15s ease;
}
.gallery-lb-prev { left: 20px; }
.gallery-lb-next { right: 20px; }
.gallery-lb-prev:hover, .gallery-lb-next:hover { background: rgba(255,255,255,0.25); }

@media (max-width: 767px) {
  .gallery-lb-prev, .gallery-lb-next { display: none; }
}


/* ─── 25. Page Placeholder ──────────────────────────────── */
.page-placeholder {
  min-height: 50vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center;
  color: var(--on-surface-variant);
}
.page-placeholder h1 { color: var(--text); margin-bottom: var(--space-4); }


/* ─── 26. Footer ────────────────────────────────────────── */
.site-footer {
  background: #07111A;
  color: var(--color-neutral-500);
  border-top: 1px solid rgba(116, 91, 27, 0.2);
}

.site-footer .container {
  padding-top: var(--space-12);
  padding-bottom: var(--space-9);
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: var(--space-8);
  padding-bottom: var(--space-9);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.footer-brand .logo-name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  letter-spacing: 0.05em;
  color: #fff;
}

.footer-brand .logo-tagline {
  font-family: var(--font-sans);
  color: var(--color-neutral-600);
  font-size: 0.625rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.footer-brand p {
  margin-top: var(--space-4);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-neutral-500);
  max-width: 26ch;
}

.footer-since {
  display: block;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--accent);
  margin-top: var(--space-4);
}

.footer-social { display: flex; gap: var(--space-4); margin-top: var(--space-5); }
.footer-social a {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-neutral-500);
  text-decoration: none;
  transition: color var(--t-base);
}
.footer-social a:hover { color: var(--accent); }

.footer-grid > div:not(.footer-brand) h4 {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--accent);
  margin-bottom: var(--space-5);
}

.footer-grid > div:not(.footer-brand) ul {
  display: flex; flex-direction: column; gap: var(--space-3);
}

.footer-grid > div:not(.footer-brand) ul a {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-neutral-500);
  text-decoration: none;
  transition: color var(--t-base);
}
.footer-grid > div:not(.footer-brand) ul a:hover { color: #fff; }

.footer-link {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-neutral-500);
  text-decoration: none;
  transition: color var(--t-base);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.footer-link:hover { color: #fff; }

.footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding-top: var(--space-6);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--color-neutral-700);
}
.footer-bottom a { color: inherit; text-decoration: none; }
.footer-bottom a:hover { color: var(--color-neutral-400); }

.footer-copyright,
.footer-design-credit {
  font-family: var(--font-sans);
  font-size: 11px;
  color: var(--color-neutral-500, rgba(255,255,255,0.45));
  margin: 3px 0;
  letter-spacing: 0.05em;
}

.footer-design-credit a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 200ms;
}

.footer-design-credit a:hover {
  border-bottom-color: var(--accent);
}

@media (max-width: 1023px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: span 2; }
}
@media (max-width: 600px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-brand { grid-column: span 1; }
  .footer-bottom { flex-direction: column; text-align: center; }
}


/* ─── 27. Utility ───────────────────────────────────────── */
.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }
.text-primary { color: var(--primary); }
.text-accent  { color: var(--accent); }
.text-muted   { color: var(--on-surface-variant); }

.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mt-8 { margin-top: var(--space-8); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-8 { margin-bottom: var(--space-8); }
.hidden { display: none !important; }

.divider {
  border: none;
  border-top: 1px solid var(--outline-variant);
  margin: var(--space-8) 0;
}

/* Editorial intro section */
.intro-section { background: var(--surface); }

.intro-grid {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: var(--space-10);
  align-items: center;
}

.intro-image-col { overflow: hidden; }
.intro-image-col img {
  width: 100%; aspect-ratio: 4 / 5;
  object-fit: cover;
  display: block;
  transition: transform var(--t-slow);
}
.intro-image-col:hover img { transform: scale(1.02); }

.intro-text-col { max-width: 42ch; }

.founder-quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  color: rgba(0, 36, 59, 0.5);
  margin-top: var(--space-8);
}

/* Borovets teaser */
.borovets-teaser {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}

.borovets-teaser-bg {
  position: absolute; inset: 0;
  background: var(--primary);
}
.borovets-teaser-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.6;
}

.borovets-teaser-overlay {
  position: absolute; inset: 0;
  background: rgba(0, 36, 59, 0.45);
}

.borovets-teaser-content {
  position: relative; z-index: 1;
  color: #fff;
  padding: var(--space-16) var(--space-6);
  max-width: 800px;
}

.borovets-teaser-content h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 400;
  color: #fff;
  margin-bottom: var(--space-8);
}

.borovets-teaser-link {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-accent-200);
  text-decoration: none;
  border-bottom: 1px solid rgba(201, 169, 97, 0.4);
  padding-bottom: 2px;
  transition: color var(--t-base), border-color var(--t-base);
}
.borovets-teaser-link:hover { color: #fff; border-color: #fff; }

/* About section */
.about { background: var(--surface); }
.about .container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
}
.about-content { max-width: 60ch; }
.services-preview { background: var(--color-neutral-100); }
.contact { background: var(--color-neutral-100); }

/* Contact CTA section (dark) */
.contact-cta-section {
  background: #061320;
  text-align: center;
  color: #fff;
}
.contact-cta-section h2 {
  color: #fff;
  font-size: clamp(2rem, 4vw, 3rem);
}
.contact-cta-section p {
  color: rgba(255,255,255,0.75);
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  margin: var(--space-2) auto 0;
  max-width: none;
}

@media (max-width: 767px) {
  .intro-grid { grid-template-columns: 1fr; }
  .intro-text-col { max-width: none; }
  .about .container { grid-template-columns: 1fr; }
}


/* ─── 28. Reduced Motion ────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
}


/* ─── 29. Promo Banner ──────────────────────────────────── */
.promo-banner {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 200;
  height: 44px;
  background: var(--primary);
  color: rgba(255,255,255,0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 0 var(--space-10);
  gap: var(--space-3);
}

.promo-banner-text {
  display: flex; align-items: center;
  gap: var(--space-3); flex-wrap: wrap; justify-content: center;
}

.promo-banner-text strong { color: var(--color-accent-200); font-weight: 700; }

.promo-banner-cta {
  color: var(--color-accent-200);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid rgba(201,169,97,0.4);
  transition: border-color var(--t-base);
  white-space: nowrap;
}
.promo-banner-cta:hover { border-color: var(--color-accent-200); }

.promo-banner-dismiss {
  position: absolute;
  right: var(--space-4); top: 50%;
  transform: translateY(-50%);
  background: none; border: none;
  color: rgba(255,255,255,0.5);
  font-size: 1rem; cursor: pointer;
  padding: var(--space-2);
  display: flex; align-items: center;
  transition: color var(--t-base);
}
.promo-banner-dismiss:hover { color: #fff; }
.promo-banner.hidden { display: none; }

@media (max-width: 600px) {
  .promo-banner { font-size: var(--text-xs); padding: 0 var(--space-8); overflow: hidden; }
  .promo-banner-text { flex-wrap: nowrap; }
  .promo-banner-text > span { display: none; }
}


/* ─── 30. Phase 7 — UX Polish ───────────────────────────── */

/* Property detail section spacing */
.property-detail-section {
  padding-top: var(--space-10);
  padding-bottom: 0;
}

.property-lower-section {
  padding-top: var(--space-10);
  padding-bottom: var(--section-v);
}

.property-complex-label {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  margin-top: var(--space-2);
  margin-bottom: var(--space-4);
  max-width: none;
}

.property-description {
  margin-top: var(--space-6);
  line-height: 1.65;
}

/* Property spec chips with Material Symbols */
.property-spec {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--on-surface-variant);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.property-spec .material-symbols-outlined {
  font-size: 1.125rem;
  color: var(--accent);
  flex-shrink: 0;
}

/* Contact sidebar — editorial typography (no colored buttons) */
.property-contact-box .kicker { margin-bottom: var(--space-4); }

.contact-phone-row {
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--outline-variant);
}

.contact-phone-number {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 400;
  color: var(--primary);
  text-decoration: none;
  display: block;
  line-height: 1.2;
  transition: color var(--t-base);
}
.contact-phone-number:hover { color: var(--accent); }

.contact-channel-row {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: var(--space-5);
}

.contact-channel-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--on-surface-variant);
  text-decoration: none;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--outline-variant);
  transition: color var(--t-base);
}
.contact-channel-link:last-child { border-bottom: none; }
.contact-channel-link:hover { color: var(--primary); }

.contact-channel-link .material-symbols-outlined {
  font-size: 1.125rem;
  color: var(--outline);
  transition: color var(--t-base);
}
.contact-channel-link:hover .material-symbols-outlined { color: var(--accent); }

.contact-inquire-btn { width: 100%; justify-content: center; }

/* Amenities grid with Material Symbols icons */
.property-amenities-section { margin-bottom: var(--space-9); }
.property-amenities-section h3 { margin-bottom: var(--space-6); }

.amenities-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-4) var(--space-6);
}

.amenity-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--on-surface-variant);
}

.amenity-item .material-symbols-outlined {
  font-size: 1.25rem;
  color: var(--accent);
  flex-shrink: 0;
}

/* Complex hero banner — full-bleed cinematic (property page) */
.complex-hero-banner {
  display: block;
  position: relative;
  aspect-ratio: 21 / 9;
  overflow: hidden;
  text-decoration: none;
  color: #fff;
}

.complex-hero-banner-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--t-slow);
}

.complex-hero-banner:hover .complex-hero-banner-img { transform: scale(1.03); }

.complex-hero-banner-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 36, 59, 0.80) 0%,
    rgba(0, 36, 59, 0.25) 55%,
    transparent 100%
  );
}

.complex-hero-banner-content {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: var(--space-12) var(--space-10);
}

.complex-hero-banner-content .kicker { color: var(--color-accent-200); }

.complex-hero-banner-content h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 400;
  color: #fff;
  margin: var(--space-3) 0 var(--space-2);
}

.complex-hero-banner-tagline {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: rgba(255, 255, 255, 0.75);
  max-width: 52ch;
  margin: 0;
}

@media (max-width: 767px) {
  .complex-hero-banner { aspect-ratio: 16 / 9; }
  .complex-hero-banner-content { padding: var(--space-7) var(--space-6); }
  .complex-hero-banner-content h2 { font-size: 1.75rem; }
}

/* Single Feature Property — Royal Plaza editorial layout */
.single-feature-property {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--color-neutral-100);
  border: 1px solid var(--outline-variant);
  margin-top: var(--space-6);
  overflow: hidden;
}

.sfp-image {
  position: relative;
  overflow: hidden;
}

.sfp-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--t-slow);
}

.single-feature-property:hover .sfp-image img { transform: scale(1.03); }

.sfp-content {
  padding: var(--space-9) var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  justify-content: center;
  border-left: 1px solid var(--outline-variant);
}

.sfp-content .kicker { margin-bottom: 0; }

.sfp-content h3 {
  font-size: clamp(1.5rem, 3vw, 2rem);
  line-height: 1.15;
}

.sfp-content > p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.65;
  max-width: 46ch;
}

.sfp-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--on-surface-variant);
}

.sfp-meta span {
  padding: var(--space-1) var(--space-3);
  background: var(--surface);
  border: 1px solid var(--outline-variant);
}

@media (max-width: 767px) {
  .single-feature-property { grid-template-columns: 1fr; }
  .sfp-image { aspect-ratio: 4 / 3; }
  .sfp-content {
    padding: var(--space-6);
    border-left: none;
    border-top: 1px solid var(--outline-variant);
  }
}

/* Services page — explicit 3-column grid (no 7th empty cell) */
.services-grid--3col {
  grid-template-columns: repeat(3, 1fr);
}

/* Service card hover — arrow nudge */
.service-card:hover .service-link-arrow { transform: translateX(4px); }
.service-link-arrow { transition: transform var(--t-base); }

/* Property card meta icons */
.card-meta-icon {
  font-size: 0.875rem;
  vertical-align: middle;
  margin-right: 2px;
  color: var(--accent);
}

/* Mobile responsive fixes */
@media (max-width: 767px) {
  .services-grid--3col { grid-template-columns: repeat(2, 1fr); }
  .amenities-grid { grid-template-columns: 1fr 1fr; }
  .property-grid { grid-template-columns: 1fr; }
  .property-detail-section { padding-top: var(--space-7); }
  .property-lower-section { padding-top: var(--space-7); }
}

@media (max-width: 480px) {
  .services-grid--3col { grid-template-columns: 1fr; }
  .amenities-grid { grid-template-columns: 1fr; }
}


/* ─── 31. Phase 8 — Real Content & Premium Polish ─────────── */

/* (scroll reveal defined in base styles above) */

/* Service hero — full-bleed photo */
.service-hero {
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--primary);
}

.service-hero-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--t-slow);
}

.service-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 36, 59, 0.85) 0%,
    rgba(0, 36, 59, 0.30) 60%,
    transparent 100%
  );
}

.service-hero-content {
  position: relative; z-index: 1;
  padding-top: var(--space-16);
  padding-bottom: var(--space-12);
  color: #fff;
}

.service-hero-content h1 {
  color: #fff;
  font-size: clamp(2rem, 5vw, 3.5rem);
  margin-top: var(--space-3);
}

@media (max-width: 767px) {
  .service-hero { min-height: 360px; }
  .service-hero-content { padding-bottom: var(--space-9); }
}

/* Accordion — hiking tours */
.accordion { margin-top: var(--space-8); }

.accordion-item {
  border-bottom: 1px solid var(--outline-variant);
}

.accordion-header {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  width: 100%;
  background: none;
  border: none;
  padding: var(--space-6) 0;
  cursor: pointer;
  text-align: left;
}

.accordion-num {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--accent);
  min-width: 2rem;
  flex-shrink: 0;
}

.accordion-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  color: var(--text);
  flex: 1;
  line-height: 1.3;
}

.accordion-icon {
  font-family: var(--font-sans);
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--accent);
  flex-shrink: 0;
  transition: transform 300ms ease;
  line-height: 1;
}

.accordion-item.open .accordion-icon { transform: rotate(45deg); }

.accordion-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 500ms ease;
}

.tour-details-list {
  padding: 0 0 var(--space-7) var(--space-10);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.tour-details-list li {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.55;
  padding-left: var(--space-2);
}

@media (max-width: 767px) {
  .accordion-title { font-size: var(--text-base); }
  .tour-details-list { padding-left: var(--space-6); }
}

/* Safari — 2×2 tour cards */
.safari-tours-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-8);
}

.safari-tour-card {
  border: 1px solid var(--accent);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.safari-tour-card .kicker { margin-bottom: 0; }

.safari-tour-card h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  line-height: 1.25;
  color: var(--text);
}

@media (max-width: 767px) {
  .safari-tours-grid { grid-template-columns: 1fr; }
  .safari-tour-card { padding: var(--space-6); }
}

/* About Borovets — editorial layout */
.about-editorial-body {
  max-width: 68ch;
}

.about-editorial-body p {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 400;
  line-height: 1.7;
  color: var(--text);
}

.about-editorial-body .kicker {
  display: block;
  margin-bottom: var(--space-5);
}

/* Borovets photo mosaic */
.borovets-mosaic-section {
  padding: var(--space-8) 0;
  overflow: hidden;
}

.borovets-mosaic {
  columns: 3;
  column-gap: 4px;
}

.borovets-mosaic-cell {
  break-inside: avoid;
  margin-bottom: 4px;
  overflow: hidden;
}

.borovets-mosaic-cell img {
  width: 100%;
  display: block;
  object-fit: cover;
  transition: transform var(--t-slow);
}

.borovets-mosaic-cell:hover img { transform: scale(1.04); }

@media (max-width: 767px) {
  .borovets-mosaic { columns: 2; }
}

@media (max-width: 480px) {
  .borovets-mosaic { columns: 1; }
}

/* Ski facts — 3-column (2 rows of 3) */
.ski-facts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--outline-variant);
  border: 1px solid var(--outline-variant);
  margin-top: var(--space-6);
}

.ski-fact {
  background: var(--surface);
  padding: var(--space-6) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.ski-fact-value {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 400;
  color: var(--primary);
  line-height: 1;
}

.ski-fact-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--on-surface-variant);
}

@media (max-width: 767px) {
  .ski-facts-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .ski-facts-grid { grid-template-columns: 1fr; }
}

/* Ski zones — 3 cards */
.ski-zones-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-6);
}

.ski-zone-card {
  border-left: 3px solid var(--accent);
  padding: var(--space-5) var(--space-6);
  background: var(--surface);
}

.ski-zone-card h3 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 400;
  margin-bottom: var(--space-2);
}

.ski-zone-card p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
}

@media (max-width: 767px) {
  .ski-zones-grid { grid-template-columns: 1fr; }
}

/* Premium contact page */
.contact-premium-section { padding: var(--section-v) 0; }

.contact-premium-grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-14);
  align-items: start;
}

.contact-info-col {
  position: sticky;
  top: calc(var(--header-h, 72px) + var(--space-8));
}

.contact-info-company {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 400;
  margin-top: var(--space-4);
  line-height: 1.2;
}

.contact-info-desc {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--on-surface-variant);
  margin-top: var(--space-2);
}

.contact-info-license {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--on-surface-variant);
  margin-top: var(--space-1);
}

.contact-info-block {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--outline-variant);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.contact-info-block .kicker { margin-bottom: var(--space-1); }

.contact-info-phone {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 400;
  color: var(--primary);
  text-decoration: none;
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  transition: color var(--t-base);
}
.contact-info-phone:hover { color: var(--accent); }

.contact-info-lang {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--on-surface-variant);
}

.contact-info-fax {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  display: block;
}

.contact-info-hours {
  display: block;
  margin-top: 2px;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--on-surface-variant);
  opacity: 0.85;
}

.contact-info-email {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--primary);
  text-decoration: none;
  transition: color var(--t-base);
  display: block;
}
.contact-info-email:hover { color: var(--accent); }

/* Contact channel links (Viber / WhatsApp in contact page) */
.contact-info-col .contact-channel-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--on-surface-variant);
  text-decoration: none;
  transition: color var(--t-base);
}
.contact-info-col .contact-channel-link:hover { color: var(--primary); }
.contact-info-col .contact-channel-link svg { flex-shrink: 0; }

/* Premium form */
.contact-form-col .kicker { display: block; margin-bottom: var(--space-7); }

.contact-premium-form { display: flex; flex-direction: column; gap: var(--space-7); }

.form-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}

.form-field { display: flex; flex-direction: column; gap: var(--space-2); }

.form-label-kicker {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--accent);
}

.form-required { color: var(--accent); margin-left: 2px; }

.form-input-line {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--text);
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--outline);
  padding: var(--space-3) 0;
  outline: none;
  width: 100%;
  transition: border-color var(--t-base);
  appearance: none;
  -webkit-appearance: none;
}

.form-input-line:focus { border-bottom-color: var(--primary); }

.form-select-line {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' viewBox='0 0 12 8'%3E%3Cpath stroke='%23745b1b' stroke-width='1.5' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0 center;
  padding-right: var(--space-6);
}

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

.contact-submit-btn {
  margin-top: var(--space-3);
  letter-spacing: 0.1em;
}

@media (max-width: 1023px) {
  .contact-premium-grid { grid-template-columns: 1fr; gap: var(--space-10); }
  .contact-info-col { position: static; }
}

@media (max-width: 600px) {
  .form-row-2 { grid-template-columns: 1fr; }
}

/* Property management page */
.pm-content-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-12);
  align-items: start;
  margin-top: var(--space-10);
  padding-bottom: var(--section-v);
}

.pm-body p {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--text);
  line-height: 1.7;
  margin-bottom: var(--space-5);
}

.pm-body .lead {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: 1.55;
  color: var(--text);
  margin-bottom: var(--space-6);
}

.pm-body-image {
  margin-top: var(--space-8);
  overflow: hidden;
}

.pm-body-image img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
}

.pm-services-list {
  margin: var(--space-6) 0;
  padding-left: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.pm-services-list li {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.65;
}

.pm-sidebar {
  position: sticky;
  top: calc(var(--header-h, 72px) + var(--space-8));
  display: flex;
  flex-direction: column;
  gap: 0;
}

.pm-key-service {
  padding: var(--space-6);
  border-bottom: 1px solid var(--outline-variant);
}
.pm-key-service:first-child { border-top: 1px solid var(--outline-variant); }

.pm-key-icon {
  font-size: 1.5rem;
  color: var(--accent);
  margin-bottom: var(--space-3);
  display: block;
}

.pm-key-service h4 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  margin-bottom: var(--space-2);
}

.pm-key-service p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.55;
}

@media (max-width: 1023px) {
  .pm-content-grid { grid-template-columns: 1fr; }
  .pm-sidebar { position: static; flex-direction: row; flex-wrap: wrap; }
  .pm-key-service { flex: 1 1 240px; border: 1px solid var(--outline-variant); }
  .pm-key-service:first-child { border-top: 1px solid var(--outline-variant); }
}

/* Image slow zoom on card hover (complex cards, service cards) */
.complex-card:hover .property-card-image,
.service-card { overflow: hidden; }

.property-card-bg-img {
  transition: transform 800ms ease;
}
.property-card:hover .property-card-bg-img { transform: scale(1.05); }

/* Contact methods grid */
.contact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.contact-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--surface);
  border: 1px solid var(--color-neutral-200);
  border-radius: 10px;
  text-decoration: none;
  color: var(--on-surface);
  transition: border-color 0.18s, box-shadow 0.18s;
}

.contact-card:hover {
  border-color: var(--primary);
  box-shadow: 0 2px 12px rgba(0,36,59,0.08);
}

.contact-card-icon {
  width: 2.75rem;
  height: 2.75rem;
  background: var(--sky);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contact-card-icon .material-symbols-outlined,
.contact-card-icon svg {
  display: block;
  font-size: 1.25rem;
  width: 1.25rem;
  height: 1.25rem;
  color: var(--accent);
}

.contact-card-body h3 {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--on-surface);
  margin-bottom: var(--space-1);
  font-family: var(--font-sans);
}

.contact-card-body p {
  font-size: var(--text-sm);
  color: var(--primary);
  font-family: var(--font-sans);
  font-weight: 500;
}

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

@media (max-width: 540px) {
  .contact-grid { grid-template-columns: 1fr; }
}

/* Button hover polish */
.btn-primary:hover { background: #001929; }
.btn-outline:hover { color: var(--primary); border-color: var(--primary); }


/* ─── 32. Phase 9 — Polish + Webcams + Layout ─────────────── */

/* Property grid — 3 cols, generous gap */
.property-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-8);
  background: transparent;
}

.property-grid--2col {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-8);
}

@media (max-width: 1023px) {
  .property-grid       { grid-template-columns: repeat(2, 1fr); }
  .property-grid--2col { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .property-grid       { grid-template-columns: 1fr; }
  .property-grid--2col { grid-template-columns: 1fr; }
}

/* Premium Viber / WhatsApp — official brand colors */
.btn-viber {
  background: #7360F2;
  color: #fff;
  border: none;
  opacity: 1;
  transition: background var(--t-base), transform var(--t-base);
}
.btn-viber:hover {
  background: #5A4FE6;
  opacity: 1;
  transform: translateY(-2px) scale(1.02);
}

.btn-whatsapp {
  background: #25D366;
  color: #fff;
  border: none;
  opacity: 1;
  transition: background var(--t-base), transform var(--t-base);
}
.btn-whatsapp:hover {
  background: #1DB854;
  opacity: 1;
  transform: translateY(-2px) scale(1.02);
}

/* CTA social buttons wrapper */
.cta-social-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  margin-top: var(--space-5);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.cta-social-buttons .btn-viber,
.cta-social-buttons .btn-whatsapp {
  flex: 1;
  min-width: 160px;
  justify-content: center;
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
}

/* PM services checklist */
.pm-checklist-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 var(--space-10);
  margin: var(--space-8) 0 var(--space-6);
}

.pm-checklist-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--accent);
}

.pm-checklist-icon {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--accent);
}

.pm-checklist-icon svg {
  display: block;
  width: 16px;
  height: 16px;
  stroke: currentColor;
}

.pm-checklist-text {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.55;
}

@media (max-width: 767px) {
  .pm-checklist-grid { grid-template-columns: 1fr; }
}

/* PM furnishing packages */
.pm-furnishing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-8);
}

.pm-furnishing-card {
  border: 1px solid var(--accent);
  padding: var(--space-8) var(--space-6);
  text-align: center;
}

.pm-furnishing-card .kicker { display: block; margin-bottom: var(--space-4); }

.pm-furnishing-name {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 400;
  color: var(--primary);
  line-height: 1.1;
}

.pm-furnishing-note {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--on-surface-variant);
  line-height: 1.65;
  margin-top: var(--space-6);
  max-width: 68ch;
}

@media (max-width: 767px) {
  .pm-furnishing-grid { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* PM CTA — dark navy full-bleed */
.pm-cta-section {
  background: var(--primary);
}

.pm-cta-section h2 {
  color: #fff;
  font-size: clamp(1.75rem, 4vw, 2.75rem);
}

.pm-cta-section .pm-cta-lead {
  color: rgba(255, 255, 255, 0.78);
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  margin-top: var(--space-4);
  max-width: 52ch;
  margin-left: auto;
  margin-right: auto;
}

/* Services contact strip — 2-column premium layout */
.services-contact-strip {
  background: var(--primary);
  padding: var(--space-16) 0;
  position: relative;
  overflow: hidden;
}

.services-contact-strip::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 55%;
  background: radial-gradient(ellipse at 85% 50%, rgba(116,91,27,0.14) 0%, transparent 65%);
  pointer-events: none;
}

.scs-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
  position: relative;
  z-index: 1;
}

.scs-text h2 {
  color: #fff;
  font-size: clamp(1.75rem, 3.5vw, 2.5rem);
  margin-top: var(--space-3);
  line-height: 1.2;
}

.scs-text p {
  color: rgba(255,255,255,0.62);
  margin-top: var(--space-5);
  font-size: var(--text-lg);
  font-family: var(--font-sans);
  line-height: 1.6;
}

.scs-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.scs-phone-card {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  color: #fff;
  text-decoration: none;
  transition: background 0.18s, border-color 0.18s;
}

.scs-phone-card:hover {
  background: rgba(255,255,255,0.13);
  border-color: rgba(255,255,255,0.22);
}

.scs-phone-card .material-symbols-outlined {
  font-size: 1.5rem;
  color: var(--color-accent-200);
  flex-shrink: 0;
}

.scs-lang-tag {
  display: block;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--color-accent-200);
  text-transform: uppercase;
  margin-bottom: 2px;
}

.scs-phone-num {
  display: block;
  font-size: var(--text-lg);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.scs-instant {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

.scs-instant .btn-viber,
.scs-instant .btn-whatsapp {
  justify-content: center;
  flex: none;
}

@media (max-width: 900px) {
  .scs-inner { grid-template-columns: 1fr; gap: var(--space-8); }
}

/* Transfers page — icon hero */
.transfers-hero-section {
  background: linear-gradient(135deg, var(--primary) 0%, #0a2d47 100%);
  padding: var(--space-20) 0 var(--space-16);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.transfers-hero-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(116,91,27,0.18) 0%, transparent 65%);
  pointer-events: none;
}

.transfers-hero-content {
  position: relative;
  z-index: 1;
}

.transfers-hero-icon {
  font-size: 3.5rem;
  color: var(--color-accent-200);
  display: block;
  margin-bottom: var(--space-4);
}

.transfers-hero-content h1 {
  color: #fff;
  font-size: clamp(2rem, 5vw, 3.25rem);
  margin-top: var(--space-3);
}

.transfers-hero-content .lead {
  color: rgba(255,255,255,0.78);
  margin-top: var(--space-4);
  font-size: var(--text-xl);
  max-width: 52ch;
  margin-left: auto;
  margin-right: auto;
}

/* Transfers route cards */
.transfers-routes-section {
  padding: var(--space-16) 0;
}

.transfers-routes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-8);
}

.transfer-route-card {
  padding: var(--space-8) var(--space-6);
  background: var(--surface);
  border: 1px solid var(--color-neutral-200);
  border-radius: 12px;
  text-align: center;
}

.transfer-route-card .material-symbols-outlined {
  font-size: 2.5rem;
  color: var(--primary);
  display: block;
  margin-bottom: var(--space-4);
}

.transfer-route-card h3 {
  font-size: var(--text-xl);
  color: var(--primary);
  margin-bottom: var(--space-3);
}

.transfer-route-card p {
  font-size: var(--text-base);
  color: var(--on-surface-variant);
  line-height: 1.7;
}

.transfers-note {
  margin-top: var(--space-8);
  text-align: center;
  color: var(--on-surface-variant);
  font-size: var(--text-sm);
}

@media (max-width: 767px) {
  .transfers-routes-grid { grid-template-columns: 1fr; }
}

/* About Borovets — editorial photo rows */
.about-photo-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  overflow: hidden;
}

.about-photo-row--2col {
  grid-template-columns: 2fr 1fr;
}

.about-photo-row img {
  width: 100%;
  aspect-ratio: 3/2;
  height: auto;
  object-fit: cover;
  display: block;
}

.about-photo-single { overflow: hidden; }

.about-photo-single img {
  width: 100%;
  height: clamp(380px, 30vw, 600px);
  object-fit: cover;
  display: block;
}

@media (max-width: 767px) {
  .about-photo-row            { grid-template-columns: repeat(2, 1fr); }
  .about-photo-row--2col      { grid-template-columns: 1fr; }
  .about-photo-row img        { aspect-ratio: unset; height: 180px; }
  .about-photo-single img     { height: 260px; }
}

/* Webcam page */
.webcam-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-8);
}

.webcam-card {
  border: 1px solid var(--accent);
  overflow: hidden;
}

.webcam-thumb {
  position: relative;
  overflow: hidden;
  background: var(--color-neutral-100, #f0ece4);
  aspect-ratio: 16 / 9;
}

.webcam-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.webcam-card-label {
  background: #000;
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: var(--space-2) var(--space-4);
}

@media (max-width: 767px) {
  .webcam-grid { grid-template-columns: 1fr; }
}

/* Footer brand / credit */
.footer-copyright,
.footer-design-credit {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.45);
  letter-spacing: 0.05em;
}
.footer-design-credit a {
  color: var(--accent);
  border-bottom: 1px solid transparent;
  transition: border-color 200ms;
}
.footer-design-credit a:hover { border-color: var(--accent); }


/* ─── 33. Phase 9.2 — Services Editorial + Mobile Fixes ─── */

/* hero-sm — compact hero used on complex/service pages */
.hero-sm {
  min-height: 380px;
}

/* Prevent horizontal scroll site-wide */
html, body { overflow-x: hidden; max-width: 100%; }

/* Smaller hero on mobile */
@media (max-width: 767px) {
  .hero       { min-height: 60vh; }
  .hero-sm    { min-height: 240px; }
  .hero h1,
  .hero-title { font-size: clamp(2rem, 8vw, 2.75rem); }
  .hero-subtitle { font-size: var(--text-base); margin-bottom: var(--space-6); }
}

/* Touch targets on mobile */
@media (max-width: 767px) {
  .btn,
  .btn-viber,
  .btn-whatsapp,
  a.btn-viber,
  a.btn-whatsapp {
    min-height: 44px;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
  }
}

/* Services compact hero */
.services-compact-hero {
  background: var(--primary);
  padding: var(--space-16) 0 var(--space-12);
  text-align: center;
}

.services-compact-hero .kicker {
  color: var(--accent);
}

.services-compact-hero h1 {
  color: #fff;
  font-size: clamp(2.5rem, 5vw, 4rem);
  margin-top: var(--space-4);
  margin-bottom: 0;
}

.services-compact-hero .services-lead {
  color: rgba(255, 255, 255, 0.72);
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  margin-top: var(--space-5);
  margin-bottom: 0;
}

.services-hero-divider {
  width: 64px;
  height: 1px;
  background: var(--accent);
  margin: var(--space-8) auto 0;
}

/* Services editorial grid */
.services-editorial-section {
  padding: var(--space-12) 0;
}

.services-editorial-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* Editorial card — portrait, image + gradient overlay */
.service-editorial-card {
  position: relative;
  display: block;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  text-decoration: none;
  cursor: pointer;
  color: inherit;
}

.sec-image {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 600ms cubic-bezier(0.25, 0.46, 0.45, 0.94),
              filter 600ms ease;
}

.service-editorial-card:hover .sec-image {
  transform: scale(1.04);
  filter: brightness(1.06);
}

.sec-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 30%, rgba(0, 24, 40, 0.86) 100%);
  transition: background 600ms ease;
}

.service-editorial-card:hover .sec-overlay {
  background: linear-gradient(to bottom, transparent 20%, rgba(0, 24, 40, 0.93) 100%);
}

.sec-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--space-8) var(--space-6);
}

.sec-rule {
  width: 24px;
  height: 1px;
  background: var(--accent);
  margin-bottom: var(--space-4);
}

.sec-kicker {
  display: block;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent-200);
  margin-bottom: var(--space-3);
}

.sec-content h3 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.2vw, 2rem);
  font-weight: 400;
  color: #fff;
  margin: 0 0 var(--space-3);
  line-height: 1.15;
}

.sec-desc {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: rgba(255, 255, 255, 0.78);
  margin: 0 0 var(--space-5);
  line-height: 1.5;
}

.sec-arrow {
  display: inline-block;
  font-size: var(--text-lg);
  color: var(--accent);
  transition: transform 300ms ease;
}

.service-editorial-card:hover .sec-arrow {
  transform: translateX(6px);
}

/* Editorial cards — responsive */
@media (max-width: 1023px) {
  .services-editorial-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .service-editorial-card {
    aspect-ratio: 16 / 9;
  }
}

@media (max-width: 600px) {
  .service-editorial-card {
    aspect-ratio: 4 / 3;
  }
}

/* Safari tour card — hover lift */
.safari-tour-card {
  transition: box-shadow 200ms ease, transform 200ms ease;
}
.safari-tour-card:hover {
  box-shadow: 0 8px 24px rgba(0, 36, 59, 0.12);
  transform: translateY(-3px);
}


/* ─── 34. Phase 9.3 — Mobile Optimization ────────────────── */

/* Fix: homepage services icon grid — Phase 9.2 incorrectly overwrote the
   border-trick layout. Restore it with higher specificity selectors. */
.services-preview .services-editorial-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(116, 91, 27, 0.2);
  border-left: 1px solid rgba(116, 91, 27, 0.2);
  margin-top: var(--space-10);
}
@media (max-width: 1023px) {
  .services-editorial-section .services-editorial-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .services-preview .services-editorial-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .services-preview .services-editorial-grid { grid-template-columns: 1fr; }
}

/* 1. Hamburger — 44×44px touch target, gold lines */
@media (max-width: 1023px) {
  .mobile-menu-toggle {
    min-width: 44px;
    min-height: 44px;
    justify-content: center;
    align-items: center;
  }
  .hamburger-line { background: var(--accent); }
}

/* 2. Hero mobile — 50vh, stacked + centered CTAs */
@media (max-width: 767px) {
  .hero { min-height: 50vh; }
  .hero-cta {
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  .hero-cta .btn {
    width: 100%;
    max-width: 280px;
    text-align: center;
    justify-content: center;
  }
}

/* 3. About / Intro section — photo max-height + gold divider on mobile */
@media (max-width: 767px) {
  .intro-image-col {
    border-bottom: 1px solid rgba(116, 91, 27, 0.25);
    padding-bottom: var(--space-6);
  }
  .intro-image-col img {
    aspect-ratio: auto;
    max-height: 280px;
    width: 100%;
    object-fit: cover;
  }
}

/* 4. Complex overlay cards — gap, portrait ratio, cleaner gradient */
.complex-overlay-gradient {
  background: linear-gradient(to top, rgba(0, 24, 40, 0.82) 0%, transparent 42%);
}

.complex-apt-count {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--color-accent-200);
  letter-spacing: 0.04em;
  margin-top: var(--space-2);
  opacity: 0.9;
}

@media (max-width: 767px) {
  .complexes-wrapper { padding: 0 !important; }
  .complexes-overlay-grid {
    gap: 12px;
    background: transparent;
    padding: 0;
  }
  .complex-overlay-card { aspect-ratio: 4 / 5; }
  .complex-overlay-content { padding: var(--space-5); }
  .complex-overlay-content h3 {
    font-size: 1.375rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .complex-kicker { font-size: 10px; opacity: 0.7; }
}

/* 5. Homepage services icon cells — tighter padding on mobile */
@media (max-width: 767px) {
  .service-editorial-cell { padding: var(--space-6) var(--space-5); gap: var(--space-3); }
}

/* 6. Borovets teaser — less height + smaller headline on mobile */
@media (max-width: 767px) {
  .borovets-teaser { min-height: auto; }
  .borovets-teaser-content { padding: var(--space-12) var(--space-5); }
  .borovets-teaser-content h2 { font-size: clamp(1.75rem, 7vw, 2rem); }
  .borovets-teaser-link { display: inline-flex; align-items: center; min-height: 44px; }
}

/* 7. Trust stats — smaller numbers on mobile */
@media (max-width: 767px) {
  .trust-stat { padding: var(--space-6) var(--space-5); }
  .trust-stat-number { font-size: clamp(2rem, 8vw, 2.5rem); }
}

/* 8. Contact CTA — tighter padding on mobile */
@media (max-width: 767px) {
  .contact-cta-section { padding: var(--space-10) var(--space-5); }
  .contact-cta-section p { font-size: var(--text-base); }
}

/* 9. Footer — tighter spacing on mobile */
@media (max-width: 600px) {
  .site-footer .container { padding-top: var(--space-8); padding-bottom: var(--space-6); }
  .footer-grid { gap: var(--space-6); }
  .footer-grid > div:not(.footer-brand) ul { gap: var(--space-2); }
  .footer-grid > div:not(.footer-brand) ul a,
  .footer-link { font-size: 13px; }
}

/* 10. Section vertical rhythm — reduce on mobile */
@media (max-width: 767px) {
  .section-header h2 { font-size: clamp(1.5rem, 6vw, 2rem); }
  .intro-section { padding-top: var(--space-12); padding-bottom: var(--space-12); }
  #complexes { padding-top: var(--space-12) !important; padding-bottom: var(--space-12) !important; }
  .services-preview { padding-top: var(--space-10) !important; padding-bottom: var(--space-10) !important; }
}

/* 11. Hamburger lines — thinner, wider, gold, with X animation on open */
.hamburger-line {
  width: 24px;
  height: 1.5px;
  transition: transform 350ms cubic-bezier(0.16, 1, 0.3, 1),
              opacity 200ms ease;
}
.mobile-menu-toggle { gap: 6px; }

.mobile-menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(1) {
  transform: translateY(7.5px) rotate(45deg);
}
.mobile-menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.mobile-menu-toggle[aria-expanded="true"] .hamburger-line:nth-child(3) {
  transform: translateY(-7.5px) rotate(-45deg);
}

/* 12. Premium mobile nav — navy overlay */
@media (max-width: 1023px) {
  .main-nav {
    background: #00243b;
    transition: transform 400ms cubic-bezier(0.16, 1, 0.3, 1);
    align-items: center;
  }
  .main-nav > a {
    color: rgba(255, 255, 255, 0.85);
    border-bottom: 1px solid rgba(116, 91, 27, 0.25);
    text-align: center;
    width: 100%;
    padding: var(--space-5) 0;
  }
  .main-nav > a[aria-current="page"],
  .main-nav > a:hover { color: var(--color-accent-200); }
  .main-nav > a:last-of-type { border-bottom: none; }
  .mobile-nav-divider { background: rgba(116, 91, 27, 0.25); }
  .mobile-nav-contact a { color: rgba(255, 255, 255, 0.65); text-align: center; }
  .mobile-nav-lang {
    justify-content: center;
    color: rgba(255, 255, 255, 0.65);
  }
  .mobile-nav-lang .lang-active { color: var(--color-accent-200); }
  .mobile-nav-lang a { color: rgba(255, 255, 255, 0.65); }
}

/* 13. Logo overflow on mobile — prevent clipping */
@media (max-width: 1023px) {
  .logo { max-width: 160px; overflow: hidden; }
  .logo-name { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
}

/* 14. Nav icons — hidden desktop, gold + visible on mobile hamburger */
.nav-icon { display: none; }
@media (max-width: 1023px) {
  .nav-icon {
    display: inline;
    font-size: 18px;
    line-height: 1;
    vertical-align: -4px;
    margin-right: var(--space-3);
    color: var(--color-accent-200);
    font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
  }
  .main-nav > a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    font-size: 1rem;
    letter-spacing: 0.06em;
  }
  .main-nav > a .nav-icon { margin-right: 0; }
}

/* 15. Complex cards: match container side padding (not full bleed), shorter ratio */
@media (max-width: 767px) {
  .complexes-wrapper { padding: 0 var(--space-6) !important; }
  .complex-overlay-card { aspect-ratio: 3 / 2; }
}

/* 16. Services compact hero — reduce vertical padding on mobile */
@media (max-width: 767px) {
  .services-compact-hero { padding-top: var(--space-10) !important; padding-bottom: var(--space-8) !important; }
  .services-compact-hero h1 { font-size: clamp(2rem, 8vw, 3rem); }
  .services-hero-divider { margin-top: var(--space-5); }
  .services-editorial-section { padding-top: var(--space-6) !important; padding-bottom: var(--space-8) !important; }
}

/* 17. Service editorial cards — better overlay + text readability */
.sec-overlay {
  background: linear-gradient(to bottom, rgba(0, 24, 40, 0.08) 0%, rgba(0, 24, 40, 0.90) 65%);
}
.sec-content h3,
.sec-desc,
.sec-kicker {
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.55);
}
@media (max-width: 767px) {
  .service-editorial-card { aspect-ratio: 16 / 9; }
  .sec-overlay {
    background: linear-gradient(to bottom, rgba(0, 24, 40, 0.18) 0%, rgba(0, 24, 40, 0.94) 58%);
  }
  .sec-content { padding: var(--space-5) var(--space-5); }
}

/* 18. Property card: dark navy placeholder (no ugly grey), better crop position */
.property-card-image { background: var(--primary); }
.property-card-bg-img { object-position: center center; }
.sfp-image { background: var(--primary); }

/* 19. Apartment page: gold separator between complex sections */
.complex-filter-section + .complex-filter-section {
  border-top: 1px solid rgba(116, 91, 27, 0.2);
}
.complex-filter-section + .complex-filter-section .complex-section-header:first-child {
  padding-top: var(--space-10);
}

/* 20. Service photo gallery grid */
.service-gallery-section {
  padding: var(--space-4) 0 0;
}
.service-body-section {
  padding-top: var(--space-8);
}
.service-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
}
.service-gallery-item {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--primary);
}
.service-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 400ms ease;
}
.service-gallery-item:hover img {
  transform: scale(1.04);
}
@media (max-width: 767px) {
  .service-gallery-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-1); }
}
@media (max-width: 480px) {
  .service-gallery-grid { grid-template-columns: repeat(2, 1fr); }
}
