
:root{
  --ink:#082226; --ink-2:#203b40; --muted:#5f7477; --paper:#effbf6; --paper-2:#dcf4f1; --white:#ffffff;
  --green:#4fd58b; --green-2:#a8efc6; --blue:#69c8ff; --blue-2:#c9f0ff; --line:rgba(8,34,38,.13); --dark:#071b20; --gold:#b8d88f;
  --radius:22px; --shadow:0 24px 80px rgba(27,118,130,.16); --glow:0 18px 60px rgba(105,200,255,.24); --max:1180px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth; overflow-x:hidden} body{margin:0;font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;color:var(--ink);background:radial-gradient(circle at 12% 4%, rgba(105,200,255,.34), transparent 34vw), radial-gradient(circle at 88% 8%, rgba(79,213,139,.30), transparent 30vw), linear-gradient(180deg,#f4fffb 0%,#eefbf7 42%,#f6fffb 100%);line-height:1.58;overflow-x:hidden;-webkit-font-smoothing:antialiased} body.nav-open{overflow:hidden} img{display:block;max-width:100%;height:auto} a{color:inherit;text-decoration:none} .container{width:min(var(--max), calc(100% - 36px));margin-inline:auto}.section{padding:92px 0}.eyebrow{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green);font-weight:800}.lead{font-size:clamp(1.08rem,2vw,1.35rem);color:var(--ink-2);max-width:760px}.muted{color:var(--muted)} h1,h2,h3{line-height:1.05;margin:0 0 18px;letter-spacing:-.045em} h1{font-size:clamp(3.05rem,7vw,6.4rem)} h2{font-size:clamp(2.25rem,5.7vw,5.1rem)} h3{font-size:clamp(1.25rem,2.2vw,2rem)} p{margin:0 0 16px}.skip-link{position:absolute;left:-999px;top:8px;background:var(--ink);color:white;padding:10px 14px;border-radius:12px;z-index:99}.skip-link:focus{left:8px}.site-header{position:sticky;top:0;z-index:50;background:rgba(244,255,251,.78);backdrop-filter:blur(22px);border-bottom:1px solid rgba(105,200,255,.22);box-shadow:0 12px 35px rgba(8,34,38,.04)}.nav{min-height:76px;display:flex;align-items:center;justify-content:space-between;gap:22px}.brand{display:flex;align-items:center;gap:12px;font-weight:900;letter-spacing:-.04em}.brand-mark{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,var(--ink),#0d5560 52%,var(--green));color:var(--white);display:grid;place-items:center;position:relative;overflow:hidden;box-shadow:0 12px 28px rgba(79,213,139,.24)}.brand-mark:after{content:"";position:absolute;inset:auto -15px -12px 10px;height:25px;background:var(--blue);transform:rotate(-20deg);opacity:.78}.brand-mark span{position:relative;z-index:2}.brand small{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:800}.nav-links{display:flex;align-items:center;gap:4px}.nav-links a{padding:10px 13px;border-radius:999px;font-weight:750;color:var(--ink-2)}.nav-links a:hover,.nav-links a.active{background:linear-gradient(135deg,rgba(105,200,255,.24),rgba(79,213,139,.20));color:var(--ink)}.nav-cta{display:flex;align-items:center;gap:10px}.burger{display:none;width:48px;height:48px;border:1px solid var(--line);border-radius:16px;background:var(--white);padding:12px}.burger span{display:block;height:2px;background:var(--ink);margin:6px 0;border-radius:4px;transition:.25s}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:13px 18px;border-radius:999px;font-weight:850;border:1px solid rgba(8,34,38,.2);background:linear-gradient(135deg,#0b2a30,#0a5966 48%,#2cce85);color:var(--white);box-shadow:0 16px 40px rgba(44,206,133,.20);transition:.22s ease}.btn:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(16,32,27,.18)}.btn.secondary{background:rgba(255,255,255,.58);color:var(--ink);border-color:rgba(105,200,255,.36);box-shadow:none}.btn.secondary:hover{background:var(--white)}.btn.light{background:var(--white);color:var(--ink);border-color:rgba(255,255,255,.5)}.hero{padding:72px 0 60px;position:relative}.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(420px,.92fr);gap:56px;align-items:end}.hero-copy{padding:32px 0;min-width:0;position:relative;z-index:2}.hero-copy h1{font-size:clamp(2.95rem,5.45vw,5.95rem);max-width:720px;overflow-wrap:normal}.hero-copy .lead{max-width:610px}.hero-visual{min-width:0}.hero h1 span{background:linear-gradient(100deg,#18b875,#2aa9ff);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:30px 0}.hero-note{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-weight:700}.hero-visual{position:relative;min-height:600px;z-index:1;border-radius:38px;overflow:hidden;background:var(--dark);box-shadow:var(--shadow), var(--glow);isolation:isolate;border:1px solid rgba(105,200,255,.32)}.hero-visual img{width:100%;height:100%;min-height:600px;object-fit:cover;opacity:.90;filter:saturate(1.12) contrast(1.03)}.hero-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(105,200,255,.24),transparent 40%,rgba(79,213,139,.18));pointer-events:none}.hero-panel{position:absolute;left:22px;right:22px;bottom:22px;border:1px solid rgba(201,240,255,.38);background:linear-gradient(135deg,rgba(7,27,32,.72),rgba(9,74,83,.56));backdrop-filter:blur(18px);color:white;border-radius:28px;padding:22px;box-shadow:0 24px 80px rgba(0,0,0,.18);z-index:2}.hero-panel strong{display:block;font-size:1.2rem;margin-bottom:6px}.hero-panel p{color:rgba(255,255,255,.74);margin:0}.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(105,200,255,.26);border-radius:28px;overflow:hidden;background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(220,244,241,.72));box-shadow:0 18px 60px rgba(44,164,190,.10)}.promise{padding:24px;border-right:1px solid var(--line);min-height:160px}.promise:last-child{border-right:0}.promise .num{display:inline-grid;place-items:center;color:#063234;background:linear-gradient(135deg,var(--green-2),var(--blue-2));font-weight:950;margin-bottom:34px;width:42px;height:42px;border-radius:14px}.promise h3{font-size:1.1rem;letter-spacing:-.025em;margin-bottom:10px}.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:44px;align-items:start}.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.service-card{background:linear-gradient(180deg,#fff,rgba(233,251,248,.96));border:1px solid rgba(105,200,255,.24);border-radius:28px;overflow:hidden;min-height:100%;transition:.24s ease;position:relative;box-shadow:0 12px 36px rgba(8,34,38,.05)}.service-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--green),var(--blue));opacity:.9;z-index:1}.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow),0 0 0 1px rgba(79,213,139,.18)}.service-card img{height:230px;width:100%;object-fit:cover}.service-card .body{padding:23px}.service-card h3{font-size:1.35rem}.service-card p{color:var(--muted)}.service-card .arrow{font-weight:900;color:var(--green)}.dark-band{background:radial-gradient(circle at top right,rgba(105,200,255,.24),transparent 30%),linear-gradient(135deg,#071b20,#0b3f49 58%,#0b2f34);color:var(--white);border-radius:42px;padding:56px;overflow:hidden;position:relative;box-shadow:var(--shadow)}.dark-band:before{content:"";position:absolute;right:-130px;top:-130px;width:380px;height:380px;border-radius:50%;background:rgba(120,145,120,.26);filter:blur(4px)}.dark-band p{color:rgba(255,255,255,.72)}.dark-band .eyebrow{color:#a9c3aa}.before-after-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.ba-card{border:1px solid rgba(105,200,255,.26);background:linear-gradient(180deg,#fff,rgba(239,251,246,.92));border-radius:30px;overflow:hidden;box-shadow:0 14px 40px rgba(8,34,38,.06)}.ba-images{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line)}.ba-frame{position:relative;aspect-ratio:1.05/1;overflow:hidden;background:#ddd}.ba-frame img{width:100%;height:100%;object-fit:cover}.ba-label{position:absolute;left:10px;top:10px;background:linear-gradient(135deg,rgba(8,34,38,.82),rgba(24,184,117,.82));color:#fff;border-radius:999px;font-size:.75rem;font-weight:900;padding:5px 9px}.ba-body{padding:22px}.ba-body small{color:var(--green);font-weight:900;text-transform:uppercase;letter-spacing:.12em}.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:center}.image-stack{position:relative}.image-stack img{border-radius:34px;box-shadow:var(--shadow);width:100%;object-fit:cover;max-height:620px}.floating-card{position:absolute;right:-18px;bottom:26px;width:min(330px,80%);background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border:1px solid rgba(105,200,255,.30);border-radius:24px;padding:22px;box-shadow:var(--shadow)}.list-clean{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:10px}.list-clean li{padding-left:28px;position:relative;color:var(--ink-2)}.list-clean li:before{content:"";position:absolute;left:0;top:.7em;width:10px;height:10px;border-radius:50%;background:var(--green)}.cta{background:radial-gradient(circle at 14% 20%,rgba(105,200,255,.34),transparent 30%),linear-gradient(135deg,#071b20,#0a5360 54%,#2bbd7a);color:var(--white);border-radius:40px;padding:48px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;overflow:hidden;box-shadow:var(--shadow)}.cta p{color:rgba(255,255,255,.72)}.cta a:not(.btn){color:var(--white);font-weight:850}.page-hero{padding:74px 0 42px}.page-hero .lead{max-width:850px}.service-detail{display:grid;grid-template-columns:.42fr .58fr;gap:34px;padding:34px 0;border-top:1px solid var(--line)}.service-detail:first-child{border-top:0}.service-detail img{border-radius:26px;aspect-ratio:1.25/1;object-fit:cover}.service-detail h2{font-size:clamp(1.8rem,3.3vw,3.3rem)}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.tag{border:1px solid var(--line);background:rgba(255,255,255,.58);padding:7px 10px;border-radius:999px;color:var(--ink-2);font-weight:750;font-size:.9rem}.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px}.contact-card,.form-card{background:linear-gradient(180deg,#fff,rgba(239,251,246,.92));border:1px solid rgba(105,200,255,.25);border-radius:30px;padding:30px;box-shadow:0 14px 45px rgba(8,34,38,.06)}.contact-item{padding:18px 0;border-bottom:1px solid var(--line)}.contact-item:last-child{border-bottom:0}.contact-item strong{display:block}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:grid;gap:7px}.field.full{grid-column:1/-1}label{font-weight:850;color:var(--ink)}input,textarea{width:100%;border:1px solid var(--line);border-radius:16px;background:#fbfaf5;padding:14px 14px;font:inherit;color:var(--ink);outline:none}input:focus,textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(73,108,85,.14)}textarea{min-height:150px;resize:vertical}.map-embed{margin-top:18px;border:1px solid rgba(105,200,255,.32);border-radius:24px;min-height:300px;overflow:hidden;position:relative;box-shadow:0 14px 40px rgba(8,34,38,.08);background:var(--blue-2)}.map-embed iframe{display:block;width:100%;height:320px;border:0}.map-note{font-size:.86rem;color:var(--muted);margin-top:10px}.legal-box{background:linear-gradient(180deg,#fff,rgba(239,251,246,.92));border:1px solid rgba(105,200,255,.25);border-radius:30px;padding:34px;max-width:840px;box-shadow:0 14px 45px rgba(8,34,38,.06)}.site-footer{padding:52px 0 34px;background:linear-gradient(135deg,#06181c,#0b3740 64%,#093027);color:rgba(255,255,255,.78);margin-top:70px}.footer-grid{display:grid;grid-template-columns:1.15fr .85fr .85fr;gap:28px}.footer-grid h3,.site-footer strong{color:#fff}.footer-links{display:grid;gap:9px}.footer-links a:hover{color:#fff}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .7s ease}.reveal.in-view{opacity:1;transform:none}
@media (max-width: 980px){.nav-links,.nav-cta{display:none}.burger{display:block}.nav-links{position:fixed;inset:76px 14px auto 14px;background:var(--white);border:1px solid var(--line);border-radius:24px;padding:14px;box-shadow:var(--shadow);flex-direction:column;align-items:stretch}.nav-links a{padding:15px}.nav-open .nav-links{display:flex}.nav-open .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}.nav-open .burger span:nth-child(2){opacity:0}.nav-open .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.hero-grid,.split,.feature-row,.contact-grid,.cta{grid-template-columns:1fr}.hero-visual,.hero-visual img{min-height:420px}.stats-strip,.service-grid,.before-after-grid{grid-template-columns:1fr 1fr}.service-detail{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.section{padding:70px 0}.dark-band{padding:36px}.cta{padding:34px}.floating-card{right:16px;bottom:16px}}
@media (max-width: 620px){.container{width:min(100% - 28px, var(--max))}.hero{padding-top:42px}.hero h1{font-size:clamp(2.65rem,17vw,4.1rem)}.hero-actions .btn{width:100%}.hero-note{display:grid;gap:8px}.stats-strip,.service-grid,.before-after-grid,.footer-grid,.form-grid{grid-template-columns:1fr}.promise{border-right:0;border-bottom:1px solid var(--line);min-height:auto}.promise:last-child{border-bottom:0}.hero-visual,.hero-visual img{min-height:380px;border-radius:28px}.hero-panel{left:14px;right:14px;bottom:14px;border-radius:22px;padding:18px}.service-card img{height:210px}.page-hero{padding-top:52px}.dark-band,.cta{border-radius:28px}.footer-bottom{display:block}.brand small{display:none}.contact-card,.form-card,.legal-box{padding:22px;border-radius:24px}}
@media (prefers-reduced-motion: reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}


/* V2: hellgrün/hellblau, mehr Tiefe */
.hero:before,.page-hero:before{content:"";position:absolute;left:max(14px,calc((100vw - var(--max))/2));top:22px;width:110px;height:110px;border-radius:32px;background:linear-gradient(135deg,rgba(79,213,139,.22),rgba(105,200,255,.20));transform:rotate(10deg);z-index:-1}.page-hero{position:relative}.section{position:relative}.service-grid,.before-after-grid{margin-top:30px}.service-card img,.ba-frame img,.image-stack img{filter:saturate(1.08) contrast(1.02)}.eyebrow{display:inline-flex;align-items:center;gap:9px}.eyebrow:before{content:"";width:22px;height:2px;border-radius:99px;background:linear-gradient(90deg,var(--green),var(--blue))}.hero-note span{background:rgba(255,255,255,.66);border:1px solid rgba(105,200,255,.24);padding:7px 11px;border-radius:999px}.tag{background:linear-gradient(135deg,rgba(255,255,255,.82),rgba(201,240,255,.45));border-color:rgba(105,200,255,.26)}
@media (max-width: 620px){.map-embed iframe{height:270px}.hero:before,.page-hero:before{width:72px;height:72px;border-radius:22px}}

/* V3 refinements: icon spacing, brighter fresh palette, stronger image presentation */
:root{
  --green:#49e08f;
  --green-2:#c7f8da;
  --blue:#5fc8ff;
  --blue-2:#d8f4ff;
  --paper:#f3fff9;
  --paper-2:#e9fbff;
  --shadow:0 28px 90px rgba(42, 155, 179, .18);
  --glow:0 20px 70px rgba(82, 207, 255, .25);
}
body{
  background:
    radial-gradient(circle at 10% 2%, rgba(95,200,255,.42), transparent 32vw),
    radial-gradient(circle at 86% 7%, rgba(73,224,143,.38), transparent 32vw),
    radial-gradient(circle at 50% 38%, rgba(216,244,255,.55), transparent 34vw),
    linear-gradient(180deg,#f6fffb 0%,#eafcff 38%,#f3fff9 100%);
}
.site-header{background:rgba(246,255,251,.86)}
.promise{position:relative;overflow:hidden}
.promise:before{content:"";position:absolute;right:-36px;top:-36px;width:94px;height:94px;border-radius:30px;background:linear-gradient(135deg,rgba(95,200,255,.22),rgba(73,224,143,.22));transform:rotate(14deg);pointer-events:none;z-index:0}
.promise .num{position:relative;z-index:1;margin-bottom:16px;width:46px;height:46px;min-width:46px;line-height:1;box-shadow:0 12px 28px rgba(73,224,143,.18)}
.promise h3,.promise p{position:relative;z-index:1}
.stats-strip{overflow:hidden;background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(216,244,255,.70) 52%,rgba(199,248,218,.55));}
.service-card{box-shadow:0 18px 55px rgba(8,34,38,.075), inset 0 1px 0 rgba(255,255,255,.75)}
.service-card img{height:250px;background:linear-gradient(135deg,var(--blue-2),var(--green-2));}
.service-detail img,.hero-visual img,.image-stack img,.service-card img{filter:saturate(1.14) contrast(1.04) brightness(1.01)}
.ba-label{z-index:2;white-space:nowrap}
.hero-panel{background:linear-gradient(135deg,rgba(7,27,32,.72),rgba(11,91,102,.58),rgba(34,143,104,.46));}
.btn{background:linear-gradient(135deg,#073238,#1280a0 46%,#32d889);box-shadow:0 18px 48px rgba(50,216,137,.24)}
.btn.secondary{background:rgba(255,255,255,.74)}
input,textarea{background:#ffffff}

@media (max-width:980px){
  .promise .num{margin-bottom:12px}
  .service-card img{height:230px}
}
@media (max-width:620px){
  .promise{padding:22px}
  .promise:before{width:70px;height:70px;right:-22px;top:-22px}
  .promise .num{width:42px;height:42px;min-width:42px;margin-bottom:12px}
  .service-card img{height:215px}
  .ba-label{font-size:.68rem;left:7px;top:7px;padding:4px 7px}
}

/* V4: fertigere Bildbereiche, stärkere Scroll-Effekte, keine überlappenden Nummern */
:root{
  --green:#38d88a;
  --blue:#49bfff;
  --mint:#effff7;
  --sky:#eefbff;
}
body::before{content:"";position:fixed;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(8,34,38,.035) 1px,transparent 1px),linear-gradient(180deg,rgba(8,34,38,.025) 1px,transparent 1px);background-size:72px 72px;mask-image:linear-gradient(180deg,rgba(0,0,0,.75),transparent 75%);z-index:-1}.site-header{box-shadow:0 14px 44px rgba(41,167,194,.10)}.brand-mark{flex:0 0 42px}.promise{isolation:isolate;display:flex;flex-direction:column;align-items:flex-start;gap:8px}.promise .num{margin:0 0 10px 0;position:relative;z-index:2}.promise h3{clear:both}.service-card,.ba-card,.contact-card,.form-card,.legal-box{backdrop-filter:blur(10px)}.service-card{will-change:transform;transform-origin:center bottom}.service-card:hover img{transform:scale(1.045)}.service-card img,.ba-frame img,.service-detail img,.hero-visual img,.image-stack img{transition:transform .8s cubic-bezier(.2,.8,.2,1), filter .45s ease}.ba-card{transition:transform .26s ease, box-shadow .26s ease}.ba-card:hover{transform:translateY(-5px);box-shadow:0 24px 65px rgba(26,132,156,.14)}.ba-body small{color:#0b9871}.ba-body p{color:var(--muted)}.ba-label{box-shadow:0 8px 20px rgba(0,0,0,.12);backdrop-filter:blur(8px)}.form-card form{margin-top:18px}.form-card .btn{margin-top:18px}.contact-grid>*{min-width:0}.contact-card,.form-card{position:relative;overflow:hidden}.contact-card:before,.form-card:before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--green),var(--blue));}.map-embed{min-height:360px}.map-embed iframe{height:360px}.reveal{opacity:0;transform:translateY(34px) scale(.985);transition:opacity .85s ease, transform .85s cubic-bezier(.2,.75,.2,1)}.reveal.in-view{opacity:1;transform:none}.reveal-card{opacity:0;transform:translateY(38px) scale(.96);transition:opacity .75s ease, transform .75s cubic-bezier(.18,.8,.2,1), box-shadow .25s ease}.reveal-card.in-view{opacity:1;transform:none}.detail-animate{opacity:0;transform:translateX(-26px);transition:opacity .85s ease, transform .85s cubic-bezier(.2,.8,.2,1)}.detail-animate:nth-of-type(even){transform:translateX(26px)}.detail-animate.in-view{opacity:1;transform:none}.parallax-soft{will-change:transform}.parallax-soft.is-moving img{transform:scale(1.04) translateY(var(--parallax-y,0px))}.scroll-progress{position:fixed;left:0;top:0;height:3px;width:0;background:linear-gradient(90deg,var(--green),var(--blue));z-index:100;box-shadow:0 0 18px rgba(73,191,255,.7)}.hero-panel,.floating-card{animation:softFloat 6s ease-in-out infinite}@keyframes softFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}.list-clean li{transition:transform .25s ease}.list-clean li:hover{transform:translateX(4px)}
@media (max-width:980px){.contact-grid{gap:18px}.map-embed,.map-embed iframe{height:300px;min-height:300px}.detail-animate,.detail-animate:nth-of-type(even){transform:translateY(28px)}}
@media (max-width:620px){.container{width:min(100% - 24px,var(--max))}.hero h1{letter-spacing:-.065em}.promise{padding:20px}.promise .num{width:40px;height:40px;min-width:40px;border-radius:13px;font-size:.86rem}.ba-images{grid-template-columns:1fr 1fr}.ba-body{padding:19px}.form-card .btn{width:100%;white-space:normal}.map-embed,.map-embed iframe{height:260px;min-height:260px}.hero-panel,.floating-card{animation:none}.floating-card{position:relative;right:auto;bottom:auto;width:100%;margin-top:-28px;z-index:2}.service-detail{gap:18px}}
@media (prefers-reduced-motion: reduce){.hero-panel,.floating-card{animation:none}.reveal,.reveal-card,.detail-animate{opacity:1;transform:none}.parallax-soft.is-moving img{transform:none}}

/* V5 mobile safety + finished photo-style image layout */
html, body { max-width: 100%; overflow-x: clip; }
body { touch-action: pan-y; }
main, header, footer, section, .container { max-width: 100%; }
img, iframe, video, canvas, svg { max-width: 100%; }
.nav, .hero-grid, .split, .feature-row, .contact-grid, .service-detail, .service-grid, .before-after-grid, .footer-grid, .form-grid, .cta { min-width: 0; }
.nav > *, .hero-grid > *, .split > *, .feature-row > *, .contact-grid > *, .service-detail > *, .service-grid > *, .before-after-grid > *, .footer-grid > *, .form-grid > *, .cta > * { min-width: 0; }
.service-card img, .service-detail img, .hero-visual img, .image-stack img { object-position: center; }
.hero-panel, .floating-card { max-width: calc(100% - 28px); }

@media (max-width: 900px) {
  .site-header { position: sticky; }
  .nav { min-height: 68px; gap: 10px; }
  .brand { max-width: calc(100% - 62px); }
  .brand > span:last-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .burger { display: inline-flex; flex-direction: column; justify-content: center; align-items: center; flex: 0 0 48px; position: relative; z-index: 80; }
  .nav-cta { display: none !important; }
  .nav-links { display: none !important; position: fixed; left: 12px; right: 12px; top: 76px; width: auto; max-width: calc(100vw - 24px); max-height: calc(100vh - 96px); overflow-y: auto; background: rgba(255,255,255,.96); border: 1px solid rgba(8,34,38,.12); border-radius: 22px; padding: 10px; box-shadow: 0 24px 70px rgba(8,34,38,.18); backdrop-filter: blur(18px); z-index: 70; }
  body.nav-open .nav-links { display: grid !important; grid-template-columns: 1fr; gap: 6px; }
  .nav-links a { width: 100%; border-radius: 16px; padding: 15px 16px; }
  .hero-grid, .split, .feature-row, .contact-grid, .service-detail, .cta { grid-template-columns: 1fr !important; }
  .stats-strip, .service-grid, .before-after-grid { grid-template-columns: 1fr 1fr; }
  .section { padding: 64px 0; }
  .hero { padding: 48px 0 36px; }
  .hero-copy { padding: 10px 0 0; }
  .hero-visual, .hero-visual img { min-height: 420px; }
  .floating-card { right: 14px; bottom: 14px; }
  .service-detail img { width: 100%; max-height: 430px; }
  .cta { gap: 16px; }
}

@media (max-width: 720px) {
  .container { width: calc(100% - 24px); }
  h1 { font-size: clamp(2.35rem, 13vw, 3.7rem); letter-spacing: -.07em; }
  h2 { font-size: clamp(2rem, 10vw, 3.15rem); letter-spacing: -.06em; }
  .lead { font-size: 1.04rem; }
  .hero-actions { display: grid; grid-template-columns: 1fr; gap: 10px; }
  .hero-actions .btn, .cta .btn { width: 100%; }
  .stats-strip, .service-grid, .before-after-grid, .footer-grid, .form-grid { grid-template-columns: 1fr !important; }
  .promise { border-right: 0 !important; border-bottom: 1px solid var(--line); }
  .promise:last-child { border-bottom: 0; }
  .service-card, .ba-card, .contact-card, .form-card, .legal-box { border-radius: 24px; }
  .service-card img { height: 235px; }
  .hero-visual, .hero-visual img { min-height: 340px; border-radius: 26px; }
  .hero-panel { position: relative; left: auto; right: auto; bottom: auto; margin: -78px 12px 12px; width: auto; }
  .before-after-grid { gap: 16px; }
  .ba-images { grid-template-columns: 1fr 1fr !important; }
  .ba-frame { aspect-ratio: 1 / .82; }
  .ba-label { font-size: .65rem; padding: 4px 7px; left: 7px; top: 7px; }
  .feature-row { gap: 18px; }
  .floating-card { position: relative; right: auto; bottom: auto; margin: -34px 12px 0; width: auto; max-width: none; }
  .contact-card, .form-card, .legal-box { padding: 20px; }
  input, textarea { font-size: 16px; border-radius: 14px; }
  .map-embed, .map-embed iframe { height: 250px !important; min-height: 250px !important; }
  .site-footer { margin-top: 44px; padding: 42px 0 28px; }
  .footer-bottom { display: grid; gap: 8px; }
}

@media (max-width: 390px) {
  .container { width: calc(100% - 18px); }
  .brand-mark { width: 38px; height: 38px; flex-basis: 38px; border-radius: 12px; }
  .brand { font-size: .95rem; gap: 9px; }
  .burger { width: 44px; height: 44px; flex-basis: 44px; }
  h1 { font-size: 2.25rem; }
  .hero-panel { margin-top: -56px; padding: 15px; }
  .service-card img { height: 205px; }
  .ba-body { padding: 17px; }
  .cta, .dark-band { padding: 24px 18px; border-radius: 24px; }
}


/* v6 desktop hero safety: prevents long German headline from running into the image column */
@media (min-width: 981px) and (max-width: 1320px){
  .hero{padding-top:54px}
  .hero-grid{grid-template-columns:minmax(0,1.06fr) minmax(360px,.94fr);gap:44px;align-items:center}
  .hero-copy h1{font-size:clamp(3.2rem,5.2vw,4.9rem);letter-spacing:-.055em;max-width:640px}
  .hero-copy .lead{font-size:1.05rem;max-width:560px}
  .hero-visual{min-height:520px;border-radius:32px}
  .hero-visual img{min-height:520px}
}
@media (min-width: 1321px){
  .hero-copy h1{font-size:clamp(4.2rem,5.4vw,6.05rem);max-width:760px}
}
@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-copy h1{font-size:clamp(2.7rem,12vw,4.8rem);max-width:100%}
  .hero-visual{min-height:360px;border-radius:28px}
  .hero-visual img{min-height:360px}
}
@media (max-width: 520px){
  .hero-copy h1{font-size:clamp(2.45rem,13vw,3.6rem);letter-spacing:-.06em}
  .hero-actions .btn{width:100%}
}

/* v7 mobile fixes: fixed header, visible burger icon, and safer homepage headline wrapping */
body{padding-top:76px;}
.site-header{position:fixed;top:0;left:0;right:0;width:100%;}
.burger{cursor:pointer;-webkit-tap-highlight-color:transparent;}
.burger span{width:22px;min-width:22px;flex:0 0 2px;display:block;}
body.nav-open .burger span{width:22px;min-width:22px;}

@media (max-width:900px){
  body{padding-top:68px;}
  .site-header{position:fixed;top:0;left:0;right:0;width:100%;}
  .nav-links{top:74px;}
}

@media (max-width:720px){
  .hero-copy h1,
  .hero h1{
    max-width:100%;
    font-size:clamp(2.05rem,10.6vw,3.05rem) !important;
    line-height:1.03;
    letter-spacing:-.055em;
    overflow-wrap:normal;
    word-break:normal;
    hyphens:auto;
  }
  .hero-copy h1 span{display:inline-block;max-width:100%;}
  .hero-copy .lead{max-width:100%;font-size:1rem;}
}

@media (max-width:390px){
  .hero-copy h1,
  .hero h1{font-size:clamp(1.92rem,9.8vw,2.25rem) !important;letter-spacing:-.045em;}
  .nav{gap:8px;}
  .brand{max-width:calc(100% - 56px);}
}


/* v8: original-style T&T Clean logo without white background */
.brand-logo{
  flex:0 1 auto;
  min-width:0;
  max-width:260px;
  padding:0;
}
.brand-logo img{
  display:block;
  width:clamp(150px, 18vw, 235px);
  height:auto;
  max-height:58px;
  object-fit:contain;
}
.brand-logo:hover{opacity:.92}
@media (max-width:900px){
  .brand-logo{max-width:calc(100% - 60px)}
  .brand-logo img{width:clamp(140px, 45vw, 210px);max-height:50px}
}
@media (max-width:390px){
  .brand-logo img{width:142px;max-height:46px}
}


/* Local folder version: legal links and cookie banner */
.cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;z-index:120;display:none;align-items:center;justify-content:space-between;gap:18px;max-width:980px;margin:0 auto;padding:18px 18px 18px 20px;border:1px solid rgba(105,200,255,.32);border-radius:22px;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);box-shadow:0 22px 70px rgba(8,34,38,.18)}
.cookie-banner.is-visible{display:flex}
.cookie-banner p{margin:0;color:var(--ink-2);font-size:.95rem}.cookie-banner a{font-weight:850;color:#0b9871}.cookie-actions{display:flex;gap:10px;flex:0 0 auto}.cookie-actions .btn{min-height:42px;padding:10px 15px}.legal-box h2{margin-top:28px}.legal-box h2:first-child{margin-top:0}.legal-box a{text-decoration:underline;text-underline-offset:3px}
@media (max-width:720px){.cookie-banner{flex-direction:column;align-items:flex-start;left:12px;right:12px;bottom:12px;padding:16px}.cookie-actions{width:100%;flex-direction:column}.cookie-actions .btn{width:100%}}


/* v9 content image update: keep supplied photos symmetrical and not distorted */
.brand-logo img{width:clamp(168px, 17vw, 248px);height:auto;max-height:54px;object-fit:contain;object-position:left center;}
.service-card img,.service-detail img,.ba-frame img,.image-stack img{object-fit:cover;object-position:center center;}
.service-card img{aspect-ratio:3/2;height:auto;min-height:210px;}
.ba-frame{aspect-ratio:1.12/1;}
.hero-visual img{object-position:center center;}
@media (min-width:981px){
  .hero-grid{grid-template-columns:minmax(0,1fr) minmax(420px,.88fr);align-items:center;}
  .hero-copy h1{max-width:690px;}
}
@media (max-width:620px){
  .brand-logo img{width:clamp(148px, 42vw, 190px);max-height:46px;}
  .service-card img{min-height:190px;}
}
