/* =================================================================
   CRAFTING YARN — "Art to wear"
   Bold, image-led handmade-fashion storefront.
   Reference language: full-bleed collection banners, one grotesque
   typeface, white ground, terracotta + brown accents, minimal copy.
   ================================================================= */

:root{
  --paper:#FFFFFF;
  --bg:#FAF7F3;            /* faint warm white for alt blocks */
  --ink:#171513;           /* near-black */
  --ink-2:#6E665C;
  --terra:#E35D40;         /* signature terracotta */
  --terra-d:#C8472C;
  --brown:#5E2816;         /* deep brown for display headings */
  --line:rgba(23,21,19,.14);
  --line-2:rgba(23,21,19,.07);

  --maxw:1500px;
  --gut:clamp(16px,4vw,60px);
  --r:3px;

  --font:"Bricolage Grotesque",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font);font-weight:400;background:var(--paper);color:var(--ink);
  line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
[hidden]{display:none!important}
::selection{background:var(--terra);color:#fff}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;padding:1.15em 2.4em;border-radius:var(--r);
  border:1.5px solid var(--ink);color:var(--ink);transition:.35s var(--ease)}
.btn:hover{background:var(--ink);color:#fff}
.btn--solid{background:var(--terra);border-color:var(--terra);color:#fff}
.btn--solid:hover{background:var(--brown);border-color:var(--brown);color:#fff}
.btn--block{width:100%}

.shopnow{display:inline-block;background:#fff;color:var(--ink);font-weight:700;font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;padding:1.05em 2.1em;border-radius:var(--r);
  position:relative;transition:.35s var(--ease)}
.shopnow span,.shopnow::after{content:"";position:absolute;left:2.1em;right:2.1em;bottom:.85em;height:1.5px;background:currentColor}
.shopnow:hover{background:var(--terra);color:#fff}

.icon-btn{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:50%;transition:opacity .25s}
.icon-btn:hover{opacity:.55}
.icon-btn svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round}
.round-btn{width:48px;height:48px;border-radius:50%;border:1.5px solid var(--ink);font-size:1.05rem;
  display:grid;place-items:center;transition:.3s var(--ease)}
.round-btn:hover{background:var(--ink);color:#fff}

/* =================================================================
   ANNOUNCEMENT
   ================================================================= */
.ticker{background:var(--terra);color:#fff;overflow:hidden}
.ticker__track{display:flex;align-items:center;gap:2.4rem;white-space:nowrap;padding:.6rem 0;
  width:max-content;animation:ticker 42s linear infinite}
.ticker span{font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase}
.ticker i{font-style:normal;opacity:.7}
@keyframes ticker{to{transform:translateX(-50%)}}

/* =================================================================
   HEADER
   ================================================================= */
.site-header{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:.3s}
.site-header.is-scrolled{border-color:var(--line-2);background:color-mix(in srgb,var(--paper) 96%,transparent)}
.header__inner{max-width:var(--maxw);margin:0 auto;padding:.7rem var(--gut);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}
.header__menu{display:flex;flex-direction:column;gap:6px;justify-self:start;padding:8px 0;width:30px}
.header__menu span{display:block;height:2px;width:28px;background:var(--ink);transition:.3s}
.header__menu[aria-expanded="true"] span:first-child{transform:translateY(8px) rotate(45deg)}
.header__menu[aria-expanded="true"] span:last-child{transform:translateY(-8px) rotate(-45deg)}
.brand{justify-self:center}
.brand__logo{height:clamp(76px,10vw,112px);width:auto;transition:height .3s}
.is-scrolled .brand__logo{height:clamp(58px,7vw,80px)}
.header__actions{justify-self:end;display:flex;align-items:center;gap:.3rem}
.cart-btn{position:relative}
.cart-count{position:absolute;top:1px;right:1px;background:var(--terra);color:#fff;font-size:.6rem;font-weight:700;
  min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px}

.searchbar{border-top:1px solid var(--line-2)}
.searchbar__inner{max-width:var(--maxw);margin:0 auto;padding:1rem var(--gut);display:flex;align-items:center;gap:1rem}
.searchbar__icon{width:22px;height:22px;fill:none;stroke:var(--ink-2);stroke-width:1.6;stroke-linecap:round}
.searchbar input{flex:1;border:none;background:none;font-family:var(--font);font-size:1.5rem;font-weight:500;color:var(--ink);outline:none}
.searchbar input::placeholder{color:var(--ink-2);opacity:.5}
.searchbar__close{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.searchbar__close:hover{color:var(--ink)}

/* menu overlay */
.menu{position:fixed;inset:0;z-index:70;background:var(--paper);padding:6rem var(--gut) 3rem;
  display:flex;flex-direction:column;justify-content:center;animation:fade .4s var(--ease)}
.menu nav{display:flex;flex-direction:column}
.menu nav a{font-weight:600;font-size:clamp(2rem,6vw,3.6rem);letter-spacing:-.02em;line-height:1.15;
  padding:.12em 0;border-bottom:1px solid var(--line-2);display:flex;align-items:baseline;gap:1rem;transition:color .25s,padding-left .3s}
.menu nav a span{font-size:.8rem;font-weight:500;color:var(--terra);letter-spacing:.1em}
.menu nav a:hover{color:var(--terra);padding-left:10px}
.menu__ig{margin-top:2.4rem;font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2)}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* =================================================================
   BANNERS — full-bleed collection blocks
   ================================================================= */
.banner{position:relative;width:100%;height:clamp(520px,84vh,880px);overflow:hidden}
.banner--hero{height:clamp(560px,90vh,940px)}
.banner__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  transition:transform 6s var(--ease)}
.banner:hover .banner__img{transform:scale(1.04)}
.banner::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top right,rgba(20,16,12,.55),rgba(20,16,12,.1) 42%,transparent 70%)}
.banner__inner{position:absolute;left:0;bottom:0;z-index:2;padding:clamp(28px,5vw,72px);max-width:760px;color:#fff}
.banner__eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;margin-bottom:.8rem;opacity:.95}
.banner__title{font-weight:800;font-size:clamp(2.8rem,8vw,6.6rem);line-height:.92;letter-spacing:-.02em;
  text-transform:uppercase;margin-bottom:1.6rem;text-shadow:0 2px 30px rgba(0,0,0,.25)}

/* =================================================================
   CAROUSEL
   ================================================================= */
.rail{max-width:var(--maxw);margin:0 auto;padding:clamp(48px,7vw,100px) 0 clamp(30px,4vw,56px)}
.rail__head{padding:0 var(--gut);display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem}
.rail__title{color:var(--brown);font-weight:700;font-size:clamp(2.2rem,5.5vw,4rem);letter-spacing:-.02em;line-height:1}
.rail__nav{display:flex;gap:.7rem;flex-shrink:0}
.rail__track{display:flex;gap:clamp(14px,1.6vw,24px);overflow-x:auto;scroll-snap-type:x mandatory;
  padding:4px var(--gut) 22px;scrollbar-width:none}
.rail__track::-webkit-scrollbar{display:none}
.rail__track .card{flex:0 0 clamp(230px,26vw,310px);scroll-snap-align:start}

/* =================================================================
   PRODUCT CARD
   ================================================================= */
.card{display:flex;flex-direction:column}
.card__media{position:relative;overflow:hidden;background:var(--bg);aspect-ratio:1/1.2;border-radius:var(--r)}
.card__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease),opacity .6s var(--ease)}
.card:hover .card__img{transform:scale(1.05)}
.card__img--hover{opacity:0}
.card.has-hover:hover .card__img--hover{opacity:1}
.card__badges{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:5px;z-index:3}
.tag{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;line-height:1;
  padding:.45em .65em;border-radius:2px}
.tag--sale{background:var(--terra);color:#fff}
.tag--new{background:var(--ink);color:#fff}
.card__wish{position:absolute;top:10px;right:10px;z-index:3;width:36px;height:36px;display:grid;place-items:center;border-radius:50%}
.card__wish svg{width:20px;height:20px;fill:none;stroke:var(--ink);stroke-width:1.5;transition:.3s var(--ease);
  filter:drop-shadow(0 1px 2px rgba(255,255,255,.7))}
.card__wish:hover svg{stroke:var(--terra)}
.card__wish.is-wished svg{fill:var(--terra);stroke:var(--terra)}
.card__actions{position:absolute;left:0;right:0;bottom:0;z-index:3;display:flex;
  transform:translateY(100%);transition:transform .45s var(--ease)}
.card:hover .card__actions,.card:focus-within .card__actions{transform:translateY(0)}
.card__quick,.card__addbar{flex:1;border:none;padding:1.05em .5em;font-size:.64rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:.3s}
.card__quick{background:rgba(255,255,255,.94);backdrop-filter:blur(6px);color:var(--ink)}
.card__quick:hover{background:#fff;color:var(--terra)}
.card__addbar{background:var(--terra);color:#fff}
.card__addbar:hover{background:var(--brown)}
.card__info{padding:.9rem .15rem 0}
.card__cat{font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}
.card__name{font-weight:600;font-size:1.04rem;line-height:1.2;margin:.3em 0 .35em;letter-spacing:-.01em}
.card__price{display:flex;align-items:baseline;gap:.55em;font-size:.92rem;font-weight:500}
.card__price .now{color:var(--ink)}
.card__price .was{color:var(--ink-2);text-decoration:line-through;font-weight:400;font-size:.84rem}
.card__price .off{color:var(--terra);font-size:.7rem;font-weight:700;letter-spacing:.04em}

/* =================================================================
   SHOP GRID
   ================================================================= */
.shop{max-width:var(--maxw);margin:0 auto;padding:clamp(20px,3vw,40px) var(--gut) clamp(56px,8vw,110px)}
.shop__bar{display:flex;justify-content:space-between;align-items:center;gap:1.4rem;flex-wrap:wrap;
  margin-bottom:2.4rem;padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.filters{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{font-size:.74rem;font-weight:600;letter-spacing:.06em;padding:.55em 1.1em;border-radius:999px;
  border:1.5px solid var(--line);color:var(--ink-2);transition:.28s var(--ease)}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip.is-active{background:var(--ink);border-color:var(--ink);color:#fff}
.chip--sale{color:var(--terra);border-color:color-mix(in srgb,var(--terra) 45%,transparent)}
.chip--sale.is-active{background:var(--terra);border-color:var(--terra);color:#fff}
.shop__tools{display:flex;align-items:center;gap:1.4rem}
.shop__count{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.shop__tools select{font-family:var(--font);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  padding:.5em 1.8em .5em .9em;border:1.5px solid var(--line);border-radius:999px;background:var(--paper);color:var(--ink);
  appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%23171513' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .8em center}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,1.8vw,30px) clamp(12px,1.4vw,22px)}
.grid__empty{text-align:center;font-size:1.3rem;font-weight:500;color:var(--ink-2);padding:4rem 0}

/* =================================================================
   STORY (minimal)
   ================================================================= */
.story{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--bg)}
.story__media{overflow:hidden}
.story__media img{width:100%;height:100%;object-fit:cover;min-height:420px}
.story__copy{padding:clamp(40px,7vw,110px) var(--gut);display:flex;flex-direction:column;justify-content:center;max-width:600px}
.story__eyebrow{font-size:.74rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--terra);margin-bottom:1.2rem}
.story__title{color:var(--brown);font-weight:700;font-size:clamp(2.2rem,4.8vw,4rem);line-height:.98;letter-spacing:-.02em;margin-bottom:1.2rem}
.story__line{color:var(--ink-2);font-size:1.05rem;max-width:42ch;margin-bottom:2rem}

/* =================================================================
   NEWSLETTER
   ================================================================= */
.news{text-align:center;padding:clamp(60px,9vw,140px) var(--gut)}
.news__inner{max-width:620px;margin:0 auto}
.news__title{color:var(--brown);font-weight:700;font-size:clamp(2rem,5vw,3.4rem);letter-spacing:-.02em;line-height:1;margin-bottom:.8rem}
.news__copy{color:var(--ink-2);font-size:1.02rem;margin-bottom:2rem}
.news__form{display:flex;gap:.6rem;max-width:460px;margin:0 auto}
.news__form input{flex:1;border:1.5px solid var(--line);border-radius:var(--r);background:var(--paper);
  padding:.95em 1.2em;font-family:var(--font);font-size:.95rem;color:var(--ink);outline:none;transition:border-color .3s}
.news__form input:focus{border-color:var(--ink)}
.news__form input::placeholder{color:var(--ink-2)}
.news__msg{margin-top:1.2rem;font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--terra);min-height:1.2em}

/* =================================================================
   FOOTER
   ================================================================= */
.site-footer{background:var(--ink);color:#fff}
.footer__top{max-width:var(--maxw);margin:0 auto;padding:clamp(50px,6vw,90px) var(--gut) 3rem;
  display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
.footer__logo{height:88px;width:auto;background:#fff;padding:10px 14px;border-radius:var(--r);margin-bottom:1.2rem}
.footer__brand p{color:rgba(255,255,255,.6);max-width:30ch;font-size:.92rem}
.footer__col h4{font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:1.2rem}
.footer__col a{display:block;color:rgba(255,255,255,.85);font-size:.94rem;padding:.34em 0;transition:color .25s,padding-left .25s}
.footer__col a:hover{color:var(--terra);padding-left:5px}
.footer__bottom{max-width:var(--maxw);margin:0 auto;padding:1.4rem var(--gut);border-top:1px solid rgba(255,255,255,.14);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.7rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5)}

/* =================================================================
   OVERLAY / CART / MODAL
   ================================================================= */
.overlay{position:fixed;inset:0;z-index:80;background:rgba(20,16,12,.45);backdrop-filter:blur(2px);animation:fade .3s}
.cart{position:fixed;top:0;right:0;bottom:0;width:min(450px,92vw);background:var(--paper);z-index:90;
  transform:translateX(105%);transition:transform .5s var(--ease);display:flex;flex-direction:column;
  box-shadow:-24px 0 70px -36px rgba(0,0,0,.45)}
.cart.is-open{transform:translateX(0)}
.cart__head{display:flex;justify-content:space-between;align-items:center;padding:1.4rem var(--gut);border-bottom:1px solid var(--line)}
.cart__head h3{font-weight:700;font-size:1.35rem;letter-spacing:-.01em}
.cart__x{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.cart__x:hover{color:var(--ink)}
.cart__body{flex:1;overflow-y:auto;padding:.5rem var(--gut)}
.cart__empty{text-align:center;color:var(--ink-2);padding:3.5rem 1rem;font-size:1.05rem}
.cart-item{display:grid;grid-template-columns:74px 1fr auto;gap:1rem;padding:1.2rem 0;border-bottom:1px solid var(--line-2)}
.cart-item img{width:74px;height:90px;object-fit:cover;background:var(--bg);border-radius:var(--r)}
.cart-item__name{font-weight:600;font-size:1rem;line-height:1.2}
.cart-item__price{color:var(--ink-2);font-size:.84rem;margin-top:.25rem}
.cart-item__qty{display:inline-flex;align-items:center;gap:.8rem;margin-top:.6rem;border:1px solid var(--line);border-radius:999px;padding:.2rem .65rem}
.cart-item__qty button{width:20px;height:20px;font-size:1rem;line-height:1;color:var(--ink-2)}
.cart-item__qty button:hover{color:var(--terra)}
.cart-item__rm{align-self:start;font-size:.64rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.cart-item__rm:hover{color:var(--terra)}
.cart__foot{padding:1.4rem var(--gut) 1.6rem;border-top:1px solid var(--line);background:var(--bg)}
.cart__row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}
.cart__row span{font-size:.72rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.cart__row strong{font-size:1.4rem;font-weight:700}
.cart__hint{font-size:.72rem;color:var(--ink-2);margin-bottom:1rem}

.modal{position:fixed;inset:0;z-index:95;display:grid;place-items:center;padding:var(--gut);
  background:rgba(20,16,12,.5);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .35s}
.modal.is-open{opacity:1;pointer-events:auto}
.modal__panel{background:var(--paper);border-radius:var(--r);max-width:900px;width:100%;max-height:90vh;overflow:auto;
  display:grid;grid-template-columns:1fr 1fr;position:relative;transform:translateY(20px);transition:transform .45s var(--ease)}
.modal.is-open .modal__panel{transform:none}
.modal__close{position:absolute;top:14px;right:16px;z-index:3;font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.modal__close:hover{color:var(--ink)}
.modal__media{background:var(--bg)}
.modal__media img{width:100%;height:100%;object-fit:cover;min-height:360px}
.modal__info{padding:clamp(28px,3.4vw,52px)}
.modal__cat{font-size:.66rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--terra)}
.modal__name{font-weight:700;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.02;letter-spacing:-.02em;margin:.5rem 0 .6rem}
.modal__price{display:flex;align-items:baseline;gap:.7em;font-size:1.15rem;font-weight:500;margin-bottom:1.3rem}
.modal__price .was{color:var(--ink-2);text-decoration:line-through;font-size:1rem;font-weight:400}
.modal__price .off{color:var(--terra);font-size:.78rem;font-weight:700;text-transform:uppercase}
.modal__desc{color:var(--ink-2);margin-bottom:1.6rem}
.modal__meta{list-style:none;margin-bottom:1.8rem;font-size:.82rem;color:var(--ink-2)}
.modal__meta li{padding:.7rem 0;border-top:1px solid var(--line-2)}
.modal__meta li:last-child{border-bottom:1px solid var(--line-2)}

.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(160%);z-index:100;
  background:var(--ink);color:#fff;padding:1em 1.6em;border-radius:999px;font-size:.76rem;font-weight:600;
  letter-spacing:.06em;transition:transform .5s var(--ease);box-shadow:0 22px 46px -22px rgba(0,0,0,.5);max-width:90vw}
.toast.is-show{transform:translateX(-50%) translateY(0)}
.toast b{color:var(--terra)}

/* =================================================================
   CONFIRMATION (success page)
   ================================================================= */
.confirm{min-height:58vh;display:grid;place-items:center;padding:clamp(48px,9vw,140px) var(--gut)}
.confirm__inner{max-width:620px;text-align:center}
.confirm__eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--terra);margin-bottom:1rem}
.confirm__title{font-weight:800;font-size:clamp(2.6rem,7vw,5rem);line-height:.95;letter-spacing:-.02em;color:var(--brown);text-transform:uppercase;margin-bottom:1.4rem}
.confirm__lead{font-size:1.12rem;color:var(--ink);margin-bottom:1rem;line-height:1.5}
.confirm__note{color:var(--ink-2);margin-bottom:2.2rem;font-size:.96rem;line-height:1.5}
.confirm__note a{color:var(--terra);font-weight:600}

/* =================================================================
   CONTENT PAGES (about / shipping / returns / contact)
   ================================================================= */
.page{max-width:760px;margin:0 auto;padding:clamp(40px,7vw,96px) var(--gut)}
.page__back{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-bottom:1.6rem}
.page__back:hover{color:var(--terra)}
.page__eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--terra);margin-bottom:.9rem}
.page h1{font-weight:800;font-size:clamp(2.4rem,6vw,4rem);line-height:.98;letter-spacing:-.02em;color:var(--brown);text-transform:uppercase;margin-bottom:1.6rem}
.page h2{font-weight:700;font-size:1.4rem;color:var(--ink);margin:2rem 0 .6rem}
.page p{color:var(--ink-2);line-height:1.7;margin-bottom:1.1rem;font-size:1.02rem}
.page p strong{color:var(--ink)}
.page a.inline{color:var(--terra);font-weight:600}
.page ul{list-style:none;margin:0 0 1.2rem;padding:0}
.page li{color:var(--ink-2);line-height:1.6;padding-left:1.3em;position:relative;margin-bottom:.5rem}
.page li::before{content:"✶";position:absolute;left:0;color:var(--terra)}
.page__media{margin:0 0 2.2rem;border-radius:var(--r);overflow:hidden;background:var(--bg)}
.page__media img{width:100%;aspect-ratio:16/10;object-fit:cover}
.contact-form{display:flex;flex-direction:column;gap:.9rem;margin-top:1.4rem}
.contact-form input,.contact-form textarea{font-family:var(--font);font-size:1rem;padding:.9em 1em;border:1.5px solid var(--line);border-radius:var(--r);background:var(--paper);color:var(--ink)}
.contact-form textarea{min-height:130px;resize:vertical}
.contact-form .btn{align-self:flex-start}

/* =================================================================
   PRODUCT DETAIL PAGE
   ================================================================= */
.pdp{max-width:var(--maxw);margin:0 auto;padding:clamp(20px,3vw,40px) var(--gut) clamp(50px,7vw,100px)}
.pdp__back{display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-bottom:1.4rem}
.pdp__back:hover{color:var(--terra)}
.pdp__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,64px);align-items:start}
.pdp__media{display:flex;flex-direction:column;gap:14px}
.pdp__media figure{border-radius:var(--r);overflow:hidden;background:var(--bg)}
.pdp__media img{width:100%;aspect-ratio:1/1.15;object-fit:cover}
.pdp__info{position:sticky;top:120px}
.pdp__cat{font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}
.pdp__name{font-weight:800;font-size:clamp(2rem,4.5vw,3.4rem);line-height:1;letter-spacing:-.02em;color:var(--brown);text-transform:uppercase;margin:.5rem 0 1rem}
.pdp__price{display:flex;align-items:baseline;gap:.7em;font-size:1.3rem;margin-bottom:1.4rem}
.pdp__price .now{font-weight:700}
.pdp__price .was{color:var(--ink-2);text-decoration:line-through;font-size:1rem}
.pdp__price .off{color:var(--terra);font-weight:700;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase}
.pdp__desc{color:var(--ink-2);line-height:1.7;font-size:1.05rem;margin-bottom:1.6rem}
.pdp__meta{list-style:none;border-top:1px solid var(--line);margin:1.6rem 0;padding-top:1rem}
.pdp__meta li{color:var(--ink-2);font-size:.92rem;padding:.45rem 0;border-bottom:1px solid var(--line-2)}
.pdp__add{width:100%;font-size:.84rem}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media(max-width:1024px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .footer__top{grid-template-columns:1fr 1fr;gap:2.6rem}
}
@media(max-width:768px){
  .pdp__grid{grid-template-columns:1fr;gap:1.6rem}
  .pdp__info{position:static}
  .story{grid-template-columns:1fr}
  .story__media img{min-height:340px}
  .modal__panel{grid-template-columns:1fr;max-height:88vh}
  .modal__media img{min-height:0;aspect-ratio:1/1}
}
  .grid{grid-template-columns:repeat(3,1fr)}
  .footer__top{grid-template-columns:1fr 1fr;gap:2.6rem}
}
@media(max-width:768px){
  .story{grid-template-columns:1fr}
  .story__media img{min-height:340px}
  .modal__panel{grid-template-columns:1fr;max-height:88vh}
  .modal__media img{min-height:0;aspect-ratio:1/1}
}
@media(max-width:560px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .shop__bar{flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:1rem}
  .filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:5px;-webkit-overflow-scrolling:touch;min-width:0}
  .chip{white-space:nowrap}
  .shop__tools{justify-content:space-between;min-width:0;flex-wrap:wrap;gap:.6rem 1rem}
  .footer__top{grid-template-columns:1fr 1fr}
  .banner__title{font-size:clamp(2.6rem,13vw,4rem)}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto}
}
