:root{
  --war-office-red:#C8102E; --ministry-teal:#0F6B68; --ministry-navy:#1C1F2A; --paper-cream:#F8F5E6; --poster-black:#222222; --muted:#6b7b74
}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper-cream);color:var(--poster-black);font:18px/1.45 "Gill Sans","Gill Sans MT",Calibri,"Trebuchet MS",system-ui,-apple-system,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--ministry-teal);text-decoration:none}a:hover{opacity:.9}
.container{max-width:1160px;margin:0 auto;padding:0 20px}
.skip{position:fixed;left:8px;top:8px;z-index:999;background:#fff;border-radius:10px;padding:8px 12px;border:1px solid #ddd;transform:translateY(-120%);transition:.2s}
.skip:focus{transform:none}

/* Visually hidden utility */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ============================================
   DARK HEADER UPDATE
   ============================================
   Replace the existing .site-header styles in main.css with this
   ============================================ */

/* Header - Dark Background */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #1C1F2A; /* Ministry Navy - same as footer */
  border-bottom: 1px solid rgba(255,255,255,0.1);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
}

.brand img {
  width: 48px;
  height: 48px;
  border-radius: 50%;
}

.brand-title {
  font-weight: 700;
  letter-spacing: 0.3px;
  color: #fff; /* White text */
}

.tagline {
  font-size: 13px;
  color: rgba(255,255,255,0.8); /* Light gray */
}

.nav-links {
  display: flex;
  gap: 10px;
  align-items: center;
}

.nav-links a {
  padding: 10px 12px;
  border-radius: 8px;
  white-space: nowrap;
  color: rgba(255,255,255,0.9); /* Light text */
  transition: color 0.3s ease, background 0.3s ease;
}

.nav-links a:hover {
  color: #fff;
  background: rgba(255,255,255,0.1);
}

.burger {
  display: none;
  gap: 8px;
  flex-direction: column;
  border: 0;
  background: transparent;
}

.burger span {
  width: 26px;
  height: 2px;
  background: #fff; /* White burger lines */
  border-radius: 2px;
}

.mobile-menu {
  display: none;
}

.mobile-menu.open {
  display: block;
}

@media (max-width:900px) {
  .nav-links {
    display: none;
  }
  .burger {
    display: flex;
  }
  .mobile-menu {
    display: none;
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    background: #1C1F2A; /* Dark background for mobile menu too */
    border-bottom: 1px solid rgba(255,255,255,0.1);
  }
  .mobile-menu a {
    display: block;
    padding: 14px 20px;
    border-top: 1px solid rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.9);
  }
  .mobile-menu a:hover {
    background: rgba(255,255,255,0.1);
    color: #fff;
  }
  .mobile-menu .cta-row {
    display: flex;
    gap: 10px;
    padding: 14px 20px;
  }
}


.btn{display:inline-grid;place-items:center;background:var(--ministry-teal);color:#fff;padding:12px 18px;border-radius:12px;font-weight:700;cursor:pointer;border:0}
.btn-secondary{background:var(--war-office-red)}
.btn-outline{background:transparent;border:2px solid:var(--ministry-teal);color:var(--ministry-teal)}
.btn-outline:hover{background:var(--ministry-teal);color:#fff}

/* Black buttons that turn red on hover (for hero) */
.btn.btn-black, a.btn-black{background:#1C1F2A;color:#fff !important;transition:background 0.3s ease}
.btn.btn-black:hover, a.btn-black:hover{background:#C8102E;color:#fff !important}
.btn-outline-black{background:#fff !important;border:2px solid #1C1F2A !important;color:#1C1F2A !important;transition:all 0.3s ease}
.btn-outline-black:hover{background:#C8102E !important;border-color:#C8102E !important;color:#fff !important}

/* ===== Masthead & Slideshow ===== */
.masthead{position:relative;overflow:hidden}
.slideshow{position:relative;height:56vh;min-height:360px;max-height:740px}
@media (max-width:700px){.slideshow{height:48vh;min-height:280px}}
.slideshow.is-fallback{background:url("/assets/hero.jpg") center/cover no-repeat}
.slides{position:absolute;inset:0}
.slides.no-anim .slide{transition:none!important}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1200ms ease}
@keyframes wssKenBurns{0%{transform:scale(1)}100%{transform:scale(1.06)}}
.slide img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;will-change:transform}
.slideshow::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.08) 30%,rgba(0,0,0,.18));pointer-events:none;z-index:1}
.slideshow-ctrl{position:absolute;z-index:3;inset:0;display:flex;align-items:center;justify-content:space-between;pointer-events:none}
.ctrl-btn{pointer-events:auto;background:rgba(255,255,255,.8);border:0;border-radius:999px;width:42px;height:42px;display:grid;place-items:center;cursor:pointer;margin:0 10px;font-size:20px;line-height:1;color:#222}
.ctrl-btn:hover{background:#fff}
.slides-dots{position:absolute;z-index:3;bottom:10px;left:0;right:0;display:flex;justify-content:center;gap:8px}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.7);border:0;cursor:pointer}
.dot.is-active{background:#fff}
.masthead .hero-card{background: rgba(255,255,255,0.85);position:absolute;left:50%;transform:translateX(-50%);bottom:24px;z-index:4;width:min(960px,calc(100% - 32px))}
.hero-card:hover{background: rgba(255,255,255,0.92);}
@media (max-width:700px){.masthead .hero-card{bottom:16px}}
.hero-card{background:rgba(248,245,230,.95);border:1px solid rgba(0,0,0,.06);border-radius:20px;padding:28px}
.hero-card--center{text-align:center}
.hero-card--center .trust{justify-items:center}
.hero-card--center .btn-row{justify-content:center}
.hero h1{margin:0 0 8px;font-size:44px;line-height:1.1}
.hero p{margin:0 0 18px;max-width:60ch}
.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.trust div{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:10px;text-align:center;font-size:15px}
@media (max-width:900px){.hero h1{font-size:34px}.trust{grid-template-columns:1fr}}

/* Sections */
section{padding:56px 0}
.section-title{font-size:32px;margin:0 0 8px}
.sub{margin:0 0 20px;color:var(--muted)}

/* Shop grid */
#theme-pills{display:flex;gap:10px;flex-wrap:wrap;overflow:auto;padding:6px 0;min-height:42px}
.pill{
  border:2px solid var(--ministry-teal);
  background:#fff;
  color:var(--ministry-teal);
  border-radius:999px;
  padding:6px 14px;
  font-size: 15px;
  font-weight: 700 !important;
  cursor:pointer;
  transition: all 0.2s ease;
}
.pill:hover,
.pill.is-active{
  background:var(--war-office-red);
  color:#fff;
  border-color:var(--war-office-red);
}
#design-grid{display:flex;flex-wrap:wrap;gap:18px;margin:16px 0 8px;min-height:60px}
.design-card{width:calc(33.333% - 12px);text-align:center;cursor:pointer}
.design-card img{border-radius:12px;border:1px solid rgba(0,0,0,.06)}
.design-title{margin-top:8px;font:700 18px inherit;color:var(--ministry-teal)}
@media (max-width:820px){.design-card{width:calc(50% - 9px)}}
@media (max-width:460px){.design-card{width:100%}}
.loadbar{display:flex;justify-content:center;margin:10px 0 32px}

/* Cards */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:18px}
.card h3{margin:0 0 6px;font-size:20px}
.badge{display:inline-block;background:var(--war-office-red);color:#fff;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}

/* Ministry-approved button styling for homepage department pills */
.benefits a,
.benefits button {
  background: #fff;
  color: var(--ministry-teal);
  border: 2px solid var(--ministry-teal);
  border-radius: 999px;
  padding: 10px 20px;
  font-weight: 700 !important;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.2s ease;
  display: inline-block;
  text-decoration: none;
}

.benefits a:hover,
.benefits button:hover,
.benefits a.is-active,
.benefits button.is-active {
  background: var(--war-office-red);
  color: #fff;
  border-color: var(--war-office-red);
  opacity: 1;
}

@media (max-width:900px){.benefits{grid-template-columns:1fr}}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery img{border-radius:16px;border:1px solid rgba(0,0,0,.06)}
@media (max-width:900px){.gallery{grid-template-columns:1fr 1fr}}

/* FAQ */
details{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:14px 16px}
details+details{margin-top:10px}
summary{cursor:pointer;font-weight:700}

/* Modal */
.wss-modal{
  --m-pad: clamp(12px, 2vh, 24px);
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.45);
  padding: var(--m-pad);
  padding-top: max(var(--m-pad), env(safe-area-inset-top, 0px));
  display: flex; align-items: flex-start; justify-content: center;
  height: 100vh; height: 100dvh;
  box-sizing: border-box;
  overflow: auto;
}
.wss-modal[hidden]{display:none!important}
.wss-modal__box{
  background:#fff;color:var(--poster-black);
  width:min(760px,90%);
  max-height:calc(100vh - 2 * var(--m-pad));
  max-height:calc(100dvh - 2 * var(--m-pad));
  overflow-y:auto;
  border-radius:16px;padding:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  display:flex;flex-direction:column;align-items:center;position:relative;
  box-sizing:border-box;
  overscroll-behavior:contain;
}
.wss-modal__close{
  position:sticky;top:-8px;align-self:flex-end;
  background:rgba(255,255,255,.9);border:0;font-size:28px;line-height:1;
  cursor:pointer;color:#444;border-radius:12px;padding:6px 8px;z-index:2
}
.format-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:10px 0 16px}
.format-tabs button{border:2px solid var(--ministry-teal);background:#fff;color:var(--ministry-teal);border-radius:999px;padding:6px 14px;font:700 15px inherit;cursor:pointer}
.format-tabs button.is-active{background:var(--war-office-red);color:#fff;border-color:var(--war-office-red)}
#buybutton-container{display:flex;justify-content:center;align-items:center;width:100%}
#buybutton-container .shopify-buy__product,
#buybutton-container .shopify-buy__product__content,
#buybutton-container .shopify-buy__product__photo{background:transparent!important;box-shadow:none!important;border:0!important;padding:0!important;margin:0 auto!important;text-align:center}
#buybutton-container .shopify-buy__quantity{margin:0!important}
.shopify-buy__modal,.shopify-buy__background-overlay{display:none!important}

/* Reset margins inside buy button */
#buybutton-container,
#buybutton-container > div,
#buybutton-container .shopify-buy__product,
#buybutton-container .shopify-buy__product__content{
  margin:0!important;
}

/* Footer */
footer{background:var(--ministry-navy);color:#fff;padding:40px 0 30px;margin-top:60px}
.footer-grid{display:grid;gap:18px;grid-template-columns:2fr 1fr 1fr}
.footer-grid a{color:#fff;opacity:.9}
.legal{font-size:13px;opacity:.8;margin-top:10px}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr}}

/* Reduce motion */
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* Modal product images */
#buybutton-container .shopify-buy__product,
#buybutton-container .shopify-buy__product__content{width:100%!important;max-width:100%!important}
#buybutton-container .shopify-buy__product__photo{width:100%!important;max-width:none!important;margin:0 auto!important;flex:1 1 auto!important}
#buybutton-container .shopify-buy__product__photo img{width:100%!important;height:auto!important;object-fit:contain!important;display:block!important}
#buybutton-container .shopify-buy__product{display:grid!important;grid-template-columns:1fr;justify-items:center}
@media (max-width:700px){
  .wss-modal__box{width:96vw;border-radius:12px;padding:16px}
}

/* === Quantity input + Add to cart height fix (high specificity) === */
#buybutton-container .shopify-buy__product .shopify-buy__product__buttons,
#buybutton-container .shopify-buy__product .shopify-buy__btn-wrapper{
  display:flex !important;
  align-items:stretch !important;
}

#buybutton-container .shopify-buy__product .shopify-buy__btn,
#buybutton-container .shopify-buy__product .shopify-buy__btn-wrapper{
  height:54px !important;
  min-height:54px !important;
  box-sizing:border-box !important;
}

#buybutton-container .shopify-buy__product .shopify-buy__btn{
  padding:0 48px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
  margin:0 !important;
  border-radius:0 27px 27px 0 !important;
}

#buybutton-container .shopify-buy__product .shopify-buy__quantity,
#buybutton-container .shopify-buy__product .shopify-buy__quantity-input,
#buybutton-container .shopify-buy__product .shopify-buy__quantity-input input{
  height:54px !important;
  min-height:54px !important;
  line-height:54px !important;
  box-sizing:border-box !important;
}

#buybutton-container .shopify-buy__product .shopify-buy__quantity-input{
  display:flex !important;
  align-items:center !important;
  border:1px solid #cfd8dc !important;
  border-right:none !important;
  border-radius:8px 0 0 8px !important;
  background:#fff !important;
  margin:0 !important;
}

#buybutton-container .shopify-buy__product .shopify-buy__quantity-input input{
  width:64px !important;
  padding:0 10px !important;
  border:0 !important;
  background:transparent !important;
  text-align:center !important;
  font-size:16px !important;
  line-height:54px !important;
  -webkit-appearance:textfield; appearance:textfield;
}
#buybutton-container .shopify-buy__product .shopify-buy__quantity-input input::-webkit-outer-spin-button,
#buybutton-container .shopify-buy__product .shopify-buy__quantity-input input::-webkit-inner-spin-button{
  -webkit-appearance:none; margin:0;
}

/* As a final catch-all, force every direct child in the row to the same height */
#buybutton-container .shopify-buy__product .shopify-buy__product__buttons > *,
#buybutton-container .shopify-buy__product .shopify-buy__product__buttons > * *{
  height:54px !important;
  min-height:54px !important;
}


/* --- Home: three-square grid under On your wall --- */
#wall-squares{ margin-top: 16px; }
#wall-squares .grid-squares{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  width: 100%;
}
#wall-squares .square-tile{
  aspect-ratio: 1 / 1;
  background: #ffffff;
  border-radius: 20px;
  box-shadow: 0 8px 18px rgba(0,0,0,.12);
}
@media (max-width: 900px){
  #wall-squares .grid-squares{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  #wall-squares .grid-squares{ grid-template-columns: 1fr; }
}

/* --- Gift ideas grid basic styling --- */
#gift-ideas-grid{
  display:grid;
  grid-template-columns: repeat(3,minmax(0,1fr));
  gap:24px;
  width:100%;
  margin-top:24px;
}
#gift-ideas-grid .gift-card{
  aspect-ratio:4/3;
  border-radius:20px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 8px 18px rgba(0,0,0,.12);
  display:flex;
}
#gift-ideas-grid .gift-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}
@media(max-width:900px){
  #gift-ideas-grid{ grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media(max-width:560px){
  #gift-ideas-grid{ grid-template-columns:1fr; }
}

/* Hero CTA subtle hover animation */
.masthead .hero-card {
  background: rgba(255, 255, 255, 0.85);
  transition: background-color 0.4s ease;
}

.masthead .hero-card:hover {
  background: rgba(255, 255, 255, 0.95);
}


/* === Scoped overrides: Home 'Explore by department' buttons === */
#home-moods-grid .card { 
  background: rgba(15, 107, 104, 0.08);
  text-align: center;
}
#home-moods-grid .card > a {
  text-align: center;
  display: block;
}
#home-moods-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-start;
}

#home-moods-grid .vibe-tile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  border-radius: 9999px;
  background: #fff;
  border: 2px solid #0F6B68;
  font-size: 15px;
  font-weight: 700 !important;
  color: #0F6B68;
  text-decoration: none;
  white-space: nowrap;
  transition: all .2s ease;
}

#home-moods-grid .vibe-tile:hover,
#home-moods-grid .vibe-tile.is-active {
  background: #C8102E;
  border-color: #C8102E;
  color: #fff;
  transform: translateY(-1px);
}

/* Benefits list styling */
.benefits-list {
  list-style: none;
  padding: 0;
  margin: 24px 0 0 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.benefits-list li {
  font-weight: 700;
  color: #1C1F2A;
  font-size: 1.1rem;
  line-height: 1.4;
  display: flex;
  align-items: center;
  gap: 8px;
}

.benefits-list li::before {
  content: "✓";
  color: #C8102E;
  font-weight: 700;
  font-size: 1.2rem;
  margin-right: 6px;
}

/* ===== MOBILE HERO FIX: Text below slideshow ===== */
@media (max-width: 768px) {
  .masthead {
    display: block;
    position: relative;
  }
  
  .masthead .slideshow {
    position: relative;
    height: 55vh;
    min-height: 340px;
    max-height: 500px;
  }
  
  .masthead > .container {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    z-index: 10;
    margin-top: -30px;
  }
  
  .masthead .hero-card {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    width: 100%;
    max-width: none;
    background: rgba(248, 245, 230, 0.98);
    backdrop-filter: blur(8px);
    padding: 24px 20px;
  }
  
  .masthead .hero-card h1 {
    font-size: 24px;
    line-height: 1.2;
    margin-bottom: 12px;
  }
  
  .masthead .hero-card p {
    font-size: 15px;
    line-height: 1.4;
    margin-bottom: 18px;
  }
  
  .masthead .hero-card .btn {
    font-size: 14px;
    padding: 11px 18px;
  }
  
  .masthead .slideshow-ctrl {
    z-index: 5;
  }
  
  .masthead .ctrl-btn {
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  }
}
/* Position the Shopify cart iframe in the header area */
/* Cart positioning - Responsive version that's always visible */

/* Cart positioning - Clean responsive version */

/* Desktop: Position cart in header top-right */
.shopify-buy-frame--toggle {
  position: fixed !important;
  top: 18px !important;
  right: 20px !important;
  bottom: auto !important;
  left: auto !important;
  z-index: 100 !important;
  width: auto !important;
  height: 50px !important;
  border: none !important; /* Remove any borders */
}

/* On narrower screens, move to bottom-right as floating button */
@media (max-width: 1400px) {
  .shopify-buy-frame--toggle {
    top: auto !important;
    bottom: 20px !important;
    right: 20px !important;
    background: #1C1F2A !important; /* Dark background */
    padding: 12px 16px !important; /* More padding so icon doesn't touch edges */
    border-radius: 16px !important; /* More rounded */
    box-shadow: 0 4px 20px rgba(0,0,0,0.4) !important; /* Stronger shadow */
    border: none !important; /* Remove teal border */
    overflow: hidden !important; /* Hide any overflow */
  }
  
  /* Hide any iframe borders that might show through */
  .shopify-buy-frame--toggle iframe {
    border: none !important;
  }
}

/* On mobile, increase padding even more */
@media (max-width: 768px) {
  .shopify-buy-frame--toggle {
    bottom: 15px !important;
    right: 15px !important;
    background: #1C1F2A !important;
    padding: 14px 18px !important; /* Extra padding */
    border-radius: 18px !important;
    box-shadow: 0 6px 24px rgba(0,0,0,0.5) !important;
    border: none !important;
  }
}

/* Add this to the bottom of your main.css */

/* Hide SEO fallback department cards when JavaScript loads and replaces them */
.benefits .seo-fallback {
  display: block;
}

/* When home-moods.js loads, it will add this class to hide fallbacks */
.benefits.js-loaded .seo-fallback {
  display: none;
}

/* Alternatively, add this to home-moods.js after it populates the grid:
   document.getElementById('home-moods-grid').classList.add('js-loaded');
*/



}
