body{margin:0;font-family:Inter,Arial,sans-serif;background:linear-gradient(180deg,#f4f7f2,#eef3ec);color:#13212a}
:root{--dark:#13212a;--muted:#60707c;--accent-dark:#16813b}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto}
.gallery-page{padding:42px 0 80px}
.gallery-hero{padding:10px 0 22px;text-align:center}
.gallery-hero-badge{display:inline-flex;padding:10px 16px;border-radius:999px;background:rgba(33,163,72,.10);color:#16813b;font-weight:800;margin-bottom:16px}
.gallery-hero h1{margin:0 0 10px;font-size:clamp(2rem,4vw,3.4rem)}
.gallery-hero p{margin:0;color:#60707c;font-size:1.02rem}
.gallery-family{margin-top:28px;background:rgba(255,255,255,.78);border:1px solid rgba(19,33,42,.06);border-radius:30px;padding:24px;box-shadow:0 18px 48px rgba(0,0,0,.06)}
.family-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.family-head h2{margin:0;font-size:1.6rem}
.family-head span{padding:8px 12px;border-radius:999px;background:#edf6e8;color:#3f6b28;font-weight:800}
.gallery-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.gallery-tile{grid-column:span 4;position:relative;border:none;padding:0;background:#dfe7de;border-radius:24px;overflow:hidden;cursor:pointer;box-shadow:0 14px 34px rgba(0,0,0,.10);min-height:220px;transition:transform .25s ease, box-shadow .25s ease}
.gallery-tile.large{grid-column:span 6;grid-row:span 2;min-height:454px}
.gallery-tile.wide{grid-column:span 6}
.gallery-tile:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.14)}
.gallery-tile img{width:100%;height:100%;object-fit:cover;display:block}
.lightbox{position:fixed;inset:0;background:rgba(7,12,16,.84);display:flex;align-items:center;justify-content:center;padding:30px;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease;z-index:5000}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:min(1100px,92vw);max-height:86vh;border-radius:24px;box-shadow:0 24px 64px rgba(0,0,0,.35);background:#fff}
.lightbox-close{position:absolute;top:22px;right:22px;width:52px;height:52px;border:none;border-radius:50%;background:#fff;color:#13212a;font-size:2rem;cursor:pointer;box-shadow:0 12px 28px rgba(0,0,0,.22)}
.quote-fixed-btn{position:fixed;top:190px;right:20px;z-index:1200;background:#21a348;color:#fff;padding:14px 18px;border-radius:999px;font-weight:bold;box-shadow:0 10px 30px rgba(0,0,0,.10);text-decoration:none}
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:3000;background:rgba(14,26,36,.96);color:#fff;box-shadow:0 -10px 28px rgba(0,0,0,.18)}
.cookie-inner{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:16px 0}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn{border:none;border-radius:999px;padding:12px 16px;font-weight:700;cursor:pointer}
.cookie-btn.accept{background:#2fb24b;color:#fff}
.cookie-btn.refuse{background:#fff;color:#0e1a24}
@media(max-width:980px){.gallery-tile,.gallery-tile.large,.gallery-tile.wide{grid-column:span 6}.gallery-tile.large{min-height:360px}}
@media(max-width:700px){.gallery-page{padding-top:24px}.gallery-family{padding:18px}.gallery-grid{grid-template-columns:1fr}.gallery-tile,.gallery-tile.large,.gallery-tile.wide{grid-column:auto;min-height:250px}.gallery-tile.large{grid-row:auto}.cookie-inner{flex-direction:column;align-items:flex-start}.quote-fixed-btn{top:auto;bottom:95px}}
.top-strip{background:#0e1a24;color:rgba(255,255,255,.85);font-size:.90rem;padding:8px 0;position:sticky;top:0;z-index:2200}
.top-strip-content{display:flex;justify-content:space-between;align-items:center;gap:20px}
.top-right{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.top-right a{color:rgba(255,255,255,.88)}
.option-wheel{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.22);font-size:1rem}
.menu-system{position:fixed;top:80px;right:20px;z-index:2100;width:98px;height:98px}
.menu-bubble-btn{
  position:absolute;top:0;right:0;width:98px;height:98px;border-radius:50%;
  border-top-right-radius:0;border-bottom-right-radius:0;border:none;cursor:pointer;
  background:linear-gradient(135deg,rgba(10,99,47,.95),rgba(22,144,71,.92));
  color:#fff;box-shadow:-8px 18px 38px rgba(0,0,0,.22);backdrop-filter:blur(10px);
  transition:transform .25s ease,background .25s ease;font-weight:bold;font-size:1rem
}
.menu-panel{
  position:absolute;right:88px;top:10px;display:flex;align-items:center;gap:12px;padding:12px;
  border-radius:999px;background:rgba(14,26,36,.40);border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(14px);box-shadow:0 14px 40px rgba(0,0,0,.18);
  transform:translateX(120%);opacity:0;visibility:hidden;
  transition:transform .35s ease,opacity .30s ease,visibility .30s ease;
  overflow-x:auto;max-width:min(78vw,900px);scrollbar-width:thin
}
.menu-system.open .menu-panel,.menu-system:hover .menu-panel{transform:translateX(0);opacity:1;visibility:visible}
.menu-pill{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;min-height:48px;padding:10px 22px;border-radius:999px;color:#fff;font-weight:600;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.28)}
.quote-fixed-btn{position:fixed;top:190px;right:20px;z-index:1200;background:#21a348;color:#fff;padding:14px 18px;border-radius:999px;font-weight:bold;box-shadow:0 10px 30px rgba(0,0,0,.10)}
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:3000;background:rgba(14,26,36,.96);color:#fff;box-shadow:0 -10px 28px rgba(0,0,0,.18)}
.cookie-inner{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:16px 0}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn{border:none;border-radius:999px;padding:12px 16px;font-weight:700;cursor:pointer}
.cookie-btn.accept{background:#2fb24b;color:#fff}
.cookie-btn.refuse{background:#fff;color:#0e1a24}
@media(max-width:800px){.top-strip-content,.cookie-inner{flex-direction:column;align-items:flex-start}.menu-system{top:150px}}

/* V3.2 menu position fix */
.menu-system{overflow:visible}
.menu-bubble-btn{display:flex;align-items:center;justify-content:center}
@media(max-width:768px){
  .menu-system{top:150px !important;right:20px !important;width:74px !important;height:74px !important}
  .menu-bubble-btn{width:74px !important;height:74px !important;font-size:.92rem !important}
  .menu-panel{right:64px !important;top:0 !important;max-width:calc(100vw - 120px) !important}
}


/* V4 lateral drawer redesign */
.menu-system{
  position:fixed !important;
  top:110px !important;
  right:0 !important;
  width:auto !important;
  height:auto !important;
  z-index:2200;
  display:flex;
  align-items:flex-start;
  gap:0 !important;
  overflow:visible;
}
.menu-edge-line{
  position:absolute;
  top:0;
  right:0;
  width:4px;
  height:100%;
  min-height:86px;
  background:linear-gradient(180deg,#dff56f,#6ea928);
  border-radius:999px 0 0 999px;
  box-shadow:0 0 18px rgba(164,255,118,.35);
}
.menu-bubble-btn{
  position:relative;
  right:0;
  margin-right:0;
  min-width:92px !important;
  width:92px !important;
  min-height:96px !important;
  height:96px !important;
  border-radius:26px 0 0 26px !important;
  background:linear-gradient(180deg,#1b2c38,#0f1921) !important;
  padding:14px 10px !important;
  display:flex !important;
  flex-direction:column;
  gap:8px;
  box-shadow:-14px 18px 42px rgba(0,0,0,.28) !important;
}
.menu-bubble-circle{
  width:36px;
  height:36px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#dff56f;
  color:#12202a;
  font-size:1rem;
  margin:0 auto;
  box-shadow:0 0 0 4px rgba(223,245,111,.16);
  animation:menuHint 1.8s ease-in-out infinite;
}
.menu-bubble-text{font-size:.84rem;font-weight:800;letter-spacing:.02em;line-height:1.1}
.menu-panel{
  width:min(760px,calc(100vw - 88px)) !important;
  max-width:min(760px,calc(100vw - 88px)) !important;
  margin-right:0 !important;
  border-radius:28px 0 0 28px !important;
  padding:22px 20px 18px !important;
  gap:14px !important;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(18,32,42,.08);
  box-shadow:-18px 24px 54px rgba(0,0,0,.18);
  transform:translateX(calc(100% + 12px));
}
.menu-system.open .menu-panel{transform:translateX(0)}
.menu-system.open .menu-bubble-circle{transform:rotate(180deg)}
.menu-brand-card{
  display:flex;
  gap:12px;
  align-items:center;
  text-decoration:none;
  color:var(--dark);
  background:linear-gradient(135deg,#f7fbef,#ffffff);
  border:1px solid #e4ead8;
  border-radius:22px;
  padding:12px 14px;
}
.menu-brand-logo{
  width:54px;
  height:54px;
  object-fit:contain;
  border-radius:16px;
  background:#fff;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}
.menu-brand-card strong{display:block;font-size:1rem}
.menu-brand-card small{color:var(--muted)}
.menu-card-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.menu-card-link,.menu-mini-btn,.menu-contact-btn,.menu-quote-cta,.lang-pill{
  text-decoration:none;
}
.menu-card-link{
  background:#f6f8fb;
  color:var(--dark);
  padding:12px 14px;
  border-radius:16px;
  font-weight:700;
  border:1px solid #e6ecf2;
  text-align:center;
}
.menu-info-group{
  background:#f8fafc;
  border:1px solid #ebf0f5;
  border-radius:18px;
  padding:14px;
}
.menu-group-title{font-size:.94rem;font-weight:800;color:var(--dark);margin-bottom:10px}
.menu-group-subtitle{font-size:.78rem;color:var(--muted);margin:10px 0 8px}
.menu-language-row{display:flex;flex-wrap:wrap;gap:8px}
.lang-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  padding:9px 12px;
  border-radius:999px;
  background:#fff;
  color:var(--dark);
  border:1px solid #dfe6ed;
  font-weight:800;
}
.lang-pill.active{background:var(--accent-dark);color:#fff;border-color:var(--accent-dark)}
.menu-anchor-list{display:flex;flex-wrap:wrap;gap:10px}
.menu-pill{margin:0 !important}
.menu-quote-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  border-radius:18px;
  background:linear-gradient(135deg,#dff56f,#8cc63e);
  color:#14202a;
  font-size:1.05rem;
  font-weight:900;
  letter-spacing:.02em;
  box-shadow:0 14px 30px rgba(140,198,62,.28);
}
.menu-domain-line{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  font-size:.92rem;
}
.menu-domain-line a{color:var(--dark);text-decoration:none;font-weight:700}
.menu-domain-line span{color:#9aa8b5}
.menu-contact-stack{display:grid;gap:10px}
.menu-contact-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  border-radius:16px;
  background:#14202a;
  color:#fff;
  font-weight:800;
}
.menu-form-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.menu-mini-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  border-radius:14px;
  background:#eef3f8;
  color:var(--dark);
  padding:10px;
  font-weight:700;
  text-align:center;
}
.menu-social-row{display:flex;gap:10px;justify-content:center}
.menu-social-row a{
  width:42px;
  height:42px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#14202a;
  color:#fff;
  text-decoration:none;
  font-weight:800;
}
@keyframes menuHint{
  0%,100%{transform:translateX(0)}
  50%{transform:translateX(-6px)}
}
@media (max-width:980px){
  .menu-system{top:90px !important}
  .menu-panel{width:min(680px,calc(100vw - 78px)) !important;max-width:min(680px,calc(100vw - 78px)) !important}
}
@media (max-width:768px){
  .menu-system{top:132px !important}
  .menu-bubble-btn{width:78px !important;min-width:78px !important;height:86px !important;min-height:86px !important;border-radius:22px 0 0 22px !important}
  .menu-panel{width:calc(100vw - 72px) !important;max-width:calc(100vw - 72px) !important;padding:18px 14px !important}
  .menu-card-grid,.menu-form-links{grid-template-columns:1fr}
  .menu-bubble-text{font-size:.75rem}
}


/* V4.1 vertical stack cleanup */
.menu-panel{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:flex-start !important;
}
.menu-brand-card,
.menu-info-group,
.menu-contact-stack,
.menu-quote-cta,
.menu-social-row,
.menu-anchor-list,
.menu-card-grid,
.menu-form-links{
  width:100%;
}
.menu-card-grid{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}
.menu-anchor-list{
  display:flex !important;
  flex-direction:column !important;
  flex-wrap:nowrap !important;
  align-items:stretch !important;
  gap:10px !important;
}
.menu-pill{
  width:100%;
  justify-content:flex-start !important;
  text-align:left !important;
  padding:14px 16px !important;
  border-radius:16px !important;
}
.menu-domain-line{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  gap:10px !important;
}
.menu-domain-line span{
  display:none !important;
}
.menu-domain-line a{
  width:100%;
  display:block;
  padding:10px 12px;
  background:#fff;
  border:1px solid #e6ecf2;
  border-radius:14px;
}
.menu-contact-stack{
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
}
.menu-form-links{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}
.menu-social-row{
  justify-content:flex-start !important;
  flex-wrap:wrap;
}
@media (max-width:768px){
  .menu-panel{gap:12px !important;}
}


/* V5 fixed full-height sidebar */
.top-strip{display:none !important}
.menu-system{
  position:fixed !important;
  top:0 !important;
  right:0 !important;
  bottom:0 !important;
  height:100vh !important;
  display:flex !important;
  align-items:stretch !important;
  gap:0 !important;
  z-index:2600 !important;
}
.menu-edge-line{display:none !important}
.menu-bubble-btn{
  align-self:center !important;
  margin-right:0 !important;
  border-radius:22px 0 0 22px !important;
}
.menu-panel-fixed{
  position:relative !important;
  right:0 !important;
  top:0 !important;
  height:100vh !important;
  width:760px !important;
  max-width:min(760px,calc(100vw - 76px)) !important;
  margin-right:0 !important;
  border-radius:0 !important;
  padding:26px 18px !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:flex-start !important;
  gap:16px !important;
  overflow-y:auto !important;
  box-shadow:-18px 0 38px rgba(0,0,0,.22) !important;
}
.menu-system:not(.open) .menu-panel-fixed{
  transform:translateX(100%) !important;
  opacity:1 !important;
  pointer-events:none !important;
}
.menu-system.open .menu-panel-fixed{
  transform:translateX(0) !important;
  pointer-events:auto !important;
}
.menu-section-block,.menu-brand-card,.menu-contact-stack{width:100% !important}
.menu-brand-external{min-height:92px !important}
.menu-brand-logo-only{display:flex !important;align-items:center !important;justify-content:center !important;padding:16px 14px !important}
.menu-brand-logo-only .menu-brand-logo{max-width:100% !important;height:auto !important;display:block !important;margin:0 auto !important}
.menu-language-row,.menu-language-row.compact{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
}
.menu-form-links{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}
.menu-social-column{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  gap:10px !important;
}
.menu-social-column a{
  width:100% !important;
  height:auto !important;
  border-radius:14px !important;
  padding:12px 14px !important;
  justify-content:flex-start !important;
}
@media (max-width:980px){
  .menu-system{top:0 !important;height:100vh !important}
  .menu-panel-fixed{width:min(760px,calc(100vw - 76px)) !important;max-width:min(760px,calc(100vw - 76px)) !important}
}
@media (max-width:768px){
  .menu-system{top:0 !important;right:0 !important;height:100vh !important}
  .menu-bubble-btn{width:76px !important;min-width:76px !important;height:86px !important;min-height:86px !important}
  .menu-panel-fixed{width:calc(100vw - 76px) !important;max-width:calc(100vw - 76px) !important;padding:20px 14px !important}
}

/* V5.1 bubble + menu + social icons */
.menu-bubble-btn{
  position:absolute !important;
  right:0 !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  width:92px !important;
  min-width:92px !important;
  height:108px !important;
  min-height:108px !important;
  padding:12px 8px !important;
}
.menu-bubble-text{
  font-size:.72rem !important;
  text-align:center !important;
}
.menu-panel-fixed{padding-top:22px !important}
.menu-anchor-list{display:flex !important;flex-direction:column !important;gap:10px !important}
.menu-anchor-list .menu-pill{display:flex !important;align-items:center !important;justify-content:flex-start !important}
.menu-contact-form-btn{background:#f1f5f9 !important;border:1px solid #dbe4ee}
.menu-social-icons{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:12px !important;
}
.menu-social-icons a{
  width:48px !important;
  height:48px !important;
  min-width:48px !important;
  border-radius:50% !important;
  padding:0 !important;
  justify-content:center !important;
  font-size:1rem !important;
  font-weight:900 !important;
}
.menu-social-icons a span{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.menu-social-icons a{min-width:56px;padding:0 8px;border-radius:999px}
.menu-social-icons a span{font-size:12px;font-weight:800;line-height:1;text-transform:none}
@media (max-width:768px){
  .menu-bubble-btn{width:76px !important;min-width:76px !important;height:96px !important;min-height:96px !important}
  .menu-bubble-text{font-size:.64rem !important}
}


/* V3.7 adjustments */
.menu-system{width:92px !important;overflow:visible;}
.menu-bubble-btn{z-index:3;}
.menu-panel{pointer-events:none;}
.menu-system.open .menu-panel{pointer-events:auto;}
.menu-contact-stack .menu-group-title{margin-bottom:12px;}
.menu-contact-stack .menu-mini-btn,.menu-contact-stack .menu-form-links,.menu-group-subtitle,.menu-language-row.compact{display:none !important;}
.menu-bubble-text{font-size:.78rem;line-height:1.05;}
.menu-social-row a span{display:flex;align-items:center;justify-content:center;width:100%;height:100%;}


.gallery-rich-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.gallery-card{position:relative;display:block;text-decoration:none;color:inherit;overflow:hidden;border-radius:22px;box-shadow:0 14px 34px rgba(0,0,0,.10);background:#fff;}
.gallery-card img{display:block;width:100%;height:320px;object-fit:cover;transition:transform .35s ease;}
.gallery-card:hover img{transform:scale(1.03);}
.gallery-watermark{position:absolute;top:12px;left:12px;z-index:2;display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);box-shadow:0 8px 20px rgba(0,0,0,.12);font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;}
.gallery-watermark img{width:24px !important;height:24px !important;object-fit:contain;border-radius:50%;background:#fff;box-shadow:none;}
.gallery-card-caption{position:absolute;left:14px;right:14px;bottom:14px;z-index:2;display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:999px;background:linear-gradient(180deg,rgba(14,26,36,.18),rgba(14,26,36,.82));color:#fff;font-weight:800;letter-spacing:.03em;text-transform:lowercase;}
.gallery-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 42%,rgba(0,0,0,.32) 100%);pointer-events:none;}
@media(max-width:800px){.gallery-card img{height:260px}.gallery-watermark strong{font-size:.68rem}}


/* V4.2 extra wide panel */
.menu-panel-fixed{width:760px !important;max-width:min(760px,calc(100vw - 76px)) !important;}
@media (max-width:980px){.menu-panel-fixed{width:min(760px,calc(100vw - 76px)) !important;max-width:min(760px,calc(100vw - 76px)) !important;}}
@media (max-width:768px){.menu-panel-fixed{width:calc(100vw - 76px) !important;max-width:calc(100vw - 76px) !important;}}


/* V4.3 reduce sidebar opening by half */
:root{
  --menu-bubble-width: 92px;
  --menu-panel-width: min(480px, calc(100vw - 96px));
}
.menu-system{
  width:var(--menu-bubble-width) !important;
}
.menu-system.open{
  width:calc(var(--menu-bubble-width) + var(--menu-panel-width)) !important;
}
.menu-panel-fixed,
.menu-panel{
  width:var(--menu-panel-width) !important;
  max-width:var(--menu-panel-width) !important;
}
@media (max-width:980px){
  :root{--menu-bubble-width:84px;--menu-panel-width:min(420px, calc(100vw - 88px));}
}
@media (max-width:768px){
  :root{--menu-bubble-width:76px;--menu-panel-width:calc(100vw - 80px);}
}


.gallery-eyebrow{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;background:rgba(33,163,72,.10);color:#16813b;font-weight:800;margin-bottom:16px}.elegant-gallery-grid .gallery-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 50%, rgba(0,0,0,.18) 100%);opacity:0;transition:opacity .25s ease}.elegant-gallery-grid .gallery-tile:hover::after{opacity:1}
