/* Gallery App — storefront styles. Standalone (no OC theme bleed). */
:root{
  --gal-bg:#f6f1ea;
  --gal-bg-card:#fff;
  --gal-ink:#1c1a17;
  --gal-ink-soft:#6a6258;
  --gal-accent:#0a2548;
  --gal-accent-hover:#143670;
  --gal-warn:#a23b3b;
  --gal-line:#d8cfc1;
  --gal-shadow:0 2px 12px rgba(0,0,0,0.08);
  --gal-radius:8px;
  --gal-font:Arial,Helvetica,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body.gallery-page,body.gallery-piece,body.gallery-submit{
  background:var(--gal-bg);color:var(--gal-ink);font-family:var(--gal-font);
  font-size:16px;line-height:1.55;
}
a{color:var(--gal-accent);text-decoration:none}
a:hover{color:var(--gal-accent-hover);text-decoration:underline}

/* --------- header --------- */
.gal-header{padding:36px 24px 18px;text-align:center;background:linear-gradient(180deg,#fff,transparent)}
.gal-brand{display:inline-block;font-weight:700;color:var(--gal-accent);margin-bottom:8px;font-size:14px;letter-spacing:.05em;text-transform:uppercase}
.gal-title{font-size:34px;margin:6px 0 4px;font-weight:700}
.gal-subtitle{margin:0 0 14px;color:var(--gal-ink-soft);font-size:16px}
.gal-submit-cta{display:inline-block;background:var(--gal-accent);color:#fff;padding:10px 20px;border-radius:var(--gal-radius);font-weight:700;margin-top:8px}
.gal-submit-cta:hover{background:var(--gal-accent-hover);color:#fff;text-decoration:none}
.gal-i-plus::before{content:"+ ";margin-right:4px}

.gal-header-piece h1{font-size:28px}
.gal-by-line{margin:4px 0 0;color:var(--gal-ink-soft)}
.gal-back{display:inline-block;color:var(--gal-accent);font-weight:600;margin:0 0 12px}

/* --------- filter bar --------- */
.gal-filterbar{background:#fff;border-bottom:1px solid var(--gal-line);padding:14px 24px;position:sticky;top:0;z-index:5}
.gal-filterbar form{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-start}
.gal-search input{padding:8px 12px;border:1px solid var(--gal-line);border-radius:var(--gal-radius);font-size:14px;min-width:200px}
.gal-filter-group{flex:0 0 auto}
.gal-filter-group summary{cursor:pointer;font-weight:600;font-size:14px;padding:6px 0;color:var(--gal-ink)}
.gal-filter-group summary::-webkit-details-marker{display:none}
.gal-filter-group summary::before{content:"▸ ";color:var(--gal-ink-soft)}
.gal-filter-group[open] summary::before{content:"▾ "}
.gal-chip-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px;max-width:520px}
.gal-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:999px;background:#f0e9dd;border:2px solid transparent;cursor:pointer;font-size:13px;user-select:none}
.gal-chip input{display:none}
.gal-chip.is-active{background:var(--chip,#666);color:#fff;border-color:var(--chip,#666)}
.gal-sort{display:flex;align-items:center;gap:8px;margin-left:auto;font-size:14px}
.gal-sort select{padding:6px 10px;border:1px solid var(--gal-line);border-radius:var(--gal-radius);font-size:14px}
.gal-apply{background:var(--gal-accent);color:#fff;border:0;padding:7px 14px;border-radius:var(--gal-radius);font-weight:600;cursor:pointer}
.gal-clear{font-size:13px;color:var(--gal-ink-soft)}

/* --------- grid --------- */
.gal-grid-wrap{padding:24px;max-width:1400px;margin:0 auto}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.gal-card{background:var(--gal-bg-card);border-radius:var(--gal-radius);overflow:hidden;box-shadow:var(--gal-shadow);display:block;color:inherit;transition:transform .12s ease,box-shadow .12s ease}
.gal-card:hover{transform:translateY(-2px);box-shadow:0 4px 18px rgba(0,0,0,0.12);text-decoration:none;color:inherit}
.gal-card img{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;background:#eee}
.gal-no-image{aspect-ratio:4/5;background:#eee}
.gal-card-meta{padding:10px 12px}
.gal-card h3{margin:0 0 4px;font-size:15px;font-weight:700;line-height:1.3}
.gal-by{color:var(--gal-ink-soft);font-size:12px;display:block}
.gal-wood{display:inline-block;font-size:11px;padding:2px 6px;background:#f0e9dd;border-radius:999px;color:#7a3f25;margin-right:4px;margin-top:4px}
.gal-likes{display:inline-block;font-size:12px;color:var(--gal-warn);margin-top:4px}
.gal-card.is-featured{outline:2px solid var(--gal-accent);outline-offset:-2px}
.gal-card.is-featured::after{content:"★";position:absolute}
.gal-empty{text-align:center;padding:60px 20px;color:var(--gal-ink-soft);font-size:18px}

.gal-pagination{display:flex;justify-content:center;align-items:center;gap:18px;padding:30px 0;font-size:14px}
.gal-page-info{color:var(--gal-ink-soft)}
.gal-page-prev,.gal-page-next{font-weight:600}

/* --------- piece detail --------- */
.gal-piece-main{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,1fr);gap:24px;padding:0 24px;max-width:1400px;margin:0 auto}
@media (max-width: 800px){.gal-piece-main{grid-template-columns:1fr}}

.gal-carousel{position:relative;background:#fff;border-radius:var(--gal-radius);overflow:hidden;box-shadow:var(--gal-shadow)}
.gal-carousel-stage{position:relative;aspect-ratio:4/3}
.gal-slide{position:absolute;inset:0;opacity:0;transition:opacity .25s;margin:0;display:flex;align-items:center;justify-content:center;background:#000}
.gal-slide.is-active{opacity:1;z-index:1}
.gal-slide img{max-width:100%;max-height:100%;display:block;cursor:zoom-in}
.gal-slide figcaption{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;background:rgba(0,0,0,.6);color:#fff;font-size:13px}

.gal-carousel-prev,.gal-carousel-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.85);border:0;border-radius:999px;width:42px;height:42px;font-size:22px;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center}
.gal-carousel-prev{left:10px}.gal-carousel-next{right:10px}
.gal-carousel-prev:hover,.gal-carousel-next:hover{background:#fff}

.gal-carousel-thumbs{display:flex;gap:6px;padding:8px;background:#fff;overflow-x:auto}
.gal-thumb{flex:0 0 60px;height:60px;border:2px solid transparent;border-radius:6px;overflow:hidden;background:#000;padding:0;cursor:pointer}
.gal-thumb.is-active{border-color:var(--gal-accent)}
.gal-thumb img{width:100%;height:100%;object-fit:cover}

/* lightbox */
.gal-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:1000;display:none;align-items:center;justify-content:center}
.gal-lightbox.is-open{display:flex}
.gal-lightbox img{max-width:96vw;max-height:92vh;display:block}
.gal-lightbox-close{position:absolute;top:18px;right:22px;background:transparent;border:0;color:#fff;font-size:32px;cursor:pointer}
.gal-lightbox-prev,.gal-lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:0;color:#fff;font-size:30px;width:54px;height:54px;cursor:pointer;border-radius:999px}
.gal-lightbox-prev{left:24px}.gal-lightbox-next{right:24px}

/* --------- piece meta sidebar --------- */
.gal-piece-meta{background:#fff;border-radius:var(--gal-radius);padding:20px;box-shadow:var(--gal-shadow);align-self:start}
.gal-meta-row{margin:6px 0;font-size:14px}
.gal-meta-label{color:var(--gal-ink-soft)}
.gal-meta-tags{margin:10px 0}
.gal-tag{display:inline-block;background:var(--chip,#666);color:#fff;padding:3px 10px;border-radius:999px;font-size:11px;margin-right:4px;margin-bottom:4px}
.gal-desc{margin:16px 0;color:var(--gal-ink);font-size:15px}

.gal-actions{margin:18px 0}
.gal-like-btn{background:#fff;border:2px solid var(--gal-warn);color:var(--gal-warn);padding:10px 18px;border-radius:var(--gal-radius);cursor:pointer;font-size:15px;font-weight:600;display:inline-flex;align-items:center;gap:8px;transition:all .15s}
.gal-like-btn:hover{background:var(--gal-warn);color:#fff}
.gal-like-btn.is-liked,.gal-like-btn:disabled{background:var(--gal-warn);color:#fff;cursor:default}
.gal-heart{font-size:18px}

.gal-share{margin:18px 0;font-size:13px;color:var(--gal-ink-soft)}
.gal-share-link{display:inline-block;padding:4px 10px;border:1px solid var(--gal-line);border-radius:var(--gal-radius);margin-left:6px}

.gal-products{margin-top:18px;border-top:1px solid var(--gal-line);padding-top:14px}
.gal-products h3{margin:0 0 10px;font-size:16px}
.gal-products ul{list-style:none;padding:0;margin:0}
.gal-product-link{display:flex;align-items:center;gap:10px;padding:8px;border-radius:6px;color:inherit}
.gal-product-link:hover{background:#f6f1ea;text-decoration:none;color:inherit}
.gal-product-link img{width:60px;height:60px;object-fit:cover;border-radius:4px;flex:0 0 60px}
.gal-product-link span{flex:1;font-size:14px}
.gal-product-link strong{color:var(--gal-accent);font-weight:700}

/* --------- comments --------- */
.gal-comments{padding:24px;max-width:900px;margin:0 auto}
.gal-comments h2{font-size:22px;border-bottom:2px solid var(--gal-line);padding-bottom:8px}
.gal-no-comments{color:var(--gal-ink-soft);text-align:center;padding:20px}
.gal-comment-list{list-style:none;padding:0}
.gal-comment{background:#fff;border-radius:var(--gal-radius);padding:14px 18px;margin-bottom:10px;box-shadow:var(--gal-shadow)}
.gal-comment header{font-size:13px;color:var(--gal-ink-soft);margin-bottom:6px}
.gal-comment header strong{color:var(--gal-ink)}
.gal-comment time{margin-left:8px}
.gal-comment-body{font-size:15px}

.gal-comment-form{margin-top:24px;background:#fff;padding:18px;border-radius:var(--gal-radius);box-shadow:var(--gal-shadow)}
.gal-comment-form h3{margin:0 0 12px;font-size:16px}
.gal-comment-form label{display:block;margin-bottom:10px;font-size:13px;color:var(--gal-ink-soft)}
.gal-comment-form input,.gal-comment-form textarea{width:100%;padding:8px 10px;border:1px solid var(--gal-line);border-radius:6px;font-size:14px;font-family:inherit}
.gal-comment-form button{background:var(--gal-accent);color:#fff;border:0;padding:9px 18px;border-radius:6px;font-weight:600;cursor:pointer;margin-top:6px}
.gal-comment-msg{margin-top:10px;font-size:13px}
.gal-comment-msg.is-ok{color:#3b6e3a}
.gal-comment-msg.is-err{color:var(--gal-warn)}

/* --------- submit form --------- */
.gal-submit-main{max-width:780px;margin:24px auto;padding:0 24px}
.gal-field{margin-bottom:18px}
.gal-field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.gal-field input[type=text],.gal-field input[type=email],.gal-field select,.gal-field textarea{
  width:100%;padding:10px 12px;border:1px solid var(--gal-line);border-radius:var(--gal-radius);font-size:15px;font-family:inherit
}
.gal-req{color:var(--gal-warn)}
.gal-hint{font-size:12px;color:var(--gal-ink-soft);margin:4px 0 0}
.gal-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width: 600px){.gal-row-2{grid-template-columns:1fr}}
.gal-file-list{margin-top:10px;display:flex;flex-wrap:wrap;gap:10px}
.gal-file-list .gal-file-tile{position:relative;width:90px;height:90px;border-radius:6px;overflow:hidden;background:#eee}
.gal-file-list img{width:100%;height:100%;object-fit:cover;display:block}
.gal-file-tile button{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.6);color:#fff;border:0;border-radius:999px;width:22px;height:22px;cursor:pointer;font-size:14px;line-height:1}
.gal-btn-primary{background:var(--gal-accent);color:#fff;border:0;padding:12px 28px;border-radius:var(--gal-radius);font-weight:700;font-size:16px;cursor:pointer}
.gal-btn-primary:hover{background:var(--gal-accent-hover)}
.gal-progress{height:6px;background:#eee;border-radius:999px;margin-top:14px;overflow:hidden}
.gal-bar{height:100%;width:0;background:var(--gal-accent);transition:width .15s}
.gal-msg.is-err{color:var(--gal-warn);font-weight:600}
.gal-msg.is-ok{color:#3b6e3a;font-weight:600}
.gal-thanks{text-align:center;padding:60px 20px}

/* --------- footer --------- */
.gal-footer{padding:30px 24px 60px;text-align:center;color:var(--gal-ink-soft);font-size:14px;border-top:1px solid var(--gal-line);margin-top:36px;background:#fff}
