/* =================================================================
   SOTRAN DEKORATIV — SHARED STYLESHEET
   Brand tokens, typography, common components, reusable blocks.
   Linked from every page in the project.
   ================================================================= */

/* -----------------------------------------------------------------
   TOKENS
   ----------------------------------------------------------------- */
:root{
  --ink:#0d0f0e;
  --ink-2:#1a1d1c;
  --paper:#ffffff;
  --paper-2:#f6f3ec;
  --paper-3:#efeae0;
  --line:#ebe7df;
  --line-strong:#d8d3c8;
  --muted:#7c7d77;
  --mint:#7ccbbd;
  --mint-deep:#4ea99a;
  --sun:#ffcf75;
  --sun-deep:#f0b94a;
  --serif:'Fraunces', 'Times New Roman', serif;
  --sans:'Jost', system-ui, sans-serif;
  --maxw:1360px;
  --pad:clamp(20px,4vw,56px);
}

/* -----------------------------------------------------------------
   RESET / BASELINE
   ----------------------------------------------------------------- */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;letter-spacing:-0.005em;line-height:1.5}
body{overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
::selection{background:var(--ink);color:#fff}

/* -----------------------------------------------------------------
   SECTION SHELL + COMMON TYPE HELPERS
   ----------------------------------------------------------------- */
section.block{padding:clamp(72px,8vw,120px) var(--pad)}
.container{max-width:var(--maxw);margin:0 auto}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:32px;flex-wrap:wrap}
.section-head.center{justify-content:center;text-align:center;flex-direction:column;align-items:center}
.section-head.center h2{margin-left:auto;margin-right:auto}
.section-head.center .lede{max-width:560px}
.section-head h2{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.03em;
  font-size:clamp(34px,4.4vw,54px);line-height:1.04;margin:14px 0 0;max-width:740px;
}
.section-head h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint-deep)}
.section-head .lede{color:var(--muted);font-size:15px;line-height:1.65;max-width:380px;margin:14px 0 0}

.eyebrow{font-size:11.5px;letter-spacing:0.28em;text-transform:uppercase;color:var(--muted);font-weight:400;display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--mint-deep)}

.section-link{font-size:13px;font-weight:500;letter-spacing:0.02em;display:inline-flex;align-items:center;gap:9px;border-bottom:1px solid var(--ink);padding-bottom:4px;transition:gap .2s}
.section-link:hover{gap:13px}

/* dark pill button (primary CTA) */
.pill-btn{display:inline-flex;align-items:center;gap:14px;padding:15px 24px 15px 28px;background:var(--ink);color:#fff;border-radius:999px;font-size:13px;font-weight:500;letter-spacing:0.02em;transition:transform .2s,background .2s}
.pill-btn:hover{transform:translateY(-2px);background:var(--mint-deep);color:var(--ink)}
.pill-btn .arr{width:26px;height:26px;border-radius:50%;background:#fff;color:var(--ink);display:inline-flex;align-items:center;justify-content:center}
.pill-btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.pill-btn.ghost .arr{background:var(--ink);color:#fff}
.pill-btn.ghost:hover{background:var(--ink);color:#fff}
.pill-btn.ghost:hover .arr{background:#fff;color:var(--ink)}

/* -----------------------------------------------------------------
   TEXT-LED DARK HERO (legal pages, contact, payment options)
   ----------------------------------------------------------------- */
.page-hero{background:var(--ink);color:#fff;padding:clamp(80px,9vw,140px) var(--pad) clamp(60px,7vw,100px);position:relative;overflow:hidden}
.page-hero::before{
  content:"";position:absolute;inset:auto -10% -40% auto;width:50%;height:80%;
  background:radial-gradient(circle, rgba(124,203,189,0.12), transparent 60%);
  pointer-events:none;
}
.page-hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:1}
.page-hero-inner.narrow{max-width:880px}
.page-hero .crumb{font-size:11.5px;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:22px;display:inline-flex;align-items:center;gap:8px}
.page-hero .crumb a{color:rgba(255,255,255,0.55);transition:color .2s}
.page-hero .crumb a:hover{color:#fff}
.page-hero .crumb .sep{opacity:0.35}
.page-hero h1{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.035em;
  font-size:clamp(40px,5.4vw,72px);line-height:1.05;margin:0 0 20px;
  color:#fff;max-width:18ch;
}
.page-hero h1 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint)}
.page-hero p.lede{
  font-size:16.5px;line-height:1.65;font-weight:300;
  color:rgba(255,255,255,0.78);
  max-width:600px;margin:0;
}

/* -----------------------------------------------------------------
   IMAGE-LED FULL-BLEED HERO (Stone Basins, Hayloft, Stores, About, Customer Images)
   ----------------------------------------------------------------- */
.image-hero{position:relative}
.image-hero-inner{
  position:relative;width:100%;
  min-height:clamp(440px, 50vw, 580px);overflow:hidden;
  background:#1f211f;
}
.image-hero-image{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.image-hero-image::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 50% 70%, rgba(0,0,0,0.4), transparent 70%);
}
.image-hero-content{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:22px;
  color:#fff;padding:60px clamp(40px,8vw,120px);
}
.image-hero h1{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.035em;
  font-size:clamp(40px,5.6vw,76px);line-height:1.05;margin:0;
  color:#fff;text-wrap:balance;max-width:18ch;
  text-shadow:0 2px 30px rgba(0,0,0,0.35);
}
.image-hero h1 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint)}
.image-hero p.lede{
  font-size:15.5px;line-height:1.65;font-weight:300;
  color:rgba(255,255,255,0.9);
  max-width:600px;margin:0;
  text-shadow:0 1px 18px rgba(0,0,0,0.45);
}

/* -----------------------------------------------------------------
   SPLIT ASYMMETRIC HERO (Hayloft Collection, About Us)
   ----------------------------------------------------------------- */
.hero-split{display:grid;grid-template-columns:1fr 1fr;min-height:clamp(520px, 60vw, 660px)}
.hero-copy{
  background:var(--ink);color:#fff;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(48px,7vw,90px) clamp(28px,5vw,72px);
  position:relative;
}
.hero-copy.seam-right::after{
  content:"";position:absolute;top:50%;right:-1px;transform:translateY(-50%);
  width:2px;height:64px;background:var(--mint);
}
.hero-copy.seam-left::after{
  content:"";position:absolute;top:50%;left:-1px;transform:translateY(-50%);
  width:2px;height:64px;background:var(--mint);
}
.hero-copy .badge{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);
  padding:8px 14px;border-radius:999px;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--mint);font-weight:500;
  margin-bottom:28px;width:fit-content;
}
.hero-copy .badge .dot{width:6px;height:6px;border-radius:50%;background:var(--mint)}
.hero-copy h1{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.035em;
  font-size:clamp(40px,5vw,68px);line-height:1.04;margin:0 0 22px;color:#fff;text-wrap:balance;max-width:14ch;
}
.hero-copy h1 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint)}
.hero-copy p.lede{
  font-size:15.5px;line-height:1.7;font-weight:300;color:rgba(255,255,255,0.78);
  max-width:440px;margin:0 0 32px;
}
.hero-copy .pill{
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 22px 14px 26px;background:#fff;color:var(--ink);
  border-radius:999px;font-size:13px;font-weight:500;letter-spacing:0.02em;transition:.2s;
  width:fit-content;
}
.hero-copy .pill:hover{background:var(--mint);color:var(--ink)}
.hero-copy .pill .arr{width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center}
.hero-photo{
  background-size:cover;background-position:center;
  position:relative;
}
.hero-photo::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,0.18) 0%, transparent 30%, rgba(0,0,0,0.18) 100%);
}
@media(max-width:900px){
  .hero-split{grid-template-columns:1fr}
  .hero-copy.seam-right::after, .hero-copy.seam-left::after{display:none}
  .hero-photo{min-height:340px}
}

/* -----------------------------------------------------------------
   TRUST STRIP (used on Homepage)
   ----------------------------------------------------------------- */
.trust-strip{background:var(--ink);color:#fff}
.trust-strip-inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  padding:26px var(--pad);gap:24px;
}
.trust-item{display:flex;align-items:center;gap:16px}
.trust-item .ic{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,0.2);display:inline-flex;align-items:center;justify-content:center;flex:none;color:var(--mint)}
.trust-item .lab{font-size:13.5px;font-weight:500;color:#fff;line-height:1.3}
.trust-item .sub{font-size:11.5px;color:rgba(255,255,255,0.55);letter-spacing:0.04em;text-transform:uppercase;margin-top:3px}
@media(max-width:780px){
  .trust-strip-inner{grid-template-columns:repeat(2,1fr);gap:32px 16px}
  .trust-item{flex-direction:column;text-align:center;align-items:center;gap:12px}
  .trust-item .sub{margin-top:2px}
}

/* -----------------------------------------------------------------
   STORE CARDS (Homepage, Stores, Contact Us)
   ----------------------------------------------------------------- */
.store-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.store-card{
  background:#fff;border-radius:8px;overflow:hidden;border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .3s, box-shadow .3s, border-color .3s;
}
.store-card:hover{transform:translateY(-4px);box-shadow:0 24px 50px -25px rgba(0,0,0,0.18);border-color:transparent}
.store-card .head{
  padding:32px 28px 24px;border-bottom:1px solid var(--line);position:relative;
}
.store-card .head .province{
  display:inline-flex;align-items:center;gap:9px;
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);font-weight:500;
  margin-bottom:18px;
}
.store-card .head .province .dot{width:7px;height:7px;border-radius:50%;background:var(--mint-deep)}
.store-card .head .city{
  font-family:var(--sans);font-weight:500;
  font-size:clamp(28px,3.2vw,36px);line-height:1.15;letter-spacing:-0.025em;
  margin:0 0 8px;color:var(--ink);
}
.store-card .head .mark{
  font-family:var(--sans);font-weight:500;font-size:11.5px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
  display:block;
}
.store-card.s1 .head .province .dot{background:var(--mint-deep)}
.store-card.s2 .head .province .dot{background:var(--sun-deep)}
.store-card.s3 .head .province .dot{background:var(--ink)}

.store-body{padding:26px 28px 28px;display:flex;flex-direction:column;flex:1}
.store-body .addr{font-size:13.5px;line-height:1.6;color:var(--ink-2);margin:0 0 22px}
.store-body .contact{list-style:none;padding:14px 0 0;margin:0 0 16px;display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--line)}
.store-body .contact li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-2);line-height:1.4}
.store-body .contact li svg{flex:none;color:var(--mint-deep);opacity:0.9}
.store-body .contact li a{color:var(--ink-2);transition:color .2s}
.store-body .contact li a:hover{color:var(--ink)}
.store-body .hours{margin:0 0 22px}
.store-body .hours .lab{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink);font-weight:500;margin-bottom:8px;display:block}
.store-body .hours p{font-size:12.5px;color:var(--muted);line-height:1.7;margin:0}

.store-actions{display:flex;gap:8px;margin-top:auto;flex-wrap:wrap}
.store-actions a{flex:1 1 auto;min-width:0;text-align:center;padding:12px 14px;border-radius:999px;font-size:12.5px;font-weight:500;letter-spacing:0.02em;border:1px solid var(--ink);transition:.2s;white-space:nowrap}
.store-actions a.primary{background:var(--ink);color:#fff}
.store-actions a.primary:hover{background:var(--mint);border-color:var(--mint);color:var(--ink)}
.store-actions a.ghost{background:#fff;color:var(--ink)}
.store-actions a.ghost:hover{background:var(--ink);color:#fff}
@media(max-width:560px){
  .store-actions{flex-direction:column;gap:8px}
  .store-actions a{flex:none;width:100%;padding:13px 16px}
}
@media(max-width:1000px){.store-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}}

/* -----------------------------------------------------------------
   PRODUCT CARD GRID + SKELETON LOADER (Homepage, Promo)
   ----------------------------------------------------------------- */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px 22px}
.prod-card{cursor:pointer}
.prod-img{
  aspect-ratio:1/1;border-radius:6px;background:var(--paper-2);overflow:hidden;position:relative;
  margin-bottom:18px;
}
.prod-img .badge{position:absolute;top:14px;left:14px;background:var(--mint);color:var(--ink);font-size:11px;font-weight:600;letter-spacing:0.05em;padding:5px 11px;border-radius:999px;z-index:2}
.prod-img .badge.dark{background:var(--ink);color:#fff}
.prod-img .badge.sun{background:var(--sun);color:var(--ink)}
.prod-cat{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.prod-name{font-family:var(--sans);font-weight:600;font-size:15.5px;line-height:1.3;margin:0 0 6px;letter-spacing:-0.01em}
.prod-price{font-size:14px;font-weight:500;color:var(--ink)}
.prod-price .was{color:var(--muted);text-decoration:line-through;margin-right:8px;font-weight:400}
@media(max-width:1100px){.prod-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:780px){.prod-grid{grid-template-columns:repeat(2,1fr)}}

/* dark variant of product grid (used in Bestsellers section) */
.dark-block{background:var(--ink);color:#fff}
.dark-block .section-head h2{color:#fff}
.dark-block .section-head h2 em{color:var(--mint)}
.dark-block .eyebrow{color:rgba(255,255,255,0.6)}
.dark-block .eyebrow::before{background:#fff}
.dark-block .section-link{color:#fff;border-color:rgba(255,255,255,0.5)}
.dark-block .lede{color:rgba(255,255,255,0.65)}
.dark-block .prod-img{background:#222524}
.dark-block .prod-cat{color:rgba(255,255,255,0.5)}
.dark-block .prod-name{color:#fff}
.dark-block .prod-price{color:#fff}
.dark-block .prod-price .was{color:rgba(255,255,255,0.45)}

/* skeleton loaders */
.prod-skel{pointer-events:none}
.prod-skel .prod-img{background:linear-gradient(110deg, var(--paper-2) 30%, var(--paper-3) 50%, var(--paper-2) 70%);background-size:200% 100%;animation:skel 1.4s ease-in-out infinite}
.prod-skel .prod-cat,.prod-skel .prod-name,.prod-skel .prod-price{background:var(--paper-2);color:transparent;border-radius:3px;display:inline-block;min-width:60%}
.prod-skel .prod-name{min-width:80%}
.prod-skel .prod-price{min-width:40%}
@keyframes skel{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* -----------------------------------------------------------------
   FAQ ACCORDION (Stone Basins, Hayloft, Mockana, Style Guide)
   ----------------------------------------------------------------- */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq{
  background:#fff;border-radius:8px;border:1px solid var(--line);overflow:hidden;
  transition:border-color .25s, box-shadow .25s;
}
.faq[open]{border-color:var(--line-strong);box-shadow:0 18px 40px -25px rgba(0,0,0,0.12)}
.faq summary{
  list-style:none;cursor:pointer;
  padding:22px 28px;display:flex;align-items:center;justify-content:space-between;gap:24px;
  font-family:var(--sans);font-weight:500;font-size:15.5px;letter-spacing:-0.005em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--line-strong);
  display:inline-flex;align-items:center;justify-content:center;color:var(--ink);flex:none;
  transition:transform .25s, background .25s, color .25s, border-color .25s;
}
.faq[open] summary .ic{background:var(--ink);color:#fff;border-color:var(--ink);transform:rotate(45deg)}
.faq .body{padding:0 28px 24px;color:var(--ink-2);font-size:14.5px;line-height:1.7}
.faq .body p{margin:0 0 10px}
.faq .body p:last-child{margin-bottom:0}

/* -----------------------------------------------------------------
   LEGAL ARTICLE BODY (Privacy Policy, T&C, Couches Warranty)
   ----------------------------------------------------------------- */
.notice{background:var(--paper-2);padding:clamp(40px,5vw,64px) var(--pad)}
.notice-inner{
  max-width:880px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-left:3px solid var(--mint-deep);
  padding:28px 32px;border-radius:0 6px 6px 0;
}
.notice-inner .lab{
  display:block;font-size:11px;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--mint-deep);font-weight:600;margin-bottom:12px;
}
.notice-inner p{font-size:14.5px;line-height:1.7;color:var(--ink-2);margin:0}
.notice-inner p strong{font-weight:600;color:var(--ink)}

article.legal{
  max-width:880px;margin:0 auto;
  padding:clamp(56px,7vw,96px) var(--pad);
}
article.legal section{margin-bottom:48px}
article.legal section:last-child{margin-bottom:0}
article.legal .num{
  display:block;font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:18px;color:var(--mint-deep);letter-spacing:0;margin-bottom:8px;
}
article.legal h2{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.025em;
  font-size:clamp(24px,2.8vw,32px);line-height:1.15;margin:0 0 20px;color:var(--ink);
}
article.legal h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint-deep)}
article.legal p{font-size:15.5px;line-height:1.75;color:var(--ink-2);margin:0 0 16px}
article.legal p:last-child{margin-bottom:0}
article.legal ul{padding-left:0;list-style:none;margin:14px 0 18px}
article.legal ul li{
  position:relative;padding:0 0 10px 24px;font-size:15px;line-height:1.7;color:var(--ink-2);
}
article.legal ul li::before{
  content:"";position:absolute;left:0;top:13px;width:10px;height:1px;background:var(--mint-deep);
}
article.legal ul li strong{font-weight:600;color:var(--ink)}
article.legal a{color:var(--ink);text-decoration:underline;text-decoration-color:var(--mint-deep);text-underline-offset:3px;text-decoration-thickness:1px;transition:color .2s}
article.legal a:hover{color:var(--mint-deep)}

/* -----------------------------------------------------------------
   NEWSLETTER BLOCK (Homepage, Promo, etc.)
   ----------------------------------------------------------------- */
.news-block{background:var(--ink);color:#fff;text-align:center;padding:clamp(72px,8vw,120px) var(--pad)}
.news-inner{max-width:720px;margin:0 auto}
.news-block .eyebrow{color:rgba(255,255,255,0.55)}
.news-block .eyebrow::before{background:#fff}
.news-block h2{font-family:var(--sans);font-weight:500;font-size:clamp(34px,4.4vw,54px);line-height:1.05;letter-spacing:-0.03em;margin:14px 0 16px;color:#fff}
.news-block h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint)}
.news-block p{color:rgba(255,255,255,0.7);font-size:15px;line-height:1.65;margin:0 0 32px}
.news-form{display:flex;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);border-radius:999px;padding:6px;max-width:520px;margin:0 auto;gap:6px}
.news-form input{flex:1;min-width:0;background:transparent;border:0;color:#fff;font-family:var(--sans);font-size:14px;padding:0 16px;outline:none}
.news-form input::placeholder{color:rgba(255,255,255,0.5)}
.news-form button{flex:none;white-space:nowrap;padding:13px 22px;background:#fff;color:var(--ink);border-radius:999px;font-size:13px;font-weight:500;letter-spacing:0.02em;transition:.2s}
.news-form button:hover{background:var(--mint);color:var(--ink)}
@media(max-width:520px){
  .news-form{flex-direction:column;border-radius:14px;padding:8px;gap:8px}
  .news-form input{padding:12px 16px;text-align:center}
  .news-form button{width:100%;padding:14px 22px}
}

/* -----------------------------------------------------------------
   CONTACT CARD (3-column row of label + value, used on legal/about)
   ----------------------------------------------------------------- */
.contact-block{background:var(--paper-2);padding:clamp(56px,6vw,80px) var(--pad)}
.contact-inner{max-width:880px;margin:0 auto;text-align:center}
.contact-inner .eyebrow{justify-content:center;margin-bottom:14px}
.contact-inner h2{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.025em;
  font-size:clamp(26px,3vw,38px);line-height:1.15;margin:0 0 28px;
}
.contact-inner h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint-deep)}
.contact-card{
  background:#fff;border:1px solid var(--line);border-radius:8px;
  padding:32px;display:grid;grid-template-columns:repeat(3,1fr);gap:0;text-align:left;
}
.contact-card .row{padding:0 24px;border-left:1px solid var(--line)}
.contact-card .row:first-child{border-left:0;padding-left:0}
.contact-card .row:last-child{padding-right:0}
.contact-card .lab{font-size:10.5px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);font-weight:500;display:block;margin-bottom:8px}
.contact-card .val{font-family:var(--sans);font-weight:500;font-size:15px;color:var(--ink);line-height:1.4}
.contact-card .val a{text-decoration:none;color:var(--ink);border-bottom:1px solid var(--mint-deep);padding-bottom:1px}
.contact-card .val a:hover{color:var(--mint-deep)}
@media(max-width:780px){
  .contact-card{grid-template-columns:1fr;gap:0}
  .contact-card .row{border-left:0;padding:18px 0;border-top:1px solid var(--line)}
  .contact-card .row:first-child{border-top:0;padding-top:0}
  .contact-card .row:last-child{padding-bottom:0}
}

/* -----------------------------------------------------------------
   QUOTE / PULL QUOTE (Style Guide, About, Mockana)
   ----------------------------------------------------------------- */
.pull{
  margin:48px 0;padding:38px 32px 38px 44px;
  border-left:3px solid var(--mint-deep);
  background:var(--paper-2);border-radius:0 6px 6px 0;
}
.pull p{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(20px,2.2vw,26px);line-height:1.4;letter-spacing:-0.01em;color:var(--ink);
  margin:0;
}

/* -----------------------------------------------------------------
   BLOG POST META (Style Guide, Mockana)
   ----------------------------------------------------------------- */
.post-meta{
  display:inline-flex;align-items:center;gap:12px;margin-bottom:22px;
  font-size:12px;letter-spacing:0.22em;text-transform:uppercase;font-weight:500;
  background:var(--ink);color:var(--mint);
  padding:9px 16px;border-radius:999px;
  border:1px solid rgba(255,255,255,0.1);
}
.post-meta .dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,0.4)}
.post-meta .read{color:rgba(255,255,255,0.85)}

/* -----------------------------------------------------------------
   FORM FIELDS (Contact Us, future signup forms)
   ----------------------------------------------------------------- */
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field label{
  font-size:10.5px;letter-spacing:0.2em;text-transform:uppercase;font-weight:500;color:var(--ink);
}
.form-field input,
.form-field select,
.form-field textarea{
  background:#fff;border:1px solid var(--line-strong);border-radius:6px;
  padding:14px 16px;font-family:var(--sans);font-size:14.5px;color:var(--ink);
  transition:border-color .2s, box-shadow .2s;outline:none;
  width:100%;
}
.form-field textarea{resize:vertical;min-height:140px;line-height:1.6}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{border-color:var(--mint-deep);box-shadow:0 0 0 3px rgba(124,203,189,0.18)}
.form-field select{
  appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230d0f0e' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;
}
.form-field .hint{font-size:11.5px;color:var(--muted);margin-top:2px}

/* -----------------------------------------------------------------
   EDITORIAL SPLIT (Homepage, About Us, Stone Basins)
   Two-column layout: copy on one side, image on the other.
   Includes a 3-up stats row inside .edit-copy.
   ----------------------------------------------------------------- */
.edit-split{background:var(--paper-2)}
.edit-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(40px,6vw,96px);align-items:center}
.edit-grid.copy-first{grid-template-columns:1.05fr 1fr}
.edit-grid.image-first{grid-template-columns:1.15fr 1fr}
.edit-copy .eyebrow{margin-bottom:18px}
.edit-copy h2{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.03em;
  font-size:clamp(34px,4.4vw,54px);line-height:1.05;margin:0 0 24px;
}
.edit-copy h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint-deep)}
.edit-copy p{color:var(--ink-2);font-size:15px;line-height:1.7;margin:0 0 14px;max-width:480px}

.edit-copy .meta-row{display:flex;gap:0;margin:32px 0 36px;padding-top:30px;border-top:1px solid var(--line-strong)}
.edit-copy .meta-row .stat{flex:1;padding:0 22px;min-width:0}
.edit-copy .meta-row .stat:first-child{padding-left:0}
.edit-copy .meta-row .stat:last-child{padding-right:0}
.edit-copy .meta-row .stat + .stat{border-left:1px solid var(--line-strong)}
.edit-copy .meta-row .stat .num{
  font-family:var(--serif) !important;font-style:italic !important;font-weight:400 !important;
  font-size:clamp(24px, 3.2vw, 42px) !important;line-height:1 !important;
  letter-spacing:-0.025em;color:var(--mint-deep) !important;white-space:nowrap;
}
.edit-copy .meta-row .stat .lb{
  font-size:clamp(10px, 0.9vw, 11.5px) !important;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--muted);margin-top:6px;display:block;
}
@media(max-width:780px){
  .edit-copy .meta-row{margin:28px 0 28px;padding-top:24px}
  .edit-copy .meta-row .stat{padding:0 10px}
}
@media(max-width:420px){
  .edit-copy .meta-row .stat{padding:0 6px}
}

.edit-image{
  aspect-ratio:5/6;border-radius:6px;overflow:hidden;
  background-size:cover;background-position:center;
  position:relative;
}
.edit-image.flat{aspect-ratio:5/4}
.edit-image::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(80% 60% at 50% 70%, rgba(0,0,0,0.18), transparent 70%);
}
@media(max-width:900px){
  .edit-grid{grid-template-columns:1fr}
  .edit-image{aspect-ratio:4/4}
  .edit-image.flat{aspect-ratio:4/3}
}

/* -----------------------------------------------------------------
   COMPACT PRODUCT GRID (Stone Basins, Hayloft Collection)
   4-up variant with hover-revealed "View product" pill and contained
   product photography (background-size:contain) rather than cover.
   ----------------------------------------------------------------- */
.prod-grid.compact{grid-template-columns:repeat(4,1fr);gap:36px 24px}
.prod-grid.compact .prod-card{display:flex;flex-direction:column}
.prod-grid.compact .prod-img .photo{
  position:absolute;inset:0;background-size:contain;background-position:center;background-repeat:no-repeat;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
/* cover variant for lifestyle product photos (full-bleed shots) */
.prod-grid.compact.cover-photo .prod-img .photo{background-size:cover}
.prod-grid.compact .prod-card:hover .prod-img .photo{transform:scale(1.05)}
.prod-grid.compact .prod-view{
  position:absolute;left:14px;right:14px;bottom:14px;z-index:2;
  background:var(--ink);color:#fff;border-radius:999px;
  padding:11px 16px;font-size:12.5px;font-weight:500;letter-spacing:0.02em;
  display:flex;align-items:center;justify-content:center;gap:9px;
  opacity:0;transform:translateY(8px);transition:.3s;
}
.prod-grid.compact .prod-card:hover .prod-view{opacity:1;transform:translateY(0)}
.prod-grid.compact .prod-name{font-size:16px;margin:0;font-weight:600}
@media(max-width:1100px){.prod-grid.compact{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.prod-grid.compact{grid-template-columns:1fr}}

/* -----------------------------------------------------------------
   BLOG POST LAYOUT (Style Guide, Mockana Diffusers)
   Full-bleed hero with bottom-anchored title + article body with
   pull-quotes, dark callouts, captioned figures and end CTA.
   ----------------------------------------------------------------- */
.post-hero{position:relative}
.post-hero-inner{
  position:relative;width:100%;
  min-height:clamp(380px, 46vw, 540px);overflow:hidden;background:#1f211f;
}
.post-hero-image{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
}
.post-hero-content{
  position:absolute;inset:0;z-index:2;
  display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;
  color:#fff;padding:clamp(48px,7vw,80px) clamp(28px,6vw,90px);
  max-width:1080px;margin:0 auto;
}
.post-hero h1{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.03em;
  font-size:clamp(34px,4.6vw,62px);line-height:1.08;margin:0 0 20px;
  color:#fff;text-wrap:balance;max-width:22ch;text-shadow:0 2px 30px rgba(0,0,0,0.35);
}
.post-hero h1 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint)}
.post-hero p.dek{
  font-size:16.5px;line-height:1.55;font-weight:300;color:rgba(255,255,255,0.9);
  max-width:620px;margin:0;text-shadow:0 1px 18px rgba(0,0,0,0.45);
}

article.post{max-width:1240px;margin:0 auto;padding:clamp(56px,7vw,96px) var(--pad)}
.lead{
  font-family:var(--sans);font-weight:300;
  font-size:clamp(19px,2vw,22px);line-height:1.55;
  color:var(--ink-2);margin:0 0 36px;letter-spacing:-0.012em;
}
.lead em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint-deep)}
article.post h2{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.025em;
  font-size:clamp(26px,2.8vw,34px);line-height:1.18;margin:56px 0 18px;
}
article.post h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint-deep)}
article.post h2:first-child{margin-top:0}
article.post p{font-size:16px;line-height:1.78;color:var(--ink-2);margin:0 0 18px}
article.post p:last-child{margin-bottom:0}
article.post .figure{margin:36px 0;border-radius:6px;overflow:hidden;background:var(--paper-2)}
article.post .figure img{width:100%;height:auto;display:block}
article.post .figure .cap{
  padding:14px 20px;font-size:12px;letter-spacing:0.06em;color:var(--muted);
  font-style:italic;font-family:var(--serif);
}

/* dark callout box */
.qbox{
  margin:48px 0;padding:36px 36px 32px;
  background:var(--ink);color:#fff;border-radius:8px;
}
.qbox .lab{
  font-size:11px;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--mint);font-weight:500;margin-bottom:16px;display:block;
}
.qbox h3{
  font-family:var(--sans);font-weight:500;font-size:24px;line-height:1.25;
  letter-spacing:-0.02em;margin:0 0 20px;color:#fff;
}
.qbox h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--sun)}
.qbox ol, .qbox ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.qbox ol{counter-reset:q}
.qbox ol li{
  counter-increment:q;display:flex;align-items:flex-start;gap:14px;
  font-size:15.5px;line-height:1.55;color:rgba(255,255,255,0.9);
}
.qbox ol li::before{
  content:counter(q,decimal-leading-zero);
  font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint);
  font-size:15px;flex:none;line-height:1.55;min-width:22px;
}
.qbox ul li{display:flex;align-items:flex-start;gap:14px;font-size:15.5px;line-height:1.55;color:rgba(255,255,255,0.9)}
.qbox ul li strong{color:var(--mint);font-weight:500;min-width:170px;flex:none;display:block}
@media(max-width:640px){.qbox ul li{flex-direction:column;gap:4px}.qbox ul li strong{min-width:0}}

/* style-block (image + tag + h2 + body for catalog-style entries in a post) */
.style-block{margin:64px 0}
.style-block .figure{margin:0 0 28px}
.style-block h2{margin:0 0 16px}
.style-block .tag{
  display:inline-block;font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--mint-deep);font-weight:500;margin-bottom:10px;
}
@media(max-width:680px){.style-block{margin:48px 0}}

/* paired figures inside a post */
.fig-pair{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:36px 0}
.fig-pair .figure{margin:0}
@media(max-width:640px){.fig-pair{grid-template-columns:1fr}}

/* FAQ section wrapper (blog-post version on cream background) */
.faq-section{background:var(--paper-2);padding:clamp(56px,7vw,96px) var(--pad)}
.faq-wrap{max-width:1240px;margin:0 auto}
.faq-wrap .head{margin-bottom:36px}
.faq-wrap h2{
  font-family:var(--sans);font-weight:500;letter-spacing:-0.025em;
  font-size:clamp(28px,3vw,38px);line-height:1.15;margin:14px 0 0;
}
.faq-wrap h2 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint-deep)}

/* dark closing CTA (blog-post end CTA, with two-pill button row) */
.end-cta{padding:clamp(64px,7vw,100px) var(--pad);background:var(--ink);color:#fff;text-align:center}
.end-cta .inner{max-width:640px;margin:0 auto}
.end-cta .lab{
  font-size:11px;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--mint);font-weight:500;margin-bottom:14px;display:block;
}
.end-cta h3{
  font-family:var(--sans);font-weight:500;font-size:clamp(28px,3.4vw,42px);
  line-height:1.1;letter-spacing:-0.025em;margin:0 0 14px;color:#fff;
}
.end-cta h3 em{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--mint)}
.end-cta p{color:rgba(255,255,255,0.7);font-size:15px;line-height:1.65;margin:0 0 28px}
.end-cta .btn-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.end-cta a.pill{
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 22px 14px 26px;background:#fff;color:var(--ink);
  border-radius:999px;font-size:13px;font-weight:500;letter-spacing:0.02em;transition:.2s;
}
.end-cta a.pill .arr{width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;display:inline-flex;align-items:center;justify-content:center}
.end-cta a.pill:hover{background:var(--mint);color:var(--ink)}
.end-cta a.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.3)}
.end-cta a.ghost .arr{background:#fff;color:var(--ink)}
.end-cta a.ghost:hover{background:#fff;color:var(--ink)}

/* -----------------------------------------------------------------
   PRE-ARRIVALS PAGE — hero, how-it-works, product grid
   ----------------------------------------------------------------- */

/* hero */
.pa-hero{background:linear-gradient(180deg,rgba(13,15,14,0.72) 0%,rgba(13,15,14,0.86) 100%),url('https://preprod.sotran.co.za/wp-content/uploads/2026/05/Indian-Furniture-Collection-scaled.jpg') center/cover no-repeat var(--ink);color:var(--paper);padding:120px var(--pad) 110px;position:relative;overflow:hidden}
.pa-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 85% 20%,rgba(124,203,189,0.22) 0%,transparent 50%),radial-gradient(ellipse at 10% 90%,rgba(255,207,117,0.10) 0%,transparent 45%);pointer-events:none}
.pa-hero::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);background-size:64px 64px;background-position:-1px -1px;pointer-events:none;mask-image:radial-gradient(ellipse at center,rgba(0,0,0,0.7) 0%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,rgba(0,0,0,0.7) 0%,transparent 75%)}
.pa-hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:1}
.pa-hero-inner > div{max-width:920px}
.pa-hero h1{font-family:var(--sans);font-weight:500;font-size:clamp(40px,6.2vw,84px);line-height:1.02;letter-spacing:-0.035em;margin:0 0 32px}
.pa-hero h1 em{font-family:var(--serif);font-style:italic;color:var(--sun);font-weight:300;letter-spacing:-0.02em}
.pa-hero .dek{font-size:clamp(15px,1.3vw,19px);line-height:1.6;max-width:620px;color:rgba(255,255,255,0.78);margin:0 0 44px;font-weight:300}
.pa-hero .hero-meta{display:flex;align-items:center;gap:24px;flex-wrap:wrap;padding-top:32px;border-top:1px solid rgba(255,255,255,0.1)}
.pa-hero .hero-meta .item{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(255,255,255,0.7);letter-spacing:0.01em}
.pa-hero .hero-meta .item svg{width:16px;height:16px;color:var(--mint);flex:none}
.pa-hero .hero-meta .sep{width:1px;height:14px;background:rgba(255,255,255,0.18)}

/* how-it-works */
.pa-how{padding:80px var(--pad);background:var(--paper-2)}
.pa-how-inner{max-width:var(--maxw);margin:0 auto}
.pa-how .head{text-align:center;margin-bottom:56px;max-width:640px;margin-left:auto;margin-right:auto}
.pa-how h2{font-family:var(--sans);font-weight:500;font-size:clamp(26px,3.6vw,44px);line-height:1.1;letter-spacing:-0.03em;margin:0 0 16px}
.pa-how h2 em{font-family:var(--serif);font-style:italic;color:var(--mint-deep);font-weight:300;letter-spacing:-0.015em}
.pa-how .lede{color:var(--muted);font-size:15px;line-height:1.6;margin:0}
.pa-how .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pa-how .step{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:32px 28px;position:relative}
.pa-how .step .num{font-family:var(--serif);font-style:italic;font-weight:300;font-size:42px;color:var(--mint-deep);line-height:1;margin-bottom:14px}
.pa-how .step h3{font-family:var(--serif);font-weight:400;font-size:21px;margin:0 0 10px;letter-spacing:-0.01em}
.pa-how .step p{font-size:14px;line-height:1.65;color:var(--ink-2);margin:0}

/* section title between sections */
.pa-filters{padding:80px var(--pad) 16px;background:var(--paper)}
.pa-filters-inner{max-width:var(--maxw);margin:0 auto}
.pa-filters .section-title h2{font-family:var(--sans);font-weight:500;font-size:clamp(24px,3vw,38px);line-height:1.1;letter-spacing:-0.03em;margin:0 0 12px}
.pa-filters .section-title h2 em{font-family:var(--serif);font-style:italic;color:var(--mint-deep);font-weight:300;letter-spacing:-0.015em}
.pa-filters .section-title p{font-size:14px;color:var(--muted);line-height:1.5;margin:0;max-width:560px}

/* product grid */
.pa-grid-wrap{padding:36px var(--pad) 96px;background:var(--paper)}
.pa-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.pa-card{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}
.pa-card:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:0 8px 24px rgba(13,15,14,0.06)}
.pa-card .imgwrap{position:relative;background:var(--paper-3);aspect-ratio:1/1;overflow:hidden}
.pa-card .imgwrap img{width:100%;height:100%;object-fit:cover;object-position:center}
.pa-card .placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--muted);background:linear-gradient(135deg,var(--paper-3) 25%,transparent 25%),linear-gradient(225deg,var(--paper-3) 25%,transparent 25%),linear-gradient(45deg,var(--paper-3) 25%,transparent 25%),linear-gradient(315deg,var(--paper-3) 25%,var(--paper-2) 25%);background-size:18px 18px;background-position:0 0,9px 0,9px -9px,0 9px}
.pa-card .placeholder svg{width:28px;height:28px;opacity:0.55}
.pa-card .placeholder span{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;font-weight:500;opacity:0.7}
.pa-card .badge{position:absolute;top:12px;left:12px;background:var(--ink);color:var(--paper);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;padding:6px 10px;border-radius:999px;font-weight:500}
.pa-card .body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.pa-card .code{font-size:10px;letter-spacing:0.14em;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.pa-card .name{font-family:var(--serif);font-size:16px;font-weight:400;line-height:1.3;margin:0 0 10px;color:var(--ink);letter-spacing:-0.005em}
.pa-card .price{font-family:var(--sans);margin-top:auto;margin-bottom:14px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;line-height:1.2}
.pa-card .price .was{font-size:13px;color:var(--muted);text-decoration:line-through;font-weight:400}
.pa-card .price .now{font-size:17px;color:var(--mint-deep);font-weight:600;letter-spacing:-0.005em}
.pa-card .price .off{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink);font-weight:500;background:var(--sun);padding:3px 8px;border-radius:999px;line-height:1.2}
.pa-card .actions{display:flex;gap:6px}
.pa-card .btn-reserve{flex:1;background:var(--ink);color:var(--paper);border-radius:999px;padding:11px 14px;font-size:12px;letter-spacing:0.04em;font-weight:500;text-align:center;transition:background .2s ease}
.pa-card .btn-reserve:hover{background:var(--mint-deep)}

/* FAQ on pa page reuses .faq-section */
.pa-faq{padding-top:64px}
.pa-faq .head h2,
.end-cta .inner h3{font-family:var(--sans);font-weight:500;letter-spacing:-0.03em}
.pa-faq .head h2 em,
.end-cta .inner h3 em{font-family:var(--serif);font-style:italic;font-weight:300;letter-spacing:-0.015em}

/* responsive */
@media (max-width:1100px){.pa-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:880px){
  .pa-how .steps{grid-template-columns:1fr}
}
@media (max-width:780px){.pa-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){
  .pa-hero{padding:72px var(--pad) 60px}
  .pa-hero .hero-meta .sep{display:none}
  .pa-how{padding:56px var(--pad)}
  .pa-how .head{margin-bottom:36px}
  .pa-filters{padding:56px var(--pad) 12px}
  .pa-grid-wrap{padding:28px var(--pad) 64px}
}
@media (max-width:520px){.pa-grid{grid-template-columns:1fr}}

/* -----------------------------------------------------------------
   PRE-ARRIVALS — REP PICKER MODAL
   ----------------------------------------------------------------- */
.pa-rep-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:24px}
.pa-rep-modal.is-open{display:flex}
.pa-rep-backdrop{position:absolute;inset:0;background:rgba(13,15,14,0.6);backdrop-filter:blur(4px);cursor:pointer}
.pa-rep-panel{position:relative;background:var(--paper);border-radius:22px;padding:clamp(28px,4vw,44px);max-width:760px;width:100%;max-height:calc(100vh - 48px);overflow-y:auto;box-shadow:0 30px 80px rgba(0,0,0,0.25);animation:paRepIn .25s ease-out}
@keyframes paRepIn{from{opacity:0;transform:translateY(12px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}
.pa-rep-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;background:var(--paper-2);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;transition:background .2s ease;border:0;cursor:pointer;z-index:2;padding:0;line-height:1}
.pa-rep-close:hover{background:var(--paper-3)}
.pa-rep-close svg{width:16px;height:16px;display:block;color:var(--ink);stroke:currentColor}
.pa-rep-head{margin-bottom:28px;text-align:center;max-width:520px;margin-left:auto;margin-right:auto}
.pa-rep-head h3{font-family:var(--sans);font-weight:500;font-size:clamp(22px,2.6vw,30px);line-height:1.15;letter-spacing:-0.025em;margin:0 0 10px}
.pa-rep-head h3 em{font-family:var(--serif);font-style:italic;color:var(--mint-deep);font-weight:300;letter-spacing:-0.015em}
.pa-rep-head p{font-size:14px;color:var(--ink-2);line-height:1.6;margin:0}
.pa-rep-piece{margin-top:14px;display:inline-block;background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:500}
.pa-rep-piece:empty{display:none}
.pa-rep-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.pa-rep-card{display:flex;align-items:center;gap:16px;background:var(--paper-2);border:1px solid var(--line);border-radius:14px;padding:18px;transition:all .2s ease;text-decoration:none;color:var(--ink)}
.pa-rep-card:hover{border-color:var(--ink);background:var(--paper);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,0.06)}
.pa-rep-card .ph{flex:none;width:58px;height:58px;border-radius:50%;background:var(--mint);color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:24px;font-weight:400;letter-spacing:-0.01em}
.pa-rep-card .ph span{line-height:1}
.pa-rep-card .info{flex:1;min-width:0}
.pa-rep-card .name{font-family:var(--serif);font-size:18px;font-weight:400;margin-bottom:2px;letter-spacing:-0.01em}
.pa-rep-card .role{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:8px}
.pa-rep-card .num{display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-2);font-weight:500}
.pa-rep-card .num svg{width:14px;height:14px;color:#25D366;flex:none}
@media (max-width:560px){
  .pa-rep-grid{grid-template-columns:1fr}
  .pa-rep-card{padding:14px}
  .pa-rep-card .ph{width:48px;height:48px;font-size:20px}
}

/* -----------------------------------------------------------------
   WIN A R10,000 VOUCHER — COMPETITION PAGE
   ----------------------------------------------------------------- */

/* hero */
.win-hero{background:var(--ink);color:var(--paper);padding:110px var(--pad) 90px;position:relative;overflow:hidden}
.win-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 85% 25%,rgba(255,207,117,0.18) 0%,transparent 50%),radial-gradient(ellipse at 10% 80%,rgba(124,203,189,0.14) 0%,transparent 45%);pointer-events:none}
.win-hero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:1;display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center}
.win-hero h1{font-family:var(--sans);font-weight:500;font-size:clamp(36px,5.8vw,76px);line-height:1.02;letter-spacing:-0.035em;margin:0 0 28px}
.win-hero h1 em{font-family:var(--serif);font-style:italic;color:var(--sun);font-weight:300;letter-spacing:-0.02em}
.win-hero .dek{font-size:clamp(15px,1.3vw,18px);line-height:1.65;max-width:560px;color:rgba(255,255,255,0.78);margin:0 0 40px;font-weight:300}
.win-hero .hero-meta{display:flex;gap:20px;flex-wrap:wrap;padding-top:28px;border-top:1px solid rgba(255,255,255,0.1)}
.win-hero .hero-meta .item{display:flex;align-items:center;gap:10px;font-size:13px;color:rgba(255,255,255,0.7)}
.win-hero .hero-meta .item svg{width:16px;height:16px;color:var(--sun);flex:none}

/* hero image collage */
.win-hero .collage{position:relative;aspect-ratio:1/1.05}
.win-hero .collage figure{position:absolute;margin:0;border-radius:14px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,0.45)}
.win-hero .collage figure img{width:100%;height:100%;object-fit:cover;display:block}
.win-hero .collage .f1{top:0;left:8%;width:60%;aspect-ratio:1/1;transform:rotate(-3deg)}
.win-hero .collage .f2{bottom:6%;right:0;width:54%;aspect-ratio:1/1;transform:rotate(4deg)}
.win-hero .collage .f3{bottom:0;left:0;width:40%;aspect-ratio:1/1;transform:rotate(-6deg);border:3px solid var(--ink)}

/* how to enter */
.win-how{padding:96px var(--pad);background:var(--paper-2)}
.win-how-inner{max-width:var(--maxw);margin:0 auto}
.win-how .head{text-align:center;margin-bottom:64px;max-width:640px;margin-left:auto;margin-right:auto}
.win-how h2{font-family:var(--sans);font-weight:500;font-size:clamp(26px,3.6vw,44px);line-height:1.1;letter-spacing:-0.03em;margin:0 0 16px}
.win-how h2 em{font-family:var(--serif);font-style:italic;color:var(--mint-deep);font-weight:300;letter-spacing:-0.015em}
.win-how .lede{color:var(--muted);font-size:15px;line-height:1.6;margin:0}
.win-how .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.win-how .step{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:34px 30px}
.win-how .step .num{font-family:var(--serif);font-style:italic;font-weight:300;font-size:44px;color:var(--mint-deep);line-height:1;margin-bottom:16px}
.win-how .step h3{font-family:var(--serif);font-weight:400;font-size:22px;margin:0 0 10px;letter-spacing:-0.01em}
.win-how .step p{font-size:14px;line-height:1.65;color:var(--ink-2);margin:0}

/* form section */
.win-form-section{padding:110px var(--pad);background:var(--paper)}
.win-form-inner{max-width:920px;margin:0 auto}
.win-form-inner .head{text-align:center;margin-bottom:48px}
.win-form-inner h2{font-family:var(--sans);font-weight:500;font-size:clamp(28px,3.8vw,48px);line-height:1.05;letter-spacing:-0.03em;margin:0 0 18px}
.win-form-inner h2 em{font-family:var(--serif);font-style:italic;color:var(--mint-deep);font-weight:300;letter-spacing:-0.015em}
.win-form-inner .head p{color:var(--ink-2);font-size:16px;line-height:1.6;max-width:560px;margin:0 auto}
.win-form-wrap{background:var(--paper-2);border:1px solid var(--line);border-radius:22px;padding:clamp(24px,4vw,52px);position:relative}
.win-form-wrap::before{content:"";position:absolute;inset:0;border-radius:22px;background:radial-gradient(ellipse at top right,rgba(255,207,117,0.12) 0%,transparent 60%);pointer-events:none}
.win-form-wrap > *{position:relative}

/* what you could buy / range grid */
.win-buy{padding:96px var(--pad) 110px;background:var(--paper-2)}
.win-buy-inner{max-width:var(--maxw);margin:0 auto}
.win-buy .head{text-align:center;margin-bottom:56px;max-width:640px;margin-left:auto;margin-right:auto}
.win-buy h2{font-family:var(--sans);font-weight:500;font-size:clamp(26px,3.6vw,44px);line-height:1.1;letter-spacing:-0.03em;margin:0 0 16px}
.win-buy h2 em{font-family:var(--serif);font-style:italic;color:var(--mint-deep);font-weight:300;letter-spacing:-0.015em}
.win-buy .lede{color:var(--muted);font-size:15px;line-height:1.6;margin:0}
.win-buy .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.win-buy figure{margin:0;border-radius:14px;overflow:hidden;aspect-ratio:1/1;background:var(--paper-3)}
.win-buy figure img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.win-buy figure:hover img{transform:scale(1.04)}

/* T&Cs */
.win-tcs{padding:80px var(--pad);background:var(--paper);border-top:1px solid var(--line)}
.win-tcs-inner{max-width:820px;margin:0 auto}
.win-tcs h2{font-family:var(--sans);font-weight:500;font-size:clamp(22px,2.5vw,30px);line-height:1.15;letter-spacing:-0.025em;margin:0 0 24px;text-align:center}
.win-tcs h2 em{font-family:var(--serif);font-style:italic;color:var(--mint-deep);font-weight:300}
.win-tcs ol{counter-reset:tcs;list-style:none;padding:0;margin:0}
.win-tcs li{counter-increment:tcs;position:relative;padding:18px 0 18px 60px;border-bottom:1px solid var(--line);font-size:14.5px;line-height:1.65;color:var(--ink-2)}
.win-tcs li:last-child{border-bottom:0}
.win-tcs li::before{content:counter(tcs,decimal-leading-zero);position:absolute;left:0;top:18px;font-family:var(--serif);font-style:italic;font-weight:300;font-size:22px;color:var(--mint-deep)}

/* responsive — tablet */
@media (max-width:880px){
  .win-hero{padding:80px var(--pad) 64px}
  .win-hero-inner{grid-template-columns:1fr;gap:48px}
  .win-hero .collage{max-width:460px;margin:0 auto}
  .win-how{padding:72px var(--pad)}
  .win-how .head{margin-bottom:44px}
  .win-how .steps{grid-template-columns:1fr}
  .win-form-section{padding:72px var(--pad)}
  .win-form-inner .head{margin-bottom:36px}
  .win-buy{padding:72px var(--pad) 80px}
  .win-buy .head{margin-bottom:40px}
  .win-buy .grid{grid-template-columns:repeat(2,1fr)}
  .win-tcs{padding:60px var(--pad)}
}

/* responsive — phone */
@media (max-width:560px){
  .win-hero{padding:64px var(--pad) 52px}
  .win-hero .dek{margin-bottom:28px}
  .win-hero .hero-meta{gap:14px;padding-top:22px}
  .win-hero .hero-meta .item{font-size:12px}
  .win-hero .collage{max-width:340px}
  .win-how{padding:56px var(--pad)}
  .win-how .head{margin-bottom:32px}
  .win-how .step{padding:28px 24px}
  .win-how .step .num{font-size:36px;margin-bottom:10px}
  .win-how .step h3{font-size:19px}
  .win-form-section{padding:56px var(--pad)}
  .win-form-inner .head{margin-bottom:28px}
  .win-buy{padding:56px var(--pad) 64px}
  .win-buy .grid{gap:12px}
  .win-tcs{padding:48px var(--pad)}
  .win-tcs li{padding:16px 0 16px 48px;font-size:14px}
  .win-tcs li::before{font-size:19px;top:16px}
}

/* -----------------------------------------------------------------
   END
   ----------------------------------------------------------------- */
