/* ===================================================================
   DEKOM.IT – Gemeinsames Design-System (v2 „Vertrauen mit Gesicht")
   Warme Paper-Farbwelt · Sora + Inter · Amber-Akzent.
   Eingebunden von allen Unterseiten via <link href="/assets/dekom.css">.
   Klassennamen bleiben kompatibel zur bestehenden Seitenstruktur –
   nur die visuelle Sprache ist neu.
   =================================================================== */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  /* Kern-Palette (neu) */
  --ink:#0B1020;--ink-2:#141a2e;--ink-soft:#2a3147;
  --paper:#F5F3EE;--paper-2:#EDEAE2;--white:#ffffff;
  --blue:#1E47FF;--blue-dark:#1536CC;--blue-soft:#E7ECFF;
  --amber:#E9A93B;--amber-soft:#FBEFD8;--emerald:#0FA968;
  /* Rückwärtskompatible Aliase (werden inline von Unterseiten genutzt) */
  --primary:#1E47FF;--primary-dark:#1536CC;--primary-light:#E7ECFF;
  --accent:#60A5FA;--accent-dark:#3B82F6;--accent-light:#DBEAFE;
  --gray-900:#0B1020;--gray-700:#3a4158;--gray-500:#6b7186;--gray-300:#b0b0c8;--gray-100:#EDEAE2;
  --bg-light:#EDEAE2;--text-muted:#6b7186;
  --danger:#e5484d;--success:#0FA968;--line:#E2DED5;
  --radius:14px;--radius-lg:22px;--r-pill:100px;
  --shadow-sm:0 2px 14px rgba(11,16,32,.05);
  --shadow:0 18px 50px rgba(11,16,32,.10);--shadow-lg:0 30px 80px rgba(11,16,32,.18);
  --transition:.25s cubic-bezier(.4,0,.2,1);--ease:cubic-bezier(.4,0,.2,1);
  --max-width:1180px;--content-width:760px;
}

html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;padding-bottom:72px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:'Sora',sans-serif;font-weight:700;letter-spacing:-.02em;line-height:1.12;color:var(--ink);overflow-wrap:break-word}
.container{max-width:var(--max-width);margin:0 auto;padding:0 24px}
.skip-link{position:absolute;top:-100px;left:16px;background:var(--blue);color:#fff;padding:12px 24px;border-radius:10px;z-index:9999;font-weight:600;transition:top .3s}
.skip-link:focus{top:16px}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:6px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ── ANIMATION ── */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(15,169,104,.6)}70%{box-shadow:0 0 0 9px rgba(15,169,104,0)}100%{box-shadow:0 0 0 0 rgba(15,169,104,0)}}
@keyframes spin{to{transform:rotate(360deg)}}
.spinner{animation:spin 1s linear infinite}
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay-1{transition-delay:.08s}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}.reveal-delay-5{transition-delay:.4s}

/* ── UTILITY BAR (oberhalb der Nav) ── */
.util{background:var(--ink);color:#c9cedf;font-size:.84rem}
.util .container{display:flex;align-items:center;justify-content:space-between;height:42px;gap:18px}
.util-l,.util-r{display:flex;align-items:center;gap:20px}
.util a{color:#e7eaf4;font-weight:500}
.util a:hover{color:#fff}
.util .dot{width:7px;height:7px;border-radius:50%;background:var(--emerald);box-shadow:0 0 0 3px rgba(15,169,104,.25);flex-shrink:0}
@media(max-width:760px){.util-r{display:none}}

/* ── NAV (hell, sticky) ── */
.nav{position:sticky;top:0;z-index:1000;background:rgba(245,243,238,.82);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max-width);margin:0 auto;padding:0 24px;height:72px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{color:var(--gray-700);font-size:.95rem;font-weight:500;transition:.2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--blue);color:#fff!important;padding:11px 22px;border-radius:11px;font-family:'Sora';font-weight:600!important;transition:.25s var(--ease)!important;box-shadow:0 8px 22px rgba(30,71,255,.28)}
.nav-cta:hover{background:var(--blue-dark)!important;transform:translateY(-1px)}
.nav-mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-mobile-toggle span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
@media(max-width:980px){
  .nav-links{display:none}
  .nav-mobile-toggle{display:flex}
  .nav-links.mobile-open{display:flex;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:var(--white);padding:22px 24px;gap:18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:'Sora',sans-serif;font-weight:600;font-size:.98rem;padding:15px 26px;border-radius:12px;border:1px solid transparent;cursor:pointer;transition:.25s var(--ease);white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 26px rgba(30,71,255,.30)}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 16px 36px rgba(30,71,255,.40)}
.btn-accent{background:var(--blue);color:#fff;box-shadow:0 10px 26px rgba(30,71,255,.30)}
.btn-accent:hover{background:var(--blue-dark);color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-outline:hover{border-color:var(--ink);background:var(--white)}
.btn-outline-dark{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn-outline-dark:hover{border-color:var(--ink);background:var(--white)}
.btn-arrow{transition:transform .25s}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* ── KICKER / PILL BADGES ── */
.pill-badge{display:inline-flex;align-items:center;gap:9px;font-family:'Sora',sans-serif;font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue)}
.pill-badge::before{content:'';width:22px;height:2px;border-radius:2px;background:var(--amber)}
.pill-badge-light{color:var(--blue)}
.pill-badge-dark{color:#8ea2ff}
.pill-badge-dark::before{background:var(--amber)}

/* ── SECTIONS ── */
section{padding:90px 0}
.section-label{margin-bottom:18px}
.section-title{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:800;color:var(--ink);line-height:1.14;margin-bottom:18px}
.section-sub{font-size:1.08rem;color:var(--gray-700);max-width:640px;line-height:1.65}
.bg-white{background:var(--white)}
.bg-light{background:var(--paper-2)}
.bg-soft{background:var(--paper)}

/* ── SUBPAGE HERO (hell) ── */
.subhero{position:relative;background:var(--paper);overflow:hidden;padding:120px 0 64px;border-bottom:1px solid var(--line)}
.subhero::before{content:'';position:absolute;top:-30%;right:-8%;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(30,71,255,.07),transparent 70%);pointer-events:none;animation:float 10s ease-in-out infinite}
.subhero-grid{display:none}
.subhero .container{position:relative;z-index:2}
.subhero-inner{max-width:840px}
.subhero h1{font-size:clamp(2.1rem,5vw,3.3rem);font-weight:800;color:var(--ink);line-height:1.1;letter-spacing:-.025em;margin:18px 0 18px}
.subhero h1 em{font-style:normal;color:var(--ink);-webkit-text-decoration:underline var(--amber);text-decoration:underline;text-decoration-color:var(--amber);text-decoration-thickness:.13em;text-underline-offset:.08em;text-decoration-skip-ink:none}
.subhero-sub{font-size:clamp(1.05rem,2vw,1.25rem);color:var(--gray-700);max-width:640px;margin-bottom:30px}
.subhero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:38px;align-items:center}
.subhero-stats{display:flex;gap:40px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:26px}
.subhero-stat-num{font-family:'Sora',sans-serif;font-size:1.7rem;font-weight:700;color:var(--ink)}
.subhero-stat-label{font-size:.82rem;color:var(--gray-500);margin-top:3px}

/* ── BREADCRUMB ── */
.breadcrumb{font-size:.84rem;color:var(--gray-500)}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.breadcrumb a{color:var(--blue);font-weight:500}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb li:not(:last-child)::after{content:'/';margin-left:6px;color:var(--gray-300)}
.breadcrumb-light a{color:var(--blue)}

/* ── PROSE ── */
.prose{max-width:var(--content-width);margin:0 auto}
.prose>*+*{margin-top:1.1em}
.prose h2{font-size:1.7rem;font-weight:700;color:var(--ink);margin-top:1.6em}
.prose h3{font-size:1.25rem;font-weight:700;color:var(--ink);margin-top:1.4em}
.prose p,.prose li{font-size:1.04rem;color:var(--gray-700);line-height:1.78}
.prose ul:not(.card-list),.prose ol{padding-left:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.prose ul:not(.card-list) li{position:relative;padding-left:30px}
.prose ul:not(.card-list) li::before{content:'';position:absolute;left:4px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--blue)}
.prose ol{counter-reset:ol}
.prose ol li{position:relative;padding-left:38px;counter-increment:ol}
.prose ol li::before{content:counter(ol);position:absolute;left:0;top:1px;width:25px;height:25px;border-radius:50%;background:var(--blue-soft);color:var(--blue);font-family:'Sora';font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.prose strong{color:var(--ink);font-weight:600}
.prose a{color:var(--blue);font-weight:500;text-decoration:underline;text-decoration-color:var(--blue-soft);text-underline-offset:3px}
.prose a:hover{text-decoration-color:var(--blue)}
.prose blockquote{border-left:3px solid var(--amber);background:var(--white);padding:16px 22px;border-radius:0 12px 12px 0;font-size:1.06rem;color:var(--gray-700);box-shadow:var(--shadow-sm)}
.lead{font-size:1.2rem;color:var(--gray-700);line-height:1.7}

/* ── KEY-BOX ── */
.keybox{background:var(--white);border:1px solid var(--line);border-left:3px solid var(--amber);border-radius:0 14px 14px 0;padding:24px 28px;box-shadow:var(--shadow-sm)}
.keybox h2,.keybox h3{margin-top:0;font-family:'Sora';font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--blue)}
.keybox ul{margin-top:12px}

/* ── GRID / CARDS ── */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:.25s var(--ease);position:relative}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.card-icon{width:48px;height:48px;border-radius:12px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--blue)}
.card h3{font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.card p{font-size:.92rem;color:var(--gray-500);line-height:1.6;margin-bottom:14px}
.card-list{list-style:none;display:flex;flex-direction:column;gap:9px}
.card-list li{position:relative;padding-left:19px;font-size:.88rem;color:var(--gray-700);line-height:1.5;overflow-wrap:break-word}
.card-list li::before{content:'';position:absolute;left:1px;top:.5em;width:6px;height:6px;border-radius:50%;background:var(--amber)}
.card-list li a{color:var(--blue);font-weight:500}
.card-link{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-family:'Sora';font-size:.86rem;font-weight:600;color:var(--blue);transition:.2s}
.card-link:hover{gap:10px}

/* ── CHECK LISTS ── */
.checks{list-style:none;display:flex;flex-direction:column;gap:14px}
.checks li{display:flex;align-items:flex-start;gap:12px;font-size:.98rem;line-height:1.55;color:var(--gray-700)}
.checks li svg{color:var(--emerald);flex-shrink:0;margin-top:3px}
.checks-dark li{color:var(--gray-300)}
.checks-dark li svg{color:var(--amber)}

/* ── LOCAL / NAP ── */
.nap{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:18px}
.nap li{display:flex;gap:12px;align-items:flex-start;font-size:.96rem;color:var(--gray-300)}
.nap a{color:#fff;font-weight:600}

/* ── TRUST BAR ── */
.trust-bar{background:var(--white);border-bottom:1px solid var(--line);padding:24px 0}
.trust-bar-inner{display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap}
.trust-bar-item{font-size:.85rem;color:var(--gray-700);font-weight:500;display:flex;align-items:center;gap:8px}
.trust-bar-item svg{color:var(--blue);flex-shrink:0}

/* ── STEPS ── */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:s}
.step{padding-top:18px;border-top:3px solid var(--blue);position:relative}
.step .step-num,.step-num{width:auto;height:auto;border:none;background:none;box-shadow:none;display:block;margin:0 0 8px;font-family:'Sora';font-weight:800;font-size:1.4rem;color:var(--amber);text-align:left}
.step h3{font-size:1.12rem;font-weight:700;color:var(--ink);margin-bottom:8px}
.step p{font-size:.92rem;color:var(--gray-700);line-height:1.55}

/* ── FAQ ── */
.faq-list{max-width:var(--content-width);margin:46px auto 0;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.2s}
.faq-item:hover{border-color:var(--blue)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:20px 26px;cursor:pointer;width:100%;background:none;border:none;font-family:'Sora',sans-serif;font-size:1.02rem;font-weight:600;color:var(--ink);text-align:left;gap:16px}
.faq-question svg{flex-shrink:0;transition:transform .3s;color:var(--blue)}
.faq-item.active .faq-question svg{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.active .faq-answer{max-height:420px}
.faq-answer-inner{padding:0 26px 22px;color:var(--gray-700);font-size:.96rem;line-height:1.7}
.faq-answer-inner a{color:var(--blue);font-weight:500}

/* ── RELATED / LINKCLOUD ── */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.related a{display:block;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:22px;transition:.25s var(--ease)}
.related a:hover{border-color:transparent;transform:translateY(-4px);box-shadow:var(--shadow)}
.related .rl-kicker{font-family:'Sora';font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--amber);font-weight:700}
.related .rl-title{display:block;font-family:'Sora';font-size:1rem;font-weight:700;color:var(--ink);margin-top:6px}
.related .rl-desc{display:block;font-size:.85rem;color:var(--gray-500);margin-top:6px;line-height:1.5}
.linkcloud{display:flex;flex-wrap:wrap;gap:10px}
.linkcloud a{background:var(--white);border:1px solid var(--line);color:var(--gray-700);padding:11px 20px;border-radius:var(--r-pill);font-family:'Sora';font-size:.9rem;font-weight:500;transition:.2s}
.linkcloud a:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}

/* ── CONTACT / CTA (dunkel) ── */
.ctablock{background:linear-gradient(160deg,#0B1020,#16203f);position:relative;overflow:hidden}
.ctablock::before{content:'';position:absolute;top:-120px;left:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(30,71,255,.28),transparent 70%)}
.ctablock .container{position:relative;z-index:2}
.ctablock .section-title{color:#fff}
.ctablock .section-sub{color:#c9cedf}
.ctablock .pill-badge{color:#8ea2ff}
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:46px}
.contact-wrap>*{min-width:0}
.contact-aside h3{color:#fff;font-family:'Sora';font-size:1.3rem;margin-bottom:16px}
.contact-phone{font-family:'Sora';font-size:1.4rem;color:#fff;display:inline-flex;align-items:center;gap:12px}
.contact-phone:hover{color:var(--amber)}
/* Formular als weiße Karte */
.cform{background:var(--white);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-lg)}
.cform-group{margin-bottom:14px}
.cform-group label{display:block;font-family:'Sora';font-size:.82rem;font-weight:600;color:var(--gray-700);margin-bottom:6px}
.cform-group input,.cform-group textarea,.cform-group select{width:100%;padding:13px 15px;border-radius:11px;background:var(--paper);border:1px solid var(--line);color:var(--ink);font-family:'Inter',sans-serif;font-size:.95rem;transition:.2s;outline:none}
.cform-group input::placeholder,.cform-group textarea::placeholder{color:var(--gray-500)}
.cform-group input:focus,.cform-group textarea:focus,.cform-group select:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px var(--blue-soft)}
.cform-group textarea{resize:vertical;min-height:88px}
.cform-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform .btn{width:100%;justify-content:center;margin-top:6px}
.cform-note{font-size:.78rem;color:var(--gray-500);text-align:center;margin-top:12px}
.cform-group.has-error input,.cform-group.has-error textarea,.cform-group.has-error select{border-color:var(--danger);background:#fff5f5}
.hp-field{position:absolute!important;left:-9999px;top:-9999px;opacity:0;height:0;width:0;overflow:hidden;pointer-events:none}
.dsgvo-check{display:flex;align-items:flex-start;gap:10px;margin:14px 0 4px}
.dsgvo-check input[type="checkbox"]{width:18px;height:18px;margin-top:2px;accent-color:var(--blue);flex-shrink:0;cursor:pointer}
.dsgvo-check label{font-size:.78rem;color:var(--gray-500);line-height:1.5}
.dsgvo-check a{color:var(--blue);text-decoration:underline}

/* ── FOOTER (dunkel) ── */
.footer{background:var(--ink);color:var(--gray-300);padding:62px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.footer-brand{max-width:340px}
.footer-brand img{height:38px;margin-bottom:16px}
.footer-brand p{font-size:.88rem;line-height:1.7;margin-bottom:18px;color:#9aa3c0}
.footer h4{color:#fff;font-family:'Sora';font-size:.82rem;font-weight:700;margin-bottom:18px;letter-spacing:.08em;text-transform:uppercase}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:11px}
.footer-links a{color:#9aa3c0;font-size:.9rem;transition:.2s}
.footer-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:26px;display:flex;align-items:center;justify-content:space-between;font-size:.82rem;color:#9aa3c0;flex-wrap:wrap;gap:12px}
.footer-bottom a{color:#9aa3c0}
.footer-bottom a:hover{color:#fff}

/* ── STICKY CTA (mobil) ── */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;z-index:999;background:var(--white);box-shadow:0 -6px 24px rgba(11,16,32,.1);padding:10px 16px;display:none;border-top:1px solid var(--line)}
.sticky-cta.visible{display:block}
.sticky-cta-inner{max-width:var(--max-width);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:14px}
.sticky-cta-text{font-family:'Sora';font-weight:600;color:var(--ink);font-size:.92rem}
.sticky-cta-text span{color:var(--blue)}
.sticky-cta-actions{display:flex;gap:10px}
.sticky-cta .btn{padding:11px 20px;font-size:.9rem}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .related{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .contact-wrap{grid-template-columns:1fr;gap:32px}
}
@media(max-width:768px){
  section{padding:56px 0}
  .subhero{padding:84px 0 48px}
  .subhero h1{font-size:clamp(1.6rem,6.4vw,2.3rem);letter-spacing:-.02em}
  .subhero-sub{font-size:1.02rem}
  .section-title{font-size:clamp(1.5rem,5.6vw,2rem)}
  .section-sub{font-size:1rem}
  .subhero-stat-num{font-size:1.4rem}
  .prose h2{font-size:1.4rem}.prose h3{font-size:1.15rem}
  .grid-2,.grid-3,.grid-4,.related{grid-template-columns:1fr}
  .cform-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .footer-bottom{flex-direction:column;text-align:center}
  .sticky-cta-text{display:none}.sticky-cta-inner{justify-content:center}
  .subhero-stats{gap:22px}
}
@media(max-width:480px){
  .container{padding:0 18px}
  .subhero h1{font-size:clamp(1.5rem,7vw,2rem)}
  .subhero-ctas{flex-direction:column;align-items:stretch}
  .subhero-ctas .btn{justify-content:center;width:100%}
  .subhero-stats{gap:16px 24px}
  .subhero-stat-num{font-size:1.25rem}
}
