:root{
  --bg:#1a1813;
  --bg-soft:#211e17;
  --panel:#28251c;
  --panel-2:#302c21;
  --bark:#141209;
  --oat:#e9e1cf;
  --oat-dim:#b2a98f;
  --muted:#827a64;
  --line:rgba(233,225,207,.12);
  --line-strong:rgba(233,225,207,.22);
  --moss:#9fb05f;
  --moss-deep:#7d8d48;
  --moss-soft:rgba(159,176,95,.14);
  --clay:#c47a4a;
  --display:"Bitter", Georgia, serif;
  --body:"Mulish", system-ui, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--oat);line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* grain */
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:min(1240px,90vw);margin-inline:auto;position:relative;z-index:1}

/* topographic contour decoration */
.contours{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.5}
.contours path{fill:none;stroke:var(--moss);stroke-width:1;opacity:.16}

.eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--moss)}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--moss);border-radius:2px}
.leaf-accent{color:var(--moss)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--body);font-weight:700;font-size:.9rem;letter-spacing:.02em;padding:.95rem 1.7rem;border-radius:8px;cursor:pointer;border:1.5px solid transparent;transition:all .35s cubic-bezier(.2,.8,.2,1)}
.btn svg{width:17px;height:17px;transition:transform .35s}
.btn-moss{background:var(--moss);color:#20240f}
.btn-moss:hover{background:#aebf6c;transform:translateY(-2px);box-shadow:0 14px 30px -14px rgba(159,176,95,.7)}
.btn-moss:hover svg{transform:translateX(4px)}
.btn-line{border-color:var(--line-strong);color:var(--oat)}
.btn-line:hover{border-color:var(--moss);color:var(--moss);transform:translateY(-2px)}
.btn-dark{background:#20240f;color:var(--moss)}
.btn-dark:hover{background:#14160a;transform:translateY(-2px)}
.btn-cream{background:#eee6d3;color:#20240f}
.btn-cream:hover{background:#fff;transform:translateY(-2px)}

/* header */
header{position:sticky;top:0;z-index:100;border-bottom:1px solid transparent;transition:.45s}
header.scrolled{background:rgba(26,24,19,.8);backdrop-filter:blur(12px);border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 0}
.brand{display:flex;align-items:center;gap:.8rem}
.brand .mark{width:42px;height:42px;border-radius:12px;background:var(--moss);color:#20240f;display:grid;place-items:center}
.brand .mark svg{width:24px;height:24px}
.brand-text b{font-family:var(--display);font-size:1.18rem;font-weight:600;display:block;line-height:1.05}
.brand-text span{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-size:.92rem;font-weight:600;color:var(--oat-dim);position:relative;transition:color .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--moss);border-radius:2px;transition:width .35s}
.nav-links a:hover{color:var(--oat)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:1.2rem}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.menu-toggle span{width:24px;height:2px;background:var(--oat);border-radius:2px;transition:.3s}

/* hero */
.hero{padding:clamp(2.5rem,7vw,6rem) 0 clamp(3rem,7vw,5.5rem);position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,6.5vw,5rem);line-height:1.02;letter-spacing:-.01em;margin:1.6rem 0}
.hero h1 .small{display:block;font-family:var(--display);font-style:italic;font-weight:400;font-size:.4em;color:var(--oat-dim);margin-top:.5rem;letter-spacing:0}
.hero-lead{font-size:1.12rem;color:var(--oat-dim);max-width:48ch;font-weight:400;margin-bottom:2.2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero-meta{display:flex;gap:2.6rem;margin-top:2.8rem;flex-wrap:wrap}
.hero-meta .item b{font-family:var(--display);font-size:1.8rem;font-weight:600;color:var(--moss);display:block;line-height:1}
.hero-meta .item span{font-size:.82rem;color:var(--muted)}

/* portrait */
.portrait{position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;border:1px solid var(--line-strong);background:linear-gradient(160deg,var(--panel-2),var(--panel));box-shadow:0 30px 70px -34px rgba(0,0,0,.7)}
.portrait img{width:100%;height:100%;object-fit:cover}
.portrait .ph{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:var(--muted);padding:1rem}
.portrait .ph svg{width:58px;height:58px;color:var(--moss);opacity:.6;margin-bottom:.9rem}
.portrait .ph span{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase}
.stamp{position:absolute;right:-12px;bottom:26px;background:var(--moss);color:#20240f;width:92px;height:92px;border-radius:50%;display:grid;place-content:center;text-align:center;font-family:var(--display);font-weight:600;line-height:1.05;transform:rotate(-8deg);box-shadow:0 14px 30px -14px rgba(0,0,0,.6)}
.stamp b{font-size:1.4rem;display:block}
.stamp span{font-size:.56rem;letter-spacing:.14em;text-transform:uppercase;font-family:var(--body);font-weight:700}

/* marquee */
.strip{border-block:1px solid var(--line);padding:1rem 0;overflow:hidden;white-space:nowrap;background:var(--bg-soft)}
.strip .track{display:inline-flex;animation:scroll 32s linear infinite}
.strip .track span{display:inline-flex;align-items:center;gap:2.2rem;padding-right:2.2rem;font-family:var(--display);font-style:italic;font-size:1.25rem;color:var(--oat-dim)}
.strip .track .d{color:var(--moss);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}

section{position:relative;z-index:1}
.pad{padding:clamp(4rem,8vw,7rem) 0}
.head{max-width:60ch;margin-bottom:3.2rem}
.head h2{font-family:var(--display);font-weight:700;font-size:clamp(2rem,4.6vw,3.4rem);line-height:1.08;letter-spacing:-.01em;margin-top:1rem}
.head p{color:var(--oat-dim);font-size:1.06rem;margin-top:1rem}

/* about */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about-text h2{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4.3vw,3.1rem);line-height:1.1;letter-spacing:-.01em}
.about-text h2 em{font-style:italic;font-weight:500;color:var(--moss)}
.values{display:flex;gap:1.2rem;margin:1.6rem 0;flex-wrap:wrap}
.values span{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--moss);display:inline-flex;align-items:center;gap:1.2rem}
.values span:not(:last-child)::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--muted)}
.about-text p{color:var(--oat-dim);margin-bottom:1.1rem}
.sign{font-family:var(--display);font-style:italic;font-size:1.4rem;color:var(--oat);margin-top:1.4rem}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.3rem}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:2.1rem;transition:transform .4s cubic-bezier(.2,.8,.2,1),border-color .4s,background .4s;position:relative;overflow:hidden}
.card::after{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--moss);transform:scaleX(0);transform-origin:left;transition:transform .45s}
.card:hover{transform:translateY(-6px);border-color:var(--line-strong);background:var(--panel-2)}
.card:hover::after{transform:scaleX(1)}
.card .top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.2rem}
.card .ic{width:52px;height:52px;border-radius:13px;background:var(--moss-soft);color:var(--moss);display:grid;place-items:center;transition:.4s}
.card:hover .ic{background:var(--moss);color:#20240f}
.card .ic svg{width:26px;height:26px}
.card .num{font-family:var(--display);font-size:1.1rem;color:var(--muted)}
.card h3{font-family:var(--display);font-weight:600;font-size:1.42rem;margin-bottom:.55rem}
.card p{color:var(--oat-dim);font-size:.96rem;font-weight:400}

/* focus */
.focus-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:2.8rem}
.focus-item{padding-top:1.4rem;border-top:2px solid var(--moss)}
.focus-item b{font-family:var(--display);font-size:2.3rem;font-weight:700;color:var(--moss);display:block;line-height:1}
.focus-item h4{font-size:1.02rem;font-weight:700;margin:.8rem 0 .35rem}
.focus-item p{font-size:.9rem;color:var(--muted)}

/* quote */
.quote{background:var(--bg-soft);border-block:1px solid var(--line);padding:clamp(4rem,8vw,6.5rem) 0;text-align:center;position:relative;overflow:hidden}
.quote blockquote{font-family:var(--display);font-weight:500;font-style:italic;font-size:clamp(1.7rem,4vw,2.8rem);line-height:1.3;max-width:24ch;margin:0 auto;position:relative}
.quote blockquote em{color:var(--moss);font-style:italic}
.quote .who{margin-top:1.8rem;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:700}
.quote .pawmark{display:inline-block;color:var(--moss);margin-bottom:1.4rem}
.quote .pawmark svg{width:42px;height:42px}

/* cta */
.cta-card{border-radius:24px;background:linear-gradient(150deg,var(--moss-deep),#5f6c34);color:#1c2010;padding:clamp(2.6rem,6vw,4.5rem);display:grid;grid-template-columns:1.4fr 1fr;gap:2.6rem;align-items:center;position:relative;overflow:hidden}
.cta-card .contours path{stroke:#20240f;opacity:.12}
.cta-card h2{font-family:var(--display);font-weight:700;font-size:clamp(1.9rem,4.4vw,3.1rem);line-height:1.08;position:relative}
.cta-card p{margin-top:.9rem;color:#2a3015;font-weight:500;position:relative}
.cta-actions{display:flex;flex-direction:column;gap:.9rem;position:relative}
.cta-actions .btn{justify-content:center}

/* ===== page hero (subpages) ===== */
.page-hero{padding:clamp(2.5rem,6vw,4.5rem) 0 clamp(1.5rem,3vw,2.5rem);position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero h1{font-family:var(--display);font-weight:700;font-size:clamp(2.2rem,5.5vw,3.8rem);line-height:1.05;margin-top:1rem}
.page-hero p{color:var(--oat-dim);margin-top:.9rem;max-width:52ch;font-size:1.05rem}
.crumb{font-size:.78rem;letter-spacing:.06em;color:var(--muted)}
.crumb a:hover{color:var(--moss)}

/* ===== contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-info .ci-item{display:flex;gap:1rem;padding:1.3rem 0;border-bottom:1px solid var(--line)}
.contact-info .ci-item:last-child{border-bottom:none}
.contact-info .ci-ic{width:46px;height:46px;border-radius:12px;background:var(--moss-soft);color:var(--moss);display:grid;place-items:center;flex-shrink:0}
.contact-info .ci-ic svg{width:22px;height:22px}
.contact-info h4{font-family:var(--display);font-size:1.1rem;margin-bottom:.2rem}
.contact-info a,.contact-info p{color:var(--oat-dim);font-size:.96rem}
.contact-info a:hover{color:var(--moss)}

.form{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:clamp(1.6rem,4vw,2.4rem)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.82rem;font-weight:700;letter-spacing:.04em;margin-bottom:.5rem;color:var(--oat)}
.field input,.field textarea{width:100%;background:var(--bg);border:1px solid var(--line-strong);border-radius:10px;padding:.85rem 1rem;color:var(--oat);font-family:var(--body);font-size:1rem;transition:border-color .3s,box-shadow .3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--moss);box-shadow:0 0 0 3px var(--moss-soft)}
.field textarea{resize:vertical;min-height:130px}
.form .btn{width:100%;justify-content:center;margin-top:.4rem}
.form-note{font-size:.8rem;color:var(--muted);margin-top:1rem;text-align:center}
.form-status{display:none;margin-top:1rem;padding:.9rem 1rem;border-radius:10px;font-size:.92rem}
.form-status.ok{display:block;background:var(--moss-soft);color:var(--moss);border:1px solid var(--moss)}
.form-status.err{display:block;background:rgba(196,122,74,.14);color:var(--clay);border:1px solid var(--clay)}

/* ===== legal / prose pages ===== */
.legal{max-width:760px;margin-inline:auto;padding:clamp(2.5rem,6vw,4.5rem) 0}
.legal h2{font-family:var(--display);font-weight:700;font-size:1.5rem;margin:2.2rem 0 .8rem;color:var(--oat)}
.legal h2:first-child{margin-top:0}
.legal h3{font-family:var(--display);font-weight:600;font-size:1.15rem;margin:1.6rem 0 .5rem;color:var(--oat)}
.legal p,.legal li{color:var(--oat-dim);margin-bottom:.9rem;font-size:1rem}
.legal ul{padding-left:1.3rem;margin-bottom:.9rem}
.legal li{margin-bottom:.4rem}
.legal a{color:var(--moss);text-decoration:underline;text-underline-offset:3px}
.legal strong{color:var(--oat)}
.legal .todo{background:var(--moss-soft);border:1px solid var(--moss);border-radius:8px;padding:.2rem .5rem;color:var(--moss);font-size:.82rem;font-weight:700}
.legal .box{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.2rem 1.4rem;margin:1.2rem 0;font-size:.92rem;color:var(--oat-dim)}

/* footer */
footer{background:var(--bark);padding:clamp(3rem,6vw,4.5rem) 0 2rem;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2.5rem;padding-bottom:2.8rem;border-bottom:1px solid var(--line)}
.foot-grid h5{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--moss);margin-bottom:1.2rem;font-weight:700}
.foot-grid a,.foot-grid p{color:var(--oat-dim);font-size:.93rem;margin-bottom:.6rem;transition:color .3s;display:block}
.foot-grid a:hover{color:var(--moss)}
.foot-brand .brand{margin-bottom:1.1rem}
.foot-brand p{max-width:32ch}
.socials{display:flex;gap:.7rem;margin-top:1.3rem}
.socials a{width:42px;height:42px;border:1px solid var(--line-strong);border-radius:11px;display:grid;place-items:center;transition:.35s}
.socials a svg{width:18px;height:18px}
.socials a:hover{border-color:var(--moss);color:var(--moss);transform:translateY(-3px)}
.foot-bottom{padding-top:1.6rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:var(--muted)}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.2,.8,.2,1),transform .85s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

@media(max-width:920px){
  .hero-grid,.about-grid,.cta-card,.contact-grid{grid-template-columns:1fr}
  .portrait{max-width:380px;margin-top:.5rem}
  .focus-grid{grid-template-columns:repeat(2,1fr)}
  .nav-links{position:fixed;inset:68px 0 auto 0;background:var(--bg-soft);flex-direction:column;gap:0;padding:1rem 5vw 2rem;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .4s;align-items:flex-start}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:.9rem 0;width:100%;border-bottom:1px solid var(--line)}
  .menu-toggle{display:flex}
  .nav .btn-moss.desk{display:none}
}
@media(max-width:560px){
  .svc-grid,.focus-grid{grid-template-columns:1fr}
}

/* ===== news & termine ===== */
.news-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.news-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:transform .4s cubic-bezier(.2,.8,.2,1),border-color .4s}
.news-card:hover{transform:translateY(-5px);border-color:var(--line-strong)}
.news-card .img{aspect-ratio:16/9;background:linear-gradient(160deg,var(--panel-2),var(--panel));overflow:hidden}
.news-card .img img{width:100%;height:100%;object-fit:cover}
.news-card .body{padding:1.6rem;display:flex;flex-direction:column;flex:1}
.news-card .date{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--moss);margin-bottom:.6rem}
.news-card h3{font-family:var(--display);font-weight:600;font-size:1.35rem;line-height:1.15;margin-bottom:.6rem}
.news-card p{color:var(--oat-dim);font-size:.96rem;margin-bottom:1rem;white-space:pre-line}
.news-card .more{margin-top:auto;font-weight:700;font-size:.88rem;color:var(--moss);display:inline-flex;align-items:center;gap:.4rem}
.news-card .more svg{width:15px;height:15px}

.termine-list{display:flex;flex-direction:column;gap:1rem}
.termin{display:grid;grid-template-columns:auto 1fr auto;gap:1.4rem;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.3rem 1.5rem;transition:border-color .4s}
.termin:hover{border-color:var(--moss)}
.termin .when{text-align:center;background:var(--moss-soft);border-radius:10px;padding:.7rem .9rem;min-width:70px}
.termin .when .day{font-family:var(--display);font-size:1.6rem;font-weight:700;color:var(--moss);line-height:1;display:block}
.termin .when .mon{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--moss);font-weight:700}
.termin .what h4{font-family:var(--display);font-size:1.2rem;margin-bottom:.25rem}
.termin .what p{font-size:.9rem;color:var(--oat-dim)}
.termin .what .meta{font-size:.82rem;color:var(--muted);margin-top:.3rem}
.termin .act .btn{padding:.7rem 1.2rem;font-size:.82rem}
@media(max-width:620px){
  .news-grid{grid-template-columns:1fr}
  .termin{grid-template-columns:auto 1fr;gap:1rem}
  .termin .act{grid-column:1 / -1}
  .termin .act .btn{width:100%;justify-content:center}
}

.state{text-align:center;padding:3rem 1rem;color:var(--muted)}
.state svg{width:46px;height:46px;color:var(--moss);opacity:.5;margin-bottom:1rem}
.spinner{width:34px;height:34px;border:3px solid var(--line-strong);border-top-color:var(--moss);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}
@keyframes spin{to{transform:rotate(360deg)}}
.section-label{display:flex;align-items:center;gap:1rem;margin:0 0 2rem}
.section-label h2{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,3.6vw,2.4rem);white-space:nowrap}
.section-label .ln{height:1px;background:var(--line);flex:1}

/* ===== blog feed ===== */
.blog-feed{max-width:760px;margin-inline:auto}
.post{background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;margin-bottom:1.8rem}
.post .post-media{display:grid;gap:3px}
.post .post-media.cols-1{grid-template-columns:1fr}
.post .post-media.cols-2{grid-template-columns:1fr 1fr}
.post .post-media img{width:100%;height:100%;max-height:540px;object-fit:cover;display:block}
.post .post-body{padding:1.8rem clamp(1.4rem,4vw,2.4rem)}
.post .post-date{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--moss);margin-bottom:.6rem}
.post h2{font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3.4vw,2.2rem);line-height:1.14;margin-bottom:.9rem}
.post .post-text{color:var(--oat-dim);white-space:pre-line;line-height:1.75}
.post video{width:100%;border-radius:12px;margin-top:1.2rem;background:#000;display:block}

/* ===== admin / upload ===== */
.admin-wrap{max-width:680px;margin-inline:auto;padding:clamp(2.5rem,6vw,4.5rem) 0}
.admin-wrap .form{margin-top:1.8rem}
.field input[type=file]{padding:.7rem;background:var(--bg);cursor:pointer}
.field input[type=file]::file-selector-button{background:var(--moss-soft);color:var(--moss);border:none;border-radius:7px;padding:.5rem .9rem;margin-right:.8rem;font-weight:700;font-family:var(--body);cursor:pointer}
.filelist{margin-top:.7rem}
.filelist span{display:inline-block;background:var(--moss-soft);color:var(--moss);border-radius:6px;padding:.25rem .6rem;margin:.2rem .3rem .2rem 0;font-size:.82rem}
.hint{font-size:.84rem;color:var(--muted);margin-top:.5rem}
.admin-note{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.2rem 1.4rem;font-size:.9rem;color:var(--oat-dim);margin-top:1.4rem}

/* ===== galerie ===== */
.gallery{columns:3 260px;column-gap:14px}
.gallery figure{break-inside:avoid;margin:0 0 14px;border-radius:14px;overflow:hidden;border:1px solid var(--line);cursor:pointer;position:relative;background:var(--panel)}
.gallery figure img{width:100%;display:block;transition:transform .55s cubic-bezier(.2,.8,.2,1)}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figure::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(16,14,12,.45),transparent 45%);opacity:0;transition:opacity .4s}
.gallery figure:hover::after{opacity:1}
.gallery figure .zoom{position:absolute;right:12px;bottom:12px;width:34px;height:34px;border-radius:50%;background:rgba(16,14,12,.55);color:var(--oat);display:grid;place-items:center;opacity:0;transition:opacity .4s;z-index:1}
.gallery figure:hover .zoom{opacity:1}
.gallery figure .zoom svg{width:16px;height:16px}
@media(max-width:560px){.gallery{columns:2 140px;column-gap:10px}.gallery figure{margin-bottom:10px}}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(8,7,5,.93);backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:1000;padding:5vw}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:0 40px 90px -25px rgba(0,0,0,.85)}
.lightbox button{position:absolute;border:1px solid var(--line-strong);border-radius:50%;background:rgba(0,0,0,.35);color:var(--oat);cursor:pointer;display:grid;place-items:center;transition:.3s}
.lightbox button:hover{border-color:var(--moss);color:var(--moss)}
.lightbox button svg{width:20px;height:20px}
.lightbox .lb-close{top:20px;right:22px;width:46px;height:46px}
.lightbox .lb-prev,.lightbox .lb-next{top:50%;transform:translateY(-50%);width:52px;height:52px}
.lightbox .lb-prev{left:18px}.lightbox .lb-next{right:18px}
@media(max-width:560px){.lightbox .lb-prev{left:8px}.lightbox .lb-next{right:8px}}
