﻿/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito Sans',sans-serif;font-size:14px;color:#222;background:#fff;line-height:1.65;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}
button{cursor:pointer;font-family:'Nunito Sans',sans-serif;}

/* ─── TOPBAR ─── */
#topbar{background:#1a1a1a;height:38px;display:flex;align-items:center;justify-content:flex-end;padding:0 52px;gap:20px;}
.tb-lang{display:flex;align-items:center;gap:6px;}
.tb-lang-btn{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.06em;color:rgba(255,255,255,.55);background:none;border:none;padding:4px 8px;cursor:pointer;transition:color .2s;}
.tb-lang-btn.active{color:#fff;}
.tb-lang-btn:hover{color:#fff;}
.tb-flag-svg{width:18px;height:12px;border-radius:2px;flex-shrink:0;}
.tb-sep{width:1px;height:16px;background:rgba(255,255,255,.2);}
.tb-bayi{font-size:11px;font-weight:600;letter-spacing:.08em;color:rgba(255,255,255,.65);border:1px solid rgba(255,255,255,.2);padding:4px 14px;transition:color .2s,border-color .2s;background:none;}
.tb-bayi:hover{color:#fff;border-color:rgba(255,255,255,.5);}

/* ─── HEADER ─── */
#header{background:#fff;border-bottom:1px solid #e8e8e8;position:sticky;top:0;z-index:500;box-shadow:none;transition:box-shadow .3s;}
#header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.07);}
#header-inner{max-width:1440px;margin:0 auto;padding:0 52px;height:70px;display:flex;align-items:center;justify-content:space-between;}
#logo{display:flex;align-items:center;gap:11px;}
#logo-diamond{width:44px;height:44px;background:#1a1a1a;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);}
#logo-diamond::before{content:'';position:absolute;width:200%;height:8px;background:rgba(255,255,255,.12);transform:rotate(-30deg);top:8px;left:-50%;}
#logo-diamond span{font-size:14px;font-weight:800;color:#fff;position:relative;z-index:1;letter-spacing:-.01em;}
#logo-namestack{display:flex;flex-direction:column;}
#logo-name{font-size:22px;font-weight:800;color:#1a1a1a;letter-spacing:-.02em;line-height:1;}
#logo-name em{color:#8B5E35;font-style:normal;}
#logo-tagline{font-size:9px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:#bbb;margin-top:3px;}
#main-nav{display:flex;align-items:stretch;height:100%;}
.nav-item{position:relative;display:flex;align-items:center;gap:5px;padding:0 18px;font-size:12px;font-weight:700;letter-spacing:.08em;color:#333;border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s;background:none;border-top:none;border-left:none;border-right:none;}
.nav-item:hover,.nav-item.active{color:#1a1a1a;border-bottom-color:#1a1a1a;}
.nav-item > svg{width:9px;height:9px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;transition:transform .2s;}
.nav-item:hover > svg{transform:rotate(180deg);}
.mega-wrap{display:none;position:absolute;top:calc(100% + 1px);left:50%;transform:translateX(-40%);background:#fff;border:1px solid #eee;border-top:3px solid #1a1a1a;box-shadow:0 12px 48px rgba(0,0,0,.1);padding:28px 32px;z-index:400;min-width:680px;}
.nav-item:hover .mega-wrap{display:flex;gap:32px;}
.mega-brand-col{}
.mega-brand-title{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#1a1a1a;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid #1a1a1a;cursor:pointer;}
.mega-brand-title:hover{color:#8B5E35;border-bottom-color:#8B5E35;}
.mega-col-item{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid #f5f5f5;cursor:pointer;transition:background .15s;}
.mega-col-item:last-child{border-bottom:none;}
.mega-col-item:hover .mci-name{color:#8B5E35;}
.mci-thumb{width:52px;height:36px;flex-shrink:0;overflow:hidden;background:#f0ebe3;position:relative;}
.mci-thumb-fill{width:100%;height:100%;position:relative;}
.mci-name{font-size:11px;font-weight:600;color:#444;transition:color .15s;}
.simple-dropdown{display:none;position:absolute;top:calc(100% + 1px);left:0;background:#fff;border:1px solid #eee;border-top:3px solid #1a1a1a;box-shadow:0 8px 32px rgba(0,0,0,.08);min-width:200px;padding:8px 0;z-index:400;}
.nav-item:hover .simple-dropdown{display:block;}
.nav-item-wrap{position:relative;display:flex;align-items:stretch;}
.nav-item-wrap:hover .simple-dropdown{display:block;}
.sd-link{display:block;padding:9px 20px;font-size:11px;font-weight:600;letter-spacing:.06em;color:#555;border-bottom:1px solid #f8f8f8;transition:color .15s,background .15s;}
.sd-link:last-child{border-bottom:none;}
.sd-link:hover{background:#faf7f3;color:#8B5E35;}
#hamburger{display:none;background:none;border:none;padding:8px;cursor:pointer;flex-direction:column;gap:5px;}
#hamburger span{display:block;width:22px;height:2px;background:#1a1a1a;transition:transform .3s,opacity .3s;}
#mobile-nav{display:none;position:fixed;inset:0;z-index:600;background:#fff;overflow-y:auto;padding:0;}
#mobile-nav.open{display:flex;flex-direction:column;}
.mn-header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:64px;border-bottom:1px solid #eee;}
.mn-close{background:none;border:none;font-size:22px;cursor:pointer;color:#555;}
.mn-links{padding:24px 24px 48px;display:flex;flex-direction:column;gap:6px;}
.mn-link{display:block;padding:12px 0;font-size:14px;font-weight:700;color:#1a1a1a;border-bottom:1px solid #f5f5f5;letter-spacing:.04em;}
.mn-link:hover{color:#8B5E35;}

/* ─── HERO ─── */
#hero{height:520px;position:relative;overflow:hidden;background:#1a1a1a;display:grid;grid-template-columns:repeat(5,1fr);gap:0;}
.hero-slice{position:relative;overflow:hidden;cursor:pointer;display:block;}
.hero-slice:hover .hs-img{transform:scale(1.06);}
.hero-slice:hover .hs-overlay{background:rgba(0,0,0,.35);}
.hs-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;display:block;}
.hs-grain{position:absolute;inset:0;background:repeating-linear-gradient(170deg,transparent,transparent 12px,rgba(255,255,255,.03) 12px,rgba(255,255,255,.03) 13px);}
.hs-plank{position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 70px,rgba(0,0,0,.08) 70px,rgba(0,0,0,.08) 72px);}
.hs-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);transition:background .35s;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:32px;}
.hs-label-top{font-size:9px;font-weight:800;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:6px;}
.hs-label-bot{font-size:15px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:#fff;text-align:center;line-height:1.15;}
.hero-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;text-align:center;pointer-events:none;}
.hero-center-title{font-size:11px;font-weight:800;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:8px;}
.hero-center-h{font-size:42px;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.05;text-shadow:0 2px 24px rgba(0,0,0,.6);}
.hero-center-h em{color:#D4B87A;font-style:normal;}
.hero-center-sub{font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.06em;margin-top:8px;}
.hero-roomvo{position:absolute;bottom:0;left:0;right:0;z-index:4;background:rgba(0,0,0,.72);display:flex;align-items:center;justify-content:center;gap:16px;padding:12px;font-size:12px;font-weight:600;color:rgba(255,255,255,.75);letter-spacing:.04em;}
.hero-roomvo-btn{background:#fff;color:#1a1a1a;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:8px 20px;border:none;transition:background .2s;text-decoration:none;display:inline-block;}
.hero-roomvo-btn:hover{background:#D4B87A;}

/* ─── COLLECTION SHOWCASE ─── */
#collection-showcase{background:#1a1a1a;padding:0;overflow:hidden;display:grid;grid-template-columns:repeat(5,1fr);height:80px;}
.cs-item{display:flex;align-items:center;justify-content:center;flex-direction:column;border-right:1px solid rgba(255,255,255,.07);cursor:pointer;padding:14px 16px;transition:background .2s;text-decoration:none;}
.cs-item:last-child{border-right:none;}
.cs-item:hover{background:rgba(255,255,255,.05);}
.cs-top{font-size:8px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:4px;}
.cs-bot{font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.75);}

/* ─── ABOUT ─── */
#about{padding:80px 52px;max-width:1440px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.about-img-wrap{position:relative;}
.about-img{width:100%;height:420px;background:linear-gradient(135deg,#2C1810,#0e0a06);position:relative;overflow:hidden;}
.about-img-grain{position:absolute;inset:0;background:repeating-linear-gradient(170deg,transparent,transparent 13px,rgba(255,255,255,.03) 13px,rgba(255,255,255,.03) 14px);}
.about-img-plank{position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 80px,rgba(0,0,0,.08) 80px,rgba(0,0,0,.08) 82px);}
.about-img-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.6);padding:14px 20px;display:flex;align-items:center;gap:20px;}
.about-img-label-n{font-size:22px;font-weight:800;color:#D4B87A;line-height:1;}
.about-img-label-l{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55);}
.about-eyebrow{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#8B5E35;margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.about-eyebrow::before{content:'';display:block;width:22px;height:2px;background:#8B5E35;}
.about-h2{font-size:30px;font-weight:800;color:#1a1a1a;line-height:1.2;letter-spacing:-.01em;margin-bottom:18px;}
.about-body{font-size:13px;color:#666;line-height:1.9;margin-bottom:32px;}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid #eee;border-left:1px solid #eee;margin-bottom:32px;}
.about-stat{padding:20px 16px;border-right:1px solid #eee;border-bottom:1px solid #eee;text-align:center;}
.about-stat-n{font-size:20px;font-weight:800;color:#1a1a1a;letter-spacing:-.01em;line-height:1;}
.about-stat-n span{font-size:13px;font-weight:600;color:#8B5E35;}
.about-stat-l{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#aaa;margin-top:4px;}
.about-cta{display:inline-flex;align-items:center;gap:10px;background:#1a1a1a;color:#fff;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:13px 28px;border:none;transition:background .2s;text-decoration:none;}
.about-cta:hover{background:#8B5E35;}
.about-cta svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;}

/* ─── PRODUCT GROUPS ─── */
#product-groups{background:#f8f7f4;padding:72px 52px;border-top:1px solid #eee;}
#pg-inner{max-width:1440px;margin:0 auto;}
.pg-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;}
.pg-eyebrow{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#8B5E35;margin-bottom:10px;display:flex;align-items:center;gap:10px;}
.pg-eyebrow::before{content:'';display:block;width:22px;height:2px;background:#8B5E35;}
.pg-title{font-size:28px;font-weight:800;color:#1a1a1a;letter-spacing:-.01em;line-height:1.2;}
.pg-all{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#1a1a1a;display:flex;align-items:center;gap:6px;border-bottom:1px solid #1a1a1a;padding-bottom:2px;text-decoration:none;}
.pg-all:hover{color:#8B5E35;border-bottom-color:#8B5E35;}
.pg-all svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;}
.pg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.pg-card{position:relative;overflow:hidden;cursor:pointer;display:block;text-decoration:none;}
.pg-card:hover .pgc-img{transform:scale(1.04);}
.pg-card:hover .pgc-overlay{background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.2) 55%,transparent 100%);}
.pgc-img{width:100%;height:340px;object-fit:cover;transition:transform .5s ease;display:block;}
.pgc-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.1) 55%,transparent 100%);transition:background .4s;display:flex;flex-direction:column;justify-content:flex-end;padding:24px 22px;}
.pgc-name{font-size:18px;font-weight:800;color:#fff;letter-spacing:-.01em;}

/* ─── PROJECTS ─── */
#projects{padding:72px 52px;background:#fff;border-top:1px solid #eee;}
#proj-inner{max-width:1440px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:64px;}
.section-eyebrow{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#8B5E35;margin-bottom:10px;display:flex;align-items:center;gap:10px;}
.section-eyebrow::before{content:'';display:block;width:22px;height:2px;background:#8B5E35;}
.section-title{font-size:28px;font-weight:800;color:#1a1a1a;letter-spacing:-.01em;line-height:1.2;margin-bottom:32px;}
.proj-list{display:flex;flex-direction:column;gap:0;}
.proj-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .15s;text-decoration:none;color:inherit;}
.proj-item:hover .proj-item-name{color:#8B5E35;}
.proj-item:first-child{border-top:1px solid #f0f0f0;}
.proj-item-name{font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:4px;transition:color .15s;}
.proj-item-loc{font-size:11px;color:#aaa;}
.proj-item-right{display:flex;gap:6px;flex-shrink:0;margin-left:16px;}
.proj-thumb{width:52px;height:36px;overflow:hidden;flex-shrink:0;}
.proj-thumb-fill{width:100%;height:100%;position:relative;}
.proj-more-btn{margin-top:24px;display:inline-flex;align-items:center;gap:8px;background:#1a1a1a;color:#fff;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:12px 24px;border:none;transition:background .2s;text-decoration:none;}
.proj-more-btn:hover{background:#8B5E35;}
.proj-more-btn svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;}

/* ─── NEWSLETTER ─── */
#newsletter{background:#f8f7f4;padding:56px 52px;border-top:1px solid #eee;border-bottom:1px solid #eee;}
#nl-inner{max-width:680px;margin:0 auto;text-align:center;}
.nl-eyebrow{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#8B5E35;margin-bottom:10px;}
.nl-title{font-size:22px;font-weight:800;color:#1a1a1a;letter-spacing:-.01em;margin-bottom:8px;}
.nl-sub{font-size:13px;color:#888;margin-bottom:24px;}
.nl-form{display:flex;gap:0;max-width:480px;margin:0 auto;}
.nl-input{flex:1;border:1px solid #ddd;border-right:none;padding:12px 16px;font-size:13px;color:#333;outline:none;font-family:'Nunito Sans',sans-serif;transition:border-color .2s;}
.nl-input:focus{border-color:#1a1a1a;}
.nl-input::placeholder{color:#ccc;}
.nl-submit{background:#1a1a1a;color:#fff;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:12px 24px;border:none;transition:background .2s;white-space:nowrap;}
.nl-submit:hover{background:#8B5E35;}

/* ─── FOOTER ─── */
footer{background:#fff;padding:56px 52px 0;border-top:1px solid #eee;}
#footer-inner{max-width:1440px;margin:0 auto;}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid #eee;}
.ft-name{font-size:22px;font-weight:800;color:#1a1a1a;letter-spacing:-.02em;}
.ft-name em{color:#8B5E35;font-style:normal;}
.ft-tagline{font-size:9px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#ccc;margin-top:4px;}
.ft-contact{margin-top:20px;display:flex;flex-direction:column;gap:6px;}
.ft-contact a{font-size:12px;color:#666;display:flex;align-items:center;gap:7px;transition:color .2s;}
.ft-contact a:hover{color:#8B5E35;}
.ft-contact a svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;flex-shrink:0;}
.ft-social{display:flex;gap:8px;margin-top:18px;}
.ft-social a{width:34px;height:34px;border:1px solid #e8e8e8;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s;}
.ft-social a:hover{border-color:#1a1a1a;background:#1a1a1a;}
.ft-social a:hover svg{stroke:#fff;}
.ft-social a svg{width:14px;height:14px;stroke:#aaa;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.ft-col-title{font-size:10px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:#1a1a1a;margin-bottom:16px;}
.ft-links{display:flex;flex-direction:column;gap:9px;}
.ft-links a{font-size:12px;color:#777;transition:color .2s;}
.ft-links a:hover{color:#8B5E35;}
.footer-bottom{padding:18px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;}
.fb-legal{display:flex;gap:16px;flex-wrap:wrap;}
.fb-legal a{font-size:11px;color:#aaa;transition:color .2s;}
.fb-legal a:hover{color:#1a1a1a;}
.fb-copy{font-size:11px;color:#ccc;}

/* ─── UTILS ─── */
.vg{position:absolute;inset:0;background:repeating-linear-gradient(170deg,transparent,transparent 12px,rgba(255,255,255,.03) 12px,rgba(255,255,255,.03) 13px);}
.vgd{position:absolute;inset:0;background:repeating-linear-gradient(170deg,transparent,transparent 12px,rgba(0,0,0,.04) 12px,rgba(0,0,0,.04) 13px);}
.vp{position:absolute;inset:0;background:repeating-linear-gradient(90deg,transparent,transparent 70px,rgba(0,0,0,.07) 70px,rgba(0,0,0,.07) 72px);}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  #topbar{padding:0 24px;}
  #header-inner{padding:0 24px;}
  #about{padding:60px 24px;gap:40px;}
  #product-groups{padding:56px 24px;}
  #projects{padding:56px 24px;}
  #newsletter{padding:40px 24px;}
  footer{padding:40px 24px 0;}
}

@media(max-width:768px){
  #main-nav{display:none;}
  #hamburger{display:flex;}
  #hero{grid-template-columns:1fr;height:420px;}
  .hero-slice{display:none;}
  .hero-slice:first-child{display:block;height:420px;}
  #collection-showcase{grid-template-columns:repeat(3,1fr);height:auto;}
  .cs-item:nth-child(n+4){display:none;}
  #about{grid-template-columns:1fr;padding:40px 20px;gap:28px;}
  .about-img{height:260px;}
  .pg-grid{grid-template-columns:1fr;}
  .pgc-img{height:220px;}
  #proj-inner{grid-template-columns:1fr;gap:40px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px;}
  .nl-form{flex-direction:column;}
  .nl-input{border-right:1px solid #ddd;border-bottom:none;}
}

@media(max-width:480px){
  .footer-top{grid-template-columns:1fr;}
  .hero-center-h{font-size:28px;}
}

/* ─── Lightbox ─── */
.lightbox-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .25s;}
.lightbox-overlay.active{display:flex;opacity:1;}
.lightbox-img-wrap{position:relative;max-width:90vw;max-height:85vh;cursor:grab;overflow:hidden;}
.lightbox-img-wrap.dragging{cursor:grabbing;}
.lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;transition:transform .25s;transform-origin:center center;user-select:none;-webkit-user-drag:none;}
.lightbox-close{position:fixed;top:20px;right:20px;z-index:10001;width:44px;height:44px;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:24px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1;}
.lightbox-close:hover{background:rgba(255,255,255,.25);}
.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);z-index:10001;width:44px;height:44px;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:20px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.lightbox-nav:hover{background:rgba(255,255,255,.25);}
.lightbox-prev{left:16px;}
.lightbox-next{right:16px;}
.lightbox-counter{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:13px;font-weight:600;z-index:10001;}
.lightbox-zoom{position:fixed;bottom:20px;right:20px;z-index:10001;display:flex;gap:6px;}
.lightbox-zoom button{width:36px;height:36px;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:18px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1;}
.lightbox-zoom button:hover{background:rgba(255,255,255,.25);}
.img-zoom-trigger{position:absolute;top:8px;right:8px;width:32px;height:32px;background:rgba(0,0,0,.5);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:2;}
.img-zoom-trigger svg{width:16px;height:16px;}
*:hover>.img-zoom-trigger{opacity:1;}
