/* CE365.de — Gemeinsames Stylesheet */

:root {
  --black: #1d1d1f;
  --white: #fbfbfd;
  --g50: #f5f5f7;
  --g100: #e8e8ed;
  --g200: #d2d2d7;
  --g400: #86868b;
  --g600: #6e6e73;
  --blue: #0071e3;
  --blueH: #0077ED;
  --blueL: #E3F0FF;
  --font: 'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font);color:var(--black);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden;}

/* CONSTRUCTION BANNER */
.construction-banner{position:fixed;top:0;left:0;right:0;z-index:10001;background:#1f2937;color:#fff;text-align:center;padding:0.5rem 1rem;font-size:0.82rem;font-weight:500;letter-spacing:0.02em;height:32px;}
body:has(.construction-banner) nav{top:32px;background:rgba(251,251,253,1);}
body:has(.construction-banner) .hero{padding-top:8rem;}

/* COOKIE BANNER */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:rgba(251,251,253,0.96);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-top:1px solid var(--g200);padding:1.25rem 0;}
.cookie-inner{max-width:1100px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;}
.cookie-text{font-size:0.88rem;color:var(--g600);line-height:1.6;}
.cookie-text strong{color:var(--black);}
.cookie-text a{color:var(--blue);text-decoration:none;}
.cookie-text a:hover{text-decoration:underline;}
.cookie-actions{display:flex;gap:0.6rem;flex-shrink:0;}
.cookie-btn{padding:0.6rem 1.2rem;border-radius:20px;font-size:0.82rem;font-weight:600;cursor:pointer;border:none;font-family:var(--font);transition:all 0.2s;}
.cookie-btn-outline{background:transparent;color:var(--black);border:1px solid var(--g200);}
.cookie-btn-outline:hover{border-color:var(--g400);}
.cookie-btn-primary{background:var(--blue);color:#fff;}
.cookie-btn-primary:hover{background:var(--blueH);}

/* COOKIE MODAL */
.cookie-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;background:rgba(0,0,0,0.4);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:1.5rem;}
.cookie-modal-box{background:var(--white);border:1px solid var(--g200);border-radius:20px;padding:2.25rem;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,0.12);}
.cookie-modal-box h3{font-size:1.2rem;font-weight:700;margin-bottom:0.5rem;}
.cookie-modal-desc{font-size:0.88rem;color:var(--g600);line-height:1.6;margin-bottom:1.5rem;}
.cookie-option{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--g100);}
.cookie-option:last-of-type{border-bottom:none;}
.cookie-option-info{flex:1;}
.cookie-option-info strong{display:block;font-size:0.92rem;margin-bottom:2px;}
.cookie-option-info span{font-size:0.82rem;color:var(--g600);line-height:1.5;}
.cookie-toggle{position:relative;display:inline-block;width:48px;height:28px;flex-shrink:0;}
.cookie-toggle input{opacity:0;width:0;height:0;}
.cookie-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--g200);border-radius:28px;transition:all 0.3s;}
.cookie-toggle-slider::before{content:"";position:absolute;height:22px;width:22px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all 0.3s;box-shadow:0 1px 3px rgba(0,0,0,0.15);}
.cookie-toggle input:checked+.cookie-toggle-slider{background:var(--blue);}
.cookie-toggle input:checked+.cookie-toggle-slider::before{transform:translateX(20px);}
.cookie-toggle input:disabled+.cookie-toggle-slider{opacity:0.5;cursor:not-allowed;}
.cookie-modal-actions{margin-top:1.5rem;text-align:right;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(251,251,253,0.82);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);height:52px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(0,0,0,0.04);}
.nav-in{max-width:1200px;width:100%;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;}
.logo{display:flex;align-items:center;text-decoration:none;}
.logo img{height:40px;width:auto;}
.nav-r{display:flex;gap:2rem;align-items:center;}
.nav-r a{font-size:0.82rem;color:var(--g600);text-decoration:none;font-weight:500;transition:color 0.2s;}
.nav-r a:hover{color:var(--black);}
.nav-btn{background:var(--blue);color:#fff !important;padding:0.4rem 1.1rem;border-radius:20px;transition:background 0.2s;}
.nav-btn:hover{background:var(--blueH);}
.nav-mobile{display:none;background:none;border:none;cursor:pointer;padding:0.5rem;flex-direction:column;gap:5px;}
.nav-mobile span{display:block;width:22px;height:2px;background:var(--black);border-radius:2px;transition:all 0.3s;}
.nav-mobile.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.nav-mobile.open span:nth-child(2){opacity:0;}
.nav-mobile.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:7rem 2rem 4rem;position:relative;width:100%;}
.hero h1{font-size:clamp(2.8rem,7vw,5.5rem);font-weight:700;letter-spacing:-0.04em;line-height:1.05;max-width:900px;margin-bottom:1.5rem;animation:fu .9s cubic-bezier(.25,.46,.45,.94) both;}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,#0071e3,#5856D6 60%,#AF52DE);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero p{font-size:clamp(1.15rem,2.2vw,1.45rem);color:var(--g600);max-width:560px;line-height:1.45;font-weight:400;margin-bottom:2.5rem;animation:fu .9s .12s cubic-bezier(.25,.46,.45,.94) both;}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;animation:fu .9s .22s cubic-bezier(.25,.46,.45,.94) both;}
.btn{display:inline-flex;align-items:center;padding:0.9rem 2.2rem;border-radius:28px;font-size:1.05rem;font-weight:600;text-decoration:none;border:none;cursor:pointer;font-family:var(--font);transition:all 0.3s;}
.btn-p{background:var(--blue);color:#fff;}.btn-p:hover{background:var(--blueH);transform:scale(1.02);}
.btn-s{color:var(--blue);background:transparent;}.btn-s:hover{background:var(--blueL);}
.hero-sub{margin-top:3.5rem;font-size:0.85rem;color:var(--g400);animation:fu .9s .32s cubic-bezier(.25,.46,.45,.94) both;}
.hero-sub strong{color:var(--g600);}
@keyframes fu{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
.scroll-cue{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:var(--g400);animation:bounce 2s infinite;text-decoration:none;transition:color 0.2s;}
.scroll-cue:hover{color:var(--blue);}
@keyframes bounce{0%,20%,50%,80%,100%{transform:translateX(-50%) translateY(0);}40%{transform:translateX(-50%) translateY(-12px);}60%{transform:translateX(-50%) translateY(-6px);}}

/* FULLWIDTH IMAGE SECTION */
.img-section{width:100%;padding:0;position:relative;overflow:hidden;}
.img-section img{width:100%;height:60vh;object-fit:cover;display:block;}
.img-section .overlay{position:absolute;bottom:0;left:0;right:0;padding:4rem 0;background:linear-gradient(0deg,rgba(0,0,0,0.6) 0%,transparent 100%);}
.img-section .overlay-in{max-width:1100px;margin:0 auto;padding:0 2rem;}
.img-section .overlay h2{color:#fff;font-size:clamp(1.6rem,3.5vw,2.8rem);font-weight:700;letter-spacing:-0.02em;max-width:600px;}
.img-section .overlay p{color:rgba(255,255,255,0.8);font-size:1.1rem;margin-top:0.75rem;max-width:500px;line-height:1.45;}

/* TEXT SECTIONS */
.txt{padding:7rem 2rem;text-align:center;width:100%;}
.txt-inner{max-width:800px;margin:0 auto;padding:0 2rem;}
.label{font-size:0.78rem;font-weight:600;color:var(--blue);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:0.75rem;}
.txt h2{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:700;letter-spacing:-0.03em;line-height:1.1;margin-bottom:1.25rem;}
.txt p.sub{font-size:1.15rem;color:var(--g600);line-height:1.5;max-width:580px;margin:0 auto;}

/* AUDIENCE SPLIT */
.split{padding:0 0 7rem;width:100%;}
.split-wrap{max-width:1200px;margin:0 auto;padding:0 2rem;}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.split-card{border-radius:24px;overflow:hidden;position:relative;min-height:520px;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer;transition:transform 0.5s cubic-bezier(.25,.46,.45,.94);}
.split-card:hover{transform:scale(1.01);}
.split-card .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 0.6s cubic-bezier(.25,.46,.45,.94);}
.split-card:hover .bg{transform:scale(1.04);}
.split-card .content{position:relative;z-index:2;padding:3rem 2.5rem;background:linear-gradient(0deg,rgba(0,0,0,0.72) 0%,rgba(0,0,0,0.15) 60%,transparent 100%);}
.split-card h3{color:#fff;font-size:1.8rem;font-weight:700;letter-spacing:-0.02em;margin-bottom:0.5rem;}
.split-card p{color:rgba(255,255,255,0.85);font-size:1rem;line-height:1.5;margin-bottom:1.5rem;max-width:340px;}
.split-card .tag{display:inline-block;padding:0.35rem 0.9rem;border-radius:16px;font-size:0.78rem;font-weight:600;background:rgba(255,255,255,0.2);color:#fff;backdrop-filter:blur(8px);margin-right:0.5rem;margin-bottom:0.4rem;}
.card-cta{display:inline-flex;align-items:center;gap:0.4rem;color:#fff;font-weight:600;font-size:0.95rem;text-decoration:none;margin-top:0.75rem;transition:gap 0.3s;}
.card-cta:hover{gap:0.7rem;}

/* SERVICE STRIP */
.services{padding:7rem 0;background:var(--g50);width:100%;}
.services-in{max-width:1100px;margin:0 auto;padding:0 2rem;}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.5rem;}
.srv{background:var(--white);border-radius:20px;padding:2.5rem 2rem;border:1px solid var(--g100);transition:all 0.4s;}
.srv:hover{border-color:var(--g200);box-shadow:0 12px 40px rgba(0,0,0,0.04);transform:translateY(-3px);}
.srv h4{font-size:1.1rem;font-weight:600;margin-bottom:0.5rem;}
.srv p{font-size:0.88rem;color:var(--g600);line-height:1.55;}

/* HOW IT WORKS */
.how{padding:7rem 0;width:100%;}
.how-in{max-width:900px;margin:0 auto;padding:0 2rem;}
.steps{display:grid;grid-template-columns:1fr;gap:0;margin-top:3.5rem;}
.step{display:flex;gap:2rem;padding:2rem 0;border-bottom:1px solid var(--g100);}
.step:last-child{border-bottom:none;}
.step-num{min-width:48px;height:48px;border-radius:50%;background:var(--g50);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--blue);flex-shrink:0;}
.step h4{font-size:1.1rem;font-weight:600;margin-bottom:0.35rem;}
.step p{font-size:0.9rem;color:var(--g600);line-height:1.5;}

/* REGION */
.region{padding:7rem 0;background:var(--black);color:#fff;text-align:center;width:100%;}
.region .label{color:var(--g400);}
.region h2{color:#fff;}
.region p.sub{color:var(--g400);}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2.5rem;max-width:900px;margin:3.5rem auto 0;}
.stat-n{font-size:3rem;font-weight:700;letter-spacing:-0.03em;background:linear-gradient(135deg,#0071e3,#5856D6,#AF52DE);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.stat-l{font-size:0.82rem;color:var(--g400);margin-top:0.3rem;line-height:1.3;}

/* NEWSLETTER */
.newsletter{padding:5rem 0;background:var(--blueL);text-align:center;width:100%;}
.newsletter-in{max-width:560px;margin:0 auto;}
.newsletter h2{font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:700;letter-spacing:-0.02em;margin-bottom:0.75rem;}
.newsletter p.sub{font-size:1rem;color:var(--g600);line-height:1.5;margin-bottom:2rem;}
.newsletter-form{display:flex;gap:0.75rem;max-width:460px;margin:0 auto;}
.newsletter-form input{flex:1;padding:0.85rem 1.2rem;border-radius:14px;border:1px solid var(--g200);font-family:var(--font);font-size:0.95rem;background:var(--white);outline:none;transition:border-color 0.2s,box-shadow 0.2s;}
.newsletter-form input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,113,227,0.1);}
.newsletter-form button{padding:0.85rem 1.8rem;border-radius:14px;background:var(--blue);color:#fff;font-family:var(--font);font-size:0.95rem;font-weight:600;border:none;cursor:pointer;transition:background 0.2s;white-space:nowrap;}
.newsletter-form button:hover{background:var(--blueH);}
.newsletter-form button:disabled{opacity:0.6;cursor:not-allowed;}
.newsletter-msg{margin-top:1rem;font-size:0.88rem;padding:0.75rem 1rem;border-radius:12px;display:none;}
.newsletter-msg.success{display:block;background:rgba(52,199,89,0.1);color:#248a3d;}
.newsletter-msg.error{display:block;background:rgba(255,59,48,0.1);color:#d70015;}
.newsletter-hint{margin-top:1rem;font-size:0.75rem;color:var(--g400);}

/* FAQ */
.faq{padding:7rem 0;width:100%;}
.faq-in{max-width:800px;margin:0 auto;padding:0 2rem;}
.faq details{border-bottom:1px solid var(--g100);}
.faq details:first-of-type{border-top:1px solid var(--g100);}
.faq summary{padding:1.25rem 0;font-size:1.05rem;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;transition:color 0.2s;}
.faq summary:hover{color:var(--blue);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";font-size:1.4rem;font-weight:300;color:var(--g400);transition:transform 0.3s;}
.faq details[open] summary::after{content:"\2212";color:var(--blue);}
.faq details p{padding:0 0 1.25rem;font-size:0.95rem;color:var(--g600);line-height:1.6;max-width:680px;}

/* CTA */
.cta{padding:7rem 0;text-align:center;width:100%;}
.cta-in{max-width:600px;margin:0 auto;padding:0 2rem;}
.cta h2{font-size:clamp(2rem,4vw,2.8rem);font-weight:700;letter-spacing:-0.02em;margin-bottom:1rem;}
.cta p{font-size:1.1rem;color:var(--g600);margin-bottom:2.5rem;line-height:1.5;}
.form{text-align:left;display:flex;flex-direction:column;gap:1rem;}
.form-r{display:flex;gap:1rem;}
.fg{flex:1;display:flex;flex-direction:column;gap:0.3rem;}
.fg label{font-size:0.78rem;font-weight:600;color:var(--g600);}
.fg input,.fg select,.fg textarea{padding:0.8rem 1rem;border-radius:12px;border:1px solid var(--g200);font-family:var(--font);font-size:0.95rem;background:var(--white);transition:border-color 0.2s,box-shadow 0.2s;outline:none;-webkit-appearance:none;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,113,227,0.1);}
.fg textarea{resize:vertical;min-height:80px;}
.form .btn-p{width:100%;justify-content:center;margin-top:0.5rem;}
.form-msg{text-align:center;font-size:0.9rem;padding:0.75rem 1rem;border-radius:12px;display:none;margin-top:0.5rem;}
.form-msg.success{display:block;background:rgba(52,199,89,0.1);color:#248a3d;}
.form-msg.error{display:block;background:rgba(255,59,48,0.1);color:#d70015;}
.form-hint{text-align:center;font-size:0.75rem;color:var(--g400);margin-top:0.75rem;}

/* LEGAL PAGES */
.legal{padding:7rem 2rem 5rem;max-width:800px;margin:0 auto;}
.legal-in{max-width:700px;}
.legal h1{font-size:clamp(2rem,4vw,2.8rem);font-weight:700;letter-spacing:-0.02em;margin-bottom:0.5rem;}
.legal-sub{font-size:1rem;color:var(--g400);margin-bottom:3rem;}
.legal h2{font-size:1.2rem;font-weight:700;margin-top:2.5rem;margin-bottom:0.75rem;}
.legal h3{font-size:1rem;font-weight:600;margin-top:1.5rem;margin-bottom:0.5rem;}
.legal p{font-size:0.95rem;color:var(--g600);line-height:1.7;margin-bottom:0.75rem;}
.legal ul{margin:0.5rem 0 1rem 1.5rem;font-size:0.95rem;color:var(--g600);line-height:1.7;}
.legal li{margin-bottom:0.4rem;}
.legal a{color:var(--blue);text-decoration:none;}
.legal a:hover{text-decoration:underline;}

/* FOOTER */
footer{padding:3rem 0;border-top:1px solid var(--g100);background:var(--g50);width:100%;}
.foot-in{padding:0 2rem;}
.foot-in{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:2rem;}
.foot-brand{font-size:1.15rem;font-weight:700;}.foot-brand span{color:var(--blue);}
.foot-tag{font-size:0.8rem;color:var(--g400);max-width:260px;line-height:1.4;margin-top:0.4rem;}
.foot-col h5{font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--g400);margin-bottom:0.6rem;}
.foot-col a{display:block;font-size:0.85rem;color:var(--g600);text-decoration:none;margin-bottom:0.35rem;transition:color 0.2s;cursor:pointer;}
.foot-col a:hover{color:var(--blue);}
.foot-btm{max-width:1100px;margin:2rem auto 0;padding-top:1.5rem;border-top:1px solid var(--g100);display:flex;justify-content:space-between;font-size:0.73rem;color:var(--g400);}
.foot-btm a{color:var(--g400);text-decoration:none;}.foot-btm a:hover{color:var(--g600);}

/* RESPONSIVE */
@media(max-width:768px){
.nav-r{display:none;flex-direction:column;position:absolute;top:52px;left:0;right:0;background:rgba(251,251,253,0.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:1.5rem 2rem;gap:1rem;border-bottom:1px solid var(--g100);box-shadow:0 8px 30px rgba(0,0,0,0.06);}
.nav-r.open{display:flex;}
.nav-mobile{display:flex;}
.split-grid{grid-template-columns:1fr;}
.srv-grid{grid-template-columns:1fr;}
.stats{grid-template-columns:repeat(2,1fr);}
.form-r{flex-direction:column;}
.foot-in{flex-direction:column;}
.foot-btm{flex-direction:column;gap:0.5rem;text-align:center;}
.split-card{min-height:420px;}
.cookie-inner{flex-direction:column;text-align:center;}
.cookie-actions{flex-wrap:wrap;justify-content:center;}
.newsletter-form{flex-direction:column;}
}

/* REVEALS */
.rv{opacity:0;transform:translateY(32px);transition:opacity 0.8s cubic-bezier(.25,.46,.45,.94),transform 0.8s cubic-bezier(.25,.46,.45,.94);}
.rv.v{opacity:1;transform:translateY(0);}
