/*
Theme Name: TengriWay
Theme URI: https://tengriway.org
Author: TengriWay
Author URI: https://tengriway.org
Description: A calm editorial WordPress theme for Tengri belief, steppe heritage, ancestral memory, and modern spiritual practice.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: tengriway
Tags: blog, custom-logo, custom-menu, featured-images, block-patterns, editor-style, wide-blocks
*/

:root {
  --tw-navy: #0b2d4d;
  --tw-blue: #1e5f8c;
  --tw-gold: #c99a45;
  --tw-brown: #7a5a3a;
  --tw-sand: #f4ebd8;
  --tw-cloud: #faf8f2;
  --tw-ink: #1c1c1c;
  --tw-mist: #d8d3c8;
  --tw-muted: #69635a;
  --tw-serif: "Cormorant Garamond", "Libre Baskerville", Georgia, serif;
  --tw-sans: "Inter", "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --tw-radius: 8px;
  --tw-shadow: 0 18px 48px rgba(11, 45, 77, .11);
  --tw-content: 1180px;
  --tw-reader: 780px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--tw-cloud);
  color: var(--tw-ink);
  font-family: var(--tw-sans);
  font-size: 17px;
  line-height: 1.72;
  text-rendering: optimizeLegibility;
}
a { color: var(--tw-blue); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--tw-navy); }
img { display: block; height: auto; max-width: 100%; }
h1, h2, h3, h4, h5, h6 {
  color: var(--tw-navy);
  font-family: var(--tw-serif);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.05;
  margin: 0 0 .6em;
}
h1 { font-size: clamp(3rem, 6vw, 6.7rem); }
h2 { font-size: clamp(2.2rem, 4vw, 4.1rem); }
h3 { font-size: clamp(1.45rem, 2vw, 2.05rem); }
p { margin: 0 0 1.2em; }
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  position: absolute;
  width: 1px;
}
.skip-link:focus {
  background: var(--tw-gold);
  color: var(--tw-ink);
  clip: auto;
  height: auto;
  left: 1rem;
  padding: .6rem .85rem;
  top: 1rem;
  width: auto;
  z-index: 9999;
}
.site-header {
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  transition: background .25s ease, box-shadow .25s ease, color .25s ease;
  z-index: 1000;
}
.admin-bar .site-header { top: 32px; }
.header-inner {
  align-items: center;
  display: flex;
  gap: 2rem;
  justify-content: space-between;
  margin: 0 auto;
  max-width: var(--tw-content);
  padding: 1.05rem 1.25rem;
}
.site-header.is-transparent { color: #fff; }
.site-header.is-solid,
.site-header.is-open {
  background: rgba(250, 248, 242, .96);
  box-shadow: 0 8px 28px rgba(11, 45, 77, .08);
  color: var(--tw-ink);
}
.site-branding a {
  align-items: center;
  color: inherit;
  display: inline-flex;
  gap: .72rem;
  text-decoration: none;
}
.brand-mark {
  border: 1.5px solid currentColor;
  border-radius: 999px 999px 4px 4px;
  height: 34px;
  position: relative;
  width: 42px;
}
.brand-mark:before {
  background: currentColor;
  border-radius: 999px;
  bottom: 8px;
  content: "";
  height: 7px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 7px;
}
.brand-name {
  font-family: var(--tw-serif);
  font-size: 1.55rem;
  font-weight: 600;
  line-height: 1;
}
.custom-logo { max-height: 48px; width: auto; }
.primary-menu {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1.05rem;
  justify-content: flex-end;
  list-style: none;
  margin: 0;
  padding: 0;
}
.primary-menu a {
  color: inherit;
  font-size: .82rem;
  font-weight: 650;
  letter-spacing: .04em;
  text-decoration: none;
  text-transform: uppercase;
}
.primary-menu a:hover { color: var(--tw-gold); }
.menu-toggle {
  background: transparent;
  border: 1px solid currentColor;
  border-radius: var(--tw-radius);
  color: inherit;
  display: none;
  font: 700 .78rem/1 var(--tw-sans);
  padding: .7rem .9rem;
  text-transform: uppercase;
}
.site-main { min-height: 70vh; }
.container {
  margin: 0 auto;
  max-width: var(--tw-content);
  padding: 0 1.25rem;
}
.section {
  padding: clamp(4rem, 8vw, 7.5rem) 0;
}
.section-kicker,
.card-kicker,
.entry-category {
  color: var(--tw-brown);
  display: inline-block;
  font-size: .76rem;
  font-weight: 750;
  letter-spacing: .12em;
  margin-bottom: .85rem;
  text-transform: uppercase;
}
.section-head {
  max-width: 760px;
  margin-bottom: 2.4rem;
}
.section-head p,
.lead {
  color: var(--tw-muted);
  font-size: clamp(1.08rem, 1.8vw, 1.28rem);
  line-height: 1.75;
}
.hero {
  align-items: flex-end;
  background-color: var(--tw-navy);
  background-position: center;
  background-size: cover;
  color: #fff;
  display: flex;
  min-height: min(820px, 96vh);
  overflow: hidden;
  position: relative;
}
.hero:before {
  background: linear-gradient(90deg, rgba(6, 28, 48, .78), rgba(6, 28, 48, .35) 45%, rgba(6, 28, 48, .04));
  content: "";
  inset: 0;
  position: absolute;
}
.hero:after {
  background: linear-gradient(180deg, transparent, rgba(11, 45, 77, .2));
  bottom: 0;
  content: "";
  height: 30%;
  left: 0;
  position: absolute;
  right: 0;
}
.hero-content {
  max-width: 850px;
  padding: 10rem 1.25rem 7rem;
  position: relative;
  z-index: 1;
}
.hero h1 { color: #fff; margin-bottom: 1rem; }
.hero p {
  color: rgba(255, 255, 255, .9);
  font-size: clamp(1.1rem, 2vw, 1.42rem);
  max-width: 760px;
}
.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-top: 1.8rem;
}
.button,
.wp-block-button__link,
button,
input[type="submit"] {
  border-radius: var(--tw-radius);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--tw-sans);
  font-size: .86rem;
  font-weight: 750;
  justify-content: center;
  letter-spacing: .04em;
  line-height: 1;
  padding: .95rem 1.2rem;
  text-decoration: none;
  text-transform: uppercase;
  transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}
.button:hover,
.wp-block-button__link:hover,
button:hover,
input[type="submit"]:hover { transform: translateY(-1px); }
.button-primary,
.wp-block-button__link,
input[type="submit"] {
  background: var(--tw-blue);
  border: 1px solid var(--tw-blue);
  color: #fff;
}
.button-primary:hover,
.wp-block-button__link:hover,
input[type="submit"]:hover {
  background: var(--tw-navy);
  border-color: var(--tw-gold);
  color: #fff;
}
.button-secondary {
  background: rgba(250, 248, 242, .08);
  border: 1px solid rgba(255, 255, 255, .6);
  color: #fff;
}
.button-secondary:hover {
  background: var(--tw-sand);
  border-color: var(--tw-gold);
  color: var(--tw-navy);
}
.button-outline {
  background: transparent;
  border: 1px solid var(--tw-blue);
  color: var(--tw-navy);
}
.button-outline:hover {
  background: var(--tw-navy);
  border-color: var(--tw-navy);
  color: #fff;
}
.intro-grid,
.community-grid {
  align-items: center;
  display: grid;
  gap: clamp(2rem, 5vw, 5rem);
  grid-template-columns: minmax(0, 1fr) minmax(280px, .85fr);
}
.image-panel {
  border-radius: var(--tw-radius);
  box-shadow: var(--tw-shadow);
  min-height: 410px;
  overflow: hidden;
  position: relative;
}
.image-panel img {
  height: 100%;
  object-fit: cover;
  position: absolute;
  width: 100%;
}
.start-section,
.newsletter-section {
  background: var(--tw-sand);
  border-block: 1px solid rgba(122, 90, 58, .18);
}
.cornerstone {
  background: var(--tw-cloud);
  border: 1px solid rgba(122, 90, 58, .18);
  border-radius: var(--tw-radius);
  box-shadow: var(--tw-shadow);
  display: grid;
  gap: 0;
  grid-template-columns: minmax(280px, .92fr) minmax(0, 1fr);
  overflow: hidden;
}
.cornerstone-media {
  background: var(--tw-navy);
  min-height: 390px;
  position: relative;
}
.cornerstone-media img { height: 100%; object-fit: cover; position: absolute; width: 100%; }
.cornerstone-body { padding: clamp(1.6rem, 4vw, 3rem); }
.badge {
  background: rgba(201, 154, 69, .16);
  border: 1px solid rgba(201, 154, 69, .42);
  border-radius: 999px;
  color: var(--tw-brown);
  display: inline-flex;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .11em;
  margin-bottom: 1rem;
  padding: .42rem .7rem;
  text-transform: uppercase;
}
.card-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 1rem;
}
.path-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(5, minmax(180px, 1fr));
}
.article-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.card,
.article-card,
.category-card {
  background: rgba(255, 255, 255, .62);
  border: 1px solid rgba(122, 90, 58, .16);
  border-radius: var(--tw-radius);
  min-width: 0;
  overflow: hidden;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.card:hover,
.article-card:hover,
.category-card:hover {
  border-color: rgba(201, 154, 69, .55);
  box-shadow: 0 14px 34px rgba(11, 45, 77, .08);
  transform: translateY(-2px);
}
.card a,
.article-card a,
.category-card a {
  color: inherit;
  display: block;
  height: 100%;
  padding: 1.2rem;
  text-decoration: none;
}
.category-card .symbol {
  align-items: center;
  border: 1px solid rgba(30, 95, 140, .35);
  border-radius: 999px 999px 4px 4px;
  color: var(--tw-blue);
  display: inline-flex;
  height: 42px;
  justify-content: center;
  margin-bottom: 1.2rem;
  width: 42px;
}
.category-card .symbol:before {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 7px;
  width: 7px;
}
.article-card a { padding: 0; }
.article-card img {
  aspect-ratio: 16 / 10;
  object-fit: cover;
  width: 100%;
}
.article-card-body { padding: 1.15rem; }
.entry-meta,
.article-meta {
  color: var(--tw-muted);
  display: flex;
  flex-wrap: wrap;
  font-size: .86rem;
  gap: .35rem .7rem;
}
.manifesto-band {
  background: var(--tw-navy);
  color: var(--tw-sand);
  position: relative;
}
.manifesto-band h2 { color: #fff; }
.manifesto-quote {
  color: rgba(250, 248, 242, .9);
  font-family: var(--tw-serif);
  font-size: clamp(1.7rem, 3vw, 3rem);
  line-height: 1.22;
  max-width: 980px;
}
.newsletter-box {
  align-items: center;
  display: grid;
  gap: 2rem;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .85fr);
}
.newsletter-form {
  display: flex;
  gap: .65rem;
}
input[type="email"],
input[type="search"],
input[type="text"],
textarea {
  background: #fff;
  border: 1px solid rgba(122, 90, 58, .24);
  border-radius: var(--tw-radius);
  color: var(--tw-ink);
  font: inherit;
  min-height: 48px;
  padding: .75rem .9rem;
  width: 100%;
}
.site-footer {
  background: #071f36;
  color: rgba(244, 235, 216, .78);
  padding: 4rem 0 2rem;
}
.site-footer a { color: var(--tw-sand); text-decoration: none; }
.footer-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1.3fr .8fr .8fr 1fr;
}
.footer-title {
  color: #fff;
  font-family: var(--tw-serif);
  font-size: 1.75rem;
  line-height: 1;
  margin-bottom: 1rem;
}
.footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-list li { margin-bottom: .55rem; }
.footer-bottom {
  border-top: 1px solid rgba(244, 235, 216, .16);
  font-size: .9rem;
  margin-top: 2rem;
  padding-top: 1.2rem;
}
.page-header,
.archive-header {
  background: var(--tw-sand);
  padding: 9rem 0 4rem;
}
.content-area {
  padding: 4rem 0;
}
.reader {
  margin: 0 auto;
  max-width: var(--tw-reader);
  padding: 0 1.25rem;
}
.entry-hero {
  background: var(--tw-sand);
  padding: 9rem 0 0;
}
.entry-hero .reader { padding-bottom: 3rem; }
.entry-title { margin-bottom: .35em; }
.entry-excerpt {
  color: var(--tw-muted);
  font-size: 1.25rem;
}
.featured-hero-image {
  margin: 0 auto;
  max-width: min(1180px, calc(100% - 2.5rem));
}
.featured-hero-image img {
  aspect-ratio: 16 / 8;
  border-radius: var(--tw-radius);
  object-fit: cover;
  width: 100%;
}
.article-content {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.13rem;
  line-height: 1.86;
}
.article-content > * { margin-left: auto; margin-right: auto; max-width: var(--tw-reader); }
.article-content h2,
.article-content h3,
.article-content h4 {
  margin-top: 2em;
}
.article-content .alignwide {
  max-width: 1040px;
}
.article-content .alignfull {
  max-width: none;
}
.article-content blockquote,
.wp-block-quote {
  border-left: 3px solid var(--tw-gold);
  color: var(--tw-navy);
  font-family: var(--tw-serif);
  font-size: 1.65rem;
  line-height: 1.32;
  margin-block: 2rem;
  padding: .4rem 0 .4rem 1.4rem;
}
.toc {
  background: var(--tw-sand);
  border: 1px solid rgba(122, 90, 58, .16);
  border-radius: var(--tw-radius);
  margin-bottom: 2rem;
  padding: 1rem 1.2rem;
}
.toc summary {
  color: var(--tw-navy);
  cursor: pointer;
  font-weight: 800;
}
.toc ul {
  margin: .8rem 0 0;
  padding-left: 1.1rem;
}
.post-navigation,
.related-posts {
  border-top: 1px solid rgba(122, 90, 58, .16);
  margin-top: 3rem;
  padding-top: 2.2rem;
}
.search-form {
  display: flex;
  gap: .65rem;
  max-width: 620px;
}
.pagination,
.nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 2rem;
}
.page-numbers,
.nav-links a,
.nav-links span {
  border: 1px solid rgba(122, 90, 58, .2);
  border-radius: var(--tw-radius);
  padding: .45rem .75rem;
  text-decoration: none;
}
.wp-caption-text,
.article-content figcaption {
  color: var(--tw-muted);
  font-family: var(--tw-sans);
  font-size: .88rem;
  margin-top: .55rem;
}
@media (max-width: 1040px) {
  .path-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .article-grid,
  .card-grid,
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  body { font-size: 16px; }
  .admin-bar .site-header { top: 46px; }
  .menu-toggle { display: inline-flex; }
  .main-navigation {
    background: var(--tw-cloud);
    border-top: 1px solid rgba(122, 90, 58, .18);
    display: none;
    left: 0;
    padding: 1rem 1.25rem 1.2rem;
    position: absolute;
    right: 0;
    top: 100%;
  }
  .site-header.is-open .main-navigation { display: block; }
  .primary-menu {
    align-items: stretch;
    flex-direction: column;
    gap: .3rem;
  }
  .primary-menu a {
    color: var(--tw-navy);
    display: block;
    padding: .55rem 0;
  }
  .hero { min-height: 760px; }
  .hero:before {
    background: linear-gradient(180deg, rgba(6, 28, 48, .42), rgba(6, 28, 48, .78));
  }
  .hero-content { padding-bottom: 4rem; }
  .button-row,
  .newsletter-form,
  .search-form { flex-direction: column; }
  .button,
  .wp-block-button__link,
  button,
  input[type="submit"] { width: 100%; }
  .intro-grid,
  .community-grid,
  .cornerstone,
  .newsletter-box,
  .article-grid,
  .card-grid,
  .path-grid,
  .footer-grid { grid-template-columns: 1fr; }
  .image-panel,
  .cornerstone-media { min-height: 280px; }
  .section { padding: 3.5rem 0; }
  .page-header,
  .archive-header,
  .entry-hero { padding-top: 7rem; }
  .featured-hero-image img { aspect-ratio: 4 / 3; }
}
