/* LS Wonen — Process Timeline */
.lsw-pt-section { --white:#FFFFFF; --bone:#F8F6F2; --ink:#14151A; --body:#6E707A; --rule:#ECECEA; --accent:#C89F49; --accent-soft:#FCEFE8; --green:#3FB67A; font-family:'Manrope',system-ui,sans-serif; background:var(--white); color:var(--ink); position:relative; }
.lsw-pt-section *, .lsw-pt-section *::before, .lsw-pt-section *::after { box-sizing:border-box; }
.lsw-pt { max-width:1280px; margin:0 auto; padding:96px 32px; }
.lsw-pt__head { text-align:center; max-width:640px; margin:0 auto 64px; }
.lsw-pt__eyebrow { display:inline-flex; align-items:center; gap:10px; padding:5px 14px 5px 5px; background:#fff; border:1px solid var(--rule); border-radius:999px; font-size:12.5px; font-weight:600; color:var(--ink); margin-bottom:18px; box-shadow:0 6px 18px -10px rgba(15,15,15,.12), 0 1px 2px rgba(15,15,15,.04); letter-spacing:-.005em; }
.lsw-pt__eyebrow-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; }
.lsw-pt__eyebrow-icon svg { width:16px; height:16px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.lsw-pt__h2 { font-size:clamp(26px, 3vw, 40px); line-height:1.1; letter-spacing:-.02em; font-weight:700; margin:0 0 14px; color:var(--ink); }
.lsw-pt__intro { font-size:15px; line-height:1.6; color:var(--body); margin:0; }

.lsw-pt__body { display:grid; grid-template-columns:1fr 320px; gap:64px; align-items:flex-start; position:relative; }
.lsw-pt__steps { position:relative; padding-left:20px; }
.lsw-pt__rail { position:absolute; top:24px; bottom:24px; left:39px; width:0; border-left:2px dashed var(--rule); }
.lsw-pt__rail-fill { position:absolute; top:-2px; left:-2px; bottom:0; width:0; border-left:2px solid var(--accent); transform-origin:top; height:0; }
.lsw-pt__step { display:grid; grid-template-columns:60px 1fr; gap:20px; padding:0 0 28px; position:relative; opacity:0; transform:translateX(-12px); }
.lsw-pt__step:last-child { padding-bottom:0; }
.lsw-pt__node { width:40px; height:40px; border-radius:12px; background:var(--white); border:1px solid var(--rule); display:flex; align-items:center; justify-content:center; color:var(--ink); position:relative; z-index:1; transition:background .4s ease, color .4s ease, border-color .4s ease, transform .4s cubic-bezier(.2,.7,.2,1); margin-top:6px; margin-left:0; }
.lsw-pt__node svg { width:18px; height:18px; }
.lsw-pt__step.is-active .lsw-pt__node { background:var(--accent); color:#fff; border-color:var(--accent); transform:scale(1.06); }
.lsw-pt__card { background:var(--white); border:1px solid var(--rule); border-radius:14px; padding:16px 18px; transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease, border-color .3s ease; }
.lsw-pt__step:hover .lsw-pt__card { transform:translateY(-2px); box-shadow:0 14px 30px -14px rgba(15,15,15,.14); border-color:transparent; }
.lsw-pt__step-num { font-size:11px; font-weight:700; letter-spacing:.18em; color:var(--accent); margin:0 0 4px; }
.lsw-pt__step-title { font-size:17px; font-weight:700; line-height:1.2; margin:0 0 6px; letter-spacing:-.01em; color:var(--ink); }
.lsw-pt__step-body { font-size:13.5px; line-height:1.5; color:var(--body); margin:0; max-width:480px; }

.lsw-pt__visual { position:sticky; top:32px; background:var(--bone); border-radius:24px; padding:24px; box-shadow:0 30px 60px -30px rgba(15,15,15,.16); }
.lsw-pt__visual::before { content:""; position:absolute; top:-20px; right:-20px; width:80px; height:80px; border-radius:50%; background:var(--accent-soft); z-index:-1; filter:blur(20px); }
.lsw-pt__chip { display:inline-flex; align-items:center; gap:8px; padding:5px 12px 5px 6px; background:var(--white); border:1px solid var(--rule); border-radius:999px; font-size:11px; font-weight:700; color:var(--accent); margin-bottom:14px; letter-spacing:.08em; text-transform:uppercase; }
.lsw-pt__chip::before { content:""; width:6px; height:6px; border-radius:50%; background:var(--accent); }
.lsw-pt__visual-h { font-size:20px; font-weight:700; line-height:1.2; margin:0 0 6px; color:var(--ink); letter-spacing:-.01em; }
.lsw-pt__visual-sub { font-size:13.5px; line-height:1.55; color:var(--body); margin:0 0 18px; }
.lsw-pt__usps { list-style:none; margin:0 0 18px; padding:0; display:flex; flex-direction:column; gap:6px; }
.lsw-pt__usp { display:flex; align-items:flex-start; gap:10px; padding:10px 12px; background:var(--white); border-radius:10px; transition:transform .3s cubic-bezier(.2,.7,.2,1), background .3s ease; }
.lsw-pt__usp:hover { background:var(--accent-soft); transform:translateX(2px); }
.lsw-pt__usp-icon { width:24px; height:24px; border-radius:50%; background:var(--accent-soft); color:var(--accent); display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; transition:background .3s ease, color .3s ease, transform .3s cubic-bezier(.2,.7,.2,1); }
.lsw-pt__usp:hover .lsw-pt__usp-icon { background:var(--accent); color:#fff; transform:rotate(-8deg); }
.lsw-pt__usp-icon svg { width:13px; height:13px; stroke:currentColor; fill:none; stroke-width:2.6; stroke-linecap:round; stroke-linejoin:round; }
.lsw-pt__usp-txt { line-height:1.3; }
.lsw-pt__usp-txt strong { display:block; font-size:13px; font-weight:700; color:var(--ink); }
.lsw-pt__usp-txt span { font-size:11.5px; color:var(--body); }
.lsw-pt__plan-btn { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:11px 12px 11px 16px; background:var(--ink); color:#fff; border-radius:10px; font-size:13px; font-weight:600; text-decoration:none; transition:background .3s ease; }
.lsw-pt__plan-btn:hover { background:var(--accent); }
.lsw-pt__plan-arrow { width:26px; height:26px; border-radius:50%; background:var(--accent); display:inline-flex; align-items:center; justify-content:center; transition:background .3s ease, transform .3s ease; }
.lsw-pt__plan-btn:hover .lsw-pt__plan-arrow { background:#fff; color:var(--accent); transform:rotate(-45deg); }
.lsw-pt__plan-arrow svg { width:12px; height:12px; }

@media (max-width: 1024px) {
    .lsw-pt { padding:72px 20px; }
    .lsw-pt__body { grid-template-columns:1fr; gap:48px; }
    .lsw-pt__visual { position:static; max-width:380px; margin:0 auto; width:100%; }
}
@media (max-width: 720px) {
    .lsw-pt { padding:56px 16px; }
    .lsw-pt__head { margin-bottom:44px; }
    .lsw-pt__body { gap:36px; }
    .lsw-pt__visual { padding:20px; border-radius:20px; }
}
@media (max-width: 560px) {
    .lsw-pt__step { grid-template-columns:44px 1fr; gap:14px; }
    .lsw-pt__node { width:36px; height:36px; }
    .lsw-pt__rail { left:37px; }
}
@media (prefers-reduced-motion: reduce) {
    .lsw-pt__step { opacity:1 !important; transform:none !important; }
    .lsw-pt__rail-fill { height:100% !important; }
}
