/* assets/css/app.css (FULL FIXED)
   - Fixes broken braces
   - Removes duplicate/contradictory mobile header/nav rules
   - Fixes single calculator layout order (main first on mobile, sidebars below)
   - Fixes right-side cut off (real overflow guards + min-width fixes)
*/

/* =======================================
   THEME TOKENS
======================================= */
:root{
  --bg:#ffffff;
  --surface:#ffffff;
  --card:#ffffff;

  --text:#0b1220;
  --muted:#556274;

  --border:rgba(15,23,42,.12);

  --primary:#e11d48;
  --primary-2:#be123c;

  --radius:18px;
  --shadow:0 14px 30px rgba(2,6,23,.08);

  --max:1450px;
}

:root[data-theme="dark"]{
  --bg:#0b0d10;
  --surface:#0f141b;
  --card:rgba(255,255,255,.04);

  --text:#e9eef5;
  --muted:#a9b4c2;

  --border:rgba(255,255,255,.12);

  --primary:#fb7185;
  --primary-2:#f43f5e;

  --shadow:0 16px 40px rgba(0,0,0,.45);
}

/* =======================================
   BASE
======================================= */
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }

/* Safer overflow handling (prevents horizontal cut-off without hiding legit scroll too aggressively) */
html{ overflow-x: clip; }
body{ overflow-x: hidden; }

body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.55;
}

a{ color:inherit; }
a:hover{ color:var(--primary); }
.mc-sr-only{ position:absolute; left:-9999px; }

/* Focus */
.mc-btn:focus-visible,
.mc-nav__menu a:focus-visible,
.mc-app-banner__link:focus-visible,
.mc-calc-card__link:focus-visible,
.mc-fab-theme:focus-visible{
  outline: 3px solid color-mix(in srgb, var(--primary) 40%, transparent);
  outline-offset: 3px;
  border-radius: 12px;
}

/* =======================================
   SITE LAYOUT
======================================= */
.mc-site{ min-height:100vh; display:flex; flex-direction:column; }
.mc-footer{ margin-top:100px; }

.mc-container, .mc-home{
  width: min(var(--max), calc(100% - 40px));
  margin-inline: auto;
}

.mc-page{
  width: min(calc(var(--max) * 0.8), calc(100% - 32px));
  margin-inline: auto;
}

/* Surface helper */
.mc-surface{
  /* border:1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  box-shadow: var(--shadow); */
}

/* Readability */
.mc-content-surface{
  max-width: 900px;
  margin: 0 auto;
}
.mc-content-surface p,
.mc-content-surface li{
  max-width: 75ch;
}

.mc-loadmore-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  margin: 18px 0 40px;
}

/* =======================================
   HEADER (single source of truth)
   Desktop: logo | nav | actions
   Mobile: burger | logo | actions (nav hidden, uses drawer)
======================================= */
.mc-header{
  top: 0;
  z-index: 50;
  border-bottom:1px solid var(--border);
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  backdrop-filter: blur(10px);
}

.mc-header__inner{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:14px;
  padding:14px 0;
}

.mc-brand{
  justify-self:start;
  display:flex;
  align-items:center;
  gap:10px;
}

.mc-brand__link{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  font-weight:900;
}

.mc-brand img.custom-logo{
  width:auto;
  height: 80px;
  max-height: 100px;
  display:block;
}

/* Desktop nav only */
.mc-nav{
  display:none;
  justify-self:center;
}
@media (min-width: 960px){
  .mc-nav{ display:block; }
}

.mc-nav__menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:18px;
  align-items:center;
}

.mc-nav__menu a{
  text-decoration:none;
  opacity:.88;
  font-size: 16px;
  font-weight: 800;
  letter-spacing: .2px;
}
.mc-nav__menu a:hover{ opacity:1; }

/* Desktop active underline */
.mc-nav__menu > li > a{
  position: relative;
  padding: 10px 2px;
  text-decoration: none;
}

.mc-nav__menu > li.current-menu-item > a::after,
.mc-nav__menu > li.current-menu-ancestor > a::after{
  content:"";
  position:absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 3px;
  border-radius: 3px;
  background: var(--primary);
}

.mc-header__actions{
  justify-self:end;
  display:flex;
  gap:10px;
  align-items:center;
}

/* Hamburger only on mobile */
.mc-nav__toggle{ display:inline-grid; }
@media (min-width: 960px){
  .mc-nav__toggle{ display:none; }
}

/* Mobile header layout */
@media (max-width: 959px){
  .mc-header__inner{
    grid-template-columns: auto 1fr auto; /* burger | logo | actions */
    align-items:center;
    gap: 10px;
    padding: 12px 0;
  }

  .mc-brand{ justify-self:center; }
  .mc-header__actions{ justify-self:end; }

  .mc-brand img.custom-logo{
    height: 30px;
    max-height: 30px;
  }

  /* IMPORTANT: keep desktop menu hidden on mobile */
  .mc-nav{ display:none !important; }
}

/* =======================================
   BUTTON SYSTEM (GLOBAL)
======================================= */
.mc-btn,
button.mc-btn,
input[type="submit"].mc-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background: transparent;
  color: var(--text);
  text-decoration:none;
  font-weight:900;
  font-size:14px;
  white-space:nowrap;
  cursor:pointer;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
}

.mc-btn:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
}

.mc-btn:disabled,
.mc-btn[aria-disabled="true"]{
  opacity:.6;
  cursor:not-allowed;
  transform:none;
}

.mc-btn--primary{
  background: var(--primary);
  color: #fff;
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
  width: 100%;
  max-width: 520px;
  min-width: 0;
  padding: 14px 18px;
  font-size: 15px;
  border-radius: 16px;
}
.mc-btn--primary:hover{
  background: var(--primary-2);
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
}

.mc-btn--secondary{
  background: transparent;
  color: var(--text);
  border-color: var(--border);
}
.mc-btn--secondary:hover{
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 10%, transparent);
}

/* =======================================
   SEARCH OVERLAY + FAB
======================================= */
.mc-search-overlay{
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 16px;
  background: rgba(0,0,0,.38);
  backdrop-filter: blur(6px);
  opacity: 1;
  pointer-events: auto;
}

.mc-search-overlay[hidden]{ display: none !important; }

.mc-search-panel{
  width: min(760px, calc(100% - 28px));
  margin: 90px auto 0;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: 0 22px 70px rgba(2,6,23,.18);
  animation: mcSearchIn .16s ease both;
}

@keyframes mcSearchIn{
  from { transform: translateY(6px); opacity: 0; }
  to   { transform: translateY(0);   opacity: 1; }
}

.mc-search-input{
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--border) 55%, transparent);
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  color: var(--text);
  outline: none;
}
.mc-search-input:focus{
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 16%, transparent);
}

.mc-search-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: transparent;
  text-decoration:none;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.mc-search-item:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--primary) 20%, var(--border));
  background: color-mix(in srgb, var(--primary) 8%, transparent);
}

.mc-icon-btn{
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--border) 65%, transparent);
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  cursor: pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.mc-icon-btn:hover{
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--primary) 30%, var(--border));
  background: color-mix(in srgb, var(--primary) 8%, var(--bg));
}

.mc-fab{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 999999;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 800;
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: 0 12px 30px rgba(0,0,0,.18);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform .12s ease;
}
.mc-fab:hover{ transform: translateY(-1px); }
.mc-fab:active{ transform: translateY(0px); }
.mc-fab--search{ bottom: 86px; }

/* =======================================
   APP BANNER
======================================= */
.mc-app-banner{
  width:100%;
  background: var(--surface);
  color: var(--text);
  border-top:1px solid var(--border);
}

.mc-app-banner__link{ display:block; text-decoration:none; color:inherit; }

.mc-app-banner__content{
  width:min(var(--max), calc(100% - 32px));
  margin:0 auto;
  padding:22px 0;
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:space-between;
}

.mc-app-banner__title{
  font-size:18px;
  font-weight:900;
  line-height:1.2;
}

.mc-app-banner__sub{
  font-size:14px;
  opacity:.85;
  margin-top:6px;
}

.mc-app-banner__media{
  display:flex;
  gap:10px;
  align-items:center;
}

.mc-app-banner__img{
  width:92px;
  height:auto;
  border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.15);
}

.mc-app-banner__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  background: var(--primary);
  color:#fff;
  font-weight:900;
  white-space:nowrap;
}
.mc-app-banner__cta:hover{ background: var(--primary-2); }

@media (max-width: 959px){
  .mc-app-banner__content{
    flex-direction:column;
    align-items:flex-start;
    padding:18px 0;
  }
  .mc-app-banner__media{
    width:100%;
    overflow:auto;
    padding-bottom:4px;
  }
}

/* =======================================
   HOME: Calculator Grid
======================================= */
.mc-home{ padding: 28px 0 70px; }

.mc-home__header{
  padding: 18px 0 24px;
  text-align:center;
  margin-top:14px;
}

.mc-calc-grid{
  display:grid;
  gap:22px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (min-width: 900px){
  .mc-calc-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1200px){
  .mc-calc-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.mc-calc-card{
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--surface);
  box-shadow: var(--shadow);
  overflow:hidden;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  min-height: 190px;
}
.mc-calc-card:hover{
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
  box-shadow: 0 10px 26px rgba(0,0,0,.12);
}

.mc-calc-card__link{
  display:flex;
  flex-direction:column;
  height:100%;
  text-decoration:none;
  color:inherit;
}

.mc-calc-card__thumb{
  flex: 1 1 auto;
  min-height: 140px;
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.mc-calc-card__thumb img{
  width: 100%;
  height: 100%;
  max-height: 120px;
  object-fit: contain;
  display:block;
}

.mc-calc-card__fallback{
  width:72px;
  height:72px;
  border-radius:18px;
  display:grid;
  place-items:center;
  font-weight:900;
  border:1px solid var(--border);
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  color: var(--text);
}

.mc-calc-card__title{
  margin:0;
  padding: 10px 14px 16px;
  text-align:center;
  font-size:16px;
  font-weight:800;
  line-height:1.25;
  color: color-mix(in srgb, var(--text) 72%, transparent);
}

@media (max-width: 520px){
  .mc-calc-grid{ gap:16px; }
  .mc-calc-card{ min-height: 175px; }
  .mc-calc-card__thumb{ min-height: 125px; padding: 14px; }
  .mc-calc-card__thumb img{ max-height: 105px; }
}

/* =======================================
   BLOG GRID
======================================= */
.mc-blog{ padding: 26px 0 70px; }

.mc-blog__header{
  padding: 10px 0 22px;
  text-align:center;
}

.mc-blog__title{
  margin:0;
  font-size: clamp(26px, 2.6vw, 42px);
  letter-spacing: -.03em;
}
h1.mc-calc__title {
    margin: 0 0 0 0;
    font-size: clamp(26px, 2.6vw, 42px);
    letter-spacing: -.03em;
    text-align: center;
}

.mc-blog__sub{ margin: 8px 0 0; color: var(--muted); }

.mc-post-grid{
  display:grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap:18px;
}
@media (min-width: 760px){
  .mc-post-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1100px){
  .mc-post-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.mc-post-card{
  border:1px solid var(--border);
  border-radius: 14px;
  background: var(--surface);
  overflow:hidden;
  box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.mc-post-card:hover{
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
  box-shadow: 0 10px 26px rgba(0,0,0,.12);
}

.mc-post-card__link{ display:block; text-decoration:none; color:inherit; }

.mc-post-card__media{
  aspect-ratio: 16 / 9;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  overflow:hidden;
}
.mc-post-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.mc-post-card__body{ padding: 14px 14px 16px; }

.mc-post-card__title{
  margin: 0 0 6px;
  font-size: 16px;
  line-height: 1.25;
  font-weight: 900;
  letter-spacing: -.01em;
  color: color-mix(in srgb, var(--text) 78%, transparent);
}

.mc-post-card__date{
  display:block;
  font-size:12px;
  color: color-mix(in srgb, var(--muted) 85%, transparent);
}

.mc-pagination{
  margin-top: 22px;
  display:flex;
  justify-content:center;
}
.mc-pagination .page-numbers{
  display:inline-flex;
  gap:8px;
  align-items:center;
}
.mc-pagination a.page-numbers,
.mc-pagination span.page-numbers{
  padding: 8px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  text-decoration:none;
  color: var(--text);
}
.mc-pagination span.current{
  background: var(--primary);
  color:#fff;
  border-color: transparent;
}

/* =======================================
   FOOTER
======================================= */
.mc-footer__bottom{
  background: var(--surface);
  color: var(--text);
  border-top:1px solid var(--border);
}

.mc-footer__bottom-inner{
  padding:16px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

.mc-footer__copy{ font-size:13px; opacity:.78; }
.mc-footer__note{ font-size: 13px; opacity: .78; }

.mc-footer__menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  align-items:center;
}

.mc-footer__menu a{
  text-decoration:none;
  font-size:13px;
  opacity:.82;
}
.mc-footer__menu a:hover{ opacity:1; color: var(--primary); }

@media (max-width: 720px){
  .mc-footer__bottom-inner{ justify-content:center; text-align:center; }
  .mc-footer__menu{ justify-content:center; }
}

/* =======================================
   SINGLE CALCULATOR LAYOUT (RESPONSIVE + ORDER)
======================================= */
.mc-single{ padding:22px 0 70px; }

/* Grid container */
.mc-layout{
  display:grid;
  gap:16px;
  align-items:start;
  width:100%;
  margin-top:14px;
  min-width:0;
}

/* Area hooks from your PHP */
.mc-layout__left  { grid-area: left; }
.mc-layout__main  { grid-area: main; min-width:0; }
.mc-layout__right { grid-area: right; }

/* Desktop columns */
.mc-layout.has-left.has-right{
  grid-template-columns: 15% minmax(0, 70%) 15%;
  grid-template-areas: "left main right";
}
.mc-layout.has-left:not(.has-right){
  grid-template-columns: 15% minmax(0, 85%);
  grid-template-areas: "left main";
}
.mc-layout.has-right:not(.has-left){
  grid-template-columns: minmax(0, 85%) 15%;
  grid-template-areas: "main right";
}
.mc-layout:not(.has-left):not(.has-right){
  grid-template-columns: 1fr;
  grid-template-areas: "main";
}

/* Sidebar */
.mc-sidebar{
  align-self:start;
  position: sticky;
  top: 86px;
  max-height: calc(100vh - 96px);
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-width:0;
}
.mc-sidebar *{ max-width:100%; }
.mc-sidebar table{ width:100%; table-layout:fixed; }

/* Mobile/tablet: stack main then sidebars (below calculator) */
@media (max-width: 1200px){
  .mc-layout{
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "main"
      "left"
      "right";
  }

  .mc-sidebar{
    position: static;
    top: auto;
    max-height:none;
    overflow:visible;
  }
}

/* =======================================
   RESPONSIVE OVERFLOW FIXES (CALCULATORS)
   This prevents "right side cut off"
======================================= */
.mc-container,
.mc-layout,
.mc-layout__main,
.mc-sidebar{ min-width:0; }

.mc-layout__main{ overflow: visible; }

/* Stop any calculator UI from exceeding viewport */
.mc-calc{ width:100%; max-width:100%; }
.mc-calc *{ max-width:100%; }

/* Sliders are common overflow offenders */
.mc-calc input[type="range"]{
  width:100% !important;
  max-width:100% !important;
  display:block;
}

/* Inputs/select/buttons */
.mc-calc input,
.mc-calc select,
.mc-calc textarea,
.mc-calc button{
  max-width:100%;
}

/* =======================================
   MOBILE NAV (DRAWER)
======================================= */
.mc-mobile-nav{
  position: fixed;
  inset: 0;
  z-index: 90;
  background: rgba(0,0,0,.38);
  backdrop-filter: blur(6px);
}

.mc-mobile-nav__panel{
  width: min(520px, calc(100% - 28px));
  margin: 74px auto 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 14px;
}

.mc-mobile-nav__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 4px 2px 10px;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  margin-bottom: 10px;
}

.mc-mobile-nav__title{
  font-weight: 900;
  letter-spacing: -.01em;
}

.mc-mobile-nav__list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}

.mc-mobile-nav__list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background: color-mix(in srgb, var(--card) 92%, transparent);
  text-decoration:none;
  color:inherit;
  font-weight:800;
}

.mc-mobile-nav__list a:hover{
  border-color: color-mix(in srgb, var(--primary) 45%, var(--border));
}

/* Mobile active */
.mc-mobile-nav__list .current-menu-item > a{
  border-color: var(--primary);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--primary) 25%, transparent);
}

/* =======================================
   FLOATING THEME SWITCH
======================================= */
.mc-fab-theme{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9999;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  box-shadow: var(--shadow);
  cursor:pointer;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.mc-fab-theme:hover{
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
}
.mc-fab-theme:active{ transform: translateY(0); }
.mc-fab-theme__icon{ font-size: 20px; line-height:1; }

/* =======================================
   404 PAGE
======================================= */
.mc-404{ padding: 34px 0 70px; }

.mc-404__wrap{
  border: 1px solid var(--border);
  border-radius: 22px;
  background: color-mix(in srgb, var(--surface) 92%, transparent);
  box-shadow: var(--shadow);
  padding: 22px;
  text-align: center;
  margin-bottom: 22px;
}

.mc-404__badge{
  width: 64px;
  height: 64px;
  border-radius: 18px;
  margin: 0 auto 10px;
  display: grid;
  place-items: center;
  font-weight: 1000;
  letter-spacing: -0.04em;
  background: color-mix(in srgb, var(--primary) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--primary) 38%, var(--border));
  color: var(--primary);
}

.mc-404__title{
  margin: 0;
  font-size: clamp(26px, 2.6vw, 44px);
  letter-spacing: -0.04em;
}

.mc-404__sub{
  margin: 10px auto 0;
  max-width: 62ch;
  color: var(--muted);
}

.mc-404__search{
  margin: 18px auto 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  max-width: 640px;
}

.mc-404__input{
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--text);
  outline: none;
}
.mc-404__input:focus{
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}

.mc-404__btn{
  border-radius: 14px;
  padding: 12px 16px;
}

.mc-404__actions{
  margin-top: 14px;
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

@media (max-width: 640px){
  .mc-404__search{ grid-template-columns: 1fr; }
}

/* =======================================
   SINGLE BLOG POST
======================================= */
.mc-single-post{ padding: 22px 0 70px; }

.mc-single-post__header{
  text-align: center;
  margin: 0 0 14px;
  padding-top: 6px;
}

.mc-single-post__title{
  margin: 0;
  font-size: clamp(26px, 2.7vw, 46px);
  letter-spacing: -.03em;
  line-height: 1.15;
}

.mc-single-post__meta{
  margin-top: 10px;
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 13px;
}

.mc-single-post__thumb{
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  margin: 0 auto 14px;
  max-width: 980px;
}
.mc-single-post__thumb img{
  width: 100%;
  height: auto;
  display: block;
}

.mc-single-post__surface{
  max-width: 980px;
  margin: 0 auto;
}

.mc-single-post__content{ padding: 22px; }

.mc-single-post__content p,
.mc-single-post__content li{
  max-width: 75ch;
}

.mc-single-post__content a{
  color: var(--primary);
  text-decoration: none;
  font-weight: 700;
}
.mc-single-post__content a:hover{ text-decoration: underline; }

.mc-single-post__nav{
  max-width: 980px;
  margin: 14px auto 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.mc-single-post__nav a{
  display: inline-block;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  text-decoration: none;
}
.mc-single-post__nav a:hover{
  border-color: color-mix(in srgb, var(--primary) 55%, var(--border));
  color: var(--primary);
}

@media (max-width: 720px){
  .mc-single-post__nav{ grid-template-columns: 1fr; }
  .mc-single-post__nav-item:last-child{ text-align: left !important; }
}


