/* Knijanka Design System - Based on Figma Analysis */
/* Font Imports - Matching Design System */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap");
/* Import special display font for hero title */
@import url("https://fonts.googleapis.com/css2?family=Amatic+SC:wght@700&display=swap");
.site-brand-title {
  font-size: clamp(4.75rem, 14vw, 9rem);
  margin: 0;
  font-family: "Amatic SC", "AmaticSC", cursive;
  font-weight: 700;
  letter-spacing: 0.2px;
  line-height: 1.02;
  color: #b45036;
  -webkit-text-stroke: 0.6px rgba(0, 0, 0, 0.06);
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.02), 0 2px 0 rgba(0, 0, 0, 0.02);
}

.site-header__image {
  max-width: 100%;
}

.site-category-nav {
  margin-inline: auto;
  max-width: 100%;
}

/* CSS Custom Properties (Design Tokens) */
:root {
  /* Colors inspired by hero image - warm, inviting palette */
  /* Primary: Deep burgundy/maroon from hero */
  --color-primary: #3c1428;
  --color-primary-foreground: #ffffff;
  --color-primary-hover: #5a2040;
  /* Secondary: Warm coral/salmon accent */
  --color-secondary: #f5735f;
  --color-secondary-foreground: #2d1810;
  --color-secondary-hover: #e4a482;
  /* Tertiary: Soft blue accent */
  --color-tertiary: #a0c8dc;
  --color-tertiary-foreground: #1a3c4c;
  /* Background colors - soft, warm neutrals */
  --color-background: #faf8f5;
  --color-foreground: #2d2624;
  --color-card: #ffffff;
  --color-card-foreground: #2d2624;
  /* Muted colors - warm beige tones */
  --color-muted: #f0dcc8;
  --color-muted-foreground: #6b5e54;
  /* Accent colors - light blue wash */
  --color-accent: #dcf0f0;
  --color-accent-foreground: #2d3438;
  /* Border and input colors */
  --color-border: #dcd4cc;
  --color-input: transparent;
  --color-input-background: #ffffff;
  --color-ring: #3c1428;
  /* Status colors */
  --color-destructive: #c84838;
  --color-destructive-foreground: #ffffff;
  /* Typography - Enhanced font stack matching design */
  --font-family-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;
  --font-family-display: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', sans-serif;
  /* Font sizes - Modular scale */
  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-base: 1rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.25rem;
  --font-size-2xl: 1.5rem;
  --font-size-3xl: 1.875rem;
  --font-size-4xl: 2.25rem;
  --font-size-5xl: 3rem;
  --font-size-6xl: 3.75rem;
  /* Font weights */
  --font-weight-light: 300;
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  /* Line heights */
  --line-height-tight: 1.25;
  --line-height-snug: 1.375;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;
  /* Spacing - Enhanced scale for better visual hierarchy */
  --spacing-unit: 0.25rem; /* 4px base */
  --spacing-0\.5: calc(var(--spacing-unit) * 0.5); /* 2px */
  --spacing-1: calc(var(--spacing-unit) * 1); /* 4px */
  --spacing-1\.5: calc(var(--spacing-unit) * 1.5); /* 6px */
  --spacing-2: calc(var(--spacing-unit) * 2); /* 8px */
  --spacing-3: calc(var(--spacing-unit) * 3); /* 12px */
  --spacing-4: calc(var(--spacing-unit) * 4); /* 16px */
  --spacing-5: calc(var(--spacing-unit) * 5); /* 20px */
  --spacing-6: calc(var(--spacing-unit) * 6); /* 24px */
  --spacing-8: calc(var(--spacing-unit) * 8); /* 32px */
  --spacing-10: calc(var(--spacing-unit) * 10); /* 40px */
  --spacing-12: calc(var(--spacing-unit) * 12); /* 48px */
  --spacing-16: calc(var(--spacing-unit) * 16); /* 64px */
  --spacing-20: calc(var(--spacing-unit) * 20); /* 80px */
  --spacing-24: calc(var(--spacing-unit) * 24); /* 96px */
  --spacing-32: calc(var(--spacing-unit) * 32); /* 128px */
  /* Border radius */
  --radius-sm: 0.375rem;
  --radius: 0.5rem;
  --radius-md: 0.75rem;
  --radius-lg: 1rem;
  --radius-xl: 1.5rem;
  --radius-2xl: 2rem;
  /* Container max-widths */
  --container-sm: 40rem;
  --container-md: 48rem;
  --container-lg: 64rem;
  --container-xl: 80rem;
  --container-2xl: 96rem;
}

/* Dark theme */
.dark {
  --color-background: #1f1614;
  --color-foreground: #f5f0eb;
  --color-card: #332824;
  --color-card-foreground: #f5f0eb;
  --color-muted: #4a3c34;
  --color-muted-foreground: #c8b8a8;
  --color-accent: #506464;
  --color-accent-foreground: #dcf0f0;
  --color-border: #4a3c34;
  --color-input: #4a3c34;
  --color-primary: #643c50;
  --color-primary-foreground: #f5f0eb;
  --color-primary-hover: #7a4860;
  --color-secondary: #ff0000;
  --color-secondary-foreground: #1f1614;
  --color-secondary-hover: #e4a482;
  --color-tertiary: #788ca0;
  --color-tertiary-foreground: #dcf0f0;
}

/* Base styles */
* {
  box-sizing: border-box;
}

html {
  font-size: var(--font-size-base);
  font-family: var(--font-family-sans);
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  margin: 0;
  padding: 0;
  line-height: 1.6;
  font-weight: var(--font-weight-normal);
  background-color: var(--color-background);
  color: var(--color-foreground);
  font-feature-settings: "rlig" 1, "calt" 1, "ss01" 1;
  letter-spacing: -0.011em;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Container */
.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--spacing-6);
  padding-right: var(--spacing-6);
}

@media (min-width: 40rem) {
  .container {
    padding-left: var(--spacing-8);
    padding-right: var(--spacing-8);
  }
}
@media (min-width: 40rem) {
  .container {
    max-width: var(--container-sm);
  }
}
@media (min-width: 48rem) {
  .container {
    max-width: var(--container-md);
  }
}
@media (min-width: 64rem) {
  .container {
    max-width: var(--container-lg);
  }
}
@media (min-width: 80rem) {
  .container {
    max-width: var(--container-xl);
  }
}
@media (min-width: 96rem) {
  .container {
    max-width: var(--container-2xl);
  }
}
/* Utility Classes */
/* Display */
.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.inline {
  display: inline;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.grid {
  display: grid;
}

.hidden {
  display: none;
}

/* Flex utilities */
.flex-col {
  flex-direction: column;
}

.flex-row {
  flex-direction: row;
}

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

.flex-shrink-0 {
  flex-shrink: 0;
}

.items-center {
  align-items: center;
}

.items-start {
  align-items: flex-start;
}

.items-end {
  align-items: flex-end;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

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

.flex-1 {
  flex: 1;
}

.grow {
  flex-grow: 1;
}

.shrink-0 {
  flex-shrink: 0;
}

/* Responsive flex utilities */
@media (min-width: 40rem) {
  .sm\:flex-row {
    flex-direction: row !important;
  }
  .sm\:flex-col {
    flex-direction: column !important;
  }
}
@media (min-width: 48rem) {
  .md\:flex-row {
    flex-direction: row !important;
  }
  .md\:flex-col {
    flex-direction: column !important;
  }
  .md\:justify-between {
    justify-content: space-between !important;
  }
  .md\:max-w-sm {
    max-width: 24rem !important;
  }
  .md\:gap-12 {
    gap: var(--spacing-12) !important;
  }
}
/* Grid utilities */
.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (min-width: 48rem) {
  .md-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .md-grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .md-grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (min-width: 64rem) {
  .lg-grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .lg-grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .lg-col-span-1 {
    grid-column: span 1/span 1;
  }
  .lg-col-span-2 {
    grid-column: span 2/span 2;
  }
}
/* Gap utilities */
.gap-0\.5 {
  gap: var(--spacing-0\.5);
}

.gap-1 {
  gap: var(--spacing-1);
}

.gap-1\.5 {
  gap: var(--spacing-1\.5);
}

.gap-2 {
  gap: var(--spacing-2);
}

.gap-3 {
  gap: var(--spacing-3);
}

.gap-4 {
  gap: var(--spacing-4);
}

.gap-5 {
  gap: var(--spacing-5);
}

.gap-6 {
  gap: var(--spacing-6);
}

.gap-8 {
  gap: var(--spacing-8);
}

.gap-10 {
  gap: var(--spacing-10);
}

.gap-12 {
  gap: var(--spacing-12);
}

.gap-16 {
  gap: var(--spacing-16);
}

.gap-20 {
  gap: var(--spacing-20);
}

/* Spacing utilities */
/* Margins */
.m-0 {
  margin: 0;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.mt-2 {
  margin-top: var(--spacing-2);
}

.mt-4 {
  margin-top: var(--spacing-4);
}

.mt-6 {
  margin-top: var(--spacing-6);
}

.mt-8 {
  margin-top: var(--spacing-8);
}

.mt-12 {
  margin-top: var(--spacing-12);
}

.mt-16 {
  margin-top: var(--spacing-16);
}

.mt-20 {
  margin-top: var(--spacing-20);
}

.mt-24 {
  margin-top: var(--spacing-24);
}

.mb-1 {
  margin-bottom: var(--spacing-1);
}

.mb-2 {
  margin-bottom: var(--spacing-2);
}

.mb-3 {
  margin-bottom: var(--spacing-3);
}

.mb-4 {
  margin-bottom: var(--spacing-4);
}

.mb-6 {
  margin-bottom: var(--spacing-6);
}

.mb-8 {
  margin-bottom: var(--spacing-8);
}

.mb-12 {
  margin-bottom: var(--spacing-12);
}

.mb-16 {
  margin-bottom: var(--spacing-16);
}

.mb-20 {
  margin-bottom: var(--spacing-20);
}

.my-8 {
  margin-top: var(--spacing-8);
  margin-bottom: var(--spacing-8);
}

.my-12 {
  margin-top: var(--spacing-12);
  margin-bottom: var(--spacing-12);
}

.my-16 {
  margin-top: var(--spacing-16);
  margin-bottom: var(--spacing-16);
}

/* Padding */
.p-0 {
  padding: 0;
}

.p-2 {
  padding: var(--spacing-2);
}

.p-3 {
  padding: var(--spacing-3);
}

.p-4 {
  padding: var(--spacing-4);
}

.p-6 {
  padding: var(--spacing-6);
}

.p-8 {
  padding: var(--spacing-8);
}

.px-2 {
  padding-left: var(--spacing-2);
  padding-right: var(--spacing-2);
}

.px-3 {
  padding-left: var(--spacing-3);
  padding-right: var(--spacing-3);
}

.px-4 {
  padding-left: var(--spacing-4);
  padding-right: var(--spacing-4);
}

.px-6 {
  padding-left: var(--spacing-6);
  padding-right: var(--spacing-6);
}

.px-8 {
  padding-left: var(--spacing-8);
  padding-right: var(--spacing-8);
}

.py-1 {
  padding-top: var(--spacing-1);
  padding-bottom: var(--spacing-1);
}

.py-2 {
  padding-top: var(--spacing-2);
  padding-bottom: var(--spacing-2);
}

.py-3 {
  padding-top: var(--spacing-3);
  padding-bottom: var(--spacing-3);
}

.py-4 {
  padding-top: var(--spacing-4);
  padding-bottom: var(--spacing-4);
}

.py-6 {
  padding-top: var(--spacing-6);
  padding-bottom: var(--spacing-6);
}

.py-8 {
  padding-top: var(--spacing-8);
  padding-bottom: var(--spacing-8);
}

.py-12 {
  padding-top: var(--spacing-12);
  padding-bottom: var(--spacing-12);
}

.py-16 {
  padding-top: var(--spacing-16);
  padding-bottom: var(--spacing-16);
}

.py-20 {
  padding-top: var(--spacing-20);
  padding-bottom: var(--spacing-20);
}

.py-24 {
  padding-top: var(--spacing-24);
  padding-bottom: var(--spacing-24);
}

.pt-8 {
  padding-top: var(--spacing-8);
}

.pt-12 {
  padding-top: var(--spacing-12);
}

.pt-16 {
  padding-top: var(--spacing-16);
}

.pb-8 {
  padding-bottom: var(--spacing-8);
}

.pb-12 {
  padding-bottom: var(--spacing-12);
}

.pb-16 {
  padding-bottom: var(--spacing-16);
}

.pl-10 {
  padding-left: var(--spacing-10);
}

.pl-12 {
  padding-left: var(--spacing-12);
}

.pr-4 {
  padding-right: var(--spacing-4);
}

@media (min-width: 48rem) {
  .md-py-24 {
    padding-top: var(--spacing-24);
    padding-bottom: var(--spacing-24);
  }
  .md-py-32 {
    padding-top: var(--spacing-32);
    padding-bottom: var(--spacing-32);
  }
  .md-px-12 {
    padding-left: var(--spacing-12);
    padding-right: var(--spacing-12);
  }
  .md-gap-10 {
    gap: var(--spacing-10) !important;
  }
  .md-gap-12 {
    gap: var(--spacing-12) !important;
  }
  .md-gap-16 {
    gap: var(--spacing-16) !important;
  }
}
/* Width and height */
.w-full {
  width: 100%;
}

.w-64 {
  width: 16rem;
}

.w-auto {
  width: auto;
}

.h-4 {
  height: 1rem;
}

.w-4 {
  width: 1rem;
}

.h-5 {
  height: 1.25rem;
}

.w-5 {
  width: 1.25rem;
}

.h-8 {
  height: 2rem;
}

.h-12 {
  height: 3rem;
}

.h-16 {
  height: 4rem;
}

.h-10 {
  height: 2.5rem;
}

.h-20 {
  height: 5rem;
}

.h-24 {
  height: 6rem;
}

.h-28 {
  height: 7rem;
}

.w-12 {
  width: 3rem;
}

.size-9 {
  width: 2.25rem;
  height: 2.25rem;
}

.min-h-screen {
  min-height: 100vh;
}

/* Logo specific styles */
.logo-img {
  max-height: 2.5rem; /* 40px */
  width: auto;
  transition: transform 150ms ease-in-out;
}

.logo-img:hover {
  transform: scale(1.05);
}

.logo-img-large {
  max-height: 3.5rem; /* 56px */
  width: auto;
  transition: transform 150ms ease-in-out;
}

.logo-img-large:hover {
  transform: scale(1.05);
}

/* Search icon specific styles */
.search-icon {
  width: 1.25rem !important;
  height: 1.25rem !important;
  flex-shrink: 0;
  transform: translateY(-50%) !important;
  top: 50% !important;
}

/* Position */
.relative {
  position: relative;
}

.absolute {
  position: absolute;
}

.sticky {
  position: sticky;
}

.top-0 {
  top: 0;
}

.top-24 {
  top: var(--spacing-24);
}

.left-3 {
  left: var(--spacing-3);
}

.z-50 {
  z-index: 50;
}

/* Typography */
/* Headings - Using display font for better visual hierarchy */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-family-display);
  font-weight: var(--font-weight-semibold);
  line-height: 1.2;
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--color-foreground);
}

h1 {
  font-size: 2.25rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.035em;
}

h2 {
  font-size: 1.875rem;
  font-weight: var(--font-weight-semibold);
}

h3 {
  font-size: 1.5rem;
}

h4 {
  font-size: 1.25rem;
}

h5, h6 {
  font-size: 1.125rem;
}

/* Text size utilities */
.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}

.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}

.text-3xl {
  font-size: 1.875rem;
  line-height: 2.25rem;
}

.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}

@media (min-width: 48rem) {
  .md-text-5xl {
    font-size: 3rem;
    line-height: 1;
  }
  h1 {
    font-size: 2.5rem;
  }
  h2 {
    font-size: 2rem;
  }
}
@media (min-width: 64rem) {
  .lg-text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }
  h1 {
    font-size: 3rem;
  }
  h2 {
    font-size: 2.25rem;
  }
}
/* Font weight utilities */
.font-light {
  font-weight: var(--font-weight-light);
}

.font-normal {
  font-weight: var(--font-weight-normal);
}

.font-medium {
  font-weight: var(--font-weight-medium);
}

.font-semibold {
  font-weight: var(--font-weight-semibold);
}

.font-bold {
  font-weight: var(--font-weight-bold);
}

/* Text alignment */
.text-center {
  text-align: center;
}

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

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

/* Letter spacing for refined typography */
.tracking-tight {
  letter-spacing: -0.025em;
}

.tracking-normal {
  letter-spacing: 0em;
}

.tracking-wide {
  letter-spacing: 0.025em;
}

/* Prose styling for better readability */
p {
  margin: 0 0 1rem 0;
  line-height: var(--line-height-relaxed);
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color 150ms ease-in-out;
}

a:hover {
  color: color-mix(in srgb, var(--color-primary) 80%, black);
  text-decoration: underline;
}

/* Enhanced readability for Bulgarian text */
.bulgarian-text {
  font-feature-settings: "kern" 1, "liga" 1, "calt" 1, "pnum" 1, "tnum" 0, "onum" 1, "lnum" 0, "dlig" 0;
}

/* Review content styling */
.review-content {
  line-height: var(--line-height-relaxed);
  font-size: var(--font-size-lg);
}
.review-content h2, .review-content h3 {
  margin-top: var(--spacing-16);
  margin-bottom: var(--spacing-6);
}
.review-content h2:first-child, .review-content h3:first-child {
  margin-top: 0;
}
.review-content h2 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-semibold);
  color: var(--color-foreground);
  padding-bottom: var(--spacing-2);
  border-bottom: 2px solid var(--color-border);
}
.review-content h3 {
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-medium);
}
.review-content h4 {
  margin-top: var(--spacing-8);
  margin-bottom: var(--spacing-4);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-medium);
}
.review-content p {
  margin-bottom: var(--spacing-6);
  text-align: left;
  line-height: var(--line-height-relaxed);
}
.review-content ul, .review-content ol {
  margin: var(--spacing-6) 0;
  padding-left: var(--spacing-8);
}
.review-content ul li, .review-content ol li {
  margin-bottom: var(--spacing-3);
  line-height: var(--line-height-relaxed);
}
.review-content img {
  margin: var(--spacing-12) 0;
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 6px -1px rgba(250, 248, 245, 0.6), 0 2px 4px -1px rgba(250, 248, 245, 0.4);
}
.review-content blockquote {
  margin: var(--spacing-8) 0;
  padding: var(--spacing-6);
  border-left: 4px solid var(--color-primary);
  background-color: var(--color-muted);
  border-radius: var(--radius);
  font-style: italic;
}
.review-content strong {
  font-weight: var(--font-weight-semibold);
  color: var(--color-foreground);
}
.review-content em {
  font-style: italic;
  color: var(--color-muted-foreground);
}

.review-sidebar {
  padding: var(--spacing-6);
}

.review-sidebar__cover {
  margin-bottom: var(--spacing-5);
  display: flex;
  justify-content: center;
  padding: var(--spacing-4);
  background-color: rgba(60, 20, 40, 0.04);
}

.review-sidebar__cover-image {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: 22rem;
  height: auto;
  object-fit: contain;
  border-radius: var(--radius);
  box-shadow: 0 8px 20px rgba(60, 20, 40, 0.14);
}

.review-gallery__grid {
  display: grid;
  gap: var(--spacing-6);
}

.review-gallery__item {
  margin: 0;
}

.review-gallery__image {
  display: block;
  width: 100%;
  height: auto;
  margin: 0;
}

@media (min-width: 48rem) {
  .review-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.review-sidebar__body {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5);
}

.review-sidebar__author-link,
.review-sidebar__meta-link,
.review-sidebar__value {
  font-weight: var(--font-weight-semibold);
  color: var(--color-foreground);
}

.review-sidebar__author-link:hover,
.review-sidebar__meta-link:hover {
  color: var(--color-primary);
}

.review-sidebar__details {
  margin: 0;
  padding: 0;
}

.review-sidebar__detail {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
  padding: var(--spacing-3) 0;
  border-bottom: 1px solid rgba(60, 20, 40, 0.08);
}

.review-sidebar__label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-muted-foreground);
}

.review-sidebar__label--section {
  display: block;
  margin-bottom: var(--spacing-2);
}

.review-sidebar__detail-value {
  margin: 0;
}

.review-sidebar__actions {
  padding-top: var(--spacing-4);
  border-top: 1px solid var(--color-border);
}

.news-sidebar {
  padding: var(--spacing-6);
}

.news-sidebar__cover {
  margin-bottom: var(--spacing-5);
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(60, 20, 40, 0.08), rgba(245, 115, 95, 0.18));
}

.news-sidebar__cover-image {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

.news-sidebar__cover-placeholder {
  min-height: 14rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
}

.news-sidebar__source {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  padding-top: var(--spacing-5);
  border-top: 1px solid rgba(60, 20, 40, 0.08);
}

.news-sidebar__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-2);
  padding-top: var(--spacing-5);
  border-top: 1px solid rgba(60, 20, 40, 0.08);
}

/* Colors */
.bg-background {
  background-color: var(--color-background);
}

.bg-card {
  background-color: var(--color-card);
}

.bg-primary {
  background-color: var(--color-primary);
}

.bg-secondary {
  background-color: var(--color-secondary);
}

.bg-accent {
  background-color: var(--color-accent);
}

.bg-muted {
  background-color: var(--color-background);
}

.bg-input-background {
  background-color: var(--color-input-background);
}

.text-foreground {
  color: var(--color-foreground);
}

.text-card-foreground {
  color: var(--color-card-foreground);
}

.text-primary {
  color: var(--color-primary);
}

.text-primary-foreground {
  color: var(--color-primary-foreground);
}

.text-secondary-foreground {
  color: var(--color-secondary-foreground);
}

.text-accent-foreground {
  color: var(--color-accent-foreground);
}

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

/* Borders */
.border {
  border: 1px solid var(--color-border);
}

.border-b {
  border-bottom: 1px solid var(--color-border);
}

.border-t {
  border-top: 1px solid var(--color-border);
}

.border-input {
  border-color: var(--color-input);
}

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

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

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

.rounded-2xl {
  border-radius: var(--radius-2xl);
}

/* Shadows */
.shadow-lg {
  box-shadow: 0 10px 15px -3px rgba(250, 248, 245, 0.6), 0 4px 6px -4px rgba(250, 248, 245, 0.4);
}

.shadow-2xl {
  box-shadow: 0 25px 50px -12px rgba(250, 248, 245, 0.8);
}

/* Effects */
.backdrop-blur {
  backdrop-filter: blur(8px);
}

.transition-colors {
  transition-property: color, background-color, border-color;
  transition-duration: 150ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.transition-transform {
  transition-property: transform;
  transition-duration: 150ms;
}

.transition-all {
  transition-property: all;
  transition-duration: 150ms;
}

.duration-200 {
  transition-duration: 200ms;
}

.duration-300 {
  transition-duration: 300ms;
}

.duration-500 {
  transition-duration: 500ms;
}

/* Hover states */
.hover-bg-accent-50:hover {
  background-color: rgba(219, 234, 254, 0.5);
}

.hover-bg-accent:hover {
  background-color: var(--color-accent);
}

.hover-text-foreground:hover {
  color: var(--color-foreground);
}

.hover-text-primary:hover {
  color: var(--color-primary);
}

.hover-scale-105:hover {
  transform: scale(1.05);
}

.hover-shadow-lg:hover {
  box-shadow: 0 10px 15px -3px rgba(250, 248, 245, 0.6), 0 4px 6px -4px rgba(250, 248, 245, 0.4);
}

/* Group hover */
.group:hover .group-hover-scale-105 {
  transform: scale(1.05);
}

.group:hover .group-hover-text-primary {
  color: var(--color-primary);
}

/* Focus states */
.focus\\:outline-none:focus {
  outline: none;
}

.focus\\:ring-2:focus {
  box-shadow: 0 0 0 2px var(--color-ring);
}

.focus\\:ring-ring:focus {
  --tw-ring-color: var(--color-ring);
}

/* Responsive utilities */
@media (min-width: 48rem) {
  .md\:flex, .md-flex {
    display: flex !important;
  }
  .md\:hidden, .md-hidden {
    display: none !important;
  }
  .md\:block, .md-block {
    display: block !important;
  }
}
@media (min-width: 64rem) {
  .lg\:flex, .lg-flex {
    display: flex !important;
  }
  .lg\:hidden, .lg-hidden {
    display: none !important;
  }
}
/* Additional navigation specific styles */
@media (min-width: 48rem) {
  .desktop-nav {
    display: flex !important;
  }
}
@media (max-width: 47.9rem) {
  .desktop-nav {
    display: none !important;
  }
}
/* Additional utilities needed for footer and spacing */
.min-w-0 {
  min-width: 0;
}

.max-w-sm {
  max-width: 24rem;
}

.max-w-none {
  max-width: none;
}

/* Space-y utilities for vertical spacing */
.space-y-1 > * + * {
  margin-top: var(--spacing-1);
}

.space-y-2 > * + * {
  margin-top: var(--spacing-2);
}

.space-y-3 > * + * {
  margin-top: var(--spacing-3);
}

.space-y-4 > * + * {
  margin-top: var(--spacing-4);
}

.space-y-5 > * + * {
  margin-top: var(--spacing-5);
}

.space-y-6 > * + * {
  margin-top: var(--spacing-6);
}

.space-y-8 > * + * {
  margin-top: var(--spacing-8);
}

.space-y-10 > * + * {
  margin-top: var(--spacing-10);
}

.space-y-12 > * + * {
  margin-top: var(--spacing-12);
}

/* Gradient backgrounds */
.bg-gradient-to-br {
  background: linear-gradient(135deg, rgba(60, 20, 40, 0.03) 0%, var(--color-background) 50%, rgba(220, 140, 100, 0.06) 100%);
}

/* Knijanka background experiment */
.knijanka-bg {
  background-image: url("/assets/images/static/knijanka-hero.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  position: relative;
}

.knijanka-bg::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgb(250, 248, 245); /* Opaque overlay using --color-background */
  z-index: -1;
}

.dark .knijanka-bg::before {
  background: rgb(31, 22, 20); /* Dark theme overlay matching new scheme */
}

/* Custom component classes */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-3) var(--spacing-6);
  border-radius: var(--radius-lg);
  font-weight: var(--font-weight-medium);
  text-decoration: none;
  transition: all 150ms ease-in-out;
  border: none;
  cursor: pointer;
  font-size: 1rem;
  font-family: inherit;
  line-height: 1.5;
}

.btn-primary {
  background-color: #e5f0f3;
  color: #1a3c4c;
}

.btn-primary:hover {
  background-color: #cfe3e8;
}

.btn-secondary {
  background-color: transparent;
  color: var(--color-foreground);
  border: 1px solid var(--color-border);
}

.btn-secondary:hover {
  background-color: var(--color-accent);
}

.btn-nav {
  background-color: rgba(240, 220, 200, 0.28);
  color: var(--color-foreground);
  border: 1px solid color-mix(in srgb, var(--color-border) 55%, var(--color-primary) 45%);
}

.btn-nav:hover {
  background-color: rgba(240, 220, 200, 0.46);
  border-color: color-mix(in srgb, var(--color-border) 42%, var(--color-primary) 58%);
  text-decoration: none;
}

.btn-nav.is-active {
  background-color: rgba(240, 220, 200, 0.78);
  color: #b45036;
  border-color: color-mix(in srgb, var(--color-border) 24%, var(--color-primary) 76%);
  text-decoration: none;
}

.card {
  background-color: var(--color-card);
  color: var(--color-card-foreground);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--spacing-8);
  box-shadow: 0 1px 3px 0 rgba(250, 248, 245, 0.6), 0 1px 2px 0 rgba(250, 248, 245, 0.4);
}

.review-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.review-card > .aspect-ratio-16-9 {
  aspect-ratio: auto;
  flex-shrink: 0;
}
.review-card > .aspect-ratio-16-9 > img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.review-card__body {
  flex: 1 1 0%;
  min-height: 0;
  overflow: hidden;
}

.review-card__footer {
  flex-shrink: 0;
  margin-top: var(--spacing-4);
}

@media (min-width: 40rem) {
  .card {
    padding: var(--spacing-10);
  }
}
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--spacing-1) var(--spacing-3);
  font-size: 0.75rem;
  font-weight: var(--font-weight-medium);
  border-radius: var(--radius);
  background-color: #f4a675;
  color: var(--color-secondary-foreground);
}

.badge-collection {
  padding: var(--spacing-2) var(--spacing-4);
  font-size: 0.875rem;
  border-radius: var(--radius-lg);
  background-color: rgba(240, 220, 200, 0.28);
  color: var(--color-foreground);
  border: 1px solid color-mix(in srgb, var(--color-border) 55%, var(--color-primary) 45%);
}

.aspect-ratio-4-3 {
  aspect-ratio: 4/3;
}

.aspect-ratio-16-9 {
  aspect-ratio: 16/9;
}

/* Responsive visibility */
@media (max-width: 47.9rem) {
  .hidden-mobile {
    display: none !important;
  }
}
@media (min-width: 48rem) {
  .hidden-desktop {
    display: none !important;
  }
}
.article-layout {
  max-width: 64rem;
}

.about-content {
  max-width: none;
  overflow: hidden;
}

.content-figure {
  float: left;
  width: min(18rem, 34%);
  margin: 0 var(--spacing-6) var(--spacing-2) 0;
}

.content-figure--right {
  float: right;
  width: min(18rem, 34%);
  margin: 0 0 var(--spacing-2) var(--spacing-6);
}

.content-figure--wide {
  float: none;
  clear: both;
  width: 100%;
  margin: var(--spacing-2) 0;
}

.content-figure img,
.content-figure--right img,
.content-figure--wide img {
  display: block;
  margin: 0;
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
}

.about-content h2 {
  margin-top: var(--spacing-10);
  padding-top: var(--spacing-8);
  border-top: 1px solid var(--color-border);
  margin-bottom: var(--spacing-4);
  font-size: clamp(1.5rem, 3vw, 2.15rem);
  color: var(--color-primary);
}

.about-content h3 {
  margin-top: var(--spacing-6);
  margin-bottom: var(--spacing-3);
  color: var(--color-primary);
}

.about-content p {
  margin: 0 0 var(--spacing-4);
  font-size: var(--font-size-lg);
  line-height: var(--line-height-relaxed);
}

.about-content p:last-child {
  margin-bottom: 0;
}

.about-content > :first-child {
  margin-top: 0;
}

.links-content {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-10);
}

.links-content > p:first-child {
  margin-bottom: 0;
  padding: var(--spacing-6) var(--spacing-8);
  border: 1px solid rgba(60, 20, 40, 0.1);
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, rgba(240, 220, 200, 0.55), rgba(220, 240, 240, 0.45));
}

.links-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
}

.links-section h2 {
  margin: 0;
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  color: var(--color-primary);
}

.links-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--spacing-4);
}

.links-list li {
  display: grid;
  grid-template-columns: 4.5rem minmax(0, 1fr);
  align-items: center;
  gap: var(--spacing-4);
  padding: var(--spacing-5) var(--spacing-6);
  border: 1px solid rgba(60, 20, 40, 0.1);
  border-radius: var(--radius-lg);
  background-color: rgba(255, 255, 255, 0.82);
  box-shadow: 0 1px 2px rgba(60, 20, 40, 0.04);
}

.links-item__media {
  width: 4.5rem;
  height: 4.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-2);
  border-radius: var(--radius);
  overflow: hidden;
  background: linear-gradient(135deg, rgba(240, 220, 200, 0.45), rgba(220, 240, 240, 0.45));
  border: 1px solid rgba(60, 20, 40, 0.08);
}

.links-item__logo {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.links-item__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
}

.links-list a,
.links-label {
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
}

.links-note {
  font-size: var(--font-size-sm);
  color: var(--color-muted-foreground);
}

@media (min-width: 48rem) {
  .links-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 47.9rem) {
  .about-content h2 {
    padding-top: var(--spacing-6);
  }
  .about-content p {
    font-size: var(--font-size-base);
  }
  .content-figure {
    float: none;
    width: min(16rem, 100%);
    margin: 0 auto var(--spacing-3);
  }
  .content-figure--right {
    float: none;
    width: min(16rem, 100%);
    margin: 0 auto var(--spacing-3);
  }
  .content-figure--wide {
    margin: var(--spacing-2) 0;
  }
  .links-content {
    gap: var(--spacing-8);
  }
  .links-content > p:first-child,
  .links-list li {
    padding: var(--spacing-4) var(--spacing-5);
  }
  .links-list li {
    grid-template-columns: 3.75rem minmax(0, 1fr);
    gap: var(--spacing-3);
  }
  .links-item__media {
    width: 3.75rem;
    height: 3.75rem;
  }
}
/* Landing page hero styles */
.landing-page, .hero {
  height: 100%;
  margin: 0;
}

.hero {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
}

.hero__picture {
  position: relative;
  display: block;
  width: 100%;
  height: 100vh;
}

.hero__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Position content in the lower-left quarter */
.hero__content {
  position: absolute;
  right: 4%;
  bottom: 8%;
  z-index: 2;
  text-align: center;
  color: var(--color-foreground);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1.5rem;
  width: clamp(40%, 45vw, 520px);
  max-width: 60%;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 0.85);
  border-radius: 12px;
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  min-height: 220px;
}

.hero__title {
  font-size: clamp(4.75rem, 14vw, 9rem);
  margin: 0 0 0.5rem;
  font-family: "Amatic SC", "AmaticSC", cursive;
  font-weight: 700;
  letter-spacing: 0.2px;
  line-height: 1.02;
  -webkit-text-stroke: 0.6px rgba(0, 0, 0, 0.06);
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.02), 0 2px 0 rgba(0, 0, 0, 0.02);
  color: #b45036;
}

/* Portrait block shown on top of the image: title + compact lead */
.hero__portrait-block {
  display: none;
}

.hero__portrait-content {
  font-size: clamp(0.95rem, 2.4vw, 1.05rem);
  margin-top: 0.35rem;
  color: var(--color-foreground);
}

/* center portrait block content; keep lists readable by centering the list container */
.hero__portrait-block {
  text-align: center;
}

.hero__portrait-content p {
  margin: 0.25rem 0;
}

.hero__portrait-content ul {
  display: inline-block;
  text-align: left;
  margin: 0.3rem 0 0;
  padding-left: 1rem;
}

.hero__portrait-block .hero__enter--portrait {
  display: inline-block;
  margin-top: 0.6rem;
}

/* Force-centre headings and lead text inside portrait block */
.hero__portrait-block .hero__title {
  text-align: center;
  margin: 0 auto;
  display: block;
}

.hero__portrait-block .hero__portrait-content {
  text-align: center;
}

/* Ensure landscape/full card text is centered; lists remain readable */
.hero__content {
  text-align: center;
}

.hero__content .hero__title {
  margin-left: auto;
  margin-right: auto;
}

.hero__lead ul {
  display: inline-block;
  text-align: left;
  margin: 0.4rem auto 0;
  padding-left: 1rem;
}

.hero__lead {
  font-size: clamp(0.95rem, 2.4vw, 1.2rem);
  margin: 0 0 1rem;
}

.hero__enter {
  display: inline-block;
  padding: 0.6rem 1rem;
  background: rgb(180, 80, 54);
  color: #fff;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.hero__enter:hover {
  background: rgb(156, 66, 43);
  color: #fff;
}

/* Portrait: slightly larger content area and lower-left placement */
@media (orientation: portrait) {
  .hero__title {
    font-size: clamp(2.1rem, 8vw, 4.5rem);
  }
  /* hide the full content card on portrait; use the compact portrait block instead */
  .hero__content {
    display: none !important;
  }
  .hero__portrait-block {
    display: block;
    position: absolute;
    top: 6%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    width: 86%;
    max-width: 720px;
    box-sizing: border-box;
    background: rgba(255, 255, 255, 0.88);
    padding: 0.75rem 1rem;
    border-radius: 10px;
    -webkit-backdrop-filter: blur(2px);
    backdrop-filter: blur(2px);
  }
  .hero__portrait-block .hero__title {
    color: #b45036;
    text-shadow: none;
  }
}
/* Landscape: keep content in lower-left quarter but narrower */
@media (orientation: landscape) {
  .hero__content {
    right: 4%;
    bottom: 8%;
    width: clamp(35%, 40vw, 520px);
  }
}
/* Small screens: ensure legibility and spacing */
@media (max-width: 600px) {
  .hero__content {
    width: 92%;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.95);
  }
  .hero__title {
    font-size: clamp(1.6rem, 8vw, 3rem);
  }
}
/* Smaller phones: show taller image and a centered, scrollable card overlay */
/* (SVG rules removed - using text rendering for the title) */
@media (max-width: 480px) {
  .hero {
    display: block;
  }
  /* make the image cover full viewport height */
  .hero__picture {
    position: relative;
    width: 100%;
    height: 100vh;
  }
  .hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  /* centered floating card that sits over the middle of the image */
  .hero__content {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    right: auto;
    bottom: auto;
    margin: 0;
    width: 86%;
    max-width: 520px;
    max-height: 66vh;
    overflow: auto;
    text-align: center;
    padding: 1rem;
    background: rgba(255, 255, 255, 0.95);
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  /* ensure title is visible inside the card */
  .hero__content .hero__title {
    display: block;
  }
  /* slightly reduce lead and button sizes */
  .hero__lead {
    font-size: 0.95rem;
  }
  .hero__enter {
    padding: 0.5rem 0.9rem;
  }
}
/* ensure the lead paragraph expands so the button stays at the bottom of the card */
.hero__content .hero__lead {
  flex: 1 1 auto;
  margin-bottom: 0.75rem;
}

.hero__content .hero__enter {
  margin-top: 0.5rem;
}

@media (max-width: 480px) {
  .hero__title {
    -webkit-text-stroke: 0.6px rgba(0, 0, 0, 0.06);
    text-shadow: 0 1px 0 rgba(0, 0, 0, 0.03), 0 2px 6px rgba(0, 0, 0, 0.06);
  }
}
@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
  }
}

/*# sourceMappingURL=main.css.map */