
:root{
  --navy:#061b3d;
  --navy2:#0a2d67;
  --cyan:#42c0ff;
  --lime:#b3ef20;
  --lime2:#9bd318;
  --ink:#071f46;
  --muted:#5f6d80;
  --soft:#eef7fc;
  --line:rgba(13,53,105,.18);
  --white:#fff;
  --shadow:0 24px 80px rgba(6,27,61,.16);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink);background:#ecf6fb;overflow-x:hidden}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}.container{width:min(1180px,calc(100% - 48px));margin:0 auto}.section-dark{background:var(--navy) url('../assets/img/bg_dark.png') center/cover no-repeat;color:#fff}.site-header{position:sticky;top:0;z-index:100;background:rgba(3,16,36,.9);backdrop-filter:blur(18px);border-bottom:1px solid rgba(255,255,255,.12)}.nav{height:86px;display:flex;align-items:center;gap:30px}.brand img{width:210px;height:auto}.nav-links{margin-left:auto;display:flex;align-items:center;gap:34px;color:#fff;font-size:15px;font-weight:800}.nav-links a{position:relative;opacity:.9}.nav-links a.active:after,.nav-links a:hover:after{content:"";position:absolute;left:0;right:0;bottom:-10px;height:3px;background:var(--lime);border-radius:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;border-radius:999px;padding:14px 24px;font-weight:900;border:1px solid transparent;transition:.25s ease;cursor:pointer}.btn span{font-size:20px;line-height:1}.btn-lime{background:linear-gradient(135deg,var(--lime),#d6ff3d);color:#062049;box-shadow:0 14px 36px rgba(179,239,32,.28)}.btn-lime:hover{transform:translateY(-2px);box-shadow:0 20px 45px rgba(179,239,32,.35)}.btn-ghost{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff}.btn-outline{border-color:rgba(179,239,32,.55);color:#fff;background:rgba(4,19,43,.55);padding:12px 18px;font-size:14px}.menu-toggle{display:none;margin-left:auto;background:none;border:0;width:42px;height:42px}.menu-toggle span{display:block;height:2px;background:#fff;margin:7px 0;border-radius:2px}
.hero{position:relative;overflow:hidden;min-height:760px}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 45%,rgba(179,239,32,.18),transparent 28%),linear-gradient(90deg,rgba(1,9,24,.97),rgba(2,12,30,.72) 45%,rgba(2,12,30,.2));pointer-events:none}.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:0.9fr 1.15fr;gap:55px;align-items:center;padding:88px 0 86px}.eyebrow,.kicker{font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan);font-size:13px}.hero h1{font-size:clamp(48px,5.3vw,82px);line-height:.98;margin:18px 0 24px;letter-spacing:-.05em;color:#fff}.hero h1 strong{color:var(--lime)}.lead{font-size:18px;line-height:1.65;color:#d9e7f5;max-width:520px}.hero-badges{display:flex;gap:16px;margin:32px 0}.badge{display:grid;grid-template-columns:40px 1fr;column-gap:12px;align-items:center;width:190px;padding:15px;border:1px solid rgba(111,194,255,.35);border-radius:16px;background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 1px rgba(255,255,255,.03)}.badge b{color:#fff;font-size:13px}.badge small{grid-column:2;color:#cfe3f5}.icon{display:inline-block;width:34px;height:34px;border:2px solid var(--cyan);border-radius:10px;position:relative}.icon-leaf{border-color:var(--lime);border-radius:50% 12px 50% 12px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.hero-visual{position:relative}.hero-image-card{border-radius:34px;background:rgba(255,255,255,.96);padding:14px;box-shadow:0 36px 90px rgba(0,0,0,.36),0 0 0 1px rgba(255,255,255,.22)}.hero-image-card img{height:520px;width:100%;object-fit:contain;border-radius:24px}.hero-mini-card{position:absolute;right:46px;bottom:-34px;display:grid;grid-template-columns:120px 1fr 28px;gap:14px;align-items:center;width:372px;padding:13px;border-radius:18px;background:rgba(8,28,61,.82);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.22);box-shadow:0 18px 40px rgba(0,0,0,.28)}.hero-mini-card img{height:74px;width:120px;border-radius:12px;object-fit:cover}.hero-mini-card b{display:block;color:#fff}.hero-mini-card small{display:block;color:#c4d5e7;line-height:1.35}.hero-mini-card i{font-style:normal;color:#fff;font-size:22px}.slider-dots{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);display:flex;gap:12px}.slider-dots span{width:10px;height:10px;border-radius:50%;background:#5d7baf}.slider-dots .on{width:24px;border-radius:999px;background:var(--lime)}
.solutions{position:relative;background:#f4f9fd url('../assets/img/bg_light.png') center/cover no-repeat;padding:72px 0 84px}.section-heading{margin-bottom:32px}.section-heading.center{text-align:center}.section-heading h2{font-size:clamp(34px,4vw,52px);line-height:1.05;margin:12px 0 10px;color:var(--navy);letter-spacing:-.035em}.section-heading.light h2,.section-heading.light p{color:#fff}.section-heading h2 strong{color:var(--lime)}.section-heading p{font-size:17px;color:var(--muted);line-height:1.6}.solution-cards{display:grid;grid-template-columns:1fr 1fr;gap:28px}.solution-card{position:relative;min-height:280px;border-radius:24px;overflow:hidden;display:grid;grid-template-columns:0.85fr 1.15fr;background:#071f46;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.14)}.solution-card:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(1,16,42,.95),rgba(1,16,42,.76) 42%,rgba(1,16,42,.1));z-index:1}.solution-card img{height:100%;width:100%;object-fit:cover;min-height:280px}.solution-content{position:relative;z-index:2;padding:36px 26px;color:#fff}.solution-content h3{font-size:30px;line-height:1.05;margin:18px 0 14px}.solution-content h3 strong{display:block;color:var(--lime)}.solution-content p{line-height:1.55;color:#d7e6f3;font-size:15px}.line-icon{display:inline-grid;place-items:center;width:52px;height:52px;border-radius:16px;border:2px solid var(--cyan);box-shadow:0 0 24px rgba(66,192,255,.22)}.line-icon.home:before{content:'⌂';font-size:30px;color:var(--cyan)}.line-icon.cube:before{content:'□';font-size:30px;color:var(--cyan)}
.pavilions{padding:78px 0}.pavilion-layout{display:grid;grid-template-columns:330px 1fr;gap:36px;align-items:start}.feature-list{margin-top:28px;display:grid;gap:16px}.feature-list div{display:grid;grid-template-columns:42px 1fr;gap:14px;align-items:start;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:14px}.feature-list .line-icon{width:38px;height:38px;border-radius:10px;border-color:var(--lime);box-shadow:0 0 18px rgba(179,239,32,.18)}.feature-list .line-icon:before{font-size:21px;color:var(--lime)}.frame:before{content:'▱'}.building:before{content:'▥'}.grid:before{content:'▦'}.modules:before{content:'▩'}.window:before{content:'▤'}.feature-list p{margin:0;color:#dceafa;line-height:1.45;font-size:14px}.feature-list b{display:block;color:#fff}.pavilion-gallery{display:grid;grid-template-columns:1.15fr .9fr;gap:18px}.gallery-card{border-radius:22px;overflow:hidden;background:#fff;padding:8px;box-shadow:0 20px 60px rgba(0,0,0,.25)}.gallery-card img{height:250px;width:100%;object-fit:cover;border-radius:16px}.gallery-card.wide img{height:330px}.gallery-card.small{grid-column:span 2}.gallery-card.small img{height:210px;object-fit:cover}
.homes{background:#f6fbff url('../assets/img/bg_light.png') center/cover no-repeat;padding:78px 0}.homes-grid{display:grid;grid-template-columns:0.8fr 1.2fr;gap:40px;align-items:center}.home-copy h2{font-size:clamp(38px,4vw,58px);margin:12px 0 8px;color:var(--navy);letter-spacing:-.04em}.home-copy h2 strong{color:var(--lime2)}.home-copy p{font-size:17px;color:var(--muted)}.check-list{list-style:none;padding:0;margin:28px 0 0;display:grid;gap:15px}.check-list li{position:relative;padding-left:36px;font-weight:800;color:var(--ink)}.check-list li:before{content:'✓';position:absolute;left:0;top:-1px;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:#eaf8c8;color:#5e8b00;font-weight:900}.home-images{display:grid;grid-template-columns:1.35fr .8fr;gap:20px}.home-main,.home-side{border-radius:26px;background:#fff;padding:10px;box-shadow:var(--shadow)}.home-main img,.home-side img{height:360px;width:100%;border-radius:18px;object-fit:cover}.home-side img{height:360px}
.benefits{padding:70px 0}.benefit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.benefit-card{border:1px solid rgba(111,194,255,.25);border-radius:20px;background:rgba(255,255,255,.055);padding:28px 22px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.02)}.benefit-icon{display:grid;place-items:center;width:58px;height:58px;border-radius:16px;border:1px solid rgba(66,192,255,.35);color:var(--cyan);font-size:28px;margin-bottom:18px}.benefit-card h3{margin:0 0 10px;color:#fff}.benefit-card p{margin:0;color:#cfdef0;line-height:1.55;font-size:14px}.site-footer{padding:70px 0}.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1.25fr;gap:44px;align-items:center}.footer-brand img{width:250px}.footer-brand p{color:#d5e6f7;line-height:1.6}.footer-contact p{margin:12px 0;color:#fff}.footer-contact span{display:inline-block;width:26px;color:var(--lime)}.footer-cta{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:26px;padding:32px}.footer-cta h2{font-size:28px;margin:0 0 12px}.footer-cta p{color:#d5e6f7;line-height:1.55}.reveal{opacity:0;transform:translateY(22px);transition:all .7s ease}.reveal.visible{opacity:1;transform:none}.delay-1{transition-delay:.12s}.delay-2{transition-delay:.22s}.delay-3{transition-delay:.32s}
@media (max-width: 980px){.nav{height:auto;min-height:78px}.menu-toggle{display:block}.nav-links{position:absolute;top:78px;left:24px;right:24px;display:none;flex-direction:column;background:#071f46;border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:22px;align-items:flex-start}.nav-links.open{display:flex}.nav-cta{display:none}.hero-grid,.pavilion-layout,.homes-grid,.footer-grid{grid-template-columns:1fr}.hero{min-height:auto}.hero-image-card img{height:auto}.hero-mini-card{position:relative;right:auto;bottom:auto;margin-top:18px;width:100%}.solution-cards,.benefit-grid{grid-template-columns:1fr}.home-images{grid-template-columns:1fr}.pavilion-gallery{grid-template-columns:1fr}.gallery-card.small{grid-column:auto}.hero h1{font-size:46px}.footer-brand img{width:210px}}
@media (max-width: 560px){.container{width:min(100% - 28px,1180px)}.brand img{width:170px}.hero-grid{padding:54px 0}.hero-badges{flex-direction:column}.badge{width:100%}.solution-card{grid-template-columns:1fr}.solution-card:before{background:linear-gradient(180deg,rgba(1,16,42,.95),rgba(1,16,42,.65),rgba(1,16,42,.1))}.solution-content{padding:28px}.home-main img,.home-side img{height:260px}.benefit-grid{grid-template-columns:1fr}.footer-grid{gap:26px}.section-heading h2{font-size:34px}}

.sub-hero{min-height:640px}.home-hero-bg:before{background:radial-gradient(circle at 70% 45%,rgba(66,192,255,.14),transparent 28%),linear-gradient(90deg,rgba(1,9,24,.97),rgba(2,12,30,.72) 45%,rgba(2,12,30,.2))}.light-section{background:#f4f9fd url('../assets/img/bg_light.png') center/cover no-repeat;padding:72px 0 84px}.sub-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.sub-gallery-item{background:#fff;padding:10px;border-radius:24px;box-shadow:var(--shadow)}.sub-gallery-item img{width:100%;height:320px;object-fit:cover;border-radius:16px}.sub-gallery-item:first-child img{object-fit:contain;background:#fff}.footer-brand img,.brand img{background:transparent}.site-header .brand{display:block;line-height:0}.site-header .brand img{border-radius:6px} .footer-brand img{border-radius:8px} @media (max-width:980px){.sub-gallery{grid-template-columns:1fr}}

/* === DK CUBE fixes: image windows + backgrounds === */
@media (min-width: 981px){
  .section-dark,
  .homes,
  .light-section,
  .hero-light{
    background-attachment: fixed;
  }
}

/* Hero / main product windows: no white empty space */
.hero-image-card{
  padding:0 !important;
  overflow:hidden !important;
  aspect-ratio:16/9;
  background:transparent !important;
  border:1px solid rgba(255,255,255,.22);
}
.hero-image-card img{
  height:100% !important;
  width:100% !important;
  object-fit:cover !important;
  object-position:center center;
  border-radius:34px !important;
}

/* Thumbnail / gallery windows: card ratio follows photo ratio, not the other way around */
.gallery-card,
.sub-gallery-item,
.home-main,
.home-side{
  padding:0 !important;
  overflow:hidden !important;
  background:transparent !important;
}
.gallery-card img,
.sub-gallery-item img,
.home-main img,
.home-side img{
  display:block;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center;
  border-radius:inherit !important;
}
.gallery-card{
  aspect-ratio:16/10;
}
.gallery-card.wide{
  aspect-ratio:16/8;
}
.gallery-card.small{
  aspect-ratio:16/7;
}
.sub-gallery-item{
  aspect-ratio:16/10;
}
.sub-gallery-item:first-child img{
  object-fit:contain !important;
  background:#fff;
  padding:10px;
}
.home-main,
.home-side{
  aspect-ratio:16/10;
}
.home-side{
  aspect-ratio:4/5;
}

/* Product cards on the homepage: avoid empty lower/side gaps */
.solution-card img{
  object-fit:cover !important;
  object-position:center center;
}
.solution-card{
  align-items:stretch;
}

/* The benefits strip should not repeat the same wave background */
.benefits.section-dark{
  background:#06152f !important;
  background-image:
    radial-gradient(circle at 72% 25%, rgba(179,239,32,.12), transparent 26%),
    radial-gradient(circle at 22% 35%, rgba(66,192,255,.10), transparent 24%),
    linear-gradient(180deg, #06152f 0%, #071f46 100%) !important;
  color:#fff;
}

/* Make repeated backgrounds in adjacent sections feel locked and consistent */
.pavilions.section-dark,
.sub-hero.section-dark{
  background-position:center top !important;
  background-size:cover !important;
}
.homes,
.light-section{
  background-position:center top !important;
  background-size:cover !important;
}

@media (max-width: 980px){
  .hero-image-card{
    aspect-ratio:auto;
  }
  .hero-image-card img{
    height:auto !important;
    aspect-ratio:16/10;
  }
  .gallery-card,
  .gallery-card.wide,
  .gallery-card.small,
  .sub-gallery-item,
  .home-main,
  .home-side{
    aspect-ratio:16/10;
  }
}


/* Language switcher */
.lang-switch{
  display:flex;
  align-items:center;
  gap:4px;
  padding:4px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);
  border-radius:999px;
  backdrop-filter:blur(10px);
  white-space:nowrap;
}
.lang-switch a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:38px;
  height:32px;
  padding:0 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.04em;
  color:#fff;
  opacity:.85;
}
.lang-switch a.active{
  background:linear-gradient(135deg,var(--lime),#d6ff3d);
  color:#062049;
  opacity:1;
  box-shadow:0 8px 20px rgba(179,239,32,.18);
}
@media (max-width:980px){
  .lang-switch{
    margin-left:auto;
  }
}


/* === DK CUBE mobile image sizing fix + privacy notice === */
@media (max-width: 980px){
  .hero-visual,
  .solution-card,
  .gallery-card,
  .sub-gallery-item,
  .home-main,
  .home-side{
    max-width:100%;
  }
  .hero-image-card,
  .gallery-card,
  .gallery-card.wide,
  .gallery-card.small,
  .sub-gallery-item,
  .home-main,
  .home-side{
    aspect-ratio:auto !important;
    height:auto !important;
    background:#fff !important;
  }
  .hero-image-card img,
  .gallery-card img,
  .gallery-card.wide img,
  .gallery-card.small img,
  .sub-gallery-item img,
  .home-main img,
  .home-side img{
    width:100% !important;
    height:auto !important;
    max-height:none !important;
    aspect-ratio:auto !important;
    object-fit:contain !important;
    object-position:center center !important;
    background:#fff !important;
    border-radius:18px !important;
  }
  .solution-card img{
    width:100% !important;
    height:auto !important;
    min-height:0 !important;
    object-fit:contain !important;
    object-position:center center !important;
    background:#061b3d;
  }
  .solution-card{
    min-height:0 !important;
  }
  .solution-card:before{
    pointer-events:none;
  }
  .hero-mini-card{
    grid-template-columns:92px 1fr 24px;
  }
  .hero-mini-card img{
    width:92px !important;
    height:64px !important;
    object-fit:cover !important;
    background:transparent !important;
  }
}

.policy-hero{padding:88px 0 70px;}
.policy-hero h1{font-size:clamp(42px,5vw,72px);line-height:1;margin:16px 0;color:#fff;letter-spacing:-.045em;}
.policy-hero p{max-width:760px;color:#d9e7f5;font-size:18px;line-height:1.6;}
.policy-page{padding:56px 0 76px;background:#eef7fc;}
.policy-card{background:#fff;border-radius:28px;box-shadow:var(--shadow);padding:42px;line-height:1.72;color:var(--ink);}
.policy-card h2{font-size:24px;margin:30px 0 10px;color:var(--navy);}
.policy-card p{margin:0 0 14px;color:#283e5f;}
.policy-card ul{margin:0 0 18px;padding-left:22px;color:#283e5f;}
.policy-card a{color:var(--navy2);font-weight:800;text-decoration:underline;text-underline-offset:3px;}
.footer-contact a{color:#fff;text-decoration:underline;text-underline-offset:3px;}
.privacy-consent{position:fixed;left:24px;right:24px;bottom:24px;z-index:1000;display:flex;align-items:center;justify-content:space-between;gap:22px;max-width:980px;margin:0 auto;padding:18px 20px;border-radius:22px;background:rgba(6,27,61,.96);color:#fff;border:1px solid rgba(255,255,255,.16);box-shadow:0 20px 70px rgba(0,0,0,.36);transform:translateY(130%);opacity:0;transition:.25s ease;backdrop-filter:blur(16px);}
.privacy-consent.visible{transform:translateY(0);opacity:1;}
.privacy-consent strong{display:block;margin-bottom:4px;color:#fff;}
.privacy-consent p{margin:0;color:#d8e7f5;line-height:1.45;font-size:14px;}
.privacy-consent a{color:var(--lime);font-weight:900;text-decoration:underline;text-underline-offset:3px;}
.privacy-consent .btn{flex:0 0 auto;padding:12px 18px;}
@media (max-width: 640px){
  .policy-card{padding:26px 20px;border-radius:22px;}
  .privacy-consent{left:12px;right:12px;bottom:12px;display:block;padding:16px;}
  .privacy-consent .btn{width:100%;margin-top:14px;}
}
