/*
 * assets/css/main.css
 * Dizajn systém — CSS premenné, reset, typografia, základné utility.
 * Toto je základ — components.css a pages.css stavajú na tomto.
 *
 * DÔLEŽITÉ: Neupravuj farby ani fonty bez konzultácie s dizajnom.
 * Referencia: realitna-stranka-luxury.html
 */

/* ─── GOOGLE FONTS ────────────────────────────────────────────────────────── */
/* Načítané cez enqueue.php — tu nie je potrebný @import */

/* ─── CSS PREMENNÉ (dizajn systém) ───────────────────────────────────────── */
:root {
  /* Pozadie — tmavá paleta (neutrálna, chladná — spots rebrand) */
  --black:    #0A0B0D;
  --black2:   #111317;
  --black3:   #191C21;
  --black4:   #23262D;

  /* Modrá paleta — primárny akcent (spots brand blue #083EDC, na tmavom
     pozadí zosvetlené odtiene kvôli kontrastu; názvy --gold* ostávajú
     kvôli spätnej kompatibilite naprieč components/pages.css) */
  --gold:     #3D6BFF;
  --gold2:    #6B8FFF;
  --gold3:    #9DB5FF;
  --gold4:    #CEDBFF;

  /* Text — WCAG AA/AAA compliant na tmavom pozadí */
  --offwhite: #F2F4F8;   /* nadpisy, kľúčový obsah  — kontrast ~16:1 AAA */
  --dim:      #C4C9D4;   /* bežný text, odseky       — kontrast ~8.5:1 AAA */
  --dimmer:   #A0A6B2;   /* sekundárny text, labely  — kontrast ~6.2:1 AA  */

  /* Linky a orámovanie */
  --line:     rgba(61, 107, 255, 0.25);    /* modrá linka */
  --linew:    rgba(242, 244, 248, 0.09);   /* biela linka */

  /* Typografia */
  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans:  'Jost', system-ui, sans-serif;
  --font-brand: 'Tenor Sans', Georgia, serif;

  /* Spacing */
  --section-pad-v: 5rem;
  --section-pad-h: 3.5rem;
  --section-pad-v-mobile: 3rem;
  --section-pad-h-mobile: 1.5rem;

  /* Prechody */
  --transition: 0.25s ease;
  --transition-slow: 0.5s ease;
}

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

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

body {
  font-family: var(--font-sans);
  font-weight: 300;
  background-color: var(--black);
  color: var(--offwhite);
  overflow-x: hidden;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

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

button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
}

ul, ol {
  list-style: none;
}

/* ─── SCROLLBAR ──────────────────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 4px; }
::-webkit-scrollbar-track { background: var(--black); }
::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 2px; }

/* ─── TYPOGRAFIA ─────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  font-weight: 300;
  line-height: 1.1;
  color: var(--offwhite);
}

h1 { font-size: clamp(2.5rem, 5vw, 4.5rem); }
h2 { font-size: clamp(1.8rem, 3vw, 2.5rem); }
h3 { font-size: clamp(1.3rem, 2vw, 1.8rem); }
h4 { font-size: 1.1rem; font-family: var(--font-sans); font-weight: 400; }

p {
  font-size: 0.95rem;
  font-weight: 400;
  line-height: 1.9;
  color: var(--dim);
}

em, i {
  font-style: italic;
  color: var(--gold3);
}

strong, b {
  font-weight: 400;
}

/* ─── SEKCIE ─────────────────────────────────────────────────────────────── */
.section {
  padding: var(--section-pad-v) var(--section-pad-h);
}

.section--dark  { background: var(--black2); }
.section--darker { background: var(--black3); }

/* ─── KONTAJNER ──────────────────────────────────────────────────────────── */
.container {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 var(--section-pad-h);
}

/* ─── SECTION HEADER ─────────────────────────────────────────────────────── */
.sec-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold3);
  margin-bottom: 0.8rem;
}

.sec-eyebrow::before {
  content: '';
  display: block;
  width: 20px;
  height: 0.5px;
  background: var(--gold);
  flex-shrink: 0;
}

.sec-title {
  font-family: var(--font-serif);
  font-weight: 300;
  color: var(--offwhite);
}

/* ─── TLAČIDLÁ ───────────────────────────────────────────────────────────── */
.btn {
  display: inline-block;
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 1rem 2.2rem;
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  text-align: center;
  white-space: nowrap;
  line-height: 1;
}

.btn--gold {
  background: var(--gold);
  color: var(--black);
}
.btn--gold:hover { background: var(--gold2); }

.btn--ghost {
  background: transparent;
  color: var(--offwhite);
  border: 0.5px solid var(--linew);
}
.btn--ghost:hover { border-color: var(--dim); }

.btn--outline-gold {
  background: transparent;
  color: var(--gold);
  border: 0.5px solid var(--gold);
}
.btn--outline-gold:hover { background: var(--gold); color: var(--black); }

/* ─── BADGE ──────────────────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  font-size: 0.70rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 0.25rem 0.65rem;
  border: 0.5px solid rgba(61, 107, 255, 0.4);
  color: var(--gold2);
  background: rgba(10, 11, 13, 0.6);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.badge--predaj       { color: var(--gold2); border-color: rgba(61,107,255,0.4); }
.badge--prenajom     { color: var(--gold2); border-color: rgba(61,107,255,0.4); }
.badge--offmarket    { color: var(--gold2); border-color: rgba(61,107,255,0.4); }
.badge--rezervovane  { color: var(--gold2); border-color: rgba(61,107,255,0.4); }
.badge--zrealizovane { color: var(--gold2); border-color: rgba(61,107,255,0.4); }
.badge--new      { color: #A8C4A0; border-color: rgba(168,196,160,0.3); }

/* ─── ORÁMOVANIE (linka) ─────────────────────────────────────────────────── */
.border-top    { border-top:    0.5px solid var(--linew); }
.border-bottom { border-bottom: 0.5px solid var(--linew); }
.border-gold   { border:        0.5px solid var(--line); }

/* ─── ICON ───────────────────────────────────────────────────────────────── */
.icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: middle;
  stroke: currentColor;
  fill: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SVETLÁ TÉMA — .theme-light na <body>
   Prepíše CSS premenné, zvyšok dizajnu sa prispôsobí automaticky cez var().
   ═══════════════════════════════════════════════════════════════════════════ */
body.theme-light {
  /* Pozadie — čistá biela paleta (spots rebrand) */
  --black:    #FFFFFF;
  --black2:   #F5F7FA;
  --black3:   #EBEEF4;
  --black4:   #DCE1EA;

  /* Text — tmavý na svetlom pozadí, WCAG AA */
  --offwhite: #14161A;
  --dim:      #383D47;
  --dimmer:   #686E7B;

  /* Linky */
  --linew:    rgba(20, 25, 40, 0.1);
  --line:     rgba(8, 62, 220, 0.3);

  /* Modrá — na svetlom pozadí plná brand modrá #083EDC */
  --gold:     #083EDC;
  --gold2:    #2456E8;
  --gold3:    #7E9BF0;
  --gold4:    #C2D0F8;
}

/* Nav — solid stav */
body.theme-light .site-nav.nav--solid {
  background: rgba(255, 255, 255, 0.96);
}

/* Nav — mobile menu */
body.theme-light .site-nav__mobile {
  background: rgba(245, 247, 250, 0.98);
}

/* Badge pozadie */
body.theme-light .badge {
  background: rgba(255, 255, 255, 0.85);
}

/* Karta — overlay gradient */
body.theme-light .property-card__overlay {
  background: linear-gradient(
    to top,
    rgba(245, 247, 250, 0.7) 0%,
    rgba(245, 247, 250, 0.2) 60%,
    transparent 100%
  );
}

/* Karta — text farby na svetlom overlay */
body.theme-light .property-card__price,
body.theme-light .property-card__title a,
body.theme-light .property-card__location {
  color: var(--offwhite);
}

/* Formulár inputy */
body.theme-light input,
body.theme-light textarea,
body.theme-light select {
  background: var(--black2);
  color: var(--offwhite);
  border-color: var(--linew);
}

body.theme-light input::placeholder,
body.theme-light textarea::placeholder {
  color: var(--dimmer);
}

/* Filter bar */
body.theme-light .filter-bar {
  background: var(--black2);
  border-color: var(--linew);
}

/* Property sidebar */
body.theme-light .property-sidebar__price-box,
body.theme-light .property-sidebar__params,
body.theme-light .property-sidebar__contact {
  background: var(--black2);
  border-color: var(--linew);
}

/* Hero + CTA — zostávajú tmavé (text na fotke potrebuje kontrast) */
body.theme-light .hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(10, 11, 13, 0.2) 0%,
    rgba(10, 11, 13, 0.4) 60%,
    rgba(10, 11, 13, 0.65) 100%
  );
}
body.theme-light .cta-section__bg {
  background-color: var(--black3);
  background-image: linear-gradient(135deg, #2a2520 0%, #1c1a17 50%, #141210 100%);
}
body.theme-light .cta-section__overlay {
  background: rgba(10, 11, 13, 0.72);
}

/* ─── SKRYTÉ PRE SCREEN READERS ──────────────────────────────────────────── */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ─── FOCUS ŠTÝLY (prístupnosť) ──────────────────────────────────────────── */
:focus-visible {
  outline: 1.5px solid var(--gold);
  outline-offset: 3px;
}

/* ─── MOBILNÉ ZÁKLADY ────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .section {
    padding: var(--section-pad-v-mobile) var(--section-pad-h-mobile);
  }
}

/* ─── DESKTOP: väčšie písmo pre lepšiu čitateľnosť ──────────────────────── */
/* Mobile ostáva na 19px — clamp() nadpisy by pri väčšom base pretiekli.    */
@media (min-width: 769px) {
  html { font-size: 22px; } /* 19px × 1.158 = +15.8%; body ~21px, nav sa zmestí */

  /* Nav: zabrání zalomeniu na Mac/Safari — gap stiahnuť, nowrap ako poistka */
  .site-nav__menu { gap: 1.8rem; }
  .site-nav__menu li a { white-space: nowrap; }
}
