@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Playfair+Display:wght@700;800;900&display=swap";.navbar{position:fixed;top:0;left:0;right:0;z-index:100;padding:20px 0;transition:all .35s cubic-bezier(.4,0,.2,1)}.navbar.scrolled,.navbar.static{background:#0f1f3df7;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:12px 0;box-shadow:0 4px 24px #0000004d}.navbar-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}.navbar-logo{font-family:var(--fd);font-size:1.5rem;font-weight:800;letter-spacing:-.02em;flex-shrink:0}.navbar-links{display:flex;align-items:center;gap:8px}.nav-link{color:#ffffffb3;font-size:.9rem;font-weight:500;padding:8px 12px;border-radius:var(--radius-sm);transition:var(--transition)}.nav-link:hover{color:var(--white);background:#ffffff14}.nav-cta{margin-left:8px;padding:10px 20px;font-size:.88rem}.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:8px;cursor:pointer;z-index:200}.burger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:var(--transition);transform-origin:center}.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu{position:fixed;inset:0;background:var(--navy-deep);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:150;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-link{color:#fffc;font-size:1.4rem;font-weight:600;padding:16px 32px;border-radius:var(--radius);transition:var(--transition);width:100%;max-width:280px;text-align:center}.mobile-link:hover{color:var(--white);background:#ffffff0f}.mobile-cta{margin-top:16px;font-size:1rem;padding:16px 40px;border-radius:var(--radius)}@media(max-width:768px){.navbar-links{display:none}.burger{display:flex}}.footer{background:var(--navy-deep);padding:40px 0 32px;border-top:1px solid rgba(255,255,255,.06)}.footer-inner{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}.footer-brand{display:flex;flex-direction:column;align-items:center;gap:8px}.footer-logo{font-family:var(--fd);font-size:1.3rem;font-weight:800}.logo-haus{color:#ffffffe6}.logo-griff{background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-brand p{color:#fff6;font-size:.84rem;line-height:1.5}.footer-links{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.footer-links a{color:#ffffff73;font-size:.85rem;transition:color .2s}.footer-links a:hover{color:#fffc}.footer-legal{color:#ffffff40;font-size:.78rem;line-height:1.6}.footer-legal a{color:#ffffff59}.footer-legal a:hover{color:#fff9}.wa-float{position:fixed;bottom:28px;right:24px;z-index:99;width:58px;height:58px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #25d36666,0 2px 8px #00000026;transition:all .3s cubic-bezier(.4,0,.2,1);color:#fff}.wa-float:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 8px 32px #25d36680,0 4px 12px #0003}.wa-icon{width:28px;height:28px}.wa-tooltip{position:absolute;right:calc(100% + 12px);background:var(--g900);color:var(--white);font-size:.8rem;font-weight:500;padding:6px 12px;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;transform:translate(8px);transition:all .25s ease;pointer-events:none}.wa-tooltip:after{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%);border:5px solid transparent;border-right:none;border-left-color:var(--g900)}.wa-float:hover .wa-tooltip,.wa-float.hovered .wa-tooltip{opacity:1;transform:translate(0)}@media(max-width:768px){.wa-float{bottom:20px;right:16px;width:52px;height:52px}.wa-tooltip{display:none}}.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:var(--navy-deep);overflow:hidden}.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 10% 90%,rgba(237,137,54,.2) 0%,transparent 60%),radial-gradient(ellipse 60% 80% at 90% 10%,rgba(43,87,154,.4) 0%,transparent 55%),radial-gradient(ellipse 50% 50% at 50% 50%,rgba(74,144,217,.15) 0%,transparent 70%),radial-gradient(ellipse 90% 40% at 70% 80%,rgba(237,137,54,.08) 0%,transparent 50%);animation:bgShift 12s ease-in-out infinite alternate}@keyframes bgShift{0%{opacity:1;filter:hue-rotate(0deg)}50%{opacity:.85;filter:hue-rotate(5deg)}to{opacity:1;filter:hue-rotate(-3deg)}}.hero-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none}.shape{position:absolute;border-radius:50%}.shape-1{width:500px;height:500px;top:-15%;right:-8%;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;background:linear-gradient(135deg,var(--orange),var(--sky));opacity:.08;animation:morph 20s ease-in-out infinite alternate}.shape-2{width:300px;height:300px;bottom:-5%;left:-5%;border-radius:60% 40% 30% 70%/60% 30% 70% 40%;background:linear-gradient(225deg,var(--sky),var(--orange));opacity:.06;animation:morph 15s ease-in-out infinite alternate-reverse}.shape-3{width:160px;height:160px;top:20%;left:12%;border-radius:50%;border:2px solid rgba(237,137,54,.12);background:transparent;opacity:1;animation:float 8s ease-in-out infinite}.shape-4{width:80px;height:80px;top:60%;right:15%;border-radius:50%;border:1px solid rgba(74,144,217,.15);background:transparent;opacity:1;animation:float 6s ease-in-out infinite reverse}@keyframes morph{0%{border-radius:30% 70% 70% 30%/30% 30% 70% 70%;transform:rotate(0) scale(1)}50%{border-radius:50% 50% 30% 70%/50% 70% 30% 50%}to{border-radius:40% 60% 60% 40%/60% 40% 40% 60%;transform:rotate(10deg) scale(1.05)}}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(5deg)}}.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 20%,transparent 70%)}.hero-line{position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,var(--orange) 30%,var(--sky) 70%,transparent 100%);opacity:.6}.hero-content{position:relative;z-index:2;max-width:820px;margin:0 auto;padding:140px 24px 100px;text-align:center}.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#ed89361a;border:1px solid rgba(237,137,54,.25);color:var(--orange-light);padding:8px 22px;border-radius:50px;font-size:.84rem;font-weight:600;letter-spacing:.03em;margin-bottom:32px;animation:fadeDown .8s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badge-dot{width:8px;height:8px;background:#4ade80;border-radius:50%;animation:pulse 2s ease-in-out infinite;flex-shrink:0}.hero h1{font-family:var(--fd);font-size:clamp(3.2rem,8vw,5.5rem);font-weight:800;color:var(--white);line-height:1;margin-bottom:8px;animation:fadeDown .8s ease-out .1s both;letter-spacing:-.02em}.brand-haus{color:#fffffff2}.brand-griff{background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-slogan{font-size:clamp(1rem,2.2vw,1.2rem);color:#ffffff80;font-style:italic;font-weight:500;margin-bottom:6px;animation:fadeDown .8s ease-out .15s both}.hero-tagline{font-size:clamp(.8rem,1.8vw,1rem);color:#fff6;letter-spacing:.2em;text-transform:uppercase;margin-bottom:24px;animation:fadeDown .8s ease-out .2s both}.hero-sub{font-size:clamp(1rem,2.2vw,1.2rem);color:#ffffffa6;max-width:520px;margin:0 auto 40px;line-height:1.7;animation:fadeDown .8s ease-out .25s both}.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;animation:fadeDown .8s ease-out .3s both}.btn-outline{background:#ffffff0f;color:var(--white);border:1.5px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-outline:hover{border-color:#ffffff80;background:#ffffff1a;transform:translateY(-2px)}.hero-stats{display:flex;justify-content:center;gap:1px;margin-top:56px;animation:fadeDown .8s ease-out .4s both;background:#ffffff0d;border-radius:var(--radius-lg);overflow:hidden;max-width:500px;margin-left:auto;margin-right:auto;border:1px solid rgba(255,255,255,.07)}.stat{text-align:center;flex:1;padding:22px 16px;background:#ffffff05;transition:background .3s}.stat:hover{background:#ffffff0d}.stat-num{font-family:var(--fd);font-size:1.7rem;font-weight:700;background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.75rem;color:#fff6;margin-top:4px;font-weight:500}.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translate(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;animation:fadeDown .8s ease-out .6s both}.scroll-hint span{font-size:.7rem;color:#ffffff4d;letter-spacing:.1em;text-transform:uppercase}.scroll-mouse{width:24px;height:38px;border:1.5px solid rgba(255,255,255,.2);border-radius:12px;position:relative}.scroll-wheel{display:block;position:absolute;top:6px;left:50%;transform:translate(-50%);width:4px;height:8px;background:#fff6;border-radius:2px;animation:scrollDown 1.8s ease-in-out infinite}@keyframes scrollDown{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(14px)}}@media(max-width:768px){.hero-content{padding:120px 16px 80px}.hero-stats{margin-top:40px}.stat{padding:16px 8px}.stat-num{font-size:1.4rem}.stat-label{font-size:.7rem}}.services{padding:100px 0;background:var(--g100)}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:32px}.service-card{background:var(--white);border-radius:var(--radius-lg);padding:28px 24px;transition:var(--transition);border:1px solid var(--g200);position:relative;overflow:hidden}.service-card:after{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--navy),var(--orange));transform:scaleX(0);transform-origin:left;transition:transform .35s}.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.service-card:hover:after{transform:scaleX(1)}.service-card.featured{border-color:var(--orange);background:linear-gradient(135deg,rgba(237,137,54,.03),var(--white) 60%)}.service-card.featured:after{background:linear-gradient(90deg,var(--orange),var(--orange-light))}.service-badge{display:inline-block;background:var(--orange);color:var(--white);font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:50px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px}.service-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px;background:#1a365d0f}.service-card.featured .service-icon{background:#ed89361a}.service-card h3{font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:8px}.service-card p{color:var(--g500);font-size:.9rem;line-height:1.65}.service-price{margin-top:16px;font-weight:700;color:var(--navy);font-size:1rem}.anfahrt-note{padding:18px 22px;background:var(--white);border-radius:var(--radius);border:1px solid var(--g200);border-left:4px solid var(--orange);display:flex;align-items:flex-start;gap:12px;max-width:680px}.note-icon{font-size:1.2rem;flex-shrink:0;margin-top:1px}.note-text{color:var(--g700);font-size:.9rem;line-height:1.6}.note-text strong{color:var(--navy)}@media(max-width:768px){.services{padding:72px 0}.services-grid{grid-template-columns:1fr;gap:16px}}.portfolio{padding:100px 0;background:var(--white)}.portfolio-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px}.filter-btn{padding:8px 18px;border-radius:50px;border:1.5px solid var(--g200);background:var(--white);color:var(--g700);font-size:.85rem;font-weight:600;transition:var(--transition);cursor:pointer}.filter-btn:hover{border-color:var(--navy);color:var(--navy)}.filter-btn.active{background:var(--navy);border-color:var(--navy);color:var(--white)}.cases-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.case-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--g200);overflow:hidden;transition:var(--transition)}.case-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--g300)}.case-card.featured{border-color:#ed89364d;box-shadow:0 0 0 2px #ed89361a}.case-image{position:relative;aspect-ratio:4/3;overflow:hidden}.case-category-badge{position:absolute;top:12px;right:12px;z-index:10;background:#0f1f3dd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--white);font-size:.72rem;font-weight:600;padding:4px 10px;border-radius:50px;letter-spacing:.04em}.ba-slider{position:relative;width:100%;height:100%;cursor:col-resize;-webkit-user-select:none;user-select:none;overflow:hidden}.ba-after,.ba-before{position:absolute;inset:0;width:100%;height:100%}.ba-after img,.ba-before img{width:100%;height:100%;object-fit:cover}.ba-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.before-placeholder{background:linear-gradient(135deg,#2d3748,#4a5568)}.after-placeholder{background:linear-gradient(135deg,#1a365d,#2b579a)}.ba-placeholder span{color:#ffffffb3;font-size:.9rem;font-weight:600;padding:8px 16px;background:#00000040;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ba-divider{position:absolute;top:0;bottom:0;width:2px;background:var(--white);box-shadow:0 0 12px #0006;transform:translate(-50%);z-index:5}.ba-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #00000040;color:var(--navy)}.ba-handle svg{width:18px;height:18px}.ba-labels{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:space-between;padding:0 12px;pointer-events:none;z-index:6}.ba-label-before,.ba-label-after{font-size:.7rem;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.06em}.ba-label-before{background:#00000080;color:#ffffffd9}.ba-label-after{background:#1a365db3;color:#ffffffd9}.case-body{padding:20px}.case-meta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:10px}.case-location,.case-duration{font-size:.8rem;color:var(--g500);font-weight:500}.case-title{font-size:1.05rem;font-weight:700;color:var(--navy);margin-bottom:8px}.case-desc{font-size:.88rem;color:var(--g500);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:all .3s}.case-desc.expanded{-webkit-line-clamp:unset;overflow:visible}.case-expand{background:none;border:none;color:var(--sky);font-size:.8rem;font-weight:600;cursor:pointer;margin-top:4px;padding:0;transition:color .2s}.case-expand:hover{color:var(--blue)}.case-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}.case-tag{background:#1a365d12;color:var(--navy);font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:50px;letter-spacing:.03em}.portfolio-note{margin-top:40px;padding:18px 22px;background:#ed89360d;border-radius:var(--radius);border:1px solid rgba(237,137,54,.2);border-left:4px solid var(--orange);display:flex;align-items:flex-start;gap:12px;max-width:600px}.portfolio-note .note-text{color:var(--g700);font-size:.9rem;line-height:1.6}.portfolio-note .note-text strong{color:var(--navy)}.portfolio-note .note-icon{font-size:1.2rem;flex-shrink:0}.no-results{text-align:center;padding:60px 0;color:var(--g500);font-size:1rem}@media(max-width:768px){.portfolio{padding:72px 0}.cases-grid{grid-template-columns:1fr;gap:16px}.ba-placeholder span{font-size:.8rem}}.calculator{padding:100px 0;background:linear-gradient(180deg,var(--g100) 0%,var(--white) 100%)}.calc-wrapper{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start}.calc-steps{display:flex;gap:0;margin-bottom:28px;background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--g200);overflow:hidden;grid-column:1 / -1}.calc-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;font-size:.78rem;font-weight:600;color:var(--g500);border-right:1px solid var(--g200);transition:background .25s}.calc-step:last-child{border-right:none}.calc-step.active{background:#ed89360d;color:var(--orange)}.calc-step.done{background:#1a365d08;color:var(--navy)}.step-circle{width:30px;height:30px;border-radius:50%;background:var(--g200);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:700;color:var(--g500);transition:all .25s}.calc-step.active .step-circle{background:var(--orange);color:var(--white)}.calc-step.done .step-circle{background:var(--navy);color:var(--white)}.calc-body{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--g200);overflow:hidden;box-shadow:var(--shadow-sm)}.calc-step-content{padding:32px}.calc-step-content h3{font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:6px}.calc-step-desc{color:var(--g500);font-size:.9rem;margin-bottom:24px}.service-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:24px}.service-select-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border-radius:var(--radius);border:2px solid var(--g200);background:var(--white);cursor:pointer;transition:var(--transition);text-align:center}.service-select-btn:hover{border-color:var(--navy);background:#1a365d05}.service-select-btn.selected{border-color:var(--orange);background:#ed89360d}.ss-icon{font-size:1.8rem}.ss-label{font-size:.85rem;font-weight:600;color:var(--g900);line-height:1.2}.ss-price{font-size:.78rem;color:var(--g500);font-weight:500}.service-select-btn.selected .ss-price{color:var(--orange);font-weight:700}.calc-quantity{background:var(--g50);border-radius:var(--radius);padding:20px;margin-bottom:24px}.calc-quantity label{display:block;font-size:.88rem;font-weight:600;color:var(--g700);margin-bottom:12px}.quantity-control{display:flex;align-items:center;gap:16px;margin-bottom:10px}.quantity-control button{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--g300);background:var(--white);font-size:1.1rem;font-weight:700;color:var(--navy);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.quantity-control button:hover{border-color:var(--orange);color:var(--orange)}.quantity-control span{font-size:1.3rem;font-weight:700;color:var(--navy);min-width:48px;text-align:center}.calc-hint{font-size:.8rem;color:var(--g500);line-height:1.5}.address-section{margin-bottom:24px}.calc-address-input{width:100%;padding:14px 16px;border:1.5px solid var(--g300);border-radius:var(--radius);font-family:var(--fb);font-size:.95rem;color:var(--g900);outline:none;transition:border-color .2s;margin-bottom:12px}.calc-address-input:focus{border-color:var(--navy)}.calc-address-input::placeholder{color:var(--g500)}.api-notice{font-size:.8rem;color:var(--g500);padding:8px 12px;background:#4a90d90d;border-radius:var(--radius-sm);border:1px solid rgba(74,144,217,.15);margin-top:8px}.calc-loading{display:flex;align-items:center;gap:10px;color:var(--g500);font-size:.88rem;padding:12px 0}.calc-spinner{width:18px;height:18px;border:2px solid var(--g200);border-top-color:var(--navy);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.distance-result{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--g50);border-radius:var(--radius);border:1px solid var(--g200)}.dist-icon{font-size:1.3rem}.distance-result strong{font-size:.95rem;color:var(--navy);display:block}.dist-free{color:#16a34a;font-size:.82rem;font-weight:600;display:block;margin-top:2px}.dist-paid{color:var(--orange);font-size:.82rem;font-weight:600;display:block;margin-top:2px}.calc-nav{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.calc-next-btn{margin-top:20px}.order-form{display:flex;flex-direction:column;gap:16px;margin-top:20px}.order-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.order-input-group{display:flex;flex-direction:column;gap:6px}.order-input-group label{font-size:.82rem;font-weight:600;color:var(--g700)}.order-input-group input,.order-input-group textarea{padding:11px 14px;border:1.5px solid var(--g200);border-radius:var(--radius);font-family:var(--fb);font-size:.9rem;color:var(--g900);outline:none;transition:border-color .2s;background:var(--white)}.order-input-group input:focus,.order-input-group textarea:focus{border-color:var(--navy)}.order-input-group textarea{resize:vertical}.order-error{background:#dc354514;border:1px solid rgba(220,53,69,.2);color:#dc3545;font-size:.85rem;padding:10px 14px;border-radius:var(--radius-sm);text-align:center}.order-success{text-align:center;padding:32px 16px}.success-icon{font-size:3rem;margin-bottom:12px}.order-success h4{font-size:1.3rem;font-weight:700;color:var(--navy);margin-bottom:8px}.order-success p{color:var(--g500);font-size:.95rem}.price-on-request{text-align:center;padding:24px}.por-icon{font-size:2.5rem;margin-bottom:12px}.price-on-request h4{font-size:1.2rem;font-weight:700;color:var(--navy);margin-bottom:8px}.price-on-request p{color:var(--g500);font-size:.9rem;max-width:360px;margin:0 auto}.price-breakdown{display:flex;flex-direction:column;gap:20px}.price-items{background:var(--g50);border-radius:var(--radius);border:1px solid var(--g200);overflow:hidden}.price-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--g200);font-size:.9rem;color:var(--g700)}.price-item:last-child{border-bottom:none}.price-item-val{font-weight:600;color:var(--navy)}.price-total{text-align:center;padding:28px 20px;background:linear-gradient(135deg,var(--navy-deep),var(--navy));border-radius:var(--radius-lg);color:var(--white)}.price-total-label{font-size:.85rem;font-weight:600;opacity:.7;margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em}.price-total-val{font-family:var(--fd);font-size:2.4rem;font-weight:800;background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.price-disclaimer{font-size:.78rem;opacity:.5}.price-cta{display:flex;gap:12px;flex-wrap:wrap}.calc-restart{background:none;border:none;color:var(--g500);font-size:.85rem;cursor:pointer;margin-top:8px;transition:color .2s}.calc-restart:hover{color:var(--navy)}.calc-summary{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--g200);padding:20px;position:sticky;top:100px;box-shadow:var(--shadow-sm)}.calc-summary h4{font-size:.85rem;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.summary-item{display:flex;justify-content:space-between;font-size:.85rem;color:var(--g700);padding:8px 0;border-bottom:1px solid var(--g100)}.summary-item span:last-child{font-weight:600;color:var(--navy)}.summary-price{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:2px solid var(--g200);font-size:.9rem;color:var(--g500)}.summary-price strong{font-size:1.1rem;color:var(--orange)}@media(max-width:900px){.calc-wrapper{grid-template-columns:1fr}.calc-summary{position:static;order:-1}}@media(max-width:640px){.calculator{padding:72px 0}.calc-step-content{padding:20px}.service-select-grid{grid-template-columns:repeat(2,1fr)}.order-form-row{grid-template-columns:1fr}.calc-steps{gap:0}.calc-step span{display:none}.calc-step{padding:12px 4px}}.reviews{padding:100px 0;background:var(--white)}.reviews-summary{display:flex;align-items:center;gap:32px;flex-wrap:wrap;margin-bottom:48px;padding:28px 32px;background:var(--g50);border-radius:var(--radius-lg);border:1px solid var(--g200)}.summary-score{display:flex;flex-direction:column;gap:4px}.score-big{font-family:var(--fd);font-size:2.4rem;font-weight:800;color:var(--navy);line-height:1}.score-count{font-size:.8rem;color:var(--g500)}.stars{display:flex;gap:2px}.star{font-size:1.1rem;color:var(--g300)}.star.filled{color:#f59e0b}.google-badge{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;background:var(--white);border:1.5px solid var(--g200);border-radius:var(--radius);font-size:.9rem;font-weight:600;color:var(--g700);transition:var(--transition)}.google-badge:hover{border-color:var(--navy);color:var(--navy);transform:translateY(-1px);box-shadow:var(--shadow)}.google-g{width:28px;height:28px;background:linear-gradient(135deg,#4285f4,#34a853,#fbbc04,#ea4335);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.2rem;font-weight:900}.badge-arrow{color:var(--g400)}.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.review-card{background:var(--g50);border-radius:var(--radius-lg);padding:24px;border:1px solid var(--g200);transition:var(--transition)}.review-card:hover{background:var(--white);box-shadow:var(--shadow);transform:translateY(-2px)}.review-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.reviewer-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--blue));color:var(--white);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;flex-shrink:0}.reviewer-info{flex:1;display:flex;flex-direction:column;gap:2px}.reviewer-name{font-weight:700;font-size:.9rem;color:var(--g900)}.reviewer-location{font-size:.78rem;color:var(--g500)}.review-header .stars{margin-left:auto}.review-header .star{font-size:.9rem}.review-text{color:var(--g700);font-size:.9rem;line-height:1.7;font-style:italic;margin-bottom:16px}.review-footer{display:flex;justify-content:space-between;align-items:center}.review-service{background:#1a365d12;color:var(--navy);font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:50px}.review-date{font-size:.75rem;color:var(--g500)}@media(max-width:768px){.reviews{padding:72px 0}.reviews-grid{grid-template-columns:1fr}.reviews-summary{flex-direction:column;align-items:flex-start;gap:20px;padding:20px}}.faq{padding:100px 0;background:var(--g100)}.faq-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;align-items:start}.faq-header{position:sticky;top:100px}.faq-header .section-desc{margin-bottom:28px}.faq-list{display:flex;flex-direction:column;gap:10px}.faq-item{background:var(--white);border-radius:var(--radius);border:1px solid var(--g200);overflow:hidden;transition:border-color .25s,box-shadow .25s}.faq-item.open{border-color:var(--orange);box-shadow:0 4px 20px #ed89361a}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;background:none;border:none;text-align:left;font-size:.95rem;font-weight:600;color:var(--g900);cursor:pointer;transition:color .2s}.faq-item.open .faq-question{color:var(--navy)}.faq-icon{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--g100);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--g500);transition:var(--transition)}.faq-item.open .faq-icon{background:var(--orange);color:var(--white)}.faq-answer{overflow:hidden;transition:max-height .35s cubic-bezier(.4,0,.2,1)}.faq-answer p{padding:0 22px 20px;color:var(--g500);font-size:.92rem;line-height:1.7}@media(max-width:900px){.faq-layout{grid-template-columns:1fr;gap:40px}.faq-header{position:static}}@media(max-width:768px){.faq{padding:72px 0}.faq-question{padding:16px 18px;font-size:.9rem}.faq-answer p{padding:0 18px 16px}}.cta-section{position:relative;padding:100px 24px;text-align:center;overflow:hidden;background:var(--navy-deep)}.cta-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 20% 50%,rgba(237,137,54,.15),transparent 60%),radial-gradient(ellipse 60% 60% at 80% 50%,rgba(74,144,217,.15),transparent 60%)}.cta-inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:28px}.cta-title{font-family:var(--fd);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;color:var(--white);margin-bottom:8px}.cta-sub{color:#fff9;font-size:1.1rem;max-width:480px;line-height:1.6}.cta-phone{font-family:var(--fd);font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;color:var(--orange-light);text-decoration:none;transition:var(--transition)}.cta-phone:hover{color:var(--white);transform:scale(1.02)}.cta-methods{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}.cta-method{display:flex;align-items:center;gap:8px;padding:14px 24px;background:#ffffff14;border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius);color:var(--white);font-weight:600;font-size:.95rem;transition:var(--transition);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cta-method:hover{background:#ffffff26;border-color:#ffffff59;transform:translateY(-2px)}.method-icon{font-size:1.1rem}.cta-tax{color:#ffffff80;font-size:.88rem}.cta-tax strong{color:#ffffffbf}@media(max-width:768px){.cta-section{padding:72px 16px}.cta-methods{gap:10px}.cta-method{padding:12px 18px;font-size:.88rem}}.admin-login{min-height:100vh;background:var(--navy-deep);display:flex;align-items:center;justify-content:center;padding:24px;background-image:radial-gradient(ellipse 60% 60% at 20% 50%,rgba(237,137,54,.1),transparent 60%),radial-gradient(ellipse 60% 60% at 80% 50%,rgba(74,144,217,.1),transparent 60%)}.login-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:48px 40px;width:100%;max-width:420px;text-align:center}.login-logo{font-family:var(--fd);font-size:2rem;font-weight:800;margin-bottom:24px}.login-logo .logo-haus{color:#ffffffe6}.login-logo .logo-griff{background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-card h1{font-size:1.3rem;font-weight:700;color:var(--white);margin-bottom:8px}.login-card>p{color:#ffffff73;font-size:.9rem;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px;text-align:left}.form-group label{color:#fff9;font-size:.84rem;font-weight:600}.form-group input{background:#ffffff12;border:1.5px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:12px 16px;color:var(--white);font-size:.95rem;font-family:var(--fb);outline:none;transition:border-color .2s}.form-group input::placeholder{color:#ffffff40}.form-group input:focus{border-color:var(--orange)}.login-error{background:#dc354526;border:1px solid rgba(220,53,69,.3);color:#ff6b7a;font-size:.85rem;padding:10px 14px;border-radius:var(--radius-sm);text-align:center}.login-btn{width:100%;justify-content:center;font-size:1rem;padding:14px}.login-back{margin-top:24px}.login-back a{color:#ffffff59;font-size:.85rem;transition:color .2s}.login-back a:hover{color:#ffffffb3}.admin-layout{display:flex;min-height:100vh;background:#f0f2f5}.admin-sidebar{width:240px;flex-shrink:0;background:var(--navy-deep);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-header{padding:28px 20px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo{font-family:var(--fd);font-size:1.4rem;font-weight:800;margin-bottom:4px}.sidebar-logo .logo-haus{color:#ffffffe6}.sidebar-logo .logo-griff{background:linear-gradient(135deg,var(--orange),var(--orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-subtitle{color:#ffffff59;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:var(--radius);background:none;border:none;color:#ffffff8c;font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition);text-align:left;width:100%}.sidebar-item:hover{background:#ffffff12;color:#ffffffe6}.sidebar-item.active{background:#ed893626;color:var(--orange-light)}.sidebar-icon{font-size:1.1rem}.sidebar-footer{padding:16px 12px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:6px}.sidebar-view-site,.sidebar-logout{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius);font-size:.85rem;font-weight:500;cursor:pointer;transition:var(--transition);width:100%;text-align:left}.sidebar-view-site{color:#ffffff73;background:none;border:1px solid rgba(255,255,255,.08)}.sidebar-view-site:hover{background:#ffffff0f;color:#ffffffbf}.sidebar-logout{background:none;border:none;color:#ed893699}.sidebar-logout:hover{background:#ed893614;color:var(--orange)}.admin-main{flex:1;display:flex;flex-direction:column;min-width:0}.admin-topbar{background:var(--white);padding:16px 24px;display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--g200);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:50}.topbar-menu{display:none;background:none;border:none;font-size:1.3rem;cursor:pointer;padding:4px;color:var(--g700)}.topbar-title{font-size:1.1rem;font-weight:700;color:var(--navy);flex:1;display:flex;align-items:center;gap:8px}.topbar-badge{background:#1a365d14;color:var(--navy);font-size:.78rem;font-weight:600;padding:4px 12px;border-radius:50px}.admin-content{flex:1;padding:32px 28px;overflow-y:auto}.admin-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--g200);padding:24px;margin-bottom:20px}.admin-section-title{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--g200)}.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.admin-input-group{display:flex;flex-direction:column;gap:6px}.admin-input-group label{font-size:.82rem;font-weight:600;color:var(--g700)}.admin-input-group input,.admin-input-group textarea,.admin-input-group select{padding:10px 14px;border:1.5px solid var(--g200);border-radius:var(--radius);font-family:var(--fb);font-size:.9rem;color:var(--g900);transition:border-color .2s;outline:none;background:var(--white)}.admin-input-group input:focus,.admin-input-group textarea:focus,.admin-input-group select:focus{border-color:var(--navy)}.admin-input-group textarea{resize:vertical;min-height:80px}.admin-btn{padding:10px 20px;border-radius:var(--radius);font-size:.88rem;font-weight:600;cursor:pointer;border:none;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.admin-btn-primary{background:var(--navy);color:var(--white)}.admin-btn-primary:hover{background:var(--navy-mid);transform:translateY(-1px)}.admin-btn-orange{background:var(--orange);color:var(--white)}.admin-btn-orange:hover{background:var(--orange-deep);transform:translateY(-1px)}.admin-btn-danger{background:#dc35451a;color:#dc3545;border:1px solid rgba(220,53,69,.2)}.admin-btn-danger:hover{background:#dc354533}.admin-btn-secondary{background:var(--g100);color:var(--g700);border:1px solid var(--g200)}.admin-btn-secondary:hover{background:var(--g200)}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;padding:10px 12px;background:var(--g50);font-size:.78rem;font-weight:700;color:var(--g500);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--g200)}.admin-table td{padding:12px;font-size:.88rem;border-bottom:1px solid var(--g100);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--g50)}.admin-success{background:#48c78e1a;border:1px solid rgba(72,199,142,.3);color:#276749;padding:10px 16px;border-radius:var(--radius);font-size:.88rem;margin-bottom:16px}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:90}@media(max-width:900px){.admin-sidebar{position:fixed;left:-240px;top:0;bottom:0;z-index:100;transition:left .3s cubic-bezier(.4,0,.2,1)}.admin-sidebar.open{left:0}.sidebar-overlay,.topbar-menu{display:block}.admin-content{padding:20px 16px}.admin-form-row{grid-template-columns:1fr}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--navy: #1a365d;--navy-deep: #0f1f3d;--navy-mid: #1e3a6e;--blue: #2b579a;--sky: #4a90d9;--orange: #ed8936;--orange-light: #f6ad55;--orange-deep: #d4782e;--cream: #fdf8f0;--white: #fff;--g50: #f9fafb;--g100: #f7f7f8;--g200: #e8e8ec;--g300: #d1d5db;--g500: #6b7280;--g700: #374151;--g900: #111827;--fb: "DM Sans", sans-serif;--fd: "Playfair Display", serif;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--shadow: 0 4px 20px rgba(0,0,0,.08);--shadow-lg: 0 12px 40px rgba(0,0,0,.12);--shadow-orange: 0 4px 24px rgba(237,137,54,.35);--transition: all .3s cubic-bezier(.4,0,.2,1)}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--fb);color:var(--g900);background:var(--white);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--fb)}.container{max-width:1100px;margin:0 auto;padding:0 24px}.container-wide{max-width:1280px;margin:0 auto;padding:0 24px}.section-label{display:inline-block;background:#1a365d14;color:var(--navy);padding:6px 16px;border-radius:50px;font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}.section-title{font-family:var(--fd);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;color:var(--navy);margin-bottom:12px;line-height:1.15}.section-desc{color:var(--g500);font-size:1.05rem;max-width:580px;margin-bottom:48px;line-height:1.7}.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius);font-family:var(--fb);font-size:.95rem;font-weight:600;transition:var(--transition);cursor:pointer;border:none;text-decoration:none}.btn-orange{background:linear-gradient(135deg,var(--orange),var(--orange-deep));color:var(--white);box-shadow:var(--shadow-orange)}.btn-orange:hover{background:linear-gradient(135deg,var(--orange-light),var(--orange));transform:translateY(-2px);box-shadow:0 8px 32px #ed893673}.btn-outline-dark{background:transparent;color:var(--navy);border:1.5px solid var(--g300)}.btn-outline-dark:hover{border-color:var(--navy);background:#1a365d0a;transform:translateY(-2px)}.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}.reveal:nth-child(1){transition-delay:0s}.reveal:nth-child(2){transition-delay:.1s}.reveal:nth-child(3){transition-delay:.2s}.reveal:nth-child(4){transition-delay:.3s}.reveal:nth-child(5){transition-delay:.4s}.reveal:nth-child(6){transition-delay:.5s}@keyframes fadeDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--g100)}::-webkit-scrollbar-thumb{background:var(--g300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--g500)}@media(max-width:768px){.container,.container-wide{padding:0 16px}.section-title{font-size:clamp(1.6rem,6vw,2.2rem)}}.service-admin-row{border:1px solid var(--g200);border-radius:var(--radius);overflow:hidden}.service-row-display{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--white)}.service-row-icon{font-size:1.4rem;flex-shrink:0}.service-row-info{flex:1;display:flex;flex-direction:column;gap:2px}.service-row-info strong{font-size:.92rem;color:var(--g900)}.service-row-info span{font-size:.82rem;color:var(--g500)}.service-edit-form{padding:16px;background:var(--g50)}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.84rem;color:var(--g500);font-weight:500}.toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--orange);cursor:pointer}.portfolio-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.portfolio-admin-card{background:var(--white);border:1px solid var(--g200);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}.portfolio-admin-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.pa-image{aspect-ratio:4/3;position:relative;overflow:hidden}.pa-image img{width:100%;height:100%;object-fit:cover}.pa-no-image{width:100%;height:100%;background:var(--g100);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--g500);flex-direction:column;gap:4px}.pa-featured-badge{position:absolute;top:8px;right:8px;background:var(--orange);color:var(--white);font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:50px}.pa-body{padding:12px 14px}.pa-category{font-size:.72rem;font-weight:600;color:var(--navy);background:#1a365d12;padding:2px 8px;border-radius:50px;display:inline-block;margin-bottom:6px}.pa-body h3{font-size:.9rem;font-weight:700;color:var(--g900);margin-bottom:4px}.pa-body p{font-size:.78rem;color:var(--g500)}.pa-actions{display:flex;gap:8px;padding:10px 14px;border-top:1px solid var(--g100)}.image-upload-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.image-upload-box{border:2px dashed var(--g300);border-radius:var(--radius);aspect-ratio:4/3;cursor:pointer;overflow:hidden;transition:border-color .2s;position:relative}.image-upload-box:hover{border-color:var(--navy)}.image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px;text-align:center}.upload-icon{font-size:1.8rem}.image-placeholder>span:nth-child(2){font-size:.85rem;font-weight:600;color:var(--g700)}.upload-hint{font-size:.75rem;color:var(--g500);line-height:1.4}.image-preview{position:relative;width:100%;height:100%}.image-preview img{width:100%;height:100%;object-fit:cover}.image-remove{position:absolute;top:8px;right:8px;background:#0009;color:var(--white);border:none;border-radius:50%;width:24px;height:24px;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.image-remove:hover{background:#dc3545cc}@media(max-width:600px){.image-upload-row{grid-template-columns:1fr}.service-row-display{flex-wrap:wrap}}
