/* Dutch'n Decent — component styles */

/* ========== RESET + BASE ========== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh;min-height:100dvh}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;cursor:pointer}
button{font:inherit;cursor:pointer;border:0;background:none}
button,.btn,a.btn,.icon-btn{min-height:44px;touch-action:manipulation}

/* ========== TOPBAR ========== */
.topbar{background:var(--black);color:#cfcfcf;font-size:13px;border-bottom:1px solid var(--line)}
.topbar__inner{max-width:var(--container);margin:0 auto;padding:10px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar__left{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.topbar__left span{display:inline-flex;align-items:center;gap:8px}
.dot{width:6px;height:6px;border-radius:50%;background:var(--red)}

/* ========== HEADER ========== */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid #ececec}
.header__inner{max-width:var(--container);margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo img{height:54px;width:auto}
.nav{display:flex;gap:22px;font-weight:600;font-size:13px;letter-spacing:.02em}
.nav a{position:relative;padding:6px 0}
.nav a::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.nav a:hover::after{transform:scaleX(1)}
.header__cta{display:flex;gap:12px;align-items:center}
.icon-btn{width:42px;height:42px;border-radius:50%;border:1px solid #e6e6e6;display:grid;place-items:center;transition:.2s}
.icon-btn:hover{border-color:var(--red);color:var(--red)}

/* ========== BUTTONS ========== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;font-weight:600;font-size:14px;letter-spacing:.02em;border-radius:8px;transition:.25s}
.header .btn{padding:10px 18px;font-size:13px}
.btn--red{background:var(--red);color:#fff}
.btn--red:hover{background:var(--red-dark);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn--dark{background:var(--black);color:#fff}
.btn--dark:hover{background:#222}
.btn .arr{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:11px}

/* ========== HERO ========== */
.hero{position:relative;background:var(--black);color:#fff;overflow:hidden;min-height:88vh;display:flex;align-items:center}
.hero__bg{position:absolute;inset:0;background-image:radial-gradient(ellipse at 70% 30%,rgba(227,6,19,.28),transparent 55%),linear-gradient(120deg,#0a0a0a 0%,#161616 60%,#0a0a0a 100%)}
.hero__inner{position:relative;z-index:2;max-width:var(--container);margin:0 auto;padding:80px 24px;width:100%;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero__eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:#cfcfcf;margin-bottom:24px}
.hero__eyebrow::before{content:"";width:40px;height:1px;background:var(--red)}
.hero__title{font-family:var(--display);font-size:clamp(48px,6.5vw,108px);line-height:.95;margin:0 0 28px;letter-spacing:.5px;text-transform:uppercase}
.hero__title em{font-style:normal;color:var(--red);display:block}
.hero__lead{font-size:18px;color:#bdbdbd;max-width:560px;margin:0 0 36px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero__meta{margin-top:60px;display:flex;gap:40px;color:#9a9a9a;font-size:13px;flex-wrap:wrap}
.hero__meta b{display:block;color:#fff;font-family:var(--display);font-size:30px;font-weight:400;line-height:1;margin-bottom:4px}
.hero__meta div{position:relative;padding-right:40px}
.hero__meta div:last-child{padding-right:0}
.hero__meta div:not(:last-child)::after{content:"";position:absolute;right:0;top:4px;bottom:4px;width:1px;background:rgba(255,255,255,.15)}
.hero__visual{position:relative;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;background:linear-gradient(155deg,#1a1a1a,#2a2a2a);border:1px solid var(--line)}
.hero__visual::before{content:"";position:absolute;inset:0;background:var(--heroimg) center/cover;filter:contrast(1.05) brightness(.85)}
.hero__visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.6) 100%)}
.hero__badge{position:absolute;top:24px;left:24px;z-index:2;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);padding:10px 16px;border-radius:999px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,.15);color:#fff}
.hero__badge .dot{display:inline-block;margin-right:8px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero__quote{position:absolute;bottom:24px;left:24px;right:24px;z-index:2;background:rgba(255,255,255,.06);backdrop-filter:blur(12px);padding:20px 24px;border-radius:14px;border:1px solid rgba(255,255,255,.12);font-size:14px;color:#fff}
.hero__quote b{display:block;font-family:var(--display);font-size:20px;margin-bottom:4px;letter-spacing:.5px}
.hero__urgency{display:inline-flex;align-items:center;gap:8px;background:rgba(227,6,19,.12);border:1px solid rgba(227,6,19,.3);color:#ffb8bc;padding:8px 14px;border-radius:999px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;margin-bottom:18px}
.hero__urgency .dot{background:var(--red);width:6px;height:6px;border-radius:50%;animation:pulse 2s infinite}

/* ========== CATEGORIES GRID (homepage) ========== */
.cats{background:var(--black);padding:0;overflow:hidden}
.cats__head{max-width:var(--container);margin:0 auto;padding:80px 24px 50px;color:#fff;display:flex;justify-content:space-between;align-items:flex-end;gap:40px}
.cats__head h2{font-family:var(--display);font-size:clamp(36px,4vw,64px);line-height:1;margin:0;text-transform:uppercase;letter-spacing:.5px;max-width:760px}
.cats__head h2 em{font-style:normal;color:var(--red)}
.cats__head p{margin:0;color:#999;font-size:14px;max-width:300px}
.cats__grid{display:grid;grid-template-columns:repeat(6,1fr)}
.cat{position:relative;aspect-ratio:3/4;overflow:hidden;cursor:pointer;border-right:1px solid rgba(255,255,255,.08);min-height:380px}
.cat:last-child{border-right:none}
.cat__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s ease,filter .4s ease;filter:grayscale(.3) brightness(.6)}
.cat:hover .cat__img{transform:scale(1.06);filter:grayscale(0) brightness(.75)}
.cat__overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(0,0,0,.92) 95%)}
.cat__label{position:absolute;left:24px;bottom:130px;transform-origin:left bottom;transform:rotate(-90deg);font-family:var(--display);font-size:28px;color:#fff;letter-spacing:1px;text-transform:uppercase;line-height:1;white-space:nowrap;text-shadow:0 4px 30px rgba(0,0,0,.9);pointer-events:none}
.cat__bottom{position:absolute;left:24px;right:24px;bottom:24px;color:#fff;z-index:2}
.cat__bottom p{margin:0 0 14px;font-size:13px;color:#e5e5e5;line-height:1.55;max-width:230px}
.cat__bottom span{display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding-bottom:6px;border-bottom:2px solid var(--red)}
.cat__link{position:absolute;inset:0;z-index:5;font-size:0;text-indent:-9999px;overflow:hidden;white-space:nowrap}
.cat__link:focus-visible{outline:3px solid var(--red);outline-offset:-3px;border-radius:var(--radius)}

/* ========== USPS (4 icon items) ========== */
.usps{background:var(--bone);padding:60px 24px}
.usps__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:32px}
.usp{display:flex;gap:18px;align-items:flex-start}
.usp__icon{flex:0 0 52px;height:52px;border-radius:14px;background:#fff;display:grid;place-items:center;color:var(--red);box-shadow:var(--shadow-sm)}
.usp__icon svg{width:24px;height:24px}
.usp h4{margin:0 0 4px;font-size:15px;font-weight:700;letter-spacing:.02em}
.usp p{margin:0;font-size:13px;color:#666}

/* ========== INTRO (text + image) ========== */
.intro{padding:120px 24px;background:#fff}
.intro__inner{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.intro__visual{aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;background-size:cover;background-position:center;position:relative}
.intro__visual::after{content:"";position:absolute;left:-30px;bottom:-30px;width:120px;height:120px;background:var(--red);border-radius:50%}
.intro__eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:var(--red);font-weight:700;margin-bottom:24px}
.intro__eyebrow::before{content:"";width:30px;height:1px;background:var(--red)}
.intro h2{font-family:var(--display);font-size:clamp(40px,5vw,72px);line-height:.95;margin:0 0 24px;text-transform:uppercase;letter-spacing:.5px}
.intro h2 em{font-style:normal;color:var(--red)}
.intro p{font-size:16px;color:#555;margin:0 0 20px;line-height:1.7}

/* ========== OFFERTE block ========== */
.offerte{background:var(--black);color:#fff;padding:90px 24px;position:relative;overflow:hidden}
.offerte::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(227,6,19,.15),transparent 70%)}
.offerte__inner{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.offerte h3{font-family:var(--display);font-size:clamp(36px,4vw,60px);line-height:1;margin:0 0 24px;text-transform:uppercase;letter-spacing:.5px}
.offerte p{color:#bbb;font-size:16px;max-width:480px;margin:0 0 32px}
.offerte__cta{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.offerte__cta a.alt{font-size:14px;text-decoration:underline;color:#ddd}
.offerte__visual{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background-size:cover;background-position:center}
.offerte__circle{position:absolute;top:-30px;right:-30px;width:160px;height:160px;border-radius:50%;background:var(--red);display:grid;place-items:center;color:#fff;font-family:var(--display);text-align:center;font-size:14px;line-height:1.2;letter-spacing:.05em;text-transform:uppercase;transform:rotate(-12deg);box-shadow:0 20px 40px rgba(227,6,19,.3)}

/* ========== SECTION HEADER ========== */
.section__head{max-width:var(--container);margin:0 auto 60px;display:flex;justify-content:space-between;align-items:flex-end;gap:40px}
.section__head h2{font-family:var(--display);font-size:clamp(40px,4.5vw,68px);line-height:.95;margin:0;text-transform:uppercase;letter-spacing:.5px}
.section__head h2 em{font-style:normal;color:var(--red)}
.section__head p{margin:0;color:#666;font-size:15px;max-width:380px}

/* ========== PROCES (4 steps) ========== */
.proces{padding:120px 24px;background:var(--bone)}
.proces__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{padding:36px 28px;border:1px solid #e5e0d8;border-radius:var(--radius);transition:.3s;background:#fff;position:relative}
.step:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.step__num{font-family:var(--display);font-size:64px;color:var(--bone);line-height:1;margin-bottom:16px}
.step:hover .step__num{color:var(--red)}
.step h4{margin:0 0 10px;font-size:18px;font-weight:700}
.step p{margin:0;color:#666;font-size:14px;line-height:1.6}

/* ========== VALUES (5 items) ========== */
.values{padding:120px 24px;background:#fff}
.values__grid{max-width:var(--container);margin:60px auto 0;display:grid;grid-template-columns:repeat(5,1fr);gap:24px}
.value{text-align:center;padding:30px 20px;border-right:1px solid #eee}
.value:last-child{border-right:none}
.value__num{font-family:var(--display);font-size:24px;color:var(--red);margin-bottom:14px;letter-spacing:.05em}
.value h4{font-family:var(--display);font-size:24px;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}
.value p{margin:0;color:#666;font-size:13px;line-height:1.6}

/* ========== CASES (large photo cards) ========== */
.cases{padding:120px 24px;background:var(--bone)}
.cases__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.case{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;cursor:pointer}
.case__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s ease}
.case:hover .case__img{transform:scale(1.05)}
.case__overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.85) 100%)}
.case__content{position:absolute;left:36px;right:36px;bottom:36px;color:#fff}
.case__tag{display:inline-block;font-size:11px;letter-spacing:.15em;text-transform:uppercase;background:var(--red);color:#fff;padding:6px 12px;border-radius:999px;margin-bottom:14px}
.case h4{font-family:var(--display);font-size:32px;margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px;line-height:1}
.case p{margin:0 0 18px;font-size:14px;color:#d4d4d4;max-width:420px;line-height:1.6}
.case a{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.case a .arr{width:32px;height:32px;border-radius:50%;background:var(--red);display:grid;place-items:center}

/* ========== BEHIND THE SCENES (masonry) ========== */
.behind{padding:120px 24px;background:#fff}
.behind__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:16px}
.behind__item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;background:#1a1a1a}
.behind__item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .4s ease}
.behind__item:hover img{transform:scale(1.06);filter:brightness(1.1)}
.behind__item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.5) 100%)}
.behind__tag{position:absolute;left:18px;bottom:18px;z-index:2;background:rgba(255,255,255,.95);color:var(--ink);padding:7px 14px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.behind__item--tall{grid-row:span 2}
.behind__item--wide{grid-column:span 2}

/* ========== TESTIMONIAL QUOTE ========== */
.quote{background:linear-gradient(155deg,#0a0a0a,#1a1a1a);color:#fff;padding:120px 24px;text-align:center;position:relative;overflow:hidden}
.quote::before{content:"";position:absolute;top:50%;left:50%;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(227,6,19,.1),transparent 70%);transform:translate(-50%,-50%)}
.quote__inner{max-width:880px;margin:0 auto;position:relative}
.quote__mark{font-family:var(--display);font-size:140px;color:var(--red);line-height:.6;margin-bottom:0}
.quote blockquote{font-family:var(--display);font-size:clamp(28px,3.5vw,44px);line-height:1.2;margin:0 0 32px;text-transform:uppercase;letter-spacing:.3px}
.quote cite{display:block;font-style:normal;font-size:13px;letter-spacing:.15em;text-transform:uppercase;color:#999}
.quote cite b{display:block;color:#fff;margin-bottom:4px;font-size:14px}

/* ========== BRANDS MARQUEE ========== */
.brands{padding:80px 24px;background:#fff;border-top:1px solid #f0f0f0;border-bottom:1px solid #f0f0f0;overflow:hidden}
.brands__head{text-align:center;margin-bottom:50px}
.brands__head span{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);font-weight:700}
.brands__head h3{font-family:var(--display);font-size:clamp(28px,3vw,42px);text-transform:uppercase;margin:10px 0 0;letter-spacing:.5px}
.brands__marquee{max-width:100%;overflow:hidden;position:relative;display:flex;flex-wrap:nowrap;white-space:nowrap;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.brands__track{display:inline-flex;flex:0 0 auto;gap:70px;align-items:center;animation:bMarquee 45s linear infinite;padding-left:70px}
.brands__track img{max-height:44px;width:auto;filter:grayscale(1) opacity(.55);transition:.3s;flex-shrink:0}
.brands__track img:hover{filter:grayscale(0) opacity(1)}
@keyframes bMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.brands__track{animation:none}}

/* ========== FINAL CTA ========== */
.finalcta{background:var(--red);color:#fff;padding:100px 24px;text-align:center;position:relative;overflow:hidden}
.finalcta::before,.finalcta::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.05)}
.finalcta::before{top:-150px;left:-150px}
.finalcta::after{bottom:-150px;right:-150px}
.finalcta__inner{max-width:780px;margin:0 auto;position:relative}
.finalcta h2{font-family:var(--display);font-size:clamp(40px,5vw,72px);line-height:1;margin:0 0 20px;text-transform:uppercase;letter-spacing:.5px}
.finalcta p{font-size:18px;color:rgba(255,255,255,.9);margin:0 0 36px}
.finalcta .btn{background:#fff;color:var(--red)}
.finalcta .btn:hover{background:var(--ink);color:#fff}

/* ========== FOOTER ========== */
.footer{background:var(--black);color:#999;padding:80px 24px 30px}
.footer__grid{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;padding-bottom:60px;border-bottom:1px solid var(--line)}
.footer__brand img{height:60px;margin-bottom:24px;filter:brightness(0) invert(1)}
.footer__brand p{font-size:14px;line-height:1.7;max-width:340px;margin:0 0 24px}
.footer__social{display:flex;gap:12px}
.footer__social a{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:.2s}
.footer__social a:hover{background:var(--red);border-color:var(--red);color:#fff}
.footer h5{color:#fff;font-size:14px;letter-spacing:.05em;text-transform:uppercase;margin:0 0 20px}
.footer ul{list-style:none;padding:0;margin:0;font-size:14px;line-height:2}
.footer ul a:hover{color:var(--red)}
.footer__contact li{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px;line-height:1.5}
.footer__contact svg{flex-shrink:0;margin-top:2px;width:14px;height:14px}
.footer__social svg{width:16px;height:16px}
.sticky-cta__icon svg{width:20px;height:20px}
.usp__icon svg{width:24px;height:24px}
.guarantee__icon svg{width:24px;height:24px}
.topbar__left svg,.hero__badge svg,.hero__quote svg{width:14px;height:14px}
.btn svg{width:16px;height:16px}
svg{max-width:100%}
.footer__bottom{max-width:var(--container);margin:0 auto;padding-top:30px;display:flex;justify-content:space-between;font-size:13px;flex-wrap:wrap;gap:16px}
.footer__bottom a:hover{color:var(--red)}

/* ========== TRUST BAR ========== */
.trustbar{background:#fff;border-bottom:1px solid #eee;padding:22px 24px}
.trustbar__inner{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:24px;align-items:center}
.trustbar__item{display:flex;gap:14px;align-items:center;font-size:13px;color:#555;line-height:1.35}
.trustbar__item svg{flex:0 0 28px;color:var(--red)}
.trustbar__item b{display:block;color:var(--ink);font-family:var(--display);font-size:22px;letter-spacing:.3px;line-height:1}

/* ========== LOGO STRIP (secondary marquee) ========== */
.logos-strip{background:var(--bone);padding:40px 0;border-bottom:1px solid #ece8df;overflow:hidden;position:relative}
.logos-strip__label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#888;font-weight:700;max-width:var(--container);margin:0 auto 20px;padding:0 24px;text-align:center}
.logos-strip__marquee{display:flex;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 10%,#000 90%,transparent 100%)}
.logos-strip__track{display:flex;gap:70px;align-items:center;padding:0 35px;animation:logos-scroll 35s linear infinite;flex-shrink:0;min-width:100%;justify-content:space-around}
.logos-strip__marquee:hover .logos-strip__track{animation-play-state:paused}
.logos-strip__track img{max-height:40px;width:auto;filter:grayscale(1) opacity(.55);transition:.3s;flex-shrink:0}
.logos-strip__track img:hover{filter:grayscale(0) opacity(1)}
@keyframes logos-scroll{from{transform:translateX(0)}to{transform:translateX(-100%)}}
@media (prefers-reduced-motion:reduce){.logos-strip__track{animation:none;flex-wrap:wrap;justify-content:center}}

/* ========== FAQ ========== */
.faq{padding:120px 24px;background:#fff}
.faq__inner{max-width:920px;margin:0 auto}
.faq__item{border-bottom:1px solid #ece8df;padding:0}
.faq__q{width:100%;text-align:left;padding:30px 0;font-family:var(--display);font-size:24px;letter-spacing:.3px;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center;gap:24px;color:var(--ink);background:none;border:0;cursor:pointer;font-weight:400;line-height:1.15}
.faq__q:hover{color:var(--red)}
.faq__q .plus{flex:0 0 40px;width:40px;height:40px;border-radius:50%;background:var(--bone);display:grid;place-items:center;font-size:22px;color:var(--red);transition:.3s}
.faq__item.open .faq__q .plus{background:var(--red);color:#fff;transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .5s ease,padding .4s ease;color:#3a3a3a;font-size:18px;line-height:1.75;max-width:72ch;font-weight:400}
.faq__item.open .faq__a{max-height:600px;padding:4px 0 32px}

/* ========== GUARANTEE BLOCK ========== */
.guarantee{background:var(--bone);padding:100px 24px}
.guarantee__inner{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.guarantee__item{background:#fff;padding:36px 28px;border-radius:var(--radius);border:1px solid #ece8df;text-align:left;transition:.25s}
.guarantee__item:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.guarantee__icon{width:52px;height:52px;border-radius:14px;background:var(--bone);display:grid;place-items:center;color:var(--red);margin-bottom:20px}
.guarantee__item h4{margin:0 0 10px;font-size:17px;font-weight:700}
.guarantee__item p{margin:0;color:#666;font-size:14px;line-height:1.6}

/* ========== COMPARE BLOCK (good vs bad) ========== */
.compare{padding:120px 24px;background:#fff}
.compare__grid{max-width:var(--container);margin:60px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.compare__col{padding:40px 36px;border-radius:var(--radius);position:relative}
.compare__col--bad{background:#faf8f4;border:1px solid #ece8df}
.compare__col--good{background:var(--ink);color:#fff}
.compare__col h4{font-family:var(--display);font-size:24px;text-transform:uppercase;letter-spacing:.5px;margin:0 0 24px;display:flex;align-items:center;gap:12px}
.compare__col--bad h4{color:#999}
.compare__col ul{list-style:none;padding:0;margin:0}
.compare__col li{padding:12px 0 12px 34px;position:relative;font-size:15px;line-height:1.55}
.compare__col--bad li{color:#777;border-bottom:1px dashed #e5e0d8}
.compare__col--bad li::before{content:"×";position:absolute;left:0;top:8px;width:22px;height:22px;border-radius:50%;background:#ece8df;color:#999;display:grid;place-items:center;font-size:14px;font-weight:700}
.compare__col--good li{color:#d4d4d4;border-bottom:1px solid rgba(255,255,255,.08)}
.compare__col--good li::before{content:"✓";position:absolute;left:0;top:8px;width:22px;height:22px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700}
.compare__col li:last-child{border-bottom:none}

/* ========== STICKY CTA ========== */
.sticky-cta{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(180%);background:var(--ink);color:#fff;border-radius:999px;padding:0;display:flex;align-items:stretch;box-shadow:0 24px 60px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.06);z-index:100;transition:transform .45s var(--ease);overflow:hidden;max-width:calc(100vw - 24px)}
.sticky-cta.show{transform:translateX(-50%) translateY(0)}
.sticky-cta__call{display:flex;align-items:center;gap:14px;padding:12px 10px 12px 18px;color:#fff;text-decoration:none;min-height:56px}
.sticky-cta__call:hover{background:rgba(255,255,255,.04)}
.sticky-cta__icon{flex:0 0 40px;width:40px;height:40px;border-radius:50%;background:var(--red);display:grid;place-items:center;color:#fff;box-shadow:0 6px 20px rgba(227,6,19,.4)}
.sticky-cta__text{display:flex;flex-direction:column;line-height:1.25;min-width:0}
.sticky-cta__text b{color:#fff;font-size:14px;font-weight:700;letter-spacing:.01em;white-space:nowrap}
.sticky-cta__text em{color:#999;font-style:normal;font-size:12px;font-family:var(--sans);margin-top:2px;white-space:nowrap}
.sticky-cta__arrow{color:#fff;font-size:18px;padding:0 14px 0 6px;opacity:.5;transition:.2s}
.sticky-cta__call:hover .sticky-cta__arrow{opacity:1;transform:translateX(4px)}
.sticky-cta__close{background:none;border:0;border-left:1px solid rgba(255,255,255,.08);color:#888;cursor:pointer;width:48px;display:grid;place-items:center;flex-shrink:0;transition:.2s}
.sticky-cta__close:hover{color:#fff;background:rgba(255,255,255,.04)}

/* ========== FORM SUCCESS ========== */
.form-success{padding:50px 40px;background:linear-gradient(155deg,#0a0a0a,#1a1a1a);color:#fff;border-radius:var(--radius);text-align:center;position:relative;overflow:hidden}
.form-success::before{content:"";position:absolute;top:50%;left:50%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(227,6,19,.12),transparent 70%);transform:translate(-50%,-50%);pointer-events:none}
.form-success__icon{position:relative;width:80px;height:80px;border-radius:50%;background:var(--red);display:grid;place-items:center;margin:0 auto 24px;color:#fff;box-shadow:0 20px 40px rgba(227,6,19,.3)}
.form-success h3{position:relative;font-family:var(--display);font-size:clamp(28px,3.5vw,40px);text-transform:uppercase;letter-spacing:.5px;margin:0 0 16px;line-height:1}
.form-success p{position:relative;color:#bdbdbd;font-size:15px;line-height:1.7;margin:0 auto 28px;max-width:420px}
.form-success a{color:#fff;text-decoration:underline;text-underline-offset:3px}
.form-success a:hover{color:var(--red)}
.form-success .btn{position:relative;background:var(--red);color:#fff;text-decoration:none}
.form-success .btn:hover{background:var(--red-dark)}

/* ========== TEAM PHOTO CARDS ========== */
.team-card{text-align:center;padding:36px 28px}
.team-card__photo{width:140px;height:140px;border-radius:50%;background-size:cover;background-position:center top;margin:0 auto 22px;border:3px solid var(--bone);box-shadow:0 12px 30px rgba(0,0,0,.08);transition:.3s}
.team-card:hover .team-card__photo{border-color:var(--red);transform:scale(1.04)}
.team-card h4{text-align:center;margin:0 0 6px}
.team-card p{text-align:center}

/* ========== MOBILE MENU DRAWER ========== */
.hamburger{display:none;width:44px;height:44px;border:1px solid #e6e6e6;border-radius:50%;place-items:center;background:#fff;cursor:pointer;flex-shrink:0;transition:.2s}
.hamburger:hover{border-color:var(--red)}
.hamburger span{display:block;width:18px;height:2px;background:var(--ink);margin:3px 0;transition:.3s;border-radius:2px}
.hamburger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
.mobile-menu{position:fixed;inset:0;background:var(--ink);color:#fff;z-index:200;transform:translateX(100%);transition:transform .45s cubic-bezier(.7,0,.3,1);padding:90px 28px 40px;overflow-y:auto;display:flex;flex-direction:column;padding-top:calc(90px + env(safe-area-inset-top));padding-bottom:calc(40px + env(safe-area-inset-bottom))}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu__nav{display:flex;flex-direction:column;gap:4px;margin-bottom:40px}
.mobile-menu__nav a{font-family:var(--display);font-size:clamp(26px,6vw,38px);text-transform:uppercase;letter-spacing:.5px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.08);color:#fff;display:flex;align-items:center;justify-content:space-between;line-height:1}
.mobile-menu__nav a::after{content:"→";opacity:.3;font-size:22px}
.mobile-menu__nav a:active{color:var(--red)}
.mobile-menu__cta{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding-top:20px}
.mobile-menu__cta .btn{justify-content:center;padding:18px 20px;font-size:15px}
.mobile-menu__contact{margin-top:28px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);color:#999;font-size:13px;line-height:1.8}
.mobile-menu__contact a{color:#fff}
.mobile-menu__contact .label{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:#666;display:block;margin-bottom:4px}
body.menu-open{overflow:hidden}

/* ========== BLOG INDEX + ARTICLE (from build.py) ========== */
.blog-grid{padding:120px 24px;background:#fff}
.blog-grid__inner{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.blog-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid #ece8df;transition:.3s;text-decoration:none;color:inherit}
.blog-card:hover{border-color:var(--red);transform:translateY(-6px);box-shadow:0 30px 60px rgba(0,0,0,.08)}
.blog-card__img{aspect-ratio:4/3;background-size:cover;background-position:center;position:relative;overflow:hidden}
.blog-card__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.2) 100%)}
.blog-card__cat{position:absolute;left:18px;top:18px;z-index:2;background:var(--red);color:#fff;padding:6px 14px;border-radius:999px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.blog-card__body{padding:32px 28px;flex:1;display:flex;flex-direction:column}
.blog-card__meta{display:flex;gap:16px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:600}
.blog-card__meta span+span{position:relative;padding-left:16px}
.blog-card__meta span+span::before{content:"";position:absolute;left:0;top:50%;width:4px;height:4px;border-radius:50%;background:var(--red);transform:translateY(-50%)}
.blog-card h3{font-family:var(--display);font-size:26px;text-transform:uppercase;letter-spacing:.3px;line-height:1.05;margin:0 0 14px}
.blog-card p{font-size:14px;color:#666;line-height:1.6;margin:0 0 20px;flex:1}
.blog-card__more{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--red);margin-top:auto}
.blog-card__more .arr{width:28px;height:28px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center}
.article-hero{position:relative;background:var(--black);color:#fff;padding:140px 24px 70px;overflow:hidden}
.article-hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(ellipse at 30% 40%,rgba(227,6,19,.18),transparent 55%),linear-gradient(160deg,#0a0a0a,#1a1a1a 60%,#0a0a0a);z-index:0}
.article-hero__inner{position:relative;max-width:880px;margin:0 auto;z-index:1}
.article-hero__breadcrumb{display:flex;gap:10px;align-items:center;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#999;margin-bottom:32px;font-weight:600}
.article-hero__breadcrumb a{color:#ccc}
.article-hero__breadcrumb a:hover{color:var(--red)}
.article-hero__breadcrumb .sep{color:#444}
.article-hero__cat{display:inline-block;background:var(--red);color:#fff;padding:8px 18px;border-radius:999px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;font-weight:700;margin-bottom:24px}
.article-hero h1{font-family:var(--display);font-size:clamp(40px,6vw,84px);line-height:1;margin:0 0 32px;text-transform:uppercase;letter-spacing:.5px}
.article-hero__meta{display:flex;gap:28px;align-items:center;font-size:13px;color:#999;flex-wrap:wrap}
.article-hero__meta b{color:#fff;font-weight:600}
.article-body{background:#fff;padding:100px 24px 80px}
.article-body__inner{max-width:720px;margin:0 auto;font-size:18px;line-height:1.8;color:#2a2a2a}
.article-body__inner > .lead{font-size:22px;line-height:1.65;color:#444;margin:0 0 40px;font-weight:500;padding-bottom:40px;border-bottom:1px solid #ece8df}
.article-body__inner p{margin:0 0 26px}
.article-body__inner h2{font-family:var(--display);font-size:clamp(28px,3.5vw,42px);text-transform:uppercase;letter-spacing:.3px;line-height:1.1;margin:56px 0 20px;color:var(--ink)}
.article-body__inner h2::before{content:"";display:block;width:50px;height:3px;background:var(--red);margin-bottom:18px}
.article-body__inner h3{font-family:var(--display);font-size:24px;text-transform:uppercase;letter-spacing:.3px;margin:40px 0 16px;color:var(--ink)}
.article-body__inner ul,.article-body__inner ol{margin:0 0 26px;padding-left:0;list-style:none}
.article-body__inner ul li{position:relative;padding:8px 0 8px 36px;line-height:1.7}
.article-body__inner ul li::before{content:"";position:absolute;left:0;top:17px;width:18px;height:18px;border-radius:50%;background:var(--bone)}
.article-body__inner ul li::after{content:"";position:absolute;left:6px;top:23px;width:6px;height:6px;border-radius:50%;background:var(--red)}
.article-body__inner a{color:var(--red);text-decoration:underline;text-underline-offset:3px}
.article-body__inner blockquote{font-family:var(--display);font-size:clamp(24px,3.5vw,32px);line-height:1.3;margin:50px 0;padding:30px 40px;border-left:4px solid var(--red);background:var(--bone);color:var(--ink);text-transform:uppercase;letter-spacing:.3px}

/* ========== RESPONSIVE BREAKPOINTS ========== */
@media (max-width:1100px){
  .hero__inner{grid-template-columns:1fr;gap:40px}
  .hero__visual{max-width:500px}
  .cats__grid{grid-template-columns:repeat(3,1fr)}
  .usps__grid,.trustbar__inner{grid-template-columns:repeat(2,1fr)}
  .intro__inner{grid-template-columns:1fr}
  .offerte__inner{grid-template-columns:1fr;gap:40px}
  .proces__grid{grid-template-columns:repeat(2,1fr)}
  .values__grid{grid-template-columns:repeat(3,1fr)}
  .value{border-right:none;border-bottom:1px solid #eee}
  .cases__grid{grid-template-columns:1fr}
  .behind__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .behind__item--tall{grid-row:span 1}
  .behind__item--wide{grid-column:span 2}
  .footer__grid{grid-template-columns:1fr 1fr;gap:40px}
  .guarantee__inner,.blog-grid__inner{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .nav{display:none}
  .hamburger{display:grid}
  .header .btn{padding:9px 14px;font-size:12px}
  .header__cta .btn--dark{display:none}
  .usps__grid,.proces__grid,.values__grid,.guarantee__inner,.cases__grid,.behind__grid,.cats__grid,.compare__grid{display:flex !important;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;gap:14px;padding:8px 24px 24px;margin:0 -24px;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-padding-left:24px;grid-template-columns:none !important}
  .usps__grid::-webkit-scrollbar,.proces__grid::-webkit-scrollbar,.values__grid::-webkit-scrollbar,.guarantee__inner::-webkit-scrollbar,.cases__grid::-webkit-scrollbar,.behind__grid::-webkit-scrollbar,.cats__grid::-webkit-scrollbar,.compare__grid::-webkit-scrollbar{display:none}
  .usps__grid > *,.proces__grid > *,.values__grid > *,.guarantee__inner > *,.cases__grid > *,.cats__grid > *,.compare__grid > *{flex:0 0 82%;scroll-snap-align:start;scroll-snap-stop:always}
  .cases__grid > *{flex:0 0 86%;aspect-ratio:3/4 !important}
  .cases__grid .case__overlay{background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.45) 35%,rgba(0,0,0,.88) 65%,rgba(0,0,0,.96) 100%) !important}
  .cases__grid .case__content{left:22px !important;right:22px !important;bottom:22px !important}
  .cases__grid .case h4{font-size:24px !important;text-shadow:0 2px 20px rgba(0,0,0,.6);line-height:1.05 !important}
  .cases__grid .case p{font-size:13px !important;color:#e5e5e5 !important}
  .cat{min-height:320px}
  .cat__label{font-size:22px;bottom:110px}
  .intro,.proces,.values,.cases,.behind,.usps,.quote,.offerte,.finalcta,.faq,.compare,.guarantee,.brands{padding:60px 24px}
  .usps{padding:28px 0 20px}
  .intro__inner,.offerte__inner{gap:30px}
  .intro h2,.offerte h3,.section__head h2,.finalcta h2{font-size:clamp(32px,8vw,48px) !important;line-height:1}
  .step__num{font-size:48px;margin-bottom:10px}
  .quote{padding:70px 24px}
  .quote__mark{font-size:90px;margin-bottom:-10px}
  .quote blockquote{font-size:clamp(22px,5.5vw,32px)}
  .finalcta{padding:70px 24px}
  .offerte__circle{width:110px;height:110px;font-size:11px;top:-20px;right:-20px}
  .offerte__visual{aspect-ratio:5/4}
  .logos-strip{padding:28px 0}
  .logos-strip__track{gap:50px;animation-duration:28s}
  .logos-strip__track img{max-height:30px}
  .compare__grid{grid-template-columns:1fr;gap:14px}
  .compare__col{padding:28px 24px}
  .faq{padding:60px 20px}
  .faq__q{font-size:18px;padding:22px 0;letter-spacing:.3px;gap:16px}
  .faq__q .plus{flex-basis:34px;width:34px;height:34px;font-size:18px}
  .faq__a{font-size:16px;line-height:1.7}
  .faq__item.open .faq__a{padding:4px 0 24px}
  .section__head{margin-bottom:36px;padding:0 24px;gap:16px;flex-direction:column;align-items:flex-start}
  .hero{min-height:auto;padding:50px 0 60px}
  .hero__inner{padding:40px 24px 20px;gap:30px}
  .hero__title{font-size:clamp(42px,11vw,64px) !important;margin-bottom:18px}
  .hero__lead{font-size:16px;margin-bottom:22px}
  .hero__meta{margin-top:32px;gap:24px;flex-wrap:wrap}
  .hero__meta div{padding-right:20px}
  .hero__meta b{font-size:22px}
  .hero__meta div:not(:last-child)::after{display:none}
  .hero__visual{max-width:100%;aspect-ratio:4/5}
  .hero__badge{top:16px;left:16px;padding:8px 12px;font-size:10px}
  .hero__quote{bottom:16px;left:16px;right:16px;padding:14px 18px}
  .hero__quote b{font-size:16px}
  .footer{padding:60px 24px calc(30px + env(safe-area-inset-bottom))}
  .footer__grid{grid-template-columns:1fr 1fr !important;gap:36px 28px;padding-bottom:40px}
  .footer__brand{grid-column:1/-1;padding-bottom:8px;border-bottom:1px solid var(--line);margin-bottom:12px}
  .footer__brand p{font-size:13px;line-height:1.6;max-width:none;margin-bottom:18px}
  .footer__brand img{height:48px;margin-bottom:16px}
  .footer h5{font-size:12px;margin-bottom:14px;letter-spacing:.08em}
  .footer ul{font-size:13px;line-height:1.9}
  .footer__contact li{font-size:13px;margin-bottom:8px}
  .footer__contact svg{width:12px;height:12px}
  .footer__bottom{padding-top:24px;font-size:12px;flex-direction:column;align-items:flex-start;gap:12px}
  .sticky-cta{bottom:calc(12px + env(safe-area-inset-bottom));left:12px;right:12px;transform:translateY(200%);max-width:none;border-radius:18px;padding:0}
  .sticky-cta.show{transform:translateY(0)}
  .sticky-cta__call{flex:1;padding:14px 10px 14px 16px;min-height:64px;gap:14px}
  .sticky-cta__icon{width:44px;height:44px;flex-basis:44px}
  .brands{padding:50px 0}
  .brands__head{margin-bottom:30px;padding:0 20px}
  .brands__track{gap:60px;padding:0 30px;animation-duration:32s}
  .brands__track img{max-height:46px}
  .trustbar{padding:18px 20px}
  .trustbar__inner{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:18px;padding:4px 0 8px;margin:0;scrollbar-width:none;scroll-snap-type:x mandatory}
  .trustbar__inner::-webkit-scrollbar{display:none}
  .trustbar__item{flex:0 0 auto;scroll-snap-align:start;padding-right:18px;border-right:1px solid #ece8df}
  .trustbar__item:last-child{border-right:none}
  .trustbar__item b{font-size:18px}
  .blog-grid{padding:60px 0}
  .blog-grid__inner{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;gap:14px;padding:0 24px 24px;margin:0;scrollbar-width:none}
  .blog-grid__inner::-webkit-scrollbar{display:none}
  .blog-grid__inner > *{flex:0 0 82%;scroll-snap-align:start}
  .article-hero{padding:90px 20px 50px}
  .article-hero h1{font-size:clamp(32px,9vw,56px)}
  .article-body{padding:60px 20px 50px}
  .article-body__inner{font-size:16px;line-height:1.75}
}
@media (max-width:540px){
  .hero__inner{padding:32px 20px 16px}
  .intro,.proces,.values,.cases,.behind,.quote,.offerte,.finalcta,.faq,.compare,.guarantee{padding:50px 20px}
  .header__inner{padding:12px 16px;gap:10px}
  .logo img{height:42px}
  .header__cta{gap:8px}
  .header .btn--red{padding:10px 16px}
  .topbar{display:none}
  .trustbar__inner{grid-template-columns:1fr}
}

/* Contact Form 7 styling */
.contact-form-wrap .wpcf7-form p{margin:0 0 16px}
.contact-form-wrap .wpcf7-form label{display:block;font-size:14px;color:#333;line-height:1.5;font-weight:500}
.contact-form-wrap .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-acceptance):not([type=checkbox]):not([type=radio]){width:100%;padding:14px 16px;border:1px solid #e5e0d8;border-radius:8px;font:inherit;background:#fff;margin-top:6px;box-sizing:border-box}
.contact-form-wrap .wpcf7-form-control:focus{outline:none;border-color:var(--red)}
.contact-form-wrap textarea.wpcf7-form-control{resize:vertical;min-height:130px}
.contact-form-wrap .wpcf7-form .cf7-grid{display:grid;gap:16px}
.contact-form-wrap .wpcf7-form .cf7-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-form-wrap .wpcf7-form .cf7-row-2 > p{margin:0}
.contact-form-wrap .cf7-consent{font-size:13px;color:#666;line-height:1.5}
.contact-form-wrap .cf7-consent .wpcf7-list-item{margin:0;display:flex;gap:10px;align-items:flex-start}
.contact-form-wrap .cf7-consent .wpcf7-list-item-label{flex:1}
.contact-form-wrap .cf7-consent a{color:var(--red);text-decoration:underline}
@media (max-width:540px){.contact-form-wrap .wpcf7-form .cf7-row-2{grid-template-columns:1fr}}
.contact-form-wrap .wpcf7-submit{margin-top:8px !important;cursor:pointer}
.contact-form-wrap .wpcf7-not-valid-tip{color:#b00020;font-size:13px;margin-top:4px}
.contact-form-wrap .wpcf7-response-output{margin:16px 0 0 !important;padding:12px 16px !important;border-radius:8px;font-size:14px}
.contact-form-wrap .wpcf7 form.sent .wpcf7-response-output{border-color:#2e7d32;background:#e8f5e9;color:#1b5e20}
.contact-form-wrap .wpcf7 form.invalid .wpcf7-response-output,.contact-form-wrap .wpcf7 form.failed .wpcf7-response-output{border-color:#b00020;background:#fde7e9;color:#7a0015}
.contact-form-wrap .wpcf7-spinner{display:inline-block;margin-left:12px}
