@charset "UTF-8";
@font-face{font-family:"Raleway";src:url("../themes/main/assets/fonts/Raleway-VariableFont_wght.woff2") format("woff2");font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:"bootstrap-icons";src:url("../themes/main/assets/bootstrap/icons/font/fonts/bootstrap-icons.woff2") format("woff2"),url("../themes/main/assets/bootstrap/icons/font/fonts/bootstrap-icons.woff") format("woff");font-weight:normal;font-style:normal;font-display:swap !important}
header{width:100%}
header .top-bar{height:60px;position:relative}
header .top-bar::after{content:"";background-color:var(--accent);position:absolute;left:0;height:10px;width:100%;bottom:-5px}
header .bottom-bar{width:100%;padding:24px 0}
header .bottom-bar .logo-wrapper .logo-image{max-width:100%;height:auto;display:block}
header .scrolled{position:fixed;top:0;left:0;width:100%;background-color:white;box-shadow:0 0 10px rgba(0,0,0,0.15);z-index:99999}
nav.navbar .navbar-brand{font-weight:700;color:var(--bs-primary)}
nav.navbar .navbar-toggler{border:none;box-shadow:none}
nav.navbar .navbar-toggler:focus{box-shadow:none}
nav.navbar .navbar-nav .nav-item .nav-link{padding:12px 16px;text-transform:uppercase;font-weight:500;line-height:20px;color:var(--bs-primary);position:relative;transition:all 0.2s ease}
nav.navbar .navbar-nav .nav-item .nav-link:hover{color:var(--bs-primary)}
nav.navbar .navbar-nav .nav-item .nav-link:hover::before{content:"";position:absolute;top:12px;left:0;height:20px;width:4px;background-color:var(--accent);border-radius:4px}
nav.navbar .navbar-nav .nav-item .nav-link.active,nav.navbar .navbar-nav .nav-item .nav-link[aria-current="page"]{position:relative}
nav.navbar .navbar-nav .nav-item .nav-link.active::before,nav.navbar .navbar-nav .nav-item .nav-link[aria-current="page"]::before{content:"";position:absolute;top:12px;left:0;height:20px;width:4px;background-color:var(--accent);border-radius:4px}
nav.navbar .dropdown-menu{position:absolute;top:calc(100% - 10px);z-index:1000;background-color:#fff;padding:0.5rem;border:1px solid #ddd;min-width:250px;max-height:60vh;overflow-y:auto}
nav.navbar .dropdown-menu .dropdown-item{list-style:none;padding:0}
nav.navbar .dropdown-menu .dropdown-item .dropdown-link{display:block;padding:0.5rem;text-decoration:none;color:#333}
nav.navbar .dropdown-menu .dropdown-item .dropdown-link:hover{background-color:#f5f5f5}
.offcanvas .offcanvas-header{border-bottom:1px solid rgba(0,0,0,0.08)}
.offcanvas .offcanvas-header .offcanvas-title{color:var(--bs-primary);font-weight:700;text-transform:uppercase}
.offcanvas .offcanvas-header .btn-close{box-shadow:none}
.offcanvas .offcanvas-header .btn-close:focus{box-shadow:none}
.offcanvas .offcanvas-body .nav-link{color:var(--bs-primary);font-weight:500;transition:all 0.2s ease}
.offcanvas .offcanvas-body .nav-link.bg-light{background-color:#f4f6f8 !important;border-radius:10px;padding:12px 14px;text-transform:none}
.offcanvas .offcanvas-body .nav-link.bg-light:hover{background-color:rgba(var(--bs-primary-rgb),0.08) !important;color:var(--bs-primary)}
.offcanvas .offcanvas-body .small{letter-spacing:0.08em}
@media (min-width:1200px){nav.navbar .nav-item.dropdown.position-static{position:static !important}nav.navbar .nav-item.dropdown:hover .dropdown-menu{display:block}}
.offcanvas .nav-item .nav-link{padding:12px;text-transform:uppercase;font-weight:500;line-height:20px;color:var(--bs-primary)}
.offcanvas .nav-item .active{position:relative}
.offcanvas .nav-item .active::before{content:"";position:absolute;left:0;height:20px;width:4px;background-color:var(--accent)}
footer{position:relative;padding:100px 0;background-color:#1E3067;color:white}
footer .line-after::after{background-color:white}
footer .logo-wrapper .logo-image{max-width:100%;height:auto;display:block}
footer .footer-menu .footer-links{padding:0;margin:10px 0}
footer .footer-menu .footer-links .footer-item{padding:10px}
footer .footer-menu .footer-links .footer-item::marker{content:"▸"}
footer .footer-menu .footer-links .footer-item .footer-link{transition-duration:300ms;color:white}
footer .footer-menu .footer-links .footer-item .footer-link:hover{opacity:0.6}
@media (max-width:575px){footer .footer-menu{flex-direction:column}}
footer .newsletter{margin:10px 0;display:flex;flex-direction:column;gap:16px}
footer .newsletter .form-field{padding:12px 20px;background-color:transparent;border:2px solid white;border-radius:100px;color:white;font-size:16px;width:100%}
footer .newsletter .form-field::placeholder{color:white;opacity:1}
footer .newsletter .form-field::-ms-input-placeholder{color:white}
footer .newsletter .btn{padding:16px 32px;border-radius:100px;width:fit-content;margin-left:auto}
footer .newsletter .btn:hover{background-color:transparent;color:white;border-color:white}
:root{--accent:#A4BBD6}
h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{font-weight:600 !important}
h1,.h1{font-size:clamp(28px,calc(28px + (52px - 28px) * ((100vw - 360px) / (1400px - 360px))),52px) !important}
h2,.h2{font-size:clamp(26px,calc(26px + (42px - 26px) * ((100vw - 360px) / (1400px - 360px))),42px) !important}
h3,.h3{font-size:clamp(24px,calc(24px + (34px - 24px) * ((100vw - 360px) / (1400px - 360px))),34px) !important}
h4,.h4{font-size:clamp(22px,calc(22px + (28px - 22px) * ((100vw - 360px) / (1400px - 360px))),28px) !important}
h5,.h5{font-size:clamp(18px,calc(18px + (22px - 18px) * ((100vw - 360px) / (1400px - 360px))),22px) !important}
h6,.h6{font-size:clamp(16px,calc(16px + (20px - 16px) * ((100vw - 360px) / (1400px - 360px))),20px) !important}
body{font-family:"Raleway" !important;font-size:1rem}
body [id]{scroll-margin-top:100px}
body .anchor-target{scroll-margin-top:100px}
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:#A4BBD6}
::-webkit-scrollbar-thumb{background:#2A2C69}
::-webkit-scrollbar-thumb:hover{background:#1b1d45}
.overlay{position:absolute;top:0;left:0;z-index:0;width:100%;height:100%;background-color:rgba(0,0,0,0.6);backdrop-filter:blur(5px)}
img{max-width:100%;height:100%;object-fit:cover;border-radius:10px}
a{color:var(--bs-primary);text-decoration:none !important}
.logo-image{width:150px;object-fit:cover}
@media (max-width:480px){.logo-image{width:100px}}
.text-accent{color:var(--accent) !important}
.hr{border-top:5px solid white;border-radius:100px;width:70px;opacity:1;margin:30px 0 60px 0}
.hr-primary{border-top:5px solid var(--bs-primary)}
.hr-white{border-top:5px solid white}
.line-after{position:relative}
.line-after::after{content:"";position:absolute;bottom:-10px;left:0;width:70px;height:3px;border-radius:100px;background-color:var(--accent)}
section{position:relative;padding:70px 0}
section .btn{font-weight:500;padding:16px 32px;border-radius:100px;text-transform:uppercase}
section .btn-primary{color:white !important;background-color:var(--bs-primary)}
section .btn-primary:hover{background-color:white;border-color:var(--bs-primary);color:var(--bs-primary) !important}
section .btn-white{color:var(--bs-primary) !important;background-color:white}
section .btn-white:hover{background-color:#f1f1f1;border-color:var(--bs-primary);color:var(--bs-primary) !important}
section .btn-green{color:white !important;background-color:#1DAF54}
section .btn-green:hover{background-color:#108d40;border-color:#1DAF54;color:white !important}
.home-header{background:linear-gradient(rgba(0,0,0,0.6),rgba(0,0,0,0.6)),url("/storage/app/media/schluesseldienst-duesseldorf.de_1.webp");background-size:cover;background-position:center}
.home-header>.container{position:relative;z-index:2}
.form-wrapper{position:relative;z-index:3}
.form-wrapper .form-header{border-top-left-radius:10px;border-top-right-radius:10px;background-color:var(--bs-primary);color:white;padding:40px;position:relative}
.form-wrapper .form-header::after{content:"";background-color:var(--accent);position:absolute;left:0;height:10px;width:100%;bottom:-5px}
.form-wrapper .form-body-footer{background-color:unset !important;padding:unset !important}
.form-wrapper .form-body{border-bottom-left-radius:10px;border-bottom-right-radius:10px;background-color:white;padding:40px}
.form-wrapper .form-body .contact-form{display:flex;flex-direction:column;gap:16px}
.form-wrapper .form-body .contact-form .form-field{padding:12px 20px;border-radius:5px;border:2px solid var(--bs-primary)}
.contact-form{display:flex;flex-direction:column;gap:16px}
.contact-form .form-field{padding:12px 20px;border-radius:0;border:2px solid var(--bs-primary);width:100%}
.leistungen{background:url("/storage/app/media/duesseldorf.webp") scroll center;background-size:cover;position:relative}
.leistungen h2{text-transform:none !important}
.leistungen .overlay{background-color:var(--bs-primary);opacity:0.8;position:absolute;left:0;top:0;width:100%;height:100%;z-index:0}
.leistungen .container{position:relative;z-index:1}
.leistungen .leistung-card{padding:35px;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;height:250px;width:100%;background-color:rgba(164,187,214,0.75);transition:300ms}
.leistungen .leistung-card:hover{border:3px solid white}
.kunden{background-color:#F7F8F8}
.kunden .carousel-control-prev-icon,.kunden .carousel-control-next-icon{width:80px;height:80px}
.kunden .carousel-control-next-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23152e5a'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708'/%3e%3c/svg%3e")}
.kunden .carousel-control-prev-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23152e5a'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0'/%3e%3c/svg%3e")}
table.gebiet-table,table.custom-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden}
table.gebiet-table thead,table.custom-table thead{background:linear-gradient(135deg,#111827,#1f2937);color:#f9fafb}
table.gebiet-table th,table.gebiet-table td,table.custom-table th,table.custom-table td{padding:10px;text-align:left;font-size:0.95rem}
table.gebiet-table th,table.custom-table th{font-weight:600;letter-spacing:0.02em}
table.gebiet-table tbody tr:nth-child(even),table.custom-table tbody tr:nth-child(even){background-color:#f9fafb}
table.gebiet-table tbody tr:hover,table.custom-table tbody tr:hover{background-color:#eef2ff;transition:background-color 0.15s ease-out}
table.gebiet-table .gebiet-label,table.custom-table .gebiet-label{font-weight:500;color:#111827}
table.gebiet-table .gebiet-value,table.custom-table .gebiet-value{font-weight:600;color:#047857}
table.gebiet-table .gebiet-detail,table.custom-table .gebiet-detail{font-size:0.8rem;color:#6b7280;margin-left:4px}
@media (max-width:480px){.gebiet-table th,.gebiet-table td{padding:10px 12px}}
.card-lg{position:relative;display:flex;align-items:flex-end;min-height:550px;padding:25px 20px;background-position:center;background-size:cover;background-repeat:no-repeat;text-decoration:none;overflow:hidden}
.card-lg::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.75),rgba(0,0,0,0.15));z-index:1}
.card-lg .card-content{position:relative;z-index:2;width:100%}
.card-lg .h5,.card-lg p{position:relative;z-index:2}
.duesseldorf-cards{margin:40px 0}
.duesseldorf-cards__grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.duesseldorf-cards .duesseldorf-card{display:flex;flex-direction:column;justify-content:space-between;min-height:140px;padding:18px;border-radius:14px;text-decoration:none;background:#fff;border:1px solid rgba(0,0,0,0.08);box-shadow:0 8px 18px rgba(0,0,0,0.06);transition:transform 0.15s ease,box-shadow 0.15s ease,border-color 0.15s ease}
.duesseldorf-cards .duesseldorf-card:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,0,0,0.1);border-color:rgba(0,0,0,0.14)}
.duesseldorf-cards .duesseldorf-card:focus-visible{outline:3px solid #f5cc00;outline-offset:3px}
.duesseldorf-cards .duesseldorf-card__title{font-weight:700;font-size:1.05rem;line-height:1.25;color:#111}
.duesseldorf-cards .duesseldorf-card__meta{margin-top:10px;font-size:0.9rem;color:rgba(0,0,0,0.6)}