/* gallery.css — Gallery page: masonry grid, two-row filters, lightbox */

/* page header */
.g-head{padding:40px 0 8px;position:relative}
.g-head .dot{position:absolute;border-radius:50%;filter:blur(1px);z-index:0}
.g-head-inner{position:relative;z-index:1}
.g-head .eyebrow{display:block;margin-bottom:10px}
.g-head h1{font-family:var(--serif);font-weight:500;font-size:54px;line-height:1.06;margin:0;letter-spacing:.006em}
.g-head .intro{margin:18px 0 0;max-width:520px;color:var(--ink-soft);font-size:16.5px;line-height:1.65}
.g-head .count{margin-top:14px;font-size:13px;color:var(--ink-faint);font-weight:700;letter-spacing:.04em}

/* filter bar */
.g-filterwrap{position:sticky;top:0;z-index:20;background:linear-gradient(var(--cream) 72%,rgba(245,241,233,0));
  padding:22px 48px 18px;margin:18px -48px 0}
.g-frow{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.g-frow + .g-frow{margin-top:12px}
.g-flabel{font-family:var(--body);font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:10.5px;
  color:var(--ink-faint);width:60px;flex:0 0 auto}
.g-chip{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line-soft);
  border-radius:100px;padding:8px 15px;font-weight:700;font-size:13px;color:var(--ink-soft);cursor:pointer;transition:.15s}
.g-chip .e{width:8px;height:8px;border-radius:50%;background:var(--sage)}
.g-chip:hover{border-color:var(--sage);color:var(--ink)}
.g-chip.active{background:var(--ink);color:#f7f4ee;border-color:var(--ink)}
.g-chip.active .e{background:var(--sage-soft)}
.g-chip.tagchip .e{background:var(--rose)}
.g-chip.tagchip.active .e{background:var(--rose-tint)}
.g-chip.srcchip .e{background:var(--ink-soft)}
.g-chip.srcchip.active .e{background:var(--cream-deep)}

/* masonry grid (CSS multicol) */
.g-grid{column-count:var(--g-cols,3);column-gap:var(--g-gap,24px);margin-top:8px}
.g-grid.uniform{column-count:initial;display:grid;grid-template-columns:repeat(var(--g-cols,3),1fr);gap:var(--g-gap,24px)}
.g-card{break-inside:avoid;width:100%;margin:0 0 var(--g-gap,24px);background:var(--card);border-radius:var(--g-radius,20px);
  padding:12px;box-shadow:0 8px 22px rgba(64,63,59,.06);cursor:pointer;transition:transform .2s,box-shadow .2s;
  -webkit-column-break-inside:avoid}
.g-grid.uniform .g-card{margin:0}
.g-card:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(64,63,59,.12)}
.g-card .g-thumb{position:relative;border-radius:calc(var(--g-radius,20px) - 7px);overflow:hidden}
.g-card .g-thumb .ph{width:100%;height:100%}
.g-grid.uniform .g-card .g-thumb{aspect-ratio:1/1}
.g-card .g-thumb .g-badge{position:absolute;top:12px;left:12px;box-shadow:0 4px 12px rgba(64,63,59,.12)}
.g-card .g-thumb .g-more{position:absolute;bottom:12px;right:12px;display:inline-flex;align-items:center;gap:6px;
  background:rgba(251,249,244,.92);border-radius:100px;padding:5px 11px;font-family:var(--mono);font-size:11px;color:var(--ink-soft)}
.g-card .g-body{padding:14px 8px 8px}
.g-card h3{font-family:var(--serif);font-weight:600;font-size:23px;margin:0 0 5px;line-height:1.12}
.g-card .g-meta{font-size:13px;color:var(--ink-faint);line-height:1.5}
.g-card .g-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:11px}
.g-card .g-tag{font-size:11px;font-weight:700;letter-spacing:.03em;color:var(--sage-deep);
  background:var(--sage-tint);border-radius:100px;padding:3px 9px}
.g-empty{padding:60px 0;text-align:center;color:var(--ink-faint);font-size:16px}

/* badge size override inside cards */
.badge.soon-pattern{background:var(--rose-tint);color:var(--rose-deep)}
.badge.soon-pattern .dot{background:var(--rose-deep)}

/* ---------- lightbox ---------- */
.lb-overlay{position:fixed;inset:0;background:rgba(40,39,37,.5);backdrop-filter:blur(5px);z-index:60;
  display:flex;align-items:center;justify-content:center;gap:16px;padding:36px;animation:lbfade .2s ease}
@keyframes lbfade{from{opacity:0}to{opacity:1}}
.lb{position:relative;background:var(--card);border-radius:26px;flex:0 1 1040px;min-width:0;max-height:90vh;overflow:hidden;
  display:grid;grid-template-columns:1.08fr .92fr;grid-template-rows:minmax(0,1fr);box-shadow:0 40px 90px rgba(40,39,37,.4);animation:lbpop .24s cubic-bezier(.2,.8,.3,1)}
@keyframes lbpop{from{transform:scale(.96) translateY(8px);opacity:.6}to{transform:none;opacity:1}}
.lb-media{background:var(--cream-deep);padding:20px;display:flex;flex-direction:column;gap:14px;min-height:0}
.lb-main{flex:1 1 auto;border-radius:16px;overflow:hidden;min-height:340px}
.lb-main .ph{width:100%;height:100%}
.lb-thumbs{display:flex;gap:8px;flex:0 0 auto;overflow-x:auto}
.lb-thumb{border:2px solid transparent;background:none;padding:0;cursor:pointer;line-height:0;border-radius:10px;overflow:hidden;flex:0 0 auto;transition:border-color .15s}
.lb-thumb:hover{border-color:var(--sage-soft)}
.lb-thumb.active{border-color:var(--sage-deep)}
.lb-thumb img{width:68px;height:68px;object-fit:cover;display:block}
.lb-thumbs .ph{width:68px;height:68px;border-radius:0;flex:none}
.lb-info{padding:34px 34px 30px;overflow-y:auto;min-height:0;display:flex;flex-direction:column}
.lb-info .lb-cat{font-family:var(--body);font-weight:800;letter-spacing:.16em;text-transform:uppercase;font-size:11px;color:var(--sage-deep)}
.lb-info h2{font-family:var(--serif);font-weight:500;font-size:36px;line-height:1.08;margin:8px 0 0}
.lb-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.lb-note{display:inline-flex;align-items:center;font-family:var(--body);font-weight:700;font-size:11px;
  letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:100px;line-height:1;
  background:var(--cream-deep);color:var(--ink-soft)}
.lb-blurb{color:var(--ink-soft);font-size:15px;line-height:1.6;margin:18px 0 0}
.lb-subh{display:block;font-family:var(--body);font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  font-size:10.5px;color:var(--ink-faint);margin-bottom:11px}

/* inspiration block */
.lb-inspo{margin:22px 0 0;padding:16px;background:var(--cream-deep);border-radius:16px}
.lb-inspo-row{display:flex;gap:14px;align-items:center}
.lb-inspo-img{flex:0 0 auto;width:74px;height:74px;border-radius:12px;overflow:hidden}
.lb-inspo-img .ph{width:100%;height:100%}
.lb-inspo-img .ph-tag{font-size:9px;padding:3px 6px}
.lb-inspo-txt{display:flex;flex-direction:column;gap:2px;min-width:0}
.lb-inspo-txt strong{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--ink);line-height:1.1}
.lb-inspo-txt .from{font-size:13.5px;color:var(--ink-soft)}
.lb-inspo-txt .cred{font-size:11.5px;color:var(--ink-faint);margin-top:3px;font-style:italic}

/* materials */
.lb-mats{margin:22px 0 0}
.lb-matlist{list-style:none;margin:0;padding:0;display:grid;gap:0}
.lb-matlist li{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--line-soft);font-size:14px}
.lb-matlist li:first-child{border-top:1px solid var(--line-soft)}
.lb-matlist .mk{color:var(--ink-faint);font-weight:700;letter-spacing:.02em;flex:0 0 auto}
.lb-matlist .mv{color:var(--ink);text-align:right}

.lb-specs{margin:22px 0 0;border-top:1px solid var(--line-soft)}
.lb-spec{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line-soft);font-size:14.5px}
.lb-spec .k{color:var(--ink-faint);font-weight:700;letter-spacing:.02em}
.lb-spec .v{color:var(--ink);text-align:right}
.lb-spec .v.credit{color:var(--rose-deep);font-weight:600}
.lb-tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:18px}
.lb-tags .g-tag{font-size:11.5px;font-weight:700;color:var(--sage-deep);background:var(--sage-tint);border-radius:100px;padding:4px 11px}
.lb-soon{display:flex;align-items:center;gap:9px;margin-top:20px;padding:12px 16px;background:var(--rose-tint);
  border-radius:14px;font-size:13.5px;color:var(--rose-deep);font-weight:600;line-height:1.4}
.lb-soon .soon-dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--rose-deep)}
.lb-soon.avail{background:var(--sage-tint);color:var(--sage-deep)}
.lb-soon.avail .soon-dot{background:var(--sage-deep)}
.lb-actions{margin-top:auto;padding-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.lb-close{position:absolute;top:16px;right:16px;z-index:3;width:38px;height:38px;border-radius:50%;border:none;
  background:rgba(251,249,244,.9);color:var(--ink);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(64,63,59,.16);transition:.15s}
.lb-close:hover{background:#fff;transform:rotate(90deg)}
.lb-nav{position:relative;flex:0 0 auto;width:44px;height:44px;border-radius:50%;border:none;
  background:rgba(251,249,244,.92);color:var(--ink);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 18px rgba(40,39,37,.25);z-index:3;transition:.15s}
.lb-nav:hover{background:#fff}

@media (max-width:860px){
  .lb{grid-template-columns:1fr;grid-template-rows:auto;max-height:92vh;overflow-y:auto;flex:1 1 auto;width:100%}
  .lb-info{overflow:visible}
  .lb-main{min-height:260px}
  .lb-nav{position:absolute;top:50%;transform:translateY(-50%)}
  .lb-prev{left:8px}
  .lb-next{right:8px}
}
