.page-gallery-baccino .gallery-baccino-wrap { background: #faf9f7; color: #333; padding-top: 5.5rem; min-height: 100vh; }
.gallery-baccino-header { text-align: center; padding: 2.5rem 1rem 1rem; }
.gallery-baccino-header h1 { font-family: Georgia, 'Times New Roman', serif; font-size: clamp(2rem, 4vw, 2.75rem); color: #2c2c2c; font-weight: 400; }
.gallery-baccino-header .sub { color: #666; font-size: 1.05rem; margin-top: 0.5rem; }
.gallery-filter-wrap { max-width: 1100px; margin: 0 auto; padding: 1rem; border-bottom: 1px solid #e5e0d8; }
.gallery-filter-wrap .label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.12em; color: #888; margin-bottom: 0.75rem; }
.gallery-filter-btns { display: flex; flex-wrap: wrap; gap: 0.4rem; justify-content: center; }
.gallery-filter-btns button { border: 1px solid #d4cfc6; background: #fff; color: #555; padding: 0.35rem 0.85rem; font-size: 0.8rem; border-radius: 2px; transition: all .2s; }
.gallery-filter-btns button:hover, .gallery-filter-btns button.active { background: #2c2c2c; color: #fff; border-color: #2c2c2c; }
.gallery-masonry { max-width: 1200px; margin: 0 auto; padding: 2rem 1rem 4rem; display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 1.5rem; }
.gallery-item { background: #fff; box-shadow: 0 2px 12px rgba(0,0,0,0.06); border-radius: 2px; overflow: hidden; }
.gallery-item.hidden-item { display: none !important; }
.gallery-item img { width: 100%; height: 200px; object-fit: cover; }
.gallery-item-body { padding: 1rem 1.1rem 1.25rem; }
.gallery-item-body h3 { font-size: 0.95rem; font-weight: 600; color: #2c2c2c; line-height: 1.35; margin-bottom: 0.75rem; min-height: 2.6em; }
.gallery-item-body .meta { display: flex; justify-content: space-between; align-items: center; font-size: 0.8rem; color: #888; }
.gallery-item-body a.read { color: #8b7355; text-decoration: none; font-weight: 500; }
.gallery-item-body a.read:hover { text-decoration: underline; }
.gallery-load-wrap { text-align: center; padding-bottom: 4rem; }
.gallery-load-wrap button { border: 2px solid #2c2c2c; background: transparent; color: #2c2c2c; padding: 0.65rem 2.5rem; font-weight: 600; text-transform: uppercase; font-size: 0.75rem; letter-spacing: 0.1em; }
.gallery-load-wrap button:hover { background: #2c2c2c; color: #fff; }

