﻿:root{
  --bg:#050607;
  --surface:rgba(12,16,19,0.88);
  --surface-strong:rgba(15,20,26,0.98);
  --surface-soft:rgba(255,255,255,0.05);
  --border:rgba(255,255,255,0.12);
  --accent:#d8b86e;
  --accent-soft:#8d7b52;
  --text:#f5f3ee;
  --muted:#a9a29f;
  --shadow:0 34px 90px rgba(0,0,0,0.42);
  --radius:28px;
  --transition:0.28s ease;
}
*{
  box-sizing:border-box;
}
html{
  scroll-behavior:smooth;
}

.skip-link{
  position:absolute;
  left:0;
  top:0;
  transform:translateY(-100%);
  background:rgba(5,6,7,0.98);
  color:var(--text);
  padding:14px 18px;
  border-radius:0 0 0 14px;
  z-index:100;
  text-decoration:none;
  font-weight:700;
  transition:transform 180ms var(--ease), opacity 180ms var(--ease);
}
.skip-link:focus-visible{
  transform:translateY(0);
  opacity:1;
  outline:3px solid rgba(216,184,110,0.85);
  outline-offset:4px;
}

:root{
  --transition-fast:0.16s ease;
  --ease: cubic-bezier(.2,.8,.2,1);
  --card-shadow: 0 20px 60px rgba(0,0,0,0.22);
  --glass: rgba(255,255,255,0.04);
}

/* Animations & modern transitions */
@keyframes fadeUp {
  from{opacity:0; transform:translateY(10px);} 
  to{opacity:1; transform:translateY(0);} 
}

@keyframes pop {
  from{opacity:0; transform:scale(.98);} to{opacity:1; transform:scale(1);} 
}

/* Apply subtle entrance animation to major blocks */
.hero-content,
.page-hero,
.features,
.premium-band-inner,
.card,
.photo-card,
.service-highlight-card{
  animation: fadeUp 720ms var(--ease) both;
}

/* Image & card hover */
.photo-card{position:relative; overflow:hidden; border-radius:24px; transition:transform var(--transition-fast), box-shadow var(--transition-fast);}
.photo-card img{transition:transform 600ms var(--ease), filter 360ms var(--ease); will-change:transform;}
.photo-card:hover img{transform:scale(1.06); filter:brightness(.96);}
.photo-card::after{content:'';position:absolute;inset:0;border-radius:24px;background:linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.36));opacity:0;transition:opacity 260ms var(--ease);}
.photo-card:hover::after{opacity:1;}

/* Buttons and CTAs */
.cta, .btn, button{transition:transform var(--transition-fast), box-shadow var(--transition-fast), filter var(--transition-fast);}
.cta:hover, .btn:hover, button:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 18px 48px rgba(0,0,0,0.28);}

/* Mobile panel show/hide with smooth transform */
.mobile-panel{transition:transform 360ms var(--ease), opacity 260ms var(--ease);transform:translateY(-6px);opacity:0;}
.menu-open .mobile-panel{transform:translateY(0);opacity:1;}

/* Hamburger -> X */
.mobile-menu-button span{transition:transform 280ms var(--ease), opacity 180ms var(--ease);display:block;}
.menu-open .mobile-menu-button span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-open .mobile-menu-button span:nth-child(2){opacity:0;transform:scaleX(0);}
.menu-open .mobile-menu-button span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Navigation link subtle transition */
.nav a{transition:color 220ms var(--ease);}

/* Grid responsiveness improvements */
.grid{grid-auto-rows:1fr;}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important;}
}
body{
  margin:0;
  min-height:100vh;
  width:100%;
  overflow-x:hidden;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:radial-gradient(circle at top left, rgba(216,184,110,0.14), transparent 28%),
    radial-gradient(circle at bottom right, rgba(120,104,72,0.14), transparent 22%),
    linear-gradient(180deg, #050607 0%, #080b0f 100%);
}
main{
  width:100%;
  max-width:100%;
}
a{
  color:inherit;
  text-decoration:none;
  transition:color var(--transition), transform var(--transition), opacity var(--transition);
}
a:hover{
  color:var(--accent);
}
a, .btn, .cta, button, .nav a, .feature, .card, .premium-metric, .mobile-menu-button {
  transition:color var(--transition), background var(--transition), transform var(--transition), box-shadow var(--transition), border-color var(--transition), opacity var(--transition);
}
a:focus-visible,
.btn:focus-visible,
.cta:focus-visible,
button:focus-visible,
.nav a:focus-visible,
.mobile-menu-button:focus-visible {
  outline:3px solid rgba(216,184,110,0.9);
  outline-offset:4px;
}
img{max-width:100%;display:block;}
button, .btn, .cta{
  font:inherit;
  cursor:pointer;
}
.topbar{
  position:sticky;
  top:0;
  z-index:99;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  min-height:88px;
  padding:0 5vw;
  background:rgba(6,9,12,0.72);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px);
}
.logo{
  display:flex;
  align-items:center;
  gap:10px;
}
.logo span{
  font-weight:800;
  letter-spacing:.16em;
}
.nav{
  display:flex;
  flex:1 1 auto;
  justify-content:center;
  min-width:0;
  gap:clamp(14px,1.8vw,28px);
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.18em;
}
.nav a{
  position:relative;
  color:var(--muted);
  transition:color var(--transition);
}
.nav a:hover,
.nav a.active{
  color:var(--accent);
}
.nav a::after{
  content:'';
  position:absolute;
  left:0;
  bottom:-6px;
  width:0;
  height:2px;
  background:var(--accent);
  transition:width var(--transition);
}
.nav a:hover::after,
.nav a.active::after{
  width:100%;
}
.header-actions{
  display:flex;
  align-items:center;
  flex:0 1 auto;
  gap:12px;
  min-width:0;
}
.call{
  color:var(--text);
  font-weight:700;
  white-space:nowrap;
}
.cta, .btn, button{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 26px;
  border-radius:999px;
  border:1px solid transparent;
  background:linear-gradient(135deg, rgba(216,184,110,0.95), rgba(148,122,72,0.92));
  color:#06100c;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  transition:transform var(--transition), box-shadow var(--transition), filter var(--transition);
  white-space:nowrap;
}
.cta:hover, .btn:hover, button:hover{
  transform:translateY(-2px);
  filter:brightness(1.05);
}
.nav a:hover,
.nav a:focus-visible{
  color:var(--accent);
  transform:translateY(-1px);
}
.feature,
.card,
.premium-metric{
  will-change:transform, box-shadow;
}
.feature:hover,
.card:hover,
.premium-metric:hover{
  transform:translateY(-4px);
  box-shadow:0 36px 100px rgba(0,0,0,0.28);
}
.premium-metric:hover{
  background:rgba(255,255,255,0.08);
}
.card:hover .icon,
.feature:hover .feature-icon{
  transform:translateY(-2px) scale(1.03);
}
.cta:focus-visible, .btn:focus-visible, button:focus-visible, .nav a:focus-visible, .mobile-panel a:focus-visible, .mobile-menu-button:focus-visible{
  outline:3px solid rgba(216,184,110,0.9);
  outline-offset:4px;
}
.btn.outline{
  background:transparent;
  color:var(--text);
  border-color:rgba(255,255,255,0.16);
}
.hero{
  position:relative;
  min-height:90vh;
  display:grid;
  align-items:center;
  padding:0 5vw;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:url('assets/images/Lysa_nad_Labem_foto/lysa_nad_labem_01.webp') center/cover no-repeat;
  opacity:0.62;
  filter:saturate(0.96) contrast(0.9);
}
.hero::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(5,6,7,0.88) 0%, rgba(5,6,7,0.54) 44%, rgba(5,6,7,0.18) 100%),
    linear-gradient(180deg, rgba(5,6,7,0.08), rgba(5,6,7,0.92));
}
.hero-content{
  position:relative;
  z-index:1;
  width:100%;
  max-width:1180px;
  margin:0 auto;
  padding:120px 0;
}
.hero h1{
  margin:0;
  font-size:clamp(48px,8vw,96px);
  line-height:0.95;
  letter-spacing:-0.06em;
  text-transform:uppercase;
  font-weight:800;
}
.hero p{
  margin:28px 0 0;
  max-width:720px;
  font-size:20px;
  line-height:1.85;
  color:rgba(245,243,238,0.88);
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  margin-top:36px;
}
.features{
  display:grid;
  grid-template-columns:repeat(4, minmax(180px, 1fr));
  gap:18px;
  margin:0 auto;
  width:min(94vw, 1320px);
  padding:28px;
  border:1px solid var(--border);
  border-radius:32px;
  background:rgba(10,14,19,0.72);
  backdrop-filter:blur(24px);
  box-shadow:var(--shadow);
  margin-top:-48px;
  position:relative;
  z-index:2;
}
.feature{
  display:flex;
  gap:18px;
  align-items:flex-start;
  padding:18px 0;
  border-right:1px solid rgba(255,255,255,0.08);
}
.feature:last-child{border-right:0;}
.feature-icon{
  width:56px;
  height:56px;
  min-width:56px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:rgba(216,184,110,0.14);
  color:var(--accent);
  font-size:24px;
}
.feature strong{
  display:block;
  font-size:1rem;
  font-weight:700;
  margin-bottom:6px;
}
.feature span{
  color:var(--muted);
  font-size:.92rem;
  line-height:1.8;
}
.section{
  padding:100px 5vw;
  background:linear-gradient(180deg, rgba(5,7,11,0.96), rgba(12,16,22,0.99));
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.section.light{
  background:rgba(255,255,255,0.03);
  color:rgba(245,243,238,0.92);
}
.section.muted{
  background:rgba(255,255,255,0.02);
}
.section h2{
  margin:0 0 18px;
  font-size:clamp(2.6rem,5vw,4rem);
  line-height:1.04;
  letter-spacing:-0.04em;
  color:#fff;
}
.section p,
.section li{
  color:rgba(245,243,238,0.78);
}
.page-hero{
  position:relative;
  display:grid;
  place-items:center;
  min-height:65vh;
  padding:100px 5vw;
  text-align:center;
  background:linear-gradient(180deg, rgba(12,16,22,0.92), rgba(6,9,13,0.95));
  border:1px solid rgba(255,255,255,0.08);
  border-radius:36px;
  box-shadow:0 38px 120px rgba(0,0,0,0.32);
  overflow:hidden;
}
.page-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:url('assets/images/Jasenice_foto/jasenice_01.jpg') center/cover no-repeat;
  opacity:0.5;
  filter:saturate(0.9) contrast(0.92);
  pointer-events:none;
}
.page-hero::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(5,7,10,0.36), rgba(5,7,10,0.88)),
    radial-gradient(circle at top left, rgba(216,184,110,0.14), transparent 28%);
  pointer-events:none;
}
.page-hero > *{
  position:relative;
  z-index:1;
}
.page-hero h1{
  margin:0;
  font-size:clamp(40px,6vw,72px);
  line-height:1.02;
  letter-spacing:-0.04em;
  color:#fff;
  z-index:1;
}
.page-hero p{
  margin:24px auto 0;
  max-width:760px;
  color:rgba(245,243,238,0.8);
  font-size:1.05rem;
  line-height:1.95;
  z-index:1;
}
.page-hero.house-hero-alt::before{background-image:url('assets/images/praha-moderni-dum/praha-dum-1.webp');}
.page-hero.house-hero-local::before{background-image:url('assets/images/praha-moderni-dum/praha-dum-2.webp');}
.request-hero,
.contact-premium{
  position:relative;
  padding:92px 5vw;
  border-radius:32px;
  border:1px solid rgba(255,255,255,0.08);
  background:linear-gradient(180deg, rgba(12,16,22,0.95), rgba(7,11,16,0.95));
  box-shadow:0 35px 110px rgba(0,0,0,0.30);
}
.request-hero{
  min-height:52vh;
  display:grid;
  place-items:center;
  text-align:center;
  overflow:hidden;
}
.request-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:url('assets/images/praha-moderni-dum/praha-dum-1.webp') center/cover no-repeat;
  opacity:0.52;
  filter:saturate(0.92) contrast(0.9);
}
.request-hero::after{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(5,7,10,0.28), rgba(5,7,10,0.9)),
    radial-gradient(circle at top left, rgba(216,184,110,0.14), transparent 30%);
}
.request-hero > *{
  position:relative;
  z-index:1;
}
.request-hero h1,
.contact-premium h2{
  margin:0;
  color:#fff;
  font-size:clamp(2.8rem,6vw,4.4rem);
  line-height:1.02;
}
.request-hero p,
.contact-premium p{
  margin:24px auto 0;
  max-width:760px;
  color:rgba(245,243,238,0.78);
  font-size:1rem;
  line-height:1.9;
}
.request-form-section{
  padding:80px 5vw 100px;
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:32px;
  box-shadow:0 30px 90px rgba(0,0,0,0.22);
}
.ultra-location-seo,
.ultra-seo-content{
  background:rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:32px;
  box-shadow:0 28px 90px rgba(0,0,0,0.20);
  padding:56px 5vw;
}
.ultra-location-seo strong,
.ultra-location-seo b,
.ultra-seo-content strong,
.ultra-seo-content b{
  color:var(--accent);
}
.ultra-seo-content h2{
  margin-top:0;
  color:#fff;
}
.ultra-seo-content p,
.ultra-location-seo p,
.ultra-seo-content li,
.ultra-location-seo li{
  color:rgba(245,243,238,0.78);
  line-height:1.9;
}
.ultra-location-seo ul{
  margin-top:18px;
  padding-left:1.35rem;
}
.premium-band{
  padding:40px 5vw;
}
.premium-band-inner{
  display:grid;
  grid-template-columns:repeat(4, minmax(180px, 1fr));
  gap:24px;
  align-items:center;
  max-width:1320px;
  margin:0 auto;
}
.premium-metric{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:28px;
  border-radius:28px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
}
.premium-metric strong{
  font-size:2rem;
  line-height:1;
  font-weight:800;
}
.premium-metric span{
  color:var(--muted);
  line-height:1.7;
}
.trust-section{
  background:linear-gradient(180deg, rgba(245,243,238,0.98), rgba(235,231,220,0.96));
}
.trust-section h2{
  max-width:900px;
}
.trust-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(180px,1fr));
  gap:18px;
  margin-top:34px;
}
.trust-item{
  padding:24px;
  border:1px solid rgba(6,16,12,0.1);
  border-radius:18px;
  background:rgba(255,255,255,0.56);
}
.trust-item strong{
  display:block;
  color:#06100c;
  font-size:1.05rem;
  margin-bottom:10px;
}
.trust-item span{
  color:#55605b;
  line-height:1.7;
}
.filter-pills{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:32px 0 18px;
}
.filter-pills span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:999px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  color:var(--text);
  cursor:pointer;
  transition:transform var(--transition), background var(--transition), border-color var(--transition);
}
.filter-pills span:hover{
  background:rgba(216,184,110,0.14);
}
.gallery-section{
  margin-top:28px;
  background:rgba(7,10,13,0.95);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:36px;
  padding:56px 48px;
  box-shadow:0 40px 110px rgba(0,0,0,0.32);
}
.gallery-section .section-label{
  color:var(--accent);
}
.gallery-section h2{
  margin-top:0;
  font-size:clamp(2.4rem,4vw,3.6rem);
  line-height:1.02;
}
.gallery-section .lead{
  margin-top:18px;
  color:rgba(245,243,238,0.76);
  max-width:760px;
}
.photo-gallery{
  display:grid;
  grid-template-columns:repeat(3, minmax(260px, 1fr));
  gap:28px;
  margin-top:42px;
}
.photo-card{
  display:block;
  border-radius:30px;
  overflow:hidden;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.12);
  box-shadow:0 28px 90px rgba(0,0,0,0.28);
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.photo-card:hover{
  transform:translateY(-8px);
  box-shadow:0 40px 120px rgba(0,0,0,0.36);
  border-color:rgba(216,184,110,0.3);
}
.photo-card img{
  width:100%;
  height:320px;
  object-fit:cover;
}
.gallery-section .photo-card-body{
  padding:28px;
  background:rgba(5,7,10,0.96);
}
.gallery-section .photo-card-body h3{
  margin:0 0 12px;
  color:#fff;
  font-size:1.18rem;
}
.gallery-section .photo-card-body p{
  margin:0;
  color:rgba(245,243,238,0.72);
  line-height:1.85;
}
.architecture-showcase{
  background:linear-gradient(180deg, rgba(8,10,13,0.98) 0%, rgba(5,7,10,0.98) 100%);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:40px;
  padding:72px 5vw;
  box-shadow:0 44px 130px rgba(0,0,0,0.32);
  margin-top:42px;
}
.architecture-grid{
  display:grid;
  grid-template-columns:1fr minmax(360px, 1.2fr);
  gap:40px;
  align-items:center;
  max-width:1320px;
  margin:0 auto;
}
.showcase-panel h2{
  margin:24px 0 18px;
  font-size:clamp(3rem,4vw,4.6rem);
  line-height:1;
  letter-spacing:-0.05em;
}
.showcase-panel .lead{
  max-width:680px;
  color:rgba(245,243,238,0.74);
  margin-top:18px;
}
.showcase-meta{
  display:grid;
  gap:18px;
  margin-top:42px;
}
.showcase-meta div{
  padding:24px 26px;
  border-radius:28px;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
}
.showcase-meta strong{
  display:block;
  font-size:1.05rem;
  color:#fff;
  margin-bottom:8px;
}
.showcase-meta p{
  margin:0;
  color:rgba(245,243,238,0.74);
  line-height:1.8;
}
.showcase-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:24px;
}
.showcase-card{
  position:relative;
  min-height:440px;
  border-radius:32px;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  box-shadow:0 38px 110px rgba(0,0,0,0.30);
  border:1px solid rgba(255,255,255,0.1);
  transition:transform var(--transition), box-shadow var(--transition), filter var(--transition);
}
.showcase-card:hover{
  transform:translateY(-8px);
  box-shadow:0 46px 120px rgba(0,0,0,0.36);
}
.showcase-overlay{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:34px;
  background:linear-gradient(180deg, rgba(0,0,0,0) 38%, rgba(0,0,0,0.72) 100%);
}
.showcase-overlay h3{
  margin:0 0 10px;
  color:#fff;
  font-size:1.9rem;
  line-height:1.05;
}
.showcase-overlay p{
  margin:0;
  color:rgba(255,255,255,0.78);
  font-size:1rem;
  line-height:1.8;
}
.hero-copy{
  display:grid;
  gap:28px;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr minmax(320px,0.95fr);
  gap:40px;
  align-items:center;
}
.hero-eyebrow{
  display:inline-block;
  margin-bottom:24px;
  color:#c7c7c1;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-size:0.85rem;
}
.hero-media{
  display:grid;
  gap:18px;
}
.hero-media-card{
  position:relative;
  min-height:460px;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 32px 90px rgba(0,0,0,.24);
}
.hero-media-card img,
.hero-media-grid img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-media-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.hero-media-grid img{
  min-height:220px;
  border-radius:22px;
}
.hero-media-card .media-caption{
  position:absolute;
  inset:auto 0 0 0;
  padding:24px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.72));
  color:#fff;
  font-weight:700;
  font-size:0.95rem;
}
.hero-chips{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:32px;
}
.hero-chip{
  display:inline-flex;
  flex-direction:column;
  gap:6px;
  padding:14px 18px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
}
.hero-chip strong{
  font-size:0.98rem;
  color:#fff;
}
.hero-chip span{
  color:#c7c7c1;
  font-size:0.88rem;
}
.gallery-section .photo-gallery{
  margin-top:42px;
}
.gallery-section .photo-card{
  display:block;
  width:100%;
  padding:0;
  border-radius:24px;
  background:rgba(255,255,255,.02);
  border:1px solid rgba(255,255,255,.08);
}
.gallery-section .photo-card:hover{
  transform:translateY(-6px);
}
.gallery-section .photo-card-body{
  padding:24px;
  background:#fff;
  color:#111;
}
.gallery-section .photo-card-body h3{
  margin-bottom:10px;
}
.section-label{
  display:inline-block;
  margin-bottom:18px;
  font-size:.79rem;
  letter-spacing:.28em;
  color:var(--accent);
  text-transform:uppercase;
}
.section h2,
.page-hero h1{
  margin:0;
  font-size:clamp(40px,6vw,72px);
  line-height:1.02;
  letter-spacing:-.04em;
}
.lead{
  max-width:760px;
  margin-top:18px;
  color:var(--muted);
  font-size:1.06rem;
  line-height:1.8;
}
.grid{
  display:grid;
  gap:26px;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.card,
.area-card,
.review,
.photo-card,
.service-highlight-card,
.form-card,
.process-card{
  position:relative;
  background:rgba(15,21,29,0.72);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:30px;
  padding:36px;
  box-shadow:0 28px 80px rgba(0,0,0,0.26);
  overflow:hidden;
  transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition);
}
.card:hover,
.area-card:hover,
.photo-card:hover,
.service-highlight-card:hover,
.form-card:hover,
.process-card:hover{
  transform:translateY(-5px);
  border-color:rgba(216,184,110,0.34);
  box-shadow:0 40px 110px rgba(0,0,0,0.32);
}
.card .icon{
  font-size:34px;
  color:var(--accent);
}
.card h3,
.area-card h3,
.photo-card-body h3,
.service-highlight-card h3{
  margin:0 0 16px;
  font-size:1.7rem;
  line-height:1.1;
}
.card p,
.area-card p,
.photo-card-body p,
.service-highlight-card p,
.form-card p{
  color:var(--muted);
  line-height:1.8;
}
.split,
.contact-section,
.service-highlight,
.process-premium,
.footer-grid{
  display:grid;
  gap:32px;
}
.split{grid-template-columns:1.1fr 0.9fr;align-items:center;}
.contact-section{grid-template-columns:1fr 1fr;align-items:start;}
.service-highlight{grid-template-columns:1fr 1fr;}
.process-premium{grid-template-columns:repeat(4, minmax(160px, 1fr));}
.dark-box{
  border-radius:32px;
  padding:48px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12);
  box-shadow:0 28px 70px rgba(0,0,0,0.2);
}
.dark-box h2,
.dark-box p{
  color:#fff;
}
input, select, textarea{
  width:100%;
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:18px;
  color:var(--text);
  padding:18px 20px;
  outline:none;
  transition:border-color var(--transition), box-shadow var(--transition);
}
input:focus,
select:focus,
textarea:focus{
  border-color:rgba(216,184,110,0.65);
  box-shadow:0 0 0 4px rgba(216,184,110,0.12);
}
textarea{min-height:170px;resize:vertical;}
footer{
  padding:56px 5vw 40px;
  background:rgba(8,12,16,0.98);
  border-top:1px solid rgba(255,255,255,0.08);
}
.footer-grid{grid-template-columns:1.5fr 1fr 1fr 1fr;}
.footer-grid > div{
  min-width:0;
}
.footer-grid h4{
  margin:0 0 22px;
  font-size:1rem;
  color:var(--text);
}
.footer-grid p,
.footer-grid a{
  display:block;
  color:var(--muted);
  line-height:1.9;
  overflow-wrap:anywhere;
}
.footer-grid a + a,
.footer-grid p + p,
.footer-grid h4 + a,
.footer-grid h4 + p{
  margin-top:8px;
}
.footer-grid a:hover{
  color:var(--accent);
}
.copy{
  margin-top:40px;
  padding-top:30px;
  border-top:1px solid rgba(255,255,255,0.06);
  color:rgba(255,255,255,0.5);
  text-align:center;
}
.whatsapp-float{
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:99;
  width:54px;
  height:54px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:linear-gradient(135deg, rgba(216,184,110,0.96), rgba(148,122,72,0.95));
  color:#06100c;
  text-decoration:none;
  font-size:1.35rem;
  box-shadow:0 24px 60px rgba(0,0,0,0.22);
}
.mobile-menu-button{
  display:none;
  border:none;
  background:transparent;
  flex-direction:column;
  gap:8px;
  padding:14px;
}
.mobile-menu-button span{
  width:28px;
  height:2px;
  background:var(--text);
  border-radius:999px;
}
.mobile-panel{
  display:none;
  position:fixed;
  inset:0;
  z-index:98;
  overflow-y:auto;
  background:rgba(4,7,10,0.96);
  backdrop-filter:blur(20px);
  padding:0;
}
.menu-open{
  overflow:hidden;
}
.menu-open .mobile-panel{
  display:grid;
}
.mobile-panel a{
  color:var(--text);
}
.mobile-panel .mobile-call,
.mobile-panel .mobile-whatsapp{
  font-weight:700;
}
@media(max-width:1200px){
  .topbar{padding:0 4vw;}
  .call{display:none;}
  .hero{min-height:88vh;}
  .page-hero{padding:90px 4vw;}
  .premium-band-inner{grid-template-columns:repeat(2,minmax(220px,1fr));}
  .footer-grid{grid-template-columns:1.5fr 1fr 1fr;}
  .process-premium{grid-template-columns:repeat(2,minmax(180px,1fr));}
}
@media(max-width:992px){
  .features{grid-template-columns:repeat(2, minmax(220px,1fr));}
  .trust-grid{grid-template-columns:repeat(2,minmax(180px,1fr));}
  .premium-band-inner{grid-template-columns:repeat(2, minmax(180px,1fr));}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .split,
  .contact-section,
  .service-highlight{grid-template-columns:1fr;}
  .page-hero{padding:80px 4vw;}
  .hero-content{padding:100px 0 60px;}
  .hero-grid{grid-template-columns:1fr;}
  .hero-media-grid{grid-template-columns:1fr;}
}
@media(max-width:760px){
  .topbar{
    padding:0 18px;
    min-height:84px;
    flex-wrap:wrap;
    row-gap:16px;
    justify-content:space-between;
  }
  .hero-content{padding:90px 0 60px;}
  .hero h1{font-size:clamp(34px,10vw,58px);}
  .hero p{font-size:18px;}
  .features{padding:22px;gap:16px;margin-top:-28px;grid-template-columns:1fr;}
  .feature{flex-direction:column;align-items:flex-start;border-right:0;border-bottom:1px solid rgba(255,255,255,0.08);padding-bottom:16px;}
  .feature:last-child{border-bottom:0;}
  .section{padding:64px 20px;}
  .page-hero{min-height:56vh;padding:80px 20px;border-radius:24px;}
  .footer-grid{grid-template-columns:1fr;gap:28px;}
  .hero-actions{flex-direction:column;align-items:stretch;}
  .hero-actions .btn, .hero-actions a{width:100%;justify-content:center;}
  .premium-band{padding:32px 20px;}
  .premium-band-inner{grid-template-columns:1fr;gap:16px;}
  .trust-grid{grid-template-columns:1fr;}
  .filter-pills{justify-content:flex-start;flex-wrap:wrap;gap:10px;}
  .photo-gallery{grid-template-columns:1fr;gap:18px;}
  .mobile-menu-button{display:flex;}
  .nav{display:none;}
  .header-actions{display:none;}
  .mobile-panel{inset:88px 0 0;padding:24px 18px;}
  .mobile-panel a{padding:16px 18px;border-radius:18px;background:rgba(255,255,255,0.04);}
}
@media(max-width:520px){
  .topbar{padding:0 14px;}
  .hero{min-height:70vh;}
  .hero-content{padding:80px 0 50px;}
  .page-hero{min-height:50vh;padding:64px 16px;}
  .section{padding:48px 16px;}
  .cta, .btn, button{width:100%;justify-content:center;}
  .mobile-panel{inset:84px 0 0;}
  .hero h1{font-size:clamp(30px,12vw,52px);}
  .hero-actions{gap:12px;}
  .premium-band{padding:24px 16px;}
  .footer-grid{gap:20px;}
  .whatsapp-float{right:16px;bottom:16px;}
}

/* Contact form premium styles */
.request-form-section{max-width:1100px;margin:36px auto;padding:48px;border-radius:28px;background:linear-gradient(180deg, rgba(8,10,12,0.95), rgba(12,14,18,0.96));box-shadow:0 34px 120px rgba(0,0,0,0.36);border:1px solid rgba(255,255,255,0.06);}
.request-form{display:block;gap:22px}
.form-grid{display:grid;gap:18px}
.form-grid.two{grid-template-columns:1fr 1fr}
.form-grid.three{grid-template-columns:repeat(3,1fr)}
.form-field{display:flex;flex-direction:column;gap:10px}
.form-field label{font-weight:700;color:rgba(245,243,238,0.9);letter-spacing:0.01em}
.block-label{font-weight:700;color:var(--accent);margin-bottom:8px}
.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:8px}
.request-submit{margin-top:18px;padding:16px 22px;border-radius:14px;background:linear-gradient(90deg, rgba(216,184,110,0.98), rgba(148,122,72,0.95));border:none;color:#06100c;font-weight:800;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease}
.request-submit:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(0,0,0,0.28)}
.request-submit.loading{opacity:0.8;cursor:wait}
.form-note{color:rgba(245,243,238,0.7);margin-top:12px}
.form-messages{margin-top:14px;min-height:28px}
.form-message{padding:14px 16px;border-radius:12px;font-weight:700}
.form-message.info{background:rgba(255,255,255,0.04);color:var(--text)}
.form-message.success{background:linear-gradient(90deg, rgba(34,150,86,0.12), rgba(34,150,86,0.06));color:#d7f6e6;border:1px solid rgba(34,150,86,0.14)}
.form-message.error{background:linear-gradient(90deg, rgba(255,80,90,0.06), rgba(255,80,90,0.02));color:#ffdfe0;border:1px solid rgba(255,80,90,0.08)}
.form-error{margin:0 0 18px;padding:14px 16px;border-radius:12px;background:linear-gradient(90deg, rgba(255,80,90,0.08), rgba(255,80,90,0.03));color:#ffdfe0;border:1px solid rgba(255,80,90,0.14);font-weight:700}
.honeypot-wrapper{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

@media(max-width:760px){
  .form-grid.three{grid-template-columns:1fr}
  .form-grid.two{grid-template-columns:1fr}
  .checkbox-grid{grid-template-columns:1fr}
}

/* Realizace / LiberoHaus-inspired portfolio */
.libero-realizace-hero::before{
  background-image:url('assets/images/praha-moderni-dum/praha-dum-4.webp');
}
.libero-realizace-hero{
  align-items:flex-start;
  text-align:left;
}
.libero-realizace-hero .section-label,
.libero-realizace-section .section-label,
.libero-request-head .section-label{
  color:#58a6ff;
}
.libero-realizace-section{
  padding-top:72px;
}
.libero-realizace-section h2,
.libero-request-section h2{
  max-width:780px;
}
.libero-project-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  margin-top:36px;
}
.libero-project-card{
  height:100%;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border:1px solid rgba(88,166,255,0.18);
  border-radius:8px;
  background:linear-gradient(180deg, rgba(10,15,22,0.98), rgba(5,8,12,0.98));
  box-shadow:0 28px 80px rgba(0,0,0,0.28);
  transition:transform .32s ease, border-color .32s ease, box-shadow .32s ease;
}
.libero-project-card:hover{
  transform:translateY(-6px);
  border-color:rgba(88,166,255,0.52);
  box-shadow:0 34px 96px rgba(0,0,0,0.38), 0 0 38px rgba(31,111,235,0.28);
}
.libero-project-image{
  display:block;
  position:relative;
  aspect-ratio:4/3;
  min-height:260px;
  overflow:hidden;
  background:#07111d;
}
.libero-project-image img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  transition:transform .45s ease, filter .45s ease;
}
.libero-project-card:hover .libero-project-image img{
  transform:scale(1.055);
  filter:saturate(1.08) contrast(1.04);
}
.libero-project-body{
  flex:1;
  display:flex;
  flex-direction:column;
  padding:22px;
}
.libero-project-body h3{
  margin:0 0 10px;
  font-size:clamp(20px,2vw,26px);
}
.libero-project-meta{
  margin:0 0 20px;
  color:rgba(245,243,238,0.68);
}
.libero-project-params{
  display:grid;
  gap:8px;
  margin:0 0 22px;
  padding:0;
  list-style:none;
  color:rgba(245,243,238,0.76);
  font-size:0.95rem;
}
.libero-project-params li{
  display:flex;
  justify-content:space-between;
  gap:14px;
  border-bottom:1px solid rgba(255,255,255,0.07);
  padding-bottom:8px;
}
.libero-project-params span{
  color:#9cc8ff;
  font-weight:700;
}
.libero-detail{
  margin-top:auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:0 22px;
  border:1px solid rgba(88,166,255,0.5);
  border-radius:4px;
  background:rgba(47,125,246,0.12);
  color:#d9ecff;
  font-weight:800;
  text-decoration:none;
  letter-spacing:.08em;
  transition:background .18s ease, border-color .18s ease, transform .18s ease;
}
.libero-detail:hover{
  transform:translateY(-2px);
  border-color:#58a6ff;
  background:#1f6feb;
  color:#fff;
}
.libero-request-section{
  max-width:1120px;
  margin:28px auto 72px;
  border:1px solid rgba(88,166,255,0.2);
  border-radius:8px;
  background:
    linear-gradient(135deg, rgba(31,111,235,0.14), transparent 34%),
    linear-gradient(180deg, rgba(8,13,20,0.98), rgba(4,7,11,0.98));
  box-shadow:0 34px 110px rgba(0,0,0,0.32);
}
.libero-request-head{
  margin-bottom:26px;
}
.libero-request-form{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.libero-request-form input,
.libero-request-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:6px;
  background:rgba(255,255,255,0.045);
  color:var(--text);
}
.libero-request-form input:focus,
.libero-request-form textarea:focus{
  border-color:#58a6ff;
  outline:2px solid rgba(88,166,255,0.2);
}
.form-field-wide{
  grid-column:1 / -1;
}
.libero-consent{
  flex-direction:row;
  align-items:center;
  gap:12px;
  color:rgba(245,243,238,0.82);
}
.libero-consent input{
  width:18px;
  height:18px;
  accent-color:#1f6feb;
}
.libero-submit{
  min-height:54px;
  border:0;
  border-radius:4px;
  background:linear-gradient(90deg, #1f6feb, #58a6ff);
  color:#fff;
  font-weight:900;
  letter-spacing:.08em;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease;
}
.libero-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 46px rgba(31,111,235,0.34);
}

@media(max-width:992px){
  .libero-project-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .libero-request-form{
    grid-template-columns:1fr;
  }
}

@media(max-width:760px){
  .libero-realizace-hero{
    min-height:58vh;
  }
  .libero-project-grid{
    grid-template-columns:1fr;
    gap:18px;
  }
  .libero-project-body{
    padding:18px;
  }
  .libero-request-section{
    margin:12px 16px 48px;
  }
}

/* Premium architecture redesign */
:root{
  --bg:#02060d;
  --surface:rgba(8,14,24,0.78);
  --surface-strong:rgba(6,12,20,0.94);
  --surface-soft:rgba(82,165,255,0.08);
  --border:rgba(126,190,255,0.18);
  --accent:#58a6ff;
  --accent-soft:#1f6feb;
  --accent-deep:#0b2f6f;
  --text:#f7fbff;
  --muted:#aeb9c8;
  --shadow:0 34px 120px rgba(0,0,0,0.46);
}
body{
  background:
    radial-gradient(circle at 16% 0%, rgba(47,125,246,0.2), transparent 30%),
    radial-gradient(circle at 86% 18%, rgba(88,166,255,0.16), transparent 28%),
    linear-gradient(180deg, #02060d 0%, #050b14 44%, #03060b 100%);
}
.topbar{
  min-height:82px;
  background:linear-gradient(180deg, rgba(2,6,13,0.78), rgba(2,6,13,0.46));
  border-bottom:1px solid rgba(126,190,255,0.14);
  box-shadow:0 18px 70px rgba(0,0,0,0.28);
  backdrop-filter:blur(24px) saturate(1.25);
}
.logo span,
.footer-brand strong{
  color:#fff;
  text-shadow:0 0 22px rgba(88,166,255,0.25);
}
.nav a:hover,
.nav a.active,
a:hover,
.section-label,
.gallery-section .section-label{
  color:var(--accent);
}
.nav a::after{
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
  box-shadow:0 0 18px rgba(88,166,255,0.7);
}
.cta,
.btn,
button,
.request-submit,
.libero-submit{
  border:1px solid rgba(126,190,255,0.36);
  background:linear-gradient(135deg, #1f6feb 0%, #58a6ff 100%);
  color:#fff;
  box-shadow:0 18px 48px rgba(31,111,235,0.24);
}
.btn.outline,
.cta.outline{
  background:rgba(255,255,255,0.045);
  color:#eaf4ff;
  border-color:rgba(126,190,255,0.32);
  backdrop-filter:blur(18px);
}
.cta:hover,
.btn:hover,
button:hover{
  color:#fff;
  box-shadow:0 24px 70px rgba(31,111,235,0.34), 0 0 32px rgba(88,166,255,0.18);
}
.hero{
  min-height:100vh;
  isolation:isolate;
}
.hero::before{
  background:url('assets/images/Neratovice_foto/neratovice_01.jpg') center/cover no-repeat;
  opacity:0.82;
  filter:saturate(1.08) contrast(1.08);
  transform:scale(1.02);
}
.hero::after{
  background:
    linear-gradient(90deg, rgba(2,6,13,0.92) 0%, rgba(2,6,13,0.66) 45%, rgba(2,6,13,0.28) 100%),
    radial-gradient(circle at 78% 32%, rgba(88,166,255,0.2), transparent 34%),
    linear-gradient(180deg, rgba(2,6,13,0.12), rgba(2,6,13,0.96));
}
.hero h1,
.page-hero h1{
  letter-spacing:0;
  text-shadow:0 22px 90px rgba(0,0,0,0.55);
}
.hero-eyebrow,
.section-label{
  color:#9cc8ff;
}
.hero-chip,
.premium-metric,
.feature,
.trust-item,
.area-card,
.card,
.dark-box,
.checklist,
.form-card,
.process-card{
  background:linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.035));
  border:1px solid rgba(126,190,255,0.16);
  box-shadow:0 22px 70px rgba(0,0,0,0.24);
  backdrop-filter:blur(20px);
}
.hero-media-card,
.hero-media-grid img,
.photo-card,
.showcase-card,
.service-highlight-card,
.libero-project-card{
  border:1px solid rgba(126,190,255,0.2);
  box-shadow:0 34px 110px rgba(0,0,0,0.42);
}
.hero-media-card img,
.hero-media-grid img,
.photo-card img{
  transition:transform 700ms var(--ease), filter 420ms var(--ease);
}
.hero-media-card:hover img,
.hero-media-grid img:hover,
.photo-card:hover img{
  transform:scale(1.06);
  filter:saturate(1.08) contrast(1.05);
}
.section{
  position:relative;
}
.section.light,
.section.muted,
.section.dark,
.gallery-section,
.architecture-showcase,
.contact-premium,
.top-firma-final,
.ultra-seo-content,
.seo-hidden-service-area{
  background:
    linear-gradient(135deg, rgba(88,166,255,0.08), transparent 36%),
    linear-gradient(180deg, rgba(8,14,24,0.9), rgba(3,7,13,0.96));
  color:var(--text);
  border-color:rgba(126,190,255,0.14);
}
.gallery-section,
.architecture-showcase,
.contact-premium,
.libero-request-section{
  backdrop-filter:blur(22px);
  box-shadow:0 42px 140px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.08);
}
.gallery-section .photo-card{
  min-height:100%;
  background:rgba(5,10,18,0.78);
}
.gallery-section .photo-card img{
  width:100%;
  aspect-ratio:16/11;
  object-fit:cover;
}
.gallery-section .photo-card-body{
  background:rgba(4,9,16,0.94);
  color:var(--text);
}
.showcase-card::before,
.service-highlight-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at top right, rgba(88,166,255,0.16), transparent 32%),
    linear-gradient(180deg, rgba(2,6,13,0.1), rgba(2,6,13,0.84));
  pointer-events:none;
}
.showcase-card,
.service-highlight-card{
  transition:transform 420ms var(--ease), box-shadow 420ms var(--ease), border-color 420ms var(--ease), filter 420ms var(--ease);
}
.showcase-card:hover,
.service-highlight-card:hover{
  transform:translateY(-8px);
  border-color:rgba(88,166,255,0.46);
  box-shadow:0 46px 130px rgba(0,0,0,0.46), 0 0 44px rgba(31,111,235,0.24);
}
.service-highlight-card h3,
.service-highlight-card p{
  position:relative;
  z-index:1;
  color:#fff;
}
.page-hero::before{
  background:url('assets/images/Podebrady_foto/podebrady_01.jpg') center/cover no-repeat;
  opacity:0.68;
  filter:saturate(1.06) contrast(1.05);
}
.page-hero::after,
.request-hero::after{
  background:
    linear-gradient(180deg, rgba(2,6,13,0.28), rgba(2,6,13,0.92)),
    radial-gradient(circle at top left, rgba(88,166,255,0.2), transparent 32%);
}
.request-hero::before{
  background:url('assets/images/praha-moderni-dum/praha-dum-1.webp') center/cover no-repeat;
}
.page-hero.house-hero-alt::before{background-image:url('assets/images/praha-moderni-dum/praha-dum-2.webp');}
.page-hero.house-hero-local::before{background-image:url('assets/images/praha-moderni-dum/praha-dum-3.webp');}
.contact-form-premium,
.request-form,
.libero-request-form{
  background:linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.035));
  border:1px solid rgba(126,190,255,0.18);
  box-shadow:0 34px 110px rgba(0,0,0,0.34);
  backdrop-filter:blur(22px);
}
.form-group input,
.form-group textarea,
.form-group select,
.form-field input,
.form-field textarea,
.form-field select{
  background:rgba(255,255,255,0.055);
  border-color:rgba(126,190,255,0.2);
  color:#f7fbff;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus,
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{
  border-color:#58a6ff;
  box-shadow:0 0 0 4px rgba(88,166,255,0.14);
}
footer{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 15% 0%, rgba(88,166,255,0.16), transparent 30%),
    linear-gradient(180deg, rgba(4,9,16,0.98), #02060d);
  border-top:1px solid rgba(126,190,255,0.16);
}
footer::before{
  content:'';
  position:absolute;
  inset:0;
  background:url('assets/images/Praha-Štěrboholy/praha_sterboholy_01.jpg') center/cover no-repeat;
  opacity:0.08;
  filter:saturate(1.1) contrast(1.1);
  pointer-events:none;
}
footer > *{
  position:relative;
  z-index:1;
}
.footer-grid{
  align-items:start;
}
.footer-grid > div{
  padding:22px;
  border:1px solid rgba(126,190,255,0.1);
  border-radius:18px;
  background:rgba(255,255,255,0.035);
}
.footer-social{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.footer-social a{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:50%;
  border:1px solid rgba(126,190,255,0.25);
  background:rgba(88,166,255,0.08);
  color:#dceeff;
  font-size:0.76rem;
  font-weight:800;
  letter-spacing:.04em;
}
.footer-social a:hover{
  background:#1f6feb;
  color:#fff;
  transform:translateY(-3px);
}

@media(max-width:992px){
  .hero{min-height:auto;}
  .hero-media-card{min-height:380px;}
  .showcase-card{min-height:360px;}
}

@media(max-width:760px){
  .topbar{
    background:rgba(2,6,13,0.88);
  }
  .hero{
    min-height:100svh;
    padding:0 18px;
  }
  .hero-content{
    padding:92px 0 48px;
  }
  .hero h1{
    font-size:clamp(38px,12vw,62px);
    line-height:1;
  }
  .hero p{
    font-size:16px;
    line-height:1.72;
  }
  .hero-media-card{
    min-height:300px;
    border-radius:22px;
  }
  .hero-media-grid{
    grid-template-columns:1fr 1fr;
  }
  .hero-media-grid img{
    min-height:150px;
    border-radius:18px;
  }
  .gallery-section,
  .architecture-showcase,
  .contact-premium{
    border-radius:24px;
    padding:48px 18px;
  }
  .footer-grid > div{
    padding:18px;
  }
}

/* Bright luxury architecture photo pass */
.hero::before{
  background:var(--hero-image, url('assets/images/ujezd-nad-lesy-photos/ujezd-nad-lesy-01.jpg')) center/cover no-repeat;
  opacity:0.94;
  filter:brightness(1.14) saturate(1.08) contrast(1.02);
}
.hero::after{
  background:
    linear-gradient(90deg, rgba(2,6,13,0.76) 0%, rgba(2,6,13,0.42) 45%, rgba(2,6,13,0.08) 100%),
    radial-gradient(circle at 74% 28%, rgba(120,190,255,0.22), transparent 35%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(2,6,13,0.72));
}
.page-hero,
.request-hero{
  min-height:68vh;
}
.page-hero::before,
.request-hero::before{
  background:var(--page-hero-image, url('assets/images/Lysa_nad_Labem_foto/lysa_nad_labem_03.webp')) center/cover no-repeat;
  opacity:0.86;
  filter:brightness(1.14) saturate(1.08) contrast(1.02);
}
.page-hero::after,
.request-hero::after{
  background:
    linear-gradient(180deg, rgba(2,6,13,0.22), rgba(2,6,13,0.72)),
    linear-gradient(90deg, rgba(2,6,13,0.72), rgba(2,6,13,0.16)),
    radial-gradient(circle at top left, rgba(104,181,255,0.2), transparent 34%);
}
.hero h1,
.hero p,
.page-hero h1,
.page-hero p,
.request-hero h1,
.request-hero p{
  text-shadow:0 18px 62px rgba(0,0,0,0.58);
}
.hero-media-card{
  min-height:540px;
}
.hero-media-card,
.hero-media-grid img,
.photo-card,
.showcase-card,
.service-highlight-card,
.libero-project-card{
  box-shadow:0 30px 95px rgba(0,0,0,0.34), 0 0 34px rgba(88,166,255,0.12);
}
.hero-media-card img,
.hero-media-grid img,
.gallery-section .photo-card img,
.libero-project-image img{
  filter:brightness(1.08) saturate(1.08) contrast(1.02);
}
.hero-media-card:hover img,
.hero-media-grid img:hover,
.gallery-section .photo-card:hover img,
.libero-project-card:hover .libero-project-image img{
  filter:brightness(1.13) saturate(1.12) contrast(1.04);
}
.photo-card::after{
  background:linear-gradient(180deg, rgba(0,0,0,0) 48%, rgba(2,6,13,0.22));
}
.gallery-section .photo-card-body,
.libero-project-body{
  background:linear-gradient(180deg, rgba(6,13,22,0.94), rgba(4,9,16,0.98));
}
.showcase-overlay{
  background:linear-gradient(180deg, rgba(2,6,13,0.08), rgba(2,6,13,0.58));
}
.showcase-card::before,
.service-highlight-card::before{
  background:
    radial-gradient(circle at top right, rgba(124,196,255,0.18), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(2,6,13,0.58));
}
.section.light,
.section.muted,
.section.dark,
.gallery-section,
.architecture-showcase,
.contact-premium,
.top-firma-final,
.ultra-seo-content,
.seo-hidden-service-area{
  background:
    radial-gradient(circle at 12% 0%, rgba(88,166,255,0.1), transparent 30%),
    linear-gradient(180deg, rgba(10,18,30,0.88), rgba(5,11,20,0.94));
}
.libero-project-image{
  min-height:300px;
}
.libero-project-card:hover{
  box-shadow:0 34px 100px rgba(0,0,0,0.36), 0 0 52px rgba(88,166,255,0.3);
}

@media(max-width:992px){
  .page-hero,
  .request-hero{
    min-height:62vh;
  }
  .hero-media-card{
    min-height:420px;
  }
}

@media(max-width:760px){
  .page-hero,
  .request-hero{
    min-height:58svh;
  }
  .hero::after{
    background:
      linear-gradient(180deg, rgba(2,6,13,0.55), rgba(2,6,13,0.78)),
      radial-gradient(circle at top right, rgba(88,166,255,0.18), transparent 34%);
  }
  .page-hero::after,
  .request-hero::after{
    background:
      linear-gradient(180deg, rgba(2,6,13,0.36), rgba(2,6,13,0.74)),
      radial-gradient(circle at top left, rgba(88,166,255,0.16), transparent 34%);
  }
  .hero-media-card{
    min-height:340px;
  }
  .hero-media-grid img{
    min-height:170px;
  }
  .libero-project-image{
    min-height:260px;
  }
}



/* Bright premium architecture update */
:root{
  --luxury-bg:#05080d;
  --luxury-panel:rgba(13,20,31,.72);
  --luxury-border:rgba(141,190,255,.22);
  --accent:#58a6ff;
  --accent-strong:#2f8cff;
}
body{background:radial-gradient(circle at 20% 0%,rgba(88,166,255,.16),transparent 34%),linear-gradient(180deg,#07101a 0%,#05080d 55%,#080c12 100%);}
.topbar{background:rgba(5,10,17,.64)!important;border-bottom:1px solid rgba(255,255,255,.12);box-shadow:0 18px 50px rgba(0,0,0,.24);backdrop-filter:blur(22px) saturate(145%);}
.hero,.page-hero,.request-hero{min-height:clamp(560px,86svh,860px);position:relative;overflow:hidden;background:var(--hero-image,var(--page-hero-image)) center/cover no-repeat!important;isolation:isolate;}
.page-hero,.request-hero{background:var(--page-hero-image) center/cover no-repeat!important;}
.hero::before,.page-hero::before,.request-hero::before{content:"";position:absolute;inset:0;background:inherit;filter:brightness(1.18) contrast(1.04) saturate(1.08);transform:scale(1.02);z-index:-2;}
.hero::after,.page-hero::after,.request-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,7,12,.70) 0%,rgba(3,7,12,.38) 42%,rgba(3,7,12,.12) 100%),linear-gradient(0deg,rgba(5,8,13,.72) 0%,rgba(5,8,13,.10) 44%,rgba(255,255,255,.05) 100%);z-index:-1;}
.hero-content,.page-hero > *, .request-hero > *{position:relative;z-index:1;}
.hero h1,.page-hero h1,.request-hero h1{color:#fff;text-shadow:0 20px 58px rgba(0,0,0,.45);letter-spacing:-.03em;}
.hero p,.page-hero p,.request-hero p{color:rgba(255,255,255,.9);text-shadow:0 12px 32px rgba(0,0,0,.35);}
.section.dark,.section.light,.section.muted{background:linear-gradient(180deg,rgba(8,14,23,.94),rgba(5,8,13,.98))!important;color:#fff;}
.card,.area-card,.libero-project-card,form,.dark-box,.contact-panel,.feature,.premium-panel{background:linear-gradient(145deg,rgba(255,255,255,.11),rgba(255,255,255,.045))!important;border:1px solid var(--luxury-border)!important;box-shadow:0 24px 70px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.12);backdrop-filter:blur(16px) saturate(135%);}
.card p,.lead,.area-card p,.libero-project-card p,.footer-grid p,.footer-grid a{color:rgba(255,255,255,.78)!important;}
.cta,.btn,button{background:linear-gradient(135deg,var(--accent),var(--accent-strong))!important;color:#fff!important;border:1px solid rgba(255,255,255,.22)!important;box-shadow:0 14px 36px rgba(47,140,255,.26);transition:transform .25s ease,box-shadow .25s ease,filter .25s ease;}
.cta:hover,.btn:hover,button:hover{transform:translateY(-2px);box-shadow:0 20px 54px rgba(47,140,255,.38);filter:brightness(1.08);}
img,.showcase-card,.service-highlight-card,.libero-project-card img{object-fit:cover;filter:brightness(1.08) contrast(1.03) saturate(1.06);transition:transform .55s ease,filter .55s ease,box-shadow .35s ease;}
.showcase-card:hover,.service-highlight-card:hover,.libero-project-card:hover{box-shadow:0 30px 80px rgba(47,140,255,.24),0 16px 44px rgba(0,0,0,.32);border-color:rgba(88,166,255,.48)!important;}
.showcase-card:hover,.service-highlight-card:hover{transform:translateY(-5px) scale(1.01);}
.libero-realizace-grid,.realizace-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;}
.libero-project-card{overflow:hidden;border-radius:18px!important;}
.libero-project-card .project-image,.libero-project-card img{height:clamp(260px,30vw,390px)!important;width:100%;}
.libero-project-card:hover img{transform:scale(1.06);filter:brightness(1.18) contrast(1.05) saturate(1.1);}
.gallery-grid img,.media-stack img,.preview-gallery img{width:100%;aspect-ratio:16/10;border-radius:18px;box-shadow:0 22px 55px rgba(0,0,0,.28);}
.gallery-grid img:hover,.media-stack img:hover,.preview-gallery img:hover{transform:scale(1.035);filter:brightness(1.18) contrast(1.04);}
footer{background:linear-gradient(180deg,#07101a,#04070c)!important;border-top:1px solid rgba(88,166,255,.22);}
@media(max-width:1024px){.libero-realizace-grid,.realizace-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.hero,.page-hero,.request-hero{min-height:70svh;background-position:center!important;}}
@media(max-width:680px){.libero-realizace-grid,.realizace-grid{grid-template-columns:1fr;}.hero,.page-hero,.request-hero{min-height:64svh;background-position:center!important;}.libero-project-card .project-image,.libero-project-card img{height:260px!important;}.hero::after,.page-hero::after,.request-hero::after{background:linear-gradient(180deg,rgba(3,7,12,.44),rgba(3,7,12,.72));}}

/* Realizace premium grid class alignment */
.libero-project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:28px;}
.libero-project-image{display:block;overflow:hidden;border-radius:18px 18px 0 0;background:#0b111b;}
.libero-project-image img{width:100%;height:clamp(260px,30vw,390px)!important;object-fit:cover;}
.libero-project-card:hover .libero-project-image img{transform:scale(1.06);filter:brightness(1.18) contrast(1.05) saturate(1.1);}
@media(max-width:1024px){.libero-project-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media(max-width:680px){.libero-project-grid{grid-template-columns:1fr;}.libero-project-image img{height:260px!important;}}

/* Premium bright architecture design refresh */
:root{
  --premium-ink:#f7fbff;
  --premium-muted:rgba(235,245,255,.78);
  --premium-soft:rgba(255,255,255,.12);
  --premium-line:rgba(125,190,255,.28);
  --premium-blue:#62b4ff;
  --premium-blue-deep:#247cff;
  --premium-glow:0 26px 80px rgba(47,140,255,.26);
}
html{scroll-behavior:smooth;}
body{font-family:Inter,Arial,sans-serif;color:var(--premium-ink);text-rendering:geometricPrecision;background:linear-gradient(180deg,#0b1624 0%,#07111d 42%,#05080d 100%)!important;}
body::before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 8%,rgba(98,180,255,.18),transparent 28%),radial-gradient(circle at 82% 0%,rgba(255,255,255,.08),transparent 24%);z-index:-1;}
.topbar{height:82px;background:rgba(7,15,26,.58)!important;border-bottom:1px solid rgba(255,255,255,.14)!important;box-shadow:0 18px 60px rgba(0,0,0,.24)!important;backdrop-filter:blur(24px) saturate(160%)!important;}
.logo span,.footer-brand strong{letter-spacing:.04em;color:#fff;}
.logo small,.footer-brand span{color:var(--premium-blue);}
.nav a{position:relative;color:rgba(255,255,255,.82)!important;transition:color .25s ease;}
.nav a::after{content:"";position:absolute;left:0;right:0;bottom:-10px;height:2px;background:linear-gradient(90deg,var(--premium-blue),transparent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease;}
.nav a:hover,.nav a.active{color:#fff!important;}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);}
.hero,.page-hero,.request-hero{min-height:clamp(620px,88svh,900px)!important;background-position:center!important;box-shadow:inset 0 -120px 110px rgba(5,8,13,.74);}
.page-hero,.request-hero{min-height:clamp(520px,72svh,760px)!important;display:grid;align-items:end;padding-top:110px!important;padding-bottom:72px!important;}
.hero::before,.page-hero::before,.request-hero::before{filter:brightness(1.26) contrast(1.03) saturate(1.12)!important;transform:scale(1.035);transition:transform 1.2s ease,filter 1.2s ease;}
.hero:hover::before,.page-hero:hover::before,.request-hero:hover::before{transform:scale(1.055);filter:brightness(1.32) contrast(1.04) saturate(1.16)!important;}
.hero::after,.page-hero::after,.request-hero::after{background:linear-gradient(90deg,rgba(4,9,16,.64) 0%,rgba(4,9,16,.32) 48%,rgba(4,9,16,.08) 100%),linear-gradient(0deg,rgba(5,8,13,.66) 0%,rgba(5,8,13,.12) 46%,rgba(255,255,255,.08) 100%)!important;}
.hero h1,.page-hero h1,.request-hero h1{max-width:980px;color:#fff!important;font-weight:900;line-height:.98;letter-spacing:-.025em;text-wrap:balance;text-shadow:0 22px 70px rgba(0,0,0,.44);}
.hero p,.page-hero p,.request-hero p,.lead{color:var(--premium-muted)!important;line-height:1.72;text-wrap:pretty;}
.section{position:relative;padding-top:clamp(72px,8vw,128px)!important;padding-bottom:clamp(72px,8vw,128px)!important;}
.section::before{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.035),transparent 38%,rgba(98,180,255,.045));opacity:.8;}
.section > *{position:relative;z-index:1;}
.section-label{color:var(--premium-blue)!important;letter-spacing:.14em;font-size:12px;}
.section h2{color:#fff!important;letter-spacing:-.025em;text-wrap:balance;}
.card,.area-card,.trust-item,.premium-metric,.photo-card,.showcase-panel,.dark-box,form,.libero-project-card{border-radius:22px!important;background:linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.055))!important;border:1px solid var(--premium-line)!important;box-shadow:0 24px 72px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.16)!important;backdrop-filter:blur(18px) saturate(145%);transition:transform .32s ease,border-color .32s ease,box-shadow .32s ease,background .32s ease;}
.card:hover,.area-card:hover,.trust-item:hover,.premium-metric:hover,.photo-card:hover,.libero-project-card:hover{transform:translateY(-7px);border-color:rgba(98,180,255,.58)!important;box-shadow:var(--premium-glow),0 24px 70px rgba(0,0,0,.32)!important;}
img,.photo-card img,.hero-media-card img,.hero-media-grid img,.libero-project-image img{filter:brightness(1.15) contrast(1.02) saturate(1.1)!important;object-fit:cover;}
.photo-card,.hero-media-card,.showcase-card,.service-highlight-card,.libero-project-image{overflow:hidden;border:1px solid rgba(255,255,255,.14);background:#0b1420;}
.photo-card img,.hero-media-card img,.hero-media-grid img,.libero-project-image img{transition:transform .65s cubic-bezier(.2,.65,.2,1),filter .65s ease;}
.photo-card:hover img,.hero-media-card:hover img,.hero-media-grid img:hover,.libero-project-card:hover img{transform:scale(1.06);filter:brightness(1.24) contrast(1.04) saturate(1.14)!important;}
.showcase-card,.service-highlight-card{background-size:cover!important;background-position:center!important;transition:transform .42s ease,box-shadow .42s ease,filter .42s ease;filter:brightness(1.1) saturate(1.08);}
.showcase-card:hover,.service-highlight-card:hover{transform:translateY(-8px) scale(1.015);filter:brightness(1.18) saturate(1.12);}
.showcase-overlay,.photo-card-body,.libero-project-body{background:linear-gradient(180deg,rgba(8,16,27,.70),rgba(6,11,19,.94))!important;border-top:1px solid rgba(255,255,255,.12);}
input,select,textarea{background:rgba(255,255,255,.09)!important;border:1px solid rgba(166,210,255,.26)!important;color:#fff!important;border-radius:12px!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.08);}
input:focus,select:focus,textarea:focus{outline:none;border-color:rgba(98,180,255,.75)!important;box-shadow:0 0 0 4px rgba(98,180,255,.13),inset 0 1px 0 rgba(255,255,255,.1);}
.cta,.btn,button,.libero-detail,.request-submit{border-radius:999px!important;background:linear-gradient(135deg,#74c2ff,#257fff)!important;box-shadow:0 18px 46px rgba(37,127,255,.32)!important;letter-spacing:.04em;}
.cta:hover,.btn:hover,button:hover,.libero-detail:hover,.request-submit:hover{transform:translateY(-3px);box-shadow:0 26px 70px rgba(37,127,255,.44)!important;}
footer{position:relative;background:linear-gradient(180deg,#081421,#03060b)!important;border-top:1px solid rgba(98,180,255,.28)!important;box-shadow:0 -30px 90px rgba(0,0,0,.24);}
footer::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 0%,rgba(98,180,255,.16),transparent 32%);}
.footer-grid{position:relative;z-index:1;gap:28px!important;}
.footer-grid>div{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:24px;}
.footer-social a{border:1px solid rgba(98,180,255,.35);background:rgba(98,180,255,.1);transition:transform .24s ease,background .24s ease,box-shadow .24s ease;}
.footer-social a:hover{transform:translateY(-3px);background:rgba(98,180,255,.22);box-shadow:0 14px 36px rgba(37,127,255,.26);}
.libero-project-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:clamp(18px,2.4vw,34px)!important;}
.libero-project-card{min-height:100%;}
.libero-project-image img{height:clamp(300px,32vw,430px)!important;}
@media (prefers-reduced-motion:no-preference){.hero-content,.page-hero>* ,.section>.section-label,.section h2,.card,.photo-card,.libero-project-card{animation:premiumFadeUp .75s ease both;}@keyframes premiumFadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}}
@media(max-width:1100px){.topbar{height:76px;}.hero,.page-hero,.request-hero{min-height:clamp(560px,76svh,760px)!important;}.footer-grid{grid-template-columns:1fr 1fr!important;}.libero-project-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}}
@media(max-width:680px){body{background:#06101b!important;}.topbar{height:72px;padding:0 18px!important;background:rgba(6,13,23,.84)!important;}.hero,.page-hero,.request-hero{min-height:70svh!important;padding-left:18px!important;padding-right:18px!important;background-position:center!important;}.hero::after,.page-hero::after,.request-hero::after{background:linear-gradient(180deg,rgba(4,9,16,.34),rgba(4,9,16,.78))!important;}.hero h1,.page-hero h1,.request-hero h1{font-size:clamp(34px,11vw,54px)!important;}.hero p,.page-hero p,.request-hero p,.lead{font-size:16px!important;}.section{padding-left:18px!important;padding-right:18px!important;}.footer-grid,.libero-project-grid{grid-template-columns:1fr!important;}.footer-grid>div{padding:20px;}.libero-project-image img{height:280px!important;}.hero-media-card{min-height:320px!important;}.hero-media-grid{gap:12px!important;}}


/* All assets realizace gallery */
.all-assets-realizace-section{overflow:hidden;}
.asset-gallery-count{display:inline-flex;align-items:center;margin:18px 0 34px;padding:10px 16px;border-radius:999px;background:rgba(98,180,255,.12);border:1px solid rgba(98,180,255,.34);color:#dff1ff;font-weight:800;letter-spacing:.04em;box-shadow:0 16px 42px rgba(37,127,255,.18);}
.all-assets-gallery{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:clamp(18px,2.4vw,34px)!important;align-items:stretch;}
.asset-project-card{min-height:100%;overflow:hidden;}
.asset-project-card .libero-project-image{aspect-ratio:16/11;min-height:0;border-radius:22px 22px 0 0;}
.asset-project-card .libero-project-image img{width:100%;height:100%!important;display:block;object-fit:cover;filter:brightness(1.16) contrast(1.03) saturate(1.1)!important;}
.asset-project-card .libero-project-body{display:grid;gap:12px;align-content:start;min-height:230px;}
.asset-project-card .project-location{color:#80c7ff;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.12em;}
.asset-project-card h3{margin:0;color:#fff;font-size:clamp(20px,1.8vw,28px);line-height:1.12;}
.asset-project-card p{margin:0;color:rgba(235,245,255,.76);line-height:1.65;}
.asset-project-card .libero-detail{align-self:end;justify-self:start;margin-top:6px;}
.asset-project-card:hover .libero-project-image img{transform:scale(1.07);filter:brightness(1.26) contrast(1.05) saturate(1.16)!important;}
@media(max-width:1100px){.all-assets-gallery{grid-template-columns:repeat(2,minmax(0,1fr))!important;}.asset-project-card .libero-project-image{aspect-ratio:16/10;}}
@media(max-width:680px){.all-assets-gallery{grid-template-columns:1fr!important;}.asset-gallery-count{width:100%;justify-content:center;}.asset-project-card .libero-project-image{aspect-ratio:4/3;}.asset-project-card .libero-project-body{min-height:auto;}}

/* Emergency mobile overflow guard for Google/mobile indexing */
html,
body{
  max-width:100%;
  overflow-x:hidden;
}

@media(max-width:680px){
  .topbar,
  main,
  .hero,
  .page-hero,
  .request-hero,
  .section,
  footer{
    max-width:100vw;
    overflow-x:hidden;
  }

  .hero h1,
  .page-hero h1,
  .request-hero h1{
    max-width:100%;
    font-size:clamp(30px,9vw,42px)!important;
    line-height:1.04!important;
    letter-spacing:0!important;
    overflow-wrap:anywhere;
    word-break:normal;
    text-wrap:balance;
  }

  .hero-content{
    width:100%;
    max-width:100%;
  }

  .mobile-menu-button,
  .hero-actions .btn,
  .hero-actions a{
    max-width:100%;
  }
}

/* Resend contact form states */
.resend-honeypot{
  position:absolute!important;
  left:-9999px!important;
  width:1px!important;
  height:1px!important;
  opacity:0!important;
  pointer-events:none!important;
}

.is-submitting button[type="submit"]{
  cursor:wait;
  opacity:.78;
  transform:none!important;
}

.is-submitting button[type="submit"]::before{
  content:"";
  width:16px;
  height:16px;
  border:2px solid rgba(255,255,255,.5);
  border-top-color:#fff;
  border-radius:50%;
  animation:contactSpin .75s linear infinite;
}

.submit-success{
  animation:contactSuccessPulse .7s ease both;
}

.submit-success button[type="submit"]{
  background:linear-gradient(135deg,#1fbf75,#49dd9b)!important;
  box-shadow:0 18px 46px rgba(31,191,117,.32)!important;
}

@keyframes contactSpin{
  to{transform:rotate(360deg);}
}

@keyframes contactSuccessPulse{
  0%{box-shadow:0 0 0 rgba(31,191,117,0);}
  45%{box-shadow:0 0 0 8px rgba(31,191,117,.18);}
  100%{box-shadow:0 0 0 rgba(31,191,117,0);}
}

/* 2026 premium dark conversion redesign */
:root{
  --ds-bg:#05070a;
  --ds-bg-2:#0a0d11;
  --ds-surface:rgba(15,19,24,.78);
  --ds-surface-strong:rgba(18,24,31,.94);
  --ds-surface-soft:rgba(255,255,255,.055);
  --ds-border:rgba(255,255,255,.12);
  --ds-border-strong:rgba(108,180,255,.36);
  --ds-text:#f6f8fb;
  --ds-muted:#aab6c2;
  --ds-blue:#4db4ff;
  --ds-blue-2:#126dff;
  --ds-blue-soft:rgba(77,180,255,.16);
  --ds-success:#35d08f;
  --ds-error:#ff6b6b;
  --ds-radius:20px;
  --ds-radius-sm:12px;
  --ds-pill:999px;
  --ds-shadow:0 26px 80px rgba(0,0,0,.34);
  --ds-glow:0 18px 54px rgba(18,109,255,.32);
  --ds-ease:cubic-bezier(.2,.8,.2,1);
  --mobile-cta-height:0px;
  color-scheme:dark;
}

html{
  background:var(--ds-bg);
  scroll-padding-top:92px;
}

body{
  color:var(--ds-text)!important;
  background:
    linear-gradient(180deg,#05070a 0%,#0b1015 48%,#05070a 100%)!important;
  letter-spacing:0!important;
}

body::before{
  display:none!important;
}

.skip-link{
  border-radius:0 0 14px 0!important;
  background:#07101a!important;
  outline-color:var(--ds-blue)!important;
}

.topbar{
  height:78px!important;
  min-height:78px!important;
  padding:0 clamp(18px,4vw,64px)!important;
  background:rgba(5,7,10,.78)!important;
  border-bottom:1px solid rgba(255,255,255,.11)!important;
  box-shadow:0 20px 60px rgba(0,0,0,.28)!important;
  backdrop-filter:blur(22px) saturate(150%)!important;
  -webkit-backdrop-filter:blur(22px) saturate(150%)!important;
}

.logo{
  min-width:max-content;
}

.logo span{
  color:#fff!important;
  font-weight:900!important;
  letter-spacing:.08em!important;
}

.logo small{
  color:var(--ds-blue)!important;
  font-weight:800!important;
}

.nav{
  gap:clamp(14px,1.55vw,28px)!important;
  font-size:13px!important;
  letter-spacing:.11em!important;
}

.nav a{
  color:rgba(246,248,251,.76)!important;
}

.nav a:hover,
.nav a.active{
  color:#fff!important;
}

.nav a::after{
  bottom:-9px!important;
  height:2px!important;
  background:linear-gradient(90deg,var(--ds-blue),rgba(77,180,255,0))!important;
}

.call{
  color:#dbe8f6!important;
  font-size:14px;
}

.cta,
.btn,
button,
.request-submit,
.libero-detail{
  min-height:48px;
  border-radius:var(--ds-pill)!important;
  border:1px solid rgba(255,255,255,.18)!important;
  background:
    linear-gradient(135deg,#68c8ff 0%,#1b7fff 52%,#0754dd 100%)!important;
  color:#fff!important;
  box-shadow:var(--ds-glow)!important;
  font-weight:850!important;
  letter-spacing:.035em!important;
  text-transform:uppercase!important;
}

.cta:hover,
.btn:hover,
button:hover,
.request-submit:hover,
.libero-detail:hover{
  transform:translateY(-3px)!important;
  box-shadow:0 24px 76px rgba(18,109,255,.42)!important;
  filter:brightness(1.05)!important;
}

.btn.outline,
.mobile-panel .mobile-whatsapp{
  background:rgba(255,255,255,.07)!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.2)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.09)!important;
}

.btn.outline:hover,
.mobile-panel .mobile-whatsapp:hover{
  border-color:rgba(77,180,255,.55)!important;
  box-shadow:0 16px 48px rgba(18,109,255,.18)!important;
}

.hero,
.page-hero,
.request-hero{
  min-height:clamp(560px,82svh,840px)!important;
  overflow:hidden!important;
  background-position:center!important;
  isolation:isolate;
}

.page-hero,
.request-hero{
  min-height:clamp(460px,62svh,680px)!important;
  align-items:end!important;
  padding:118px clamp(18px,5vw,72px) 76px!important;
}

.hero::before,
.page-hero::before,
.request-hero::before{
  filter:brightness(.88) contrast(1.04) saturate(1.02)!important;
  transform:scale(1.035)!important;
  transition:transform 1.4s var(--ds-ease), filter 1.4s var(--ds-ease)!important;
  will-change:transform;
}

.hero:hover::before,
.page-hero:hover::before,
.request-hero:hover::before{
  transform:scale(1.065)!important;
  filter:brightness(.94) contrast(1.05) saturate(1.04)!important;
}

.hero::after,
.page-hero::after,
.request-hero::after{
  background:
    linear-gradient(90deg,rgba(3,6,10,.9) 0%,rgba(3,6,10,.7) 42%,rgba(3,6,10,.3) 100%),
    linear-gradient(0deg,rgba(5,7,10,.92) 0%,rgba(5,7,10,.18) 48%,rgba(5,7,10,.1) 100%)!important;
}

.hero-content{
  max-width:1240px!important;
  padding:118px 0 90px!important;
}

.hero-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(300px,.62fr)!important;
  gap:clamp(28px,5vw,74px)!important;
  align-items:center!important;
}

.hero-copy{
  max-width:790px;
}

.hero h1,
.page-hero h1,
.request-hero h1{
  max-width:980px!important;
  color:#fff!important;
  font-size:clamp(42px,6.8vw,92px)!important;
  line-height:.98!important;
  letter-spacing:0!important;
  text-wrap:balance;
  text-shadow:0 24px 70px rgba(0,0,0,.58)!important;
}

.page-hero h1,
.request-hero h1{
  font-size:clamp(40px,5.4vw,76px)!important;
}

.hero p,
.page-hero p,
.request-hero p,
.lead{
  max-width:760px!important;
  color:rgba(246,248,251,.84)!important;
  font-size:clamp(17px,1.5vw,21px)!important;
  line-height:1.68!important;
  text-wrap:pretty;
}

.hero-eyebrow,
.section-label{
  color:#8fd2ff!important;
  letter-spacing:.14em!important;
}

.hero-actions{
  align-items:center!important;
  gap:14px!important;
}

.hero-chips{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}

.hero-chip,
.premium-metric,
.feature,
.trust-item,
.card,
.area-card,
.photo-card,
.dark-box,
.contact-panel,
.showcase-panel,
.libero-project-card,
form{
  background:
    linear-gradient(145deg,rgba(255,255,255,.105),rgba(255,255,255,.045))!important;
  border:1px solid rgba(255,255,255,.12)!important;
  box-shadow:var(--ds-shadow), inset 0 1px 0 rgba(255,255,255,.1)!important;
  backdrop-filter:blur(18px) saturate(130%);
  -webkit-backdrop-filter:blur(18px) saturate(130%);
}

.hero-chip{
  min-width:138px;
  padding:14px 16px;
  border-radius:16px;
}

.hero-chip strong{
  display:block;
  color:#fff;
  font-size:20px;
}

.hero-chip span{
  display:block;
  color:var(--ds-muted);
  font-size:13px;
  line-height:1.35;
}

.hero-media-card,
.hero-media-grid img{
  border-radius:22px!important;
  border:1px solid rgba(255,255,255,.14)!important;
  box-shadow:0 28px 80px rgba(0,0,0,.36)!important;
  background:#0d1117;
  overflow:hidden;
}

.hero-media-card{
  min-height:clamp(360px,44vw,520px)!important;
}

.hero-media-card img,
.hero-media-grid img,
.photo-card img,
.libero-project-image img{
  filter:brightness(.98) contrast(1.04) saturate(1.02)!important;
}

.section{
  padding:clamp(70px,8vw,118px) clamp(18px,5vw,72px)!important;
}

.section::before{
  display:none!important;
}

.section h2{
  max-width:980px;
  font-size:clamp(32px,4.8vw,66px)!important;
  line-height:1.04!important;
  letter-spacing:0!important;
}

.section.light,
.section.muted,
.section.dark,
.gallery-section,
.architecture-showcase,
.contact-premium,
.top-firma-final,
.ultra-seo-content,
.seo-hidden-service-area{
  background:
    linear-gradient(180deg,rgba(9,13,18,.96),rgba(5,7,10,.98))!important;
  color:var(--ds-text)!important;
}

.features{
  width:min(92vw,1240px)!important;
  margin:-42px auto 0!important;
  padding:18px!important;
  border-radius:24px!important;
  gap:12px!important;
  position:relative;
  z-index:5;
}

.feature{
  border-radius:18px!important;
  padding:18px!important;
}

.feature-icon,
.card .icon{
  color:var(--ds-blue)!important;
}

.card:hover,
.area-card:hover,
.trust-item:hover,
.premium-metric:hover,
.photo-card:hover,
.libero-project-card:hover{
  transform:translateY(-5px)!important;
  border-color:var(--ds-border-strong)!important;
  box-shadow:0 26px 74px rgba(0,0,0,.38),0 0 42px rgba(77,180,255,.16)!important;
}

.photo-card,
.libero-project-card{
  border-radius:20px!important;
}

.photo-card img,
.libero-project-image img{
  aspect-ratio:16/11;
}

.photo-card-body,
.libero-project-body,
.showcase-overlay{
  background:linear-gradient(180deg,rgba(10,14,20,.72),rgba(7,10,14,.96))!important;
  border-top:1px solid rgba(255,255,255,.1)!important;
}

.pill,
.filter-pills span,
.asset-gallery-count{
  color:#dff2ff!important;
  background:rgba(77,180,255,.1)!important;
  border:1px solid rgba(77,180,255,.28)!important;
  box-shadow:none!important;
}

form,
.request-form{
  display:grid;
  gap:20px!important;
  border-radius:24px!important;
  padding:clamp(22px,4vw,42px)!important;
}

.request-form-section{
  padding:clamp(42px,7vw,90px) clamp(18px,5vw,72px)!important;
  background:linear-gradient(180deg,#070a0f,#05070a)!important;
}

.form-grid{
  gap:18px!important;
}

.form-field,
.form-group,
.form-block{
  min-width:0;
}

label,
.block-label,
.form-field label,
.form-group label{
  color:rgba(246,248,251,.9)!important;
  font-weight:750!important;
}

input,
select,
textarea{
  min-height:52px!important;
  padding:15px 16px!important;
  border-radius:14px!important;
  border:1px solid rgba(255,255,255,.14)!important;
  background:rgba(4,8,13,.62)!important;
  color:#fff!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08)!important;
  transition:border-color .22s var(--ds-ease), box-shadow .22s var(--ds-ease), background .22s var(--ds-ease)!important;
}

textarea{
  min-height:142px!important;
  resize:vertical;
}

input::placeholder,
textarea::placeholder{
  color:rgba(170,182,194,.62)!important;
}

input:hover,
select:hover,
textarea:hover{
  border-color:rgba(77,180,255,.42)!important;
}

input:focus,
select:focus,
textarea:focus{
  outline:none!important;
  border-color:rgba(77,180,255,.78)!important;
  box-shadow:0 0 0 4px rgba(77,180,255,.14), inset 0 1px 0 rgba(255,255,255,.1)!important;
}

.was-validated input:invalid,
.was-validated textarea:invalid,
.field-touched input:invalid,
.field-touched textarea:invalid,
select[aria-invalid="true"],
.custom-select[aria-invalid="true"] .custom-select-trigger{
  border-color:rgba(255,107,107,.78)!important;
  box-shadow:0 0 0 4px rgba(255,107,107,.12)!important;
}

.form-message{
  padding:14px 16px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.07);
  color:#fff;
  line-height:1.5;
}

.form-message.success{
  border-color:rgba(53,208,143,.36);
  background:rgba(53,208,143,.1);
}

.form-message.error{
  border-color:rgba(255,107,107,.45);
  background:rgba(255,107,107,.1);
}

.form-message.info{
  border-color:rgba(77,180,255,.35);
  background:rgba(77,180,255,.1);
}

.checkbox-grid label{
  border-radius:14px!important;
  background:rgba(255,255,255,.055)!important;
  border:1px solid rgba(255,255,255,.11)!important;
  min-height:48px;
  display:flex!important;
  align-items:center;
  gap:10px;
}

.checkbox-grid input{
  width:18px!important;
  height:18px!important;
  min-height:18px!important;
  accent-color:var(--ds-blue);
}

.native-select-hidden{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  margin:0!important;
  padding:0!important;
  border:0!important;
  opacity:0!important;
  pointer-events:none!important;
  clip-path:inset(50%)!important;
}

.custom-select{
  position:relative;
  width:100%;
}

.custom-select-trigger{
  position:relative;
  display:flex!important;
  align-items:center;
  justify-content:space-between;
  width:100%;
  min-height:52px;
  padding:15px 48px 15px 16px!important;
  border-radius:14px!important;
  border:1px solid rgba(255,255,255,.14)!important;
  background:rgba(4,8,13,.72)!important;
  color:#fff!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08)!important;
  text-align:left;
  text-transform:none!important;
  letter-spacing:0!important;
  font-weight:650!important;
}

.custom-select-trigger::after{
  content:"";
  position:absolute;
  right:18px;
  top:50%;
  width:10px;
  height:10px;
  border-right:2px solid rgba(255,255,255,.82);
  border-bottom:2px solid rgba(255,255,255,.82);
  transform:translateY(-65%) rotate(45deg);
  transition:transform .22s var(--ds-ease);
}

.custom-select.is-open .custom-select-trigger{
  border-color:rgba(77,180,255,.78)!important;
  box-shadow:0 0 0 4px rgba(77,180,255,.14), inset 0 1px 0 rgba(255,255,255,.1)!important;
}

.custom-select.is-open .custom-select-trigger::after{
  transform:translateY(-35%) rotate(225deg);
}

.custom-select-menu{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 8px);
  z-index:80;
  display:grid;
  gap:6px;
  max-height:min(320px,48svh);
  overflow:auto;
  padding:8px;
  border-radius:18px;
  border:1px solid rgba(77,180,255,.28);
  background:rgba(8,12,18,.98);
  box-shadow:0 24px 72px rgba(0,0,0,.44);
  opacity:0;
  pointer-events:none;
  transform:translateY(-8px) scale(.98);
  transform-origin:top;
  transition:opacity .22s var(--ds-ease), transform .22s var(--ds-ease);
}

.custom-select.is-open .custom-select-menu{
  opacity:1;
  pointer-events:auto;
  transform:translateY(0) scale(1);
}

.custom-select-option{
  width:100%;
  min-height:44px;
  justify-content:flex-start!important;
  padding:11px 12px!important;
  border-radius:12px!important;
  border:1px solid transparent!important;
  background:transparent!important;
  color:rgba(246,248,251,.86)!important;
  box-shadow:none!important;
  text-align:left;
  text-transform:none!important;
  letter-spacing:0!important;
  font-weight:650!important;
}

.custom-select-option:hover,
.custom-select-option.is-active{
  background:rgba(77,180,255,.13)!important;
  border-color:rgba(77,180,255,.22)!important;
  transform:none!important;
}

.custom-select-option.is-selected{
  background:linear-gradient(135deg,rgba(77,180,255,.28),rgba(18,109,255,.2))!important;
  border-color:rgba(77,180,255,.46)!important;
  color:#fff!important;
}

.mobile-menu-button{
  width:48px!important;
  height:48px!important;
  min-height:48px!important;
  padding:0!important;
  place-items:center!important;
  border-radius:50%!important;
  background:rgba(255,255,255,.07)!important;
  border:1px solid rgba(255,255,255,.12)!important;
  box-shadow:none!important;
}

.mobile-menu-button span{
  width:21px!important;
  height:2px!important;
  background:#fff!important;
  border-radius:999px!important;
}

.menu-open .mobile-menu-button span:nth-child(1){
  transform:translateY(7px) rotate(45deg)!important;
}

.menu-open .mobile-menu-button span:nth-child(2){
  opacity:0!important;
}

.menu-open .mobile-menu-button span:nth-child(3){
  transform:translateY(-7px) rotate(-45deg)!important;
}

.mobile-panel{
  display:grid!important;
  position:fixed!important;
  inset:0!important;
  z-index:90!important;
  align-content:start!important;
  gap:10px!important;
  padding:104px 18px 26px!important;
  background:rgba(5,7,10,.86)!important;
  backdrop-filter:blur(24px) saturate(150%)!important;
  -webkit-backdrop-filter:blur(24px) saturate(150%)!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
  transform:translateY(-12px) scale(.985)!important;
  transition:opacity .28s var(--ds-ease), transform .28s var(--ds-ease), visibility .28s var(--ds-ease)!important;
}

.menu-open .mobile-panel{
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  transform:translateY(0) scale(1)!important;
}

.mobile-panel a{
  display:flex!important;
  align-items:center;
  justify-content:space-between;
  min-height:50px;
  padding:13px 16px!important;
  border-radius:16px!important;
  background:rgba(255,255,255,.06)!important;
  border:1px solid rgba(255,255,255,.1)!important;
  color:#fff!important;
  font-size:16px!important;
  font-weight:750!important;
}

.mobile-panel a:hover{
  border-color:rgba(77,180,255,.42)!important;
  background:rgba(77,180,255,.12)!important;
  transform:translateY(-1px);
}

.mobile-panel .mobile-call{
  margin-top:8px;
  background:linear-gradient(135deg,#68c8ff,#126dff)!important;
  border-color:rgba(255,255,255,.16)!important;
}

.mobile-bottom-cta{
  display:none;
}

.whatsapp-float{
  box-shadow:0 18px 54px rgba(18,109,255,.3)!important;
  background:linear-gradient(135deg,#68c8ff,#126dff)!important;
}

img{
  background-color:#0a0d11;
}

@media(max-width:1100px){
  .topbar{
    height:74px!important;
    min-height:74px!important;
  }

  .nav{
    display:none!important;
  }

  .header-actions{
    margin-left:auto;
  }

  .mobile-menu-button{
    display:grid!important;
  }

  .hero-grid{
    grid-template-columns:1fr!important;
  }

  .hero-media{
    max-width:760px;
  }

  .features{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}

@media(min-width:1101px){
  .mobile-menu-button,
  .mobile-panel{
    display:none!important;
  }
}

@media(max-width:760px){
  :root{
    --mobile-cta-height:78px;
  }

  html{
    scroll-padding-top:80px;
  }

  body.has-mobile-cta{
    padding-bottom:calc(var(--mobile-cta-height) + env(safe-area-inset-bottom))!important;
  }

  body.menu-open{
    overflow:hidden;
  }

  .topbar{
    height:68px!important;
    min-height:68px!important;
    padding:0 14px!important;
  }

  .logo span{
    font-size:14px;
  }

  .logo small{
    font-size:11px;
  }

  .header-actions,
  .nav{
    display:none!important;
  }

  .mobile-menu-button{
    display:grid!important;
    margin-left:auto;
  }

  .mobile-panel{
    padding-top:84px!important;
    padding-bottom:calc(24px + env(safe-area-inset-bottom))!important;
  }

  .hero,
  .page-hero,
  .request-hero{
    min-height:62svh!important;
    padding-left:18px!important;
    padding-right:18px!important;
  }

  .page-hero,
  .request-hero{
    min-height:52svh!important;
    padding-top:96px!important;
    padding-bottom:48px!important;
  }

  .hero::after,
  .page-hero::after,
  .request-hero::after{
    background:
      linear-gradient(180deg,rgba(3,6,10,.54),rgba(3,6,10,.86)),
      linear-gradient(90deg,rgba(3,6,10,.72),rgba(3,6,10,.36))!important;
  }

  .hero-content{
    padding:92px 0 54px!important;
  }

  .hero h1,
  .page-hero h1,
  .request-hero h1{
    font-size:clamp(31px,9.6vw,48px)!important;
    line-height:1.04!important;
  }

  .hero p,
  .page-hero p,
  .request-hero p,
  .lead{
    font-size:16px!important;
    line-height:1.62!important;
  }

  .hero-actions,
  .quick-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    width:100%;
  }

  .hero-actions .btn,
  .quick-actions .btn,
  .cta,
  .btn,
  button{
    width:100%;
    justify-content:center!important;
  }

  .hero-chips{
    grid-template-columns:1fr 1fr;
    display:grid;
  }

  .hero-chip{
    min-width:0;
  }

  .hero-media{
    display:none!important;
  }

  .features{
    grid-template-columns:1fr!important;
    width:calc(100vw - 32px)!important;
    margin:-22px auto 0!important;
    padding:10px!important;
  }

  .feature{
    padding:15px!important;
  }

  .section{
    padding-left:18px!important;
    padding-right:18px!important;
  }

  .section h2{
    font-size:clamp(28px,8vw,40px)!important;
    line-height:1.08!important;
  }

  form,
  .request-form{
    padding:20px!important;
    border-radius:20px!important;
  }

  input,
  select,
  textarea,
  .custom-select-trigger{
    min-height:50px!important;
    font-size:16px!important;
  }

  .custom-select.is-open .custom-select-menu{
    position:fixed;
    left:14px;
    right:14px;
    top:auto;
    bottom:calc(var(--mobile-cta-height) + 14px + env(safe-area-inset-bottom));
    max-height:52svh;
    z-index:140;
    border-radius:20px;
  }

  .custom-select-option{
    min-height:48px;
  }

  .mobile-bottom-cta{
    position:fixed;
    left:10px;
    right:10px;
    bottom:calc(10px + env(safe-area-inset-bottom));
    z-index:120;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    padding:8px;
    min-height:64px;
    border-radius:22px;
    border:1px solid rgba(255,255,255,.14);
    background:rgba(5,7,10,.86);
    box-shadow:0 18px 60px rgba(0,0,0,.42);
    backdrop-filter:blur(22px) saturate(150%);
    -webkit-backdrop-filter:blur(22px) saturate(150%);
    transition:transform .24s var(--ds-ease), opacity .24s var(--ds-ease);
  }

  .mobile-bottom-cta a{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:3px;
    min-width:0;
    min-height:48px;
    padding:7px 6px;
    border-radius:16px;
    color:#fff!important;
    background:rgba(255,255,255,.065);
    border:1px solid rgba(255,255,255,.1);
    font-size:12px;
    font-weight:800;
    line-height:1.1;
  }

  .mobile-bottom-cta a:first-child,
  .mobile-bottom-cta a:last-child{
    background:linear-gradient(135deg,rgba(104,200,255,.95),rgba(18,109,255,.94));
  }

  .mobile-bottom-cta span{
    font-size:11px;
    letter-spacing:.08em;
    opacity:.86;
  }

  .menu-open .mobile-bottom-cta{
    transform:translateY(120%);
    opacity:0;
    pointer-events:none;
  }

  .whatsapp-float{
    display:none!important;
  }

  .footer-grid>div{
    border-radius:16px!important;
  }
}

@media(max-width:420px){
  .hero-chips{
    grid-template-columns:1fr;
  }

  .mobile-bottom-cta a{
    font-size:11px;
  }
}

@media(prefers-reduced-motion:reduce){
  .hero::before,
  .page-hero::before,
  .request-hero::before,
  .custom-select-menu,
  .mobile-panel,
  .mobile-bottom-cta{
    transition:none!important;
  }
}

/* Site-wide professional photo pass */
.hero::before,
.page-hero::before,
.request-hero::before{
  background-position:var(--hero-position, center center)!important;
  filter:brightness(1.06) contrast(1.09) saturate(1.06)!important;
  transform:scale(1.025)!important;
}

.hero:hover::before,
.page-hero:hover::before,
.request-hero:hover::before{
  filter:brightness(1.1) contrast(1.1) saturate(1.08)!important;
  transform:scale(1.045)!important;
}

.hero::after,
.page-hero::after,
.request-hero::after{
  background:
    linear-gradient(90deg,rgba(3,6,10,.82) 0%,rgba(3,6,10,.56) 44%,rgba(3,6,10,.18) 100%),
    linear-gradient(0deg,rgba(5,7,10,.78) 0%,rgba(5,7,10,.12) 50%,rgba(5,7,10,.04) 100%)!important;
}

img,
.photo-card img,
.hero-media-card img,
.hero-media-grid img,
.libero-project-image img,
.asset-project-card .libero-project-image img{
  image-rendering:auto;
  object-fit:cover!important;
  object-position:center center!important;
  filter:brightness(1.08) contrast(1.08) saturate(1.06)!important;
}

.hero-media-card img,
.hero-media-grid img,
.photo-card img,
.libero-project-image img,
.asset-project-card .libero-project-image img{
  width:100%!important;
  height:100%!important;
}

.photo-card,
.libero-project-image,
.hero-media-card,
.hero-media-grid,
.showcase-card,
.service-highlight-card{
  background-color:#0a0f15;
}

.photo-card img,
.gallery-section .photo-card img{
  aspect-ratio:16/11;
  min-height:260px;
}

.libero-project-image,
.asset-project-card .libero-project-image{
  aspect-ratio:16/11;
}

.showcase-card,
.service-highlight-card{
  background-size:cover!important;
  background-position:center 48%!important;
  filter:brightness(1.08) contrast(1.06) saturate(1.04)!important;
}

.showcase-card:hover,
.service-highlight-card:hover,
.photo-card:hover img,
.hero-media-card:hover img,
.hero-media-grid img:hover,
.libero-project-card:hover img{
  filter:brightness(1.16) contrast(1.09) saturate(1.08)!important;
}

@media(max-width:760px){
  .hero::before,
  .page-hero::before,
  .request-hero::before{
    background-position:var(--mobile-hero-position, center center)!important;
    filter:brightness(1.03) contrast(1.08) saturate(1.05)!important;
  }

  .hero::after,
  .page-hero::after,
  .request-hero::after{
    background:
      linear-gradient(180deg,rgba(3,6,10,.44),rgba(3,6,10,.82)),
      linear-gradient(90deg,rgba(3,6,10,.7),rgba(3,6,10,.28))!important;
  }

  .photo-card img,
  .gallery-section .photo-card img,
  .libero-project-image,
  .asset-project-card .libero-project-image{
    aspect-ratio:4/3;
  }
}

/* Bright Scandinavian architectural image grading */
:root{
  --photo-grade:brightness(1.34) contrast(1.14) saturate(1.08);
  --photo-grade-hover:brightness(1.42) contrast(1.16) saturate(1.1);
  --hero-photo-grade:brightness(1.32) contrast(1.15) saturate(1.08);
  --hero-photo-grade-hover:brightness(1.38) contrast(1.16) saturate(1.1);
}

.hero::before,
.page-hero::before,
.request-hero::before{
  filter:var(--hero-photo-grade)!important;
}

.hero:hover::before,
.page-hero:hover::before,
.request-hero:hover::before{
  filter:var(--hero-photo-grade-hover)!important;
}

.hero::after,
.page-hero::after,
.request-hero::after{
  background:
    linear-gradient(90deg,rgba(3,6,10,.66) 0%,rgba(3,6,10,.38) 42%,rgba(3,6,10,.08) 100%),
    linear-gradient(0deg,rgba(5,7,10,.58) 0%,rgba(5,7,10,.08) 48%,rgba(255,255,255,.04) 100%)!important;
}

.hero h1,
.hero p,
.page-hero h1,
.page-hero p,
.request-hero h1,
.request-hero p{
  text-shadow:0 18px 54px rgba(0,0,0,.72), 0 2px 12px rgba(0,0,0,.34)!important;
}

img,
.photo-card img,
.hero-media-card img,
.hero-media-grid img,
.libero-project-image img,
.asset-project-card .libero-project-image img,
.gallery-grid img,
.media-stack img,
.preview-gallery img{
  filter:var(--photo-grade)!important;
}

.showcase-card,
.service-highlight-card{
  filter:var(--photo-grade)!important;
}

.photo-card:hover img,
.hero-media-card:hover img,
.hero-media-grid img:hover,
.libero-project-card:hover img,
.asset-project-card:hover .libero-project-image img,
.gallery-grid img:hover,
.media-stack img:hover,
.preview-gallery img:hover,
.showcase-card:hover,
.service-highlight-card:hover{
  filter:var(--photo-grade-hover)!important;
}

.photo-card::after{
  background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(3,7,12,.18))!important;
}

.showcase-overlay,
.photo-card-body,
.libero-project-body{
  background:linear-gradient(180deg,rgba(8,16,27,.58),rgba(6,11,19,.9))!important;
}

@media(max-width:760px){
  .hero::before,
  .page-hero::before,
  .request-hero::before{
    filter:brightness(1.36) contrast(1.15) saturate(1.08)!important;
  }

  .hero::after,
  .page-hero::after,
  .request-hero::after{
    background:
      linear-gradient(180deg,rgba(3,6,10,.34),rgba(3,6,10,.7)),
      linear-gradient(90deg,rgba(3,6,10,.54),rgba(3,6,10,.16))!important;
  }
}
