/**
 * Prague Layout
 *
 * Structural tokens and component layout rules for the Prague theme.
 */

[data-layout="prague"] {
  --theme-header-height: 3.5rem;
  --theme-max-width: 1280px;
  --theme-section-padding: 6rem;

  --nav-display-mobile: none;
  --nav-display-desktop: flex;
  --nav-position: absolute;
  --nav-left: 0;
  --nav-list-gap: 24px;
  --nav-link-padding: 8px 0;

  --footer-padding: 3.125rem 1.5rem;
  --footer-padding-sm: 3.0625rem 4rem;
  --footer-padding-lg: var(--footer-padding-sm);
  --footer-container-display: flex;
  --footer-container-justify-content: center;
}

/* ============================================
   COMPONENT LAYOUT - Prague Theme
   ============================================ */

[data-layout="prague"] .theme-prague-post-page {
  min-height: 100vh;
  width: 100%;
}

[data-layout="prague"] .theme-prague-post-back-nav {
  padding: 8px 0px;
}

@media (max-width: 768px) {
  [data-layout="prague"] .theme-prague-post-back-nav {
    padding: 8px 0px;
  }
}

[data-layout="prague"] .theme-prague-back-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 0px;
}

[data-layout="prague"] .theme-prague-post-container {
  max-width: 1016px;
  margin: 0 auto;
  padding: 0 64px 24px;
}

@media (max-width: 768px) {
  [data-layout="prague"] .theme-prague-post-container {
    padding: 0 24px 24px;
  }
}

[data-layout="prague"] .theme-prague-post-hero {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  padding: 0 46px;
}

@media (max-width: 768px) {
  [data-layout="prague"] .theme-prague-post-hero {
    padding: 0;
  }
}

[data-layout="prague"] .theme-prague-post-cover-wrapper {
  width: 100%;
  aspect-ratio: 328 / 201;
  overflow: hidden;
  position: relative;
}

[data-layout="prague"] .theme-prague-post-cover-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 50%;
}

[data-layout="prague"] .theme-prague-post-header {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}

[data-layout="prague"] .theme-prague-category-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  width: fit-content;
}

[data-layout="prague"] .theme-prague-post-title {
  margin: 0;
}

[data-layout="prague"] .theme-prague-post-description {
  margin: 0;
}

[data-layout="prague"] .theme-prague-post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

[data-layout="prague"] .theme-prague-post-author-section {
  display: flex;
  align-items: center;
  gap: 10px;
}

[data-layout="prague"] .theme-prague-author-avatar {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

[data-layout="prague"] .theme-prague-author-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

[data-layout="prague"] .theme-prague-author-initials {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

[data-layout="prague"] .theme-prague-author-info {
  display: flex;
  flex-direction: column;
  gap: 0;
  flex: 1;
}

[data-layout="prague"] .theme-prague-author-name {
  margin: 0;
}

[data-layout="prague"] .theme-prague-post-date {
  margin: 0;
}

[data-layout="prague"] .theme-prague-divider {
  width: 100%;
  height: 1px;
  margin: 40px 0;
}

[data-layout="prague"] .theme-prague-content-divider {
  width: 100%;
  height: 1px;
  margin: 40px 0 16px;
}

[data-layout="prague"] .theme-prague-post-layout {
  display: flex;
  gap: 48px;
  width: 100%;
  align-items: flex-start;
  justify-content: center;
}

@media (max-width: 1024px) {
  [data-layout="prague"] .theme-prague-post-layout {
    flex-direction: column;
    gap: 24px;
  }
}

[data-layout="prague"] .theme-prague-toc-sidebar {
  width: 200px;
  flex-shrink: 0;
  align-self: flex-start;
}

@media (max-width: 1024px) {
  [data-layout="prague"] .theme-prague-toc-sidebar {
    width: 100%;
  }
}

[data-layout="prague"] .theme-prague-toc-sidebar h3,
[data-layout="prague"] .theme-prague-toc-sidebar h4 {
  margin: 0 0 24px 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

[data-layout="prague"] .theme-prague-toc-sidebar nav {
  display: flex;
  flex-direction: column;
  gap: 0;
}

[data-layout="prague"] .theme-prague-toc-sidebar ul {
  padding-left: 0;
  margin: 0;
  list-style: none;
}

[data-layout="prague"] .theme-prague-toc-sidebar li {
  position: relative;
  margin-left: -1px;
}

[data-layout="prague"] .theme-prague-toc-sidebar a,
[data-layout="prague"] .theme-prague-toc-sidebar button {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 8px 16px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

[data-layout="prague"] .theme-prague-post-content-wrapper {
  width: 500px;
  flex-shrink: 0;
}

@media (max-width: 768px) {
  [data-layout="prague"] .theme-prague-post-content-wrapper {
    width: 100%;
  }
}

[data-layout="prague"] .theme-prague-post-article {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

[data-layout="prague"] .theme-prague-post-article h2 {
  margin: 0 0 16px 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

[data-layout="prague"] .theme-prague-post-article p {
  margin: 0 0 10px 0;
}

[data-layout="prague"] .theme-prague-post-article blockquote {
  display: flex;
  gap: 16px;
  padding: 0;
  margin: 16px 0;
  padding-left: 16px;
}

[data-layout="prague"] .theme-prague-post-article blockquote p {
  margin: 0;
}

[data-layout="prague"] .theme-prague-post-article blockquote cite,
[data-layout="prague"] .theme-prague-post-article blockquote footer {
  margin-top: 16px;
}

[data-layout="prague"] .theme-prague-post-article ul {
  padding-left: 24px;
  margin: 0 0 10px 0;
}

[data-layout="prague"] .theme-prague-post-article ul li {
  margin-bottom: 0;
  padding-left: 0;
}

[data-layout="prague"] .theme-prague-post-article ul li:last-child {
  margin-bottom: 0;
}

[data-layout="prague"] .theme-prague-post-article ol {
  padding-left: 24px;
  margin: 0 0 10px 0;
}

[data-layout="prague"] .theme-prague-post-article ol li {
  margin-bottom: 0;
  padding-left: 0;
}

[data-layout="prague"] .theme-prague-post-article code {
  padding: 2px 6px;
}

[data-layout="prague"] .theme-prague-post-article pre {
  padding: 16px;
  overflow-x: auto;
  margin: 16px 0;
}

[data-layout="prague"] .theme-prague-post-article pre code {
  padding: 0;
}

[data-layout="prague"] .theme-prague-post-navigation {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
}

[data-layout="prague"] .theme-prague-nav-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
}

[data-layout="prague"] .theme-prague-related-posts-section {
  width: 100%;
  padding: 0 134px;
  margin-top: 40px;
}

@media (max-width: 1024px) {
  [data-layout="prague"] .theme-prague-related-posts-section {
    padding: 0 64px;
  }
}

@media (max-width: 768px) {
  [data-layout="prague"] .theme-prague-related-posts-section {
    padding: 0 24px;
  }
}

[data-layout="prague"] .theme-prague-search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  padding: 12px 16px;
  gap: 8px;
}

[data-layout="prague"] .theme-prague-search-icon {
  flex-shrink: 0;
}

[data-layout="prague"] .theme-prague-search-input {
  flex: 1;
  min-width: 0;
}

[data-layout="prague"] .theme-prague-blog-home-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 0 24px;
}

[data-layout="prague"] .theme-prague-blog-home-desktop {
  display: none;
}

@media (min-width: 1024px) {
  [data-layout="prague"] .theme-prague-blog-home-desktop {
    display: flex;
    flex-direction: column;
    gap: 48px;
    width: 100%;
    max-width: 1100px;
  }
}

[data-layout="prague"] .theme-prague-blog-header {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  padding: 0 64px;
  box-sizing: border-box;
  position: relative;
}

[data-layout="prague"] .theme-prague-blog-header-center {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 3px 0;
  width: 224px;
  flex-shrink: 0;
  box-sizing: border-box;
}

[data-layout="prague"] .theme-prague-blog-title {
  margin: 0;
  flex-shrink: 0;
}

[data-layout="prague"] .theme-prague-blog-header-left {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  min-width: 0;
}

[data-layout="prague"] .theme-prague-featured-label {
  margin: 0;
  width: 200px;
  flex-shrink: 0;
}

[data-layout="prague"] .theme-prague-blog-header-right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-shrink: 0;
}

[data-layout="prague"] .theme-prague-sort-dropdown-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 12px;
  position: relative;
}

[data-layout="prague"] .theme-prague-sort-dropdown-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  z-index: 50;
  min-width: 180px;
}

[data-layout="prague"] .theme-prague-sort-option {
  display: block;
  width: 100%;
  padding: 8px 12px;
  text-align: left;
}

[data-layout="prague"] .theme-prague-blog-content {
  display: flex;
  gap: 24px;
  width: 100%;
  padding: 0 64px;
  box-sizing: border-box;
}

[data-layout="prague"] .theme-prague-blog-sidebar {
  width: 200px;
  flex-shrink: 0;
}

[data-layout="prague"] .theme-prague-sidebar-content {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

[data-layout="prague"] .theme-prague-sidebar-content > div:has(button[aria-label*="mode"]) > div {
  padding: 0 !important;
  gap: 4px !important;
}

[data-layout="prague"] .theme-prague-sidebar-content button[aria-label*="mode"] {
  width: 24px !important;
  height: 24px !important;
  padding: 0 !important;
}

[data-layout="prague"] .theme-prague-sidebar-content button[aria-label*="mode"] > div {
  width: 24px !important;
  height: 24px !important;
  padding: 4px !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

[data-layout="prague"] .theme-prague-blog-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 40px;
}

[data-layout="prague"] .theme-prague-blog-posts {
  width: 100%;
}

[data-layout="prague"] .theme-prague-category-filter-container {
  display: flex;
  flex-direction: column;
  width: 100%;
}

[data-layout="prague"] .theme-prague-category-filter-desktop {
  display: none;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}

@media (min-width: 768px) {
  [data-layout="prague"] .theme-prague-category-filter-desktop {
    display: flex;
  }
}

[data-layout="prague"] .theme-prague-category-item {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  width: 100%;
  margin-left: -1px;
  text-align: left;
}

[data-layout="prague"] .theme-prague-category-filter-mobile {
  display: flex;
  position: relative;
  width: 100%;
}

@media (min-width: 768px) {
  [data-layout="prague"] .theme-prague-category-filter-mobile {
    display: none;
  }
}

[data-layout="prague"] .theme-prague-blog-home-mobile {
  display: flex;
  flex-direction: column;
  gap: 40px;
  padding: 16px;
}

@media (min-width: 1024px) {
  [data-layout="prague"] .theme-prague-blog-home-mobile {
    display: none;
  }
}

[data-layout="prague"] .theme-prague-blog-mobile-header {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
}

[data-layout="prague"] .theme-prague-blog-mobile-title {
  margin: 0;
  width: 100%;
}

[data-layout="prague"] .theme-prague-blog-mobile-search {
  width: 100%;
}

[data-layout="prague"] .theme-prague-blog-mobile-filters {
  display: flex;
  gap: 8px;
  width: 100%;
}

@media (max-width: 1023px) {
  [data-layout="prague"] .theme-prague-category-filter-mobile {
    display: block;
    width: 196.5px;
    flex-shrink: 0;
    position: relative;
  }
}

[data-layout="prague"] .theme-prague-category-mobile-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 12px 16px;
}

[data-layout="prague"] .theme-prague-category-mobile-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 50;
  overflow: hidden;
}

[data-layout="prague"] .theme-prague-category-mobile-item {
  display: block;
  width: 100%;
  padding: 12px 16px;
  text-align: left;
}

[data-layout="prague"] .theme-prague-blog-mobile-sort {
  flex: 1;
  position: relative;
}

[data-layout="prague"] .theme-prague-mobile-sort-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 12px 16px;
}

[data-layout="prague"] .theme-prague-mobile-sort-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  width: 100%;
  z-index: 50;
}

[data-layout="prague"] .theme-prague-mobile-sort-option {
  display: block;
  width: 100%;
  padding: 12px 16px;
  text-align: left;
}

[data-layout="prague"] .theme-prague-blog-mobile-posts {
  width: 100%;
}
