/* LS Wonen — Hero */

/* Global override — vergroot het site-logo zonder header.php aan te raken */
.lsw-brand img { height:70px !important; }

.lsw-hero-section { --white:#FFFFFF; --bone:#F8F6F2; --ink:#14151A; --ink-soft:#2E2F34; --body:#6E707A; --rule:#ECECEA; --accent:#C89F49; --accent-soft:#FCEFE8; --green:#3FB67A; --whatsapp:#25D366; --lsw-header-h:172px; --cue-ink:#14151A; --cue-bead:#C89F49; font-family:'Manrope',system-ui,sans-serif; color:var(--ink); background:var(--white); position:relative; overflow:hidden; }
.lsw-hero-section *, .lsw-hero-section *::before, .lsw-hero-section *::after { box-sizing:border-box; }

/* When bg image is enabled */
.lsw-hero-section.has-bg { background:transparent; isolation:isolate; overflow:visible; }
.lsw-hero-section.has-bg .lsw-h__pagebg { position:absolute; top:calc(-1 * var(--lsw-header-h)); left:50%; transform:translateX(-50%); width:100vw; height:calc(100% + var(--lsw-header-h)); z-index:0; pointer-events:none; overflow:hidden; }
.lsw-hero-section.has-bg .lsw-h__pagebg-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:var(--lsw-bg-pos, center center); display:block; will-change:transform; }
.lsw-hero-section.has-bg .lsw-h__pagebg-tint { position:absolute; inset:0; background:var(--lsw-bg-tint, rgba(15,15,15,.4)); }
.lsw-hero-section.has-bg .lsw-h__pagebg-grad { position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(15,15,15,.55) 100%); }
.lsw-hero-section.has-bg .lsw-h { position:relative; z-index:2; }
.lsw-hero-section.has-bg .lsw-h__deco { display:none; }

/* Light text mode (bg image + light) */
.lsw-hero-section.has-bg--light .lsw-h__h1 { color:#fff; text-shadow:0 1px 30px rgba(0,0,0,.18); }
.lsw-hero-section.has-bg--light .lsw-h__h1 em { color:#FFC7A8; }
.lsw-hero-section.has-bg--light .lsw-h__sub { color:rgba(255,255,255,.86); }
.lsw-hero-section.has-bg--light .lsw-h__badge { background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.24); color:#fff; backdrop-filter:blur(14px) saturate(140%); -webkit-backdrop-filter:blur(14px) saturate(140%); }
.lsw-hero-section.has-bg--light .lsw-h__badge-txt strong { color:#fff; }
.lsw-hero-section.has-bg--light .lsw-h__badge-loc { color:rgba(255,255,255,.85); }
.lsw-hero-section.has-bg--light .lsw-h__badge-sep { background:rgba(255,255,255,.4); }
.lsw-hero-section.has-bg--light .lsw-h__btn--ghost { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.28); color:#fff; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.lsw-hero-section.has-bg--light .lsw-h__btn--ghost:hover { background:var(--whatsapp); border-color:var(--whatsapp); color:#fff; }
.lsw-hero-section.has-bg--light .lsw-h__meta-txt { color:rgba(255,255,255,.86); }
.lsw-hero-section.has-bg--light .lsw-h__meta-txt strong { color:#fff; }
.lsw-hero-section.has-bg--light .lsw-h__av { border-color:rgba(255,255,255,.4); }
.lsw-hero-section.has-bg--light { --cue-ink:rgba(255,255,255,.78); --cue-bead:#FFC7A8; }

/* Transparent site header while hero with bg is in view (set by JS via body class) */
body.lsw-has-hero-bg .lsw-header,
body.lsw-has-hero-bg .lsw-mainbar,
body.lsw-has-hero-bg .lsw-utility { background:transparent !important; }
body.lsw-has-hero-bg-light .lsw-mainbar,
body.lsw-has-hero-bg-light .lsw-utility,
body.lsw-has-hero-bg-light .lsw-nav__link,
body.lsw-has-hero-bg-light .lsw-utility__chip,
body.lsw-has-hero-bg-light .lsw-utility__social a { color:#fff; }
body.lsw-has-hero-bg-light .lsw-utility__chip-label strong,
body.lsw-has-hero-bg-light .lsw-utility__chip-label small { color:#fff; }
body.lsw-has-hero-bg-light .lsw-utility__chip-icon { background:rgba(255,255,255,.14); color:#fff; }
body.lsw-has-hero-bg-light .lsw-utility__sep { background:linear-gradient(180deg, transparent, rgba(255,255,255,.32), transparent); }
body.lsw-has-hero-bg-light .lsw-nav__link:hover { background:rgba(255,255,255,.12); color:#fff; }
body.lsw-has-hero-bg-light .lsw-utility__chip:hover { background:rgba(255,255,255,.12); }

/* Layout */
.lsw-h { max-width:1280px; margin:0 auto; padding:80px 32px 150px; display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; position:relative; }
.lsw-h__deco { position:absolute; top:120px; right:-80px; width:520px; height:520px; border-radius:50%; background:radial-gradient(circle, var(--accent-soft) 0%, transparent 70%); pointer-events:none; z-index:0; opacity:.7; }
.lsw-h__copy { position:relative; z-index:2; }

/* Badge */
.lsw-h__badge { display:inline-flex; align-items:center; gap:10px; padding:5px 14px 5px 5px; background:var(--white); border:1px solid var(--rule); border-radius:999px; font-size:12.5px; font-weight:600; color:var(--ink); margin-bottom:24px; opacity:0; box-shadow:0 6px 18px -10px rgba(15,15,15,.12), 0 1px 2px rgba(15,15,15,.04); }
.lsw-h__badge-icon { width:28px; height:28px; border-radius:9px; background:linear-gradient(135deg, var(--accent-soft) 0%, #F6DDD0 100%); color:var(--accent); display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; position:relative; overflow:hidden; }
.lsw-h__badge-icon::after { content:""; position:absolute; left:0; right:0; bottom:0; height:3px; background:var(--accent); opacity:.12; }
.lsw-h__badge-icon svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; overflow:visible; }
.lsw-h__badge-rod { stroke-width:1.8; }
.lsw-h__badge-curtain { transform-origin:12px 5px; animation:lsw-curtain-sway 5.5s ease-in-out infinite; }
.lsw-h__badge-curtain--r { animation-delay:-2.75s; }
@keyframes lsw-curtain-sway { 0%,100% { transform:rotate(0deg) scaleY(1); } 50% { transform:rotate(1.2deg) scaleY(.985); } }
.lsw-h__badge-txt { display:inline-flex; align-items:center; gap:8px; letter-spacing:-.005em; line-height:1; }
.lsw-h__badge-kicker { font-size:9.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); }
.lsw-h__badge-sep { width:3px; height:3px; border-radius:50%; background:var(--rule); }
.lsw-h__badge-loc { display:inline-flex; align-items:center; gap:4px; font-size:12px; font-weight:600; color:var(--ink-soft); }
.lsw-h__badge-loc svg { width:11px; height:11px; color:var(--accent); }

/* H1 */
.lsw-h__h1 { font-family:'Manrope',sans-serif; font-size:clamp(30px, 3.6vw, 50px); line-height:1.06; letter-spacing:-.025em; font-weight:700; margin:0 0 20px; color:var(--ink); }
.lsw-h__h1 .lsw-w { display:inline-block; overflow:hidden; vertical-align:bottom; padding:0 .04em .1em 0; }
.lsw-h__h1 .lsw-w > span { display:inline-block; }
.lsw-h__h1 em { font-style:normal; color:var(--accent); font-weight:700; }
.lsw-h__sub { font-size:15px; line-height:1.6; color:var(--body); max-width:440px; margin:0 0 28px; opacity:0; }

/* CTA buttons */
.lsw-h__cta { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:32px; opacity:0; }
.lsw-h__btn { position:relative; display:inline-flex; align-items:center; gap:10px; padding:13px 22px; font-size:13.5px; font-weight:600; border-radius:999px; text-decoration:none; transition:transform .35s cubic-bezier(.2,.7,.2,1), background .3s ease, color .3s ease; }
.lsw-h__btn--primary { background:var(--ink); color:var(--white); padding-right:8px; }
.lsw-h__btn--primary .lsw-h__btn-arrow { width:30px; height:30px; border-radius:50%; background:var(--accent); display:inline-flex; align-items:center; justify-content:center; transition:transform .35s cubic-bezier(.2,.7,.2,1); }
.lsw-h__btn--primary:hover { background:var(--accent); transform:translateY(-2px); }
.lsw-h__btn--primary:hover .lsw-h__btn-arrow { background:var(--white); color:var(--accent); transform:rotate(-45deg); }
.lsw-h__btn--primary svg { width:14px; height:14px; color:#fff; transition:color .3s ease; }
.lsw-h__btn--primary:hover svg { color:var(--accent); }
.lsw-h__btn--ghost { background:transparent; color:var(--ink); border:1px solid var(--rule); }
.lsw-h__btn--ghost:hover { background:var(--whatsapp); color:#fff; border-color:var(--whatsapp); transform:translateY(-2px); }
.lsw-h__btn--ghost svg { width:14px; height:14px; }

/* Meta avatars + stars */
.lsw-h__meta { display:flex; align-items:center; gap:16px; opacity:0; }
.lsw-h__avatars { display:flex; }
.lsw-h__av { width:30px; height:30px; border-radius:50%; border:2px solid var(--white); background:var(--bone); margin-left:-8px; box-shadow:0 2px 6px rgba(15,15,15,.08); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; color:var(--ink); }
.lsw-h__av:first-child { margin-left:0; }
.lsw-h__av--1 { background:linear-gradient(135deg, #D9D3C2, #B5AB95); color:#fff; }
.lsw-h__av--2 { background:linear-gradient(135deg, #C89F49, #A04432); color:#fff; }
.lsw-h__av--3 { background:linear-gradient(135deg, #6E7B71, #4D584F); color:#fff; }
.lsw-h__meta-txt { font-size:12.5px; color:var(--body); line-height:1.4; }
.lsw-h__meta-txt strong { display:block; color:var(--ink); font-size:13px; font-weight:600; }
.lsw-h__meta-stars { color:var(--accent); letter-spacing:1px; font-size:11px; }

/* Visual collage */
.lsw-h__visual { position:relative; z-index:1; aspect-ratio:1/1; max-height:560px; }
.lsw-h__photo { position:absolute; inset:0; border-radius:24px; overflow:hidden; background:var(--bone); box-shadow:0 30px 60px -30px rgba(15,15,15,.25); transform-origin:center; }
.lsw-h__photo img, .lsw-h__photo video { width:100%; max-width:100%; height:100%; object-fit:cover; display:block; will-change:transform; }
.lsw-h__photo-mask { position:absolute; inset:0; background:var(--white); transform-origin:left center; z-index:2; }

/* Floating brand-logo cards */
.lsw-h__brands { position:absolute; inset:-30px -40px -120px -40px; pointer-events:none; z-index:3; }
.lsw-brand-card { position:absolute; background:#fff; border-radius:18px; padding:16px 22px; box-shadow:0 24px 50px -20px rgba(15,15,15,.28), 0 6px 14px -6px rgba(15,15,15,.08); display:inline-flex; align-items:center; justify-content:center; pointer-events:auto; opacity:0; transform:translateY(20px); will-change:transform; }
.lsw-brand-card img { display:block; max-width:100%; width:auto; height:40px; object-fit:contain; pointer-events:none; user-select:none; }
.lsw-brand-card--sq { padding:14px; border-radius:20px; }
.lsw-brand-card--sq img { height:64px; width:64px; object-fit:contain; }
.lsw-brand-card--wide { padding:14px 22px; }
.lsw-brand-card--wide img { height:32px; }
.lsw-brand-card--feature { padding:18px 26px; border-radius:22px; }
.lsw-brand-card--feature img { height:52px; }

.lsw-bp--keje    { top:50px;  left:-100px; transform:translateY(20px) rotate(-3deg); }
.lsw-bp--keje.is-in    { transform:translateY(0) rotate(-3deg); }
.lsw-bp--ambiant { top:50px;  right:-32px; transform:translateY(20px) rotate(3deg); }
.lsw-bp--ambiant.is-in { transform:translateY(0) rotate(3deg); }
.lsw-bp--life    { top:58%;   right:-72px; transform:translateY(20px) rotate(4deg); }
.lsw-bp--life.is-in { transform:translateY(0) rotate(4deg); }
.lsw-bp--spiver  { top:62%;   left:-44px; transform:translateY(20px) rotate(-4deg); }
.lsw-bp--spiver.is-in { transform:translateY(0) rotate(-4deg); }
.lsw-bp--tacito  { bottom:36px; left:14%; transform:translateY(20px) rotate(-2deg); }
.lsw-bp--tacito.is-in { transform:translateY(0) rotate(-2deg); }
.lsw-bp--mv      { bottom:14px; left:46%; transform:translateY(20px) rotate(3deg); }
.lsw-bp--mv.is-in    { transform:translateY(0) rotate(3deg); }

.lsw-h__dot-line { position:absolute; height:1px; border-top:1.5px dashed var(--rule); z-index:2; pointer-events:none; opacity:.7; }
.lsw-h__dot-line--1 { top:62px; left:8px; width:78px; transform:rotate(-12deg); }
.lsw-h__dot-line--2 { bottom:78px; right:-8px; width:64px; transform:rotate(18deg); }

@media (max-width: 1100px) {
    .lsw-h__brands { inset:-20px -16px -110px -16px; }
    .lsw-bp--keje    { left:-40px; }
    .lsw-bp--ambiant { right:-12px; }
    .lsw-bp--life    { right:-30px; }
    .lsw-bp--spiver  { left:-20px; }
}
@media (max-width: 1024px) {
    .lsw-h { grid-template-columns:1fr; gap:80px; padding:64px 20px 170px; }
    .lsw-h__visual { max-width:520px; margin:0 auto; width:100%; }
    .lsw-h__brands { inset:-16px -8px -120px -8px; }
    .lsw-bp--keje    { left:-16px; top:40px; }
    .lsw-bp--ambiant { right:-12px; top:40px; }
    .lsw-bp--life    { right:-12px; top:60%; }
    .lsw-bp--spiver  { left:-8px; top:64%; }
    .lsw-bp--tacito  { bottom:38px; left:14%; }
    .lsw-bp--mv      { bottom:12px; left:46%; }
}
@media (max-width: 720px) {
    .lsw-h { padding:48px 16px 150px; gap:56px; }
    .lsw-h__sub { margin-bottom:22px; }
}
@media (max-width: 640px) {
    .lsw-h__h1 { font-size:32px; }
    .lsw-h { padding-bottom:150px; }
    .lsw-h__brands { inset:-10px -2px -100px -2px; }
    .lsw-brand-card { padding:8px 12px; border-radius:12px; box-shadow:0 14px 28px -14px rgba(15,15,15,.25), 0 3px 8px -3px rgba(15,15,15,.08); }
    .lsw-brand-card img { height:20px; }
    .lsw-brand-card--sq { padding:7px; border-radius:13px; }
    .lsw-brand-card--sq img { height:32px; width:32px; }
    .lsw-brand-card--wide { padding:8px 12px; }
    .lsw-brand-card--wide img { height:16px; }
    .lsw-brand-card--feature { padding:10px 14px; border-radius:14px; }
    .lsw-brand-card--feature img { height:26px; }
    .lsw-bp--keje    { left:-4px;  top:14px; }
    .lsw-bp--ambiant { right:-4px; top:14px; }
    .lsw-bp--life    { right:-4px; top:58%; }
    .lsw-bp--spiver  { left:-4px;  top:60%; }
    .lsw-bp--tacito  { bottom:32px; left:4%; }
    .lsw-bp--mv      { bottom:10px; left:44%; }
    .lsw-h__cue { display:none; }
}
@media (max-width: 380px) {
    .lsw-brand-card img { height:16px; }
    .lsw-brand-card--sq img { height:26px; width:26px; }
    .lsw-brand-card--wide img { height:13px; }
    .lsw-brand-card--feature img { height:22px; }
    .lsw-brand-card { padding:6px 10px; }
    .lsw-brand-card--sq { padding:6px; }
    .lsw-brand-card--feature { padding:8px 12px; }
}

/* Scroll cue — gordijn-trekkoord met bead */
.lsw-h__cue { position:absolute; left:50%; bottom:24px; transform:translateX(-50%); display:inline-flex; flex-direction:column; align-items:center; gap:14px; padding:0; background:transparent; border:0; cursor:pointer; font-family:inherit; opacity:0; z-index:4; transition:transform .35s cubic-bezier(.2,.7,.2,1); }
.lsw-h__cue:hover { transform:translateX(-50%) translateY(3px); }
.lsw-h__cue:focus-visible { outline:2px solid var(--accent); outline-offset:6px; border-radius:6px; }
.lsw-h__cue-track { position:relative; width:34px; height:62px; }
.lsw-h__cue-rod { position:absolute; top:0; left:50%; transform:translateX(-50%); width:24px; height:2px; background:var(--cue-ink); border-radius:2px; opacity:.85; }
.lsw-h__cue-rod::before, .lsw-h__cue-rod::after { content:""; position:absolute; top:50%; transform:translateY(-50%); width:5px; height:5px; border-radius:50%; background:var(--cue-ink); }
.lsw-h__cue-rod::before { left:-4px; }
.lsw-h__cue-rod::after { right:-4px; }
.lsw-h__cue-line { position:absolute; top:2px; left:50%; transform:translateX(-50%); width:1px; height:46px; background:linear-gradient(180deg, var(--cue-ink) 0%, var(--cue-ink) 72%, transparent 100%); opacity:.5; }
.lsw-h__cue-bead { position:absolute; top:4px; left:50%; width:9px; height:9px; margin-left:-4.5px; border-radius:50%; background:var(--cue-bead); box-shadow:0 2px 6px rgba(200,159,73,.45); animation:lsw-cue-drop 2.6s cubic-bezier(.55,0,.25,1) infinite; }
.lsw-h__cue-bead::after { content:""; position:absolute; top:-6px; left:50%; transform:translateX(-50%); width:1px; height:6px; background:var(--cue-bead); opacity:.6; border-radius:1px; }
@keyframes lsw-cue-drop {
    0%   { top:4px;  opacity:0;   transform:scale(.55); }
    18%  { top:4px;  opacity:1;   transform:scale(1); }
    72%  { top:42px; opacity:1;   transform:scale(1); }
    100% { top:42px; opacity:0;   transform:scale(.6); }
}
.lsw-h__cue-label { font-size:10.5px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--cue-ink); opacity:.7; display:inline-flex; align-items:center; gap:6px; }
.lsw-h__cue-arrow { width:11px; height:11px; transition:transform .35s cubic-bezier(.2,.7,.2,1); }
.lsw-h__cue:hover .lsw-h__cue-arrow { transform:translateY(2px); }

@media (prefers-reduced-motion: reduce) {
    .lsw-h__badge-curtain { animation:none !important; }
    .lsw-h__h1 .lsw-w > span { transform:none !important; }
    .lsw-h__badge, .lsw-h__sub, .lsw-h__cta, .lsw-h__meta, .lsw-brand-card, .lsw-h__cue { opacity:1 !important; }
    .lsw-h__photo-mask { display:none; }
    .lsw-h__cue-bead { animation:none !important; top:4px !important; opacity:1 !important; }
}
