:root{
  --navy:#062847;
  --navy-2:#041b31;
  --blue:#0b3b66;
  --teal:#0b8395;
  --teal-2:#087282;
  --ice:#f5fbff;
  --ice-2:#edf7ff;
  --white:#fff;
  --line:#d7e6f0;
  --ink:#092945;
  --muted:#536d80;
  --soft:#f8fcff;
  --slate:#7c8b94;
  --shadow:0 22px 65px rgba(6,40,71,.12);
  --shadow-soft:0 12px 34px rgba(6,40,71,.07);
  --radius:22px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:linear-gradient(180deg,#fff 0%,var(--ice) 100%);color:var(--ink);font-family:"Segoe UI",Arial,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.admin-bar .site-header{top:32px}
a{color:inherit;text-decoration:none}
a:hover{color:var(--teal)}
img{max-width:100%;height:auto;display:block}
svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
button,input,select,textarea{font:inherit}

.brand,.brand-name,.brand-sub,.primary-nav,.utility-bar,.eyebrow,h1,h2,h3,.btn,.customizer-card label,.choice-grid button,.collection-card h3,.site-footer h4,.page-kicker,.section-title span,.section-heading-row span{font-family:"Eras Bold ITC","Eras Demi ITC","Trebuchet MS","Arial Rounded MT Bold",Arial,sans-serif;letter-spacing:.045em;text-transform:uppercase}

/* Header */
.site-header{position:relative;z-index:100;background:rgba(255,255,255,.98);border-bottom:1px solid var(--line);box-shadow:0 8px 24px rgba(6,40,71,.06)}
.utility-bar{min-height:30px;background:linear-gradient(90deg,var(--navy-2),var(--navy));color:#f1f9ff;display:flex;align-items:center;justify-content:center;gap:46px;padding:7px 20px;font-size:11px;font-weight:900;letter-spacing:.11em;line-height:1.2;text-align:center}
.utility-bar a{color:#fff}
.nav-wrap{max-width:1680px;margin:0 auto;min-height:86px;padding:0 42px;display:flex;align-items:center;gap:34px}
.brand{flex:0 0 255px;color:var(--navy);line-height:1;text-align:left;display:block}
.brand-gg{display:block;font-family:Georgia,serif;font-size:34px;font-weight:900;letter-spacing:-.09em;line-height:.82;text-transform:none}
.brand-name{display:block;font-size:16px;font-weight:900;letter-spacing:.30em;margin-top:5px}
.brand-sub{display:block;font-size:10px;font-weight:900;letter-spacing:.50em;margin-top:5px}
.custom-logo{max-height:64px;width:auto}
.primary-nav{flex:1;min-width:0}
.primary-nav ul,.primary-nav li,.primary-nav .menu,.menu,.menu li{list-style:none!important;margin:0!important;padding:0!important}
.primary-nav .menu{display:flex!important;align-items:center;justify-content:center;gap:30px;flex-wrap:nowrap!important;white-space:nowrap}
.primary-nav li::before,.primary-nav li::after,.menu li::before,.menu li::after{content:none!important;display:none!important}
.primary-nav a{display:block;color:var(--navy);font-size:13px;font-weight:900;letter-spacing:.09em;text-transform:uppercase;padding:31px 0 27px;border-bottom:3px solid transparent;line-height:1}
.primary-nav a:hover,.primary-nav .current-menu-item>a{color:var(--teal);border-color:var(--teal)}
.nav-icons{flex:0 0 145px;display:flex;justify-content:flex-end;gap:20px;align-items:center;color:var(--navy)}
.nav-icons a{position:relative;display:grid;place-items:center;width:34px;height:34px}
.nav-icons svg{width:25px;height:25px;stroke-width:1.95}
.cart-link span{position:absolute;right:-7px;top:-8px;background:var(--navy);color:#fff;border-radius:99px;font-size:10px;min-width:19px;height:19px;display:grid;place-items:center;font-weight:900}
.mobile-toggle{display:none;background:#fff;border:1px solid var(--line);border-radius:12px;color:var(--navy);align-items:center;gap:8px;font-weight:900;letter-spacing:.08em;cursor:pointer;padding:8px 11px}
.mobile-toggle span{display:block;width:21px;height:2px;background:var(--navy);margin:4px 0;border-radius:8px}.mobile-toggle em{font-style:normal;font-size:12px}

/* Layout */
.site-main{overflow:hidden}
.section-pad{max-width:1580px;margin:0 auto;padding:58px 54px}
.section-title{text-align:center;margin-bottom:32px}
.section-title span,.section-heading-row span,.eyebrow,.page-kicker{color:var(--teal);font-size:12px;font-weight:900;letter-spacing:.12em}
.section-title h2,.section-heading-row h2{font-size:34px;line-height:1.1;margin:9px 0 0;color:var(--navy)}
.section-heading-row{max-width:1580px;margin:0 auto 28px;display:flex;align-items:end;justify-content:space-between;gap:20px}
.section-heading-row a{font-weight:900;color:var(--teal);font-size:14px}

/* Hero */
.hero-section{background:radial-gradient(circle at 50% 0%,#fff 0%,#f7fbff 45%,#eef7ff 100%);border-bottom:1px solid var(--line)}
.hero-inner{max-width:1680px;margin:0 auto;padding:54px 54px 48px;display:grid;grid-template-columns:minmax(320px,455px) minmax(520px,1fr) minmax(330px,405px);gap:30px;align-items:center}
.hero-copy h1{font-size:clamp(46px,4.35vw,76px);line-height:.98;margin:14px 0 20px;color:var(--navy);letter-spacing:.035em;max-width:480px}
.hero-sub{font-size:21px;line-height:1.55;color:#274961;max-width:470px;margin:0 0 28px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border-radius:12px;padding:16px 24px;font-size:13px;font-weight:900;letter-spacing:.08em;line-height:1;text-transform:uppercase;transition:.18s ease}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 14px 30px rgba(6,40,71,.18)}
.btn-primary:hover{background:var(--teal);color:#fff;transform:translateY(-1px)}
.btn-secondary{background:#fff;border:1px solid #a9c3d5;color:var(--navy)}
.btn-secondary:hover{border-color:var(--teal);color:var(--teal)}
.btn-light{background:#fff;color:var(--navy)}
.hero-image-card{margin:0;border-radius:0;overflow:visible;align-self:center}
.hero-image-card img{width:100%;height:auto;object-fit:contain;border-radius:0;filter:drop-shadow(0 22px 32px rgba(6,40,71,.11))}
.customizer-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px 32px;box-shadow:var(--shadow);align-self:center}
.customizer-card h2{font-size:25px;margin:0 0 8px;color:var(--navy)}
.customizer-card p{color:var(--muted);margin:0 0 22px;font-size:14px}
.customizer-card label{display:block;font-size:11px;color:var(--navy);font-weight:900;margin:16px 0 8px;letter-spacing:.08em}
.customizer-card label small{font-size:9px;color:var(--muted)}
.customizer-card input{width:100%;height:52px;border:1px solid #bfd1df;border-radius:9px;padding:0 14px;color:var(--navy);font-weight:900;background:#fbfdff;text-transform:uppercase}
.choice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
.choice-grid button{height:40px;border:1px solid #c8d9e5;background:#fff;border-radius:9px;color:var(--navy);font-size:10px;font-weight:900;cursor:pointer}
.choice-grid button.active,.choice-grid button:hover{border-color:var(--teal);background:#effbfc}
.swatches{display:flex;gap:9px}.swatches button{width:38px;height:38px;border-radius:99px;border:2px solid #fff;box-shadow:0 0 0 1px #c6d7e3;cursor:pointer}.swatches button.active{box-shadow:0 0 0 3px var(--navy)}.swatches .navy{background:var(--navy)}.swatches .teal{background:var(--teal)}.swatches .slate{background:#7e8991}.swatches .white{background:#f3f6f7}
.preview-name{height:84px;border-radius:8px;background:linear-gradient(135deg,var(--navy),#0b3a64);display:grid;place-items:center;color:#fff;font-family:Georgia,serif;font-size:44px;font-weight:900;letter-spacing:.17em;box-shadow:inset 0 0 0 1px rgba(255,255,255,.15)}
.add-cart{margin-top:14px;display:flex;justify-content:center;background:var(--teal);color:#fff;border-radius:9px;padding:16px;font-weight:900;font-size:13px;letter-spacing:.07em;text-transform:uppercase}
.add-cart:hover{background:var(--navy);color:#fff}.free-ship{text-align:center;color:var(--teal)!important;margin:14px 0 0!important;font-size:13px!important}

/* Feature strip */
.feature-strip{max-width:1680px;margin:0 auto;padding:23px 54px;background:#fff;border-bottom:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.feature-strip article{display:flex;align-items:center;gap:16px;padding:0 22px;border-right:1px solid var(--line)}
.feature-strip article:last-child{border-right:0}.feature-strip svg{width:34px;height:34px;color:var(--navy);stroke-width:1.8;flex:0 0 auto}.feature-strip strong{display:block;color:var(--navy);font-size:13px;text-transform:uppercase;letter-spacing:.07em}.feature-strip span{display:block;color:var(--muted);font-size:13px;line-height:1.3}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.steps article{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-soft);padding:22px;display:grid;grid-template-columns:52px 1fr 150px;gap:18px;align-items:center;min-height:145px}
.steps article>span{width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:900;font-size:20px}
.steps h3{margin:0 0 7px;color:var(--navy);font-size:17px}.steps p{margin:0;color:var(--muted);font-size:15px;line-height:1.35}
.steps img{width:150px;height:82px;object-fit:contain;background:#f7fbff;border-radius:12px}

/* Collections */
.collections{padding-top:36px}
.collection-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:14px}
.collection-card{min-height:176px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 28px rgba(6,40,71,.05);overflow:hidden;display:grid;grid-template-rows:1fr 90px;transition:.18s ease}
.collection-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);color:inherit}.collection-card div{padding:18px 16px 0}.collection-card h3{font-size:15px;line-height:1.05;color:var(--navy);margin:0 0 12px}.collection-card span{font-size:12px;color:var(--teal);font-weight:900;letter-spacing:.06em;text-transform:uppercase}
.collection-card img{width:100%;height:90px;object-fit:contain;background:linear-gradient(180deg,#fff,#f4f9fd);padding:8px}

/* Products */
.best-sellers{padding-top:48px}
.product-showcase{display:grid;grid-template-columns:1fr 410px;gap:28px;max-width:1580px;margin:0 auto}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.product-tile{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 12px 30px rgba(6,40,71,.06);overflow:hidden;padding:16px;transition:.18s ease}
.product-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft);color:inherit}.product-media{height:170px;border-radius:14px;background:linear-gradient(180deg,#fff,#f3f8fc);display:grid;place-items:center;overflow:hidden;margin-bottom:16px}.product-media img{width:100%;height:100%;object-fit:contain;padding:6px}
.product-tile h3{font-size:18px;margin:0 0 10px;color:var(--navy);text-transform:none;letter-spacing:0}.product-tile p{font-size:13px;color:var(--navy);margin:0 0 8px}.product-tile p span{color:var(--muted)}.product-tile strong{font-size:18px;color:var(--navy)}
.review-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-soft);padding:30px;display:flex;flex-direction:column;gap:14px}.review-card .stars{letter-spacing:.18em;color:var(--navy);font-size:16px}.review-card h3{font-size:28px;color:var(--navy);margin:0}.review-card p{font-size:18px;line-height:1.55;color:#28475e;margin:0}.review-card strong{color:var(--navy)}.review-card img{border-radius:16px;margin-top:auto;width:100%;height:250px;object-fit:cover}

/* Story / gallery */
.story-band{max-width:1500px;margin:32px auto 62px;padding:0 54px}.story-band>div{background:linear-gradient(135deg,var(--navy),#0b426f);color:#fff;border-radius:26px;padding:56px 60px;box-shadow:var(--shadow)}
.story-band span{display:block;color:#39bdcd;font-weight:900;font-size:13px;letter-spacing:.11em;text-transform:uppercase}.story-band h2{max-width:840px;color:#fff;font-size:36px;line-height:1.14;margin:12px 0 18px}.story-band p{max-width:1000px;color:#e7f5ff;font-size:20px;line-height:1.6;margin:0 0 28px}
.gallery-strip{display:grid;grid-template-columns:repeat(6,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.gallery-strip img{width:100%;height:160px;object-fit:cover;border-radius:0}

/* Pages */
.page-hero{background:linear-gradient(135deg,#fff 0%,#f2f9ff 100%);border-bottom:1px solid var(--line);padding:70px 24px 56px;text-align:center}
.page-hero-inner{max-width:900px;margin:0 auto}.page-hero h1{font-size:clamp(42px,4.2vw,68px);line-height:1.02;color:var(--navy);margin:10px 0 18px}.page-hero p{font-size:20px;line-height:1.55;color:#38556b;margin:0 auto;max-width:760px}
.page-shell{max-width:980px;margin:54px auto 70px;padding:0 24px}.content-card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-soft);padding:56px 62px}.entry-content{font-size:18px;line-height:1.72;color:#183a54}.entry-content h1,.entry-content h2,.entry-content h3{color:var(--navy);text-transform:none;letter-spacing:0}.entry-content h2{font-size:30px;margin:34px 0 12px}.entry-content h3{font-size:23px;margin:28px 0 10px}.entry-content p{margin:0 0 22px}.entry-content ul,.entry-content ol{padding-left:24px;margin:0 0 24px}.entry-content li{margin:0 0 8px}

/* WooCommerce */
.woocommerce .site-main,.woocommerce-page .site-main{max-width:1320px;margin:0 auto;padding:42px 28px}.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-soft);padding:18px!important;overflow:hidden}.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit,.woocommerce button.single_add_to_cart_button{background:var(--navy)!important;color:#fff!important;border-radius:12px!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.06em!important}.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover{background:var(--teal)!important;color:#fff!important}

/* Footer */
.site-footer{background:linear-gradient(145deg,var(--navy-2),var(--navy));color:#fff;margin-top:0}.footer-grid{max-width:1580px;margin:0 auto;padding:54px;display:grid;grid-template-columns:1.2fr .75fr .9fr .75fr 1.1fr 260px;gap:34px}.site-footer h4{font-size:14px;margin:0 0 16px;color:#fff}.site-footer a{display:block;color:#e3f1fb;margin:0 0 9px;font-size:14px}.site-footer a:hover{color:#fff}.footer-brand p,.newsletter p,.standard-seal p{color:#c7dcea;line-height:1.55}.footer-logo{color:#fff}.newsletter form{display:flex;gap:8px}.newsletter input{height:42px;border:0;border-radius:8px;padding:0 12px;width:100%}.newsletter button{height:42px;border:0;border-radius:8px;background:var(--teal);color:#fff;font-weight:900;padding:0 18px}.socials{display:flex;gap:10px;margin-top:16px;color:#fff}.standard-seal{border:1px solid rgba(255,255,255,.28);border-radius:999px;width:170px;height:170px;display:grid;place-items:center;text-align:center;margin:auto}.standard-seal span{font-family:Georgia,serif;font-size:34px;font-weight:900}.standard-seal strong{font-size:11px;letter-spacing:.14em;text-transform:uppercase}

/* Mobile */
@media(max-width:1280px){
  .nav-wrap{padding:0 28px;gap:22px}.brand{flex-basis:230px}.primary-nav .menu{gap:20px}.primary-nav a{font-size:12px}
  .hero-inner{grid-template-columns:minmax(270px,370px) 1fr minmax(300px,360px);padding:42px 36px}.hero-copy h1{font-size:52px}.hero-sub{font-size:18px}
  .collection-grid{grid-template-columns:repeat(4,1fr)}.product-showcase{grid-template-columns:1fr}.review-card{display:grid;grid-template-columns:1fr 320px}.review-card img{height:210px}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:980px){
  body.admin-bar .site-header{top:0}.utility-bar{display:none}.nav-wrap{min-height:70px;display:grid;grid-template-columns:auto 1fr auto;padding:0 18px}.brand{grid-column:2;justify-self:center;text-align:center;min-width:0;flex-basis:auto}.brand-gg{font-size:30px}.brand-name{font-size:13px}.brand-sub{font-size:9px}.mobile-toggle{display:flex;grid-column:1}.nav-icons{grid-column:3;flex-basis:auto;gap:10px}.nav-icons a:nth-child(1),.nav-icons a:nth-child(2){display:none}.primary-nav{position:absolute;left:0;right:0;top:70px;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 20px 30px rgba(6,40,71,.1);display:none}.primary-nav.open{display:block}.primary-nav .menu{display:block!important}.primary-nav a{padding:16px 24px;border-bottom:1px solid var(--line)}
  .hero-inner{grid-template-columns:1fr;gap:24px;padding:28px 20px 34px}.hero-copy{text-align:center}.hero-copy h1{max-width:none;font-size:42px}.hero-sub{margin-left:auto;margin-right:auto}.cta-row{justify-content:center}.hero-image-card{order:-1}.customizer-card{max-width:520px;margin:0 auto;width:100%}
  .feature-strip{grid-template-columns:repeat(2,1fr);padding:18px 20px}.feature-strip article{padding:14px;border-right:0;border-bottom:1px solid var(--line)}.feature-strip article:last-child{grid-column:1/-1;border-bottom:0}
  .section-pad{padding:42px 20px}.steps{grid-template-columns:1fr}.steps article{grid-template-columns:46px 1fr 120px}.collection-grid{grid-template-columns:repeat(2,1fr)}.product-grid{grid-template-columns:repeat(2,1fr)}
  .story-band{padding:0 20px}.story-band>div{padding:36px 28px}.story-band h2{font-size:28px}.story-band p{font-size:17px}.gallery-strip{grid-template-columns:repeat(3,1fr)}.gallery-strip img{height:120px}
  .content-card{padding:34px 24px}.footer-grid{grid-template-columns:1fr 1fr;padding:38px 24px}.standard-seal{margin:0}
}
@media(max-width:640px){
  .hero-copy h1{font-size:34px}.hero-sub{font-size:16px}.btn{width:100%}.choice-grid{grid-template-columns:repeat(2,1fr)}.preview-name{font-size:34px}.feature-strip{grid-template-columns:1fr}.feature-strip article{border-bottom:1px solid var(--line)}.section-title h2,.section-heading-row h2{font-size:26px}.section-heading-row{display:block}.steps article{grid-template-columns:44px 1fr}.steps img{grid-column:1/-1;width:100%;height:100px}.collection-grid,.product-grid{grid-template-columns:1fr}.review-card{display:block}.review-card img{margin-top:18px}.gallery-strip{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr}.newsletter form{display:block}.newsletter button{margin-top:8px;width:100%}.page-hero{padding:44px 20px}.page-hero h1{font-size:34px}.page-hero p{font-size:16px}.page-shell{margin:32px auto}.content-card{border-radius:18px}.entry-content{font-size:16px}
}

/* ==========================================================
   V8 HERO MATCH PREMIUM OVERRIDE
   Built from v8; replaces only the homepage hero with the
   supplied premium hero mockup direction.
   ========================================================== */

.hero-match-section{
  position:relative;
  width:100%;
  max-width:100%;
  overflow:hidden;
  background:#f4f8fb;
  border-bottom:1px solid var(--line);
  line-height:0;
}

.hero-match-image{
  display:block;
  width:100%;
  height:auto;
  border-radius:0 !important;
  box-shadow:none !important;
}

.hero-match-seo{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* Invisible click zones over the baked-in hero buttons/card button */
.hero-click{
  position:absolute;
  z-index:4;
  display:block;
  border-radius:10px;
}

.hero-shop{
  left:4.1%;
  top:71.6%;
  width:13.4%;
  height:6.7%;
}

.hero-personalize{
  left:18.7%;
  top:71.6%;
  width:11.6%;
  height:6.7%;
}

.hero-card-cta{
  right:4.3%;
  top:82.8%;
  width:22.2%;
  height:7.2%;
}

.hero-click:focus-visible{
  outline:3px solid var(--teal);
  outline-offset:4px;
  background:rgba(8,127,143,.08);
}

.hero-mobile-live{
  display:none;
}

/* Header stays v8, but this tightens the first visual transition into the hero */
.home .site-header{
  box-shadow:0 8px 24px rgba(6,40,71,.055);
}

.home .utility-bar{
  background:linear-gradient(90deg,#031b30,#062743);
}

/* Keep the below-hero sections close to v8 but slightly tighter after the hero image */
.home .feature-strip{
  border-top:0;
}

/* Mobile fallback: use live hero content instead of shrinking the baked desktop mockup too small */
@media(max-width: 900px){
  .hero-match-section{
    display:none;
  }

  .hero-mobile-live{
    display:grid;
    grid-template-columns:1fr;
    gap:22px;
    padding:34px 20px 38px;
    background:linear-gradient(180deg,#ffffff 0%,#eef8ff 100%);
    border-bottom:1px solid var(--line);
  }

  .hero-mobile-copy{
    text-align:center;
    max-width:620px;
    margin:0 auto;
  }

  .hero-mobile-copy h1{
    font-size:38px;
    line-height:1;
    margin:12px 0 14px;
    color:var(--navy);
  }

  .hero-mobile-copy p{
    font-size:16px;
    line-height:1.55;
    color:var(--muted);
    margin:0 auto 20px;
  }

  .hero-mobile-live img{
    width:100%;
    max-width:620px;
    margin:0 auto;
    border-radius:18px;
    box-shadow:var(--shadow-soft);
    background:#fff;
  }

  .hero-mobile-live .cta-row{
    justify-content:center;
  }
}

@media(max-width: 640px){
  .hero-mobile-copy h1{
    font-size:32px;
  }

  .hero-mobile-live{
    padding:28px 16px 32px;
  }
}


/* ==========================================================
   V8 HERO MATCH COMPACT POLISH
   Keeps the approved hero image but fits the hero better
   above the fold on standard laptop/desktop screens.
   ========================================================== */
@media(min-width:901px){
  .hero-match-section{
    height:clamp(500px, calc(100vh - 154px), 650px);
    min-height:500px;
  }

  .hero-match-image{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center top;
  }

  .hero-shop{
    left:4.1%;
    top:71.4%;
    width:13.4%;
    height:7.2%;
  }

  .hero-personalize{
    left:18.7%;
    top:71.4%;
    width:11.6%;
    height:7.2%;
  }

  .hero-card-cta{
    right:4.3%;
    top:82.6%;
    width:22.2%;
    height:7.6%;
  }
}

@media(min-width:1400px){
  .hero-match-section{
    height:clamp(560px, calc(100vh - 154px), 720px);
  }
}


/* ==========================================================
   V8 SHOP SIGNATURE — FULL CUSTOM SHOP PAGE
   Matching the supplied premium shop reference.
   ========================================================== */

body.woocommerce-shop .site-main,
body.post-type-archive-product .site-main,
body.tax-product_cat .site-main,
body.page-shop .site-main{
  max-width:none !important;
  width:100% !important;
  margin:0 !important;
  padding:0 !important;
  overflow:hidden !important;
}

body.woocommerce-shop .page-hero,
body.post-type-archive-product .page-hero,
body.tax-product_cat .page-hero,
body.page-shop .page-hero,
body.woocommerce-shop .content-card,
body.post-type-archive-product .content-card,
body.tax-product_cat .content-card,
body.page-shop .content-card,
body.woocommerce-shop .page-shell,
body.post-type-archive-product .page-shell,
body.tax-product_cat .page-shell,
body.page-shop .page-shell{
  display:none !important;
}

.ggb-signature-shop-hero{
  position:relative;
  min-height:350px;
  display:grid;
  grid-template-columns:minmax(330px,42%) minmax(420px,1fr);
  align-items:center;
  gap:26px;
  padding:54px 6.6vw 38px;
  background:
    radial-gradient(circle at 62% 28%,rgba(255,255,255,.96),rgba(255,255,255,.48) 34%,transparent 68%),
    linear-gradient(135deg,#fff 0%,#fbfdff 42%,#edf7ff 100%);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}

.ggb-signature-shop-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.78) 38%,rgba(255,255,255,.18) 70%,rgba(255,255,255,.96) 100%);
  pointer-events:none;
}

.ggb-signature-shop-copy,
.ggb-signature-shop-stage{
  position:relative;
  z-index:1;
}

.ggb-signature-shop-copy span{
  display:block;
  color:var(--teal);
  font-size:13px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:11px;
}

.ggb-signature-shop-copy h1{
  font-family:Georgia,"Times New Roman",serif;
  color:var(--navy);
  text-transform:uppercase;
  letter-spacing:.075em;
  font-size:clamp(62px,7.2vw,98px);
  line-height:.88;
  margin:0 0 18px;
}

.ggb-signature-shop-copy p{
  max-width:420px;
  margin:0;
  color:#24465d;
  font-size:20px;
  line-height:1.55;
}

.ggb-signature-shop-stage{
  display:flex;
  justify-content:flex-end;
  align-self:end;
}

.ggb-signature-shop-stage img{
  width:min(890px,100%);
  max-height:330px;
  object-fit:contain;
  object-position:center bottom;
  border-radius:0 !important;
  filter:drop-shadow(0 24px 34px rgba(6,40,71,.14));
}

.ggb-signature-shop-shell{
  max-width:1480px;
  margin:0 auto;
  padding:38px 42px 34px;
}

.ggb-signature-categories{
  display:grid;
  grid-template-columns:1.35fr repeat(6, 1fr);
  gap:0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:25px;
  box-shadow:var(--shadow-soft);
  padding:16px;
  margin-bottom:22px;
}

.ggb-signature-categories a{
  min-height:56px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-right:1px solid var(--line);
  color:var(--navy);
  font-weight:900;
  font-size:13px;
  letter-spacing:.055em;
  text-transform:uppercase;
  padding:0 12px;
}

.ggb-signature-categories a:last-child{
  border-right:0;
}

.ggb-signature-categories a.active{
  background:var(--navy);
  color:#fff;
  border-radius:12px;
  border-right:0;
}

.ggb-signature-categories svg{
  width:22px;
  height:22px;
  stroke-width:1.75;
}

.ggb-signature-catalog{
  background:#fff;
  border:1px solid var(--line);
  border-radius:25px;
  box-shadow:0 18px 42px rgba(6,40,71,.07);
  padding:24px;
}

.ggb-signature-filters{
  display:grid;
  grid-template-columns:repeat(4,minmax(145px,1fr)) minmax(170px,1fr);
  gap:16px;
  margin-bottom:14px;
}

.ggb-signature-filters label span{
  display:block;
  color:#667b8d;
  text-transform:uppercase;
  letter-spacing:.09em;
  font-size:10px;
  font-weight:900;
  margin-bottom:7px;
}

.ggb-signature-filters select{
  width:100%;
  height:52px;
  border:1px solid #cddde8;
  border-radius:12px;
  color:var(--navy);
  background:#fff;
  padding:0 14px;
  font-size:15px;
}

.ggb-signature-filters .sort{
  justify-self:end;
  width:100%;
}

.ggb-signature-results{
  color:var(--muted);
  font-size:14px;
  margin-bottom:16px;
}

.ggb-signature-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}

.ggb-signature-product-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 12px 30px rgba(6,40,71,.06);
  transition:.18s ease;
}

.ggb-signature-product-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 42px rgba(6,40,71,.11);
}

.ggb-signature-card-media{
  position:relative;
  height:210px;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:linear-gradient(180deg,#fff,#f7fbfd);
}

.ggb-signature-card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:0 !important;
}

.ggb-heart{
  position:absolute;
  top:13px;
  right:13px;
  width:34px;
  height:34px;
  border-radius:50%;
  background:#fff;
  border:1px solid var(--line);
  color:var(--navy);
  display:grid;
  place-items:center;
  font-size:22px;
  box-shadow:0 8px 16px rgba(6,40,71,.08);
}

.ggb-signature-card-body{
  padding:16px 18px 18px;
}

.ggb-product-kicker{
  display:block;
  color:var(--teal);
  font-size:10px;
  font-weight:900;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:7px;
}

.ggb-signature-card-body h2{
  color:var(--navy);
  font-size:19px;
  line-height:1.15;
  margin:0 0 9px;
  letter-spacing:0;
  text-transform:none;
}

.ggb-rating{
  color:var(--navy);
  font-size:13px;
  margin-bottom:7px;
}

.ggb-rating em{
  color:var(--muted);
  font-style:normal;
  margin-left:4px;
}

.ggb-price{
  color:var(--navy);
  font-size:17px;
  font-weight:900;
  margin-bottom:10px;
}

.ggb-price .woocommerce-Price-amount,
.ggb-price bdi{
  color:var(--navy);
}

.ggb-swatches{
  display:flex;
  gap:8px;
  margin-bottom:15px;
}

.ggb-swatches i{
  width:18px;
  height:18px;
  border-radius:999px;
  border:2px solid #fff;
  box-shadow:0 0 0 1px #c9d8e2;
}

.ggb-swatches .navy{background:var(--navy);}
.ggb-swatches .teal{background:var(--teal);}
.ggb-swatches .slate{background:#7f8c95;}
.ggb-swatches .cream{background:#e9e3d7;}
.ggb-swatches .black{background:#222;}

.ggb-card-buttons{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.ggb-card-buttons a{
  min-height:42px;
  border-radius:9px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:900;
  letter-spacing:.07em;
  text-transform:uppercase;
}

.ggb-card-buttons .quick-view{
  border:1px solid #9fb7c9;
  color:var(--navy);
  background:#fff;
}

.ggb-card-buttons .quick-view:hover{
  border-color:var(--teal);
  color:var(--teal);
}

.ggb-card-buttons .cart-button{
  background:var(--navy);
  color:#fff;
  border:1px solid var(--navy);
}

.ggb-card-buttons .cart-button:hover{
  background:var(--teal);
  border-color:var(--teal);
  color:#fff;
}

.ggb-view-more{
  display:flex;
  justify-content:center;
  padding-top:22px;
}

.ggb-view-more a{
  min-width:300px;
  min-height:48px;
  border-radius:10px;
  background:var(--navy);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:13px;
}

.ggb-view-more a:hover{
  background:var(--teal);
  color:#fff;
}

.ggb-signature-trust-strip{
  max-width:none;
  background:#fbfdff;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:28px 6.5vw;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
}

.ggb-signature-trust-strip article{
  display:flex;
  align-items:center;
  gap:18px;
  padding:0 28px;
  border-right:1px solid var(--line);
}

.ggb-signature-trust-strip article:last-child{
  border-right:0;
}

.ggb-signature-trust-strip svg{
  width:40px;
  height:40px;
  color:var(--navy);
  stroke-width:1.7;
  flex:0 0 auto;
}

.ggb-signature-trust-strip strong{
  display:block;
  color:var(--navy);
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.ggb-signature-trust-strip span{
  display:block;
  color:var(--muted);
  font-size:14px;
  line-height:1.35;
}

/* Remove Woo default shop noise if any still slips through */
.ggb-signature-shop-shell .woocommerce-result-count,
.ggb-signature-shop-shell .woocommerce-ordering,
.ggb-signature-shop-shell ul.products{
  display:none !important;
}

@media(max-width:1180px){
  .ggb-signature-shop-hero{
    grid-template-columns:1fr;
    text-align:center;
    padding:44px 28px 34px;
  }
  .ggb-signature-shop-copy p{margin-left:auto;margin-right:auto;}
  .ggb-signature-shop-stage{justify-content:center;}
  .ggb-signature-categories{grid-template-columns:repeat(3,1fr);gap:8px;}
  .ggb-signature-categories a{border-right:0;border:1px solid var(--line);border-radius:12px;}
  .ggb-signature-filters{grid-template-columns:repeat(2,1fr);}
  .ggb-signature-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .ggb-signature-trust-strip{grid-template-columns:repeat(2,1fr);}
  .ggb-signature-trust-strip article{border-right:0;border-bottom:1px solid var(--line);padding:18px;}
}

@media(max-width:720px){
  .ggb-signature-shop-copy h1{font-size:48px;}
  .ggb-signature-shop-shell{padding:28px 16px;}
  .ggb-signature-categories{grid-template-columns:1fr 1fr;}
  .ggb-signature-filters{grid-template-columns:1fr;}
  .ggb-signature-grid{grid-template-columns:1fr;}
  .ggb-signature-card-media{height:230px;}
  .ggb-card-buttons{grid-template-columns:1fr;}
  .ggb-signature-trust-strip{grid-template-columns:1fr;padding:18px 20px;}
}
