:root{
  --brand:#0f766e; --accent:#f59e0b; --muted:#f5f7f8; --text:#1f2937; --radius:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;color:var(--text);background:#fff;line-height:1.6}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
.nav{display:flex;gap:24px;align-items:center;padding:12px 0;position:sticky;top:0;background:#fff;z-index:50;border-bottom:1px solid #eef2f7}
.nav a{color:var(--text);text-decoration:none;font-weight:600}
.nav .brand{display:flex;align-items:center;gap:10px;margin-right:auto}
.nav img.logo{height:34px;width:auto}
.btn{display:inline-block;padding:12px 18px;border-radius:12px;border:0;background:var(--brand);color:#fff;text-decoration:none;font-weight:700}
.btn.secondary{background:#fff;color:var(--brand);border:2px solid var(--brand)}
.hero{background:linear-gradient(135deg,#0f766e 0%,#0ea5a6 45%,#134e4a 100%);color:#fff;padding:90px 0 70px}
.hero h1{font-size:42px;line-height:1.15;margin:0 0 10px}
.hero p{max-width:720px;font-size:18px;opacity:.95}
.hero .cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.grid{display:grid;gap:18px}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.card{background:#fff;border:1px solid #eef2f7;border-radius:var(--radius);padding:18px;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.card h3{margin-top:0}
.section{padding:56px 0}
.kicker{color:var(--brand);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:12px}
.footer{background:var(--muted);padding:32px 0;color:#334155;border-top:1px solid #e5eaef;margin-top:40px}
.footer a{color:#0f766e;text-decoration:none}
.badge{display:inline-block;padding:6px 10px;border-radius:999px;background:#ecfeff;color:#0f766e;font-weight:700;border:1px solid #a5f3fc}
.small{font-size:14px;opacity:.9}
img.resp{width:100%;height:auto;border-radius:14px;border:1px solid #e5eaef}
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.gallery a{display:block}
.lb-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;padding:20px}
.lb-backdrop img{max-width:95vw;max-height:90vh;border-radius:14px}
.lb-backdrop.active{display:flex}
@media (max-width:800px){
  .grid.cols-3{grid-template-columns:1fr}
  .grid.cols-2{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .hero h1{font-size:32px}
}
.video-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.video-grid video{width:100%;height:auto;border-radius:14px;border:1px solid #e5eaef;background:#000}
@media(max-width:800px){.video-grid{grid-template-columns:1fr}}

figure{margin:0}figure figcaption{margin-top:6px}

.img-compact{border-radius:12px;border:1px solid #e5eaef}
.gallery.compact{gap:10px}
.gallery.compact img{border-radius:10px}

/* Compact thumbnail grid */
.gallery.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.gallery.thumbs img{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;border-radius:10px;border:1px solid #e5eaef}
/* Make default .gallery smaller too */
.gallery img{aspect-ratio:4/3;object-fit:cover}
/* Clear CTA note styling */
.cta-note{margin-top:8px;font-size:13px;opacity:.9}

/* Touch-friendly buttons */
.btn{min-height:44px; padding:14px 20px; border-radius:14px}
a.btn, button.btn{display:inline-flex; align-items:center; justify-content:center}
/* Consistent grid to prevent layout shift */
.gallery.thumbs{display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:10px}
.gallery.thumbs img{width:100%; height:100%; aspect-ratio:4/3; object-fit:cover; border-radius:10px; border:1px solid #e5eaef}
/* Ensure images never exceed container */
img.resp{max-width:100%; height:auto}
/* FAQ */
.faq-item{border:1px solid #eef2f7; border-radius:14px; padding:14px; margin:10px 0}
.faq-item h4{margin:0 0 8px 0}

html{scroll-behavior:smooth}

/* ---- Redesign additions ---- */
.menu{list-style:none;display:flex;gap:16px;margin:0;padding:0;align-items:center}
.menu li a{text-decoration:none;color:var(--text);font-weight:600;padding:8px 10px;border-radius:10px}
.menu li a.btn{color:#fff}
.has-sub{position:relative}
.submenu{position:absolute;display:none;list-style:none;margin:0;padding:8px;gap:6px;background:#fff;border:1px solid #e5eaef;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.06);min-width:260px}
.submenu li a{display:block;padding:8px 10px}
.has-sub:hover .submenu{display:block}
.hero .cta-inline{display:flex;gap:12px;align-items:center;margin-top:16px;flex-wrap:wrap}
.phone{font-weight:800}
/* Service cards */
.services{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
.service-card{background:#fff;border:1px solid #eef2f7;border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.service-card .pic{aspect-ratio:4/3;overflow:hidden}
.service-card .pic img{width:100%;height:100%;object-fit:cover}
.service-card .body{padding:14px}
.service-card .icon{font-size:22px}
.service-card .cta{margin-top:auto;padding:14px}
.service-card .cta a{display:inline-block}
/* Detail sections */
.detail{display:grid;grid-template-columns:1.2fr .8fr;gap:18px;align-items:start}
.detail .bigpic img{width:100%;height:auto;border-radius:14px;border:1px solid #e5eaef}
.detail .benefits li{margin-bottom:6px}
.detail .review{background:#f8fafc;border:1px solid #e5eaef;border-radius:12px;padding:12px;margin-top:12px}
/* Innovation icons & swatches */
.icon-row{display:flex;gap:12px;margin-top:10px;flex-wrap:wrap}
.icon-pill{border:1px solid #e5eaef;border-radius:999px;padding:8px 12px;font-weight:700;background:#f8fffb}
.swatches{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.swatch{width:28px;height:28px;border-radius:6px;border:1px solid #e5eaef}
/* Pricing */
.pricing .card{border:2px solid #e5eaef}
.pricing .card:nth-child(1){background:#f8fffb;border-color:#b7f0e6}
.pricing .card:nth-child(2){background:#f8fbff;border-color:#c7d8ff}
.pricing .card:nth-child(3){background:#fff8fb;border-color:#f7c0d2}
.pricing .card h3{margin-top:0}
/* Reviews carousel */
.carousel{position:relative;overflow:hidden}
.carousel-track{display:flex;scroll-snap-type:x mandatory;overflow-x:auto;gap:12px;padding-bottom:10px}
.carousel .slide{min-width:300px;scroll-snap-align:center;background:#fff;border:1px solid #eef2f7;border-radius:14px;padding:14px}
.carousel .controls{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
/* FAQ accordion */
.accordion .item{border:1px solid #e5eaef;border-radius:12px;margin:8px 0}
.accordion .q{background:#f8fafc;padding:12px;cursor:pointer;border-radius:12px}
.accordion .a{display:none;padding:12px}
/* Sticky CTA mobile */
.sticky-cta{position:fixed;bottom:10px;left:10px;right:10px;display:none;gap:10px;justify-content:space-between;z-index:70}
@media(max-width:800px){.services{grid-template-columns:1fr 1fr}.detail{grid-template-columns:1fr}.sticky-cta{display:flex}}

/* --- Wireframe: visual hierarchy & spacing --- */
:root{--green:#0ea5a1;--green-weak:#e6fbf9}
h1{font-size:clamp(28px,4vw,44px);line-height:1.15;margin:0 0 10px 0}
h2{font-size:clamp(22px,3vw,32px);line-height:1.2;margin:0 0 8px 0}
h3{font-size:clamp(18px,2.4vw,22px);line-height:1.3;margin:8px 0}
.kicker{color:#0ea5a1;text-transform:uppercase;letter-spacing:.06em;font-weight:800;margin-bottom:6px}
.section{padding:34px 0}
.container .lead{font-size:18px;opacity:.9}
.badge{background:var(--green-weak);color:#065f5b;border:1px solid #c9f2ed;padding:6px 10px;border-radius:999px;font-weight:700}
.btn{background:var(--green);}
.btn.secondary{background:#eef2f7;color:#111}
hr.sep{border:0;border-top:1px solid #eef2f7;margin:22px 0}
.usp{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:10px}
.usp .pill{background:#fff;border:1px solid #e5eaef;border-radius:12px;padding:12px;font-weight:700;display:flex;gap:8px;align-items:center}
.projects-teaser{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.projects-teaser .tile{border:1px solid #e5eaef;border-radius:14px;overflow:hidden;background:#fff}
.projects-teaser .tile img{width:100%;height:160px;object-fit:cover}
.projects-teaser .tile .meta{padding:10px}
@media(max-width:900px){.usp{grid-template-columns:1fr 1fr}.projects-teaser{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.projects-teaser{grid-template-columns:1fr}}
/* Reviews carousel visuals */
.stars{color:#f59e0b}
.review-mini{font-style:italic}
/* Footer spacing tune */
.footer .container{gap:18px}

/* --- Forms --- */
.form{display:grid;gap:12px;max-width:720px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form label{font-weight:700}
.form input,.form select,.form textarea{width:100%;padding:10px 12px;border:1px solid #e5eaef;border-radius:10px}
.form textarea{min-height:140px}
.form small.muted{opacity:.75}
/* FAQ robust */
.accordion .q{display:block;width:100%;text-align:left;background:#f8fafc;border:1px solid #e5eaef;border-radius:12px;padding:12px;font-weight:700;cursor:pointer}
.accordion .a[hidden]{display:none}

/* --- Contrast & usability fixes --- */
.menu li a.btn.secondary{background:#eef2f7 !important; color:#111 !important; border:1px solid #e5eaef !important}
.menu li a.btn{line-height:1.1}
.form input,.form select,.form textarea{background:#fff;color:#111;pointer-events:auto}
.form input:disabled,.form select:disabled,.form textarea:disabled{opacity:.6}
/* Make sure nothing overlays the form */
#review-inzenden{position:relative; z-index:2}
header.hero{position:relative; z-index:1}

/* --- Pricing block refinements (v27) --- */
.pricing{align-items:stretch}
.pricing .card{
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:10px;
  padding:16px;
  font-size:15px;
  line-height:1.45;
  word-break:normal;
  overflow-wrap:anywhere;
  border-radius:18px;
}
.pricing .card h3{font-size:20px;margin:0 0 4px 0}
.pricing .card ul{margin:0;padding-left:18px}
.pricing .card .cta{margin-top:auto}
.pricing .card .cta .btn{width:100%}
@media(max-width:820px){
  .pricing .card{font-size:16px}
}

/* --- Brand palette update: dark blue / gold accents --- */
:root{--brand:#0b2a3a;--accent:#b48b28;--bg:#ffffff}
body{background:var(--bg);}
.btn{background:var(--brand);}
.kicker{color:var(--accent);}
a{color:var(--brand);}

/* FAQ with details/summary */
.faq details{border:1px solid #e5eaef;border-radius:14px;margin:12px 0;background:#f8fbfe}
.faq summary{list-style:none;cursor:pointer;padding:14px 16px;font-weight:700;border-radius:14px;outline:none}
.faq summary::-webkit-details-marker{display:none}
.faq .answer{padding:0 16px 14px 16px;}
.faq details[open] summary{background:#f0f7ff}

/* v35: ensure FAQ styling visible */
.faq details{border:1px solid #e5eaef;border-radius:14px;margin:12px 0;background:#f8fbfe}
.faq summary{list-style:none;cursor:pointer;padding:14px 16px;font-weight:700;border-radius:14px;outline:none}
.faq summary::-webkit-details-marker{display:none}
.faq .answer{padding:0 16px 14px 16px;}
.faq details[open] summary{background:#f0f7ff}

#luxeVideoControls{display:none}


/* ONE TRUE CTA STYLES */
.cta-buttons{ display:flex; gap:12px; flex-wrap:wrap; margin-top:18px; }
.btn{ padding:12px 20px; border-radius:18px; font-weight:700; text-decoration:none; display:inline-block;
      background-color:#0b2a3a; color:#fff !important; box-shadow: 0 0 0 3px rgba(0,0,0,0.25) inset; }
.btn:hover{ background-color:#163d55; }


/* === Mobile & Tablet Optimization Patch (non-breaking) === */
img, video { max-width: 100%; height: auto; display: block; }
@media (max-width: 480px){
  .container{ padding: 0 12px; }
  .btn{ width: 100%; text-align: center; }
  .hero .cta .btn{ min-height: 44px; }
  .hero h1{ font-size: 30px; }
  .hero p{ font-size: 16px; }
}
@media (min-width: 481px) and (max-width: 1024px){
  .container{ padding: 0 16px; }
  .hero h1{ font-size: 36px; }
}
@media (max-width: 720px){
  .nav{ flex-wrap: wrap; gap: 12px; }
  .nav a.btn{ flex: 1 1 auto; text-align: center; }
}
.video-grid{ display: grid; gap: 14px; grid-template-columns: repeat(2,minmax(0,1fr)); }
@media (max-width: 640px){
  .video-grid{ grid-template-columns: 1fr; }
}
@media (min-width: 1024px){
  .video-grid{ grid-template-columns: repeat(3,minmax(0,1fr)); }
}
@media (max-width: 640px){
  .gallery{ grid-template-columns: 1fr; }
}
@media (min-width: 641px) and (max-width: 1024px){
  .gallery{ grid-template-columns: 1fr 1fr; }
}
.btn{ min-height: 44px; line-height: 1.2; }
.card{ border-radius: 14px; }
.small{ font-size: 14px; }
body{ -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce){
  *{ animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}
/* === End Mobile & Tablet Patch === */
