:root{
  --bg:#f4f8fc;
  --surface:#ffffff;
  --surface-2:#eef5fb;
  --line:#d3dfec;
  --text:#10233d;
  --muted:#56718f;
  --primary:#1d62d8;
  --primary-dark:#143e7b;
  --accent:#16b5c7;
  --accent-soft:#e4fbfd;
  --shadow:0 18px 42px rgba(16,35,61,.08);
  --radius-xl:32px;
  --radius-lg:24px;
  --radius-md:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Segoe UI, Inter, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(29,98,216,.08) 0%, transparent 28%),
    linear-gradient(180deg,#f7fbff 0%, #eef5fb 100%);
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font:inherit}
.wrap{width:min(1180px, calc(100% - 32px)); margin:0 auto}
.page-shell{min-height:100vh}
.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(250,252,255,.86);
  border-bottom:1px solid rgba(211,223,236,.95);
}
.nav{
  display:flex; justify-content:space-between; align-items:center;
  min-height:78px; gap:20px;
}
.brand{
  display:inline-flex; align-items:center; gap:12px;
  font-size:18px; font-weight:900; color:#092049;
}
.brand-mark{
  width:16px; height:16px; border-radius:5px;
  background:linear-gradient(135deg,var(--primary) 0%, var(--accent) 100%);
  box-shadow:0 8px 24px rgba(29,98,216,.28);
}
.menu{display:flex; gap:22px; flex-wrap:wrap}
.menu a{font-weight:700; color:#355472}
.menu a:hover{color:var(--primary)}

.blueprint-surface{
  position:relative;
  overflow:hidden;
}
.blueprint-surface::before{
  content:"";
  position:absolute; inset:0;
  background:
    repeating-linear-gradient(0deg, rgba(61,98,142,.08) 0, rgba(61,98,142,.08) 1px, transparent 1px, transparent 34px),
    repeating-linear-gradient(90deg, rgba(61,98,142,.08) 0, rgba(61,98,142,.08) 1px, transparent 1px, transparent 34px),
    linear-gradient(180deg, rgba(29,98,216,.04) 0%, rgba(20,181,199,.02) 100%);
  pointer-events:none;
}
.hero{padding:56px 0 30px}
.hero-grid{
  position:relative;
  display:grid; grid-template-columns:minmax(0,1.05fr) minmax(380px,.95fr); gap:32px; align-items:center;
}
.eyebrow,.section-kicker,.partner-badge,.frame-label{
  display:inline-flex; align-items:center; padding:10px 14px; border-radius:999px;
  background:rgba(29,98,216,.08); color:var(--primary-dark); font-size:12px; font-weight:900;
  letter-spacing:.08em; text-transform:uppercase;
}
h1{
  margin:18px 0 16px;
  font-size:66px; line-height:1.02; letter-spacing:-.03em;
}
h2{
  margin:12px 0 14px;
  font-size:40px; line-height:1.08; letter-spacing:-.03em;
}
h3{margin:0 0 10px}
.lead{font-size:20px; line-height:1.65; color:var(--muted); max-width:720px}
.max-text{max-width:760px}
.muted{color:var(--muted)}
.hero-points{display:grid; gap:12px; margin:26px 0}
.hero-point{
  display:flex; align-items:center; gap:12px; min-height:54px; padding:0 18px;
  background:rgba(255,255,255,.82); border:1px solid rgba(211,223,236,.95);
  border-radius:18px; box-shadow:var(--shadow); font-weight:700; color:#26445f;
}
.hero-icon{
  display:grid; place-items:center; width:30px; height:30px; border-radius:999px;
  background:linear-gradient(135deg, rgba(29,98,216,.14) 0%, rgba(20,181,199,.16) 100%);
  color:var(--primary-dark); font-size:16px; font-weight:900;
}
.actions{display:flex; gap:14px; flex-wrap:wrap; margin:28px 0 24px}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:170px; min-height:54px; padding:0 24px; border-radius:16px;
  font-size:17px; font-weight:900; border:1px solid transparent;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  color:#fff;
  background:linear-gradient(135deg, var(--primary) 0%, #2769df 52%, var(--accent) 100%);
  box-shadow:0 20px 38px rgba(29,98,216,.22);
}
.btn-secondary{
  color:var(--primary-dark); background:#fff; border-color:rgba(211,223,236,.95); box-shadow:var(--shadow);
}
.hero-mini-stats{
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; margin-top:8px;
}
.mini-stat{
  padding:16px 18px; border-radius:18px; background:rgba(255,255,255,.78);
  border:1px solid rgba(211,223,236,.95); box-shadow:var(--shadow);
}
.mini-stat strong{display:block; font-size:18px}
.mini-stat span{display:block; margin-top:5px; color:var(--muted); font-size:14px}

.hero-visual{position:relative; min-height:560px}
.visual-frame{
  position:relative; background:#fff; border:1px solid rgba(211,223,236,.95); border-radius:32px;
  box-shadow:0 26px 52px rgba(16,35,61,.12); overflow:hidden;
}
.main-shot{padding:16px}
.main-shot img{
  width:100%; min-height:420px; object-fit:cover; object-position:center top;
  border-radius:24px; border:1px solid rgba(211,223,236,.86); background:#eaf3fb;
}
.frame-label{position:absolute; left:22px; top:22px; z-index:2}
.floating-card{
  position:absolute; max-width:280px; padding:18px 20px; border-radius:22px;
  background:rgba(255,255,255,.94); border:1px solid rgba(211,223,236,.95); box-shadow:var(--shadow);
}
.floating-title{display:block; margin-bottom:8px; font-size:13px; font-weight:900; color:var(--primary-dark); text-transform:uppercase; letter-spacing:.05em}
.floating-card p{margin:0; color:var(--muted); line-height:1.6}
.floating-plan{left:-16px; bottom:30px}
.floating-pro{right:-6px; top:56px}

.section{padding:42px 0}
.section-tight{padding-top:18px}
.section-soft{padding:52px 0}
.light-surface{
  background:
    linear-gradient(180deg, rgba(255,255,255,.86) 0%, rgba(244,248,252,.95) 100%);
  border-top:1px solid rgba(211,223,236,.7);
  border-bottom:1px solid rgba(211,223,236,.7);
}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:28px}
.split-head{align-items:flex-end}
.centered-head{justify-content:center; text-align:center}
.gallery-note{
  padding:12px 16px; border-radius:16px; background:#fff; border:1px solid rgba(211,223,236,.9); box-shadow:var(--shadow);
  font-weight:700; color:#365170;
}
.product-side-note{
  max-width:340px; padding:20px 22px; border-radius:22px; background:#fff;
  border:1px solid rgba(211,223,236,.95); box-shadow:var(--shadow);
}
.product-side-note strong{display:block; font-size:18px; margin-bottom:6px}
.product-side-note span{color:var(--muted); line-height:1.6}

.trust-strip-section{padding-top:0}
.trust-strip{
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px;
}
.trust-item{
  padding:18px 20px; border-radius:22px; background:#fff; border:1px solid rgba(211,223,236,.95); box-shadow:var(--shadow);
}
.trust-item strong{display:block; font-size:17px}
.trust-item span{display:block; margin-top:6px; color:var(--muted); line-height:1.5}

.feature-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px}
.feature-card,.why-card{
  padding:26px; border-radius:24px; background:#fff; border:1px solid rgba(211,223,236,.95); box-shadow:var(--shadow);
}
.feature-icon{
  display:grid; place-items:center; width:54px; height:54px; margin-bottom:18px;
  border-radius:18px; background:linear-gradient(135deg, rgba(29,98,216,.10) 0%, rgba(20,181,199,.12) 100%);
  color:var(--primary-dark); font-size:26px; font-weight:900;
}
.feature-card p,.why-card p{margin:0; color:var(--muted); line-height:1.65}

.products-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:22px}
.product-card{
  position:relative;
  padding:28px; border-radius:28px; background:#fff; border:1px solid rgba(211,223,236,.95); box-shadow:var(--shadow);
}
.pro-card{
  border-color:rgba(20,181,199,.28);
  box-shadow:0 24px 52px rgba(20,181,199,.12);
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(242,254,255,.98) 100%);
}
.pro-card::after{
  content:"Aanbevolen";
  position:absolute; top:18px; right:18px;
  padding:9px 12px; border-radius:999px; font-size:12px; font-weight:900; letter-spacing:.05em;
  text-transform:uppercase; color:#0c4f63; background:rgba(20,181,199,.15);
}
.demo-card{background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(246,249,253,.98) 100%)}
.product-card-top{display:flex; justify-content:space-between; align-items:flex-start; gap:14px}
.product-badge{
  flex:none; padding:10px 14px; border-radius:999px; font-size:12px; font-weight:900; letter-spacing:.05em; text-transform:uppercase
}
.demo-card .product-badge{background:rgba(44,115,234,.10); color:#1f5ed3}
.pro-card .product-badge{background:rgba(20,181,199,.12); color:#0d7280}
.product-card h3{margin:0 0 10px; font-size:30px}
.product-card p{margin:0; color:var(--muted); line-height:1.65}
.price{font-size:36px; font-weight:900; color:var(--text); margin:20px 0 8px}
.meta{font-size:13px; color:#6f87a1; margin-bottom:16px}
.product-highlights{list-style:none; padding:0; margin:16px 0 24px; display:grid; gap:10px}
.product-highlights li{
  position:relative; padding-left:26px; color:#365170; font-weight:600; line-height:1.45
}
.product-highlights li::before{
  content:""; position:absolute; left:0; top:8px; width:12px; height:12px; border-radius:999px;
  background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);
  box-shadow:0 0 0 5px rgba(20,181,199,.08)
}
.card-actions{display:flex; gap:12px; flex-wrap:wrap}
.placeholder-card{padding:26px; text-align:center; color:var(--muted)}

.gallery-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:18px}
.gallery-thumb{
  display:flex; flex-direction:column; gap:10px; padding:14px; border-radius:22px; border:1px solid rgba(211,223,236,.92);
  background:#fff; box-shadow:var(--shadow); cursor:pointer; text-align:left;
  transition:transform .18s ease, box-shadow .18s ease
}
.gallery-thumb:hover{transform:translateY(-2px); box-shadow:0 24px 52px rgba(16,35,61,.12)}
.gallery-thumb.featured{grid-column:span 2}
.gallery-thumb img{
  height:220px; object-fit:cover; object-position:center top; border-radius:16px;
  border:1px solid rgba(211,223,236,.8); background:#edf4fb
}
.gallery-thumb.featured img{height:260px}
.gallery-zoom{font-size:14px; font-weight:800; color:var(--primary-dark)}

.partner-rotator{
  position:relative; overflow:hidden;
  padding:28px; border-radius:30px; border:1px solid rgba(211,223,236,.95); background:#fff; box-shadow:var(--shadow);
}
.partner-slide{display:none; grid-template-columns:minmax(0,1fr) minmax(320px,.92fr); gap:26px; align-items:center}
.partner-slide.active{display:grid}
.partner-copy h3{font-size:34px; line-height:1.08; margin:12px 0 12px}
.partner-copy p{margin:0 0 22px; color:var(--muted); line-height:1.7}
.partner-visual{
  min-height:260px; padding:24px; border-radius:24px; display:flex; flex-direction:column; justify-content:flex-end; gap:8px;
  position:relative; overflow:hidden; border:1px solid rgba(211,223,236,.65)
}
.partner-visual::before{
  content:""; position:absolute; inset:0;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.09) 0, rgba(255,255,255,.09) 1px, transparent 1px, transparent 26px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.09) 0, rgba(255,255,255,.09) 1px, transparent 1px, transparent 26px);
}
.partner-blueprint{
  color:#fff;
  background:linear-gradient(135deg, #10233d 0%, #16457f 55%, #16b5c7 100%);
}
.partner-dark{
  color:#eff7ff;
  background:linear-gradient(140deg, #08111f 0%, #0d2a4a 55%, #0f7f9a 100%);
}
.partner-light{
  color:#092049;
  background:linear-gradient(140deg, #ffffff 0%, #eef6fd 58%, #d9fbff 100%);
}
.partner-brand,.partner-visual strong,.partner-visual small{position:relative; z-index:1}
.partner-brand{display:inline-flex; align-self:flex-start; padding:8px 12px; border-radius:999px; font-size:12px; font-weight:900; letter-spacing:.05em; text-transform:uppercase; background:rgba(255,255,255,.14)}
.partner-light .partner-brand{background:rgba(9,32,73,.08)}
.partner-visual strong{font-size:26px; line-height:1.08}
.partner-visual small{font-size:15px; line-height:1.5; opacity:.9}
.partner-dots{
  display:flex; justify-content:center; gap:10px; margin-top:20px;
}
.partner-dot{
  width:12px; height:12px; border:none; border-radius:999px; background:#c5d4e3; cursor:pointer;
}
.partner-dot.active{background:linear-gradient(135deg,var(--primary) 0%, var(--accent) 100%)}

.why-grid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px}
.support-card{display:grid; grid-template-columns:minmax(0,1.08fr) minmax(280px,.92fr); gap:24px; padding:28px; border-radius:28px; background:#fff; border:1px solid rgba(211,223,236,.95); box-shadow:var(--shadow)}
.support-copy h2{margin-top:12px}
.email-link{font-size:26px; font-weight:900; color:var(--primary-dark)}
.legal-links{display:flex; gap:14px; flex-wrap:wrap; margin-top:18px}
.legal-links a{padding:10px 14px; border-radius:999px; background:rgba(29,98,216,.08); color:#31506f; font-weight:800}
.support-side{display:flex; align-items:stretch}
.support-mini-card{
  width:100%; padding:24px; display:flex; flex-direction:column; justify-content:center; gap:12px;
  border-radius:24px; background:linear-gradient(180deg,#10233d 0%,#163150 100%); color:#dce9f9
}
.support-mini-card strong{font-size:22px; color:#fff}

.footer{padding:28px 0 34px; border-top:1px solid rgba(211,223,236,.8)}
.footer-row{display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap; color:#4e6885}
.footer-row strong{display:block; color:var(--text); margin-bottom:6px}
.footer-links{display:flex; gap:16px; flex-wrap:wrap}
.footer a{font-weight:800}

.lightbox{
  position:fixed; inset:0; background:rgba(7,18,34,.82); z-index:1000;
  display:flex; align-items:center; justify-content:center; padding:30px
}
.lightbox[hidden]{display:none !important;}
.lightbox-inner{max-width:min(1120px,92vw); max-height:90vh; text-align:center}
.lightbox img{
  max-width:100%; max-height:78vh; border-radius:20px; border:1px solid rgba(211,223,236,.65);
  box-shadow:0 24px 60px rgba(0,0,0,.35); background:#edf4fb
}
.lightbox-caption{margin-top:14px; color:#eff6ff; font-size:14px}
.lightbox-close{
  position:absolute; top:18px; right:22px; width:46px; height:46px; border-radius:999px;
  border:1px solid rgba(255,255,255,.18); background:rgba(15,23,42,.86); color:#fff; font-size:28px; cursor:pointer
}

@media (max-width:1100px){
  h1{font-size:52px}
  .hero-grid,.support-card,.partner-slide{grid-template-columns:1fr}
  .hero-visual{min-height:auto; padding-top:10px}
  .floating-plan{left:10px; bottom:16px}
  .floating-pro{right:10px; top:16px}
  .trust-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:820px){
  .nav{min-height:auto; padding:18px 0}
  .menu{gap:14px}
  h1{font-size:40px}
  h2{font-size:31px}
  .hero-mini-stats,.feature-grid,.why-grid,.products-grid,.gallery-grid,.trust-strip{grid-template-columns:1fr}
  .gallery-thumb.featured{grid-column:auto}
  .gallery-thumb img,.gallery-thumb.featured img{height:190px}
  .main-shot img{min-height:280px}
  .floating-card{position:relative; left:auto; right:auto; top:auto; bottom:auto; max-width:none; margin-top:14px}
  .product-side-note{max-width:none}
  .section-head{align-items:flex-start; flex-direction:column}
}

/* PortalPC manual gallery fix */
.gallery-thumb img{
  object-fit: contain !important;
  object-position: center center !important;
  background: #ffffff !important;
  padding: 8px !important;
}
.gallery-thumb.featured img{
  object-fit: cover !important;
  object-position: center top !important;
  background: #edf4fb !important;
  padding: 0 !important;
}