/* ============================================================================
   Marokko Shirts — "Atlas" design system
   Moroccan flag red + green, Sahara sand neutrals, zellige geometry, Fraunces display.
   ========================================================================== */

/* ----------------------------------- Fonts ----------------------------------- */
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;
  src:url(/assets/fonts/e4af272ccee01ff0-s.p.woff2) format("woff2");
  unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;
  src:url(/assets/fonts/8e9860b6e62d6359-s.woff2) format("woff2");
  unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}
@font-face{font-family:Fraunces;font-style:normal;font-weight:500 700;font-display:swap;
  src:url(/assets/fonts/fraunces-latin.woff2) format("woff2");
  unicode-range:u+0000-00ff,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+2000-206f,u+2074,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}
@font-face{font-family:Fraunces;font-style:normal;font-weight:500 700;font-display:swap;
  src:url(/assets/fonts/fraunces-latinext.woff2) format("woff2");
  unicode-range:u+0100-02af,u+0304,u+0308,u+0329,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}

/* ----------------------------------- Tokens -----------------------------------
   Design-variabelen (kleuren, radii, schaduwen). Pas hier de huisstijl aan:
   rood = Marokkaanse vlag, groen = vlag, sand/gold = Sahara-accent.            */
:root{
  /* Moroccan red */
  --red-900:#4d0d18; --red-800:#6e1423; --red-700:#8c1a2c; --red:#b21e30; --red-600:#c1272d; --red-soft:#e7b9bd;
  /* Moroccan green */
  --green-900:#06281b; --green-800:#0a3a28; --green-700:#0e5236; --green:#11704a; --green-600:#1a8a5c;
  /* Sahara sand */
  --sand-50:#faf6ee; --sand-100:#f4ecdb; --sand-200:#ece0c7; --sand-300:#e0cda6; --sand-400:#cdb182; --sand-500:#b8945f;
  /* Gold / brass (zellige) */
  --gold:#c2922b; --gold-400:#d8ad45; --gold-200:#ecd699;
  /* Ink */
  --ink:#241a12; --ink-2:#4a3c2e; --ink-3:#7a6a57;
  --cream:#fffdf8; --line:#e6d8bf; --line-strong:#d8c39c;
  --wa:#25D366; --wa-dark:#1ebe5a;

  --maxw:1180px;
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:34px; --r-pill:999px;
  --shadow-sm:0 1px 2px rgba(40,26,12,.06), 0 4px 14px -8px rgba(40,26,12,.18);
  --shadow-md:0 10px 30px -14px rgba(40,26,12,.35);
  --shadow-red:0 16px 40px -16px rgba(178,30,48,.55);
  --shadow-green:0 16px 40px -16px rgba(14,82,54,.5);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* zellige 8-point star tiles (two overlapping squares) */
:root{
  --zellige-gold:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Cg fill='none' stroke='%23c2922b' stroke-opacity='0.16' stroke-width='1.1'%3E%3Crect x='18' y='18' width='28' height='28'/%3E%3Crect x='18' y='18' width='28' height='28' transform='rotate(45 32 32)'/%3E%3C/g%3E%3C/svg%3E");
  --zellige-cream:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.06' stroke-width='1.1'%3E%3Crect x='18' y='18' width='28' height='28'/%3E%3Crect x='18' y='18' width='28' height='28' transform='rotate(45 32 32)'/%3E%3C/g%3E%3C/svg%3E");
}

/* ----------------------------------- Reset ----------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--sand-50);
  line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  min-height:100vh;display:flex;flex-direction:column;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
input,textarea,select{font:inherit;color:inherit}
svg{display:block}
::selection{background:var(--red-600);color:#fff}

/* ----------------------------------- Type ----------------------------------- */
.display{font-family:Fraunces,Georgia,serif;font-optical-sizing:auto;font-weight:600;line-height:1.02;letter-spacing:-.015em}
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--red-600)}
.eyebrow--gold{color:var(--gold)}
.eyebrow--sand{color:var(--sand-300)}
.lead{font-size:1.08rem;color:var(--ink-2);line-height:1.7}

/* ----------------------------------- Layout ----------------------------------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.flex-1{flex:1}
.section{padding-block:clamp(3.5rem,7vw,6rem)}
.section__head{max-width:640px;margin-bottom:2.6rem}
.section__head h2{font-size:clamp(1.9rem,4.4vw,2.9rem);margin-top:.5rem}
.section__head p{margin-top:.9rem}
.center{text-align:center;margin-inline:auto}

/* divider with zellige dots */
.zdivider{height:34px;display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold)}
.zdivider span{width:8px;height:8px;transform:rotate(45deg);background:currentColor;opacity:.5}
.zdivider span:nth-child(2){opacity:.9;width:11px;height:11px}

/* ----------------------------------- Buttons ----------------------------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  height:52px;padding-inline:1.7rem;border-radius:var(--r-pill);font-weight:600;font-size:.95rem;
  transition:transform .18s var(--ease),box-shadow .25s var(--ease),background-color .2s,color .2s;
  white-space:nowrap;border:1.5px solid transparent}
.btn:active{transform:scale(.97)}
.btn--sm{height:44px;padding-inline:1.25rem;font-size:.9rem}
.btn--block{width:100%}
.btn--primary{background:var(--red-600);color:#fff;box-shadow:var(--shadow-red)}
.btn--primary:hover{background:var(--red-700);box-shadow:0 20px 46px -16px rgba(178,30,48,.7);transform:translateY(-2px)}
.btn--dark{background:var(--ink);color:var(--sand-100)}
.btn--dark:hover{background:#3a2c1d;transform:translateY(-2px)}
.btn--ghost{background:transparent;border-color:currentColor;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--sand-50);border-color:var(--ink)}
.btn--gold{background:linear-gradient(135deg,var(--gold-400),var(--gold));color:#3a2a06;box-shadow:0 14px 34px -16px rgba(194,146,43,.8)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 20px 44px -16px rgba(194,146,43,.9)}
.btn--wa{background:var(--wa);color:#fff;box-shadow:0 14px 34px -16px rgba(37,211,102,.8)}
.btn--wa:hover{background:var(--wa-dark);transform:translateY(-2px)}
.btn--outline-light{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.35);color:#fff;backdrop-filter:blur(4px)}
.btn--outline-light:hover{background:rgba(255,255,255,.14)}
.btn[aria-disabled="true"],.btn:disabled{cursor:not-allowed;opacity:1}
.btn--muted{background:var(--sand-200);color:var(--ink-3);box-shadow:none;border-color:var(--line-strong);cursor:not-allowed}
.btn--muted:hover{transform:none;background:var(--sand-200)}
/* shirt-look buttons */
.btn--thuis{background:var(--red-800);color:#1f9d63;border-color:rgba(31,157,99,.45);box-shadow:var(--shadow-red)}
.btn--thuis:hover{background:var(--red-900);color:#27b873;transform:translateY(-2px)}
.btn--uit{background:#fffdf8;color:#d8ad45;border-color:rgba(216,173,69,.55);box-shadow:0 14px 34px -18px rgba(0,0,0,.5)}
.btn--uit:hover{background:#fff;color:#c2922b;transform:translateY(-2px)}

/* ----------------------------------- Announce ----------------------------------- */
.announce{background:linear-gradient(90deg,var(--green-800),var(--red-800));color:var(--sand-100);
  font-size:.8rem;letter-spacing:.02em}
.announce__inner{display:flex;align-items:center;justify-content:center;gap:.6rem;
  text-align:center;padding-block:.6rem;min-height:38px}
.announce b{color:var(--gold-200);font-weight:600}

/* ----------------------------------- Header ----------------------------------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,246,238,.82);
  backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.site-header__inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem;height:74px}
.brand{display:flex;align-items:center;gap:.65rem}
.brand__logo{width:42px;height:42px;border-radius:var(--r-pill);object-fit:cover}
.brand__name{font-family:Fraunces,serif;font-weight:600;font-size:1.18rem;letter-spacing:-.01em;color:var(--ink)}
.nav{display:flex;align-items:center;gap:2rem;justify-self:center}
.nav__link{font-size:.95rem;font-weight:500;color:var(--ink-2);position:relative;padding-block:.4rem}
.nav__link::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;
  background:var(--red-600);transition:width .25s var(--ease)}
.nav__link:hover{color:var(--ink)}
.nav__link:hover::after,.nav__link[aria-current="page"]::after{width:100%}
.header-actions{display:flex;align-items:center;gap:.35rem}
.icon-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:var(--r-pill);color:var(--ink);transition:background .2s}
.icon-btn:hover{background:var(--sand-200)}
.cart-badge{position:absolute;top:4px;right:4px;min-width:20px;height:20px;padding-inline:5px;
  display:flex;align-items:center;justify-content:center;border-radius:var(--r-pill);
  background:var(--red-600);color:#fff;font-size:.68rem;font-weight:700;box-shadow:0 0 0 2px var(--sand-50)}
.menu-toggle{display:none;justify-self:start}

/* mobile menu — opens from the LEFT */
.mobile-menu{display:none;position:fixed;inset:0;z-index:60}
.mobile-menu[data-open="true"]{display:block}
.mobile-menu__scrim{position:absolute;inset:0;background:rgba(36,26,18,.5);backdrop-filter:blur(2px)}
.mobile-menu__panel{position:absolute;top:0;left:0;height:100%;width:min(82%,340px);
  background:var(--sand-50);box-shadow:20px 0 50px -20px rgba(0,0,0,.4);
  padding:1.5rem;display:flex;flex-direction:column;gap:.3rem;
  border-right:3px solid var(--gold);animation:slideIn .3s var(--ease)}
@keyframes slideIn{from{transform:translateX(-100%)}to{transform:translateX(0)}}
.mobile-menu__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.mobile-menu__link{padding:.95rem .4rem;font-size:1.15rem;font-weight:500;font-family:Fraunces,serif;
  border-bottom:1px solid var(--line)}
.mobile-menu__link:hover{color:var(--red-600)}

/* ----------------------------------- Hero ----------------------------------- */
.hero{position:relative;overflow:hidden;color:var(--sand-50);
  background:radial-gradient(120% 120% at 80% -10%,var(--green-700) 0%,var(--green-900) 45%,#05201500 100%),
             linear-gradient(160deg,var(--green-900) 0%,var(--ink) 60%,var(--red-900) 130%)}
.hero__pattern{position:absolute;inset:0;background-image:var(--zellige-cream);background-size:54px 54px;
  opacity:.9;mask-image:radial-gradient(120% 80% at 30% 20%,#000,transparent 75%)}
.hero__glow{position:absolute;width:60vw;height:60vw;border-radius:50%;filter:blur(90px);opacity:.45;pointer-events:none}
.hero__glow--red{background:var(--red-600);right:-12vw;bottom:-22vw}
.hero__glow--gold{background:var(--gold);left:-10vw;top:-16vw;opacity:.22}
.hero{min-height:660px}
.hero__inner{position:relative;display:flex;align-items:center;min-height:660px;
  padding-block:clamp(3rem,6vw,5rem)}
.hero__content{position:relative;z-index:2;max-width:560px;text-shadow:0 2px 18px rgba(0,0,0,.32)}
.hero__models{position:absolute;bottom:0;right:max(.5rem,calc(50% - 590px));z-index:1;
  height:min(88%,620px);width:auto;object-fit:contain;object-position:bottom right;
  pointer-events:none;filter:drop-shadow(0 26px 36px rgba(0,0,0,.5))}
/* scrim sits between the photo and the text so the copy stays legible when they overlap */
.hero__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:transparent}
.hero__title{font-size:clamp(2.7rem,6.6vw,5rem);margin-top:1.3rem}
.hero__title em{font-style:normal;color:var(--gold-400);position:relative}
.hero__desc{margin-top:1.5rem;max-width:30rem;color:rgba(250,246,238,.82);font-size:1.06rem}
.hero__cta{margin-top:2.2rem;display:flex;flex-wrap:wrap;gap:.85rem}
.hero__meta{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:1.4rem;color:rgba(250,246,238,.7);font-size:.88rem}
.hero__meta span{display:inline-flex;align-items:center;gap:.5rem}
.hero__meta i{width:7px;height:7px;transform:rotate(45deg);background:var(--gold-400);display:inline-block}

.hero__art{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.hero-card{position:relative;display:block;transition:transform .5s var(--ease)}
.hero-card:nth-child(2){transform:translateY(2.2rem)}
.hero-card:hover{transform:translateY(-6px)}
.hero-card:nth-child(2):hover{transform:translateY(1.4rem)}
.hero-card__img{aspect-ratio:4/5;object-fit:cover;width:100%;
  border-radius:var(--r-pill) var(--r-pill) var(--r-md) var(--r-md);
  border:2px solid rgba(236,214,153,.45);box-shadow:var(--shadow-md)}
.hero-card__tag{position:absolute;left:50%;bottom:-.7rem;transform:translateX(-50%);
  background:var(--cream);color:var(--ink);border:1.5px solid var(--gold);
  border-radius:var(--r-pill);padding:.35rem 1rem;font-size:.82rem;font-weight:600;white-space:nowrap;
  box-shadow:var(--shadow-sm)}
.hero-card__tag b{color:var(--red-600)}

/* ----------------------------------- Feature strip ----------------------------------- */
.features{background:var(--cream);border-block:1px solid var(--line)}
.features__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;padding-block:2.2rem}
.feature{display:flex;gap:.85rem;align-items:flex-start}
.feature__icon{flex:none;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:var(--sand-100);color:var(--green-700);border:1px solid var(--line)}
.feature h3{font-size:.95rem;font-weight:600}
.feature p{font-size:.84rem;color:var(--ink-3);line-height:1.45}

/* ----------------------------------- Section variants ----------------------------------- */
.section--sand{background:var(--sand-100)}
.section--green{background:
  var(--zellige-cream) 0 0/54px 54px,
  radial-gradient(90% 90% at 20% 0%,var(--green-700),var(--green-900));color:var(--sand-50)}
.section--green .section__head p{color:rgba(250,246,238,.78)}
.section--red{background:
  var(--zellige-cream) 0 0/54px 54px,
  radial-gradient(90% 90% at 80% 0%,var(--red-700),var(--red-900));color:var(--sand-50)}

/* ----------------------------------- Product cards ----------------------------------- */
.product-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,3vw,2rem)}
.product-card{position:relative;display:flex;flex-direction:column;background:var(--cream);
  border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.product-card__media{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--sand-200)}
.product-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.product-card:hover .product-card__media img{transform:scale(1.05)}
.product-card__flag{position:absolute;top:1rem;left:1rem;display:flex;gap:4px}
.product-card__flag span{width:14px;height:10px;border-radius:2px;box-shadow:0 1px 4px rgba(0,0,0,.25)}
.product-card__body{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;padding:1.25rem 1.4rem 1.4rem}
.product-card__body h3{font-family:Fraunces,serif;font-weight:600;font-size:1.2rem;margin-top:.25rem}
.product-card__body .sub{font-size:.82rem;color:var(--ink-3);margin-top:.3rem}
.product-card__price{text-align:right;flex:none}
.product-card__price b{font-size:1.25rem;font-family:Fraunces,serif}
.product-card__price .go{display:block;font-size:.78rem;color:var(--red-600);font-weight:600;margin-top:.3rem}

/* ----------------------------------- Story ----------------------------------- */
.story{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.story__media{position:relative;border-radius:var(--r-pill) var(--r-pill) var(--r-lg) var(--r-lg);
  overflow:hidden;border:2px solid var(--gold-200);box-shadow:var(--shadow-md);aspect-ratio:5/4}
.story__media img{width:100%;height:100%;object-fit:cover}
.story h2{font-size:clamp(1.9rem,4.4vw,2.9rem);margin-top:.6rem}
.story p{margin-top:1.1rem}
.badge-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.chip{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .9rem;border-radius:var(--r-pill);
  background:var(--sand-100);border:1px solid var(--line);font-size:.84rem;font-weight:500}
.chip i{width:7px;height:7px;transform:rotate(45deg);background:var(--green-600)}

/* ----------------------------------- Size advice ----------------------------------- */
.size-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.7rem}
.size-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-md);
  padding:.9rem .5rem;text-align:center}
.size-card .k{font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3)}
.size-card .v{font-size:1.05rem;font-weight:700;font-family:Fraunces,serif}
.size-card .v--accent{color:var(--red-600)}
.size-card .arrow{color:var(--gold);margin-block:.35rem;font-size:.8rem}

/* ----------------------------------- Footer ----------------------------------- */
.site-footer{margin-top:auto;background:
  var(--zellige-cream) 0 0/54px 54px,
  linear-gradient(180deg,var(--ink) 0%,#1a120b 100%);color:var(--sand-200)}
.site-footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding-block:clamp(2.6rem,5vw,3.8rem)}
.site-footer h4{font-size:.74rem;text-transform:uppercase;letter-spacing:.18em;color:var(--gold);margin-bottom:1rem}
.site-footer a{color:var(--sand-200);font-size:.92rem;display:inline-block;padding-block:.25rem;transition:color .2s}
.site-footer a:hover{color:var(--gold-200)}
.site-footer .muted{color:var(--ink-3);font-size:.92rem}
.footer-brand{display:flex;align-items:center;gap:.6rem;margin-bottom:.9rem}
.footer-brand img{width:38px;height:38px;border-radius:var(--r-pill);box-shadow:0 0 0 2px var(--gold)}
.footer-brand b{font-family:Fraunces,serif;font-size:1.1rem;color:var(--sand-50)}
.site-footer__bottom{}
.site-footer__bottom .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;
  padding-block:1.3rem;font-size:.8rem;color:var(--ink-3)}

/* ----------------------------------- WhatsApp FAB ----------------------------------- */
.wa-fab{position:fixed;right:1.3rem;bottom:1.3rem;z-index:55;width:60px;height:60px;border-radius:var(--r-pill);
  background:var(--wa);color:#fff;display:grid;place-items:center;box-shadow:0 16px 36px -12px rgba(0,0,0,.4);
  transition:transform .2s var(--ease),background .2s}
.wa-fab:hover{background:var(--wa-dark);transform:scale(1.07)}
.wa-fab::before{content:"";position:absolute;inset:0;border-radius:inherit;background:var(--wa);
  opacity:.55;animation:ping 1.8s cubic-bezier(0,0,.2,1) infinite;z-index:-1}
@keyframes ping{75%,100%{transform:scale(1.7);opacity:0}}

/* ===================================================================== */
/* PRODUCT PAGE                                                          */
/* ===================================================================== */
.breadcrumb{font-size:.82rem;color:var(--ink-3);padding-block:1.6rem .4rem}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb span{color:var(--ink)}
.pdp{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,3.5rem);padding-bottom:4rem}
.gallery{position:sticky;top:96px}
.gallery__main{aspect-ratio:4/5;overflow:hidden;background:var(--sand-200);
  border-radius:var(--r-xl) var(--r-xl) var(--r-lg) var(--r-lg);
  border:2px solid var(--gold-200);box-shadow:var(--shadow-md)}
.gallery__main img{width:100%;height:100%;object-fit:cover}
.gallery__thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;margin-top:.9rem}
.thumb{aspect-ratio:1;border-radius:var(--r-sm);overflow:hidden;background:var(--sand-200);
  border:2px solid transparent;box-shadow:0 0 0 1px var(--line);transition:border-color .2s,box-shadow .2s}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb[aria-pressed="true"]{border-color:var(--red-600);box-shadow:0 0 0 1px var(--red-600)}
.thumb:hover{box-shadow:0 0 0 1px var(--line-strong)}

.pdp__info{padding-top:.5rem}
.pdp__title{font-size:clamp(1.9rem,4.2vw,2.7rem);margin-top:.55rem}
.price{display:flex;align-items:baseline;gap:.7rem;margin-top:1.1rem}
.price b{font-family:Fraunces,serif;font-size:1.9rem;font-weight:600}
.price .vat{font-size:.85rem;color:var(--ink-3)}
.pdp__desc{margin-top:1.3rem;color:var(--ink-2);max-width:34rem}
.callout{margin-top:1.4rem;display:flex;gap:.7rem;padding:.95rem 1.1rem;border-radius:var(--r-md);
  background:#e7f5ec;border:1px solid #bce3cd;font-size:.9rem;color:var(--green-800)}
.callout svg{flex:none;color:var(--green);margin-top:1px}
.callout b{color:var(--green-900)}

.field-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}
.field-label p{font-size:.92rem;font-weight:600}
.field-label .hint{font-size:.78rem;color:var(--ink-3)}
.size-select{display:grid;grid-template-columns:repeat(6,1fr);gap:.55rem}
@media(max-width:520px){.size-select{grid-template-columns:repeat(3,1fr)}}
.size-opt{display:flex;flex-direction:column}
.size-opt__btn{position:relative;height:52px;border-radius:var(--r-sm);border:1.5px solid var(--line-strong);
  background:var(--cream);font-weight:600;font-size:.95rem;overflow:hidden;
  transition:border-color .18s,background .18s,color .18s}
.size-opt__btn:hover:not(:disabled){border-color:var(--ink)}
.size-opt__btn[data-selected="true"]{background:var(--ink);border-color:var(--ink);color:var(--sand-50)}
.size-opt__btn:disabled{background:var(--sand-100);border-color:var(--line);color:var(--sand-500);cursor:not-allowed}
.size-opt__btn .cross{position:absolute;inset:0;width:100%;height:100%;color:var(--line-strong);pointer-events:none}
.size-opt__stock{margin-top:.4rem;height:16px;text-align:center;font-size:.68rem;font-weight:600}
.size-opt__stock .s{display:inline-flex;align-items:center;gap:.3rem}
.size-opt__stock .s i{width:6px;height:6px;border-radius:50%}
.stock-amber{color:#b7791f}.stock-amber i{background:#d8a13a}
.stock-low{color:var(--red-600)}.stock-low i{background:var(--red-600);animation:pulse 1.4s infinite}
@keyframes pulse{50%{opacity:.4}}

.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line-strong);border-radius:var(--r-sm);
  overflow:hidden;background:var(--cream)}
.qty__btn{width:46px;height:46px;font-size:1.2rem;color:var(--ink-2);transition:background .15s}
.qty__btn:hover{background:var(--sand-100)}
.qty__val{width:46px;text-align:center;font-weight:600}

.pdp__actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.3rem}
.pdp__actions .btn{flex:1;min-width:170px}
.form-error{color:var(--red-600);font-size:.88rem;font-weight:500}
.trust-list{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-top:2rem}
.trust-list div{display:flex;align-items:center;gap:.55rem;font-size:.9rem;color:var(--ink-2)}
.trust-list svg{color:var(--green-600);flex:none}
.stack{display:flex;flex-direction:column;gap:1.7rem}
.soldout-note{padding:1rem 1.1rem;border-radius:var(--r-md);background:var(--sand-100);
  border:1px solid var(--line);color:var(--ink-3);font-size:.9rem}

/* ===================================================================== */
/* CART                                                                  */
/* ===================================================================== */
.page-head{padding-block:clamp(2.4rem,5vw,3.4rem) 0}
.page-head h1{font-size:clamp(2.1rem,5vw,3.1rem)}
.cart{display:grid;grid-template-columns:1fr 380px;gap:2rem;padding-block:2rem 4rem;align-items:start}
.cart__items{display:flex;flex-direction:column;gap:.9rem}
.cart-item{display:flex;gap:1.1rem;align-items:center;background:var(--cream);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:1rem}
.cart-item__media{display:block;width:96px;height:96px;flex:none;border-radius:var(--r-md);
  overflow:hidden;background:var(--sand-200);cursor:pointer}
.cart-item__media img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.cart-item__media:hover img{transform:scale(1.06)}
.cart-item__info{flex:1;min-width:0}
.cart-item__info .eyebrow{font-size:.66rem}
.cart-item__info h3{font-family:Fraunces,serif;font-weight:600;font-size:1.05rem;margin-top:.2rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item__link{color:inherit;transition:color .18s}
.cart-item__link:hover{color:var(--red-600)}
.cart-item__info .size{font-size:.85rem;color:var(--ink-3);margin-top:.2rem}
.cart-item__info .pr{font-weight:600;margin-top:.4rem}
.cart-item__controls{display:flex;flex-direction:column;align-items:flex-end;gap:.6rem}
.qty--sm .qty__btn{width:38px;height:38px;font-size:1.05rem}
.qty--sm .qty__val{width:38px;font-size:.9rem}
.link-remove{font-size:.78rem;color:var(--ink-3)}
.link-remove:hover{color:var(--red-600)}

.summary{position:sticky;top:96px;background:var(--cream);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:1.6rem;display:flex;flex-direction:column;gap:1.2rem;box-shadow:var(--shadow-sm)}
.summary h2{font-family:Fraunces,serif;font-size:1.3rem;font-weight:600}
.summary__rows{display:flex;flex-direction:column;gap:.6rem}
.summary__row{display:flex;justify-content:between;justify-content:space-between;font-size:.92rem;color:var(--ink-2)}
.summary__row--save{color:var(--green-700);font-weight:500}
.summary__total{display:flex;justify-content:space-between;font-weight:700;font-size:1.05rem;
  padding-top:.85rem;border-top:1px solid var(--line);color:var(--ink)}
.summary__total b{font-family:Fraunces,serif}
.summary .note{font-size:.78rem;color:var(--ink-3);line-height:1.5}

.code-toggle{font-size:.88rem;color:var(--ink-2);text-decoration:underline;text-underline-offset:3px;align-self:flex-start}
.code-toggle:hover{color:var(--ink)}
.code-form label{font-size:.88rem;font-weight:600;display:block;margin-bottom:.5rem}
.code-form .row{display:flex;gap:.5rem}
.code-applied{display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  border:1px solid #bfe3cf;background:#eaf7f0;color:var(--green-800);border-radius:var(--r-sm);padding:.6rem .8rem;font-size:.86rem}
.code-applied .rm{font-size:.76rem;text-decoration:underline}

.input{width:100%;height:46px;border:1.5px solid var(--line-strong);border-radius:var(--r-sm);
  padding-inline:.85rem;background:var(--cream);font-size:.92rem;transition:border-color .18s,box-shadow .18s}
.input:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(36,26,18,.12)}
.input--code{text-transform:uppercase;letter-spacing:.05em}
textarea.input{height:auto;padding-block:.7rem;resize:vertical;min-height:108px}

.delivery{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.delivery__opt{display:flex;align-items:center;justify-content:center;height:46px;border-radius:var(--r-sm);
  border:1.5px solid var(--line-strong);background:var(--cream);font-size:.88rem;font-weight:600;
  cursor:pointer;text-align:center;transition:border-color .18s,background .18s,color .18s}
.delivery__opt[data-on="true"]{background:var(--ink);border-color:var(--ink);color:var(--sand-50)}
.delivery__opt input{position:absolute;opacity:0;pointer-events:none}
.field-stack{display:flex;flex-direction:column;gap:.65rem}
.field-row{display:grid;grid-template-columns:120px 1fr;gap:.5rem}
.qr-box{border:1px solid var(--line);background:var(--sand-100);border-radius:var(--r-md);
  padding:1.3rem;display:flex;flex-direction:column;align-items:center;gap:.8rem;text-align:center}
.qr-box p{font-size:.86rem;color:var(--ink-2);max-width:24rem}
.qr-box .qr{background:#fff;padding:.7rem;border-radius:var(--r-sm);border:1px solid var(--line)}
.qr-box a{font-size:.86rem;text-decoration:underline;color:var(--ink-2)}
.empty{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:3.5rem 1.5rem;text-align:center}
.empty p:first-child{font-family:Fraunces,serif;font-size:1.3rem}
.empty p+p{color:var(--ink-3);font-size:.9rem;margin-top:.5rem}

/* ===================================================================== */
/* SELLER / VERKOPEN                                                     */
/* ===================================================================== */
.narrow{max-width:660px;margin-inline:auto}
.seller-hero{padding-block:clamp(2.6rem,5vw,3.6rem) 0}
.seller-hero h1{font-size:clamp(2rem,4.6vw,3rem);margin-top:.55rem}
.seller-hero p{margin-top:1.1rem}
.form-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.4rem,3vw,2.2rem);margin-block:2rem 4rem;box-shadow:var(--shadow-sm)}
.form-field{margin-bottom:1.2rem}
.form-field label{display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}
.form-field .req{color:var(--red-600)}
.form-field .opt{color:var(--ink-3);font-weight:400}

/* contact methods */
#onze-shirts{scroll-margin-top:90px}
.contact-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.contact-card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-md);
  padding:1.3rem;display:flex;flex-direction:column;gap:.55rem;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.contact-card__icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:var(--sand-100);color:var(--green-700);border:1px solid var(--line)}
.contact-card h3{font-size:.98rem;font-weight:600}
.contact-card p,.contact-card a{font-size:.86rem;color:var(--ink-3)}
.contact-card a{color:var(--green-700);font-weight:600}
.contact-card a:hover{color:var(--green-600)}
@media(max-width:680px){.contact-methods{grid-template-columns:1fr}}

/* ----------------------------------- Responsive ----------------------------------- */
/* As the viewport narrows the photo (right-anchored) drifts left and slides BEHIND
   the text; the scrim fades in to keep the copy readable. */
@media(max-width:1024px){
  .hero,.hero__inner{min-height:600px}
  .hero__models{height:min(92%,560px)}
  .hero__scrim{background:linear-gradient(95deg,rgba(7,26,18,.92) 0%,rgba(7,26,18,.62) 42%,rgba(7,26,18,0) 74%)}
}
@media(max-width:560px){
  .hero,.hero__inner{min-height:580px}
  .hero__models{height:min(84%,500px)}
  .hero__scrim{background:linear-gradient(95deg,rgba(7,26,18,.95) 0%,rgba(7,26,18,.74) 52%,rgba(7,26,18,.18) 92%)}
}
@media(max-width:900px){
  .features__grid{grid-template-columns:1fr 1fr;gap:1.6rem 1.2rem}
  .story{grid-template-columns:1fr}
  .story__media{order:-1;max-height:420px}
  .pdp{grid-template-columns:1fr}
  .gallery{position:static}
  .cart{grid-template-columns:1fr}
  .summary{position:static}
  .site-footer__top{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav{display:none}
  .menu-toggle{display:inline-flex}
  .brand{justify-self:center}
  .header-actions{justify-self:end}
  .product-grid{grid-template-columns:1fr}
  .size-grid{grid-template-columns:repeat(3,1fr)}
  .site-footer__top{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .hero-card__img{border-radius:var(--r-lg) var(--r-lg) var(--r-md) var(--r-md)}
}
@media(min-width:681px){.brand__name--mobile{display:none}}
