/* =========================================================================
   PESHAS / PHPC — Phulkari hand embroidery
   Design system
   ========================================================================= */

:root{
  /* Core palette */
  --ink:        #2a2422;
  --ink-soft:   #574e48;
  --muted:      #877d74;
  --cream:      #fbf7f0;
  --cream-2:    #f4ece0;
  --paper:      #ffffff;
  --crimson:    #8c1d2c;
  --crimson-dk: #6f1623;
  --gold:       #b58a3c;
  --gold-soft:  #d8be8b;
  --line:       rgba(42,36,34,.12);
  --line-strong:rgba(42,36,34,.22);

  /* Phulkari accents — used sparingly */
  --marigold:#e0a82e;
  --fuchsia: #c42a6b;
  --teal:    #1e8c84;
  --indigo:  #34408c;

  --shadow-sm: 0 1px 2px rgba(42,36,34,.05), 0 6px 18px rgba(42,36,34,.06);
  --shadow-md: 0 10px 40px rgba(42,36,34,.12);

  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);

  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --display: "Marcellus", Georgia, serif;
  --sans: "Mulish", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; scroll-padding-top:96px; }
body{
  margin:0;
  font-family:var(--sans);
  font-size:17px;
  line-height:1.75;
  color:var(--ink-soft);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--crimson); text-decoration:none; transition:color .25s ease; }
a:hover{ color:var(--gold); }
h1,h2,h3,h4{ color:var(--ink); font-family:var(--serif); font-weight:600; line-height:1.12; margin:0 0 .4em; letter-spacing:.005em; }
h1{ font-size:clamp(2.6rem, 6vw, 4.7rem); }
h2{ font-size:clamp(2rem, 4.2vw, 3.2rem); }
h3{ font-size:clamp(1.4rem, 2.4vw, 1.9rem); }
p{ margin:0 0 1.1em; }
::selection{ background:var(--gold-soft); color:var(--ink); }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(64px, 9vw, 132px); }
.section--tight{ padding-block:clamp(48px, 6vw, 88px); }
.bg-paper{ background:var(--paper); }
.bg-cream2{ background:var(--cream-2); }
.bg-ink{ background:var(--ink); color:#e9e2d8; }
.bg-ink h2,.bg-ink h3{ color:#fff; }
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.measure{ max-width:64ch; }
.measure-sm{ max-width:50ch; }

/* Eyebrow */
.eyebrow{
  font-family:var(--display);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.74rem;
  color:var(--gold);
  margin:0 0 1rem;
  display:inline-block;
}
.bg-ink .eyebrow{ color:var(--gold-soft); }
.lead{ font-size:1.18rem; color:var(--ink-soft); }

/* Gold hairline + motif divider */
.rule{ width:64px; height:1px; background:var(--gold); border:0; margin:1.6rem 0; }
.center .rule{ margin-inline:auto; }
.motif{ display:flex; align-items:center; justify-content:center; gap:14px; color:var(--gold); margin:0 auto; }
.motif::before,.motif::after{ content:""; height:1px; width:min(90px,18vw); background:linear-gradient(90deg,transparent,var(--gold-soft)); }
.motif::after{ background:linear-gradient(90deg,var(--gold-soft),transparent); }
.motif svg{ width:30px; height:30px; flex:0 0 auto; }

/* ---------- Buttons ---------- */
.btn{
  --b:var(--crimson);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-weight:700; font-size:.82rem;
  letter-spacing:.12em; text-transform:uppercase;
  padding:.95em 1.9em; border:1px solid var(--b); border-radius:2px;
  background:var(--b); color:#fff; cursor:pointer;
  transition:transform .2s ease, background .25s ease, color .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.btn:hover{ background:transparent; color:var(--b); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.btn--gold{ --b:var(--gold); color:#fff; }
.btn--gold:hover{ color:var(--gold); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line-strong); }
.btn--ghost:hover{ background:var(--ink); color:#fff; border-color:var(--ink); }
.btn--light{ background:#fff; color:var(--ink); border-color:#fff; }
.btn--light:hover{ background:transparent; color:#fff; }
.btn-row{ display:flex; flex-wrap:wrap; gap:16px; }
.center .btn-row{ justify-content:center; }
.btn svg{ width:1.05em; height:1.05em; }

.textlink{
  font-weight:700; letter-spacing:.04em; color:var(--crimson);
  border-bottom:1px solid var(--gold-soft); padding-bottom:2px;
}
.textlink:hover{ border-color:var(--gold); }

/* ---------- Header / nav ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
  padding-block:18px;
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.brand{ display:flex; align-items:center; gap:14px; }
.brand img{ height:54px; width:auto; transition:height .35s ease; }
.brand-text{ font-family:var(--display); line-height:1.05; color:var(--ink); }
.brand-text b{ display:block; font-size:1.06rem; letter-spacing:.04em; font-weight:400; }
.brand-text span{ font-size:.62rem; letter-spacing:.24em; text-transform:uppercase; color:var(--muted); }

.nav{ display:flex; align-items:center; gap:34px; }
.nav a{
  font-family:var(--sans); font-size:.8rem; font-weight:700;
  letter-spacing:.13em; text-transform:uppercase; color:var(--ink);
  position:relative; padding-block:6px;
}
.nav a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--gold); transition:width .28s ease; }
.nav a:hover,.nav a[aria-current="page"]{ color:var(--crimson); }
.nav a:hover::after,.nav a[aria-current="page"]::after{ width:100%; }

/* transparent over hero */
.site-header.is-top{ background:transparent; }
.site-header.is-top .brand-text,
.site-header.is-top .brand-text b{ color:#fff; }
.site-header.is-top .brand-text span{ color:rgba(255,255,255,.8); }
.site-header.is-top .nav a{ color:#fff; }
.site-header.is-top .nav a:hover,
.site-header.is-top .nav a[aria-current="page"]{ color:#fff; }
.site-header.is-top .navtoggle span{ background:#fff; }
.site-header.is-top .brand-logo--dark{ filter:drop-shadow(0 1px 3px rgba(0,0,0,.35)); }
/* solid (scrolled / inner pages) */
.site-header.is-solid{ background:rgba(251,247,240,.94); backdrop-filter:saturate(140%) blur(10px); box-shadow:0 1px 0 var(--line); padding-block:12px; }
.site-header.is-solid .brand img{ height:46px; }

.navtoggle{ display:none; flex-direction:column; gap:5px; width:34px; height:30px; justify-content:center; background:none; border:0; cursor:pointer; }
.navtoggle span{ display:block; height:2px; width:26px; background:var(--ink); transition:transform .3s ease, opacity .3s ease; }
.nav-open .navtoggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-open .navtoggle span:nth-child(2){ opacity:0; }
.nav-open .navtoggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; min-height:min(92vh,820px); display:flex; align-items:flex-end; color:#fff; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img{ width:100%; height:100%; object-fit:cover; }
.hero::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(20,13,11,.62) 0%, rgba(20,13,11,.40) 42%, rgba(20,13,11,.88) 100%),
    linear-gradient(90deg, rgba(20,13,11,.55) 0%, rgba(20,13,11,.12) 55%, rgba(20,13,11,0) 80%); }
.hero--sub::after{ background:linear-gradient(180deg, rgba(20,13,11,.55) 0%, rgba(20,13,11,.45) 45%, rgba(20,13,11,.80) 100%); }
.hero__inner{ padding-block:clamp(56px,12vh,140px); max-width:780px; }
.hero h1{ color:#fff; margin-bottom:.25em; }
.hero .eyebrow{ color:var(--gold-soft); }
.hero p{ font-size:1.22rem; color:rgba(255,255,255,.92); max-width:54ch; }
.hero--sub{ min-height:auto; align-items:center; text-align:center; }
.hero--sub .hero__inner{ margin-inline:auto; padding-block:clamp(120px,20vh,200px); }
.hero--page{ min-height:54vh; }

/* ---------- Split / feature ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,80px); align-items:center; }
.split--media-right .split__media{ order:2; }
.split__media img{ width:100%; height:100%; max-height:640px; object-fit:cover; border-radius:3px; box-shadow:var(--shadow-md); }
.split__body{ max-width:54ch; }

.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,40px); }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(24px,3vw,48px); }
.feature{ }
.feature .ico{ width:42px; height:42px; color:var(--gold); margin-bottom:14px; }
.feature h3{ font-size:1.3rem; }

/* Stats */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; text-align:center; }
.stat .num{ font-family:var(--serif); font-size:clamp(2.4rem,5vw,3.6rem); color:var(--crimson); line-height:1; }
.stat .lbl{ font-family:var(--display); letter-spacing:.18em; text-transform:uppercase; font-size:.72rem; color:var(--muted); margin-top:.5rem; }

/* ---------- Category cards (home) ---------- */
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.cat-card{ position:relative; overflow:hidden; border-radius:3px; aspect-ratio:3/4; box-shadow:var(--shadow-sm); display:block; }
.cat-card img{ width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.cat-card:hover img{ transform:scale(1.06); }
.cat-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 35%,rgba(28,18,16,.78)); }
.cat-card__label{ position:absolute; left:0; right:0; bottom:0; padding:22px; z-index:2; color:#fff; }
.cat-card__label .k{ font-family:var(--display); letter-spacing:.2em; text-transform:uppercase; font-size:.66rem; color:var(--gold-soft); display:block; margin-bottom:4px; }
.cat-card__label .t{ font-family:var(--serif); font-size:1.5rem; }

/* ---------- Slider (home: cluster moments) ---------- */
.slider{ position:relative; max-width:1000px; margin:48px auto 0; }
.slider__track{ list-style:none; margin:0; padding:0; position:relative; aspect-ratio:16/9; border-radius:4px; overflow:hidden; box-shadow:var(--shadow-md); background:var(--cream-2); }
.slide{ position:absolute; inset:0; opacity:0; transition:opacity .9s ease; }
.slide.is-active{ opacity:1; }
.slide img{ width:100%; height:100%; object-fit:cover; }
/* graceful no-JS fallback: stack first slide visible */
.slider:not(.is-ready) .slide:first-child{ opacity:1; }
.slider__arrow{ position:absolute; top:50%; transform:translateY(-50%); z-index:3;
  width:46px; height:46px; border-radius:50%; border:0; cursor:pointer;
  background:rgba(255,255,255,.82); color:var(--ink); display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-sm); transition:background .25s ease, transform .25s ease; }
.slider__arrow:hover{ background:#fff; }
.slider__arrow svg{ width:22px; height:22px; }
.slider__arrow--prev{ left:14px; }
.slider__arrow--next{ right:14px; }
.slider__arrow--prev:hover{ transform:translateY(-50%) translateX(-2px); }
.slider__arrow--next:hover{ transform:translateY(-50%) translateX(2px); }
.slider__dots{ display:flex; gap:9px; justify-content:center; margin-top:20px; }
.slider__dots button{ width:8px; height:8px; padding:0; border-radius:50%; border:0; cursor:pointer;
  background:var(--line-strong); transition:background .25s ease, transform .25s ease; }
.slider__dots button.is-active{ background:var(--gold); transform:scale(1.35); }

/* ---------- Collections ---------- */
.catnav{ position:sticky; top:72px; z-index:40; background:rgba(251,247,240,.95); backdrop-filter:blur(8px); border-block:1px solid var(--line); }
.catnav ul{ list-style:none; margin:0; padding:0; display:flex; gap:6px; flex-wrap:wrap; justify-content:center; padding-block:12px; }
.catnav a{ font-family:var(--display); letter-spacing:.16em; text-transform:uppercase; font-size:.7rem; color:var(--ink-soft); padding:7px 14px; border-radius:2px; }
.catnav a:hover,.catnav a.active{ color:var(--crimson); background:var(--cream-2); }

.cat-section{ scroll-margin-top:140px; }
.cat-head{ text-align:center; max-width:60ch; margin:0 auto clamp(28px,4vw,52px); }

.products{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px,2vw,30px); }
.card{ background:var(--paper); border:1px solid var(--line); border-radius:3px; overflow:hidden; display:flex; flex-direction:column; transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); border-color:transparent; }
.card__media{ position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--cream-2); }
.card__media img{ width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.2,.7,.2,1); }
.card:hover .card__media img{ transform:scale(1.05); }
.card__tag{ position:absolute; top:12px; left:12px; background:rgba(255,255,255,.92); color:var(--crimson); font-family:var(--display); font-size:.6rem; letter-spacing:.14em; text-transform:uppercase; padding:5px 10px; border-radius:2px; }
.card__body{ padding:18px 18px 20px; display:flex; flex-direction:column; gap:6px; flex:1; }
.card__name{ font-family:var(--serif); font-size:1.32rem; color:var(--ink); line-height:1.1; }
.card__code{ font-family:var(--sans); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.card__meta{ font-size:.86rem; color:var(--ink-soft); margin-top:2px; }
.card__meta b{ color:var(--ink); font-weight:700; }
.card__enquire{ margin-top:auto; padding-top:14px; }
.card__enquire a{ font-size:.74rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--crimson); display:inline-flex; align-items:center; gap:.5em; }
.card__enquire a svg{ width:1em; height:1em; transition:transform .25s ease; }
.card__enquire a:hover svg{ transform:translateX(3px); }

/* ---------- Sponsor strip ---------- */
.sponsors{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(28px,6vw,72px); }
.sponsors img{ height:64px; width:auto; object-fit:contain; opacity:.9; }
.sponsors .ms img{ height:58px; }

/* ---------- Contact ---------- */
.contact-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(32px,5vw,72px); }
.contact-item{ display:flex; gap:16px; padding:22px 0; border-bottom:1px solid var(--line); }
.contact-item:last-child{ border-bottom:0; }
.contact-item .ico{ flex:0 0 auto; width:34px; height:34px; color:var(--gold); }
.contact-item h3{ font-family:var(--display); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.contact-item p,.contact-item a{ font-size:1.06rem; color:var(--ink); margin:0; }
.contact-item a:hover{ color:var(--crimson); }

/* ---------- Prose (privacy / disclaimer / craft) ---------- */
.prose{ max-width:72ch; }
.prose h2{ margin-top:1.8em; }
.prose h3{ margin-top:1.5em; font-family:var(--display); font-size:1.05rem; letter-spacing:.06em; text-transform:uppercase; color:var(--crimson); }
.prose ul{ padding-left:1.2em; }
.prose li{ margin-bottom:.5em; }
.prose .updated{ color:var(--muted); font-size:.92rem; }

/* Pull quote */
.pullquote{ font-family:var(--serif); font-size:clamp(1.6rem,3.4vw,2.5rem); line-height:1.3; color:var(--ink); max-width:24ch; }
.pullquote .by{ display:block; font-family:var(--sans); font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-top:1.2rem; }

/* ---------- Footer ---------- */
.site-footer{ background:#211b19; color:#cbbfb2; font-size:.94rem; }
.site-footer a{ color:#cbbfb2; }
.site-footer a:hover{ color:var(--gold-soft); }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:clamp(32px,5vw,64px); padding-block:clamp(56px,7vw,88px); }
.footer-brand img{ height:54px; margin-bottom:18px; background:#fff; padding:10px 14px; border-radius:3px; }
.footer-brand p{ max-width:38ch; color:#a89c8f; }
.footer-col h4{ font-family:var(--display); color:#fff; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; margin-bottom:1.1em; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.7em; }
.footer-col .small{ color:#a89c8f; font-size:.9rem; }
.footer-sponsors{ border-top:1px solid rgba(255,255,255,.1); padding-block:30px; display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(24px,5vw,56px); }
.footer-sponsors img{ height:46px; background:#fff; padding:7px 12px; border-radius:3px; }
.footer-note{ border-top:1px solid rgba(255,255,255,.1); padding-block:22px; font-size:.82rem; color:#8f8478; display:flex; flex-wrap:wrap; gap:8px 24px; justify-content:space-between; align-items:center; }
.footer-note .legal{ display:flex; gap:18px; flex-wrap:wrap; }
.footer-credits{ padding-bottom:26px; margin-top:-6px; display:flex; flex-wrap:wrap; gap:10px; justify-content:center; align-items:center; font-size:.78rem; color:#7d7367; }
.footer-credits a{ color:#a89c8f; border-bottom:1px solid rgba(216,190,139,.35); padding-bottom:1px; }
.footer-credits a:hover{ color:var(--gold-soft); }
.footer-credits .dot{ color:#5f564d; }

/* ---------- Reveal animation (progressive enhancement) ----------
   Content is visible by default. Only when JS is present (.js on <html>)
   do we hide-then-reveal on scroll, so no-JS users always see everything. */
.js .reveal{ opacity:0; transform:translateY(22px); transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.js .reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .products{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:860px){
  body{ font-size:16px; }
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(82vw,360px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:26px;
    background:var(--cream); padding:0 var(--gutter);
    transform:translateX(100%); transition:transform .4s cubic-bezier(.4,0,.2,1);
    box-shadow:-20px 0 60px rgba(0,0,0,.18); z-index:55;
  }
  .nav a, .site-header.is-top .nav a{ color:var(--ink); font-size:1rem; }
  .nav-open .nav{ transform:none; }
  .navtoggle{ display:flex; z-index:60; }
  .nav-open .site-header.is-top .navtoggle span{ background:var(--ink); }
  .split{ grid-template-columns:1fr; }
  .split--media-right .split__media{ order:0; }
  .grid-3,.cat-grid,.stats{ grid-template-columns:1fr; }
  .grid-2,.contact-grid,.footer-top{ grid-template-columns:1fr; }
  .products{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ gap:36px; }
}
@media (max-width:480px){
  .products{ grid-template-columns:repeat(2,1fr); gap:12px; }
  .card__body{ padding:14px; }
  .card__name{ font-size:1.12rem; }
  .btn{ width:100%; justify-content:center; }
  .center .btn-row .btn{ width:auto; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; transition:none!important; scroll-behavior:auto!important; }
  .js .reveal{ opacity:1; transform:none; }
}
