/* =========================================================
   Natalis Pflegedienst — premium responsive stylesheet
   ========================================================= */

/* ---------- Scrollbar (Firefox) ---------- */
html{scrollbar-color:#29C2FD #f3f7f8;scrollbar-width:thin;}

/* ---------- Scrollbar (WebKit/Blink) ---------- */
::-webkit-scrollbar{width:11px;height:11px;}
::-webkit-scrollbar-track{background:#f3f7f8;}
::-webkit-scrollbar-thumb{background-color:#29C2FD;border-radius:10px;border:2px solid #f3f7f8;}
::-webkit-scrollbar-thumb:hover{background-color:#20B8F2;}

:root{
  /* Brand palette */
  --cyan:#29C2FD;
  --cyan-light:#29C2FD;
  --cyan-dark:#20B8F2;
  --cyan-tint:rgba(41,194,253,.14);
  --cyan-tint2:rgba(41,194,253,.07);
  --navy:#0e333f;
  --navy-2:#143f4d;
  --navy-deep:#0a242c;
  --text:#34434a;
  --muted:#647179;
  --muted-2:#8198a0;
  --gray-bg:#f3f7f8;
  --gray-bg2:#fafcfd;
  --border:#e7eef0;
  --gold:#ffb400;
  --whatsapp:#22c35e;
  --white:#ffffff;

  /* Gradients */
  --grad-primary:linear-gradient(135deg,#29C2FD 0%,#20B8F2 100%);
  --grad-primary-soft:linear-gradient(135deg,rgba(41,194,253,.12) 0%,rgba(32,184,242,.05) 100%);
  --grad-band:linear-gradient(45deg,#20B8F2 0%,#29C2FD 100%);
  --grad-navy:linear-gradient(160deg,#0e333f 0%,#163f4d 100%);
  --grad-footer:linear-gradient(180deg,#20B8F2 0%,#29C2FD 100%);

  /* Radii */
  --radius-sm:10px;
  --radius:18px;
  --radius-lg:26px;
  --radius-pill:10px;

  /* Shadows */
  --shadow-sm:0 4px 14px rgba(14,51,63,.06);
  --shadow:0 14px 36px rgba(14,51,63,.10);
  --shadow-lg:0 26px 60px rgba(14,51,63,.16);
  --shadow-cyan:0 12px 28px rgba(41,194,253,.32);

  /* Fluid spacing helpers (used inline via clamp in rules below) */
  --container-max:1280px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Poppins",Arial,sans-serif;
  color:var(--text);
  line-height:1.7;
  background:#fff;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{padding:0;margin:0;}
button{font-family:inherit;}

.container{
  max-width:var(--container-max);
  margin:0 auto;
  padding:0 clamp(20px,4vw,40px);
}
.container-wide{
  max-width:1560px;
  margin:0 auto;
  padding:0 clamp(20px,4vw,56px);
}

h1,h2,h3,h4,h5,h6{color:var(--navy);font-weight:800;margin:0 0 18px;letter-spacing:-.01em;}
h1{font-size:clamp(2.1rem,1.6rem + 2.2vw,3.6rem);line-height:1.12;}
h2{font-size:clamp(1.7rem,1.35rem + 1.4vw,2.5rem);line-height:1.18;}
h3{font-size:clamp(1.15rem,1.05rem + .4vw,1.4rem);}
p{margin:0 0 16px;}
.eyebrow{
  color:var(--cyan-dark);font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  font-size:13px;margin-bottom:12px;display:inline-flex;align-items:center;gap:8px;
}
.eyebrow:before{content:"";width:22px;height:2px;background:var(--grad-primary);border-radius:2px;}
.section{padding:clamp(56px,8vw,108px) 0;}
.section--tight{padding:clamp(40px,5vw,64px) 0;}
.section--gray{background:var(--gray-bg2);}
.center{text-align:center;}
.lead{color:var(--muted);font-size:clamp(16px,.95rem + .3vw,18.5px);max-width:720px;}
.center .lead{margin-left:auto;margin-right:auto;}
.section-head{max-width:760px;margin:0 auto clamp(34px,5vw,52px);}
.section-head.left{margin:0 0 clamp(34px,5vw,52px);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 28px;border-radius:var(--radius-pill);font-weight:700;font-size:15px;
  border:2px solid transparent;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;
}
.btn-cyan{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow-cyan);}
.btn-cyan:hover{transform:translateY(-3px);box-shadow:0 18px 34px rgba(41,194,253,.4);}
.btn-outline{background:#fff;color:var(--navy);border-color:var(--border);}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan-dark);transform:translateY(-3px);box-shadow:var(--shadow);}
.btn-whatsapp{background:#fff;color:#1b8a45;border-color:#bfe9cf;}
.btn-whatsapp:hover{background:#eafcf0;transform:translateY(-2px);}
.btn-block{width:100%;justify-content:center;}
.btn-sm{padding:10px 18px;font-size:13px;}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;width:100%;z-index:1000;background:rgba(255,255,255,.97);box-shadow:0 4px 20px rgba(14,51,63,.10);}
.header-inner{max-width:1560px;margin:0 auto;padding:16px clamp(20px,4vw,36px);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.logo img{height:40px;width:auto;}
.main-nav{flex:1;display:flex;justify-content:center;min-width:0;}
.main-nav>ul{display:flex;align-items:center;justify-content:center;gap:1px;list-style:none;position:relative;flex-wrap:nowrap;height:38px;}
.main-nav>ul>li{position:relative;display:flex;align-items:center;height:38px;}
.main-nav>ul>li>a{position:relative;display:flex;align-items:center;height:38px;box-sizing:border-box;padding:0 16px;border-radius:var(--radius-pill);font-weight:600;font-size:14px;color:var(--navy);transition:color .2s,background .2s;white-space:nowrap;line-height:1;}
.main-nav>ul>li>a:hover,.main-nav>ul>li>a.active{background:var(--cyan-tint);color:var(--cyan-dark);}
.has-dropdown>a:after{content:"▾";font-size:10px;margin-left:5px;line-height:1;}
.dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);background:#fff;min-width:240px;border-radius:16px;box-shadow:var(--shadow-lg);padding:10px;opacity:0;visibility:hidden;transition:.22s;list-style:none;z-index:50;border:1px solid var(--border);text-align:left;display:block;}
.has-dropdown:hover .dropdown,.has-dropdown.open .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.dropdown li{display:block;}
.dropdown li a{display:block;padding:11px 16px;border-radius:10px;font-size:14.5px;color:var(--navy);font-weight:600;white-space:nowrap;}
.dropdown li a:hover,.dropdown li a.active{background:var(--gray-bg);color:var(--cyan-dark);}
.header-actions{display:flex;align-items:center;gap:10px;}
.header-actions .btn{padding:11px 20px;font-size:14px;}
.header-actions{flex-wrap:nowrap;}
.nav-toggle{display:none;background:none;border:none;font-size:26px;color:var(--navy);cursor:pointer;line-height:1;}

/* ---------- Header pill buttons (WhatsApp / Call) ---------- */
.btn-pill{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--navy);font-weight:700;font-size:13.5px;padding:10px 16px;border-radius:10px;box-shadow:0 4px 14px rgba(14,51,63,.12);transition:transform .2s,box-shadow .2s;white-space:nowrap;}
.btn-pill:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(14,51,63,.18);}
.btn-pill i{color:var(--cyan);font-size:16px;}
.btn-pill-wa i{color:#25D366;}
.btn-pill-call i{color:var(--cyan);}

@media (max-width:1280px){
  .main-nav{position:fixed;inset:0 0 0 auto;width:300px;max-width:88vw;background:#fff;flex-direction:column;justify-content:flex-start;padding:96px 26px 26px;transform:translateX(100%);transition:.32s cubic-bezier(.4,0,.2,1);box-shadow:-16px 0 40px rgba(0,0,0,.18);z-index:999;overflow-y:auto;}
  .main-nav.open{transform:translateX(0);}
  .main-nav>ul{flex-direction:column;align-items:stretch;width:100%;gap:2px;}
  .main-nav>ul>li>a{padding:13px 16px;border-radius:12px;color:var(--navy)!important;}
  .main-nav>ul>li>a:hover,.main-nav>ul>li>a.active{color:var(--cyan-dark)!important;background:var(--gray-bg);}
  .header-actions .btn-pill{padding:10px 14px;}
  .nav-toggle{color:var(--navy)!important;text-shadow:none!important;}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;display:none;padding-left:14px;border:none;text-align:left;}
  .has-dropdown.open .dropdown{display:block;}
  .nav-toggle{display:block;}
  .header-actions .btn-pill span.txt{display:none;}
  .header-actions .btn-pill{gap:0;}
}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(10,30,38,.5);z-index:998;backdrop-filter:blur(2px);}
.nav-overlay.show{display:block;}

/* ---------- Decorative blobs (shared) ---------- */
.blob-field{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none;}
.blob{position:absolute;border-radius:50%;filter:blur(2px);}

/* ---------- Hero (Home) ---------- */
.hero-photo{position:relative;background-size:cover;background-position:center;overflow:hidden;}
.hero-photo:before{content:"";position:absolute;inset:0;background:rgba(10,36,44,.6);z-index:1;}
.hero-photo-inner{position:relative;z-index:2;padding:clamp(130px,17vw,195px) 0 clamp(64px,8vw,96px);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,60px);align-items:center;}
.hero-photo h1{margin-bottom:20px;color:#fff;}
.hero-photo .lead{font-size:clamp(16px,1rem + .35vw,19px);margin-bottom:30px;color:#fff;}
.hero-cta{display:flex;gap:14px;margin-bottom:36px;flex-wrap:wrap;}
.btn-pill-hero-call,.btn-pill-hero-wa{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:var(--radius-pill);font-weight:700;font-size:15px;color:#fff;transition:transform .25s,box-shadow .25s;}
.btn-pill-hero-call{background:var(--grad-primary);box-shadow:var(--shadow-cyan);}
.btn-pill-hero-wa{background:#25D366;box-shadow:0 12px 28px rgba(37,211,102,.35);}
.btn-pill-hero-call:hover,.btn-pill-hero-wa:hover{transform:translateY(-3px);}
.btn-pill-hero-call i,.btn-pill-hero-wa i{color:#fff;}
.trust-card{display:inline-flex;flex-direction:column;gap:18px;background:rgba(255,255,255,.95);border-radius:var(--radius-pill);padding:20px 26px;box-shadow:var(--shadow-lg);}
.trust-row{display:grid;grid-template-columns:repeat(3,1fr);align-items:center;justify-items:center;gap:28px;}
.trust-row img{height:74px;width:auto;max-width:100%;filter:drop-shadow(0 4px 10px rgba(14,51,63,.08));}
.trust-row.seals-row{grid-template-columns:repeat(2,1fr);}
.trust-row.seals-row img{height:50px;}
.hero-wave{position:absolute;left:0;bottom:-1px;width:100%;height:50px;z-index:3;display:block;}
.book-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:clamp(26px,3vw,34px);position:relative;}
.book-card h2{font-size:clamp(1.25rem,1.05rem + .5vw,1.5rem);margin-bottom:18px;color:var(--navy);}
.book-card form{display:grid;gap:13px;}
.book-card .f-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.book-card .full{grid-column:1/-1;}
.book-card label{display:block;font-weight:700;font-size:13.5px;color:var(--navy);margin-bottom:6px;}
.book-card .req{color:#e54848;}
.book-card input,.book-card select,.book-card textarea{width:100%;height:40px;border:none;border-radius:5px;padding:0 14px;font-family:inherit;font-size:14px;background:rgba(41,194,253,.10);transition:.2s;color:var(--navy);}
.book-card textarea{height:auto;padding:10px 14px;min-height:70px;resize:vertical;}
.book-card input:focus,.book-card select:focus,.book-card textarea:focus{outline:none;background:rgba(41,194,253,.18);}
.tel-group{display:flex;flex-wrap:nowrap;align-items:stretch;height:40px;border-radius:5px;background:rgba(41,194,253,.10);transition:.2s;overflow:hidden;}
.tel-group:focus-within{background:rgba(41,194,253,.18);}
.tel-prefix{display:flex;align-items:center;flex:0 0 auto;padding:0 8px;font-size:13.5px;font-weight:700;color:var(--navy);white-space:nowrap;border-right:1px solid rgba(14,51,63,.14);}
.tel-group input{flex:1 1 0;min-width:0;width:auto;height:100%;border:none;background:transparent;padding:0 10px;font-family:inherit;font-size:14px;color:var(--navy);}
.tel-group input:focus{outline:none;}
.tel-group.field-error{box-shadow:0 0 0 2px rgba(229,72,72,.65) inset !important;}
.recaptcha-row{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin:4px 0 2px;}
.recaptcha-error{display:none;color:#e54848;font-size:12.5px;font-weight:600;margin:0;}
.recaptcha-error.show{display:block;}
.hp-field{position:absolute !important;left:-9999px !important;top:-9999px !important;width:1px !important;height:1px !important;opacity:0;overflow:hidden;pointer-events:none;}
.btn-send{display:block;width:100%;height:46px;border:none;border-radius:5px;background:var(--cyan);color:#fff;font-weight:700;font-size:15px;cursor:pointer;transition:background .2s,transform .2s;}
.btn-send:hover{background:var(--cyan-dark);transform:translateY(-2px);}
.btn-send:disabled,.btn-cyan:disabled{opacity:.65;cursor:not-allowed;transform:none;}
.form-msg{display:none;margin:0;padding:12px 15px;border-radius:10px;font-size:13px;font-weight:600;line-height:1.45;}
.form-msg.show{display:block;}
.form-msg.success{background:rgba(34,197,94,.12);color:#178a4c;}
.form-msg.error{background:rgba(229,72,72,.10);color:#c53030;}
.field-error{box-shadow:0 0 0 2px rgba(229,72,72,.65) inset !important;}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;}}

/* ---------- Value cards (3) ---------- */
.value-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,28px);margin-top:10px;}
.value-card{background:#fff;border-radius:var(--radius);padding:clamp(28px,3vw,36px) clamp(22px,2.5vw,28px);box-shadow:var(--shadow);text-align:center;border:1px solid var(--border);transition:transform .3s,box-shadow .3s;}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.ico{display:block;font-size:60px;color:var(--cyan);margin:0 auto 18px;line-height:1;}
.service-card .ico,.team-card .ico{margin:0 0 18px;}
@media (max-width:860px){.value-cards{grid-template-columns:1fr;}}

/* ---------- About / split section ---------- */
.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,5vw,60px);align-items:center;}
.split.reverse{grid-template-columns:1.15fr .85fr;}
.split.reverse .img-col{order:2;}
.img-col{position:relative;}
.img-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);}
.img-frame img{width:100%;object-fit:cover;display:block;aspect-ratio:4/3.2;}
.img-frame:before{content:"";position:absolute;left:-18px;top:-18px;width:90px;height:90px;border-radius:50%;background:var(--grad-primary-soft);z-index:-1;}
.floating-badge{position:absolute;bottom:-18px;right:-18px;background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:14px 20px;display:flex;align-items:center;gap:10px;border:1px solid var(--border);}
.floating-badge .num{font-size:20px;font-weight:800;color:var(--navy);}
.floating-badge .lbl{font-size:11.5px;color:var(--muted);font-weight:600;line-height:1.2;}
@media (max-width:900px){.split,.split.reverse{grid-template-columns:1fr;}.split.reverse .img-col{order:0;}.floating-badge{right:10px;bottom:-14px;}}
.two-img{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media (max-width:700px){.two-img{grid-template-columns:1fr;}}

/* ---------- Services grid (6) ---------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,26px);}
.service-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:clamp(26px,2.5vw,32px) clamp(22px,2.5vw,28px);box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden;}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent;}
.service-card .ref-tag{display:inline-block;margin-top:4px;font-size:11.5px;font-weight:700;color:var(--cyan-dark);background:var(--cyan-tint2);padding:5px 12px;border-radius:var(--radius-pill);}
@media (max-width:900px){.services-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.services-grid{grid-template-columns:1fr;}}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,26px);}
.testi-card{background:#fff;border-radius:var(--radius);padding:clamp(26px,2.5vw,32px);box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative;transition:transform .3s,box-shadow .3s;}
.testi-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}
.quote-mark{font-size:38px;color:var(--cyan-tint);font-weight:800;line-height:1;margin-bottom:6px;font-family:Georgia,serif;}
.stars{color:var(--gold);letter-spacing:3px;margin-bottom:14px;font-size:15px;}
.testi-quote{font-style:italic;color:var(--navy);margin-bottom:20px;}
.testi-person{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--border);}
.testi-person img{width:44px;height:44px;border-radius:50%;border:2px solid var(--cyan-tint);}
.testi-person strong{display:block;color:var(--navy);font-size:14.5px;}
.testi-person span{font-size:12.5px;color:var(--muted);}
@media (max-width:900px){.testi-grid{grid-template-columns:1fr;}}

/* ---------- Blog / Neuigkeiten ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,2.5vw,28px);}
.blog-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:transform .3s,box-shadow .3s;}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.blog-img-wrap{overflow:hidden;height:200px;}
.blog-card img{width:100%;height:200px;object-fit:cover;transition:transform .5s;}
.blog-card:hover img{transform:scale(1.08);}
.blog-card .body{padding:24px;}
.blog-meta{font-size:12px;color:var(--cyan-dark);font-weight:700;margin-bottom:10px;letter-spacing:.03em;text-transform:uppercase;}
.blog-card h3{font-size:18px;margin-bottom:10px;line-height:1.35;}
.blog-card h3 a{color:var(--navy);}
.blog-card h3 a:hover{color:var(--cyan-dark);}
.blog-card p{font-size:14.5px;color:var(--muted);margin:0 0 14px;}
.blog-more{font-size:13.5px;font-weight:700;color:var(--cyan-dark);display:inline-flex;align-items:center;gap:6px;}
.blog-more:after{content:"→";transition:transform .2s;}
.blog-card:hover .blog-more:after{transform:translateX(4px);}
@media (max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:680px){.blog-grid{grid-template-columns:1fr;}}

/* ---------- Partners strip (logos enlarged +150%, capped to ~4 per row,
   keeps scrolling/rotating through the set via partnerScroll) ---------- */
.partners-strip{overflow:hidden;position:relative;max-width:960px;margin:0 auto;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.partners-track{display:flex;align-items:center;gap:30px;width:max-content;animation:partnerScroll 24s linear infinite;}
.partners-strip:hover .partners-track{animation-play-state:paused;}
@keyframes partnerScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.partner-logo{flex:none;height:180px;display:flex;align-items:center;justify-content:center;transition:.3s;}
.partner-logo:hover{transform:translateY(-4px);}
.partner-logo img{filter:grayscale(60%);opacity:.85;transition:.3s;height:100%;width:auto;max-width:350px;object-fit:contain;}
.partner-logo:hover img{filter:grayscale(0%);opacity:1;}

/* ---------- CTA band (Willkommen) — flows into footer gradient ---------- */
.cta-band{position:relative;background:transparent;padding:clamp(56px,7vw,80px) 0 clamp(40px,5vw,56px);overflow:hidden;z-index:2;}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,1.4rem + 1.3vw,2.4rem);}
.cta-band p{color:rgba(255,255,255,.88);max-width:760px;}
.cta-contact{display:flex;justify-content:center;gap:0;flex-wrap:wrap;margin-top:6px;padding-top:32px;position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.22);}
.cta-contact .item{display:flex;align-items:center;gap:14px;text-align:left;padding:10px 30px;border-right:1px solid rgba(255,255,255,.22);background:transparent;border-radius:0;}
.cta-contact .item:last-child{border-right:none;}
.cta-contact .cc-icon{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;margin:0;flex:none;box-shadow:0 4px 14px rgba(0,0,0,.12);}
.cta-contact .item:nth-child(1) .cc-icon{background:#ff6b5b;}
.cta-contact .item:nth-child(2) .cc-icon{background:var(--whatsapp);}
.cta-contact .item:nth-child(3) .cc-icon{background:var(--gold);}
.cta-contact h4{color:rgba(255,255,255,.75);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-weight:700;}
.cta-contact .cc-text p{color:#fff;font-weight:700;font-size:15.5px;margin:0;}
.cta-contact .cc-text p a{color:#fff;}
@media (max-width:800px){.cta-contact{flex-direction:column;align-items:stretch;}.cta-contact .item{border-right:none;border-bottom:1px solid rgba(255,255,255,.18);justify-content:center;text-align:center;flex-direction:column;gap:10px;}.cta-contact .item:last-child{border-bottom:none;}}

/* ---------- Footer — unified blue → light-blue gradient ---------- */
.site-footer{background:var(--grad-footer);color:#eafcff;padding:0;position:relative;overflow:hidden;}
.site-footer:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,40,50,0) 0%,rgba(7,40,50,.16) 45%,rgba(7,40,50,.42) 100%);pointer-events:none;z-index:1;}
.site-footer:after{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16) 0%,transparent 70%);top:-220px;right:-140px;pointer-events:none;z-index:1;}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:40px;padding:36px 0 44px;border-bottom:1px solid rgba(255,255,255,.12);position:relative;z-index:2;}
.footer-grid img{height:40px;margin-bottom:18px;}
.footer-grid p{color:rgba(255,255,255,.62);font-size:14.5px;line-height:1.75;}
.footer-grid h4{color:#fff;font-size:15px;margin-bottom:22px;letter-spacing:.05em;text-transform:uppercase;position:relative;padding-bottom:13px;}
.footer-grid h4:after{content:"";position:absolute;left:0;bottom:0;width:26px;height:2px;background:var(--cyan);border-radius:2px;}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:13px;}
.footer-grid ul.links a{color:rgba(255,255,255,.72);font-size:14.5px;transition:.2s;}
.footer-grid ul.links a:before{content:"›";color:var(--cyan);font-weight:800;margin-right:7px;}
.footer-grid ul.links a:hover{color:#fff;padding-left:4px;}
.footer-grid ul.contact-list li{display:flex;align-items:flex-start;gap:10px;color:rgba(255,255,255,.82);font-size:14.5px;}
.footer-grid ul.contact-list a{color:rgba(255,255,255,.82);transition:.2s;}
.footer-grid ul.contact-list a:hover{color:#fff;}
.footer-grid ul.contact-list i{margin-top:3px;color:var(--cyan);}
.social-row{display:flex;gap:10px;margin-top:20px;}
.social-row a{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff;transition:.25s;box-shadow:0 6px 16px rgba(0,0,0,.18);}
.social-row a:hover{transform:translateY(-3px) scale(1.06);}
.soc-fb{background:#3B5998;}
.soc-ig{background:#FF6E00;}
.soc-wa{background:#25D366;}
.soc-vb{background:#665CAC;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-size:13px;color:rgba(255,255,255,.55);flex-wrap:wrap;gap:10px;position:relative;z-index:2;}
.footer-bottom a{color:rgba(255,255,255,.55);}
.footer-bottom a:hover{color:var(--cyan);}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}

/* ---------- Inner-page hero / breadcrumb banner ---------- */
.page-hero{position:relative;background:var(--grad-band);padding:clamp(110px,14vw,150px) 0 clamp(40px,5vw,56px);text-align:left;overflow:hidden;}
.page-hero h1{color:#fff;font-size:clamp(2rem,1.6rem + 1.8vw,3.1rem);margin-bottom:14px;position:relative;z-index:2;}
.breadcrumb{display:inline-flex;align-items:center;gap:8px;list-style:none;color:#fff;font-size:14.5px;position:relative;z-index:2;}
.breadcrumb li:not(:last-child):after{content:"›";margin-left:8px;opacity:.8;}
.breadcrumb a{color:#fff;opacity:.85;}
.breadcrumb a:hover{opacity:1;text-decoration:underline;}
.breadcrumb li:last-child{font-weight:700;color:#fff;opacity:1;}

/* ---------- Generic content blocks ---------- */
.content-block{max-width:860px;}
.content-block.center{margin:0 auto;}
.list-check{list-style:none;display:flex;flex-direction:column;gap:13px;margin:20px 0;}
.list-check li{padding-left:36px;position:relative;}
.list-check li:before{content:"✓";position:absolute;left:0;top:-1px;width:24px;height:24px;border-radius:50%;background:var(--grad-primary-soft);color:var(--cyan-dark);font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;}
.feature-row{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:26px 0;}
@media (max-width:700px){.feature-row{grid-template-columns:1fr;}}
.feature-row .f{background:var(--gray-bg2);border-left:3px solid var(--cyan);border-radius:0 14px 14px 0;padding:20px 22px;}
.feature-row .f strong{color:var(--navy);display:block;margin-bottom:4px;}
.legal-section{padding:28px 0;border-bottom:1px solid var(--border);}
.legal-section:last-child{border-bottom:none;}
.legal-section h3{font-size:20px;}
.philosophy-list{display:flex;flex-direction:column;gap:6px;margin:22px 0;}
.philosophy-list .p-item{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--border);}
.philosophy-list .p-item:last-child{border-bottom:none;}
.philosophy-list .p-num{flex:none;width:42px;height:42px;border-radius:50%;background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;box-shadow:var(--shadow-cyan);}
.philosophy-list .p-item strong{display:block;color:var(--navy);font-size:17px;margin-bottom:4px;}
.philosophy-list .p-item p{margin:0;color:var(--muted);}
table.quality-table{width:100%;border-collapse:collapse;margin:24px 0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);}
table.quality-table th,table.quality-table td{padding:14px 18px;text-align:left;font-size:15px;border-bottom:1px solid var(--border);}
table.quality-table th{background:var(--navy);color:#fff;font-weight:700;}
table.quality-table tr:last-child td{border-bottom:none;}
table.quality-table tr:nth-child(even) td{background:var(--gray-bg2);}

/* ---------- Kontakt ---------- */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,44px);}
.contact-info-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;border:1px solid var(--border);}
.contact-info-card iframe{width:100%;height:280px;border:0;display:block;filter:grayscale(8%);}
.contact-info-card .pad{padding:28px;}
.contact-info-card ul{list-style:none;display:flex;flex-direction:column;gap:14px;margin-top:16px;}
.info-item{display:flex;align-items:flex-start;gap:12px;font-size:14.5px;}
.info-item .ic{flex:none;width:38px;height:38px;border-radius:50%;background:var(--grad-primary-soft);display:flex;align-items:center;justify-content:center;font-size:16px;}
.contact-form-card{background:var(--gray-bg2);border-radius:var(--radius-lg);padding:clamp(26px,3vw,36px);border:1px solid var(--border);}
.contact-form-card form{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.contact-form-card .full{grid-column:1/-1;}
.contact-form-card input,.contact-form-card textarea{width:100%;border:1.5px solid var(--border);border-radius:12px;padding:13px 16px;font-family:inherit;font-size:14px;background:#fff;color:var(--navy);transition:.2s;}
.contact-form-card input:focus,.contact-form-card textarea:focus{outline:none;border-color:var(--cyan);}
.contact-form-card textarea{min-height:110px;resize:vertical;}
@media (max-width:860px){.contact-wrap{grid-template-columns:1fr;}}

/* ---------- Karriere ---------- */
.team-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:26px;text-align:center;max-width:300px;margin:34px auto 0;border:1px solid var(--border);}
.team-card img{border-radius:16px;margin-bottom:18px;width:100%;height:240px;object-fit:cover;}
.team-card h3{margin-bottom:4px;}
.team-card span{color:var(--cyan-dark);font-weight:700;font-size:14px;}
blockquote{border-left:3px solid var(--cyan);margin:20px 0;padding:8px 0 8px 20px;color:var(--muted);font-style:italic;}

/* ---------- Blog single ---------- */
.blog-hero-wrap{position:relative;}
.blog-hero-img{width:100%;max-height:440px;object-fit:cover;border-radius:0 0 32px 32px;}
.article{max-width:760px;margin:0;text-align:left;}
.article h2{font-size:clamp(1.4rem,1.2rem + .6vw,1.7rem);margin-top:36px;}
.article h3{margin-top:28px;}

/* ---------- Cookie overlay (background dim) ---------- */
.cookie-overlay{position:fixed;inset:0;background:rgba(8,28,34,.5);z-index:1490;opacity:0;visibility:hidden;transition:opacity .4s ease;}
.cookie-overlay.show{opacity:1;visibility:visible;}
.cookie-overlay.hide{display:none;}

/* ---------- Cookie banner ---------- */
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;margin:0 auto;max-width:1100px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1500;border:1px solid var(--border);overflow:hidden;transform:translateY(140%);opacity:0;transition:transform .5s cubic-bezier(.22,1,.36,1),opacity .4s ease;}
.cookie-banner.show{transform:translateY(0);opacity:1;}
.cookie-banner.hide{display:none;}

.cookie-top{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px;padding:18px 26px;border-bottom:1px solid var(--border);}
.cookie-brand img{height:30px;display:block;}
.cookie-top h4{margin:0;text-align:center;font-size:16px;font-weight:700;color:var(--navy);}
.cookie-close{justify-self:end;width:34px;height:34px;border:none;border-radius:50%;background:var(--gray-bg);color:var(--muted);font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s;}
.cookie-close:hover{background:var(--cyan-tint);color:var(--cyan-dark);}

.cookie-body{display:flex;align-items:center;gap:28px;padding:24px 26px;flex-wrap:wrap;}
.cookie-text{flex:1 1 260px;min-width:220px;}
.cookie-text h5{margin:0 0 8px;font-size:15px;font-weight:700;color:var(--navy);}
.cookie-text p{margin:0 0 6px;font-size:13.5px;line-height:1.55;color:var(--muted);}
.cookie-text p:last-child{margin-bottom:0;}
.cookie-text a{color:var(--cyan-dark);}

.cookie-actions{display:flex;gap:10px;flex:2 1 440px;flex-wrap:wrap;}
.cookie-btn{flex:1 1 130px;min-width:0;padding:12px 14px;border-radius:var(--radius-pill);font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;border:1.5px solid var(--border);background:var(--gray-bg);color:var(--navy);transition:.2s;white-space:normal;text-align:center;line-height:1.25;}
.cookie-btn:hover{border-color:var(--cyan);color:var(--cyan-dark);}
.cookie-btn-primary{background:var(--grad-band);border-color:transparent;color:#fff;}
.cookie-btn-primary:hover{background:var(--cyan-dark);color:#fff;}

.cookie-settings{display:none;padding:0 26px 24px;border-top:1px solid var(--border);}
.cookie-settings.show{display:block;padding-top:20px;}
.cookie-cat{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0;border-bottom:1px solid var(--border);}
.cookie-cat:last-of-type{border-bottom:none;}
.cookie-cat-text strong{display:block;font-size:13.5px;color:var(--navy);margin-bottom:2px;}
.cookie-cat-text span{font-size:12.5px;color:var(--muted);}
.cookie-switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0;}
.cookie-switch input{opacity:0;width:0;height:0;}
.cookie-switch .slider{position:absolute;inset:0;background:var(--border);border-radius:24px;transition:.2s;cursor:pointer;}
.cookie-switch .slider::before{content:'';position:absolute;left:3px;top:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 2px 5px rgba(0,0,0,.15);}
.cookie-switch input:checked + .slider{background:var(--cyan);}
.cookie-switch input:checked + .slider::before{transform:translateX(18px);}
.cookie-switch.is-disabled{opacity:.6;cursor:not-allowed;}
.cookie-settings .cookie-save{margin-top:16px;width:100%;}

.cookie-links{padding:14px 26px;font-size:12px;color:var(--muted);border-top:1px solid var(--border);}
.cookie-links a{color:var(--cyan-dark);}

/* ---------- Floating buttons ---------- */
.floating-buttons{position:fixed;left:0;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:0;z-index:900;}
.floating-buttons a{width:62px;height:62px;border-radius:0 25px 25px 0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:30px;box-shadow:0 4px 14px rgba(0,0,0,.18);transition:transform .25s,width .25s;}
.floating-buttons a:hover{width:67px;}
.fb-whatsapp{background:rgb(38,211,103);}
.fb-call{background:rgb(34,136,191);}

/* ---------- Reveal-on-scroll ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1);}
[data-reveal].in{opacity:1;transform:translateY(0);}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none;}.partners-track{animation:none;}}

/* =========================================================
   Responsive breakpoints — tablet down to smallest phones
   ========================================================= */
@media (max-width:1180px){
  :root{--container-max:1080px;}
}
@media (max-width:760px){
  h1{font-size:clamp(1.9rem,1.6rem + 2vw,2.6rem);}
  .section{padding:clamp(46px,9vw,64px) 0;}
  .cta-contact .item{text-align:center;}
}
@media (max-width:700px){
  .partner-logo{height:110px;}
}
@media (max-width:560px){
  .hero-cta{flex-direction:column;}
  .hero-cta .btn-pill-hero-call,.hero-cta .btn-pill-hero-wa{width:100%;justify-content:center;}
  .book-card .f-row{grid-template-columns:1fr;}
  .contact-form-card form{grid-template-columns:1fr;}
  .recaptcha-row .g-recaptcha{transform:scale(.9);transform-origin:0 0;width:274px;height:70px;}
  .cookie-banner{left:10px;right:10px;bottom:10px;}
  .cookie-top{padding:14px 16px;gap:10px;}
  .cookie-top h4{font-size:13.5px;}
  .cookie-brand img{height:24px;}
  .cookie-close{width:30px;height:30px;}
  .cookie-body{padding:18px 16px;flex-direction:column;align-items:stretch;gap:16px;}
  .cookie-text{flex:0 0 auto;min-width:0;}
  .cookie-text p{font-size:13px;}
  .cookie-actions{flex:0 0 auto;flex-direction:column;gap:10px;}
  .cookie-btn{flex:0 0 auto;width:100%;min-width:0;padding:13px 14px;font-size:13px;}
  .cookie-settings{padding:0 16px 18px;}
  .cookie-settings.show{padding-top:16px;}
  .cookie-cat{flex-wrap:wrap;gap:10px;}
  .cookie-links{padding:12px 16px;font-size:11.5px;text-align:center;}
  .hero-photo-inner{padding-top:168px;}
  .floating-buttons{display:none;}
  .header-inner{padding:14px 18px;}
  .logo img{height:32px;}
  .trust-card{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:space-between;width:100%;padding:12px 12px;gap:6px;}
  .trust-row{display:contents;}
  .trust-row img{height:auto;width:auto;max-height:26px;max-width:17%;object-fit:contain;}
  .trust-row.seals-row img:first-child{max-height:26px;max-width:13%;}
  .trust-row.seals-row img:last-child{max-height:20px;max-width:26%;}
  .partner-logo{height:74px;}
  .partner-logo img{max-width:160px;}
  .partners-track{gap:18px;}
  table.quality-table th,table.quality-table td{padding:9px 11px;font-size:13px;}
  .contact-info-card iframe{height:220px;}
  .blog-hero-img{max-height:260px;border-radius:0 0 20px 20px;}
}
@media (max-width:400px){
  .header-actions .btn-pill{padding:9px 14px;font-size:13px;}
}
@media (max-width:380px){
  .cta-contact .item{padding:10px 16px;}
  .footer-grid{gap:30px;}
  .partner-logo{height:60px;}
  .recaptcha-row .g-recaptcha{transform:scale(.78);transform-origin:0 0;width:237px;height:61px;}
  .cookie-banner{left:6px;right:6px;bottom:6px;}
  .cookie-top{padding:12px 14px;gap:8px;}
  .cookie-top h4{font-size:12.5px;}
  .cookie-body{padding:16px 14px;gap:14px;}
  .cookie-text p{font-size:12.5px;}
  .cookie-btn{font-size:12px;padding:12px 12px;}
}

/* ---------- 2K / QHD ---------- */
@media (min-width:1600px){
  :root{--container-max:1400px;}
  body{font-size:17px;}
  .hero-photo-inner{padding-top:clamp(105px,11vw,180px);}
  .partner-logo{height:200px;}
  .trust-row img{height:80px;}
  .trust-row.seals-row img{height:54px;}
  .blog-hero-img{max-height:520px;}
  .contact-info-card iframe{height:320px;}
  .cookie-banner{max-width:1300px;}
}

/* ---------- 4K and ultra-wide ---------- */
@media (min-width:2200px){
  :root{--container-max:1640px;}
  body{font-size:18.5px;}
  .header-inner{max-width:1800px;}
  .section{padding:clamp(90px,6vw,150px) 0;}
  .ico{font-size:78px;}
  .floating-buttons a{width:70px;height:70px;font-size:33px;}
  .cookie-banner{max-width:1500px;}
  .cookie-top{padding:22px 32px;}
  .cookie-body{padding:28px 32px;}
  .cookie-links{padding:16px 32px;}
  .partner-logo{height:220px;}
  .trust-row img{height:88px;}
  .trust-row.seals-row img{height:58px;}
  .blog-hero-img{max-height:600px;}
  .contact-info-card iframe{height:360px;}
}

/* ---------- True 4K / very large ultra-wide displays ---------- */
@media (min-width:3200px){
  :root{--container-max:1900px;}
  body{font-size:20px;}
  .header-inner{max-width:2200px;}
  .container-wide{max-width:1860px;}
  .ico{font-size:88px;}
  .partner-logo{height:250px;}
  .floating-buttons a{width:76px;height:76px;font-size:36px;}
  .blog-hero-img{max-height:680px;}
  .contact-info-card iframe{height:400px;}
  .cookie-banner{max-width:1700px;}
}

/* =========================================================
   Icon badges — soft circular backdrop for Lottie icons
   ========================================================= */
.ico-badge{width:72px;height:72px;border-radius:50%;background:var(--grad-primary-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:transform .35s cubic-bezier(.4,0,.2,1),background .3s;}
.value-card:hover .ico-badge{transform:scale(1.08) rotate(-4deg);background:var(--cyan-tint);}
.service-card .ico-badge{margin:0 0 20px;width:64px;height:64px;}
.service-card:hover .ico-badge{transform:scale(1.08) rotate(-4deg);background:var(--cyan-tint);}
.qb-icon.ico-badge{width:100px;height:100px;flex:none;margin:0;}

/* ---------- Lottie icon sizing (icons enlarged +50%) ---------- */
.lottie-ico{width:96px;height:96px;margin:0 auto 18px;}
.ico-badge .lottie-ico{width:63%;height:63%;margin:0;}
.qm-icon.lottie-ico{width:48px;height:48px;margin:0 0 10px;}
.cc-icon .lottie-ico{width:42px;height:42px;margin:0;}

/* ---------- Lottie icons: a hand-drawn inline SVG glyph (no external font,
   no CDN — fully self-contained) is always in the markup and visible by
   default, so icons are never blank regardless of network conditions. JS
   swaps it for the Lottie animation only once that has confirmed success. ---------- */
.lottie-ico{display:flex;align-items:center;justify-content:center;}
.lottie-ico svg.ico-fallback{width:56%;height:56%;color:var(--cyan-dark);}
.qm-icon.lottie-ico svg.ico-fallback{width:68%;height:68%;color:var(--cyan);}
.cc-icon .lottie-ico svg.ico-fallback{width:64%;height:64%;color:#fff;}
.lottie-ico svg:not(.ico-fallback){display:none;}
.lottie-ico.lottie-active svg.ico-fallback{display:none;}
.lottie-ico.lottie-active svg:not(.ico-fallback){display:block;}

/* ---------- Inline SVG icons replacing Font Awesome glyphs site-wide on
   this page — same self-contained reasoning as above. ---------- */
svg.ico-inline{width:1em;height:1em;flex:none;display:inline-block;vertical-align:-0.14em;}
.btn-pill i,.btn-pill svg.ico-inline{color:var(--cyan);font-size:16px;}
.btn-pill-wa i,.btn-pill-wa svg.ico-inline{color:#25D366;}
.btn-pill-call i,.btn-pill-call svg.ico-inline{color:var(--cyan);}
.btn-pill-hero-call i,.btn-pill-hero-wa i,.btn-pill-hero-call svg.ico-inline,.btn-pill-hero-wa svg.ico-inline{color:#fff;}
.benefit-chips i,.benefit-chips svg.ico-inline{color:var(--cyan-dark);}
.footer-grid ul.contact-list i,.footer-grid ul.contact-list svg.ico-inline{margin-top:3px;color:var(--cyan);}

/* ---------- Mini stats (About split) ---------- */
.mini-stats{display:flex;gap:28px;margin:8px 0 26px;flex-wrap:wrap;}
.mini-stat{display:flex;flex-direction:column;}
.mini-stat strong{font-size:24px;font-weight:800;color:var(--cyan-dark);line-height:1.1;}
.mini-stat span{font-size:12.5px;color:var(--muted);font-weight:600;}

/* ---------- Benefit chips (Leistungen intro) ---------- */
.benefit-chips{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin:-10px 0 36px;}
.benefit-chips span{display:inline-flex;align-items:center;gap:8px;background:var(--gray-bg2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:9px 18px;font-size:13.5px;font-weight:600;color:var(--navy);}
.benefit-chips i{color:var(--cyan-dark);}

/* ---------- Quality banner (MDK, light card) ---------- */
.quality-banner{display:flex;align-items:center;gap:30px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:clamp(28px,3vw,42px);box-shadow:var(--shadow);position:relative;overflow:hidden;}
.quality-banner:before{content:"";position:absolute;top:0;left:0;width:6px;height:100%;background:var(--grad-primary);}
.quality-banner .qb-text{flex:1;}
.quality-banner h2{margin-bottom:8px;}
.quality-banner .lead{margin-bottom:0;}
.qb-seals{display:flex;justify-content:center;align-items:stretch;gap:24px;margin-top:30px;flex-wrap:wrap;}
.qb-seals .seal-frame{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px 26px;display:flex;align-items:center;justify-content:center;transition:.3s;box-shadow:var(--shadow-sm);}
.qb-seals .seal-frame:hover{border-color:var(--cyan);box-shadow:var(--shadow);transform:translateY(-4px);}
.qb-seals img{height:90px;width:auto;}
.qb-seals .seal-stat{flex-direction:column;background:var(--grad-primary);box-shadow:var(--shadow-cyan);border:none;}
.qb-seals .seal-stat strong{font-size:30px;color:#fff;font-weight:800;line-height:1;}
.qb-seals .seal-stat span{font-size:12px;color:rgba(255,255,255,.85);font-weight:600;text-align:center;margin-top:6px;max-width:120px;}
@media (max-width:700px){.quality-banner{flex-direction:column;text-align:center;}.quality-banner:before{display:none;}}

/* ---------- Extra scroll-reveal variants ---------- */
[data-reveal="left"]{transform:translateX(-44px);}
[data-reveal="left"].in{transform:translateX(0);}
[data-reveal="right"]{transform:translateX(44px);}
[data-reveal="right"].in{transform:translateX(0);}
[data-reveal="zoom"]{transform:scale(.86);}
[data-reveal="zoom"].in{transform:scale(1);}
@media (max-width:900px){[data-reveal="left"],[data-reveal="right"]{transform:translateY(26px);}[data-reveal="left"].in,[data-reveal="right"].in{transform:translateY(0);}}

/* ---------- Upgraded card hover/transition effects: smoother easing,
   bigger lift + slight scale, and an animated top accent bar that sweeps
   in on hover ---------- */
.value-card,.service-card,.testi-card,.blog-card,.team-card{
  position:relative;overflow:hidden;
  transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1),border-color .4s cubic-bezier(.4,0,.2,1);
}
.value-card::before,.service-card::before,.testi-card::before,.blog-card::before,.team-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--grad-primary);transform:scaleX(0);transform-origin:left;
  transition:transform .5s cubic-bezier(.4,0,.2,1);z-index:2;
}
.value-card:hover,.testi-card:hover,.blog-card:hover{transform:translateY(-9px) scale(1.012);box-shadow:var(--shadow-lg);}
.service-card:hover{transform:translateY(-9px) scale(1.012);box-shadow:var(--shadow-lg);border-color:transparent;}
.team-card:hover{transform:translateY(-9px) scale(1.012);box-shadow:0 34px 70px rgba(14,51,63,.2);}
.value-card:hover::before,.service-card:hover::before,.testi-card:hover::before,.blog-card:hover::before,.team-card:hover::before{transform:scaleX(1);}

/* ---------- Shiny sweep effect on solid/gradient CTA buttons ---------- */
.btn-cyan,.btn-pill-hero-call,.btn-pill-hero-wa,.btn-send{position:relative;overflow:hidden;}
.btn-cyan::after,.btn-pill-hero-call::after,.btn-pill-hero-wa::after,.btn-send::after{
  content:'';position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(115deg,transparent,rgba(255,255,255,.65),transparent);
  transform:skewX(-20deg);pointer-events:none;transition:left .75s cubic-bezier(.4,0,.2,1);
}
.btn-cyan:hover::after,.btn-pill-hero-call:hover::after,.btn-pill-hero-wa:hover::after,.btn-send:hover::after{left:140%;}

/* ---------- Footer social icons: enlarge the glyph inside the circle
   without changing the circle/border size itself ---------- */
.social-row a svg.ico-inline{width:19px;height:19px;}

/* =========================================================
   Final responsive pass — icon badges & quality seals
   (placed last so these win the cascade over the base rules
   for .ico-badge / .qb-seals defined earlier in the file)
   ========================================================= */
@media (max-width:700px){
  .qb-seals img{height:74px;}
}
@media (max-width:560px){
  .qb-seals{gap:14px;}
  .qb-seals img{height:58px;}
  .qb-seals .seal-frame{padding:13px 16px;}
  .qb-seals .seal-stat strong{font-size:23px;}
  .qb-seals .seal-stat span{font-size:11px;max-width:100px;}
}
@media (min-width:1600px){
  .qb-seals img{height:100px;}
  .ico-badge{width:80px;height:80px;}
  .service-card .ico-badge{width:72px;height:72px;}
  .qb-icon.ico-badge{width:112px;height:112px;}
}
@media (min-width:2200px){
  .qb-seals img{height:108px;}
  .ico-badge{width:90px;height:90px;}
  .service-card .ico-badge{width:80px;height:80px;}
  .qb-icon.ico-badge{width:124px;height:124px;}
}
@media (min-width:3200px){
  .ico-badge{width:100px;height:100px;}
  .service-card .ico-badge{width:90px;height:90px;}
  .qb-icon.ico-badge{width:138px;height:138px;}
}
