/*

Theme Name: Manzari Theme

Author: Gerry

Version: 1.0

*/

/* =============================================================================

   MANZARI — Main Stylesheet

   Theme: Custom WordPress Theme (Hello / Underscores / Custom base)

   Fonts: Cormorant Garamond (headings) + Inter (body/UI)

   Version: 1.0

   ============================================================================= */



/* -----------------------------------------------------------------------------

   0. GOOGLE FONTS IMPORT

   ----------------------------------------------------------------------------- */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400;1,600;1,700&family=Inter:wght@300;400;500;600;700&display=swap');





/* -----------------------------------------------------------------------------

   1. DESIGN TOKENS (CSS Custom Properties)

   ----------------------------------------------------------------------------- */

:root {

  /* Backgrounds */

  --color-bg:          #F7F5F0;

  --color-surface:     #FFFFFF;

  --color-surface-2:   #F2F0EB;

  --color-surface-3:   #ECEAE4;



  /* Text */

  --color-text-primary:   #0C0B09;

  --color-text-secondary: #5C5954;

  --color-text-muted:     #A09C96;



  /* Borders */

  --color-border:       #E2DFD8;

  --color-border-dark:  #D0CCC4;

  --color-rule:         rgba(12, 11, 9, 0.07);



  /* Buttons */

  --color-btn-bg:   #0C0B09;

  --color-btn-text: #F7F5F0;



  /* Tags */

  --color-tag-bg:   #ECEAE4;

  --color-tag-text: #5C5954;



  /* Typography */

  --font-display: 'Cormorant Garamond', Georgia, serif;

  --font-ui:      'Inter', system-ui, -apple-system, sans-serif;



  /* Spacing scale */

  --space-xs:  0.5rem;

  --space-sm:  1rem;

  --space-md:  1.5rem;

  --space-lg:  2.5rem;

  --space-xl:  4.5rem;

  --space-2xl: 6rem;



  /* Layout */

  --max-width:    1160px;

  --radius-sm:    4px;

  --radius-md:    7px;

  --radius-lg:    12px;

  --radius-xl:    14px;

  --radius-pill:  100px;

}





/* -----------------------------------------------------------------------------

   2. RESET & BASE

   ----------------------------------------------------------------------------- */

*,

*::before,

*::after {

  box-sizing: border-box;

  margin: 0;

  padding: 0;

}



html {

  font-size: 16px;

  scroll-behavior: smooth;

  -webkit-text-size-adjust: 100%;

}



body {

  font-family: var(--font-ui);

  font-size: 1rem;

  font-weight: 400;

  line-height: 1.6;

  background-color: var(--color-bg);

  color: var(--color-text-primary);

  -webkit-font-smoothing: antialiased;

  -moz-osx-font-smoothing: grayscale;

}



img,

picture,

video,

canvas,

svg {

  display: block;

  max-width: 100%;

}



input,

button,

textarea,

select {

  font: inherit;

}



p,

h1,

h2,

h3,

h4,

h5,

h6 {

  overflow-wrap: break-word;

}



ul,

ol {

  list-style: none;

}



a {

  color: inherit;

  text-decoration: none;

}





/* -----------------------------------------------------------------------------

   3. TYPOGRAPHY SYSTEM

   ----------------------------------------------------------------------------- */



/* Display headings — Cormorant Garamond */

h1,

h2,

h3,

h4 {

  font-family: var(--font-display);

  font-weight: 700;

  line-height: 1.1;

  color: var(--color-text-primary);

}



h1 { font-size: clamp(2.5rem, 5vw, 4rem);   letter-spacing: -0.025em; }

h2 { font-size: clamp(1.75rem, 3vw, 2.25rem); letter-spacing: -0.02em; }

h3 { font-size: clamp(1.1rem, 2vw, 1.4rem);   letter-spacing: -0.01em; }

h4 { font-size: 1.1rem; letter-spacing: -0.01em; }



/* Body text — Inter */

p {

  font-family: var(--font-ui);

  font-size: 0.9375rem;

  line-height: 1.78;

  color: var(--color-text-secondary);

}



/* Eyebrow / label utility */

.mzr-eyebrow {

  display: inline-flex;

  align-items: center;

  gap: 0.5rem;

  font-family: var(--font-ui);

  font-size: 0.65rem;

  font-weight: 700;

  letter-spacing: 0.14em;

  text-transform: uppercase;

  color: var(--color-text-muted);

}



.mzr-eyebrow__line {

  display: inline-block;

  width: 20px;

  height: 1px;

  background-color: var(--color-border-dark);

  flex-shrink: 0;

}



/* Italic accent in headings */

.mzr-italic {

  font-style: italic;

  color: var(--color-text-secondary);

}





/* -----------------------------------------------------------------------------

   4. LAYOUT UTILITIES

   ----------------------------------------------------------------------------- */

.mzr-container {

  width: 100%;

  max-width: var(--max-width);

  margin-inline: auto;

  padding-inline: 2.5rem;

}



.mzr-section {

  padding-block: var(--space-xl);

}



.mzr-divider {

  height: 1px;

  background-color: var(--color-rule);

  max-width: var(--max-width);

  margin-inline: auto;

  margin-inline-start: 2.5rem;

  margin-inline-end: 2.5rem;

}





/* -----------------------------------------------------------------------------

   5. BUTTONS

   ----------------------------------------------------------------------------- */

.mzr-btn {

  display: inline-flex;

  align-items: center;

  gap: 0.4rem;

  font-family: var(--font-ui);

  font-size: 0.82rem;

  font-weight: 600;

  letter-spacing: 0.01em;

  padding: 0.7rem 1.6rem;

  border-radius: var(--radius-md);

  border: 1px solid transparent;

  cursor: pointer;

  transition: opacity 0.2s ease, border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;

  white-space: nowrap;

  text-decoration: none;

}



.mzr-btn--primary {

  background-color: var(--color-btn-bg);

  color: var(--color-btn-text);

  border-color: var(--color-btn-bg);

}



.mzr-btn--primary:hover {

  opacity: 0.85;

}



.mzr-btn--secondary {

  background-color: transparent;

  color: var(--color-text-secondary);

  border-color: var(--color-border-dark);

}



.mzr-btn--secondary:hover {

  color: var(--color-text-primary);

  border-color: var(--color-text-muted);

}



.mzr-btn--sm {

  font-size: 0.76rem;

  padding: 0.52rem 1rem;

}





/* -----------------------------------------------------------------------------

   6. TAGS & BADGES

   ----------------------------------------------------------------------------- */

.mzr-tag {

  display: inline-block;

  font-family: var(--font-ui);

  font-size: 0.6rem;

  font-weight: 700;

  letter-spacing: 0.1em;

  text-transform: uppercase;

  color: var(--color-tag-text);

  background-color: var(--color-tag-bg);

  padding: 0.18rem 0.5rem;

  border-radius: var(--radius-sm);

}



.mzr-tag--dark {

  color: var(--color-btn-text);

  background-color: var(--color-btn-bg);

}





/* =============================================================================

   HEADER / NAVIGATION

   ============================================================================= */

.mzr-site-header {

  position: sticky;

  top: 0;

  z-index: 100;

  background-color: var(--color-bg);

  border-bottom: 1px solid var(--color-rule);

}



.mzr-nav {

  display: flex;

  align-items: center;

  justify-content: space-between;

  padding-block: 1.1rem;

  gap: 1.5rem;

}



/* Logo */

.mzr-nav__logo {

  font-family: var(--font-display);

  font-size: 1.55rem;

  font-weight: 700;

  letter-spacing: -0.01em;

  color: var(--color-text-primary);

  line-height: 1;

  white-space: nowrap;

  text-decoration: none;

}



.mzr-nav__logo-sub {

  font-family: var(--font-ui);

  font-size: 0.5rem;

  font-weight: 600;

  letter-spacing: 0.14em;

  text-transform: uppercase;

  color: var(--color-text-muted);

  vertical-align: middle;

  margin-left: 0.25rem;

}



/* Nav links */

.mzr-nav__links {

  display: flex;

  align-items: center;

  gap: 2rem;

}



.mzr-nav__links li a {

  font-family: var(--font-ui);

  font-size: 0.8rem;

  font-weight: 500;

  color: var(--color-text-secondary);

  letter-spacing: 0.005em;

  transition: color 0.2s;

}



.mzr-nav__links li a:hover {

  color: var(--color-text-primary);

}



/* Nav actions */

.mzr-nav__actions {

  display: flex;

  align-items: center;

  gap: 0.65rem;

}



.mzr-nav__signin {

  font-family: var(--font-ui);

  font-size: 0.78rem;

  font-weight: 500;

  color: var(--color-text-secondary);

  background: transparent;

  border: 1px solid var(--color-border-dark);

  border-radius: var(--radius-md);

  padding: 0.42rem 0.95rem;

  cursor: pointer;

  transition: color 0.2s, border-color 0.2s;

}



.mzr-nav__signin:hover {

  color: var(--color-text-primary);

  border-color: var(--color-text-muted);

}



/* Mobile hamburger (hidden on desktop) */

.mzr-nav__hamburger {

  display: none;

  flex-direction: column;

  gap: 5px;

  background: none;

  border: none;

  cursor: pointer;

  padding: 0.25rem;

}



.mzr-nav__hamburger span {

  display: block;

  width: 22px;

  height: 1.5px;

  background-color: var(--color-text-primary);

  transition: transform 0.2s;

}



/* Mobile nav drawer */

.mzr-nav__drawer {

  display: none;

  flex-direction: column;

  gap: 0;

  padding: 0.5rem 0 1rem;

  border-top: 1px solid var(--color-rule);

}



.mzr-nav__drawer li a {

  display: block;

  font-family: var(--font-ui);

  font-size: 0.9rem;

  font-weight: 500;

  color: var(--color-text-secondary);

  padding: 0.65rem 0;

  border-bottom: 1px solid var(--color-rule);

}



.mzr-nav__drawer--open {

  display: flex;

}





/* =============================================================================

   HERO SECTION

   ============================================================================= */

.mzr-hero {

  border-bottom: 1px solid var(--color-rule);

}



.mzr-hero__inner {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 4.5rem;

  align-items: center;

  padding-block: 5.5rem 5rem;

}



/* Left column */

.mzr-hero__content {

  display: flex;

  flex-direction: column;

  align-items: flex-start;

}



.mzr-hero__eyebrow {

  margin-bottom: 1.25rem;

}



.mzr-hero__heading {

  margin-bottom: 1.25rem;

  line-height: 1.04;

}



.mzr-hero__subtext {

  max-width: 430px;

  margin-bottom: 2rem;

}



.mzr-hero__actions {

  display: flex;

  align-items: center;

  gap: 0.875rem;

  margin-bottom: 2rem;

  flex-wrap: wrap;

}



/* Social proof strip */

.mzr-hero__meta {

  display: flex;

  align-items: center;

  gap: 1.5rem;

  padding-top: 1.75rem;

  border-top: 1px solid var(--color-rule);

  width: 100%;

}



.mzr-hero__meta-item {

  display: flex;

  flex-direction: column;

  gap: 3px;

}



.mzr-hero__meta-num {

  font-family: var(--font-display);

  font-size: 1.6rem;

  font-weight: 700;

  color: var(--color-text-primary);

  line-height: 1;

  letter-spacing: -0.02em;

}



.mzr-hero__meta-label {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  font-weight: 600;

  letter-spacing: 0.1em;

  text-transform: uppercase;

  color: var(--color-text-muted);

}



.mzr-hero__meta-divider {

  width: 1px;

  height: 34px;

  background-color: var(--color-border);

  flex-shrink: 0;

}



/* Right column — Tool panel card */

.mzr-tool-panel {

  background-color: var(--color-surface);

  border: 1px solid var(--color-border);

  border-radius: var(--radius-xl);

  padding: 1.5rem;

}



.mzr-tool-panel__header {

  display: flex;

  align-items: center;

  justify-content: space-between;

  margin-bottom: 1.25rem;

  padding-bottom: 1.25rem;

  border-bottom: 1px solid var(--color-rule);

}



.mzr-tool-panel__title {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  font-weight: 700;

  letter-spacing: 0.12em;

  text-transform: uppercase;

  color: var(--color-text-muted);

}



/* Individual tool row */

.mzr-tool-row {

  display: flex;

  align-items: center;

  justify-content: space-between;

  padding-block: 0.7rem;

  border-bottom: 1px solid var(--color-rule);

}



.mzr-tool-row:last-child {

  border-bottom: none;

  padding-bottom: 0;

}



.mzr-tool-row__info {

  display: flex;

  align-items: center;

  gap: 0.75rem;

}



.mzr-tool-row__monogram {

  width: 32px;

  height: 32px;

  border-radius: var(--radius-md);

  background-color: var(--color-surface-2);

  border: 1px solid var(--color-border);

  display: flex;

  align-items: center;

  justify-content: center;

  font-family: var(--font-display);

  font-size: 0.9rem;

  font-weight: 700;

  color: var(--color-text-primary);

  flex-shrink: 0;

  line-height: 1;

}



.mzr-tool-row__name {

  font-family: var(--font-ui);

  font-size: 0.82rem;

  font-weight: 600;

  color: var(--color-text-primary);

}



.mzr-tool-row__category {

  font-family: var(--font-ui);

  font-size: 0.67rem;

  color: var(--color-text-muted);

}



.mzr-tool-row__score {

  font-family: var(--font-ui);

  font-size: 0.7rem;

  font-weight: 600;

  color: var(--color-text-secondary);

  background-color: var(--color-tag-bg);

  padding: 0.15rem 0.45rem;

  border-radius: var(--radius-sm);

  flex-shrink: 0;

}





/* =============================================================================

   LOGO / PARTNER BAR

   ============================================================================= */

.mzr-partners {

  background-color: var(--color-surface);

  border-bottom: 1px solid var(--color-rule);

  padding-block: 1.5rem;

}



.mzr-partners__inner {

  display: flex;

  align-items: center;

  gap: 2rem;

  flex-wrap: wrap;

  justify-content: center;

}



.mzr-partners__label {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  font-weight: 700;

  letter-spacing: 0.12em;

  text-transform: uppercase;

  color: var(--color-text-muted);

  white-space: nowrap;

  padding-right: 0.6rem;

  border-right: 1px solid var(--color-border);

}



.mzr-partners__name {

  font-family: var(--font-ui);

  font-size: 0.77rem;

  font-weight: 500;

  color: var(--color-text-muted);

  transition: color 0.2s;

}



.mzr-partners__name:hover {

  color: var(--color-text-secondary);

}





/* =============================================================================

   RECOMMENDATIONS SECTION

   ============================================================================= */

.mzr-recs {

  border-bottom: 1px solid var(--color-rule);

}



.mzr-section__header {

  margin-bottom: 2.5rem;

}



.mzr-section__eyebrow {

  margin-bottom: 0.75rem;

}



.mzr-section__heading {

  margin-bottom: 0.65rem;

  line-height: 1.12;

}



.mzr-section__subtext {

  max-width: 440px;

}



/* Card grid — joined style */

.mzr-card-grid {

  display: grid;

  grid-template-columns: repeat(3, 1fr);

  gap: 1px;

  background-color: var(--color-border);

  border: 1px solid var(--color-border);

  border-radius: var(--radius-lg);

  overflow: hidden;

}



.mzr-rec-card {

  background-color: var(--color-surface);

  padding: 1.75rem;

  transition: background-color 0.2s;

}



.mzr-rec-card:hover {

  background-color: var(--color-surface-2);

}



.mzr-rec-card--featured {

  border-top: 2px solid var(--color-text-primary);

}



.mzr-rec-card__tag {

  margin-bottom: 1.1rem;

}



.mzr-rec-card__name {

  font-family: var(--font-display);

  font-size: 1.4rem;

  font-weight: 700;

  color: var(--color-text-primary);

  margin-bottom: 0.4rem;

  letter-spacing: -0.01em;

  line-height: 1.1;

}



.mzr-rec-card__desc {

  font-family: var(--font-ui);

  font-size: 0.8rem;

  line-height: 1.68;

  color: var(--color-text-secondary);

  margin-bottom: 1.25rem;

}



.mzr-rec-card__footer {

  display: flex;

  align-items: center;

  justify-content: space-between;

  gap: 0.5rem;

}



.mzr-rec-card__price {

  font-family: var(--font-ui);

  font-size: 0.73rem;

  font-weight: 600;

  color: var(--color-text-secondary);

}



.mzr-rec-card__link {

  font-family: var(--font-ui);

  font-size: 0.73rem;

  font-weight: 600;

  color: var(--color-text-primary);

  display: inline-flex;

  align-items: center;

  gap: 0.3rem;

  transition: gap 0.15s;

}



.mzr-rec-card__link:hover {

  gap: 0.55rem;

}



.mzr-recs__cta {

  text-align: center;

  margin-top: 1.75rem;

}





/* =============================================================================

   TUTORIALS SECTION

   ============================================================================= */

.mzr-tutorials {

  border-bottom: 1px solid var(--color-rule);

}



.mzr-section__row {

  display: flex;

  align-items: flex-end;

  justify-content: space-between;

  flex-wrap: wrap;

  gap: 1rem;

  margin-bottom: 2.5rem;

}



.mzr-tut-grid {

  display: grid;

  grid-template-columns: repeat(3, 1fr);

  gap: 1.5rem;

}



.mzr-tut-card {

  border-bottom: 1px solid var(--color-border);

  padding-bottom: 1.5rem;

  cursor: pointer;

}



.mzr-tut-card:hover .mzr-tut-card__title {

  text-decoration: underline;

  text-underline-offset: 3px;

}



.mzr-tut-card__meta {

  display: flex;

  align-items: center;

  gap: 0.65rem;

  margin-bottom: 0.7rem;

}



.mzr-tut-card__category {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  font-weight: 700;

  letter-spacing: 0.1em;

  text-transform: uppercase;

  color: var(--color-text-muted);

}



.mzr-tut-card__dot {

  width: 3px;

  height: 3px;

  border-radius: 50%;

  background-color: var(--color-border-dark);

  flex-shrink: 0;

}



.mzr-tut-card__time {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  color: var(--color-text-muted);

}



.mzr-tut-card__title {

  font-family: var(--font-display);

  font-size: 1.25rem;

  font-weight: 700;

  color: var(--color-text-primary);

  line-height: 1.28;

  margin-bottom: 0.5rem;

  letter-spacing: -0.01em;

}



.mzr-tut-card__desc {

  font-family: var(--font-ui);

  font-size: 0.8rem;

  line-height: 1.68;

  color: var(--color-text-secondary);

}





/* =============================================================================

   STATS BAND

   ============================================================================= */

.mzr-stats {

  background-color: var(--color-surface);

  border-top: 1px solid var(--color-rule);

  border-bottom: 1px solid var(--color-rule);

  padding-block: 3rem;

}



.mzr-stats__grid {

  display: grid;

  grid-template-columns: repeat(4, 1fr);

  border: 1px solid var(--color-border);

  border-radius: 10px;

  overflow: hidden;

}



.mzr-stat-item {

  padding: 2rem 1.75rem;

  border-right: 1px solid var(--color-border);

  background-color: var(--color-surface);

}



.mzr-stat-item:last-child {

  border-right: none;

}



.mzr-stat-item__number {

  font-family: var(--font-display);

  font-size: 2.5rem;

  font-weight: 700;

  color: var(--color-text-primary);

  letter-spacing: -0.025em;

  line-height: 1;

}



.mzr-stat-item__label {

  font-family: var(--font-ui);

  font-size: 0.68rem;

  font-weight: 600;

  letter-spacing: 0.09em;

  text-transform: uppercase;

  color: var(--color-text-muted);

  margin-top: 0.4rem;

}





/* =============================================================================

   CTA / NEWSLETTER SECTION

   ============================================================================= */

.mzr-cta {

  padding-block: var(--space-xl);

}



.mzr-cta__card {

  display: grid;

  grid-template-columns: 1fr 1fr;

  gap: 4rem;

  align-items: center;

  padding: 3.5rem 3rem;

  background-color: var(--color-surface);

  border: 1px solid var(--color-border);

  border-radius: var(--radius-xl);

}



.mzr-cta__heading {

  font-size: clamp(1.5rem, 2.5vw, 1.85rem);

  margin-bottom: 0.6rem;

}



.mzr-cta__subtext {

  max-width: 400px;

}



.mzr-cta__form {

  display: flex;

  flex-direction: column;

  gap: 0.75rem;

}



.mzr-cta__input-row {

  display: flex;

  gap: 0.65rem;

}



.mzr-cta__input {

  flex: 1;

  min-width: 0;

  background-color: var(--color-surface-2);

  border: 1px solid var(--color-border-dark);

  border-radius: var(--radius-md);

  padding: 0.68rem 1rem;

  font-family: var(--font-ui);

  font-size: 0.875rem;

  color: var(--color-text-primary);

  outline: none;

  transition: border-color 0.2s;

}



.mzr-cta__input::placeholder {

  color: var(--color-text-muted);

}



.mzr-cta__input:focus {

  border-color: var(--color-text-secondary);

}



.mzr-cta__note {

  font-family: var(--font-ui);

  font-size: 0.68rem;

  color: var(--color-text-muted);

}





/* =============================================================================

   FOOTER

   ============================================================================= */

.mzr-site-footer {

  border-top: 1px solid var(--color-rule);

  padding-block: 2rem;

}



.mzr-footer {

  display: flex;

  align-items: center;

  justify-content: space-between;

  flex-wrap: wrap;

  gap: 1rem;

}



.mzr-footer__logo {

  font-family: var(--font-display);

  font-size: 1.2rem;

  font-weight: 700;

  color: var(--color-text-primary);

  letter-spacing: -0.01em;

}



.mzr-footer__links {

  display: flex;

  align-items: center;

  gap: 1.5rem;

  flex-wrap: wrap;

}



.mzr-footer__links a {

  font-family: var(--font-ui);

  font-size: 0.73rem;

  color: var(--color-text-muted);

  transition: color 0.2s;

}



.mzr-footer__links a:hover {

  color: var(--color-text-secondary);

}



.mzr-footer__copy {

  font-family: var(--font-ui);

  font-size: 0.68rem;

  color: var(--color-text-muted);

}





/* =============================================================================

   RESPONSIVE — TABLET (max 1024px)

   ============================================================================= */

@media (max-width: 1024px) {

  .mzr-container {

    padding-inline: 1.75rem;

  }



  .mzr-hero__inner {

    gap: 2.5rem;

    padding-block: 4rem 3.5rem;

  }



  .mzr-cta__card {

    gap: 2.5rem;

    padding: 2.5rem 2rem;

  }



  .mzr-stats__grid {

    grid-template-columns: repeat(2, 1fr);

  }



  .mzr-stat-item:nth-child(2) {

    border-right: none;

  }



  .mzr-stat-item:nth-child(3) {

    border-top: 1px solid var(--color-border);

    border-right: 1px solid var(--color-border);

  }



  .mzr-stat-item:nth-child(4) {

    border-top: 1px solid var(--color-border);

    border-right: none;

  }

}





/* =============================================================================

   RESPONSIVE — MOBILE (max 768px)

   ============================================================================= */

@media (max-width: 768px) {

  :root {

    --space-xl: 3rem;

  }



  .mzr-container {

    padding-inline: 1.25rem;

  }



  /* Nav */

  .mzr-nav__links,

  .mzr-nav__actions {

    display: none;

  }



  .mzr-nav__hamburger {

    display: flex;

  }



  /* Hero */

  .mzr-hero__inner {

    grid-template-columns: 1fr;

    gap: 2.5rem;

    padding-block: 3rem 2.5rem;

  }



  .mzr-hero__heading {

    font-size: clamp(2.2rem, 8vw, 3rem);

  }



  .mzr-hero__meta {

    gap: 1rem;

  }



  /* Card grids */

  .mzr-card-grid {

    grid-template-columns: 1fr;

  }



  .mzr-tut-grid {

    grid-template-columns: 1fr;

  }



  /* Stats */

  .mzr-stats__grid {

    grid-template-columns: 1fr 1fr;

    border-radius: var(--radius-md);

  }



  .mzr-stat-item {

    padding: 1.25rem 1rem;

  }



  /* CTA */

  .mzr-cta__card {

    grid-template-columns: 1fr;

    gap: 2rem;

    padding: 2rem 1.5rem;

  }



  .mzr-cta__input-row {

    flex-direction: column;

  }



  .mzr-cta__input-row .mzr-btn {

    width: 100%;

    justify-content: center;

  }



  /* Footer */

  .mzr-footer {

    flex-direction: column;

    align-items: flex-start;

    gap: 1rem;

  }



  .mzr-footer__links {

    gap: 1rem;

  }



  /* Partners */

  .mzr-partners__inner {

    gap: 1rem;

    justify-content: flex-start;

  }



  /* Section row */

  .mzr-section__row {

    align-items: flex-start;

  }

}





/* =============================================================================

   RESPONSIVE — SMALL MOBILE (max 480px)

   ============================================================================= */

@media (max-width: 480px) {

  .mzr-hero__actions {

    flex-direction: column;

    align-items: stretch;

  }



  .mzr-hero__actions .mzr-btn {

    justify-content: center;

  }



  .mzr-stats__grid {

    grid-template-columns: 1fr;

  }



  .mzr-stat-item {

    border-right: none;

    border-bottom: 1px solid var(--color-border);

  }



  .mzr-stat-item:last-child {

    border-bottom: none;

  }



  .mzr-stat-item:nth-child(3) {

    border-right: none;

  }

}







/* =============================================================================

   MANZARI — Single Post Stylesheet

   File: single-post.css  (or append to manzari-style.css)

   Applies to: single.php / single post template

   Depends on: manzari-style.css (design tokens must be loaded first)

   ============================================================================= */





/* -----------------------------------------------------------------------------

   1. SINGLE POST WRAPPER

   ----------------------------------------------------------------------------- */

.mzr-single {

  max-width: 720px;

  margin-inline: auto;

  padding-block: var(--space-xl);   /* 4.5rem — matches all homepage sections  */

  padding-inline: 2.5rem;           /* matches .mzr-container horizontal rhythm */

}





/* -----------------------------------------------------------------------------

   2. POST HEADER

   ----------------------------------------------------------------------------- */

.mzr-single__header {

  margin-bottom: 2.5rem;

  padding-bottom: 2.5rem;

  border-bottom: 1px solid var(--color-rule);

}



/* Eyebrow row — category + read time */

.mzr-single__meta {

  display: flex;

  align-items: center;

  gap: 0.65rem;

  margin-bottom: 1.25rem;

}



.mzr-single__category {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  font-weight: 700;

  letter-spacing: 0.14em;

  text-transform: uppercase;

  color: var(--color-text-muted);

}



.mzr-single__meta-dot {

  width: 3px;

  height: 3px;

  border-radius: 50%;

  background-color: var(--color-border-dark);

  flex-shrink: 0;

}



.mzr-single__read-time {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  color: var(--color-text-muted);

}



.mzr-single__date {

  font-family: var(--font-ui);

  font-size: 0.62rem;

  color: var(--color-text-muted);

}



/* Post title */

.mzr-single__title {

  font-family: var(--font-display);

  font-size: clamp(2rem, 4vw, 3rem);

  font-weight: 700;

  letter-spacing: -0.025em;

  line-height: 1.07;

  color: var(--color-text-primary);

  margin-bottom: 1.25rem;

}



/* Post intro / excerpt */

.mzr-single__intro {

  font-family: var(--font-ui);

  font-size: 1.05rem;

  font-weight: 400;

  line-height: 1.75;

  color: var(--color-text-secondary);

  max-width: 65ch;

}





/* -----------------------------------------------------------------------------

   3. POST BODY CONTENT

   The .mzr-single__content wrapper goes around the_content()

   ----------------------------------------------------------------------------- */

.mzr-single__content {

  margin-bottom: 3rem;

}



/* Paragraphs */

.mzr-single__content p {

  font-family: var(--font-ui);

  font-size: 0.9375rem;

  font-weight: 400;

  line-height: 1.78;

  color: var(--color-text-secondary);

  max-width: 65ch;

  margin-bottom: 1.5rem;

}



.mzr-single__content p:last-child {

  margin-bottom: 0;

}



/* Headings inside content */

.mzr-single__content h2 {

  font-family: var(--font-display);

  font-size: clamp(1.5rem, 2.5vw, 1.85rem);

  font-weight: 700;

  letter-spacing: -0.02em;

  line-height: 1.15;

  color: var(--color-text-primary);

  margin-top: 2.5rem;

  margin-bottom: 0.875rem;

}



.mzr-single__content h3 {

  font-family: var(--font-display);

  font-size: clamp(1.2rem, 2vw, 1.4rem);

  font-weight: 700;

  letter-spacing: -0.01em;

  line-height: 1.2;

  color: var(--color-text-primary);

  margin-top: 2rem;

  margin-bottom: 0.75rem;

}



.mzr-single__content h4 {

  font-family: var(--font-ui);

  font-size: 0.9rem;

  font-weight: 700;

  letter-spacing: 0.06em;

  text-transform: uppercase;

  color: var(--color-text-secondary);

  margin-top: 1.75rem;

  margin-bottom: 0.6rem;

}



/* Links inside content */

.mzr-single__content a {

  color: var(--color-text-primary);

  text-decoration: underline;

  text-underline-offset: 3px;

  text-decoration-color: var(--color-border-dark);

  transition: text-decoration-color 0.2s;

}



.mzr-single__content a:hover {

  text-decoration-color: var(--color-text-primary);

}



/* Strong / bold */

.mzr-single__content strong {

  font-weight: 600;

  color: var(--color-text-primary);

}



/* Italic */

.mzr-single__content em {

  font-family: var(--font-display);

  font-style: italic;

  font-size: 1.05em;

}



/* Unordered lists */

.mzr-single__content ul {

  list-style: none;

  margin-bottom: 1.5rem;

  display: flex;

  flex-direction: column;

  gap: 0.5rem;

  max-width: 65ch;

}



.mzr-single__content ul li {

  font-family: var(--font-ui);

  font-size: 0.9375rem;

  line-height: 1.7;

  color: var(--color-text-secondary);

  padding-left: 1.25rem;

  position: relative;

}



.mzr-single__content ul li::before {

  content: '';

  position: absolute;

  left: 0;

  top: 0.65em;

  width: 5px;

  height: 1px;

  background-color: var(--color-border-dark);

}



/* Ordered lists */

.mzr-single__content ol {

  list-style: none;

  counter-reset: mzr-counter;

  margin-bottom: 1.5rem;

  display: flex;

  flex-direction: column;

  gap: 0.5rem;

  max-width: 65ch;

}



.mzr-single__content ol li {

  font-family: var(--font-ui);

  font-size: 0.9375rem;

  line-height: 1.7;

  color: var(--color-text-secondary);

  padding-left: 1.75rem;

  position: relative;

  counter-increment: mzr-counter;

}



.mzr-single__content ol li::before {

  content: counter(mzr-counter);

  position: absolute;

  left: 0;

  top: 0;

  font-family: var(--font-display);

  font-size: 0.9rem;

  font-weight: 700;

  color: var(--color-text-muted);

  line-height: 1.7;

}



/* Blockquote */

.mzr-single__content blockquote {

  margin-block: 2rem;

  padding: 1.5rem 1.75rem;

  background-color: var(--color-surface);

  border: 1px solid var(--color-border);

  border-left: 3px solid var(--color-text-primary);

  border-radius: 0 var(--radius-md) var(--radius-md) 0;

}



.mzr-single__content blockquote p {

  font-family: var(--font-display);

  font-size: clamp(1.1rem, 2vw, 1.3rem);

  font-style: italic;

  font-weight: 400;

  line-height: 1.5;

  color: var(--color-text-primary);

  margin-bottom: 0;

  max-width: none;

}



.mzr-single__content blockquote cite {

  display: block;

  font-family: var(--font-ui);

  font-size: 0.72rem;

  font-weight: 600;

  font-style: normal;

  letter-spacing: 0.08em;

  text-transform: uppercase;

  color: var(--color-text-muted);

  margin-top: 0.75rem;

}



/* Inline code */

.mzr-single__content code {

  font-family: 'Courier New', Courier, monospace;

  font-size: 0.82rem;

  background-color: var(--color-surface-3);

  color: var(--color-text-primary);

  padding: 0.15rem 0.4rem;

  border-radius: var(--radius-sm);

  border: 1px solid var(--color-border);

}



/* Code block */

.mzr-single__content pre {

  background-color: var(--color-text-primary);

  color: var(--color-bg);

  padding: 1.5rem;

  border-radius: var(--radius-md);

  overflow-x: auto;

  margin-block: 1.75rem;

  font-size: 0.82rem;

  line-height: 1.7;

}



.mzr-single__content pre code {

  background: none;

  border: none;

  padding: 0;

  color: inherit;

  font-size: inherit;

}



/* Images */

.mzr-single__content img {

  width: 100%;

  height: auto;

  border-radius: var(--radius-md);

  border: 1px solid var(--color-border);

  margin-block: 1.75rem;

}



/* Horizontal rule */

.mzr-single__content hr {

  border: none;

  height: 1px;

  background-color: var(--color-rule);

  margin-block: 2.5rem;

}





/* -----------------------------------------------------------------------------

   4. POST FOOTER — tags, author, share

   ----------------------------------------------------------------------------- */

.mzr-single__footer {

  padding-top: 2.5rem;

  border-top: 1px solid var(--color-rule);

  display: flex;

  align-items: center;

  justify-content: space-between;

  flex-wrap: wrap;

  gap: 1rem;

}



.mzr-single__tags {

  display: flex;

  align-items: center;

  gap: 0.5rem;

  flex-wrap: wrap;

}



.mzr-single__tag {

  font-family: var(--font-ui);

  font-size: 0.6rem;

  font-weight: 700;

  letter-spacing: 0.1em;

  text-transform: uppercase;

  color: var(--color-tag-text);

  background-color: var(--color-tag-bg);

  padding: 0.2rem 0.55rem;

  border-radius: var(--radius-sm);

  text-decoration: none;

  transition: background-color 0.2s;

}



.mzr-single__tag:hover {

  background-color: var(--color-surface-3);

}



.mzr-single__back {

  font-family: var(--font-ui);

  font-size: 0.73rem;

  font-weight: 600;

  color: var(--color-text-secondary);

  text-decoration: none;

  display: inline-flex;

  align-items: center;

  gap: 0.35rem;

  transition: color 0.2s, gap 0.15s;

}



.mzr-single__back:hover {

  color: var(--color-text-primary);

  gap: 0.55rem;

}





/* -----------------------------------------------------------------------------

   5. RELATED POSTS (optional — same grid pattern as tutorials section)

   ----------------------------------------------------------------------------- */

.mzr-single__related {

  margin-top: var(--space-xl);

  padding-top: var(--space-xl);

  border-top: 1px solid var(--color-rule);

}



.mzr-single__related-heading {

  font-family: var(--font-display);

  font-size: clamp(1.5rem, 2.5vw, 1.85rem);

  font-weight: 700;

  letter-spacing: -0.02em;

  color: var(--color-text-primary);

  margin-bottom: 2rem;

}





/* =============================================================================

   RESPONSIVE — TABLET (max 1024px)

   ============================================================================= */

@media (max-width: 1024px) {

  .mzr-single {

    padding-inline: 1.75rem;

  }

}





/* =============================================================================

   RESPONSIVE — MOBILE (max 768px)

   ============================================================================= */

@media (max-width: 768px) {

  .mzr-single {

    padding-block: var(--space-lg);  /* 2.5rem */

    padding-inline: 1.25rem;

  }



  .mzr-single__content p,

  .mzr-single__content ul,

  .mzr-single__content ol {

    max-width: none;  /* full width on mobile — 65ch too narrow on small screens */

  }



  .mzr-single__content blockquote {

    padding: 1.25rem;

  }



  .mzr-single__footer {

    flex-direction: column;

    align-items: flex-start;

  }

}





/* =============================================================================

   RESPONSIVE — SMALL MOBILE (max 480px)

   ============================================================================= */

@media (max-width: 480px) {

  .mzr-single {

    padding-inline: 1rem;

  }



  .mzr-single__content pre {

    padding: 1rem;

    font-size: 0.78rem;

  }

}




/* =============================================================================

   MANZARI — Category Archive Additions

   File: append to manzari-style.css (or load as separate stylesheet)

   All NEW classes — nothing existing is overridden.

   ============================================================================= */





/* -----------------------------------------------------------------------------

   ARCHIVE WRAPPER

   ----------------------------------------------------------------------------- */

.mzr-archive {

  padding-block: var(--space-xl);

}





/* -----------------------------------------------------------------------------

   ARCHIVE HEADER

   ----------------------------------------------------------------------------- */

.mzr-archive__header {

  max-width: 600px;

  margin-bottom: 3rem;

  padding-bottom: 3rem;

  border-bottom: 1px solid var(--color-rule);

}



.mzr-archive__eyebrow {

  margin-bottom: 0.75rem;

}



.mzr-archive__title {

  font-family: var(--font-display);

  font-size: clamp(2rem, 4vw, 2.75rem);

  font-weight: 700;

  letter-spacing: -0.025em;

  line-height: 1.07;

  color: var(--color-text-primary);

  margin-bottom: 0.75rem;

}



.mzr-archive__description {

  font-family: var(--font-ui);

  font-size: 0.9375rem;

  line-height: 1.75;

  color: var(--color-text-secondary);

  max-width: 55ch;

  margin-bottom: 0.75rem;

}



.mzr-archive__count {

  font-family: var(--font-ui);

  font-size: 0.72rem;

  color: var(--color-text-muted);

  margin-bottom: 0;

}



.mzr-archive__count strong {

  font-weight: 600;

  color: var(--color-text-secondary);

}





/* -----------------------------------------------------------------------------

   TUTORIAL CARD — FEATURED IMAGE

   New additions to existing mzr-tut-card for archive context.

   ----------------------------------------------------------------------------- */

.mzr-tut-card__image-link {

  display: block;

  overflow: hidden;

  border-radius: var(--radius-md);

  margin-bottom: 1rem;

  border: 1px solid var(--color-border);

}



.mzr-tut-card__image {

  width: 100%;

  height: auto;

  display: block;

  aspect-ratio: 16 / 9;

  object-fit: cover;

  transition: transform 0.3s ease;

}



.mzr-tut-card:hover .mzr-tut-card__image {

  transform: scale(1.02);

}





/* -----------------------------------------------------------------------------

   PAGINATION

   ----------------------------------------------------------------------------- */

.mzr-pagination {

  margin-top: 3rem;

  padding-top: 2.5rem;

  border-top: 1px solid var(--color-rule);

  display: flex;

  justify-content: center;

}



/* WordPress outputs a <ul> from paginate_links( type => 'list' ) */

.mzr-pagination ul {

  display: flex;

  align-items: center;

  gap: 0.35rem;

  list-style: none;

}



.mzr-pagination ul li a,

.mzr-pagination ul li span {

  display: inline-flex;

  align-items: center;

  justify-content: center;

  min-width: 36px;

  height: 36px;

  padding-inline: 0.5rem;

  font-family: var(--font-ui);

  font-size: 0.78rem;

  font-weight: 500;

  color: var(--color-text-secondary);

  background-color: var(--color-surface);

  border: 1px solid var(--color-border);

  border-radius: var(--radius-md);

  text-decoration: none;

  transition: background-color 0.2s, border-color 0.2s, color 0.2s;

}



.mzr-pagination ul li a:hover {

  color: var(--color-text-primary);

  border-color: var(--color-border-dark);

  background-color: var(--color-surface-2);

}



/* Current page */

.mzr-pagination ul li span.current {

  background-color: var(--color-btn-bg);

  color: var(--color-btn-text);

  border-color: var(--color-btn-bg);

  font-weight: 600;

}



/* Prev / Next text links */

.mzr-pagination ul li:first-child a,

.mzr-pagination ul li:last-child a {

  min-width: auto;

  padding-inline: 0.875rem;

  font-weight: 600;

}



/* Dots separator */

.mzr-pagination ul li span.dots {

  background: transparent;

  border-color: transparent;

  color: var(--color-text-muted);

  cursor: default;

}





/* -----------------------------------------------------------------------------

   EMPTY STATE

   ----------------------------------------------------------------------------- */

.mzr-archive__empty {

  padding-block: var(--space-xl);

  display: flex;

  flex-direction: column;

  align-items: flex-start;

  gap: 1.5rem;

}



.mzr-archive__empty-text {

  font-family: var(--font-ui);

  font-size: 0.9375rem;

  color: var(--color-text-secondary);

}





/* -----------------------------------------------------------------------------

   RESPONSIVE

   ----------------------------------------------------------------------------- */

@media (max-width: 1024px) {

  .mzr-archive {

    padding-block: var(--space-lg);

  }

}



@media (max-width: 768px) {

  .mzr-archive__header {

    margin-bottom: 2rem;

    padding-bottom: 2rem;

  }



  .mzr-pagination ul {

    gap: 0.25rem;

  }



  .mzr-pagination ul li a,

  .mzr-pagination ul li span {

    min-width: 32px;

    height: 32px;

    font-size: 0.72rem;

  }

}



@media (max-width: 480px) {

  .mzr-pagination ul li:not(:first-child):not(:last-child):not(.current) {

    display: none;

  }

}
