/* ===== Zoe — A Gallery ===== */
:root{
  --paper:#f7f3ec;
  --paper-2:#efe9df;
  --ink:#231f1c;
  --ink-soft:#6b6258;
  --line:#d9d0c2;
  --accent:#e23b56;
  --shadow: 0 1px 2px rgba(40,30,20,.04), 0 12px 34px -12px rgba(40,30,20,.22);
  --shadow-lift: 0 1px 2px rgba(40,30,20,.05), 0 26px 60px -18px rgba(40,30,20,.32);
  --maxw:1320px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* ===== Language switcher ===== */
.lang-switch{
  position:fixed;top:0;right:0;z-index:60;
  display:flex;gap:.1rem;
  margin:.7rem;
  margin-top:calc(.7rem + env(safe-area-inset-top));
  padding:.25rem;
  background:rgba(247,243,236,.82);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid var(--line);border-radius:999px;
  box-shadow:0 6px 20px -10px rgba(40,30,20,.3);
}
[dir=rtl] .lang-switch{right:auto;left:0}
.lang-switch button{
  appearance:none;border:none;background:transparent;cursor:pointer;
  font-family:"Inter",system-ui,sans-serif;
  font-size:.74rem;font-weight:600;letter-spacing:.04em;
  color:var(--ink-soft);
  padding:.4rem .62rem;border-radius:999px;line-height:1;
  min-height:32px;
  transition:background .2s,color .2s;
}
.lang-switch button[lang=he]{font-family:"Noto Sans Hebrew","Inter",sans-serif}
.lang-switch button:hover{color:var(--ink)}
.lang-switch button.is-active{background:var(--ink);color:var(--paper)}

/* Hebrew display type */
[lang=he] .wordmark{font-family:"Frank Ruhl Libre","Fraunces",serif}
[lang=he] .masthead__tagline,
[lang=he] .intro__lead,
[lang=he] .statement h2,
[lang=he] figcaption .t,
[lang=he] .lb__title{font-family:"Frank Ruhl Libre","Fraunces",serif;font-style:normal}
[lang=he] body,[lang=he] .statement p,[lang=he] .lang-switch{font-family:"Noto Sans Hebrew","Inter",sans-serif}
img{display:block;max-width:100%;height:auto}

/* paper grain */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(circle at 20% 15%, rgba(255,255,255,.5), transparent 45%),
    radial-gradient(circle at 85% 80%, rgba(226,59,86,.04), transparent 40%);
}

/* ===== Masthead ===== */
.masthead{
  min-height:78vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;
  padding:7rem 1.5rem 4rem;
  border-bottom:1px solid var(--line);
}
.masthead__inner{max-width:760px}
.dots{display:flex;gap:.6rem;justify-content:center;margin-bottom:2.2rem}
.dots span{
  width:13px;height:13px;border-radius:50%;background:var(--c);
  box-shadow:0 4px 10px -3px var(--c);
  animation:rise .9s cubic-bezier(.2,.8,.2,1) backwards;
}
.dots span:nth-child(1){animation-delay:.05s}
.dots span:nth-child(2){animation-delay:.12s}
.dots span:nth-child(3){animation-delay:.19s}
.dots span:nth-child(4){animation-delay:.26s}
.dots span:nth-child(5){animation-delay:.33s}
.dots span:nth-child(6){animation-delay:.40s}
.dots span:nth-child(7){animation-delay:.47s}
@keyframes rise{from{opacity:0;transform:translateY(14px) scale(.6)}to{opacity:1;transform:none}}

.wordmark{
  font-family:"Fraunces",serif;
  font-weight:560;
  font-size:clamp(5.5rem,22vw,13rem);
  line-height:.9;
  letter-spacing:-.02em;
  margin:0;
  font-optical-sizing:auto;
}
.masthead__tagline{
  font-family:"Fraunces",serif;
  font-style:italic;
  font-weight:380;
  font-size:clamp(1.25rem,3.4vw,1.9rem);
  color:var(--ink);
  margin:1.1rem 0 .2rem;
}
.masthead__meta{
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.74rem;
  color:var(--ink-soft);
  margin:1.4rem 0 0;
}
@media (max-width:480px){
  .masthead__meta{letter-spacing:.12em;font-size:.66rem}
}
.masthead__cue{
  display:inline-block;margin-top:3rem;
  font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);text-decoration:none;
  border-bottom:1px solid var(--line);padding-bottom:.3rem;
  transition:color .25s,border-color .25s;
}
.masthead__cue:hover{color:var(--accent);border-color:var(--accent)}

/* ===== Intro ===== */
.intro{max-width:760px;margin:0 auto;padding:5rem 1.5rem 1rem;text-align:center}
.intro__lead{
  font-family:"Fraunces",serif;font-weight:340;
  font-size:clamp(1.3rem,2.8vw,1.7rem);line-height:1.5;
  color:var(--ink);margin:0;
}

/* ===== Gallery grid (masonry) ===== */
.gallery{max-width:var(--maxw);margin:0 auto;padding:3.5rem 1.5rem 4rem}
.grid{
  column-count:3;
  column-gap:2.2rem;
}
@media (max-width:980px){.grid{column-count:2;column-gap:1.6rem}}
@media (max-width:600px){.grid{column-count:1}}

.piece{
  break-inside:avoid;
  margin:0 0 2.2rem;
  cursor:pointer;                 /* iOS Safari only fires click when cursor:pointer (NOT zoom-in) */
  -webkit-tap-highlight-color:rgba(0,0,0,0);
  touch-action:manipulation;
  --reveal:1;
  opacity:var(--reveal);
}
.piece *{cursor:pointer}          /* children inherit clickability so taps on the image register */
.piece__frame{
  background:#fff;
  padding:.85rem;
  border:1px solid var(--line);
  border-radius:3px;
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform .45s cubic-bezier(.2,.8,.2,1), box-shadow .45s;
}
.piece__frame img{
  border-radius:1px;
  transition:transform .8s cubic-bezier(.2,.8,.2,1);
}
.piece:hover .piece__frame{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.piece:hover .piece__frame img{transform:scale(1.03)}

figcaption{
  display:flex;flex-direction:column;gap:.15rem;
  padding:.9rem .2rem .2rem;
}
figcaption .t{
  font-family:"Fraunces",serif;font-weight:500;font-size:1.08rem;line-height:1.2;
}
figcaption .m{
  font-size:.78rem;letter-spacing:.04em;color:var(--ink-soft);
}
figcaption .p{
  margin-top:.5rem;
  align-self:flex-start;
  font-family:"Fraunces",serif;font-weight:560;font-size:.92rem;
  color:var(--accent);
  border:1px solid rgba(226,59,86,.35);
  border-radius:999px;padding:.12rem .6rem;line-height:1.5;
}
[dir=rtl] figcaption .p{align-self:flex-end}

/* reveal animation */
.reveal-on .piece{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.8,.2,1)}
.reveal-on .piece.in{opacity:1;transform:none}

/* ===== Statement ===== */
.statement{
  border-top:1px solid var(--line);
  background:var(--paper-2);
  padding:6rem 1.5rem;
}
.statement__inner{max-width:680px;margin:0 auto}
.statement h2{
  font-family:"Fraunces",serif;font-weight:540;
  font-size:clamp(1.8rem,4vw,2.6rem);
  margin:0 0 1.6rem;letter-spacing:-.01em;
}
.statement p{margin:0 0 1.3rem;color:#3a342e}
.statement__sig{
  font-family:"Fraunces",serif;font-style:italic;color:var(--ink-soft);
  margin-top:1.8rem !important;
}

/* ===== Colophon ===== */
.colophon{
  text-align:center;padding:3.5rem 1.5rem;border-top:1px solid var(--line);
}
.colophon p{margin:.2rem 0;letter-spacing:.05em}
.colophon p:first-child{font-family:"Fraunces",serif;font-size:1.2rem}
.colophon__small{font-size:.78rem;color:var(--ink-soft)}

/* ===== Lightbox ===== */
.lightbox{
  position:fixed;inset:0;z-index:100;
  background:rgba(28,24,20,.94);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  overflow-y:auto;-webkit-overflow-scrolling:touch;  /* scroll when content is taller than the screen */
  /* resting state is VISIBLE (opacity:1 by default). The fade only plays as a nicety —
     if animations are off (Reduce Motion), the lightbox still shows. */
  animation:fade .25s ease;
}
@keyframes fade{from{opacity:0}to{opacity:1}}
.lightbox[hidden]{display:none}
.lb__stage{
  min-height:100%;box-sizing:border-box;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;
  max-width:min(1100px,100%);margin:0 auto;
  /* generous top/bottom padding so content clears the fixed close/nav controls */
  padding:clamp(3.5rem,9vw,4.75rem) clamp(1rem,4vw,3rem);
}
.lb__img{
  max-width:100%;max-height:58vh;width:auto;
  background:#fff;padding:.9rem;border-radius:2px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.7);
  animation:pop .4s cubic-bezier(.2,.8,.2,1);
}
@keyframes pop{from{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}
.lb__caption{
  display:flex;flex-direction:column;gap:.3rem;text-align:center;
  color:#f3ece2;max-width:620px;
}
.lb__count{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:#bdb0a4}
.lb__title{font-family:"Fraunces",serif;font-size:1.5rem;line-height:1.2}
.lb__meta{font-size:.82rem;letter-spacing:.06em;color:#cabdaf}
.lb__desc{font-size:.95rem;color:#e6ddd0;line-height:1.55;margin-top:.3rem}

/* Buy button in lightbox */
.lb__buy{
  margin-top:1rem;align-self:center;
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:"Inter",system-ui,sans-serif;font-size:1rem;font-weight:600;
  letter-spacing:.02em;
  color:#fff;background:var(--accent);
  border:none;border-radius:999px;cursor:pointer;
  padding:.7rem 1.6rem;min-height:48px;
  box-shadow:0 10px 26px -10px rgba(226,59,86,.7);
  transition:transform .18s,box-shadow .18s,opacity .18s,background .18s;
}
.lb__buy:hover{transform:translateY(-2px);box-shadow:0 16px 32px -10px rgba(226,59,86,.8)}
.lb__buy:active{transform:translateY(0)}
.lb__buy:disabled{opacity:.6;cursor:default;transform:none}
.lb__buy.is-loading{opacity:.7;cursor:progress}
.lb__buy.is-loading .lb__buy-label::after{content:"…"}
.lb__buy-price{
  font-family:"Fraunces",serif;font-weight:600;
  padding-inline-start:.7rem;border-inline-start:1px solid rgba(255,255,255,.45);
}
.lb__buy-note{
  font-size:.74rem;letter-spacing:.04em;color:#bdb0a4;margin-top:.55rem;
}
.lb__actions{display:flex;flex-direction:column;align-items:center;gap:0}
/* Secondary: digital download */
.lb__digital{
  margin-top:1rem;align-self:center;
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:"Inter",system-ui,sans-serif;font-size:.92rem;font-weight:600;
  letter-spacing:.02em;
  color:#f3ece2;background:transparent;
  border:1px solid rgba(243,236,226,.4);border-radius:999px;cursor:pointer;
  padding:.55rem 1.3rem;min-height:44px;
  transition:transform .18s,border-color .18s,background .18s,opacity .18s;
}
.lb__digital:hover{border-color:#f3ece2;background:rgba(255,255,255,.06);transform:translateY(-1px)}
.lb__digital:disabled{opacity:.55;cursor:default;transform:none}
.lb__digital.is-loading{opacity:.7;cursor:progress}
.lb__digital.is-loading .lb__digital-label::after{content:"…"}
.lb__digital-price{font-family:"Fraunces",serif;font-weight:600;opacity:.85}
.lb__digital-note{
  font-size:.72rem;letter-spacing:.04em;color:#9d9086;margin-top:.45rem;
}

/* Shipping & handling calculator */
.lb__ship{
  margin-top:.9rem;width:min(360px,84vw);
  display:flex;flex-direction:column;gap:.55rem;
  padding:.95rem 1rem 1.05rem;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(243,236,226,.16);border-radius:14px;
  animation:pop .3s cubic-bezier(.2,.8,.2,1);
}
.lb__ship-label{
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#bdb0a4;
  text-align:start;
}
.lb__ship-country{
  width:100%;font-family:"Inter",system-ui,sans-serif;font-size:.95rem;
  color:#f3ece2;background:#2c2722;
  border:1px solid rgba(243,236,226,.28);border-radius:10px;
  padding:.6rem .7rem;min-height:44px;cursor:pointer;
}
[lang=he] .lb__ship-country{font-family:"Noto Sans Hebrew","Inter",sans-serif}
.lb__ship-country:focus{outline:2px solid var(--accent);outline-offset:1px}
.lb__ship-quote{
  min-height:1.2em;display:flex;flex-direction:column;gap:.15rem;
  font-size:.9rem;color:#e6ddd0;text-align:start;
}
.lb__ship-quote .q-total{font-family:"Fraunces",serif;font-weight:600;font-size:1.05rem;color:#fff}
.lb__ship-go{
  margin-top:.2rem;
  font-family:"Inter",system-ui,sans-serif;font-size:.98rem;font-weight:600;
  color:#fff;background:var(--accent);
  border:none;border-radius:999px;cursor:pointer;
  padding:.65rem 1.3rem;min-height:46px;
  transition:transform .18s,box-shadow .18s,opacity .18s;
  box-shadow:0 10px 26px -12px rgba(226,59,86,.7);
}
.lb__ship-go:hover:not(:disabled){transform:translateY(-2px)}
.lb__ship-go:disabled{opacity:.5;cursor:default}
[lang=he] .lb__ship-go{font-family:"Noto Sans Hebrew","Inter",sans-serif}

/* Purchase result banner */
.banner[hidden]{display:none}
.lb__ship[hidden]{display:none}
.banner{
  position:fixed;left:50%;transform:translateX(-50%);
  bottom:calc(1rem + env(safe-area-inset-bottom));
  z-index:120;max-width:min(560px,92vw);
  display:flex;align-items:flex-start;gap:.8rem;
  padding:.85rem 1rem .85rem 1.2rem;
  background:var(--ink);color:var(--paper);
  border-radius:14px;line-height:1.4;font-size:.92rem;
  box-shadow:0 18px 50px -16px rgba(0,0,0,.55);
  animation:bannerUp .4s cubic-bezier(.2,.8,.2,1);
}
@keyframes bannerUp{from{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%,0)}}
.banner.is-success{background:#1f5d3a}
.banner.is-error{background:#7a2230}
.banner__msg{flex:1}
.banner__action{
  flex-shrink:0;align-self:center;
  font-weight:600;font-size:.86rem;text-decoration:none;
  color:var(--ink);background:var(--paper);
  padding:.45rem .9rem;border-radius:999px;white-space:nowrap;
  transition:transform .15s,opacity .15s;
}
.banner__action:hover{transform:translateY(-1px);opacity:.92}
.banner__x{
  background:transparent;border:none;color:inherit;cursor:pointer;
  font-size:1.4rem;line-height:1;padding:0 .2rem;opacity:.8;
}
.banner__x:hover{opacity:1}

/* Controls stay fixed to the viewport while the lightbox content scrolls under them */
.lb__close,.lb__nav{
  position:fixed;z-index:110;background:rgba(40,34,28,.7);color:#fff;border:none;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;
}
.lb__close{top:1.1rem;right:1.1rem;width:46px;height:46px;font-size:1.7rem;line-height:1}
.lb__nav{top:50%;transform:translateY(-50%);width:50px;height:50px;font-size:2.1rem;line-height:0}
.lb__prev{left:.9rem}
.lb__next{right:.9rem}
.lb__close:hover,.lb__nav:hover{background:var(--accent)}
.lb__nav:hover{transform:translateY(-50%) scale(1.08)}
@media (max-width:600px){
  .lb__desc{display:none}
  .lb__img{max-height:52vh}
  .lb__nav{width:42px;height:42px;font-size:1.7rem}
  .lb__prev{left:.45rem}.lb__next{right:.45rem}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto}
  .reveal-on .piece{opacity:1;transform:none}
}
