/*
Theme Name: AMH
Theme URI: https://disruptivepatterns.net
Author: JD Waring
Author URI: https://disruptivepatterns.net
Description: A minimal block theme
Version: 2.0.1
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: amh
*/

/* =========================
   Design Tokens
========================= */

:root {
  --site-bg: rgb(0, 0, 0);

  /* Layout */
  --content-max-width: 1200px;

  /* Banner */
  --banner-height-desktop: 140px;
  --banner-height-mobile: 100px;

  /* Nav */
  --nav-padding-block: 18px;
  --nav-bar-height: 64px;

  /* Nav interaction colours */
  --nav-link-color: #ffffff;
  --nav-hover-color: rgba(210, 221, 225, 0.8);
  --nav-active-color: #0ec8e9;

  /* Typography */
  --font-weight-light: 300;
  --font-weight-regular: 400;

  /* Mobile */
  --mobile-gutter: 16px;

  /* Divider */
  --line-color: #ffffff;
  --line-width: 1px;
}

/* =========================
   Base
========================= */

html,
body,
.wp-site-blocks {
  background: var(--site-bg);
}

body {
  overflow-x: hidden;
}

.wp-site-blocks {
  padding-top: var(--nav-bar-height);
}

/* Admin bar */
body.admin-bar .site-nav-bar {
  top: 32px;
}
@media (max-width: 782px) {
  body.admin-bar .site-nav-bar {
    top: 46px;
  }
}

/* =========================
   Global links (CONTENT ONLY)
========================= */

.wp-site-blocks a {
  color: var(--nav-link-color);
  text-decoration: none;
  transition: color 0.15s ease;
}

.wp-site-blocks a:hover {
  color: var(--nav-hover-color);
  text-decoration: underline;
}

/* Prevent underline leakage into nav + buttons */
.site-nav-bar a,
.site-footer-nav a,
.wp-block-button__link,
.site-nav-bar a:hover,
.site-footer-nav a:hover,
.wp-block-button__link:hover {
  text-decoration: none;
}

/* =========================
   Header + Banner
========================= */

.site-header {
  position: relative;
  background: transparent;
}

.site-header-banner.wp-block-cover {
  min-height: 140px!important;
}

.site-header-banner .wp-block-cover__inner-container {
  padding: 0;
}


@media (max-width: 600px) {
  .site-header-banner.wp-block-cover {
    min-height: var(--banner-height-mobile);
  }
}

/* =========================
   Fixed Navigation Bar
========================= */

.site-nav-bar {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 1000;
  background: rgb(0, 0, 0);
  min-height: var(--nav-bar-height);
  display: flex;
  align-items: center;
}

.site-nav-bar > .wp-block-group.alignwide {
  max-width: var(--content-max-width);
  margin-inline: auto;
  padding-inline: 2rem;
}
@media (max-width: 600px) {
  .site-nav-bar > .wp-block-group.alignwide {
    padding-inline: 1rem;
  }
}

/* =========================
   Navigation (shared header + footer)
========================= */

.site-nav-bar .wp-block-navigation__container,
.site-footer-nav .wp-block-navigation__container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.25rem;
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
}

.site-nav-bar .wp-block-navigation a,
.site-footer-nav .wp-block-navigation a {
  color: var(--nav-link-color);
  font-weight: var(--font-weight-light);
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: color 0.15s ease, opacity 0.15s ease;
}

.site-nav-bar .wp-block-navigation a:hover,
.site-footer-nav .wp-block-navigation a:hover {
  color: var(--nav-hover-color);
  opacity: 0.85;
}

/* Active */
.site-nav-bar .wp-block-navigation a[aria-current="page"] {
  color: var(--nav-active-color);
}

/* Footer nav slightly smaller */
.site-footer-nav .wp-block-navigation a {
  font-size: 0.75rem;
}

/* Post navigation block spacing */
.post-nav {
  margin: 2rem 0;
}


/* =========================
   BUTTONS (FINAL + CORRECT)
========================= */

.wp-block-button .wp-block-button__link {
  display: inline-block;
  background: #000;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 0;
  padding: 0.45rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: var(--font-weight-light);
  font-size: 0.75rem;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.wp-block-button .wp-block-button__link:hover,
.wp-block-button .wp-block-button__link:focus-visible {
  background: #222;
  color: #fff;
  text-decoration: none;
}


/* =========================
   Post navigation links
   (match button styling)
========================= */

.wp-block-post-navigation-link a {
  display: inline-block;
  background: #000;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 0;
  padding: 0.45rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: var(--font-weight-light);
  font-size: 0.75rem;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease;
}

/* Hover / focus */
.wp-block-post-navigation-link a:hover,
.wp-block-post-navigation-link a:focus-visible {
  background: #222;
  color: #fff;
  text-decoration: none;
}

li.wp-block-post {
    margin-bottom: 2rem;
}

.wp-block-post-title {
    margin-bottom: .3rem;
}
.wp-block-post-date {
    font-style: italic;
}



.video-wrapper {
  position: relative;
  padding-top: 56.25%; /* 16:9 */
}

.video-wrapper iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.content-separator {
  height: 1px;
  background: linear-gradient(to right, transparent, #303030, transparent);
  margin: 2rem 0;
}
.wp-element-caption {
  text-align: center;
}


/* =========================
   Footer
========================= */

.site-footer,
footer.wp-block-template-part {
  margin: 3rem auto 2rem auto;
}

.footer-copy {
  font-size: 0.7rem;
  margin: 1rem auto !important;
}

.footer-social-links {
  margin: 1rem auto !important;
}

.footer-social-links .wp-block-social-link a {
  color: #bbbbbb;
}
.footer-social-links .wp-block-social-link a:hover {
  color: #ffffff;
}

/* =========================
   Content wrapper
========================= */

.content-wrap {
  width: min(1200px, 80vw);
  margin-inline: auto;
  padding-inline: 2rem;
}
@media (max-width: 600px) {
  .content-wrap {
    width: 100%;
    padding-inline: 1rem;
  }
}
