/*
Theme Name:   MutedCanvas Theme
Theme URI:    https://mutedcanvas.com
Author:       MutedCanvas
Description:  Quiet, cinematic wall art for modern interiors.
Version:      1.0.2
Requires at least: 6.4
Requires PHP: 8.0
Tested up to: 6.8
Text Domain:  mutedcanvas
*/
:root {
  --cream:#F4F1EC; --fog:#E8E4DC; --ash:#C8C4BA; --slate:#6B6560;
  --charcoal:#2A2724; --ink:#1C1917; --white:#FFFFFF; --dark:#1C1917;
  --gold:#C4972A; --gold-light:#F0E6C8; --gold-dark:#9A7420;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --space-sm:16px; --space-md:24px; --space-lg:40px;
  --space-xl:64px; --space-xxl:96px;
  --container:1200px; --gap:32px;
  --radius:4px; --radius-lg:8px; --radius-pill:100px;
  --transition:0.2s ease;
  --header-h:68px; --header-bg:var(--charcoal);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;transition:color var(--transition);}
button{cursor:pointer;font-family:var(--sans);}
ul,ol{list-style:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);font-weight:600;line-height:1.2;color:var(--ink);}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gap);}
#page { min-height: 100vh; }
#content { flex: 1; }

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition);text-decoration:none;white-space:nowrap;}
.btn-primary{background:var(--charcoal);color:var(--white);}
.btn-primary:hover{background:var(--gold);color:var(--white);}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,0.4);}
.btn-outline:hover{border-color:var(--white);background:rgba(255,255,255,0.08);}
.btn-gold{background:var(--gold);color:var(--white);}
.btn-gold:hover{background:var(--gold-dark);color:var(--white);}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ash);}
.btn-ghost:hover{border-color:var(--charcoal);}

/* Topbar */
/* Sticky nav wrapper — holds topbar + header together */
.mc-nav-wrap {
  position: sticky;
  top: 0;
  z-index: 400;
}
.mc-topbar {
  background: var(--gold);
  color: var(--white);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.03em;
  padding: 10px 0;
  position: relative;
  z-index: 301;
}
.mc-topbar__inner{display:flex;align-items:center;justify-content:center;gap:12px;position:relative;}
.mc-topbar__text{text-align:center;line-height:1.4;}
.mc-topbar a{color:var(--white);text-decoration:underline;}
.mc-topbar__close{position:absolute;right:0;background:none;border:none;color:rgba(255,255,255,0.7);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition);}
.mc-topbar__close:hover{color:var(--white);background:rgba(255,255,255,0.12);}

/* Countdown timer */
.topbar-countdown{display:flex;align-items:center;gap:4px;margin-left:16px;flex-shrink:0;}
.topbar-countdown__unit{display:flex;flex-direction:column;align-items:center;background:rgba(0,0,0,0.2);border-radius:4px;padding:3px 8px;min-width:44px;}
.topbar-countdown__num{font-size:16px;font-weight:900;line-height:1.2;letter-spacing:0.02em;font-family:var(--sans);}
.topbar-countdown__label{font-size:9px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;opacity:0.75;line-height:1;}
.topbar-countdown__sep{font-size:18px;font-weight:900;opacity:0.6;margin-bottom:8px;}
.topbar-countdown.is-expired{display:none;}
@media(max-width:600px){.topbar-countdown__unit{min-width:36px;padding:2px 6px;}.topbar-countdown__num{font-size:14px;}.topbar-countdown{margin-left:8px;}}

/* Header */
.site-header {
  background: var(--charcoal);
  height: var(--header-h);
  position: sticky;
  top: 0;
  z-index: 300;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}


.site-header .container{height:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);}
.site-branding a{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--white);letter-spacing:0.04em;text-decoration:none;display:flex;align-items:center;}
.site-name-canvas{color:var(--gold);}
.primary-nav{display:flex;align-items:center;gap:0;}
.primary-nav ul{display:flex;align-items:center;gap:2px;padding:0;margin:0;}
.primary-nav ul li{position:relative;}
.primary-nav ul li a{display:block;font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.65);padding:8px 12px;border-radius:var(--radius);transition:color var(--transition);}
.primary-nav ul li a:hover,.primary-nav ul li.current-menu-item>a{color:var(--white);}

/* Mega trigger */
.mc-mega-trigger{display:flex;align-items:center;gap:4px;background:none;border:none;font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:rgba(255,255,255,0.65);padding:8px 12px;border-radius:var(--radius);margin:0;-webkit-appearance:none;appearance:none;transition:color var(--transition);white-space:nowrap;cursor:pointer;line-height:1;}
/* Align mega-wrap with nav links via flex-end on nav */
.mc-mega-wrap{display:flex;align-items:center;}
.mc-mega-trigger:hover,.mc-mega-trigger[aria-expanded="true"]{color:var(--white);}
.mc-mega-trigger__arrow{transition:transform 0.2s ease;flex-shrink:0;}
.mc-mega-trigger[aria-expanded="true"] .mc-mega-trigger__arrow{transform:rotate(180deg);}

/* Header actions */
.header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.header-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.65);cursor:pointer;transition:all var(--transition);}
.header-btn:hover{background:rgba(255,255,255,0.16);color:var(--white);}
.mc-cart-btn { position: relative; }
.mc-cart-count {
  position: absolute;
  top: -5px;
  right: -5px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  background: var(--gold);
  color: var(--white);
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 800;
  line-height: 18px;
  text-align: center;
  border-radius: 100px;
  border: 2px solid var(--charcoal);
  pointer-events: none;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.mc-cart-count--pop {
  animation: mc-cart-pop 0.3s ease;
}
@keyframes mc-cart-pop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.45); }
  100% { transform: scale(1); }
}
.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;color:rgba(255,255,255,0.7);cursor:pointer;}

/* Mega panel */
.mc-mega-panel{position:absolute;top:100%;left:0;right:0;z-index:500;background:var(--charcoal);border-top:2px solid var(--gold);box-shadow:0 20px 60px rgba(0,0,0,0.5);opacity:0;transform:translateY(-8px);pointer-events:none;transition:opacity 0.2s ease,transform 0.2s ease;}
.mc-mega-panel.is-open{opacity:1;transform:translateY(0);pointer-events:auto;}
.mc-mega-panel__inner{display:grid;grid-template-columns:220px 1fr;gap:0;padding:36px 0;}
.mc-mega-panel__intro{padding-right:36px;border-right:1px solid rgba(255,255,255,0.08);display:flex;flex-direction:column;gap:10px;}
.mc-mega-panel__label{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);}
.mc-mega-panel__heading{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--white);line-height:1.3;}
.mc-mega-panel__desc{font-size:13px;color:rgba(255,255,255,0.4);line-height:1.6;}
.mc-mega-panel__all{font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold);text-decoration:none;margin-top:8px;transition:color var(--transition);}
.mc-mega-panel__all:hover{color:var(--white);}
.mc-mega-panel__grid{padding-left:36px;display:grid;grid-template-columns:repeat(4,1fr);gap:2px 12px;align-content:start;}
.mc-mega-panel__item{display:block;padding:10px 12px;border-radius:var(--radius);text-decoration:none;transition:background var(--transition);}
.mc-mega-panel__item:hover{background:rgba(255,255,255,0.06);}
.mc-mega-panel__item-name{font-size:13px;font-weight:500;color:rgba(255,255,255,0.75);display:block;line-height:1.4;}
.mc-mega-panel__item-desc{font-size:11px;color:rgba(255,255,255,0.3);margin-top:2px;display:block;}

/* Hero */
.mc-hero{background:var(--charcoal);position:relative;overflow:hidden;min-height:88vh;display:flex;align-items:center;}
.mc-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0.65;}
.mc-hero__overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(28,25,23,0.55) 0%,rgba(28,25,23,0.15) 100%);}
.mc-hero__inner{position:relative;z-index:2;max-width:640px;}
.mc-hero__eyebrow{font-size:11px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:block;}
.mc-hero h1{font-family:var(--serif);font-size:clamp(42px,6vw,80px);font-weight:600;color:var(--white);line-height:1.05;letter-spacing:-0.02em;margin-bottom:20px;}
.mc-hero h1 em{font-style:italic;color:rgba(255,255,255,0.55);}
.mc-hero__sub{font-size:17px;color:rgba(255,255,255,0.55);line-height:1.65;margin-bottom:36px;max-width:480px;}
.mc-hero__actions{display:flex;gap:12px;flex-wrap:wrap;}

/* Section chrome */
.mc-section{padding:var(--space-xl) 0;}
.mc-section--fog{background:var(--fog);}
.mc-section--dark{background:var(--charcoal);}
.mc-section--cream{background:var(--cream);}
.mc-section__head{text-align:center;margin-bottom:var(--space-lg);}
.mc-section__eyebrow{display:inline-block;font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.mc-section__title{font-family:var(--serif);font-size:clamp(26px,3.5vw,42px);font-weight:600;color:var(--ink);line-height:1.15;margin-bottom:12px;}
.mc-section--dark .mc-section__title{color:var(--white);}
.mc-section__sub{font-size:16px;color:var(--slate);max-width:520px;margin:0 auto;line-height:1.7;}
.mc-section--dark .mc-section__sub{color:rgba(255,255,255,0.4);}
.mc-divider{width:36px;height:1px;background:var(--gold);margin:16px auto 0;}

/* Style grid */
.mc-style-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;max-width:var(--container);margin:0 auto;padding:0 var(--gap);}
.mc-style-card{position:relative;overflow:hidden;aspect-ratio:4/5;cursor:pointer;display:block;text-decoration:none;min-height:220px;}
.mc-style-card__img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;background:var(--ash);}
.mc-style-card:hover .mc-style-card__img{transform:scale(1.04);}
.mc-style-card__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(28,25,23,0.85) 0%,transparent 55%);}
.mc-style-card__content{position:absolute;bottom:0;left:0;right:0;padding:20px;}
.mc-style-card__num{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(196,151,42,0.7);margin-bottom:6px;display:block;}
.mc-style-card__name{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--white);line-height:1.2;margin-bottom:8px;}
.mc-style-card__desc{font-size:13px;color:rgba(255,255,255,0.65);line-height:1.55;}
.mc-style-card__link{display:inline-block;margin-top:10px;font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);opacity:0;transform:translateY(4px);transition:all 0.2s ease;}
.mc-style-card:hover .mc-style-card__link{opacity:1;transform:translateY(0);}

/* Why section */
.mc-why{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);align-items:center;}
.mc-why__eyebrow{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:block;}
.mc-why__quote{font-family:var(--serif);font-size:clamp(16px,1.6vw,20px);font-style:italic;font-weight:400;color:rgba(255,255,255,0.45);line-height:1.7;margin-bottom:28px;}
.mc-why__title{font-family:var(--serif);font-size:clamp(28px,2.8vw,42px);font-weight:600;color:var(--white);line-height:1.2;margin-bottom:20px;}
.mc-why__title em{font-style:italic;color:var(--gold);}
.mc-why__body{font-size:14px;color:rgba(255,255,255,0.5);line-height:1.85;margin-bottom:36px;}
.mc-why__pillars{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(255,255,255,0.08);}
.mc-why__pillar{display:flex;align-items:flex-start;gap:20px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,0.08);}
.mc-why__pillar-num{font-family:var(--serif);font-size:13px;font-style:italic;color:var(--gold);flex-shrink:0;width:20px;padding-top:2px;opacity:0.8;}
.mc-why__pillar-name{display:block;font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--white);margin-bottom:4px;}
.mc-why__pillar-desc{font-size:13px;color:rgba(255,255,255,0.45);line-height:1.6;margin:0;}
.mc-why__visual{display:grid;grid-template-columns:1fr 1fr;gap:3px;border-radius:var(--radius);overflow:hidden;min-height:400px;}
.mc-why__visual--image{display:block;}
.mc-why__img{width:100%;height:100%;min-height:400px;object-fit:cover;display:block;border-radius:var(--radius);}
.mc-why__swatch{aspect-ratio:1;}

/* Room grid */
.mc-room-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;}
.mc-room-card{position:relative;overflow:hidden;cursor:pointer;display:block;text-decoration:none;aspect-ratio:4/3;}
.mc-room-card:nth-child(1){grid-column:span 1;}
.mc-room-card:nth-child(7){grid-column:span 1;}
.mc-room-card__img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease;background:var(--ash);}
.mc-room-card:hover .mc-room-card__img{transform:scale(1.06);}
.mc-room-card__label{position:absolute;bottom:0;left:0;right:0;padding:20px 14px 14px;background:linear-gradient(to top,rgba(28,25,23,0.8),transparent);font-family:var(--serif);font-size:15px;font-weight:600;color:var(--white);}

/* Location grid */
.mc-location-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:3px;}
.mc-location-card{position:relative;overflow:hidden;aspect-ratio:4/5;cursor:pointer;display:block;text-decoration:none;border-radius:var(--radius);}
.mc-location-card__img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease;background:var(--ash);}
.mc-location-card:hover .mc-location-card__img{transform:scale(1.05);}
.mc-location-card__label{position:absolute;bottom:0;left:0;right:0;padding:28px 14px 14px;background:linear-gradient(to top,rgba(28,25,23,0.85),transparent);}
.mc-location-card__name{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--white);display:block;}
.mc-location-card__sub{font-size:11px;color:rgba(255,255,255,0.45);letter-spacing:0.08em;text-transform:uppercase;}

/* Collections tabs */
.mc-collections__tabs{display:flex;gap:0;border-bottom:1px solid var(--ash);margin-bottom:var(--space-lg);overflow-x:auto;scrollbar-width:none;}
.mc-collections__tabs::-webkit-scrollbar{display:none;}
.mc-collections__tab{font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--slate);padding:14px 20px;border:none;border-bottom:2px solid transparent;background:none;cursor:pointer;white-space:nowrap;transition:all var(--transition);margin-bottom:-1px;}
.mc-collections__tab:hover{color:var(--ink);}
.mc-collections__tab.is-active{color:var(--ink);border-bottom-color:var(--gold);}
.mc-collections__panel{display:none;}
.mc-collections__panel.is-active{display:block;}
.mc-product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap);}
.mc-product-card{display:flex;flex-direction:column;gap:14px;}
.mc-product-card__img-wrap{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:3/4;background:var(--fog);}
.mc-product-card__img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease;}
.mc-product-card:hover .mc-product-card__img{transform:scale(1.04);}
.mc-product-card__badge{position:absolute;top:12px;left:12px;background:var(--charcoal);color:var(--white);font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:4px 10px;border-radius:var(--radius-pill);}
.mc-product-card__badge--gold{background:var(--gold);}
.mc-product-card__style{font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);margin-bottom:4px;}
.mc-product-card__name{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:6px;}
.mc-product-card__price{font-size:14px;font-weight:600;color:var(--slate);}
.mc-product-card__cta{display:block;text-align:center;padding:10px 20px;font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);background:transparent;border:1px solid var(--ash);border-radius:var(--radius-pill);margin-top:10px;transition:all var(--transition);text-decoration:none;}
.mc-product-card__cta:hover,.mc-product-card:hover .mc-product-card__cta{border-color:var(--charcoal);background:var(--charcoal);color:#fff;}

/* Journal */
.mc-journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);}
.mc-journal-card{display:flex;flex-direction:column;gap:14px;}
.mc-journal-card__img-wrap{overflow:hidden;border-radius:var(--radius);aspect-ratio:16/10;background:var(--fog);}
.mc-journal-card__img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s ease;}
.mc-journal-card:hover .mc-journal-card__img{transform:scale(1.04);}
.mc-journal-card__cat{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);}
.mc-journal-card__title{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink);line-height:1.3;}
.mc-journal-card__excerpt{font-size:14px;color:var(--slate);line-height:1.65;}
.mc-journal-card__link{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink);transition:color var(--transition);}
.mc-journal-card__link:hover{color:var(--gold);}

/* Trade */
.mc-trade{display:grid;grid-template-columns:1fr 1fr;min-height:380px;}
.mc-trade__visual{background:var(--ash);position:relative;overflow:hidden;}
.mc-trade__visual img{width:100%;height:100%;object-fit:cover;}
.mc-trade__visual-placeholder{width:100%;height:100%;min-height:400px;background:var(--fog);}
.mc-trade__content{background:var(--charcoal);padding:var(--space-xl);display:flex;flex-direction:column;justify-content:center;gap:16px;}
.mc-trade__eyebrow{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);}
.mc-trade__title{font-family:var(--serif);font-size:clamp(24px,2.5vw,36px);font-weight:600;color:var(--white);line-height:1.2;}
.mc-trade__body{font-size:15px;color:rgba(255,255,255,0.45);line-height:1.75;}
.mc-trade__features{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.mc-trade__feature{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,0.55);}
.mc-trade__feature::before{content:'';width:16px;height:1px;background:var(--gold);flex-shrink:0;}

/* Newsletter */
.mc-newsletter{background:var(--fog);padding:var(--space-xl) 0;text-align:center;}
.mc-newsletter__inner{max-width:480px;margin:0 auto;}
.mc-newsletter__eyebrow{font-size:10px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:block;}
.mc-newsletter h2{font-family:var(--serif);font-size:clamp(22px,2.5vw,32px);font-weight:600;color:var(--ink);margin-bottom:10px;}
.mc-newsletter__sub{font-size:14px;color:var(--slate);margin-bottom:28px;line-height:1.65;}
.mc-newsletter__form{display:flex;border:1px solid var(--ash);border-radius:var(--radius-pill);overflow:hidden;background:var(--white);}
.mc-newsletter__form input{flex:1;padding:14px 20px;border:none;background:transparent;font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;}
.mc-newsletter__form input::placeholder{color:var(--ash);}
.mc-newsletter__form button{background:var(--charcoal);color:var(--white);border:none;padding:14px 24px;font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;border-radius:var(--radius-pill);margin:3px;transition:background var(--transition);white-space:nowrap;}
.mc-newsletter__form button:hover{background:var(--gold);}
.mc-newsletter__note{font-size:12px;color:var(--ash);margin-top:12px;}

/* Footer */
.site-footer{background:var(--dark);}
.mc-footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding:64px 0 52px;align-items:start;}
.mc-footer-brand__logo{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--white);letter-spacing:0.04em;display:block;margin-bottom:14px;text-decoration:none;}
.mc-footer-brand__logo span{color:var(--gold);}
.mc-footer-brand__tagline{font-family:var(--serif);font-style:italic;font-size:13px;color:rgba(255,255,255,0.4);margin-bottom:12px;display:block;}
.mc-footer-brand__desc{font-size:12px;color:rgba(255,255,255,0.35);line-height:1.75;}
.mc-footer-col__title{font-size:10px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-bottom:16px;}
.mc-footer-col__list{display:flex;flex-direction:column;gap:9px;}
.mc-footer-col__list li a{font-size:12px;color:rgba(255,255,255,0.55);text-decoration:none;transition:color var(--transition);line-height:1.4;}
.mc-footer-col__list li a:hover{color:var(--white);}
.mc-footer-bar{background:rgba(0,0,0,0.35);border-top:1px solid rgba(255,255,255,0.06);padding:16px 0;}
.mc-footer-bar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.mc-footer-bar__copy{font-size:12px;color:rgba(255,255,255,0.2);}
.mc-footer-bar__links{display:flex;gap:20px;flex-wrap:wrap;}
.mc-footer-bar__links a{font-size:12px;color:rgba(255,255,255,0.2);text-decoration:none;transition:color var(--transition);}.mc-footer-bar__links span{font-size:12px;color:rgba(255,255,255,0.2);}
.mc-footer-bar__links a:hover{color:rgba(255,255,255,0.5);}

/* Responsive */
@media(max-width:1100px){.mc-product-grid{grid-template-columns:repeat(3,1fr);}.mc-footer-grid{grid-template-columns:1fr 1fr;gap:36px;}}
@media(max-width:900px){.primary-nav,.mc-mega-wrap{display:none;}.mobile-menu-btn{display:flex;}.mc-style-grid{grid-template-columns:repeat(2,1fr);}.mc-room-grid{grid-template-columns:repeat(2,1fr);}.mc-location-grid{grid-template-columns:repeat(3,1fr);}.mc-why{grid-template-columns:1fr;}.mc-trade{grid-template-columns:1fr;}.mc-trade__visual{min-height:240px;}.mc-product-grid{grid-template-columns:repeat(2,1fr);}.mc-journal-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:600px){:root{--gap:20px;--space-xl:48px;}.mc-style-grid,.mc-product-grid,.mc-journal-grid{grid-template-columns:repeat(2,1fr);gap:16px;}.mc-location-grid{grid-template-columns:repeat(2,1fr);}.mc-footer-grid{grid-template-columns:1fr;gap:32px;}.mc-newsletter__form{flex-direction:column;border-radius:var(--radius-lg);}.mc-newsletter__form button{border-radius:var(--radius-pill);margin:0 3px 3px;}}

.mc-section--flush{padding:0;}

/* ── Hero stats bar ─────────────────────────── */
.mc-hero__stats{position:absolute;bottom:0;left:0;right:0;background:rgba(28,25,23,0.7);backdrop-filter:blur(8px);border-top:1px solid rgba(255,255,255,0.06);}
.mc-stats-row{display:flex;align-items:center;justify-content:center;gap:0;padding:16px 0;}
.mc-stat{display:flex;align-items:center;gap:16px;padding:0 40px;border-right:1px solid rgba(255,255,255,0.1);}
.mc-stat:last-child{border-right:none;}
.mc-stat__num{font-family:var(--serif);font-size:28px;font-weight:600;color:var(--gold);line-height:1;flex-shrink:0;}
.mc-stat__label{font-size:11px;color:rgba(255,255,255,0.45);line-height:1.4;letter-spacing:0.04em;}

/* ── Style grid symbol + cta ────────────────── */
.mc-style-card__sym{
  font-size:18px;
  color:var(--gold);
  opacity:0.8;
  line-height:1;
  margin-bottom:8px;
  display:block;
}
.mc-style-grid__cta{text-align:center;padding:28px;background:var(--charcoal);}

/* ── Gallery Wall Sets promo block ──────────── */
.mc-gws-promo{max-width:720px;}
.mc-gws-tiers{display:flex;gap:16px;flex-wrap:wrap;margin-top:20px;}
.mc-gws-tier{display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--ash);border-radius:var(--radius-lg);padding:16px 20px;flex:1;min-width:200px;}
.mc-gws-tier--gold{border-color:var(--gold);background:var(--gold-light);}
.mc-gws-tier__pct{font-family:var(--serif);font-size:32px;font-weight:600;color:var(--charcoal);line-height:1;flex-shrink:0;}
.mc-gws-tier--gold .mc-gws-tier__pct{color:var(--gold-dark);}
.mc-gws-tier__label{font-size:13px;color:var(--slate);line-height:1.4;}

@media(max-width:600px){.mc-stats-row{flex-wrap:wrap;gap:16px;}.mc-stat{border-right:none;padding:0 20px;}.mc-gws-tiers{flex-direction:column;}}

/* ── 50% Off Sets — highlight nav link ─────── */
.mc-nav-highlight {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #FFFFFF !important;
  background: var(--gold);
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  margin: 0 4px;
  text-decoration: none;
  transition: background var(--transition);
  white-space: nowrap;
}
.mc-nav-highlight:hover { background: var(--gold-dark); color: #FFFFFF !important; }
@media (max-width: 900px) { .mc-nav-highlight { display: none; } }

/* FAQ nav link */
.mc-nav-faq {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  padding: 8px 12px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: color var(--transition);
  white-space: nowrap;
}
.mc-nav-faq:hover { color: #FFFFFF; }
@media (max-width: 900px) { .mc-nav-faq { display: none; } }



/* ── Trade — top-level nav link ─────────────── */
.mc-nav-trade {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold) !important;
  padding: 6px 12px;
  border-radius: var(--radius);
  border: 1px solid var(--gold);
  text-decoration: none;
  transition: all var(--transition);
  white-space: nowrap;
  margin-left: 4px;
  background: rgba(196,151,42,0.1);
}
.mc-nav-trade:hover { background: var(--gold); color: #FFFFFF !important; border-color: var(--gold); }
@media (max-width: 900px) { .mc-nav-trade { display: none; } }

/* ═══════════════════════════════════════════════════════════════════
   PAGE & POST EDITORIAL LAYOUT
   ═══════════════════════════════════════════════════════════════════ */

/* Page header — eyebrow + title band */
.mc-page-hero {
  background: var(--charcoal);
  padding: 72px 0 56px;
  border-bottom: none;
}
.mc-page-hero__eyebrow {
  display: block;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}
.mc-page-hero__title {
  font-family: var(--serif);
  font-size: clamp(40px, 6vw, 72px);
  font-weight: 300;
  color: #ffffff;
  line-height: 1.05;
  margin: 0;
}
.mc-page-hero__title em {
  font-style: italic;
  color: rgba(255,255,255,0.5);
}
.mc-page-hero__sub {
  margin: 20px 0 0;
  font-size: 18px;
  color: rgba(255,255,255,0.5);
  line-height: 1.7;
  max-width: 600px;
}

/* Prose content wrapper */
.mc-prose {
  max-width: 740px;
  margin: 0 auto;
  padding: 64px var(--gap) 96px;
}
.mc-prose h1,
.mc-prose h2,
.mc-prose h3,
.mc-prose h4 {
  font-family: var(--serif);
  font-weight: 400;
  color: var(--ink);
  margin: 2em 0 0.5em;
  line-height: 1.2;
}
.mc-prose h1 { font-size: clamp(32px, 4vw, 48px); margin-top: 0; }
.mc-prose h2 { font-size: clamp(24px, 3vw, 36px); }
.mc-prose h3 { font-size: clamp(18px, 2.5vw, 26px); }
.mc-prose h4 { font-size: 18px; font-weight: 600; font-family: var(--sans); letter-spacing: 0.04em; }
.mc-prose p {
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.8;
  color: var(--charcoal);
  margin: 0 0 1.4em;
}
.mc-prose p:last-child { margin-bottom: 0; }
.mc-prose strong { font-weight: 600; color: var(--ink); }
.mc-prose em { font-style: italic; }
.mc-prose a { color: var(--gold); text-decoration: underline; text-underline-offset: 3px; }
.mc-prose a:hover { color: var(--gold-dark); }
.mc-prose ul,
.mc-prose ol {
  padding-left: 1.5em;
  margin: 0 0 1.4em;
}
.mc-prose li {
  font-size: 17px;
  line-height: 1.8;
  color: var(--charcoal);
  margin-bottom: 0.5em;
}
.mc-prose blockquote {
  margin: 2em 0;
  padding: 24px 32px;
  border-left: 3px solid var(--gold);
  background: var(--fog);
  border-radius: 0 var(--radius) var(--radius) 0;
}
.mc-prose blockquote p {
  font-family: var(--serif);
  font-size: 20px;
  font-style: italic;
  color: var(--ink);
  margin: 0;
}
.mc-prose hr {
  border: none;
  border-top: 1px solid var(--ash);
  margin: 3em 0;
}
.mc-prose table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
  margin: 1.5em 0;
}
.mc-prose th {
  background: var(--fog);
  font-family: var(--sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
  padding: 10px 16px;
  text-align: left;
  border-bottom: 1px solid var(--ash);
}
.mc-prose td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--ash);
  color: var(--charcoal);
  vertical-align: top;
}
.mc-prose tr:last-child td { border-bottom: none; }

/* Gold section divider rule */
.mc-prose .mc-rule {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 3em 0;
  color: var(--ash);
  font-size: 12px;
  letter-spacing: 0.2em;
}
.mc-prose .mc-rule::before,
.mc-prose .mc-rule::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--ash);
}

/* Section label (like old theme's ◆ THE STORY ◆ dividers) */
.mc-prose .mc-section-label {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 3.5em 0 2em;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--ash);
}
.mc-prose .mc-section-label::before,
.mc-prose .mc-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--ash);
}

/* Callout / pull quote box */
.mc-prose .mc-callout {
  margin: 2.5em 0;
  padding: 32px 40px;
  border: 1px solid var(--ash);
  border-radius: var(--radius-lg);
  background: var(--fog);
  font-family: var(--serif);
  font-size: 21px;
  font-style: italic;
  color: var(--ink);
  line-height: 1.5;
  text-align: center;
}

/* Checklist / promise list */
.mc-prose .mc-checklist {
  list-style: none;
  padding: 0;
  margin: 1.5em 0;
}
.mc-prose .mc-checklist li {
  padding-left: 28px;
  position: relative;
  margin-bottom: 0.75em;
}
.mc-prose .mc-checklist li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: 700;
}

/* Dark CTA block at end of page (like old theme's "Explore the Shop") */
.mc-page-cta {
  background: var(--ink);
  padding: 64px var(--gap);
  text-align: center;
}
.mc-page-cta__eyebrow {
  display: block;
  font-family: var(--serif);
  font-size: 13px;
  font-style: italic;
  color: rgba(255,255,255,0.45);
  margin-bottom: 16px;
}
.mc-page-cta__title {
  font-family: var(--serif);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 300;
  color: #fff;
  margin: 0 0 12px;
}
.mc-page-cta__sub {
  font-size: 15px;
  color: rgba(255,255,255,0.5);
  margin: 0 auto 28px;
  max-width: 480px;
  line-height: 1.7;
}

/* Legal / tab pages */
.mc-legal-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--ash);
  margin-bottom: 48px;
  overflow-x: auto;
  scrollbar-width: none;
}
.mc-legal-tab {
  padding: 12px 24px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--slate);
  border-bottom: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
  transition: all var(--transition);
  text-decoration: none;
  display: block;
}
.mc-legal-tab.is-active,
.mc-legal-tab:hover {
  color: var(--ink);
  border-bottom-color: var(--gold);
}

/* Standard page.php wrapper (non-custom pages) */
.mc-page-wrap {
  background: var(--ash-beige);
  min-height: 60vh;
}

/* Hide WP page title on custom-built pages (mc-gws, mc-hero, mc-section) */
.entry-page:has(.mc-gws) .page-entry-header,
.entry-page:has(.mc-gws) .mc-page-hero,
.entry-page:has(.mc-gws) .entry-title,
.entry:has(.mc-gws) .entry-title,
.entry:has(.mc-hero) .entry-title,
.entry:has(.mc-section) .entry-title,
.entry:has(.mc-contact) .entry-title,
.entry:has(.mc-shipping) .entry-title,
.entry:has(.mc-legal) .entry-title { display: none !important; }

/* ═══════════════════════════════════════════════════════════════════
   JOURNAL INDEX — home.php & archive.php (Thailand Stay style)
   ═══════════════════════════════════════════════════════════════════ */

.mc-journal-index { background: var(--ash-beige); }

/* Dark hero band */
.mc-ji__hero {
  background: var(--charcoal);
  padding: 80px 32px 72px;
  text-align: center;
}
.mc-ji__hero-inner { max-width: 640px; margin: 0 auto; }
.mc-ji__eyebrow {
  display: block;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}
.mc-ji__title {
  font-family: var(--serif);
  font-size: clamp(36px, 6vw, 64px);
  font-weight: 600;
  color: #ffffff;
  line-height: 1.1;
  margin: 0 0 16px;
}
.mc-ji__sub {
  font-family: var(--sans);
  font-size: 16px;
  color: rgba(255,255,255,0.5);
  line-height: 1.7;
  margin: 0;
}

/* Body wrapper */
.mc-ji__body { padding: 56px 0 80px; }
.mc-ji__container {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 32px;
}

/* 3-column card grid */
.mc-ji__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

/* Individual card */
.mc-ji__card {
  background: #ffffff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--ash);
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.mc-ji__card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
.mc-ji__card-img-wrap {
  display: block;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--fog);
}
.mc-ji__card-img-wrap--empty { background: var(--fog); }
.mc-ji__card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.mc-ji__card:hover .mc-ji__card-img { transform: scale(1.03); }

.mc-ji__card-body {
  padding: 24px 24px 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 10px;
}
.mc-ji__card-cat {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--gold);
  text-decoration: none;
  text-transform: uppercase;
}
.mc-ji__card-cat:hover { color: var(--gold-dark); }
.mc-ji__card-title {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.25;
  margin: 0;
}
.mc-ji__card-title a { color: inherit; text-decoration: none; }
.mc-ji__card-title a:hover { color: var(--gold); }
.mc-ji__card-excerpt {
  font-family: var(--sans);
  font-size: 14px;
  color: var(--slate);
  line-height: 1.7;
  margin: 0;
  flex: 1;
}
.mc-ji__card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 12px;
  border-top: 1px solid var(--ash);
  margin-top: auto;
}
.mc-ji__card-date {
  font-family: var(--sans);
  font-size: 12px;
  color: var(--slate);
}
.mc-ji__card-read {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  color: var(--charcoal);
  text-decoration: none;
  letter-spacing: 0.02em;
}
.mc-ji__card-read:hover { color: var(--gold); }

/* Pagination */
.mc-ji__pagination {
  margin-top: 48px;
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}
.mc-ji__pagination .page-numbers {
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
  padding: 8px 14px;
  border: 1px solid var(--ash);
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: all 0.2s;
}
.mc-ji__pagination .page-numbers.current,
.mc-ji__pagination .page-numbers:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: #ffffff;
}
.mc-ji__empty {
  font-family: var(--sans);
  font-size: 16px;
  color: var(--slate);
  text-align: center;
  padding: 48px 0;
}

/* ═══════════════════════════════════════════════════════════════════
   ARTICLE / SINGLE POST — single.php (Thailand Stay style)
   ═══════════════════════════════════════════════════════════════════ */

.mc-article { background: var(--ash-beige); }

/* Article header */
.mc-article__header {
  background: var(--ash-beige);
  max-width: 100%;
  padding: 40px 0 28px;
  margin-bottom: 0;
}
.mc-article__header-inner {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 32px;
}
.mc-article__cat {
  display: inline-block;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
  margin-bottom: 14px;
}
.mc-article__cat:hover { color: var(--gold-dark); }
.mc-article__title {
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 52px);
  font-weight: 600;
  color: var(--ink);
  line-height: 1.15;
  margin: 0 0 20px;
}
.mc-article__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--slate);
  flex-wrap: wrap;
}
.mc-article__meta-dot { color: var(--ash); }

/* Featured image — content width, natural proportions, no crop */
.mc-article__featured-img {
  width: 100%;
  margin: 0 0 20px 0;
  padding: 0;
}
.mc-article__featured-img img {
  border-radius: 8px;
  width: 100%;
  height: auto;
  display: block;
}

/* Content + sidebar layout */
.mc-article__body { padding-bottom: 72px; padding-top: 0; }
.mc-article__container {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 32px;
}
.mc-article__layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
}
.mc-article__content { min-width: 0; }

/* Sidebar — padding-top matches mc-prose padding-top so text and widget align */
.mc-article__sidebar {
  position: sticky;
  top: 0;
  padding-top: 64px;
}
.mc-article__sidebar:empty { display: none; }

/* Related articles */
.mc-article__related {
  background: var(--fog);
  padding: 56px 0 72px;
  border-top: 1px solid var(--ash);
}
.mc-article__related-title {
  font-family: var(--serif);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 32px;
}
.mc-article__related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* Responsive */
@media (max-width: 900px) {
  .mc-ji__grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .mc-article__layout { grid-template-columns: 1fr; }
  .mc-article__sidebar { position: static; }
  .mc-article__related-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .mc-ji__grid { grid-template-columns: 1fr; gap: 20px; }
  .mc-ji__hero { padding: 56px 20px 48px; }
  .mc-ji__container, .mc-article__container, .mc-article__header-inner { padding-left: 20px; padding-right: 20px; }
}

/* ═══════════════════════════════════════════════════════════════════
   EASY DIGITAL DOWNLOADS — FULL STORE STYLES
   ═══════════════════════════════════════════════════════════════════ */

/* ── Shop page wrapper ── */
.post-type-archive-download .site-main,
.tax-download_category .site-main,
.single-download .site-main {
  background: var(--ash-beige);
}

/* ── Shop page hero header ── */
.mc-edd-hero {
  background: var(--charcoal);
  padding: 64px 32px 56px;
  text-align: center;
}
.mc-edd-hero__eyebrow {
  display: block;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}
.mc-edd-hero__title {
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 56px);
  font-weight: 400;
  color: #ffffff;
  line-height: 1.1;
  margin: 0 0 14px;
}
.mc-edd-hero__sub {
  font-family: var(--sans);
  font-size: 16px;
  color: rgba(255,255,255,0.5);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ── Category filter bar ── */
.mc-edd-filters {
  background: #fff;
  border-bottom: 1px solid var(--ash);
  padding: 0 32px;
  overflow-x: auto;
  scrollbar-width: none;
}
.mc-edd-filters::-webkit-scrollbar { display: none; }
.mc-edd-filters__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  gap: 0;
  align-items: center;
}
.mc-edd-filter {
  display: block;
  padding: 16px 20px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--slate);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: all 0.2s;
}
.mc-edd-filter:hover,
.mc-edd-filter.is-active {
  color: var(--ink);
  border-bottom-color: var(--gold);
}

/* ── Downloads grid ── */
.mc-edd-grid-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 32px 80px;
}
.mc-edd-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

/* ── Download card ── */
.mc-edd-card {
  background: #fff;
  border: 1px solid var(--ash);
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.2s, transform 0.2s;
  text-decoration: none;
}
.mc-edd-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.1);
  transform: translateY(-3px);
}
.mc-edd-card__img-wrap {
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--fog);
}
.mc-edd-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.mc-edd-card:hover .mc-edd-card__img { transform: scale(1.04); }
.mc-edd-card__body {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.mc-edd-card__cat {
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
}
.mc-edd-card__title {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 400;
  color: var(--ink);
  line-height: 1.3;
  margin: 0;
}
.mc-edd-card__price {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  color: var(--slate);
  margin-top: auto;
  padding-top: 10px;
}
.mc-edd-card__price del { color: var(--ash); margin-right: 4px; font-weight: 400; }
.mc-edd-card__price ins { color: var(--gold); text-decoration: none; }

/* ── EDD default download list overrides ── */
#edd_downloads_list {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 28px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}
#edd_downloads_list .edd_download {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  background: #fff !important;
  border: 1px solid var(--ash) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  transition: box-shadow 0.2s, transform 0.2s !important;
}
#edd_downloads_list .edd_download:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.1) !important;
  transform: translateY(-3px) !important;
}
#edd_downloads_list .edd_download .edd_download_inner { padding: 0 !important; }
#edd_downloads_list .edd_download .edd_download_image img {
  width: 100% !important;
  aspect-ratio: 3/4 !important;
  object-fit: cover !important;
  display: block !important;
}
#edd_downloads_list .edd_download .edd_download_title {
  font-family: var(--serif) !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  padding: 14px 18px 4px !important;
  margin: 0 !important;
}
#edd_downloads_list .edd_download .edd_download_title a {
  color: inherit !important;
  text-decoration: none !important;
}
#edd_downloads_list .edd_download .edd_price {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--gold) !important;
  padding: 0 18px 8px !important;
  display: block !important;
}
#edd_downloads_list .edd_download .edd_download_buy_button {
  padding: 0 18px 18px !important;
  display: block !important;
}
/* Style the first (and only) buy button as ghost pill */
#edd_downloads_list .edd_download .edd_download_buy_button .edd-add-to-cart,
#edd_downloads_list .edd_download .edd_download_buy_button input[type="submit"],
#edd_downloads_list .edd_download .edd_download_buy_button .button {
  background: transparent !important;
  color: var(--ink) !important;
  border: 1px solid var(--ash) !important;
  border-radius: 100px !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 10px 20px !important;
  width: 100% !important;
  display: block !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  box-shadow: none !important;
}
#edd_downloads_list .edd_download .edd_download_buy_button .edd-add-to-cart:hover,
#edd_downloads_list .edd_download .edd_download_buy_button input[type="submit"]:hover {
  background: var(--charcoal) !important;
  color: #fff !important;
  border-color: var(--charcoal) !important;
}
/* Hide ALL duplicate buttons and checkout redirect after the first */
#edd_downloads_list .edd_download .edd_download_buy_button .edd-add-to-cart ~ *,
#edd_downloads_list .edd_download .edd_download_buy_button .button ~ *,
#edd_downloads_list .edd_download .edd_download_buy_button input ~ *,
#edd_downloads_list .edd_download .edd-checkout-redirect,
#edd_downloads_list .edd-checkout-redirect { display: none !important; }

/* ── Single download (product) page ── */
.single-download .mc-product__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 56px 48px 72px;
}
.single-download .edd_download_wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}

/* Single download image */
.single-download .edd_download_image img {
  width: 100% !important;
  height: auto !important;
  border-radius: 12px !important;
  display: block !important;
}

/* Single download info */
.single-download .edd_download_title_wrapper h2,
.single-download h1.entry-title {
  font-family: var(--serif) !important;
  font-size: clamp(28px, 3.5vw, 44px) !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  line-height: 1.15 !important;
  margin: 0 0 16px !important;
}
.single-download .edd_price_wrapper .edd_price,
.single-download .edd-price {
  font-family: var(--serif) !important;
  font-size: 34px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  display: block !important;
  margin-bottom: 20px !important;
}
.single-download .edd_purchase_submit_wrapper .edd-add-to-cart,
.single-download .edd-submit,
.single-download input.edd-add-to-cart {
  background: var(--gold) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 18px 48px !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background 0.2s, box-shadow 0.2s !important;
  box-shadow: 0 4px 16px rgba(196,151,42,0.3) !important;
  display: block !important;
}
.single-download .edd_purchase_submit_wrapper .edd-add-to-cart:hover {
  background: var(--gold-dark) !important;
}

/* ── EDD Checkout page ── */
#edd_checkout_form_wrap,
#edd_checkout_wrap {
  max-width: 680px;
  margin: 48px auto;
  padding: 0 32px 72px;
}
#edd_checkout_form_wrap h3,
#edd_checkout_wrap h3 {
  font-family: var(--serif) !important;
  font-size: 22px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  margin-bottom: 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid var(--ash) !important;
}
#edd_checkout_form_wrap input[type="text"],
#edd_checkout_form_wrap input[type="email"],
#edd_checkout_form_wrap input[type="tel"],
#edd_checkout_wrap input[type="text"],
#edd_checkout_wrap input[type="email"] {
  width: 100% !important;
  padding: 14px 16px !important;
  border: 1px solid var(--ash) !important;
  border-radius: 8px !important;
  font-family: var(--sans) !important;
  font-size: 15px !important;
  color: var(--ink) !important;
  background: #fff !important;
  margin-bottom: 16px !important;
  transition: border-color 0.2s !important;
}
#edd_checkout_form_wrap input:focus,
#edd_checkout_wrap input:focus {
  border-color: var(--gold) !important;
  outline: none !important;
}
#edd_purchase_submit input[type="submit"],
#edd_purchase_submit .edd-submit,
.edd-submit.button {
  background: var(--gold) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 18px 48px !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background 0.2s, box-shadow 0.2s !important;
  box-shadow: 0 4px 16px rgba(196,151,42,0.3) !important;
  display: block !important;
  margin-top: 8px !important;
}
#edd_purchase_submit input[type="submit"]:hover,
.edd-submit.button:hover {
  background: var(--gold-dark) !important;
}

/* Order summary on checkout */
#edd_checkout_cart {
  background: #fff !important;
  border: 1px solid var(--ash) !important;
  border-radius: 12px !important;
  padding: 24px !important;
  margin-bottom: 32px !important;
}
#edd_checkout_cart th {
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--slate) !important;
  padding: 0 0 12px !important;
  border-bottom: 1px solid var(--ash) !important;
}
#edd_checkout_cart td {
  padding: 12px 0 !important;
  font-family: var(--sans) !important;
  font-size: 14px !important;
  color: var(--charcoal) !important;
  border-bottom: 1px solid var(--fog) !important;
}
.edd_cart_total {
  font-family: var(--serif) !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
}

/* Discount code field */
#edd-discount-code-wrap {
  display: flex;
  gap: 8px;
  margin-bottom: 20px;
}
#edd-discount-code-wrap input {
  flex: 1;
}
#edd-apply-discount,
#edd_apply_discount {
  background: var(--charcoal) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 0 20px !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background 0.2s !important;
}
#edd-apply-discount:hover { background: var(--ink) !important; }

/* ── EDD Confirmation / Receipt page ── */
#edd_purchase_receipt {
  max-width: 680px;
  margin: 48px auto;
  padding: 0 32px 72px;
}
.edd_purchase_receipt_products {
  background: #fff;
  border: 1px solid var(--ash);
  border-radius: 12px;
  padding: 24px;
  margin: 24px 0;
}
.edd_purchase_receipt_products th {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--ash);
}
.edd_purchase_receipt_products td {
  padding: 12px 0;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--charcoal);
  border-bottom: 1px solid var(--fog);
}
.edd_download_file_title a {
  color: var(--gold) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}
.edd_download_file_title a:hover { color: var(--gold-dark) !important; }

/* ── EDD notices ── */
.edd_errors,
.edd-alert {
  background: var(--fog) !important;
  border: 1px solid var(--ash) !important;
  border-radius: 8px !important;
  padding: 14px 18px !important;
  font-family: var(--sans) !important;
  font-size: 14px !important;
  color: var(--charcoal) !important;
  margin-bottom: 20px !important;
  list-style: none !important;
}
.edd_errors li { margin: 0 !important; padding: 0 !important; }

/* ── Responsive ── */
@media (max-width: 1100px) {
  #edd_downloads_list { grid-template-columns: repeat(3, 1fr) !important; }
  .mc-edd-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  #edd_downloads_list { grid-template-columns: repeat(2, 1fr) !important; }
  .mc-edd-grid { grid-template-columns: repeat(2, 1fr); }
  .single-download .edd_download_wrapper { grid-template-columns: 1fr; gap: 32px; }
  .single-download .mc-product__container,
  .mc-edd-grid-wrap { padding: 32px 20px 56px; }
  #edd_checkout_form_wrap,
  #edd_purchase_receipt { padding: 0 20px 56px; }
}
@media (max-width: 480px) {
  #edd_downloads_list { grid-template-columns: 1fr 1fr !important; gap: 16px !important; }
  .mc-edd-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
}

/* ── EDD trust badges ── */
.mc-product__trust {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 20px 0;
  border-top: 1px solid var(--ash);
  border-bottom: 1px solid var(--ash);
  margin: 20px 0;
}
.mc-product__trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--slate);
}
.mc-product__trust-item svg { color: var(--gold); flex-shrink: 0; }

/* ═══════════════════════════════════════════════════════════════════
   SINGLE DOWNLOAD (EDD PRODUCT PAGE)
   ═══════════════════════════════════════════════════════════════════ */

.mc-download-page { background: var(--ash-beige); }

/* Header */
.mc-download__header {
  background: var(--ash-beige);
  padding: 36px 0 0;
}
.mc-download__header-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 48px;
}
.mc-download__cat {
  display: inline-block;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
  margin-bottom: 10px;
}
.mc-download__cat:hover { color: var(--gold-dark); }
.mc-download__title {
  font-family: var(--serif);
  font-size: clamp(28px, 3.5vw, 48px);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.15;
  margin: 0;
}

/* Body layout */
.mc-download__body { padding: 36px 0 0; }
.mc-download__container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 48px;
}
.mc-download__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
  padding-bottom: 56px;
}

/* Gallery */
.mc-download__main-img { border-radius: 12px; overflow: hidden; }
.mc-download__main-img--empty {
  aspect-ratio: 3/4;
  background: var(--fog);
  border-radius: 12px;
}

/* Info panel */
.mc-download__info { display: flex; flex-direction: column; gap: 20px; }

.mc-download__price {
  font-family: var(--serif);
  font-size: 38px;
  font-weight: 400;
  color: var(--ink);
  line-height: 1;
}

.mc-download__excerpt {
  font-family: var(--sans);
  font-size: 15px;
  color: var(--slate);
  line-height: 1.8;
  padding: 20px 0;
  border-top: 1px solid var(--ash);
  border-bottom: 1px solid var(--ash);
}
.mc-download__excerpt p { margin: 0; }

/* Purchase button */
.mc-download__purchase .edd-add-to-cart,
.mc-download__purchase .mc-download__btn,
.mc-download__purchase a.button,
.mc-download__purchase input.edd-add-to-cart {
  background: var(--gold) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 100px !important;
  font-family: var(--sans) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 18px 48px !important;
  width: 100% !important;
  display: block !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  box-shadow: 0 4px 16px rgba(196,151,42,0.3) !important;
  text-decoration: none !important;
}
.mc-download__purchase .edd-add-to-cart:hover,
.mc-download__purchase .mc-download__btn:hover,
.mc-download__purchase a.button:hover {
  background: var(--gold-dark) !important;
  color: #fff !important;
  box-shadow: 0 6px 20px rgba(196,151,42,0.45) !important;
}

/* Trust badges */
.mc-download__trust {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mc-download__trust-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--slate);
}
.mc-download__trust-item svg { color: var(--gold); flex-shrink: 0; }

/* Discount hint */
.mc-download__discount-hint {
  background: rgba(196,151,42,0.07);
  border: 1px solid rgba(196,151,42,0.2);
  border-radius: 8px;
  padding: 14px 18px;
}
.mc-download__discount-hint-inner {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: var(--sans);
  font-size: 13px;
  color: var(--slate);
  line-height: 1.6;
}
.mc-download__discount-hint-icon {
  color: var(--gold);
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}
.mc-download__discount-hint strong { color: var(--ink); }
.mc-download__discount-hint code {
  background: rgba(196,151,42,0.12);
  border: 1px solid rgba(196,151,42,0.25);
  color: var(--gold);
  font-size: 12px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 4px;
}
.mc-download__discount-hint a { color: var(--gold); text-decoration: underline; }

/* Meta */
.mc-download__meta {
  display: flex;
  gap: 8px;
  align-items: center;
  font-family: var(--sans);
  font-size: 13px;
  padding-top: 8px;
  border-top: 1px solid var(--ash);
}
.mc-download__meta-label { color: var(--slate); font-weight: 600; }
.mc-download__meta-value { color: var(--gold); text-decoration: none; }
.mc-download__meta-value:hover { color: var(--gold-dark); }

/* Full description */
.mc-download__description {
  border-top: 1px solid var(--ash);
  padding-top: 48px;
  padding-bottom: 64px;
  max-width: 740px;
}
.mc-download__desc-title {
  font-family: var(--serif) !important;
  font-size: 26px !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  margin-bottom: 20px !important;
}

/* Related downloads */
.mc-download__related {
  background: var(--white);
  padding: 56px 0 72px;
  border-top: 1px solid var(--fog);
}
.mc-download__related-title {
  font-family: var(--serif);
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 28px;
  padding: 0 32px;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.mc-download__related-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

/* Responsive */
@media (max-width: 900px) {
  .mc-download__layout { grid-template-columns: 1fr; gap: 32px; }
  .mc-download__related-grid { grid-template-columns: repeat(2, 1fr); }
  .mc-download__container,
  .mc-download__header-inner { padding-left: 24px; padding-right: 24px; }
}
@media (max-width: 480px) {
  .mc-download__related-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
}





/* ── EDD: Keep only first purchase button, hide checkout redirect ── */
/* EDD renders: [add-to-cart] [direct-download] [checkout] — hide all but first */
.mc-download__purchase .edd_download_purchase_form {
  display: block !important;
}
/* Hide every purchase form after the first one */
.mc-download__purchase .edd_download_purchase_form ~ .edd_download_purchase_form {
  display: none !important;
}
/* Hide the checkout redirect button EDD appends */
.mc-download__purchase a.edd-checkout-redirect,
.mc-download__purchase .edd-checkout-redirect,
.edd-checkout-redirect { display: none !important; }

/* Target EDD's specific button wrapper structure */
.mc-download__purchase .edd_purchase_submit_wrapper {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}
/* Hide second input/button within same form (direct download duplicate) */
.mc-download__purchase .edd_purchase_submit_wrapper input.edd-add-to-cart ~ input,
.mc-download__purchase .edd_purchase_submit_wrapper button ~ button,
.mc-download__purchase .edd_purchase_submit_wrapper input ~ a { display: none !important; }

/* ── Download description: images full width ── */
.mc-download__description img,
.mc-download__desc-img-wrap img {
  width: 100% !important;
  height: auto !important;
  max-width: 100% !important;
  display: block !important;
  border-radius: 8px !important;
  margin: 24px 0 !important;
}
.mc-download__desc-img-wrap {
  display: block !important;
  width: 100% !important;
}



/* ═══════════════════════════════════════════════════════════════════
   EDD PRODUCT PAGE — DEFINITIVE BUTTON + CARD FIXES
   ═══════════════════════════════════════════════════════════════════ */



/* ── Related downloads: 3 columns, square images ── */
.mc-download__related-grid {
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
}
.mc-edd-card__img-wrap {
  aspect-ratio: 1 / 1 !important;
}

/* ── Card hover: image only, not container ── */
/* Remove container-level hover effects */
.mc-edd-card:hover {
  box-shadow: none !important;
  transform: none !important;
}
/* Apply zoom only to the image inside */
.mc-edd-card:hover .mc-edd-card__img {
  transform: scale(1.05) !important;
}

/* ── Article cards: image-only hover effect ── */
.mc-ji__card:hover {
  box-shadow: none !important;
  transform: none !important;
}
.mc-ji__card:hover .mc-ji__card-img {
  transform: scale(1.05) !important;
}



/* ── Download page: discount code cards ── */
.mc-download__codes {
  padding: 20px 0 4px;
  border-top: 1px solid var(--ash);
}
.mc-download__codes-title {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 10px;
  line-height: 1.2;
}
.mc-download__codes-title em { color: var(--gold); font-style: italic; }
.mc-download__codes-sub {
  font-family: var(--sans);
  font-size: 14px;
  color: var(--slate);
  line-height: 1.7;
  margin-bottom: 18px;
}
.mc-download__codes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.mc-download__code-card {
  background: #fff;
  border: 1px solid var(--ash);
  border-radius: 12px;
  padding: 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.mc-download__code-card--gold {
  border-color: var(--gold);
  background: rgba(196,151,42,0.04);
}
.mc-download__code-spend {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
}
.mc-download__code-pct {
  font-family: var(--serif);
  font-size: 38px;
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1;
}
.mc-download__code-card--gold .mc-download__code-pct { color: var(--gold); }
.mc-download__code-label {
  font-size: 13px;
  color: var(--slate);
  line-height: 1.55;
}
.mc-download__code-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
  font-size: 13px;
  color: var(--slate);
  font-weight: 600;
}
.mc-download__code-badge {
  display: inline-block;
  background: rgba(196,151,42,0.12);
  border: 1px solid rgba(196,151,42,0.3);
  color: var(--gold);
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 6px;
  letter-spacing: 0.06em;
}
.mc-download__copy-btn {
  background: none;
  border: 1px solid var(--ash);
  border-radius: 6px;
  padding: 5px 12px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  color: var(--charcoal);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: all 0.2s;
  white-space: nowrap;
}
.mc-download__copy-btn:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.mc-download__codes-note {
  font-size: 13px;
  color: var(--slate);
  line-height: 1.7;
  font-style: italic;
}
.mc-download__codes-note strong { font-style: normal; color: var(--ink); }
.mc-download__codes-note a { color: var(--gold); text-decoration: underline; }

/* =============================================================
   PRODUCT GALLERY — WooCommerce-style (v50)
   ============================================================= */

/* Gallery wrapper */
.mc-download__gallery { position: relative; }

/* ── Main slideshow ── */
.mc-gallery__main-wrap {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: var(--fog);
  aspect-ratio: 1 / 1;
}

.mc-gallery__slide {
  display: none;
  width: 100%;
  height: 100%;
  position: relative;
}
.mc-gallery__slide.is-active { display: block; }

.mc-gallery__main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.25s;
}

/* Zoom icon overlay */
.mc-gallery__zoom-btn {
  position: absolute;
  bottom: 14px;
  right: 14px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.5);
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(4px);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
  z-index: 2;
}
.mc-gallery__zoom-btn:hover {
  background: #fff;
  border-color: var(--gold);
  color: var(--gold);
}

/* Prev / Next arrows */
.mc-gallery__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.45);
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(4px);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
  transition: background 0.2s, border-color 0.2s;
}
.mc-gallery__arrow:hover { background: #fff; border-color: var(--gold); color: var(--gold); }
.mc-gallery__arrow--prev { left: 12px; }
.mc-gallery__arrow--next { right: 12px; }

/* ── Thumbnail strip ── */
.mc-gallery__thumbs {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.mc-gallery__thumb {
  width: 72px;
  height: 72px;
  border-radius: 8px;
  overflow: hidden;
  border: 2px solid transparent;
  background: var(--fog);
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
  transition: border-color 0.2s;
}
.mc-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.mc-gallery__thumb:hover { border-color: var(--gold); }
.mc-gallery__thumb.is-active { border-color: var(--ink); }

/* ── Lightbox ── */
.mc-lightbox {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mc-lightbox[hidden] { display: none; }

.mc-lightbox__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20, 18, 16, 0.92);
  backdrop-filter: blur(6px);
}

.mc-lightbox__inner {
  position: relative;
  z-index: 1;
  max-width: 90vw;
  max-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mc-lightbox__img {
  max-width: 90vw;
  max-height: 88vh;
  object-fit: contain;
  border-radius: 4px;
  display: block;
}

.mc-lightbox__close {
  position: fixed;
  top: 20px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.25);
  background: rgba(255,255,255,0.12);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s;
  z-index: 2;
}
.mc-lightbox__close:hover { background: rgba(255,255,255,0.22); }

.mc-lightbox__nav {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.25);
  background: rgba(255,255,255,0.12);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s;
  z-index: 2;
}
.mc-lightbox__nav:hover { background: rgba(255,255,255,0.22); }
.mc-lightbox__nav--prev { left: 24px; }
.mc-lightbox__nav--next { right: 24px; }

/* ── Responsive ── */
@media (max-width: 768px) {
  .mc-gallery__thumbs { gap: 8px; }
  .mc-gallery__thumb { width: 58px; height: 58px; }
  .mc-lightbox__nav--prev { left: 10px; }
  .mc-lightbox__nav--next { right: 10px; }
}

/* =============================================================
   MOBILE DRAWER (v52)
   ============================================================= */

/* Overlay */
.mc-drawer-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(20,18,16,0.55);
  backdrop-filter: blur(2px);
  z-index: 998;
}
body.mc-drawer-open .mc-drawer-overlay { display: block; }

/* Drawer panel */
.mc-mobile-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(320px, 88vw);
  background: var(--charcoal);
  z-index: 999;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.mc-mobile-drawer.is-open { transform: translateX(0); }
body.mc-drawer-open { overflow: hidden; }

/* Header row */
.mc-drawer__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
}
.mc-drawer__logo {
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--white);
  text-decoration: none;
  letter-spacing: 0.04em;
}
.mc-drawer__logo span { color: var(--gold); }
.mc-drawer__close {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.15);
  background: none;
  color: rgba(255,255,255,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.2s, color 0.2s;
}
.mc-drawer__close:hover { background: rgba(255,255,255,0.1); color: #fff; }

/* Body */
.mc-drawer__body {
  flex: 1;
  padding: 12px 0;
  overflow-y: auto;
}

/* Flat links */
.mc-drawer__link {
  display: block;
  padding: 13px 20px;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  transition: color 0.15s, background 0.15s;
}
.mc-drawer__link:hover { color: #fff; background: rgba(255,255,255,0.05); }
.mc-drawer__link--gold {
  color: var(--gold) !important;
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: 8px;
  padding-top: 16px;
  font-size: 13px;
}
.mc-drawer__link--outline {
  color: rgba(255,255,255,0.5) !important;
  font-size: 12px;
  letter-spacing: 0.08em;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius);
  margin: 6px 20px;
  padding: 10px 16px;
  text-align: center;
}
.mc-drawer__link--outline:hover { border-color: var(--gold); color: var(--gold) !important; background: transparent; }

/* Accordion sections */
.mc-drawer-section { border-top: 1px solid rgba(255,255,255,0.06); }
.mc-drawer-section__toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 20px;
  background: none;
  border: none;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  cursor: pointer;
  transition: color 0.15s;
  text-align: left;
}
.mc-drawer-section__toggle:hover { color: #fff; }
.mc-drawer-section__toggle svg {
  flex-shrink: 0;
  transition: transform 0.2s;
  opacity: 0.5;
}
.mc-drawer-section.is-open .mc-drawer-section__toggle svg { transform: rotate(180deg); }
.mc-drawer-section.is-open .mc-drawer-section__toggle { color: #fff; }

.mc-drawer-section__items {
  display: none;
  padding: 4px 0 12px;
  background: rgba(0,0,0,0.2);
}
.mc-drawer-section.is-open .mc-drawer-section__items { display: block; }
.mc-drawer-section__item {
  display: block;
  padding: 9px 28px;
  font-family: var(--sans);
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  transition: color 0.15s;
}
.mc-drawer-section__item:hover { color: var(--gold); }

/* Footer */
.mc-drawer__foot {
  display: flex;
  gap: 20px;
  padding: 16px 20px;
  border-top: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
}
.mc-drawer__foot a {
  font-family: var(--sans);
  font-size: 12px;
  color: rgba(255,255,255,0.35);
  text-decoration: none;
  transition: color 0.15s;
}
.mc-drawer__foot a:hover { color: rgba(255,255,255,0.7); }


/* =============================================================
   GLOBAL RESPONSIVE FIXES (v52)
   ============================================================= */

/* ── Prevent horizontal scroll globally ── */
html { overflow-x: clip; } /* clip instead of hidden — doesn't break position:sticky */
body { max-width: 100%; overflow-x: clip; }

/* ── mc-download container: fix hardcoded 48px padding ── */
@media (max-width: 600px) {
  .mc-download__container,
  .mc-download__header-inner {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  .mc-download__header { padding-top: 28px; padding-bottom: 0; }
  .mc-download__title { font-size: clamp(26px, 7vw, 42px); }
  .mc-download__body { padding-top: 20px; }
  .mc-download__layout { gap: 24px; padding-bottom: 36px; }
}

/* ── Discount code cards: stack on very small screens ── */
@media (max-width: 480px) {
  .mc-download__codes-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .mc-download__codes-title { font-size: 18px; }
}

/* ── Gallery thumbnails on tiny screens ── */
@media (max-width: 400px) {
  .mc-gallery__thumb { width: 52px; height: 52px; }
  .mc-gallery__thumbs { gap: 6px; }
}

/* ── Homepage hero ── */
@media (max-width: 600px) {
  .mc-hero { min-height: 70vh; padding: 0 20px; }
  .mc-hero__inner { padding: 60px 0 40px; }
  .mc-hero__actions { flex-direction: column; align-items: flex-start; gap: 12px; }
  .mc-hero__actions .mc-btn { width: 100%; text-align: center; }
}

/* ── Section headings & padding ── */
@media (max-width: 600px) {
  .mc-section { padding: 48px 0; }
  .mc-section__title { font-size: clamp(24px, 6vw, 36px); }
  .mc-techniques-grid { grid-template-columns: 1fr 1fr; gap: 2px; }
  .mc-collections__tabs { gap: 6px; flex-wrap: wrap; }
  .mc-collections__tab { font-size: 11px; padding: 6px 12px; }
}

/* ── Journal index header ── */
@media (max-width: 600px) {
  .mc-ji__hero { padding: 48px 16px 36px; }
}

/* ── Related products grid ── */
@media (max-width: 400px) {
  .mc-download__related-grid { grid-template-columns: 1fr; }
}

/* ── Topbar: prevent overflow on tiny screens ── */
@media (max-width: 400px) {
  .mc-topbar__inner { gap: 6px; }
  .mc-topbar__text { font-size: 11px; }
  .topbar-countdown { display: none; }
}

/* ── Footer bar text wrap ── */
@media (max-width: 480px) {
  .mc-footer-bar .container { flex-direction: column; text-align: center; gap: 8px; }
  .mc-footer-bar .container > * { width: 100%; }
}

/* ── EDD checkout/cart pages ── */
@media (max-width: 600px) {
  #edd_checkout_form_wrap,
  #edd_purchase_receipt { padding: 0 16px 48px; }
}

/* =============================================================
   TECHNIQUES SECTION — tighter proportions (v52)
   ============================================================= */
.mc-section--techniques {
  padding-top: 48px;
  padding-bottom: 0; /* grid flush to bottom edge */
}
.mc-section--techniques .mc-section__head {
  padding-left: var(--gap);
  padding-right: var(--gap);
}

/* Shrink card text slightly to suit the 4/5 ratio */
.mc-style-card__name  { font-size: 16px; margin-bottom: 5px; }
.mc-style-card__desc  { font-size: 12px; line-height: 1.5; }
.mc-style-card__content { padding: 16px; }

/* Responsive: at tablet the cards already go 2-col — keep aspect-ratio */
@media (max-width: 900px) {
  .mc-section--techniques { padding-top: 40px; }
}
@media (max-width: 600px) {
  .mc-style-card { min-height: 160px; }
  .mc-style-card__name { font-size: 14px; }
  .mc-style-card__desc { display: none; } /* too cramped at 2-col mobile */
  .mc-style-card__content { padding: 12px; }
}

/* =============================================================
   SHOP ARCHIVE — pagination + background (v54)
   ============================================================= */

.mc-shop-page { background: var(--ash-beige); min-height: 60vh; }
.post-type-archive-download .site-main,
.tax-download_category .site-main { background: var(--ash-beige); }

/* Pagination */
.mc-edd-pagination {
  display: flex;
  justify-content: center;
  gap: 6px;
  padding: 48px 0 0;
  flex-wrap: wrap;
}
.mc-edd-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding: 0 10px;
  border-radius: var(--radius);
  border: 1px solid var(--ash);
  background: #fff;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
  text-decoration: none;
  transition: all 0.2s;
}
.mc-edd-pagination .page-numbers:hover { border-color: var(--gold); color: var(--gold); }
.mc-edd-pagination .page-numbers.current {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.mc-edd-pagination .page-numbers.dots { border: none; background: none; cursor: default; }

/* Filter bar background */
.mc-edd-filters { background: var(--ash-beige); border-bottom: 1px solid var(--ash); }

/* =============================================================
   PRODUCT CARD — gold CTA button (v54c)
   ============================================================= */

/* Archive grid card button */
.mc-edd-card__cta {
  display: block;
  text-align: center;
  padding: 10px 20px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  background: transparent;
  border: 1px solid var(--ash);
  border-radius: var(--radius-pill);
  margin-top: 12px;
  transition: all var(--transition);
}
.mc-edd-card:hover .mc-edd-card__cta { background: var(--charcoal); color: #fff; border-color: var(--charcoal); }

/* Hard-kill any EDD-injected buy buttons on archive — our template doesn't use them
   but belt-and-suspenders in case EDD hooks fire anyway */
#edd_downloads_list .edd_download_buy_button,
#edd_downloads_list .edd-checkout-redirect,
#edd_downloads_list .edd_purchase_submit_wrapper ~ *,
.post-type-archive-download .edd_download_purchase_form { display: none !important; }

/* =============================================================
   EDD ARCHIVE — nuclear button suppression (v54d)
   Hides ALL EDD-injected purchase forms, excerpt text, and
   duplicate/checkout buttons on the products archive page.
   ============================================================= */
.post-type-archive-download .edd_download_purchase_form,
.post-type-archive-download .edd-checkout-redirect,
.post-type-archive-download .edd_purchase_submit_wrapper,
.post-type-archive-download .edd-add-to-cart,
.post-type-archive-download .edd_download_excerpt,
.post-type-archive-download .edd_download_title,
.post-type-archive-download .edd_price,
.tax-download_category .edd_download_purchase_form,
.tax-download_category .edd-checkout-redirect,
.tax-download_category .edd_purchase_submit_wrapper,
.tax-download_category .edd-add-to-cart { display: none !important; }

/* =============================================================
   EDD SHORTCODE LIST — hide excerpt + duplicate buttons (v55b)
   ============================================================= */
#edd_downloads_list .edd_download_excerpt,
#edd_downloads_list .edd_excerpt { display: none !important; }

/* =============================================================
   EDD [downloads] SHORTCODE — hide ALL purchase forms (v55c)
   Targets the /products/ page which uses a [downloads] shortcode.
   The page body has class .page so we scope to #edd_downloads_list.
   ============================================================= */

/* Hide every purchase form, every button after the first, checkout links */
#edd_downloads_list .edd_download_purchase_form { display: none !important; }
#edd_downloads_list .edd_download_buy_button form { display: none !important; }
#edd_downloads_list .edd_download_buy_button .edd_purchase_submit_wrapper { display: none !important; }
#edd_downloads_list .edd-checkout-redirect { display: none !important; }
#edd_downloads_list a.edd-checkout-redirect { display: none !important; }

/* Also hide the excerpt text EDD renders */
#edd_downloads_list .edd_download_excerpt,
#edd_downloads_list .edd_excerpt,
#edd_downloads_list .edd_download_content { display: none !important; }

/* =============================================================
   404 PAGE (v62)
   ============================================================= */
.mc-404__hero {
  background: var(--charcoal);
  padding: 100px 0 90px;
  text-align: center;
}
.mc-404__inner { max-width: 600px; margin: 0 auto; }
.mc-404__code {
  display: block;
  font-family: var(--serif);
  font-size: clamp(80px, 14vw, 160px);
  font-weight: 600;
  color: rgba(255,255,255,0.08);
  line-height: 1;
  margin-bottom: -20px;
  letter-spacing: -0.04em;
}
.mc-404__title {
  font-family: var(--serif);
  font-size: clamp(32px, 5vw, 52px);
  font-weight: 400;
  color: var(--white);
  margin: 0 0 16px;
  line-height: 1.1;
}
.mc-404__sub {
  font-family: var(--sans);
  font-size: 16px;
  color: rgba(255,255,255,0.45);
  line-height: 1.7;
  margin: 0 0 36px;
}
.mc-404__actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Suggested links */
.mc-404__links {
  background: var(--ash-beige);
  padding: 56px 0 72px;
}
.mc-404__links-title {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--slate);
  text-align: center;
  margin: 0 0 28px;
}
.mc-404__links-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  max-width: 760px;
  margin: 0 auto;
}
.mc-404__link {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 20px 24px;
  background: #fff;
  border: 1px solid var(--ash);
  border-radius: var(--radius-lg);
  text-decoration: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.mc-404__link:hover {
  border-color: var(--gold);
  box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.mc-404__link-label {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
}
.mc-404__link-desc {
  font-family: var(--sans);
  font-size: 12px;
  color: var(--slate);
}

@media (max-width: 600px) {
  .mc-404__hero { padding: 64px 0 56px; }
  .mc-404__links-grid { grid-template-columns: 1fr 1fr; }
  .mc-404__actions { flex-direction: column; align-items: center; }
}
@media (max-width: 400px) {
  .mc-404__links-grid { grid-template-columns: 1fr; }
}

/* =============================================================
   HERO IMAGE OVERLAYS (v63)
   When a background image is set via Customizer, overlay ensures
   text remains readable.
   ============================================================= */
.mc-edd-hero { position: relative; }
.mc-edd-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(28, 25, 23, 0.65);
}
.mc-edd-hero__eyebrow,
.mc-edd-hero__title,
.mc-edd-hero__sub { position: relative; z-index: 1; }

.mc-ji__hero { position: relative; overflow: hidden; }
.mc-ji__hero-inner { position: relative; z-index: 1; }

/* =============================================================
   LEGAL PAGES — shared styles (v68)
   ============================================================= */
.mc-legal__body { background: var(--ash-beige); padding: 64px 0 96px; }
.mc-legal__container { max-width: 780px; margin: 0 auto; padding: 0 48px; }
.mc-legal__highlight {
  background: var(--charcoal);
  color: rgba(255,255,255,0.85);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.6;
  margin-bottom: 40px;
}
.mc-legal__highlight strong { color: #fff; }
.mc-legal__updated { font-family: var(--sans); font-size: 12px; color: var(--slate); margin: 0 0 32px; }
.mc-legal__divider { border: none; border-top: 2px solid var(--ash); margin: 16px 0 48px; }
.mc-legal__section { padding: 16px 0 48px; }
.mc-legal__section-title { font-family: var(--serif); font-size: clamp(28px, 4vw, 40px); font-weight: 400; color: var(--ink); margin: 0 0 8px; }

/* Sticky jump-link nav on legal page */
.mc-legal__nav {
  background: #fff;
  border-bottom: 1px solid var(--ash);
  position: sticky;
  top: var(--header-h);
  z-index: 10;
}
.mc-legal__nav-inner { max-width: 780px; margin: 0 auto; padding: 0 48px; display: flex; }
.mc-legal__nav-link {
  display: block;
  padding: 14px 20px;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--slate);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: all 0.2s;
}
.mc-legal__nav-link:hover { color: var(--ink); border-bottom-color: var(--gold); }

/* Scroll offset for anchor links */
#privacy, #terms { scroll-margin-top: calc(var(--header-h) + 60px); }

@media (max-width: 600px) {
  .mc-legal__container, .mc-legal__nav-inner { padding: 0 20px; }
  .mc-legal__body { padding: 40px 0 64px; }
}

/* ══════════════════════════════════════════════════════════════════
   SEARCH OVERLAY
   ══════════════════════════════════════════════════════════════════ */
.mc-search-overlay {
  position: absolute;
  top: 0; left: 0; right: 0;
  background: var(--charcoal);
  z-index: 200;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.mc-search-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.mc-search-overlay__inner {
  display: flex;
  align-items: center;
  height: var(--header-h);
  padding: 0 var(--gap);
  max-width: var(--container);
  margin: 0 auto;
  gap: 12px;
}
.mc-search-overlay__form {
  display: flex;
  align-items: center;
  flex: 1;
  gap: 12px;
}
.mc-search-overlay__input {
  flex: 1;
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(255,255,255,0.3);
  color: var(--white);
  font-family: var(--serif);
  font-size: 22px;
  padding: 8px 0;
  outline: none;
  transition: border-color 0.2s;
}
.mc-search-overlay__input::placeholder { color: rgba(255,255,255,0.35); }
.mc-search-overlay__input:focus { border-bottom-color: var(--gold); }
.mc-search-overlay__submit {
  background: none;
  border: none;
  color: var(--white);
  cursor: pointer;
  padding: 4px;
  opacity: 0.7;
  transition: opacity 0.15s;
}
.mc-search-overlay__submit:hover { opacity: 1; }
.mc-search-overlay__close {
  background: none;
  border: none;
  color: rgba(255,255,255,0.6);
  cursor: pointer;
  padding: 4px;
  transition: color 0.15s;
}
.mc-search-overlay__close:hover { color: var(--white); }

/* ══════════════════════════════════════════════════════════════════
   SEARCH RESULTS PAGE
   ══════════════════════════════════════════════════════════════════ */

/* Hero */
.mc-search-hero {
  background: var(--charcoal);
  padding: 64px 0 56px;
  text-align: center;
}
.mc-search-hero__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gap);
}
.mc-search-hero__eyebrow {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}
.mc-search-hero__title {
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 600;
  color: var(--white);
  margin-bottom: 10px;
  line-height: 1.2;
}
.mc-search-hero__title em {
  color: var(--gold);
  font-style: italic;
}
.mc-search-hero__count {
  font-size: 13px;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.04em;
  margin-bottom: 32px;
}

/* Inline search bar in hero */
.mc-search-hero__form {
  display: flex;
  align-items: center;
  max-width: 560px;
  margin: 0 auto;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: var(--radius-pill);
  padding: 6px 6px 6px 24px;
  transition: border-color 0.2s;
}
.mc-search-hero__form:focus-within {
  border-color: var(--gold);
}
.mc-search-hero__input {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--white);
  font-family: var(--sans);
  font-size: 15px;
  outline: none;
  min-width: 0;
}
.mc-search-hero__input::placeholder { color: rgba(255,255,255,0.3); }
.mc-search-hero__submit {
  flex-shrink: 0;
  background: var(--gold);
  border: none;
  border-radius: var(--radius-pill);
  color: var(--white);
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s;
}
.mc-search-hero__submit:hover { background: var(--gold-dark); }

/* Main layout */
.mc-search-main {
  padding: 64px 0 96px;
  min-height: 40vh;
}
.mc-search-container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--gap);
}

/* Section heading */
.mc-search-section { margin-bottom: 64px; }
.mc-search-section__heading {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--serif);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 28px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--fog);
}
.mc-search-section__count {
  background: var(--gold);
  color: var(--white);
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  letter-spacing: 0.06em;
}

/* Product grid — reuses mc-edd-grid sizing */
.mc-search-product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

/* Journal results grid */
.mc-search-journal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.mc-search-journal-card {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
  padding: 20px;
  border: 1px solid var(--fog);
  border-radius: var(--radius-lg);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.mc-search-journal-card:hover {
  border-color: var(--ash);
  box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.mc-search-journal-card__img-wrap {
  flex-shrink: 0;
  width: 80px;
  height: 80px;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--fog);
}
.mc-search-journal-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mc-search-journal-card__body { flex: 1; min-width: 0; }
.mc-search-journal-card__cat {
  display: block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--gold);
  margin-bottom: 5px;
}
.mc-search-journal-card__title {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.35;
  margin-bottom: 6px;
}
.mc-search-journal-card__excerpt {
  font-size: 13px;
  color: var(--slate);
  line-height: 1.6;
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.mc-search-journal-card__meta {
  font-size: 11px;
  color: var(--ash);
}

/* Pagination */
.mc-search-pagination { margin-top: 48px; }

/* Empty / no results state */
.mc-search-empty {
  text-align: center;
  padding: 24px 0 48px;
  max-width: 600px;
  margin: 0 auto;
}
.mc-search-empty__icon {
  color: var(--ash);
  margin-bottom: 24px;
}
.mc-search-empty__title {
  font-family: var(--serif);
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 12px;
  line-height: 1.3;
}
.mc-search-empty__title em { color: var(--slate); font-style: italic; }
.mc-search-empty__sub {
  font-size: 15px;
  color: var(--slate);
  margin-bottom: 40px;
  line-height: 1.7;
}
/* Responsive */
@media (max-width: 1024px) {
  .mc-search-product-grid { grid-template-columns: repeat(3, 1fr); }
  .mc-search-journal-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .mc-search-product-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .mc-search-journal-grid { grid-template-columns: 1fr; }
  .mc-search-page-row__url { display: none; }
  .mc-search-hero { padding: 48px 0 40px; }
}
@media (max-width: 480px) {
  .mc-search-product-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════════
   HOMEPAGE — ALL PRINTS GRID SECTION
   ══════════════════════════════════════════════════════════════════ */
.mc-section--white { background: var(--white); }
.mc-hp-allprints { padding-bottom: 0; }
.mc-hp-filters { border-top: 1px solid var(--fog); }
.mc-hp-allprints__footer {
  text-align: center;
  padding: 40px 0 64px;
}
.mc-hp-allprints__footer .btn-ghost {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  border: 1px solid var(--ash);
  border-radius: var(--radius-pill);
  padding: 13px 32px;
  text-decoration: none;
  transition: all var(--transition);
  display: inline-block;
}
.mc-hp-allprints__footer .btn-ghost:hover {
  border-color: var(--charcoal);
  background: var(--charcoal);
  color: var(--white);
}

/* Curated tabs — grid wrapper override (no extra top/bottom pad, section handles it) */
.mc-collections__grid-wrap {
  padding-top: 0;
  padding-bottom: 32px;
}

/* ══════════════════════════════════════════════════════════════════
   POST-PURCHASE PAGES — BRANDED LAYOUT
   ══════════════════════════════════════════════════════════════════ */

/* Hero banner */
.mc-edd-page-hero {
  background: var(--charcoal);
  padding: 56px 20px 48px;
  text-align: center;
  border-bottom: 3px solid var(--gold);
}
.mc-edd-page-hero__inner {
  max-width: 600px;
  margin: 0 auto;
}
.mc-edd-page-hero__icon {
  color: var(--gold);
  margin-bottom: 20px;
}
.mc-edd-page-hero__icon svg {
  width: 48px;
  height: 48px;
  stroke: var(--gold);
}
.mc-edd-page-hero__eyebrow {
  display: block;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
}
.mc-edd-page-hero__title {
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 600;
  color: var(--white);
  margin: 0 0 14px;
  line-height: 1.2;
}
.mc-edd-page-hero__sub {
  font-family: var(--sans);
  font-size: 15px;
  color: rgba(255,255,255,0.55);
  line-height: 1.7;
  margin: 0;
}

/* Transaction failed — red accent */
.mc-edd-page-hero--failed {
  border-bottom-color: #C0392B;
}
.mc-edd-page-wrap--failed .mc-edd-page-hero__icon svg { stroke: #E74C3C; }
.mc-edd-page-wrap--failed .mc-edd-page-hero__eyebrow { color: #E74C3C; }

/* Content wrapper */
.mc-edd-page-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 48px 32px 24px;
}

/* Download links on success page */
.mc-edd-page-wrap .edd_purchase_receipt_products,
.mc-edd-page-wrap #edd_purchase_receipt {
  max-width: 100%;
  margin: 0;
  padding: 0;
}
.mc-edd-page-wrap .edd_download_file_title {
  font-family: var(--serif);
  font-size: 18px;
}

/* Order history table */
.mc-edd-page-wrap .edd-table,
.mc-edd-page-wrap table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--sans);
  font-size: 14px;
}
.mc-edd-page-wrap table th {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate);
  padding: 10px 12px;
  border-bottom: 2px solid var(--fog);
  text-align: left;
  background: var(--cream);
}
.mc-edd-page-wrap table td {
  padding: 14px 12px;
  color: var(--ink);
  border-bottom: 1px solid var(--fog);
  vertical-align: middle;
}
.mc-edd-page-wrap table tr:last-child td { border-bottom: none; }
.mc-edd-page-wrap table a { color: var(--gold); text-decoration: none; font-weight: 600; }
.mc-edd-page-wrap table a:hover { color: var(--gold-dark); }

/* EDD notice/error styling on these pages */
.mc-edd-page-wrap .edd_errors,
.mc-edd-page-wrap .edd-alert {
  background: #FEF9EC !important;
  border-color: var(--gold) !important;
  border-radius: 8px !important;
  padding: 16px 20px !important;
  margin-bottom: 24px !important;
}
.mc-edd-page-wrap--failed .edd_errors,
.mc-edd-page-wrap--failed .edd-alert {
  background: #FEF0EE !important;
  border-color: #E74C3C !important;
}

/* CTA strip below content */
.mc-edd-page-cta {
  text-align: center;
  padding: 32px 20px 72px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.mc-edd-page-cta__btn {
  display: inline-block;
  padding: 14px 36px;
  background: var(--charcoal);
  color: var(--white);
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 100px;
  transition: background 0.2s;
}
.mc-edd-page-cta__btn:hover { background: var(--gold); }
.mc-edd-page-cta__link {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--gold);
  text-decoration: none;
  font-weight: 600;
}
.mc-edd-page-cta__link:hover { color: var(--gold-dark); }

/* Responsive */
@media (max-width: 600px) {
  .mc-edd-page-hero { padding: 40px 20px 36px; }
  .mc-edd-page-wrap { padding: 32px 20px 16px; }
}

/* ══════════════════════════════════════════════════════════════════
   COOKIE / GDPR CONSENT BANNER
   ══════════════════════════════════════════════════════════════════ */
.mc-cookie-banner {
  position: fixed;
  bottom: 24px;
  left: 24px;
  right: 24px;
  max-width: 680px;
  z-index: 99999;
  background: var(--charcoal);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.35);
  transform: translateY(120%);
  opacity: 0;
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1), opacity 0.4s ease;
  pointer-events: none;
}
.mc-cookie-banner.is-visible {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.mc-cookie-banner__inner {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 20px 24px;
  flex-wrap: wrap;
}
.mc-cookie-banner__text { flex: 1; min-width: 200px; }
.mc-cookie-banner__title {
  display: block;
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--white);
  margin-bottom: 4px;
}
.mc-cookie-banner__desc {
  font-family: var(--sans);
  font-size: 13px;
  color: rgba(255,255,255,0.55);
  line-height: 1.6;
  margin: 0;
}
.mc-cookie-banner__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.mc-cookie-btn {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: none;
  border-radius: 100px;
  padding: 10px 20px;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.mc-cookie-btn--accept {
  background: var(--gold);
  color: var(--white);
}
.mc-cookie-btn--accept:hover { background: var(--gold-dark); }
.mc-cookie-btn--decline {
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.7);
}
.mc-cookie-btn--decline:hover {
  background: rgba(255,255,255,0.15);
  color: var(--white);
}
.mc-cookie-link {
  font-family: var(--sans);
  font-size: 11px;
  color: rgba(255,255,255,0.35);
  text-decoration: underline;
  text-underline-offset: 2px;
  white-space: nowrap;
}
.mc-cookie-link:hover { color: rgba(255,255,255,0.6); }
@media (max-width: 600px) {
  .mc-cookie-banner { left: 12px; right: 12px; bottom: 12px; }
  .mc-cookie-banner__inner { padding: 16px 18px; gap: 16px; }
  .mc-cookie-banner__actions { width: 100%; }
  .mc-cookie-btn { flex: 1; text-align: center; }
}
