:root{
  --teal:#006D77; --forest:#2B4C3D; --coral:#E76F51; --gold:#F4A261; --cream:#FDF4E3; --ink:#0c2a2a; --muted:#6b7b74
}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);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(--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}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(253,244,227,.9);backdrop-filter:saturate(140%) blur(4px);border-bottom:1px solid rgba(0,0,0,.06)}
.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:.3px}
.tagline{font-size:13px;color:var(--forest)}
.nav-links{display:flex;gap:10px;align-items:center}
.nav-links a{padding:10px 12px;border-radius:8px;white-space:nowrap}
.burger{display:none;gap:8px;flex-direction:column;border:0;background:transparent}
.burger span{width:26px;height:2px;background:var(--ink);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:var(--cream);border-bottom:1px solid rgba(0,0,0,.06)}
  .mobile-menu a{display:block;padding:14px 20px;border-top:1px solid rgba(0,0,0,.04)}
  .mobile-menu .cta-row{display:flex;gap:10px;padding:14px 20px}
}

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

/* ===== 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(253,244,227,.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(--teal);background:#fff;color:var(--teal);border-radius:999px;padding:6px 14px;font:700 15px inherit;cursor:pointer}
.pill.is-active{background:var(--teal);color:#fff}
#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(--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(--gold);color:#3b3b3b;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}
@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(--ink);
  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(--teal);background:#fff;color:var(--teal);border-radius:999px;padding:6px 14px;font:700 15px inherit;cursor:pointer}
.format-tabs button.is-active{background:var(--teal);color:#fff}
#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:#0a3a3a;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;        /* <- ensures inner text aligns */
  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;         /* <- match the control height */
  -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 vibe' mood buttons === */
#home-moods-grid .card { 
  background: rgba(0, 109, 119, 0.08); /* soft teal */
  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;   /* left aligned instead of centered */
}

#home-moods-grid .vibe-tile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  border-radius: 9999px;          /* pill shape */
  background: #008080;            /* teal background */
  border: 1px solid #006666;      /* slightly darker teal border */
  font-size: 0.95rem;
  font-weight: 600;
  color: #ffffff;                 /* white text */
  text-decoration: none;
  white-space: nowrap;
  transition: background-color .2s ease, transform .15s ease;
}

/* ===== MOBILE HERO FIX: Text below slideshow ===== */
@media (max-width: 768px) {
  /* Change masthead from position:relative to flex container */
  .masthead {
    display: block;
    position: relative;
  }
  
  /* Make slideshow take normal document flow */
  .masthead .slideshow {
    position: relative;
    height: 55vh;
    min-height: 340px;
    max-height: 500px;
  }
  
  /* Remove absolute positioning from container */
  .masthead > .container {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    z-index: 10;
    margin-top: -30px; /* Small overlap for visual connection */
  }
  
  /* Style hero card for below-slideshow position */
  .masthead .hero-card {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    width: 100%;
    max-width: none;
    background: rgba(253, 244, 227, 0.98);
    backdrop-filter: blur(8px);
    padding: 24px 20px;
  }
  
  /* Optimize text sizes for mobile */
  .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;
  }
  
  /* Ensure slideshow controls stay visible */
  .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);
  }
}
