
:root{
  --black:#111111;
  --yellow:#f4c84a;
  --warm:#fce9cc;
  --warm-light:#fce9cc;
  --grey:#f2f2f2;
  --coral:#e85a70;
  --max:1440px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Montserrat,Arial,sans-serif;color:var(--black);background:#fff;font-size:18px;line-height:1.45}
a{color:inherit}
.site-header{min-height:105px;padding:22px 5vw;display:grid;grid-template-columns:minmax(260px,470px) 1fr auto;align-items:center;gap:36px;background:#fff;border-bottom:1px solid #eee;position:relative;z-index:5}
.logo{display:block}.logo-desktop{width:100%;max-width:460px}.logo-mobile{display:none;width:72px;height:72px;object-fit:contain}.site-nav{display:flex;align-items:center;justify-content:flex-end;gap:42px;font-size:20px;font-weight:500}.site-nav a{text-decoration:none}.site-nav a:hover{text-decoration:underline;text-underline-offset:6px}
.pill-btn,.outline-btn{display:inline-flex;align-items:center;justify-content:center;min-height:56px;padding:0 42px;border-radius:999px;text-transform:uppercase;text-decoration:none;font-weight:900;letter-spacing:.04em;white-space:nowrap}.pill-btn{background:#000;color:#fff}.pill-btn:hover{background:#222}.outline-btn{border:2px solid #111;background:#fff;color:#111}.header-btn{font-size:18px;min-width:285px}
.hero{display:grid;grid-template-columns:40% 60%;height:min(470px,calc(100vh - 105px));min-height:420px;background:#fce9cc;overflow:hidden}.hero-copy{background:#fce9cc;display:flex;align-items:center}.hero-copy-inner{padding:3.4vw 3.9vw;max-width:620px}.hero h1{font-size:clamp(48px,4.65vw,74px);line-height:.98;margin:0 0 34px;text-transform:uppercase;font-weight:900;letter-spacing:-.045em}.hero h1 span{color:#ffc400}.hero p{max-width:540px;font-size:clamp(16px,1.22vw,22px);margin:0 0 18px;line-height:1.38}.hero-image{background:#fce9cc;min-height:100%;position:relative;overflow:hidden}.hero-image::before{content:"";position:absolute;inset:0;background-image:url('assets/hero.jpg');background-repeat:no-repeat;background-size:auto 100%;background-position:right center;}
.cards-section{padding:56px 4vw 90px;background:#fff;overflow:hidden}.section-heading{max-width:var(--max);margin:0 auto 58px}.section-heading h2{font-size:clamp(42px,4vw,66px);font-weight:500;margin:0}.cards-carousel{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(340px,430px);gap:42px;overflow-x:auto;scroll-snap-type:x mandatory;padding:0 calc((100vw - min(var(--max),92vw))/2) 28px;scrollbar-width:thin}.card-tile{scroll-snap-align:start;display:flex;flex-direction:column;min-height:650px;overflow:hidden}.card-tile img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;transition:transform .35s ease}.card-tile h3{font-size:clamp(34px,3vw,52px);line-height:1.05;font-weight:500;margin:24px 0 18px}.card-tile p{font-size:22px;margin:0 0 28px;max-width:95%}.card-tile .pill-btn{align-self:flex-start;margin-top:auto;font-size:18px;min-width:230px}
.coming-soon{background:#f4f4f4;padding:70px 4vw 95px}.coming-soon>*{max-width:var(--max);margin-left:auto;margin-right:auto}.coming-soon h2{font-size:28px;margin-top:0;margin-bottom:28px}.coming-soon p{font-size:24px;margin:0 auto 30px}.coming-soon .outline-btn{display:flex;width:max-content;margin-top:54px}
.about-section{min-height:560px;background-image:linear-gradient(rgba(255,255,255,.78),rgba(255,255,255,.78)),url('assets/about-bg.jpg');background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 4vw}.about-overlay{max-width:820px}.about-overlay h2{font-size:clamp(56px,6vw,92px);font-weight:500;margin:0 0 48px;letter-spacing:-.04em}.about-overlay p{font-size:clamp(24px,2.4vw,34px);line-height:1.45;margin:0 0 52px}
.stockists{padding:72px 4vw 80px;max-width:var(--max);margin:0 auto}.stockists h2{font-size:28px;margin:0 0 28px}.stockists p{font-size:24px;line-height:1.5;margin:0 0 28px}.stockists .pill-btn{margin-top:22px;font-size:16px;min-width:230px}
.site-footer{padding:42px 4vw 62px;max-width:var(--max);margin:0 auto;font-size:24px}.site-footer strong{display:block;margin-bottom:4px}.site-footer p{margin:0 0 28px}.site-footer nav{display:flex;gap:8px;flex-wrap:wrap}.site-footer a{text-underline-offset:4px}
@media (max-width:1100px){.site-header{grid-template-columns:1fr;gap:24px;text-align:center}.logo-link{margin:0 auto}.site-nav{justify-content:center}.header-btn{margin:0 auto}.hero{grid-template-columns:1fr;height:auto}.hero-copy-inner{padding:56px 7vw 40px}.hero-image{min-height:430px}.hero-image::before{background-position:center;background-size:contain}.cards-carousel{grid-auto-columns:minmax(300px,72vw);padding-left:7vw;padding-right:7vw}.card-tile{min-height:620px}}
@media (max-width:700px){
  body{font-size:16px}
  .site-header{min-height:auto;padding:18px 22px 20px;gap:16px}
  .logo-desktop{display:none}
  .logo-mobile{display:block;width:66px;height:66px}
  .site-nav{gap:28px;font-size:18px;justify-content:center}
  .header-btn{min-width:0;width:100%;font-size:16px;min-height:54px;padding:0 28px}

  .hero{display:flex;flex-direction:column;height:auto;min-height:0;background:#fce9cc;overflow:visible}
  .hero-copy{display:block;background:#fce9cc}
  .hero-copy-inner{padding:44px 24px 22px;max-width:none}
  .hero h1{font-size:46px;line-height:.95;margin:0 0 28px;letter-spacing:-.05em}
  .hero p{font-size:19px;line-height:1.45;margin-bottom:22px;max-width:100%}
  .hero-image{width:100%;min-height:56vw;background:#fce9cc;overflow:hidden;position:relative;margin:0}
  .hero-image::before{background-size:100% auto;background-position:center top}

  .cards-section{padding:46px 0 58px;background:#fff;overflow:visible}
  .section-heading{margin:0 24px 28px}
  .section-heading h2{font-size:38px;line-height:1.08;font-weight:500}
  .cards-carousel{display:grid;grid-auto-flow:row;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;padding:0 18px 8px;overflow:visible;scroll-snap-type:none}
  .card-tile{min-height:0;scroll-snap-align:unset;background:#fff;border-radius:4px;box-shadow:0 8px 22px rgba(0,0,0,.10);overflow:hidden;display:flex;flex-direction:column}
  .card-tile img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
  .card-tile h3{font-size:19px;line-height:1.14;font-weight:700;margin:14px 12px 10px;letter-spacing:-.02em}
  .card-tile p{display:none}
  .card-tile .pill-btn{min-width:0;width:calc(100% - 24px);margin:0 12px 14px;min-height:42px;font-size:12px;padding:0 10px;align-self:center}

  .coming-soon,.stockists{padding-left:24px;padding-right:24px}
  .coming-soon{padding-top:54px;padding-bottom:62px}
  .coming-soon h2,.stockists h2{font-size:24px}
  .coming-soon p,.stockists p{font-size:18px;line-height:1.5}
  .coming-soon .outline-btn{margin-top:34px;width:100%;min-height:54px}
  .about-section{min-height:480px;padding:62px 24px}
  .about-overlay h2{font-size:46px;line-height:1.05;margin-bottom:30px}
  .about-overlay p{font-size:20px;margin-bottom:30px}
  .site-footer{font-size:18px;padding-left:24px;padding-right:24px}
}



.hero-actions{
display:flex;
gap:14px;
margin-top:24px;
flex-wrap:wrap;
}
.hero-actions .pill-btn,.hero-actions .outline-btn{
text-decoration:none;
}

/* v11 performance polish */
.card-tile img{background:#f7f1e8}
.card-tile{content-visibility:auto;contain-intrinsic-size:650px 430px}
.about-section{content-visibility:auto;contain-intrinsic-size:560px}


/* v12 products and image polish */
.card-tile:hover img,
.product-card:hover img{transform:scale(1.045)}
.card-tile img,
.product-card img{will-change:transform}
.section-actions{max-width:var(--max);margin:28px auto 0;padding:0 calc((100vw - min(var(--max),92vw))/2)}
.section-actions .outline-btn{width:max-content}
.products-hero{background:#fce9cc;padding:78px 5vw 86px}
.products-hero>div,.product-category{max-width:var(--max);margin:0 auto}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:15px;font-weight:900;margin:0 0 14px;color:#6e5536}
.products-hero h1{font-size:clamp(48px,6vw,92px);line-height:.96;letter-spacing:-.055em;margin:0 0 26px;max-width:950px;text-transform:uppercase;font-weight:900}
.products-hero p{font-size:clamp(19px,2vw,27px);max-width:850px;margin:0;line-height:1.45}
.product-category{padding:70px 5vw 25px}
.product-heading h2{font-size:clamp(40px,4.4vw,70px);font-weight:500;letter-spacing:-.045em;margin:0 0 12px}
.category-intro{font-size:22px;max-width:850px;line-height:1.5;margin:0}
.products-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:34px;margin-top:34px}
.product-card{background:#fff;border-radius:8px;box-shadow:0 10px 30px rgba(0,0,0,.10);overflow:hidden;display:flex;flex-direction:column;content-visibility:auto;contain-intrinsic-size:580px 400px}
.product-card a:first-child{display:block;overflow:hidden;background:#f7f1e8}
.product-card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;transition:transform .35s ease}
.product-card h3{font-size:28px;line-height:1.08;margin:20px 20px 12px;letter-spacing:-.035em}
.product-card p{font-size:17px;line-height:1.45;margin:0 20px 18px}
.text-link{font-weight:900;text-transform:uppercase;letter-spacing:.05em;font-size:14px;margin:0 20px 24px;text-underline-offset:5px;margin-top:auto}
.muted-category{background:#f4f4f4;max-width:none;padding-left:5vw;padding-right:5vw;margin-top:60px}.muted-category .product-heading{max-width:var(--max);margin:0 auto}
.site-nav a[aria-current="page"]{text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:2px}

@media (max-width:900px){
  .products-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
  .product-category{padding-top:52px}
}
@media (max-width:700px){
  .section-actions{padding:0 18px}.section-actions .outline-btn{width:100%;min-height:52px}
  .products-hero{padding:48px 24px 56px}.products-hero h1{font-size:44px}.products-hero p{font-size:18px}
  .product-category{padding:44px 18px 12px}.product-heading h2{font-size:38px}.products-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:24px}
  .product-card{border-radius:5px}.product-card h3{font-size:18px;margin:14px 12px 8px}.product-card p{display:none}.text-link{font-size:11px;margin:0 12px 14px}
  .muted-category{padding-left:24px;padding-right:24px}.category-intro{font-size:18px}
}

/* v14 controlled seasonal site theming
   Keeps the main Bold Types layout stable, only changing logo, accents, hero mood and light decorative details. */
:root{
  --season-accent:#f4c84a;
  --season-accent-2:#e85a70;
  --season-soft:#fce9cc;
  --season-ink:#111111;
  --season-glow:rgba(244,200,74,.24);
}
html[data-seasonal-logo="christmas"]{--season-accent:#0f6b3b;--season-accent-2:#c9182b;--season-soft:#f7eee6;--season-glow:rgba(15,107,59,.16)}
html[data-seasonal-logo="valentine"]{--season-accent:#e85a70;--season-accent-2:#ff9bb0;--season-soft:#fff0f3;--season-glow:rgba(232,90,112,.18)}
html[data-seasonal-logo="easter"]{--season-accent:#f4c84a;--season-accent-2:#8dd8bd;--season-soft:#fff4d7;--season-glow:rgba(141,216,189,.18)}
html[data-seasonal-logo="halloween"]{--season-accent:#f47a20;--season-accent-2:#111111;--season-soft:#fff0df;--season-glow:rgba(244,122,32,.20)}
html[data-seasonal-logo="pride"]{--season-accent:#e85a70;--season-accent-2:#4ca3ff;--season-soft:#fff7e4;--season-glow:rgba(76,163,255,.16)}
html[data-seasonal-logo="diwali"],html[data-seasonal-logo="eid"]{--season-accent:#d6a937;--season-accent-2:#7d4fc7;--season-soft:#fff4dc;--season-glow:rgba(214,169,55,.20)}
html[data-seasonal-logo="black-history"]{--season-accent:#0f6b3b;--season-accent-2:#d71920;--season-soft:#fff1dc;--season-glow:rgba(214,169,55,.18)}

html[data-seasonal-logo] .pill-btn{background:var(--season-ink);box-shadow:0 10px 22px var(--season-glow)}
html[data-seasonal-logo] .outline-btn{border-color:var(--season-ink)}
html[data-seasonal-logo] .hero,
html[data-seasonal-logo] .hero-copy,
html[data-seasonal-logo] .hero-image,
html[data-seasonal-logo] .products-hero{background:var(--season-soft)}
html[data-seasonal-logo] .hero h1 span,
html[data-seasonal-logo] .eyebrow,
html[data-seasonal-logo] .seasonal-kicker,
html[data-seasonal-logo] .seasonal-section-kicker{color:var(--season-accent)}

.seasonal-kicker,.seasonal-section-kicker{display:none;margin:0 0 16px;text-transform:uppercase;letter-spacing:.14em;font-size:14px;font-weight:900;color:#6e5536}
html[data-seasonal-logo] .seasonal-kicker,
html[data-seasonal-logo] .seasonal-section-kicker{display:block}

html[data-seasonal-logo] .hero-image::before{filter:saturate(1.03) contrast(1.01)}
html[data-seasonal-logo] .hero-image::after{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(circle at 12% 18%, var(--season-glow) 0 0.55rem, transparent .62rem),
  radial-gradient(circle at 84% 14%, var(--season-glow) 0 0.42rem, transparent .48rem),
  radial-gradient(circle at 74% 82%, var(--season-glow) 0 0.5rem, transparent .56rem),
  linear-gradient(90deg, var(--season-soft) 0%, rgba(255,255,255,0) 24%);
}
.seasonal-hero-label{display:none;position:absolute;right:clamp(18px,3vw,46px);bottom:clamp(18px,3vw,42px);z-index:2;background:#fff;color:#111;border:2px solid var(--season-ink);border-radius:999px;padding:12px 20px;font-size:13px;text-transform:uppercase;letter-spacing:.08em;font-weight:900;box-shadow:0 12px 28px rgba(0,0,0,.10)}
html[data-seasonal-logo] .seasonal-hero-label{display:inline-flex}

html[data-seasonal-logo="christmas"] .site-header{border-bottom:3px solid #0f6b3b}
html[data-seasonal-logo="valentine"] .site-header{border-bottom:3px solid #ff9bb0}
html[data-seasonal-logo="easter"] .site-header{border-bottom:3px solid #8dd8bd}
html[data-seasonal-logo="halloween"] .site-header{border-bottom:3px solid #f47a20}
html[data-seasonal-logo="pride"] .site-header{border-bottom:3px solid transparent;border-image:linear-gradient(90deg,#e40303,#ff8c00,#ffed00,#008026,#004dff,#750787) 1}
html[data-seasonal-logo="diwali"] .site-header,html[data-seasonal-logo="eid"] .site-header{border-bottom:3px solid #d6a937}
html[data-seasonal-logo="black-history"] .site-header{border-bottom:3px solid #d71920}

/* Small seasonal detail on section blocks only, so the site never becomes too shouty. */
html[data-seasonal-logo] .cards-section{background:linear-gradient(180deg,#fff 0%,#fff 74%,var(--season-soft) 100%)}
html[data-seasonal-logo] .coming-soon{background:linear-gradient(180deg,#f3f3f3,var(--season-soft))}
html[data-seasonal-logo] .card-tile:hover,html[data-seasonal-logo] .product-card:hover{box-shadow:0 16px 38px var(--season-glow)}

@media (max-width:700px){
  .seasonal-kicker,.seasonal-section-kicker{font-size:12px;margin-bottom:12px}
  .seasonal-hero-label{right:18px;bottom:18px;font-size:11px;padding:10px 14px}
  html[data-seasonal-logo] .hero-image::after{background:linear-gradient(180deg, rgba(255,255,255,0) 40%, var(--season-soft) 100%)}
}


/* v15 refinement: keep seasonal branding subtle, remove hero callout labels, and protect hero/content crops. */
.seasonal-kicker,
.seasonal-hero-label{
  display:none !important;
}

/* Allow the hero to grow instead of clipping seasonal text. */
.hero{
  height:auto;
  min-height:470px;
}
.hero-copy,
.hero-image{
  min-height:470px;
}
.hero-copy-inner{
  padding-top:clamp(42px,3.2vw,58px);
  padding-bottom:clamp(42px,3.2vw,58px);
}
.hero h1{
  font-size:clamp(46px,4.35vw,70px);
  line-height:.94;
  margin-bottom:26px;
}

/* Force all card/product thumbnails to stay square. */
.cards-carousel .card-tile > img,
.products-grid .product-card img{
  aspect-ratio:1 / 1 !important;
  width:100% !important;
  height:auto !important;
  max-height:none !important;
  object-fit:cover !important;
  display:block !important;
}
.card-tile{
  min-height:0;
}
.card-tile h3{
  min-height:2.1em;
}

@media (max-width:1100px){
  .hero,
  .hero-copy,
  .hero-image{
    min-height:0;
  }
  .hero-image{
    min-height:430px;
  }
  .hero h1{
    font-size:clamp(44px,8vw,64px);
  }
}

@media (max-width:700px){
  .hero-copy-inner{
    padding-top:36px;
    padding-bottom:22px;
  }
  .hero h1{
    font-size:43px;
    line-height:.92;
    margin-bottom:22px;
  }
  .hero-image{
    min-height:56vw;
  }
  .cards-carousel .card-tile > img,
  .products-grid .product-card img{
    aspect-ratio:1 / 1 !important;
  }
  .card-tile h3{
    min-height:0;
  }
}

/* v16: keep seasonal branding subtle, stop hero clipping, strengthen mobile logo, and enforce square cards. */
html[data-seasonal-logo] .hero h1 span{color:#ffc400}

/* The hero must be allowed to grow with the content instead of cropping paragraphs/buttons. */
.hero{
  height:auto !important;
  min-height:clamp(560px, 42vw, 640px) !important;
  overflow:visible !important;
}
.hero-copy,
.hero-image{
  min-height:inherit !important;
}
.hero-copy-inner{
  padding-top:clamp(48px, 3.5vw, 68px) !important;
  padding-bottom:clamp(48px, 3.5vw, 68px) !important;
}
.hero h1{
  font-size:clamp(46px, 4vw, 68px) !important;
  line-height:.98 !important;
  margin-bottom:28px !important;
}
.hero p{
  font-size:clamp(16px, 1.08vw, 20px) !important;
}

/* Desktop carousel: columns and image heights use the same clamp, so thumbs stay square. */
.cards-carousel{
  grid-auto-columns:clamp(320px, 22.5vw, 430px) !important;
}
.cards-carousel .card-tile > img{
  width:100% !important;
  height:clamp(320px, 22.5vw, 430px) !important;
  aspect-ratio:auto !important;
  object-fit:cover !important;
  display:block !important;
  transition:transform .35s ease !important;
}
.card-tile{
  overflow:visible !important;
}
.card-tile > img{
  border-radius:0;
}
.card-tile:hover > img{
  transform:scale(1.045);
}

/* Products page cards: use a square image holder so product thumbnails never stretch. */
.product-card a:first-child{
  aspect-ratio:1 / 1 !important;
  overflow:hidden !important;
  display:block !important;
}
.products-grid .product-card img,
.product-card a:first-child img{
  width:100% !important;
  height:100% !important;
  aspect-ratio:auto !important;
  object-fit:cover !important;
  display:block !important;
}

@media (max-width:1100px){
  .hero{
    min-height:auto !important;
  }
  .hero-copy,
  .hero-image{
    min-height:0 !important;
  }
  .hero-copy-inner{
    padding-top:56px !important;
    padding-bottom:42px !important;
  }
  .hero h1{
    font-size:clamp(44px, 8vw, 64px) !important;
  }
  .hero-image{
    min-height:430px !important;
  }
}

@media (max-width:700px){
  /* Use the horizontal logo on mobile too; the circular seasonal logo had too much internal whitespace and looked tiny. */
  .site-header{
    padding:22px 22px 24px !important;
    gap:18px !important;
  }
  .logo-link{
    width:100% !important;
    display:flex !important;
    justify-content:center !important;
  }
  .logo-desktop{
    display:block !important;
    width:min(280px, 78vw) !important;
    max-width:280px !important;
    height:auto !important;
  }
  .logo-mobile{
    display:none !important;
  }
  .site-nav{
    gap:34px !important;
    font-size:24px !important;
  }
  .header-btn{
    width:100% !important;
    max-width:760px !important;
    min-height:60px !important;
  }
  .hero-copy-inner{
    padding:44px 24px 46px !important;
  }
  .hero h1{
    font-size:43px !important;
    line-height:.94 !important;
    margin-bottom:24px !important;
  }
  .hero p{
    font-size:19px !important;
    line-height:1.45 !important;
  }
  .hero-image{
    min-height:58vw !important;
  }
  .cards-carousel{
    grid-auto-columns:auto !important;
    grid-template-columns:repeat(2, minmax(0,1fr)) !important;
    gap:20px !important;
    padding-left:18px !important;
    padding-right:18px !important;
  }
  .cards-carousel .card-tile > img{
    height:calc((100vw - 56px) / 2) !important;
  }
  .product-card a:first-child{
    aspect-ratio:1 / 1 !important;
  }
}


/* v17 focused homepage copy and shopping journey */
.hero h1{
  max-width:560px !important;
}
.hero-actions{
  margin-top:28px !important;
}
.hero-actions .outline-btn{
  display:none !important;
}
html[data-seasonal-logo] .seasonal-section-kicker{
  display:none !important;
}
html[data-seasonal-logo] [data-seasonal-featured-title]::after{
  content:none !important;
}
@media (max-width:700px){
  .hero h1{
    font-size:46px !important;
    line-height:.94 !important;
  }
  .hero-actions .pill-btn{
    width:100% !important;
    min-height:58px !important;
  }
}

/* v18 portfolio card additions */
.portfolio-grid{
  align-items:start;
}
.product-card .product-image{
  display:block;
  overflow:hidden;
  background:#fff7e8;
}
.portfolio-card .product-image{
  aspect-ratio:3540 / 5006 !important;
}
.products-grid .portfolio-card .product-image img,
.portfolio-card .product-image img{
  width:100% !important;
  height:100% !important;
  aspect-ratio:auto !important;
  object-fit:cover !important;
  display:block !important;
  transition:transform .35s ease !important;
}
.portfolio-card h3{
  min-height:2.16em;
}
.muted-link{
  color:#777 !important;
  cursor:default;
  text-decoration:none;
}
.muted-link::after{
  content:"" !important;
}
.portfolio-card .muted-link{
  margin-top:auto;
}
@media (max-width:700px){
  .portfolio-card h3{
    min-height:0;
  }
  .portfolio-card .product-image{
    aspect-ratio:3540 / 5006 !important;
  }
}


/* v19 portfolio browser: filtered cards, compact low-res thumbnails and modal samples */
.portfolio-page .portfolio-hero{
  background:linear-gradient(135deg,#fff7e9 0%,#ffffff 72%);
  border-bottom:1px solid #f1e5d2;
}
.portfolio-browser{
  max-width:1280px;
  margin:0 auto;
  padding:46px 34px 74px;
}
.portfolio-controls{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(260px,360px);
  gap:26px;
  align-items:end;
  margin-bottom:22px;
}
.filter-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.filter-btn{
  border:2px solid #111;
  border-radius:999px;
  background:#fff;
  color:#111;
  font-family:inherit;
  font-weight:900;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:12px;
  padding:10px 16px;
  cursor:pointer;
  transition:transform .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
}
.filter-btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(0,0,0,.10)}
.filter-btn.is-active{background:#111;color:#fff}
.portfolio-search span{
  display:block;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px;
  margin-bottom:8px;
}
.portfolio-search input{
  width:100%;
  border:2px solid #111;
  border-radius:999px;
  padding:14px 18px;
  font:inherit;
  font-size:16px;
  outline:none;
}
.portfolio-search input:focus{box-shadow:0 0 0 4px rgba(252,200,74,.28)}
.portfolio-count{font-weight:700;color:#555;margin:0 0 20px}
.catalogue-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.catalogue-card{
  background:#fff;
  border-radius:18px;
  box-shadow:0 12px 34px rgba(0,0,0,.10);
  overflow:hidden;
  display:flex;
  flex-direction:column;
  min-width:0;
  content-visibility:auto;
  contain-intrinsic-size:520px 330px;
}
.catalogue-card[hidden]{display:none!important}
.sample-button{
  border:0;
  background:#fff8ec;
  padding:0;
  cursor:zoom-in;
  width:100%;
  overflow:hidden;
  display:block;
}
.catalogue-thumb{
  display:block;
  aspect-ratio:3540 / 5006;
  overflow:hidden;
  background:#fff4df;
  position:relative;
}
.catalogue-thumb::after,
.modal-image-wrap::after{
  content:"SAMPLE";
  position:absolute;
  inset:auto 10px 10px auto;
  background:rgba(255,255,255,.75);
  color:#111;
  border:1px solid rgba(0,0,0,.15);
  border-radius:999px;
  padding:6px 10px;
  font-weight:900;
  font-size:10px;
  letter-spacing:.08em;
  pointer-events:none;
}
.catalogue-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .35s ease;
  user-select:none;
  -webkit-user-drag:none;
}
.catalogue-card:hover .catalogue-thumb img{transform:scale(1.045)}
.catalogue-copy{padding:18px 18px 20px;display:flex;flex-direction:column;gap:10px;flex:1}
.catalogue-copy h3{font-size:21px;line-height:1.05;letter-spacing:-.035em;margin:0}
.catalogue-copy p{font-size:14px;line-height:1.45;margin:0;color:#333}
.card-status{font-size:11px!important;line-height:1!important;text-transform:uppercase;letter-spacing:.08em;font-weight:900;margin:0;color:#777}
.status-live{color:#06845b!important}
.status-soon{color:#e85a70!important}
.tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.tag-list span{
  background:#f4f0e8;
  border-radius:999px;
  padding:5px 8px;
  font-size:10px;
  line-height:1;
  text-transform:uppercase;
  font-weight:800;
  color:#333;
}
.catalogue-copy .text-link{margin:8px 0 0;font-size:12px;align-self:flex-start}
.no-results{font-size:20px;font-weight:800;text-align:center;padding:34px;background:#fff7e9;border-radius:18px;margin-top:20px}
body.modal-open{overflow:hidden}
.sample-modal[hidden]{display:none!important}
.sample-modal{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:24px}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.62);border:0;cursor:pointer}
.modal-panel{
  position:relative;
  z-index:1;
  width:min(1080px,96vw);
  max-height:92vh;
  background:#fff;
  border-radius:20px;
  display:grid;
  grid-template-columns:minmax(260px,560px) minmax(260px,1fr);
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.38);
}
.modal-close{
  position:absolute;
  top:12px;
  right:12px;
  width:42px;
  height:42px;
  border-radius:999px;
  border:0;
  background:#111;
  color:#fff;
  font-size:30px;
  line-height:1;
  cursor:pointer;
  z-index:2;
}
.modal-image-wrap{position:relative;background:#fff7e9;overflow:auto;display:grid;place-items:center;max-height:92vh}
.modal-image-wrap img{width:100%;height:auto;max-height:92vh;object-fit:contain;display:block;user-select:none;-webkit-user-drag:none}
.modal-details{padding:56px 34px 34px;align-self:center}
.modal-details h2{font-size:clamp(30px,3vw,54px);line-height:.98;letter-spacing:-.055em;margin:8px 0 18px}
.modal-details p{font-size:17px;line-height:1.55;margin:0 0 14px}
.modal-tags{font-size:13px!important;font-weight:800;color:#555;text-transform:capitalize}
.sample-note{font-size:12px!important;color:#777;border-top:1px solid #eee;padding-top:16px;margin-top:18px!important}
@media (max-width:1100px){
  .catalogue-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:820px){
  .portfolio-controls{grid-template-columns:1fr;align-items:start}
  .catalogue-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
  .portfolio-browser{padding:34px 18px 54px}
  .catalogue-copy{padding:14px 12px 16px}
  .catalogue-copy h3{font-size:17px}
  .catalogue-copy p{display:none}
  .tag-list span{font-size:9px;padding:4px 6px}
  .modal-panel{grid-template-columns:1fr;overflow:auto}
  .modal-image-wrap{max-height:62vh}
  .modal-details{padding:26px 22px 28px}
  .modal-details h2{font-size:32px}
}
@media (max-width:480px){
  .catalogue-grid{gap:12px}
  .filter-buttons{gap:8px}
  .filter-btn{font-size:10px;padding:9px 11px}
}


/* v25 Father’s Day feature update */
.hero-image::before{
  background-image:url('assets/hero-fathers-day.webp') !important;
  background-size:cover !important;
  background-position:center !important;
}
.hero{
  grid-template-columns:42% 58% !important;
  background:#eaf6ff !important;
}
.hero-copy{
  background:#fff3d9 !important;
}
.hero h1{
  max-width:650px !important;
}
.hero h1 span{
  color:#ffc400 !important;
}
.hero-actions .pill-btn{
  box-shadow:0 12px 26px rgba(0,0,0,.12);
}
.cards-section .section-heading h2{
  max-width:940px;
}
.card-tile img[draggable="false"]{
  user-select:none;
  -webkit-user-drag:none;
}
.status-available{color:#06845b!important}
.catalogue-card[data-categories="Father’s Day"]{
  box-shadow:0 12px 34px rgba(0,119,220,.12);
}
.catalogue-card[data-categories="Father’s Day"] .sample-button{
  background:#eaf6ff;
}
@media (max-width:1100px){
  .hero{grid-template-columns:1fr !important;}
  .hero-image{min-height:520px !important;}
  .hero-image::before{background-size:cover !important;background-position:center !important;}
}
@media (max-width:700px){
  .hero-copy-inner{padding-top:40px !important;padding-bottom:38px !important;}
  .hero h1{font-size:42px !important;line-height:.98 !important;}
  .hero-image{min-height:72vw !important;}
  .hero-image::before{background-size:cover !important;background-position:center !important;}
  .card-tile .pill-btn{font-size:10px !important;}
}


/* v27: homepage featured cards show the full portrait card and use a more compact retail-style tile. */
.cards-section{
  padding-top:44px !important;
  padding-bottom:68px !important;
}
.cards-section .section-heading{
  margin-bottom:32px !important;
}
.cards-carousel{
  grid-auto-columns:clamp(245px, 18vw, 320px) !important;
  gap:26px !important;
  align-items:start !important;
}
.cards-carousel .card-tile{
  min-height:0 !important;
  overflow:visible !important;
  background:#fff !important;
  border-radius:16px !important;
  box-shadow:0 10px 28px rgba(0,0,0,.10) !important;
  padding:12px 12px 16px !important;
}
.cards-carousel .card-tile > img{
  width:100% !important;
  height:auto !important;
  aspect-ratio:800 / 1130 !important;
  object-fit:contain !important;
  object-position:center !important;
  background:#fff !important;
  border-radius:10px !important;
  display:block !important;
  transform:none !important;
}
.cards-carousel .card-tile:hover > img{
  transform:none !important;
}
.card-tile h3{
  font-size:clamp(20px, 1.5vw, 28px) !important;
  line-height:1.12 !important;
  font-weight:800 !important;
  margin:14px 2px 8px !important;
  min-height:0 !important;
  letter-spacing:-.035em !important;
}
.card-tile p{
  font-size:15px !important;
  line-height:1.4 !important;
  margin:0 2px 14px !important;
  max-width:100% !important;
}
.card-tile .pill-btn{
  min-height:40px !important;
  min-width:0 !important;
  width:100% !important;
  padding:0 16px !important;
  font-size:12px !important;
  margin-top:auto !important;
}
@media (max-width:820px){
  .cards-carousel{
    grid-auto-flow:row !important;
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:16px !important;
    padding-left:18px !important;
    padding-right:18px !important;
    overflow:visible !important;
  }
  .cards-carousel .card-tile{
    padding:8px 8px 12px !important;
    border-radius:12px !important;
  }
  .cards-carousel .card-tile > img{
    aspect-ratio:800 / 1130 !important;
    object-fit:contain !important;
  }
  .card-tile h3{
    font-size:16px !important;
    margin:10px 2px 8px !important;
  }
  .card-tile p{display:none !important;}
}
@media (max-width:420px){
  .cards-carousel{grid-template-columns:1fr !important;}
}


/* v30: image loading/performance pass. */
.catalogue-card, .card-tile{
  content-visibility:auto;
  contain-intrinsic-size:520px 360px;
}
.catalogue-thumb img, .cards-carousel .card-tile > img{
  image-rendering:auto;
}

/* v31 portfolio default + birthday sub-filters */
.filter-panel{
  display:grid;
  gap:12px;
}
.filter-subheading{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:6px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  color:#444;
}
.filter-subheading::after{
  content:"";
  flex:1;
  min-width:48px;
  height:1px;
  background:#e5e5e5;
}
.birthday-filters{
  margin-top:0;
}
.filter-btn-small{
  font-size:11px;
  padding:8px 12px;
  border-width:1.5px;
}

/* v32: compact portfolio seasonal strip replacing the large hero */
.portfolio-page .products-hero,
.portfolio-page .portfolio-hero{
  display:none !important;
}
.portfolio-season-strip{
  max-width:1280px;
  margin:26px auto 0;
  padding:14px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  border:2px solid #111;
  border-radius:18px;
  background:linear-gradient(90deg,#fff 0%,#fff8e6 100%);
  box-shadow:0 10px 26px rgba(0,0,0,.07);
}
.season-strip-copy{
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:10px 14px;
  min-width:0;
}
.season-strip-kicker{
  background:#111;
  color:#fff;
  border-radius:999px;
  padding:7px 11px;
  font-size:11px;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-weight:900;
  white-space:nowrap;
}
.season-strip-copy strong{
  font-size:clamp(18px,2vw,27px);
  line-height:1.05;
  letter-spacing:-.035em;
  font-weight:900;
}
.season-strip-copy span:last-child{
  color:#333;
  font-size:15px;
  line-height:1.35;
}
.season-strip-link{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:2px solid #111;
  border-radius:999px;
  padding:10px 16px;
  color:#111;
  background:#ffc400;
  font-weight:900;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.05em;
  text-decoration:none;
  box-shadow:0 8px 18px rgba(0,0,0,.10);
}
.portfolio-browser{
  padding-top:30px !important;
}
@media (max-width:760px){
  .portfolio-season-strip{
    margin:18px 16px 0;
    align-items:flex-start;
    flex-direction:column;
    border-radius:15px;
  }
  .season-strip-link{width:100%;}
}

/* v33: centre portfolio quick-search buttons and expand key-age filters */
.portfolio-controls{
  display:block !important;
  max-width:1280px;
  margin-left:auto;
  margin-right:auto;
}
.portfolio-controls > div{
  width:100%;
}
.portfolio-controls .eyebrow{
  text-align:center;
}
.filter-panel{
  width:100%;
}
.filter-buttons{
  justify-content:center;
  align-items:center;
  width:100%;
}
.filter-subheading{
  justify-content:center;
  width:100%;
  margin-top:14px;
}
.filter-subheading::before,
.filter-subheading::after{
  content:"";
  flex:1;
  min-width:48px;
  height:1px;
  background:#e5e5e5;
}
.birthday-filters{
  max-width:1120px;
  margin-left:auto;
  margin-right:auto;
}
.filter-btn-small{
  min-width:52px;
  padding-left:12px;
  padding-right:12px;
}
.portfolio-search{
  display:block;
  max-width:620px;
  margin:26px auto 0;
}
.portfolio-search span{
  text-align:center;
}
@media (max-width:700px){
  .filter-buttons{justify-content:flex-start;}
  .portfolio-controls .eyebrow,
  .portfolio-search span{text-align:left;}
  .filter-subheading{justify-content:flex-start;}
  .filter-subheading::before{display:none;}
}

/* v34: use the same dynamic seasonal reminder as a slim homepage advert above the hero */
.home-season-strip{
  margin-top:28px;
  margin-bottom:0;
}
.home-season-strip + .hero{
  margin-top:24px;
}
@media (max-width:760px){
  .home-season-strip{
    margin-top:18px;
  }
  .home-season-strip + .hero{
    margin-top:18px;
  }
}
