*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(37,99,168,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(37,99,168,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.invisible{visibility:hidden}.static{position:static}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.z-10{z-index:10}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.flex-shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-\[auto_1fr\]{grid-template-columns:auto 1fr}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-14{gap:3.5rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.overflow-hidden{overflow:hidden}.border{border-width:1px}.border-0{border-width:0}.bg-transparent{background-color:transparent}.p-1{padding:.25rem}.p-7{padding:1.75rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-28{padding-top:7rem;padding-bottom:7rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pt-6{padding-top:1.5rem}.text-center{text-align:center}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-black{font-weight:900}.font-bold{font-weight:700}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-8{line-height:2rem}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-widest{letter-spacing:.1em}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}

:root {
  --white: #fff;
  --off: #f4f6f9;
  --stone: #edf0f5;
  --border: #dde2eb;
  --muted: #8a94a6;
  --body: #343d4a;
  --heading: #0d1320;
  --accent: #2563a8;
  --accent-lt: #e8f0fb;
  --accent-mid: #1d50a2;
}

*,:after,:before { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body { background: var(--white); color: var(--body); font-family: 'DM Sans', 'Segoe UI', Helvetica Neue, Helvetica, Arial, sans-serif; line-height: 1.65; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; }

.t-label { font-size: .7rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); }
.t-h1 { font-size: clamp(2.5rem, 5.2vw, 4.8rem); line-height: 1.1; letter-spacing: -.022em; }
.t-h1, .t-h2 { font-weight: 300; color: var(--heading); }
.t-h2 { font-size: clamp(1.9rem, 3.2vw, 3rem); line-height: 1.18; letter-spacing: -.018em; }
.t-h3 { font-size: 1.15rem; font-weight: 500; letter-spacing: -.01em; color: var(--heading); line-height: 1.3; }
.t-body { font-size: 1.05rem; line-height: 1.75; color: var(--body); }
.t-small { font-size: .88rem; line-height: 1.65; color: var(--muted); }

.wrap { max-width: 1160px; }
.wrap, .wrap-narrow { margin: 0 auto; padding: 0 2rem; }
.wrap-narrow { max-width: 780px; }

/* HEADER */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 200; background: hsla(0,0%,100%,0); transition: background .35s, box-shadow .35s; }
.site-header.scrolled { background: hsla(0,0%,100%,.97); backdrop-filter: blur(14px); box-shadow: 0 1px 0 var(--border); }
.header-row { display: flex; align-items: center; justify-content: space-between; height: 68px; }
.logo { text-decoration: none; display: flex; align-items: baseline; gap: 2px; }
.logo-tag { font-size: 1.2rem; font-weight: 700; letter-spacing: -.03em; color: var(--heading); }

@keyframes sqPulse {
  0%, 100% { opacity: 1; transform: scale(1) rotate(0deg); }
  50% { opacity: .3; transform: scale(.65) rotate(45deg); }
}
.logo-dot { width: 7px; height: 7px; border-radius: 3px; background: var(--accent); margin: 0 1px 2px; flex-shrink: 0; animation: sqPulse 3s cubic-bezier(.45,0,.55,1) infinite; }
.logo-de { font-size: .78rem; font-weight: 400; color: var(--muted); letter-spacing: .04em; }

.main-nav { display: flex; align-items: center; gap: 2.2rem; list-style: none; }
.main-nav a { text-decoration: none; font-size: .88rem; font-weight: 400; color: var(--body); transition: color .2s; }
.main-nav a:hover { color: var(--accent); }
.nav-btn { background: var(--accent) !important; color: #fff !important; padding: .5rem 1.3rem; border-radius: 8px; font-weight: 500 !important; transition: background .2s !important; }
.nav-btn:hover { background: var(--accent-mid) !important; }
.burger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 6px; background: none; border: none; }
.burger span { display: block; width: 22px; height: 1.5px; background: var(--heading); transition: transform .3s, opacity .3s; border-radius: 2px; }

/* HERO */
.hero { padding-top: 130px; padding-bottom: 80px; background: var(--white); border-bottom: 1px solid var(--border); position: relative; overflow: hidden; }
.hero-bg-circle { position: absolute; top: -80px; left: -160px; width: 680px; height: 680px; border-radius: 50%; background: radial-gradient(circle, var(--accent-lt) 0, transparent 70%); pointer-events: none; }
.hero-inner { display: grid; grid-template-columns: 1fr 420px; gap: 5rem; align-items: center; }
.hero h1, .hero-label { margin-bottom: 1.4rem; }
.hero h1 em { font-style: normal; color: var(--accent); }
.hero-lead { font-size: 1.1rem; color: var(--muted); line-height: 1.75; max-width: 520px; margin-bottom: 2.2rem; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; align-items: center; }

.btn { display: inline-flex; align-items: center; gap: .5rem; text-decoration: none; font-size: .9rem; font-weight: 500; border-radius: 8px; padding: .75rem 1.75rem; transition: background .2s, color .2s, border-color .2s; cursor: pointer; border: 1.5px solid transparent; }
.btn-green { background: var(--accent); color: #fff; }
.btn-green:hover { background: var(--accent-mid); }
.btn-outline { border-color: var(--border); color: var(--body); background: transparent; }
.btn-outline:hover { border-color: var(--accent); color: var(--accent); }

.hero-visual { position: relative; }
.hero-img-box { width: 100%; aspect-ratio: 4/5; border-radius: 16px; overflow: hidden; background: var(--stone); position: relative; }
.hero-img-box img { width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 1; }
.hero-img-placeholder { position: absolute; inset: 0; z-index: 0; background: linear-gradient(145deg, var(--accent-lt) 0, var(--stone) 60%, var(--border) 100%); }
.hero-badge { position: absolute; bottom: -1rem; left: -1.5rem; background: var(--white); border: 1px solid var(--border); border-radius: 16px; padding: .9rem 1.3rem; box-shadow: 0 8px 32px rgba(37,99,168,.10); display: flex; flex-direction: column; gap: .15rem; }
.badge-num { font-size: 1.5rem; font-weight: 700; color: var(--heading); line-height: 1; letter-spacing: -.03em; }
.badge-txt { font-size: .72rem; color: var(--muted); font-weight: 400; }

/* INTRO STRIP */
.intro-strip { background: var(--heading); padding: 1.2rem 0; overflow: hidden; }
.strip-scroll { display: flex; gap: 3rem; animation: stripMove 34s linear infinite; white-space: nowrap; }
.strip-item { font-size: .82rem; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: hsla(0,0%,100%,.75); flex-shrink: 0; }
.strip-dot { color: hsla(0,0%,100%,.35); }
@keyframes stripMove { 0% { transform: translateX(0); } to { transform: translateX(-50%); } }

/* SECTIONS */
.section { padding: 6.5rem 0; }
.section-sm { padding: 5rem 0; }
.section-off { background: var(--off); }
.section-stone { background: var(--stone); }
.section-head { margin-bottom: 3.5rem; }
.section-head .t-label { display: block; margin-bottom: .8rem; }

/* SERVICES */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.srv-card { background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 2rem 1.8rem; transition: box-shadow .25s, transform .25s; }
.srv-card:hover { box-shadow: 0 10px 40px rgba(37,99,168,.09); transform: translateY(-4px) scale(1.01); }
.srv-num { font-size: .72rem; font-weight: 600; letter-spacing: .14em; color: var(--accent); margin-bottom: 1.2rem; }
.srv-card h3 { margin-bottom: .7rem; }
.srv-card p { font-size: .92rem; color: var(--muted); line-height: 1.7; }

/* ABOUT */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.about-img { border-radius: 18px; overflow: hidden; aspect-ratio: 3/4; background: var(--stone); position: relative; }
.about-img img { width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 1; }
.about-img-placeholder { position: absolute; inset: 0; z-index: 0; background: linear-gradient(160deg, #d4e0f7 0, var(--stone) 100%); }
.about-text .t-label { display: block; margin-bottom: .8rem; }
.about-text .t-h2 { margin-bottom: 1.4rem; }
.about-text p { font-size: 1rem; color: var(--muted); line-height: 1.8; margin-bottom: 1rem; }
.about-pills { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.5rem; }
.pill { border: 1px solid var(--border); border-radius: 8px; padding: .3rem .9rem; font-size: .8rem; color: var(--body); }

/* HISTORY */
.history-layout { display: grid; grid-template-columns: 260px 1fr; gap: 5rem; align-items: start; }
.history-year-block { position: sticky; top: 100px; }
.history-big-year { font-size: clamp(4rem, 8vw, 7rem); font-weight: 200; line-height: 1; letter-spacing: -.04em; color: var(--heading); opacity: .1; }
.history-tag { display: inline-block; background: var(--accent-lt); color: var(--accent); font-size: .72rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; padding: .3rem .8rem; border-radius: 6px; margin-bottom: 1rem; }
.history-content .t-h2 { margin-bottom: 1.4rem; }
.history-content p { font-size: 1rem; color: var(--muted); line-height: 1.82; margin-bottom: 1rem; }
.history-stats { display: flex; gap: 3rem; margin-top: 2.5rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.hstat-num { font-size: 2rem; font-weight: 300; letter-spacing: -.03em; color: var(--heading); line-height: 1; margin-bottom: .3rem; }
.hstat-lbl { font-size: .78rem; color: var(--muted); }

/* PROCESS */
.process-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; background: var(--border); border: 1px solid var(--border); border-radius: 18px; overflow: hidden; }
.pstep { background: var(--white); padding: 2.5rem 2rem; }
.pstep-num { width: 38px; height: 38px; border-radius: 50%; background: var(--accent-lt); color: var(--accent); font-size: .8rem; font-weight: 700; display: flex; align-items: center; justify-content: center; margin-bottom: 1.4rem; }
.pstep h3 { margin-bottom: .6rem; }
.pstep p { font-size: .88rem; color: var(--muted); line-height: 1.7; }

/* CTA BAND */
.cta-band { background: var(--heading); padding: 5rem 0; }
.cta-band-inner { display: flex; align-items: center; justify-content: space-between; gap: 3rem; }
.cta-band h2 { font-size: clamp(1.7rem, 2.8vw, 2.5rem); font-weight: 300; color: #fff; letter-spacing: -.018em; line-height: 1.2; max-width: 520px; }
.cta-band h2 em { font-style: normal; color: #7fb3f5; }
.cta-band-right { flex-shrink: 0; display: flex; flex-direction: column; align-items: flex-start; gap: .8rem; }
.btn-white { background: #fff; color: var(--heading); font-weight: 600; }
.btn-white:hover { background: var(--off); }
.cta-note { font-size: .78rem; color: hsla(0,0%,100%,.4); max-width: 230px; line-height: 1.55; }

/* REVIEWS */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.rev-card { background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 1.8rem 1.6rem; }
.rev-stars { display: flex; gap: 3px; margin-bottom: 1.2rem; }
.rev-star { width: 14px; height: 14px; background: var(--accent); clip-path: polygon(50% 0, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); }
.rev-text { font-size: .93rem; color: var(--body); line-height: 1.75; margin-bottom: 1.4rem; font-style: italic; }
.rev-author { font-size: .8rem; font-weight: 600; color: var(--heading); }
.rev-city { font-size: .75rem; color: var(--muted); }

/* GEO */
.geo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.geo-text .t-label { display: block; margin-bottom: .8rem; }
.geo-text .t-h2 { margin-bottom: 1.2rem; }
.geo-text p { font-size: 1rem; color: var(--muted); line-height: 1.8; margin-bottom: 1rem; }
.geo-chips { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.5rem; }
.geo-chip { background: var(--accent-lt); color: var(--accent); font-size: .78rem; font-weight: 500; padding: .28rem .85rem; border-radius: 8px; }
.geo-box { background: var(--off); border: 1px solid var(--border); border-radius: 16px; aspect-ratio: 4/3; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .8rem; position: relative; overflow: hidden; }
.geo-grid-lines { position: absolute; inset: 0; background-image: linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px); background-size: 40px 40px; opacity: .6; }
.geo-de-text { font-size: 4rem; font-weight: 200; letter-spacing: -.04em; color: var(--heading); position: relative; z-index: 1; opacity: .2; }
.geo-label-box { position: relative; z-index: 1; background: var(--white); border: 1px solid var(--border); border-radius: 8px; padding: .5rem 1rem; font-size: .78rem; font-weight: 500; color: var(--body); }

/* EDITORIAL */
.editorial-block { padding: 6.5rem 0; background: var(--white); }
.editorial-inner { display: grid; grid-template-columns: 1fr 2fr; gap: 6rem; align-items: start; }
.editorial-side { position: sticky; top: 100px; }
.editorial-side-num { font-size: clamp(6rem, 10vw, 9rem); font-weight: 200; line-height: 1; letter-spacing: -.05em; color: var(--heading); opacity: .07; margin-bottom: -1rem; }
.editorial-side .t-label { display: block; margin-bottom: .6rem; }
.editorial-side h2 { font-size: clamp(1.4rem, 2.2vw, 2rem); font-weight: 300; letter-spacing: -.018em; color: var(--heading); line-height: 1.2; }
.editorial-body p { font-size: 1.05rem; color: var(--muted); line-height: 1.85; margin-bottom: 1.4rem; }
.editorial-body p:last-child { margin-bottom: 0; }
.editorial-body strong { font-weight: 600; color: var(--body); }
.editorial-pull { margin: 2.5rem 0; padding: 1.8rem 2rem; border-left: 4px solid var(--accent); background: var(--accent-lt); border-radius: 0 12px 12px 0; }
.editorial-pull p { font-size: 1.1rem !important; color: var(--accent) !important; font-style: italic; margin: 0 !important; line-height: 1.6 !important; }

/* TECHNIK */
.technik-block { padding: 6.5rem 0; background: var(--stone); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.technik-head { margin-bottom: 3.5rem; }
.technik-head .t-label { display: block; margin-bottom: .8rem; }
.technik-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 3rem 5rem; }
.technik-item { padding-top: 1.8rem; border-top: 1px solid var(--border); }
.technik-item-label { font-size: .7rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin-bottom: .5rem; }
.technik-item h3 { font-size: 1.1rem; font-weight: 500; color: var(--heading); margin-bottom: .6rem; letter-spacing: -.01em; }
.technik-item p { font-size: .92rem; color: var(--muted); line-height: 1.72; }
.technik-note { margin-top: 3.5rem; padding: 1.8rem 2.2rem; background: var(--white); border: 1px solid var(--border); border-radius: 18px; display: flex; align-items: flex-start; gap: 1.4rem; }
.technik-note-icon { width: 36px; height: 36px; border-radius: 50%; background: var(--accent-lt); flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.technik-note-icon svg { width: 16px; height: 16px; fill: none; stroke: var(--accent); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.technik-note-text p { font-size: .9rem; color: var(--body); line-height: 1.7; }
.technik-note-text strong { font-weight: 600; color: var(--heading); }

/* FOOTER */
.site-footer { background: var(--off); border-top: 1px solid var(--border); padding: 4rem 0 2rem; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 1px solid var(--border); margin-bottom: 2rem; }
.footer-brand p { font-size: .88rem; color: var(--muted); margin-top: .8rem; max-width: 230px; line-height: 1.65; }
.footer-col h4 { font-size: .72rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 1.1rem; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .55rem; }
.footer-col a { text-decoration: none; font-size: .88rem; color: var(--body); transition: color .2s; }
.footer-col a:hover { color: var(--accent); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; font-size: .78rem; color: var(--muted); }

/* COOKIE BANNER */
#cookie-banner { position: fixed; bottom: 0; left: 0; right: 0; z-index: 999; background: var(--heading); transform: translateY(100%); transition: transform .45s cubic-bezier(.16,1,.3,1); }
#cookie-banner.visible { transform: translateY(0); }
.ck-inner { display: flex; align-items: center; gap: 2rem; justify-content: space-between; padding: 1.2rem 2rem; max-width: 1160px; margin: 0 auto; }
.ck-text { font-size: .85rem; color: hsla(0,0%,100%,.6); line-height: 1.55; flex: 1; }
.ck-text a { color: hsla(0,0%,100%,.85); text-decoration: underline; }
.ck-btns { display: flex; gap: .7rem; flex-shrink: 0; }
.ck-accept, .ck-reject { border: none; cursor: pointer; font-size: .82rem; font-weight: 500; padding: .55rem 1.2rem; border-radius: 8px; transition: .2s; }
.ck-accept { background: var(--accent); color: #fff; }
.ck-accept:hover { background: var(--accent-mid); }
.ck-reject { background: transparent; color: hsla(0,0%,100%,.5); border: 1px solid hsla(0,0%,100%,.2); }
.ck-reject:hover { color: #fff; border-color: hsla(0,0%,100%,.5); }

/* PAGE HERO */
.page-hero { padding-top: 120px; padding-bottom: 5rem; background: var(--off); border-bottom: 1px solid var(--border); }
.page-hero-inner { max-width: 1160px; margin: 0 auto; padding: 0 2rem; }
.page-hero .t-label { display: block; margin-bottom: .8rem; }
.page-hero h1 { font-size: clamp(2rem, 4vw, 3.5rem); font-weight: 300; letter-spacing: -.022em; color: var(--heading); line-height: 1.1; margin-bottom: 1rem; }
.page-hero p { font-size: 1rem; color: var(--muted); max-width: 520px; line-height: 1.75; }

/* CONTACT */
.contact-section { padding: 6rem 0; background: var(--white); }
.contact-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 6rem; align-items: start; }
.contact-info h2 { font-size: 1.5rem; font-weight: 400; letter-spacing: -.018em; color: var(--heading); margin-bottom: 1rem; line-height: 1.25; }
.contact-info p { font-size: .95rem; color: var(--muted); line-height: 1.8; margin-bottom: .9rem; }
.contact-details { margin-top: 2.5rem; display: flex; flex-direction: column; gap: 0; }
.det-row { padding: 1rem 0; border-top: 1px solid var(--border); }
.det-row:last-child { border-bottom: 1px solid var(--border); }
.det-label { font-size: .7rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: .25rem; }
.det-val { font-size: .93rem; color: var(--body); }
.form-wrap { background: var(--off); border: 1px solid var(--border); border-radius: 16px; padding: 2.8rem; }
.form-row { margin-bottom: 1.4rem; }
.form-label { display: block; font-size: .78rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: .45rem; }
.form-input, .form-select, .form-textarea { width: 100%; background: var(--white); border: 1px solid var(--border); border-radius: 10px; padding: .75rem 1rem; font-family: 'DM Sans', 'Segoe UI', Helvetica Neue, Helvetica, Arial, sans-serif; font-size: .95rem; color: var(--heading); outline: none; transition: border-color .2s, box-shadow .2s; -webkit-appearance: none; -moz-appearance: none; appearance: none; }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(37,99,168,.1); }
.form-textarea { min-height: 130px; resize: vertical; }
.form-submit { width: 100%; background: var(--accent); color: #fff; border: none; font-family: 'DM Sans', 'Segoe UI', Helvetica Neue, Helvetica, Arial, sans-serif; font-size: .9rem; font-weight: 500; padding: .85rem 2rem; border-radius: 10px; cursor: pointer; transition: background .2s; margin-top: .5rem; }
.form-submit:hover { background: var(--accent-mid); }
.form-submit:disabled { opacity: .5; cursor: not-allowed; }
.form-note { font-size: .77rem; color: var(--muted); text-align: center; margin-top: 1rem; line-height: 1.5; }
.form-note a { color: var(--accent); }
.form-msg { display: none; padding: .85rem 1.1rem; border-radius: 10px; font-size: .88rem; margin-bottom: 1.2rem; }
.form-msg--success { display: block; background: rgba(37,99,168,.08); border: 1px solid rgba(37,99,168,.25); color: #0f3062; }
.form-msg--error { display: block; background: rgba(180,50,50,.07); border: 1px solid rgba(180,50,50,.2); color: #8a2020; }

/* REVEAL */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .65s ease, transform .65s ease; }
.reveal.in-view { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: .08s; }
.reveal-d2 { transition-delay: .16s; }
.reveal-d3 { transition-delay: .24s; }
.reveal-d4 { transition-delay: .32s; }

/* RESPONSIVE */
@media (max-width: 960px) {
  .hero-inner { grid-template-columns: 1fr; gap: 3rem; }
  .hero-visual { display: none; }
  .services-grid { grid-template-columns: 1fr 1fr; }
  .about-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .about-img { aspect-ratio: 16/9; }
  .history-layout { grid-template-columns: 1fr; gap: 2rem; }
  .history-year-block { position: static; }
  .history-big-year { font-size: 4rem; }
  .process-steps { grid-template-columns: 1fr 1fr; }
  .cta-band-inner { flex-direction: column; align-items: flex-start; }
  .reviews-grid { grid-template-columns: 1fr 1fr; }
  .geo-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .editorial-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .editorial-side { position: static; }
  .technik-grid { grid-template-columns: 1fr; gap: 2rem; }
  .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
  .form-wrap { padding: 2rem; }
}

@media (max-width: 680px) {
  .main-nav { display: none; }
  .main-nav.open { display: flex; flex-direction: column; position: fixed; inset: 0; background: var(--white); align-items: center; justify-content: center; gap: 2.2rem; z-index: 150; }
  .main-nav.open a { font-size: 1.3rem; }
  .burger { display: flex; z-index: 201; }
  .footer-grid, .process-steps, .reviews-grid, .services-grid { grid-template-columns: 1fr; }
  .footer-grid { gap: 2rem; }
  .footer-bottom { flex-direction: column; gap: .5rem; text-align: center; }
  .ck-inner { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .history-stats { flex-direction: column; gap: 1.5rem; }
  .editorial-side-num { font-size: 5rem; }
}

/* LEGAL */
.legal-section { padding: 5rem 0 7rem; background: var(--white); }
.legal-layout { display: grid; grid-template-columns: 220px 1fr; gap: 6rem; align-items: start; }
.legal-nav { position: sticky; top: 100px; }
.legal-nav-title { font-size: .7rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); margin-bottom: 1rem; }
.legal-nav ul { list-style: none; display: flex; flex-direction: column; gap: 0; border-left: 1px solid var(--border); }
.legal-nav ul li a { display: block; padding: .5rem 0 .5rem 1.2rem; font-size: .85rem; color: var(--muted); text-decoration: none; transition: color .2s, border-color .2s; border-left: 2px solid transparent; margin-left: -1px; }
.legal-nav ul li a.active, .legal-nav ul li a:hover { color: var(--accent); border-left-color: var(--accent); }
.legal-content section { margin-bottom: 3.5rem; padding-bottom: 3.5rem; border-bottom: 1px solid var(--border); }
.legal-content section:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.legal-content h2 { font-size: 1.25rem; font-weight: 500; letter-spacing: -.015em; color: var(--heading); margin-bottom: 1.2rem; line-height: 1.25; }
.legal-content h3 { font-size: 1rem; font-weight: 600; color: var(--heading); margin-top: 1.6rem; margin-bottom: .6rem; }
.legal-content p { font-size: .95rem; color: var(--muted); line-height: 1.82; margin-bottom: .9rem; }
.legal-content p:last-child { margin-bottom: 0; }
.legal-content ul { list-style: none; margin: .6rem 0 .9rem; display: flex; flex-direction: column; gap: .4rem; }
.legal-content ul li { font-size: .95rem; color: var(--muted); line-height: 1.7; padding-left: 1.2rem; position: relative; }
.legal-content ul li:before { content: "–"; position: absolute; left: 0; color: var(--accent); font-size: .85rem; }
.legal-content a { color: var(--accent); text-decoration: none; font-weight: 500; }
.legal-content a:hover { opacity: .75; }
.legal-badge { display: inline-flex; align-items: center; gap: .5rem; background: var(--accent-lt); border: 1px solid rgba(37,99,168,.15); border-radius: 10px; padding: .9rem 1.2rem; margin-bottom: 2rem; }
.legal-badge-icon { width: 20px; height: 20px; flex-shrink: 0; color: var(--accent); }
.legal-badge p { font-size: .85rem !important; color: var(--accent) !important; margin: 0 !important; line-height: 1.5 !important; }

.cookie-table { width: 100%; border-collapse: collapse; margin: 1rem 0; font-size: .88rem; }
.cookie-table th { text-align: left; font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); padding: .6rem 1rem; background: var(--off); }
.cookie-table td, .cookie-table th { border-bottom: 1px solid var(--border); }
.cookie-table td { padding: .75rem 1rem; color: var(--body); line-height: 1.55; vertical-align: top; }
.cookie-table tr:last-child td { border-bottom: none; }
.cookie-type-badge { display: inline-block; font-size: .7rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; padding: .2rem .6rem; border-radius: 4px; white-space: nowrap; }
.cookie-type-badge--required { background: var(--accent-lt); color: var(--accent); }
.cookie-type-badge--functional { background: #e8f0fe; color: #3b5bdb; }
.cookie-type-badge--marketing { background: #fff3e0; color: #c76a00; }

.impressum-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 1rem; }
.impressum-block { background: var(--off); border: 1px solid var(--border); border-radius: 14px; padding: 1.6rem; }
.impressum-block h3 { font-size: .7rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: .8rem; margin-top: 0 !important; }
.impressum-block p { font-size: .9rem !important; line-height: 1.7 !important; color: var(--body) !important; }
.impressum-block a { color: var(--accent); font-weight: 500; }

.contact-methods { margin-top: 2.5rem; display: flex; flex-direction: column; gap: .8rem; }
.contact-method-card { display: flex; align-items: flex-start; gap: 1rem; padding: 1.2rem 1.4rem; background: var(--off); border: 1px solid var(--border); border-radius: 12px; }
.contact-method-icon { width: 36px; height: 36px; border-radius: 10px; background: var(--accent-lt); flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.contact-method-icon svg { width: 16px; height: 16px; stroke: var(--accent); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.contact-method-label { font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-bottom: .2rem; }
.contact-method-val { font-size: .9rem; color: var(--body); line-height: 1.5; }
.contact-method-val a { color: var(--accent); text-decoration: none; font-weight: 500; }
.contact-privacy-note { margin-top: 1rem; font-size: .77rem; color: var(--muted); line-height: 1.6; border-top: 1px solid var(--border); padding-top: 1rem; }
.contact-privacy-note a { color: var(--accent); }

@media (max-width: 960px) {
  .legal-layout { grid-template-columns: 1fr; gap: 2.5rem; }
  .legal-nav { position: static; }
  .impressum-grid { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
  .cookie-table { display: block; overflow-x: auto; }
  .impressum-grid { grid-template-columns: 1fr; }
}

/* WIE-ES-FUNKTIONIERT */
.wie-step { display: grid; grid-template-columns: 80px 1fr; gap: 2.5rem; padding: 3rem 0; border-bottom: 1px solid var(--border); align-items: start; }
.wie-step:first-of-type { border-top: 1px solid var(--border); }
.wie-step-num { font-size: 2.8rem; font-weight: 200; letter-spacing: -.04em; color: var(--heading); opacity: .18; line-height: 1; padding-top: .2rem; }
.wie-step-body h3 { margin-bottom: .7rem; }
.wie-step-body p { font-size: 1rem; color: var(--muted); line-height: 1.8; margin-bottom: .8rem; }
.wie-step-body p:last-child { margin-bottom: 0; }
.wie-step-note { display: inline-flex; align-items: center; gap: .5rem; background: var(--accent-lt); color: var(--accent); font-size: .8rem; font-weight: 500; padding: .35rem .9rem; border-radius: 8px; margin-top: .5rem; }

/* LEISTUNGEN */
.leistung-card { display: grid; grid-template-columns: 80px 1fr; gap: 3rem; padding: 3.5rem 0; border-bottom: 1px solid var(--border); align-items: start; }
.leistung-card:first-of-type { border-top: 1px solid var(--border); }
.leistung-num { font-size: 2.8rem; font-weight: 200; letter-spacing: -.04em; color: var(--heading); opacity: .14; line-height: 1; padding-top: .3rem; }
.leistung-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: .9rem; }
.leistung-body h3 { margin-bottom: .8rem; }
.leistung-body p { font-size: 1rem; color: var(--muted); line-height: 1.8; margin-bottom: .9rem; }
.leistung-body p strong { font-weight: 600; color: var(--body); }
.leistung-details { margin-top: 1.5rem; border-top: 1px solid var(--border); padding-top: 1.2rem; display: flex; flex-direction: column; gap: 0; }
.leistung-detail-row { display: grid; grid-template-columns: 130px 1fr; gap: 1rem; padding: .6rem 0; border-bottom: 1px solid var(--border); font-size: .88rem; align-items: baseline; }
.leistung-detail-row:last-child { border-bottom: none; }
.leistung-detail-label { font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); flex-shrink: 0; }
.leistung-detail-row span:last-child { color: var(--body); line-height: 1.55; }

@media (max-width: 680px) {
  .wie-step { grid-template-columns: 1fr; gap: 1rem; padding: 2rem 0; }
  .wie-step-num { font-size: 1.8rem; opacity: .25; }
  .leistung-card { grid-template-columns: 1fr; gap: 1rem; padding: 2.5rem 0; }
  .leistung-num { font-size: 1.8rem; opacity: .2; }
  .leistung-detail-row { grid-template-columns: 1fr; gap: .2rem; }
}

@media (min-width: 768px) {
  .md\:grid-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .md\:grid-cols-\[2fr_1fr_1fr\] { grid-template-columns: 2fr 1fr 1fr; }
}
